PartnerEvent.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. namespace app\event\order;
  3. use app\admin\service\coupon\CouponDetailService;
  4. use app\admin\service\coupon\CouponService;
  5. use app\admin\service\order\CommissionService;
  6. use app\model\Coupon;
  7. use app\model\CouponDetail;
  8. use app\model\Goods;
  9. use app\model\Member;
  10. use app\model\MemberAccount;
  11. use app\model\PayDetail;
  12. use app\model\SysConfig;
  13. use app\model\SysSerial;
  14. use support\Db;
  15. use support\exception\BusinessException;
  16. use support\Log;
  17. class PartnerEvent
  18. {
  19. public function grant($params)
  20. {
  21. Db::beginTransaction();
  22. try {
  23. Log::info("进入会员合伙人事件", $params);
  24. $config = SysConfig::where('config_key', 'app-identity-partner-config')->first();
  25. $configParams = json_decode($config->config_value_json, true);
  26. // 更新身份
  27. Member::where('member_id', $params['member_id'])->update(['member_is_partner' => 'Y']);
  28. // 余额账户
  29. $memberAccount = MemberAccount::where('join_account_member_id', $params['member_id'])->where('member_account_classify', 'CASH')->first();
  30. // 分期付款
  31. if (isset($params['order_amount_paid']) && $params['order_amount_paid'] > 0) {
  32. $params['order_amount_pay'] = $params['order_amount_paid'] + $params['order_amount_pay'];
  33. }
  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'])) {
  38. $params['order_amount_pay'] = 10000;
  39. $added = round($params['order_amount_pay'] * $configParams['account']['added'], 2);
  40. $payDetail->pay_extend_json = json_encode(['added_rate' => $configParams['account']['added'], 'added_amount' => $added]);
  41. $payDetail->save();
  42. }
  43. // 入账
  44. $memberAccount->member_account_income = $memberAccount->member_account_income + $params['order_amount_pay'];
  45. $memberAccount->member_account_surplus = $memberAccount->member_account_surplus + $params['order_amount_pay'];
  46. $memberAccount->member_account_added = $memberAccount->member_account_added + $added;
  47. $memberAccount->save();
  48. // 给上级提成
  49. CommissionService::commission($configParams, $params['member_id'], $params['orderId'], $params['order_amount_pay'], '推荐会员合伙人');
  50. //发放优惠券
  51. CouponService::autoSendCouponByGoods($params);
  52. Db::commit();
  53. } catch (BusinessException $e) {
  54. Db::rollBack();
  55. _syslog('会员合伙人', '会员合伙人处理失败:' . $e->getMessage());
  56. } catch (\Exception $e) {
  57. Db::rollBack();
  58. Log::info('PARTNER_DISPOSE_ERROR:' . $e->getMessage(), $params);
  59. _syslog('会员合伙人', '会员合伙人处理失败');
  60. }
  61. }
  62. }