SubEmailJobs.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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\Servers\Email\VerifyCode as EmailVerifyCode;
  11. use App\Models\Manager\Process\LowPriceGoodsMember as LowPriceGoodsMemberModel;
  12. use App\Models\Manager\Process\LowPriceGoods as LowPriceGoodsModel;
  13. use App\Models\Manager\Process\ViolationProductMember as ViolationProductMemberModel;
  14. use App\Models\Manager\Process\ViolationProduct as ViolationProductModel;
  15. use Illuminate\Support\Carbon;
  16. /**
  17. * 订阅邮件通知
  18. * @author 唐远望
  19. * @version 1.0
  20. * @date 2026-03-30
  21. */
  22. class SubEmailJobs implements ShouldQueue
  23. {
  24. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  25. protected $message_data;
  26. /**
  27. * Create a new job instance.
  28. *
  29. * @return void
  30. */
  31. public function __construct(array $message_data)
  32. {
  33. $this->message_data = $message_data;
  34. }
  35. /**
  36. * Execute the job.
  37. *
  38. * @return void
  39. */
  40. public function handle()
  41. {
  42. try {
  43. $notice_type = $this->message_data['notice_type'];
  44. switch ($notice_type) {
  45. case 'low_price_goods':
  46. $this->send_low_price_goods_notice();
  47. break;
  48. case 'violation_product':
  49. $this->send_violation_product();
  50. break;
  51. default:
  52. break;
  53. }
  54. } catch (\Exception $e) {
  55. print_r($e->getMessage());exit;
  56. Log::info('job_error', '订阅邮件通知推送队列失败', ['data' => $this->message_data, 'error' => $e->getMessage()]);
  57. }
  58. }
  59. /**
  60. * 邮件消息消息订阅推送(低价挂网)
  61. * @author 唐远望
  62. * @version 1.0
  63. * @date 2026-03-04
  64. */
  65. private function send_low_price_goods_notice()
  66. {
  67. $EmailVerifyCode = new EmailVerifyCode();
  68. $LowPriceGoodsMemberModel = new LowPriceGoodsMemberModel();
  69. $LowPriceGoodsModel = new LowPriceGoodsModel();
  70. //获取今日待处理的商品记录
  71. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  72. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  73. $lowprice_ids = $LowPriceGoodsModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd]])->pluck('id')->toArray();
  74. if (empty($lowprice_ids)) return true;
  75. //获取开启了通知服务的用户
  76. $usert_list = $LowPriceGoodsMemberModel
  77. ->whereIn('lowprice_product_logid', $lowprice_ids)
  78. ->join('personnel_employee', 'process_lowprice_product_member.employee_id', '=', 'personnel_employee.id')
  79. ->where('personnel_employee.open_notice', 0)
  80. ->where([['personnel_employee.email', '!=', ''], ['personnel_employee.email', '!=', null]])
  81. ->select(['process_lowprice_product_member.*', 'personnel_employee.email'])
  82. ->get()->toArray();
  83. if (empty($usert_list)) return true;
  84. //按用户统计待处理的商品数量
  85. $user_data = [];
  86. foreach ($usert_list as $key => $value) {
  87. $user_id = $value['employee_id'];
  88. if (!isset($user_data[$user_id])) {
  89. $user_data[$user_id]['employee_id'] = $user_id;
  90. $user_data[$user_id]['email'] = $value['email'];
  91. $user_data[$user_id]['log_ids'][] = $value['lowprice_product_logid'];
  92. } else {
  93. $user_data[$user_id]['log_ids'][] = $value['lowprice_product_logid'];
  94. }
  95. }
  96. //发送邮件
  97. foreach ($user_data as $key => $value) {
  98. $email_to = $value['email'];
  99. $totle_number = count($value['log_ids']);
  100. $email_title = '商品提醒';
  101. $email_content = '今日待处理商品共【' . $totle_number . '】条,请及时登录系统处理。';
  102. $EmailVerifyCode->sendSmtpEmail($email_to, $email_title, $email_content);
  103. }
  104. }
  105. /**
  106. * 邮件消息消息订阅推送(禁止挂网)
  107. * @author 唐远望
  108. * @version 1.0
  109. * @date 2026-03-04
  110. */
  111. private function send_violation_product()
  112. {
  113. $EmailVerifyCode = new EmailVerifyCode();
  114. $ViolationProductMemberModel = new ViolationProductMemberModel();
  115. $ViolationProductModel = new ViolationProductModel();
  116. //获取今日待处理的商品记录
  117. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  118. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  119. $violation_price_ids = $ViolationProductModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd]])->pluck('id')->toArray();
  120. if (empty($violation_price_ids)) return true;
  121. //获取开启了通知服务的用户
  122. $usert_list = $ViolationProductMemberModel
  123. ->whereIn('violation_product_logid', $violation_price_ids)
  124. ->join('personnel_employee', 'process_violation_product_member.employee_id', '=', 'personnel_employee.id')
  125. ->where('personnel_employee.open_notice', 0)
  126. ->where([['personnel_employee.email', '!=', ''], ['personnel_employee.email', '!=', null]])
  127. ->select(['process_violation_product_member.*', 'personnel_employee.email'])
  128. ->get()->toArray();
  129. if (empty($usert_list)) return true;
  130. //按用户统计待处理的商品数量
  131. $user_data = [];
  132. foreach ($usert_list as $key => $value) {
  133. $user_id = $value['employee_id'];
  134. if (!isset($user_data[$user_id])) {
  135. $user_data[$user_id]['employee_id'] = $user_id;
  136. $user_data[$user_id]['email'] = $value['email'];
  137. $user_data[$user_id]['log_ids'][] = $value['violation_product_logid'];
  138. } else {
  139. $user_data[$user_id]['log_ids'][] = $value['violation_product_logid'];
  140. }
  141. }
  142. //发送邮件
  143. foreach ($user_data as $key => $value) {
  144. $email_to = $value['email'];
  145. $totle_number = count($value['log_ids']);
  146. $email_title = '禁止挂网商品提醒';
  147. $email_content = '今日待处理禁止挂网商品共【' . $totle_number . '】条,请及时登录系统处理。';
  148. $EmailVerifyCode->sendSmtpEmail($email_to, $email_title, $email_content);
  149. }
  150. }
  151. public function failed(\Throwable $exception)
  152. {
  153. Log::info('job_error', '订阅邮件通知推送队列完全失败', ['data' => $this->message_data, 'error' => $exception]);
  154. }
  155. }