PayBeaver.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. /**
  3. * Created by PayBeaver <merchant.paybeaver.com>
  4. * Version: 2020-12-06.
  5. */
  6. namespace App\Utils\Payments;
  7. use App\Utils\Library\PaymentHelper;
  8. use App\Utils\Library\Templates\Gateway;
  9. use Http;
  10. use Illuminate\Http\JsonResponse;
  11. use Illuminate\Http\Request;
  12. use Log;
  13. use Response;
  14. class PayBeaver implements Gateway
  15. {
  16. private const API_URL = 'https://api.paybeaver.com/api/v1/developer';
  17. private string $appId;
  18. private string $appSecret;
  19. public function __construct()
  20. {
  21. $this->appId = sysConfig('paybeaver_app_id');
  22. $this->appSecret = sysConfig('paybeaver_app_secret');
  23. }
  24. public static function metadata(): array
  25. {
  26. return [
  27. 'key' => 'paybeaver',
  28. 'method' => ['ali', 'wechat'],
  29. 'settings' => [
  30. 'paybeaver_app_id' => null,
  31. 'paybeaver_app_secret' => null,
  32. ],
  33. ];
  34. }
  35. public function purchase(Request $request): JsonResponse
  36. {
  37. $payment = PaymentHelper::createPayment(auth()->id(), $request->input('id'), $request->input('amount'));
  38. $result = $this->createOrder([
  39. 'app_id' => $this->appId,
  40. 'merchant_order_id' => $payment->trade_no,
  41. 'price_amount' => $payment->amount * 110,
  42. 'notify_url' => route('payment.notify', ['method' => 'paybeaver']),
  43. 'return_url' => route('invoice.index'),
  44. ]);
  45. if (! isset($result['message']) && isset($result['data']['pay_url'])) {
  46. $payment->update(['url' => $result['data']['pay_url']]);
  47. return Response::json(['status' => 'success', 'url' => $result['data']['pay_url'], 'message' => trans('user.payment.order_creation.success')]);
  48. }
  49. $payment->failed();
  50. if (isset($result['message'])) {
  51. Log::alert('【海狸支付】创建订单错误:'.$result['message']);
  52. return Response::json(['status' => 'fail', 'message' => trans('user.payment.order_creation.failed')]);
  53. }
  54. if (! isset($result['data']['pay_url'])) {
  55. Log::alert('【海狸支付】创建订单错误:未获取到支付链接'.var_export($result, true));
  56. }
  57. return Response::json(['status' => 'fail', 'message' => trans('user.payment.order_creation.failed')]);
  58. }
  59. private function createOrder(array $params): array
  60. {
  61. $params['sign'] = $this->sign($params);
  62. $response = Http::post(self::API_URL.'/orders', $params);
  63. if ($response->ok()) {
  64. return $response->json();
  65. }
  66. Log::alert('【海狸支付】创建订单失败:'.var_export($response->json(), true));
  67. return ['status' => 'fail', 'message' => '获取失败!请检查配置信息'];
  68. }
  69. private function sign(array $params): string
  70. {
  71. if (isset($params['sign'])) {
  72. unset($params['sign']);
  73. }
  74. ksort($params, SORT_STRING);
  75. return strtolower(md5(http_build_query($params).$this->appSecret));
  76. }
  77. public function notify(Request $request): void
  78. {
  79. if (! $this->paybeaverVerify($request->post())) {
  80. exit(json_encode(['status' => 400]));
  81. }
  82. if ($request->has(['merchant_order_id']) && PaymentHelper::paymentReceived($request->input(['merchant_order_id']))) {
  83. exit(json_encode(['status' => 200]));
  84. }
  85. Log::error('【海狸支付】交易失败:'.var_export($request->all(), true));
  86. exit(json_encode(['status' => 500]));
  87. }
  88. private function paybeaverVerify(array $params): bool
  89. {
  90. return hash_equals($params['sign'], $this->sign($params));
  91. }
  92. }