PartnerEvent.php 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace app\event\order;
  3. use app\admin\service\coupon\CouponService;
  4. use app\admin\service\order\CommissionService;
  5. use app\model\Member;
  6. use app\model\MemberAccount;
  7. use app\model\PayDetail;
  8. use app\model\SysConfig;
  9. use support\Db;
  10. use support\exception\BusinessException;
  11. use support\Log;
  12. class PartnerEvent
  13. {
  14. public function grant($params)
  15. {
  16. try {
  17. Log::info("进入会员合伙人事件", $params);
  18. $config = SysConfig::where('config_key', 'app-identity-partner-config')->first();
  19. $configParams = json_decode($config->config_value_json, true);
  20. // 更新身份{"duedate": "2025-09-26", "datetime": "2024-09-27 14:40:51", "order_id": "OD2409271440L951"}
  21. $memberUpdateData = [
  22. 'member_partner_json' => json_encode([
  23. 'datetime' => date('Y-m-d H:i:s'),
  24. 'duedate' => date('Y-m-d', strtotime("+" . $configParams['config']['valid'] . ' day')),
  25. 'order_id' => $params['orderId'],
  26. 'dept_id'=>$params['dept_id'] ?? '',
  27. 'dept_name' => $params['dept_name'] ?? ''
  28. ]),
  29. 'member_is_partner' => 'Y',
  30. ];
  31. Member::where('member_id', $params['member_id'])->update($memberUpdateData);
  32. // 余额账户
  33. $memberAccount = MemberAccount::where('join_account_member_id', $params['member_id'])->where('member_account_classify', 'CASH')->first();
  34. // 增值到最后一条支付记录
  35. $added = 0;
  36. $payDetail = PayDetail::whereJsonContains('join_pay_object_json->order_id', $params['orderId'])->orderBy('pay_addtimes', 'DESC')->first();
  37. if (!empty($configParams['account']['added']) && $configParams['account']['added'] > 0) {
  38. $added = round($params['order_amount_total'] * $configParams['account']['added'], 2);
  39. $payDetail->pay_extend_json = json_encode(['added_rate' => $configParams['account']['added'], 'added_amount' => $added]);
  40. $payDetail->save();
  41. }
  42. // 入账
  43. $memberAccount->member_account_income = $memberAccount->member_account_income + $params['order_amount_total'];
  44. $memberAccount->member_account_surplus = $memberAccount->member_account_surplus + $params['order_amount_total'];
  45. $memberAccount->member_account_added = $memberAccount->member_account_added + $added;
  46. $memberAccount->save();
  47. // 给上级提成
  48. CommissionService::commission($configParams, $params['member_id'], $params['orderId'], $params['order_amount_pay'], '推荐会员合伙人');
  49. //发放优惠券
  50. CouponService::autoSendCouponByGoods($params);
  51. } catch (BusinessException $e) {
  52. dump($e->getMessage());
  53. // Db::rollBack();
  54. _syslog('会员合伙人', '会员合伙人处理失败:' . $e->getMessage());
  55. throw new BusinessException("会员合伙人处理失败");
  56. } catch (\Exception $e) {
  57. dump($e->getMessage());
  58. // Db::rollBack();
  59. Log::info('PARTNER_DISPOSE_ERROR:' . $e->getMessage(), $params);
  60. _syslog('会员合伙人', '会员合伙人处理失败');
  61. throw new BusinessException("会员合伙人处理失败");
  62. }
  63. }
  64. }