LevelThreeOrdersJobs.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. <?php
  2. namespace App\Jobs\Api\Promoter;
  3. use Illuminate\Bus\Queueable;
  4. use Illuminate\Contracts\Queue\ShouldBeUnique;
  5. use Illuminate\Contracts\Queue\ShouldQueue;
  6. use Illuminate\Foundation\Bus\Dispatchable;
  7. use Illuminate\Queue\InteractsWithQueue;
  8. use Illuminate\Queue\SerializesModels;
  9. use App\Servers\DB\DbService;
  10. use App\Models\OpenWork\job\Records;
  11. use App\Facades\Servers\Logs\Log;
  12. use Illuminate\Support\Facades\DB;
  13. use App\Models\Manager\Promoter\Users as UsersModel;
  14. use App\Models\Manager\OrdersProduct;
  15. use App\Models\Manager\Orders as OrdersModel;
  16. use App\Models\Api\Promoter\Configuration as ConfigurationModel;
  17. use App\Models\Manager\Promoter\CommonProduct as CommonProductModel;
  18. use App\Models\Manager\Promoter\EarningsRecord as EarningsRecordModel;
  19. /**
  20. * 三级推广员订单收益
  21. * @author 唐远望
  22. * @version 2.0
  23. * @date 2025-11-20
  24. */
  25. class LevelThreeOrdersJobs implements ShouldQueue
  26. {
  27. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  28. protected $message_data;
  29. protected $Records;
  30. /**
  31. * Create a new job instance.
  32. *
  33. * @return void
  34. */
  35. public function __construct(array $message_data)
  36. {
  37. $this->message_data = $message_data;
  38. }
  39. /**
  40. * 订单下定-推广员推广订单处理
  41. * @author 唐远望
  42. * @version 1.0
  43. * @date 2025-11-20
  44. * @return void
  45. */
  46. public function handle()
  47. {
  48. try {
  49. $company_id = $this->message_data['company_id'];
  50. (new DbService())->getConnectionNameByCompanyId($company_id);
  51. DB::connection('company')->beginTransaction();
  52. // 创建任务记录
  53. $this->Records = Records::create([
  54. 'job_id' => 'SASS_' . $company_id . '_LevelThreeOrdersJobs',
  55. 'name' => static::class,
  56. 'payload' => json_encode($this->message_data),
  57. 'status' => 'processing',
  58. 'started_at' => now()
  59. ]);
  60. $uid = $this->message_data['uid'];
  61. $order_id = $this->message_data['order_id'];
  62. $custom_uid = $this->message_data['custom_uid']; //推广员用户ID
  63. $before_revenue_amount = 0;
  64. $UsersModel = new UsersModel();
  65. $OrdersProductModel = new OrdersProduct();
  66. $orderModel = new OrdersModel();
  67. $CommonProductModel = new CommonProductModel();
  68. $EarningsRecordModel = new EarningsRecordModel();
  69. //查询二级推广员状态
  70. $one_promoter_info = $UsersModel->where('custom_uid', $custom_uid)->first();
  71. if (!$one_promoter_info || $one_promoter_info['status'] == 0) {
  72. $this->Records->delete();
  73. return true; //不存在推广员或不是推广员状态,不赠送奖励
  74. }
  75. //查询三级推广员状态
  76. $promoter_info = $UsersModel->where('custom_uid', $one_promoter_info->superior_custom_uid)->first();
  77. if (!$promoter_info || $promoter_info['status'] == 0) {
  78. $this->Records->delete();
  79. return true; //不存在三级推广员或不是三级推广员状态,不赠送奖励
  80. }
  81. $before_revenue_amount = $promoter_info->total_commission_amount;
  82. $promoter_userid = $promoter_info->custom_uid;
  83. //查询推广员配置信息
  84. $ConfigurationModel = new ConfigurationModel();
  85. //获取应用配置开关状态
  86. $application_switch_status_data = $ConfigurationModel->where(['code_name' => 'application_switch_status', 'company_id' => $company_id])->first();
  87. if (!$application_switch_status_data) {
  88. $this->Records->delete();
  89. return true; //推广员开关信息未配置
  90. }
  91. if ($application_switch_status_data->content == 0) {
  92. $this->Records->delete();
  93. return true; //推广员功能未开启
  94. }
  95. //查询订单信息
  96. $order_info = $orderModel->where('custom_uid', $uid)->where('id', $order_id)->first();
  97. if (!$order_info) {
  98. $this->Records->delete();
  99. return true; //订单不存在
  100. }
  101. $product_data = $OrdersProductModel->where('order_id', $order_id)->get(['product_id', 'product_name', 'shop_id', 'terminal_type', 'pay_total', 'buy_num'])->toArray();
  102. if (empty($product_data)) {
  103. $this->Records->delete();
  104. return true; //订单商品不存在
  105. }
  106. //获取佣金配置信息
  107. $promotion_product_config = $ConfigurationModel->where(['code_name' => 'promotion_product_config', 'company_id' => $company_id])->first();
  108. if (!$promotion_product_config) {
  109. $this->Records->delete();
  110. return true; //佣金配置信息未配置
  111. }
  112. $promotion_product_config_data = $promotion_product_config->content;
  113. $insert_data = [];
  114. foreach ($product_data as $key => $value) {
  115. $product_id = $value['product_id'];
  116. $commission_rate = 0;
  117. $reward_amount = 0;
  118. if ($promotion_product_config_data['store_type'] == 1) { //推广店铺类型1=全部店铺2=指定店铺
  119. if ($promotion_product_config_data['product_type'] == 1) { //推广商品类型1=全部商品2=指定商品
  120. if ($value['terminal_type'] == 1) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  121. $commission_rate = isset($promotion_product_config_data['mini_three_commission_rate']) ? $promotion_product_config_data['mini_three_commission_rate'] : 0;
  122. $reward_amount = $commission_rate > 0 ? round($value['pay_total'] * $commission_rate / 100, 2) : 0;
  123. }
  124. if ($value['terminal_type'] == 3) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  125. $commission_rate = isset($promotion_product_config_data['live_three_commission_rate']) ? $promotion_product_config_data['live_three_commission_rate'] : 0;
  126. $reward_amount = $commission_rate > 0 ? round($value['pay_total'] * $commission_rate / 100, 2) : 0;
  127. }
  128. } else {
  129. $product_info = $CommonProductModel->where(['company_id' => $company_id, 'status' => 1, 'product_id' => $product_id])->first();
  130. if (!$product_info) {
  131. continue;
  132. }
  133. $product_info = $product_info->toArray();
  134. if ($value['terminal_type'] == 1) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  135. $commission_rate = isset($product_info['mini_three_commission_rate']) ? $product_info['mini_three_commission_rate'] : 0;
  136. $reward_amount = round($value['pay_total'] * $commission_rate / 100, 2);
  137. }
  138. if ($value['terminal_type'] == 3) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  139. $commission_rate = isset($product_info['live_three_commission_rate']) ? $product_info['live_three_commission_rate'] : 0;
  140. $reward_amount = round($value['pay_total'] * $commission_rate / 100, 2);
  141. }
  142. if ($commission_rate < 0.01 || $reward_amount < 0.01) {
  143. continue;
  144. }
  145. }
  146. }
  147. if ($promotion_product_config_data['store_type'] == 2) { //推广店铺类型1=全部店铺2=指定店铺
  148. //校验店铺是否在配置范围内
  149. $shopid_list = explode(',', $promotion_product_config_data['shopid_list']);
  150. if (!in_array($value['shop_id'], $shopid_list)) {
  151. continue;
  152. }
  153. if ($promotion_product_config_data['product_type'] == 1) { //推广商品类型1=全部商品2=指定商品
  154. if ($value['terminal_type'] == 1) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  155. $commission_rate = isset($promotion_product_config_data['mini_three_commission_rate']) ? $promotion_product_config_data['mini_three_commission_rate'] : 0;
  156. $reward_amount = $commission_rate > 0 ? round($value['pay_total'] * $commission_rate / 100, 2) : 0;
  157. }
  158. if ($value['terminal_type'] == 3) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  159. $commission_rate = isset($promotion_product_config_data['live_three_commission_rate']) ? $promotion_product_config_data['live_three_commission_rate'] : 0;
  160. $reward_amount = $commission_rate > 0 ? round($value['pay_total'] * $commission_rate / 100, 2) : 0;
  161. }
  162. } else {
  163. $product_info = $CommonProductModel->where(['company_id' => $company_id, 'status' => 1, 'product_id' => $product_id])->first();
  164. if (!$product_info) {
  165. continue;
  166. }
  167. $product_info = $product_info->toArray();
  168. if ($value['terminal_type'] == 1) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  169. $commission_rate = isset($product_info['mini_three_commission_rate']) ? $product_info['mini_three_commission_rate'] : 0;
  170. $reward_amount = round($value['pay_total'] * $commission_rate / 100, 2);
  171. }
  172. if ($value['terminal_type'] == 3) { //终端类型1=小程序 2=H5 3=直播间 4=PC
  173. $commission_rate = isset($product_info['live_three_commission_rate']) ? $product_info['live_three_commission_rate'] : 0;
  174. $reward_amount = round($value['pay_total'] * $commission_rate / 100, 2);
  175. }
  176. if ($commission_rate < 0.01 || $reward_amount < 0.01) {
  177. continue;
  178. }
  179. }
  180. }
  181. if ($commission_rate < 0.01 || $reward_amount < 0.01) {
  182. continue;
  183. }
  184. $after_revenue_amount = round($before_revenue_amount + $reward_amount, 2);
  185. $insert_data[] = [
  186. 'company_id' => $company_id,
  187. 'order_id' => $order_id,
  188. 'product_id' => $product_id,
  189. 'is_first_order' => '0',
  190. 'product_name' => $value['product_name'],
  191. 'shop_id' => $value['shop_id'],
  192. 'pay_total' => $value['pay_total'],
  193. 'custom_uid' => $uid,
  194. 'promoter_userid' => $promoter_userid,
  195. 'commission_rate' => $commission_rate,
  196. 'reward_amount' => $reward_amount,
  197. 'before_revenue_amount' => $before_revenue_amount,
  198. 'after_revenue_amount' => $after_revenue_amount,
  199. 'revenue_type' => 1, //收益类型1=产品收益2=注册收益
  200. 'commission_level' => '3', //推广等级1=一级推广员2=二级推广员3=三级推广员
  201. 'insert_time' => time(),
  202. 'status' => 1, //状态1=预计收益2=结算中3=审核中4=已转到余额
  203. ];
  204. }
  205. $EarningsRecordModel->insert($insert_data);
  206. //统计非首单奖励金额
  207. $UsersModel->where('custom_uid', $promoter_userid)->update([
  208. 'product_commission_amount' => DB::raw('product_commission_amount+' . $reward_amount)
  209. ]);
  210. DB::connection('company')->commit();
  211. //删除任务记录
  212. $this->Records->delete();
  213. // 成功处理...
  214. } catch (\Exception $e) {
  215. DB::rollBack();
  216. // 失败处理...
  217. if ($this->Records) {
  218. $this->Records->delete();
  219. }
  220. Log::info('job_error', '三级推广员订单收益队列运行失败', ['data' => $this->message_data, 'error' => $e->getMessage()]);
  221. }
  222. }
  223. public function failed(\Throwable $exception)
  224. {
  225. Log::info('job_error', '三级推广员订单收益队列彻底失败', ['data' => $this->message_data, 'error' => $exception]);
  226. // 失败处理...
  227. if ($this->Records) {
  228. $this->Records->delete();
  229. }
  230. }
  231. }