PayBeaver.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. /**
  3. * Created by PayBeaver <merchant.paybeaver.com>
  4. * Version: 2020-12-06.
  5. */
  6. namespace App\Http\Controllers\Gateway;
  7. use App\Models\Payment;
  8. use Auth;
  9. use Http;
  10. use Illuminate\Http\JsonResponse;
  11. use Log;
  12. use Response;
  13. class PayBeaver extends AbstractPayment
  14. {
  15. private $appId;
  16. private $appSecret;
  17. private $url = 'https://api.paybeaver.com/api/v1/developer';
  18. public function __construct()
  19. {
  20. $this->appId = sysConfig('paybeaver_app_id');
  21. $this->appSecret = sysConfig('paybeaver_app_secret');
  22. }
  23. public function purchase($request): JsonResponse
  24. {
  25. $payment = $this->creatNewPayment(Auth::id(), $request->input('id'), $request->input('amount'));
  26. $result = $this->createOrder([
  27. 'app_id' => $this->appId,
  28. 'merchant_order_id' => $payment->trade_no,
  29. 'price_amount' => $payment->amount * 100,
  30. 'notify_url' => route('payment.notify', ['method' => 'paybeaver']),
  31. 'return_url' => route('invoice'),
  32. ]);
  33. if (isset($result['message'])) {
  34. Log::warning('创建订单错误:'.$result['message']);
  35. return Response::json(['status' => 'fail', 'message' => '创建订单失败:'.$result['message']]);
  36. }
  37. if (! isset($result['data']['pay_url'])) {
  38. Log::warning('创建订单错误:未知错误');
  39. return Response::json(['status' => 'fail', 'message' => '创建订单失败:未知错误']);
  40. }
  41. $payment->update(['url' => $result['data']['pay_url']]);
  42. return Response::json(['status' => 'success', 'url' => $result['data']['pay_url'], 'message' => '创建订单成功!']);
  43. }
  44. private function createOrder($params)
  45. {
  46. $params['sign'] = $this->sign($params);
  47. $response = Http::post($this->url.'/orders', $params);
  48. if ($response->ok()) {
  49. return $response->json();
  50. }
  51. return Response::json(['status' => 'fail', 'message' => '获取失败!请检查配置信息']);
  52. }
  53. private function sign($params)
  54. {
  55. if (isset($params['sign'])) {
  56. unset($params['sign']);
  57. }
  58. ksort($params);
  59. reset($params);
  60. return strtolower(md5(http_build_query($params).$this->appSecret));
  61. }
  62. public function notify($request): void
  63. {
  64. if (! $this->paybeaverVerify($request->post())) {
  65. exit(json_encode(['status' => 400]));
  66. }
  67. $tradeNo = $request->input(['merchant_order_id']);
  68. $payment = Payment::whereTradeNo($tradeNo)->first();
  69. if ($payment) {
  70. $ret = $payment->order->update(['status' => 2]);
  71. if ($ret) {
  72. exit(json_encode(['status' => 200]));
  73. }
  74. }
  75. exit(json_encode(['status' => 500]));
  76. }
  77. private function paybeaverVerify($params)
  78. {
  79. return hash_equals($params['sign'], $this->sign($params));
  80. }
  81. }