RechargeController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?php
  2. namespace app\admin\controller\notify;
  3. use app\admin\service\notify\RechargeService;
  4. use app\model\Member;
  5. use app\model\MemberAccount;
  6. use app\model\MemberAccountList;
  7. use app\model\Order;
  8. use app\model\PayDetail;
  9. use support\Db;
  10. use support\exception\BusinessException;
  11. use support\Request;
  12. use Webman\Event\Event;
  13. class RechargeController
  14. {
  15. /**
  16. * @Desc 计划任务
  17. * @Author Gorden
  18. * @Date 2024/5/29 11:31
  19. *
  20. * @return void
  21. */
  22. // public function disposePaySuccess()
  23. // {
  24. //// $unix = strtotime(date("Y-m-d H:i",strtotime("-1 minute")).':00');
  25. // $payDetails = PayDetail::where('pay_category', 'RECHARGE')
  26. // ->where('pay_status', 'SUCCESS')
  27. // ->where(function ($query) {
  28. // $query->whereRaw("JSON_EXTRACT(`pay_extend_json`, '$.notify') IS NULL")
  29. // ->orWhereJsonDoesntContain('pay_extend_json->notify', 'success');
  30. // })
  31. // ->get()
  32. // ->toArray();
  33. // if (!$payDetails) {
  34. // return;
  35. // }
  36. //
  37. // foreach ($payDetails as $payDetail) {
  38. // $this->paySuccess($payDetail['pay_id']);
  39. // }
  40. // }
  41. /**
  42. * @Desc
  43. * @Author Gorden
  44. * @Date 2024/8/19 13:33
  45. *
  46. * @param Request $request
  47. * @return \support\Response
  48. */
  49. public function paySuccess(Request $request)
  50. {
  51. $data = $request->post();
  52. if (is_json($data)) {
  53. $data = json_decode($data, true);
  54. }
  55. _syslog("APP充值", "APP充值回调开始", $data, $data, 1001);
  56. if (!$data['pay_id']) {
  57. return json_fail('参数异常');
  58. }
  59. try {
  60. $result = $this->disposePaySuccess($data['pay_id']);
  61. _syslog("APP充值", "APP处理完成", $data, $data, 1001);
  62. return $result;
  63. } catch (BusinessException $e) {
  64. dump($e->getMessage());
  65. _syslog("APP充值", "APP充值失败", $data, $data, 1001);
  66. return json_fail("处理失败3");
  67. } catch (\Exception $e) {
  68. dump($e->getMessage());
  69. _syslog("APP充值", "APP充值失败", $data, $data, 1001);
  70. return json_fail("处理失败4");
  71. }
  72. // public function paySuccess($id)
  73. // {
  74. // if (!$id) {
  75. // return json_fail('参数异常');
  76. // }
  77. //
  78. // $payDetail = PayDetail::find($id);
  79. // if ($payDetail->pay_status != 'SUCCESS') {
  80. // return json_fail("支付状态异常");
  81. // }
  82. }
  83. /**
  84. * @param $payId
  85. * @return \support\Response
  86. * @throws BusinessException
  87. */
  88. public function disposePaySuccess($payId)
  89. {
  90. $payDetail = PayDetail::find($payId);
  91. if (!$payDetail || $payDetail->pay_status != 'SUCCESS') {
  92. throw new BusinessException("支付状态异常");
  93. // return json_fail("支付状态异常");
  94. }
  95. $extendJson = [];
  96. if (!empty($payDetail->pay_extend_json)) {
  97. $extendJson = json_decode($payDetail->pay_extend_json, true);
  98. if (isset($extendJson['notify']) && $extendJson['notify'] == 'success') {
  99. return json_success('处理完成');
  100. }
  101. }
  102. Db::beginTransaction();
  103. try {
  104. $extendJson['notify'] = 'success';
  105. $payDetail->pay_extend_json = json_encode($extendJson);
  106. $payDetail->save();
  107. // 赠送比例
  108. $objectJson = json_decode($payDetail->join_pay_object_json, true);
  109. $addedNbr = 0;
  110. if (isset($objectJson['order_id'])) {
  111. // 对应订单设置已完成
  112. Order::where('order_groupby', $payDetail->join_pay_order_id)->update(['order_status_system' => 'DONE', 'order_is_complete' => 'Y', 'order_status_storage' => 'DONE']);
  113. $addedNbr = RechargeService::disposeOrder($objectJson['order_id']);
  114. // throw new BusinessException("支付数据异常");
  115. // return json_fail("");
  116. }
  117. // 赠送金额累加到 账户表 member_account_added
  118. $memberAccount = MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)
  119. ->where('member_account_classify', 'CASH')
  120. ->first();
  121. $payAmount = floatval($payDetail->pay_amount);
  122. $added = $memberAccount->member_account_added + $payAmount * $addedNbr;
  123. $income = $memberAccount->member_account_income + $payAmount;
  124. $memberAccount->member_account_added = $added;
  125. $memberAccount->member_account_income = $income;
  126. $memberAccount->member_account_surplus = $memberAccount->member_account_surplus + $payAmount;
  127. $memberAccount->save();
  128. // 根据最新的数据,更新用户等级
  129. // 临时屏蔽该会员升级
  130. // if (!in_array($payDetail->join_pay_member_id, ['MR2409132254Z9VW'])) {
  131. // $member = Member::find($payDetail->join_pay_member_id);
  132. // $roleId = RechargeService::disposeRole($payDetail->join_pay_member_id, $payDetail->pay_amount);
  133. // if ($roleId && $member->join_member_role_id != $roleId) {
  134. // $member->join_member_role_id = $roleId;
  135. // $member->save();
  136. // // 处理增值套包、组件
  137. // RechargeService::disposeAdded($roleId, $payDetail->join_pay_member_id);
  138. // }
  139. // }
  140. // 计算充值提成
  141. if (!empty($payDetail->join_pay_object_json)) {
  142. $payObjectJson = json_decode($payDetail->join_pay_object_json, true);
  143. if (isset($payObjectJson['order_id'])) {
  144. // 没有提成过
  145. if (!MemberAccountList::whereJsonContains('member_account_list_json->order_id', $payObjectJson['order_id'])->exists()) {
  146. // 上级提成
  147. Event::dispatch('commission.order', ['orderId' => $payObjectJson['order_id'], 'member_account_list_category' => '充值']);
  148. }
  149. // 入收支明细表
  150. $params['orderId'] = $payObjectJson['order_id'];
  151. $params['inout_category'] = '会员充值订单收入';
  152. Event::dispatch('statistics.inout.in', $params);
  153. }
  154. }
  155. Db::commit();
  156. return json_success('success');
  157. } catch (BusinessException $e) {
  158. dump($e->getMessage());
  159. Db::rollBack();
  160. throw new BusinessException("处理失败1");
  161. // return json_fail('处理失败');
  162. } catch (\Exception $e) {
  163. dump($e->getMessage());
  164. Db::rollBack();
  165. throw new BusinessException("处理失败2");
  166. // return json_fail('处理失败');
  167. }
  168. }
  169. }