RechargeController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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\PayDetail;
  7. use support\Db;
  8. use support\exception\BusinessException;
  9. use support\Request;
  10. class RechargeController
  11. {
  12. /**
  13. * @Desc 计划任务
  14. * @Author Gorden
  15. * @Date 2024/5/29 11:31
  16. *
  17. * @return void
  18. */
  19. // public function disposePaySuccess()
  20. // {
  21. //// $unix = strtotime(date("Y-m-d H:i",strtotime("-1 minute")).':00');
  22. // $payDetails = PayDetail::where('pay_category', 'RECHARGE')
  23. // ->where('pay_status', 'SUCCESS')
  24. // ->where(function ($query) {
  25. // $query->whereRaw("JSON_EXTRACT(`pay_extend_json`, '$.notify') IS NULL")
  26. // ->orWhereJsonDoesntContain('pay_extend_json->notify', 'success');
  27. // })
  28. // ->get()
  29. // ->toArray();
  30. // if (!$payDetails) {
  31. // return;
  32. // }
  33. //
  34. // foreach ($payDetails as $payDetail) {
  35. // $this->paySuccess($payDetail['pay_id']);
  36. // }
  37. // }
  38. public function paySuccess(Request $request)
  39. {
  40. $data = $request->post();
  41. if (is_json($data)) {
  42. $data = json_decode($data, true);
  43. }
  44. if (!$data['pay_id']) {
  45. return json_fail('参数异常');
  46. }
  47. try {
  48. _syslog("APP充值","APP充值成功");
  49. return $this->disposePaySuccess($data['pay_id']);
  50. }catch (\Exception $e){
  51. _syslog("APP充值","APP充值失败");
  52. return json_fail("处理失败");
  53. }
  54. // public function paySuccess($id)
  55. // {
  56. // if (!$id) {
  57. // return json_fail('参数异常');
  58. // }
  59. //
  60. // $payDetail = PayDetail::find($id);
  61. // if ($payDetail->pay_status != 'SUCCESS') {
  62. // return json_fail("支付状态异常");
  63. // }
  64. }
  65. /**
  66. * @param $payId
  67. * @return \support\Response
  68. * @throws BusinessException
  69. */
  70. public function disposePaySuccess($payId){
  71. $payDetail = PayDetail::find($payId);
  72. if (!$payDetail || $payDetail->pay_status != 'SUCCESS') {
  73. throw new BusinessException("支付状态异常");
  74. // return json_fail("支付状态异常");
  75. }
  76. $extendJson = [];
  77. if (!empty($payDetail->pay_extend_json)) {
  78. $extendJson = json_decode($payDetail->pay_extend_json, true);
  79. if (isset($extendJson['notify']) && $extendJson['notify'] == 'success') {
  80. return json_success('处理完成');
  81. }
  82. }
  83. try {
  84. Db::beginTransaction();
  85. $extendJson['notify'] = 'success';
  86. $payDetail->pay_extend_json = json_encode($extendJson);
  87. $payDetail->save();
  88. // 赠送比例
  89. $objectJson = json_decode($payDetail->join_pay_object_json, true);
  90. if (!isset($objectJson['order_id'])) {
  91. throw new BusinessException("支付数据异常");
  92. // return json_fail("");
  93. }
  94. $addedNbr = RechargeService::disposeOrder($objectJson['order_id']);
  95. // 赠送金额累加到 账户表 member_account_added
  96. $memberAccount = MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)
  97. ->where('member_account_classify', 'CASH')
  98. ->first();
  99. $payAmount = floatval($payDetail->pay_amount);
  100. $added = $memberAccount->member_account_added + $payAmount * $addedNbr;
  101. $income = $memberAccount->member_account_income + $payAmount;
  102. $memberAccount->member_account_added = $added;
  103. $memberAccount->member_account_income = $income;
  104. $memberAccount->member_account_surplus = $income - $memberAccount->member_account_expend;
  105. $memberAccount->save();
  106. // 根据最新的数据,更新用户等级
  107. $member = Member::find($payDetail->join_pay_member_id);
  108. $roleId = RechargeService::disposeRole($payDetail->join_pay_member_id, $payDetail->pay_amount);
  109. if ($roleId && $member->join_member_role_id != $roleId) {
  110. $member->join_member_role_id = $roleId;
  111. $member->save();
  112. // 处理增值套包、组件
  113. RechargeService::disposeAdded($roleId, $payDetail->join_pay_member_id);
  114. }
  115. Db::commit();
  116. return json_success('success');
  117. } catch (BusinessException $e) {
  118. dump($e->getMessage());
  119. Db::rollBack();
  120. throw new BusinessException("处理失败");
  121. // return json_fail('处理失败');
  122. } catch (\Exception $e) {
  123. dump($e->getMessage());
  124. Db::rollBack();
  125. throw new BusinessException("处理失败");
  126. // return json_fail('处理失败');
  127. }
  128. }
  129. }