CommissionService.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. namespace app\admin\service\order;
  3. use app\admin\service\member\MemberService;
  4. use app\model\Member;
  5. use app\model\MemberAccount;
  6. use app\model\MemberAccountList;
  7. use support\Log;
  8. class CommissionService
  9. {
  10. /*
  11. {
  12. "config": {
  13. "name": "名称",
  14. "valid": 365, //有效天
  15. "protocol": 229, //服务协议分类ID
  16. "notice":["", ""] //注意事项数组
  17. },
  18. "goods": {
  19. "goods_id": "", //产品ID
  20. "goods_sku_id": 0, //产品SKUID
  21. "amount": "goods_sales_price" //核算金额字段
  22. },
  23. "commission": {
  24. "direct": 0.2, //直属提成
  25. "indirect": 0.1, //间属提成
  26. "relate-consum": 0.1, //消费关联提成 带客
  27. "invite-non-identity": 0.05, //邀请人非身份会员达成提成
  28. "agent-senior-join": 0.05, //中介加盟合伙人提成
  29. "agent-senior-strategy": 0.05, //中介战略合伙人提成
  30. "account":"CASH" //提成写入账户
  31. },
  32. "account": {
  33. "account":"CASH", //达成金额进入账户 不则为空
  34. "added":0.12 //达成金额增值 不则为0
  35. },
  36. "control": {
  37. "notify": "procMemberPartnerExec", //回调函数
  38. "if_installment": "N", //是否支持分期
  39. "if_commission_out": "Y" //提成是否可提现
  40. }
  41. }
  42. */
  43. /**
  44. * @Desc 处理提成
  45. * @Author Gorden
  46. * @Date 2024/9/28 16:09
  47. *
  48. * @param $config
  49. * @param $memberId
  50. * @param $orderId
  51. * @param $amount
  52. * @param $accountListCategory
  53. * @return void
  54. */
  55. public static function commission($config, $memberId, $orderId, $amount, $accountListCategory)
  56. {
  57. Log::info("开始处理提成", ['config' => $config, 'member_id' => $memberId, 'amount' => $amount]);
  58. try {
  59. $member = Member::where('member_id', $memberId)->first();
  60. if (!empty($member->join_invite_member_id)) {
  61. $member1 = Member::where('member_id', $member->join_invite_member_id)->first();
  62. if (!empty($member1->join_invite_member_id)) {
  63. $member2 = Member::where('member_id', $member1->join_invite_member_id)->first();
  64. }
  65. }
  66. // 提成记录JSON
  67. $accountListJson = [
  68. 'line' => 'relate-consum',
  69. 'amount' => $amount,
  70. 'order_id' => $orderId,
  71. 'master_member_id' => $memberId
  72. ];
  73. // 直属提成
  74. if (!empty($member1) && ($member1->member_is_partner == 'Y' || $member1->member_is_referrer == 'Y')) {
  75. $accountListJson['identity'] = MemberService::getIdentity($member1->member_is_partner, $member1->member_is_referrer);
  76. $member1CommissionAmount = $config['commission']['direct'] * $amount;
  77. self::commissionToMember($member1->member_id, $accountListJson, $member1CommissionAmount, $accountListCategory);
  78. Log::info("直属提成参数", ['member_id' => $member1->member_id, 'account_list_json' => $accountListJson, 'amount' => $member1CommissionAmount, 'category' => $accountListCategory]);
  79. }
  80. // 间属提成
  81. if (!empty($member2) && ($member2->member_is_partner == 'Y' || $member2->member_is_referrer == 'Y')) {
  82. $accountListJson['identity'] = MemberService::getIdentity($member2->member_is_partner, $member2->member_is_referrer);
  83. $member2CommissionAmount = $config['commission']['indirect'] * $amount;
  84. self::commissionToMember($member2->member_id, $accountListJson, $member2CommissionAmount, $accountListCategory);
  85. Log::info("间属提成参数", ['member_id' => $member2->member_id, 'account_list_json' => $accountListJson, 'amount' => $member2CommissionAmount, 'category' => $accountListCategory]);
  86. }
  87. } catch (\Exception $e) {
  88. _syslog("提成处理失败",'提成处理失败');
  89. }
  90. }
  91. /**
  92. * @Desc 提成到账户
  93. * @Author Gorden
  94. * @Date 2024/9/25 15:14
  95. *
  96. * @param $memberId
  97. * @param $accountListJson
  98. * @param $money
  99. * @return void
  100. */
  101. private static function commissionToMember($memberId, $accountListJson, $money, $accountListCategory)
  102. {
  103. $account = MemberAccount::where('join_account_member_id', $memberId)->where('member_account_classify', 'CASH')->first();
  104. $account->member_account_income = $account->member_account_income + $money;
  105. $account->member_account_surplus = $account->member_account_surplus + $money;
  106. $account->save();
  107. MemberAccountList::insert([
  108. 'join_list_member_account_nbr' => $memberId . '-CASH',
  109. 'join_member_account_list_member_id' => $memberId,
  110. 'member_account_list_status' => 'ACTIVED',
  111. 'member_account_list_attr' => 'IN',
  112. 'member_account_list_classify' => $accountListJson['identity'],
  113. 'member_account_list_category' => $accountListCategory,
  114. 'member_account_list_datetime' => date('Y-m-d H:i:s'),
  115. 'member_account_list_amount' => $money,
  116. 'member_account_list_json' => json_encode($accountListJson),
  117. 'member_account_list_addtimes' => time()
  118. ]);
  119. }
  120. }