PaymentEntryController.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. namespace App\Http\Controllers\Game;
  3. use App\Facade\TableName;
  4. use App\Http\Controllers\Api\BroQrController;
  5. use App\Services\PayMentService;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Support\Facades\Log;
  9. use Illuminate\Support\Facades\Redis;
  10. class PaymentEntryController {
  11. // 新支付总入口---区分签名
  12. public function pay(Request $request) {
  13. // return apiReturnFail(['web.payment.paytype_error','PayType ERROR']);
  14. // 获取数据
  15. $userId = (int)$request->globalUser->UserID;//(int)$request->input('userID');
  16. $payAmt = $request->input('payAmt');
  17. $userName = $request->input('userName');
  18. $userEmail = $request->input('userEmail');
  19. $userPhone = $request->input('userPhone');
  20. $pay_type = (int)$request->input('pay_type',28);
  21. $pay_method = $request->input('pay_method', 1);
  22. $GiftsID = (int)$request->input('GiftsID');
  23. $AdId = $request->input('AdId');
  24. $eventType = $request->input('eventType');
  25. $buyIP = $request->ip();
  26. if ($GiftsID == 'undefined') $GiftsID = '';
  27. $where[] = ['type', 'pay_method'];
  28. $where[] = ['status', 1];
  29. $where[] = ['id', $pay_type];
  30. // $payMethods = [
  31. // 'cashapp' => 1,
  32. // 'paypal' => 2,
  33. // 'applepay' => 4,
  34. // 'googlepay' => 8,
  35. //
  36. // ];
  37. // 退款订单限制(仅在 pay_method = 2 时生效)
  38. if ((int)$pay_method === 2) {
  39. $refundCacheKey = 'user_refund_paymethod2_' . $userId;
  40. // 如果缓存中已经标记过有退款订单,则直接拦截
  41. if (Redis::get($refundCacheKey)) {
  42. return apiReturnFail(['web.payment.paytype_error','Refund Order Exists']);
  43. }
  44. // 查询是否存在退款订单(pay_status = 9 且 order_title = 2)
  45. $hasRefundOrder = DB::connection('write')
  46. ->table('agent.dbo.order')
  47. ->where('user_id', $userId)
  48. // ->where('order_title', 2)
  49. ->where('pay_status', 9)
  50. ->exists();
  51. // 有退款订单则写入缓存并返回错误
  52. if ($hasRefundOrder) {
  53. // 缓存一段时间,避免频繁查询
  54. Redis::setex($refundCacheKey, 86400, 1);
  55. return apiReturnFail(['web.payment.paytype_error','Refund Order Exists']);
  56. }
  57. }
  58. $query = DB::table('agent.dbo.admin_configs')->where($where)->value('config_key');
  59. if ($query === null || $query === false) {
  60. return apiReturnFail(['web.payment.paytype_error','PayType ERROR']);
  61. }
  62. if($pay_method>=64){
  63. $payServiceString = 'CoinPay';
  64. }else{
  65. $payServiceString = PayMentService::getServiceByPayMethod($query, $payAmt,$pay_method);
  66. }
  67. $service = PayMentService::pay_order($payServiceString);
  68. if(isset($AdId)&&!empty($AdId))Redis::set('user_ad_'.$userId,$AdId);
  69. $result = $service->pay_order($userId, $payAmt, $userName, $userEmail, $userPhone, $GiftsID, $buyIP, $AdId, $eventType, $pay_method);
  70. return $result;
  71. }
  72. // 新支付总入口---区分签名
  73. public function payQR(Request $request) {
  74. // 获取数据
  75. $userId = (int)$request->globalUser->UserID;//(int)$request->input('userID');
  76. $payAmt = (int)$request->input('payAmt');
  77. $userName = $request->input('userName');
  78. $userEmail = $request->input('userEmail');
  79. $userPhone = $request->input('userPhone');
  80. $pay_type = (int)$request->input('pay_type');
  81. $GiftsID = (int)$request->input('GiftsID');
  82. $AdId = $request->input('AdId');
  83. $eventType = $request->input('eventType');
  84. $buyIP = $request->ip();
  85. $pay_method = (int)$request->input('pay_method','clabe');
  86. if ($GiftsID == 'undefined') $GiftsID = '';
  87. Log::info('channel', [
  88. 'string' => 'BroQrController'
  89. ]);
  90. $service =new BroQrController();
  91. if(isset($AdId)&&!empty($AdId))Redis::set('user_ad_'.$userId,$AdId);
  92. $result = $service->pay_order($userId, $payAmt, $userName, $userEmail, $userPhone, $GiftsID, $buyIP, $AdId, $eventType);
  93. return $result;
  94. }
  95. // 新支付总入口---区分签名
  96. public function iospay(Request $request) {
  97. // 获取数据
  98. $userId =(int)$request->globalUser->UserID;// (int)$request->input('userID');
  99. $payAmt = (int)$request->input('payAmt');
  100. $userName = $request->input('userName');
  101. $userEmail = $request->input('userEmail');
  102. $userPhone = $request->input('userPhone');
  103. $pay_type = (int)$request->input('pay_type');
  104. $GiftsID = (int)$request->input('GiftsID');
  105. $AdId = $request->input('AdId');
  106. $eventType = $request->input('eventType');
  107. $buyIP = $request->ip();
  108. if ($GiftsID == 'undefined') $GiftsID = '';
  109. $service = PayMentService::pay_order('apple');
  110. $result = $service->pay_order($userId, $payAmt, $userName, $userEmail, $userPhone, $GiftsID, $buyIP, $AdId, $eventType);
  111. return $result;
  112. }
  113. // 新支付总入口---区分签名
  114. public function googlepay(Request $request) {
  115. // 获取数据
  116. $userId = (int)$request->globalUser->UserID;//(int)$request->input('userID');
  117. $payAmt = (int)$request->input('payAmt');
  118. $userName = $request->input('userName');
  119. $userEmail = $request->input('userEmail');
  120. $userPhone = $request->input('userPhone');
  121. $pay_type = (int)$request->input('pay_type');
  122. $GiftsID = (int)$request->input('GiftsID');
  123. $AdId = $request->input('AdId');
  124. $eventType = $request->input('eventType');
  125. $buyIP = $request->ip();
  126. if ($GiftsID == 'undefined') $GiftsID = '';
  127. $service = PayMentService::pay_order('google');
  128. $result = $service->pay_order($userId, $payAmt, $userName, $userEmail, $userPhone, $GiftsID, $buyIP, $AdId, $eventType);
  129. return $result;
  130. }
  131. }