SubNoticeJobs.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?php
  2. namespace App\Jobs\Manager\Process;
  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\Facades\Servers\Logs\Log;
  10. use App\Models\Manager\Process\LowPriceGoodsMember as LowPriceGoodsMemberModel;
  11. use App\Models\Manager\Process\LowPriceGoods as LowPriceGoodsModel;
  12. use App\Models\Manager\Process\ViolationProductMember as ViolationProductMemberModel;
  13. use App\Models\Manager\Process\ViolationProduct as ViolationProductModel;
  14. use App\Models\Manager\Process\ViolationStore as ViolationStoreModel;
  15. use App\Models\Manager\Process\ViolationStoreMember as ViolationStoreMemberModel;
  16. use Illuminate\Support\Carbon;
  17. use App\Facades\Servers\Sms\VerifyCode as Sms;
  18. use App\Servers\Email\VerifyCode as EmailVerifyCode;
  19. /**
  20. * 订阅通知
  21. * @author 唐远望
  22. * @version 1.0
  23. * @date 2026-03-30
  24. */
  25. class SubNoticeJobs implements ShouldQueue
  26. {
  27. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  28. protected $message_data;
  29. protected $user_data;
  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. * Execute the job.
  41. *
  42. * @return void
  43. */
  44. public function handle()
  45. {
  46. try {
  47. $EmailVerifyCode = new EmailVerifyCode();
  48. $sms_tpl_id = config('verifycode.aliyun_process_merge_notice.sms_tpl');
  49. $company_id = $this->message_data['company_id'];
  50. $action_one = $this->send_low_price_goods_notice($company_id);
  51. $action_two = $this->send_violation_product($company_id);
  52. $action_three = $this->send_violation_store($company_id);
  53. if (empty($this->user_data)) return true;
  54. if ($action_one && $action_two && $action_three) {
  55. foreach ($this->user_data as $key => $value) {
  56. $mobile = $value['mobile'];
  57. $email_to = $value['email'];
  58. $number1 = isset($this->user_data[$key]['lowprice_product_logids']) ? count($this->user_data[$key]['lowprice_product_logids']) : 0;
  59. $number2 = isset($this->user_data[$key]['violation_product_logids']) ? count($this->user_data[$key]['violation_product_logids']) : 0;
  60. $number3 = isset($this->user_data[$key]['violation_store_logids']) ? count($this->user_data[$key]['violation_store_logids']) : 0;
  61. //统计总条数
  62. $totle_number = $number1 + $number2 + $number3;
  63. if (trim($mobile) != '') {
  64. $res_msg = Sms::sendContent($mobile, ['totle_number' => $totle_number, 'number1' => $number1, 'number2' => $number2, 'number3' => $number3], $sms_tpl_id);
  65. Log::info('job_send_sms', '订阅短信通知推送队列记录', ['email' => $mobile, 'sms_tpl_id' => $sms_tpl_id, 'msg' => $res_msg]);
  66. }
  67. if (trim($email_to) != '') {
  68. $email_title = '智价云违规数据通知提醒';
  69. $email_content = "智价云提醒:本次采集总数据共". $totle_number ."条,其中低价挂网商品共". $number1 ."条、禁止挂网商品共". $number2 ."条、违规挂网店铺共". $number3 ."条。";
  70. $res_msg = $EmailVerifyCode->sendSmtpEmail($email_to, $email_title, $email_content);
  71. Log::info('job_send_email', '订阅邮件通知推送队列记录', ['email' => $email_to, 'email_content' => $email_content, 'msg' => $res_msg]);
  72. }
  73. }
  74. }
  75. } catch (\Exception $e) {
  76. Log::info('job_error', '订阅短信通知推送队列失败', ['data' => $this->message_data, 'error' => $e->getMessage()]);
  77. }
  78. }
  79. /**
  80. * 短信消息消息订阅推送(低价挂网)
  81. * @author 唐远望
  82. * @version 1.0
  83. * @date 2026-03-04
  84. */
  85. private function send_low_price_goods_notice($company_id)
  86. {
  87. $LowPriceGoodsMemberModel = new LowPriceGoodsMemberModel();
  88. $LowPriceGoodsModel = new LowPriceGoodsModel();
  89. //获取今日待处理的商品记录
  90. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  91. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  92. $lowprice_ids = $LowPriceGoodsModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
  93. if (empty($lowprice_ids)) return true;
  94. //获取开启了通知服务的用户
  95. $usert_list = $LowPriceGoodsMemberModel
  96. ->whereIn('lowprice_product_logid', $lowprice_ids)
  97. ->join('personnel_employee', 'process_lowprice_product_member.employee_id', '=', 'personnel_employee.id')
  98. ->where('personnel_employee.open_notice', 0)
  99. ->where('personnel_employee.company_id', $company_id)
  100. ->select(['process_lowprice_product_member.*', 'personnel_employee.mobile', 'personnel_employee.email'])
  101. ->get()->toArray();
  102. if (empty($usert_list)) return true;
  103. //按用户统计待处理的商品数量
  104. foreach ($usert_list as $key => $value) {
  105. $user_id = $value['employee_id'];
  106. if (!isset($this->user_data[$user_id])) {
  107. $this->user_data[$user_id]['employee_id'] = $user_id;
  108. $this->user_data[$user_id]['mobile'] = $value['mobile'];
  109. $this->user_data[$user_id]['email'] = $value['email'];
  110. $this->user_data[$user_id]['lowprice_product_logids'][] = $value['lowprice_product_logid'];
  111. } else {
  112. $this->user_data[$user_id]['lowprice_product_logids'][] = $value['lowprice_product_logid'];
  113. }
  114. }
  115. return true;
  116. }
  117. /**
  118. * 短信消息消息订阅推送(禁止挂网)
  119. * @author 唐远望
  120. * @version 1.0
  121. * @date 2026-03-04
  122. */
  123. private function send_violation_product($company_id)
  124. {
  125. $ViolationProductMemberModel = new ViolationProductMemberModel();
  126. $ViolationProductModel = new ViolationProductModel();
  127. //获取今日待处理的商品记录
  128. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  129. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  130. $violation_price_ids = $ViolationProductModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
  131. if (empty($violation_price_ids)) return true;
  132. //获取开启了通知服务的用户
  133. $usert_list = $ViolationProductMemberModel
  134. ->whereIn('violation_product_logid', $violation_price_ids)
  135. ->join('personnel_employee', 'process_violation_product_member.employee_id', '=', 'personnel_employee.id')
  136. ->where('personnel_employee.open_notice', 0)
  137. ->where('personnel_employee.company_id', $company_id)
  138. ->select(['process_violation_product_member.*', 'personnel_employee.mobile', 'personnel_employee.email'])
  139. ->get()->toArray();
  140. if (empty($usert_list)) return true;
  141. //按用户统计待处理的商品数量
  142. foreach ($usert_list as $key => $value) {
  143. $user_id = $value['employee_id'];
  144. if (!isset($this->user_data[$user_id])) {
  145. $this->user_data[$user_id]['employee_id'] = $user_id;
  146. $this->user_data[$user_id]['mobile'] = $value['mobile'];
  147. $this->user_data[$user_id]['email'] = $value['email'];
  148. $this->user_data[$user_id]['violation_product_logids'][] = $value['violation_product_logid'];
  149. } else {
  150. $this->user_data[$user_id]['violation_product_logids'][] = $value['violation_product_logid'];
  151. }
  152. }
  153. return true;
  154. }
  155. /**
  156. * 短信消息消息订阅推送(禁止店铺)
  157. * @author 唐远望
  158. * @version 1.0
  159. * @date 2026-03-04
  160. */
  161. private function send_violation_store($company_id)
  162. {
  163. $ViolationStoreMemberModel = new ViolationStoreMemberModel();
  164. $ViolationStoreModel = new ViolationStoreModel();
  165. //获取今日待处理的店铺记录
  166. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  167. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  168. $violation_price_ids = $ViolationStoreModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
  169. if (empty($violation_price_ids)) return true;
  170. //获取开启了通知服务的用户
  171. $usert_list = $ViolationStoreMemberModel
  172. ->whereIn('violation_store_logid', $violation_price_ids)
  173. ->join('personnel_employee', 'process_violation_store_member.employee_id', '=', 'personnel_employee.id')
  174. ->where('personnel_employee.open_notice', 0)
  175. ->where('personnel_employee.company_id', $company_id)
  176. ->select(['process_lowprice_product_member.*', 'personnel_employee.mobile', 'personnel_employee.email'])
  177. ->get()->toArray();
  178. if (empty($usert_list)) return true;
  179. //按用户统计待处理的商品数量
  180. foreach ($usert_list as $key => $value) {
  181. $user_id = $value['employee_id'];
  182. if (!isset($this->user_data[$user_id])) {
  183. $this->user_data[$user_id]['employee_id'] = $user_id;
  184. $this->user_data[$user_id]['mobile'] = $value['mobile'];
  185. $this->user_data[$user_id]['email'] = $value['email'];
  186. $this->user_data[$user_id]['log_ids'][] = $value['violation_store_logid'];
  187. } else {
  188. $this->user_data[$user_id]['log_ids'][] = $value['violation_store_logid'];
  189. }
  190. }
  191. //按用户统计待处理的商品数量
  192. foreach ($usert_list as $key => $value) {
  193. $user_id = $value['employee_id'];
  194. if (!isset($this->user_data[$user_id])) {
  195. $this->user_data[$user_id]['employee_id'] = $user_id;
  196. $this->user_data[$user_id]['mobile'] = $value['mobile'];
  197. $this->user_data[$user_id]['violation_store_logids'][] = $value['violation_store_logid'];
  198. } else {
  199. $this->user_data[$user_id]['violation_store_logids'][] = $value['violation_store_logid'];
  200. }
  201. }
  202. return true;
  203. }
  204. public function failed(\Throwable $exception)
  205. {
  206. Log::info('job_error', '订阅短信通知推送队列完全失败', ['data' => $this->message_data, 'error' => $exception]);
  207. }
  208. }