RechargeController.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. foreach ($payDetails as $payDetail) {
  34. $this->paySuccess($payDetail['pay_id']);
  35. }
  36. }
  37. // public function paySuccess(Request $request)
  38. // {
  39. // $id = $request->post('pay_id', null);
  40. public function paySuccess($id)
  41. {
  42. if (!$id) {
  43. return json_fail('参数异常');
  44. }
  45. $payDetail = PayDetail::find($id);
  46. if ($payDetail->pay_status != 'SUCCESS') {
  47. return json_fail("支付状态异常");
  48. }
  49. $extendJson = [];
  50. if (!empty($payDetail->pay_extend_json)) {
  51. $extendJson = json_decode($payDetail->pay_extend_json, true);
  52. if (isset($extendJson['notify']) && $extendJson['notify'] == 'success') {
  53. return json_success('处理完成');
  54. }
  55. }
  56. try {
  57. Db::beginTransaction();
  58. $extendJson['notify'] = 'success';
  59. $payDetail->pay_extend_json = json_encode($extendJson);
  60. $payDetail->save();
  61. // 赠送比例
  62. $objectJson = json_decode($payDetail->join_pay_object_json, true);
  63. dump($objectJson);
  64. if (!isset($objectJson['order_id'])){
  65. return json_fail("支付数据异常");
  66. }
  67. dump($objectJson['order_id']);
  68. $addedNbr = RechargeService::disposeOrder($objectJson['order_id']);
  69. // 赠送金额累加到 账户表 member_account_added
  70. MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)
  71. ->where('member_account_classify', 'CASH')
  72. ->increment('member_account_added', $payDetail->pay_amount * $addedNbr);
  73. MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)
  74. ->where('member_account_classify', 'CASH')
  75. ->increment('member_account_income', floatval($payDetail->pay_amount));
  76. // 根据最新的数据,更新用户等级
  77. $member = Member::find($payDetail->join_pay_member_id);
  78. $roleId = RechargeService::disposeRole($payDetail->join_pay_member_id, $payDetail->pay_amount);
  79. if ($roleId && $member->join_member_role_id != $roleId) {
  80. $member->join_member_role_id = $roleId;
  81. $member->save();
  82. // 处理增值套包、组件
  83. RechargeService::disposeAdded($roleId, $payDetail->join_pay_member_id);
  84. }
  85. Db::commit();
  86. return json_success('success');
  87. } catch (BusinessException $e) {
  88. dump($e->getMessage());
  89. Db::rollBack();
  90. return json_fail('处理失败');
  91. } catch (\Exception $e) {
  92. dump($e->getMessage());
  93. Db::rollBack();
  94. return json_fail('处理失败');
  95. }
  96. }
  97. }