SubscriptionJobs.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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\Models\Manager\Personnel\Employee as EmployeeModel;
  10. use App\Facades\Servers\Wechat\Official;
  11. use App\Facades\Servers\Logs\Log;
  12. use Illuminate\Support\Carbon;
  13. use App\Models\Manager\Process\LowPriceGoodsMember as LowPriceGoodsMemberModel;
  14. use App\Models\Manager\Process\ViolationProductMember as ViolationProductMemberModel;
  15. use Illuminate\Support\Facades\DB;
  16. /**
  17. * 订阅消息通知推送
  18. * @author 唐远望
  19. * @version 1.0
  20. * @date 2026-03-04
  21. */
  22. class SubscriptionJobs 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. $map = [];
  45. $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
  46. $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
  47. switch ($notice_type) {
  48. case 'low_price_goods':
  49. $LowPriceGoodsMemberModel = new LowPriceGoodsMemberModel();
  50. //查询今日待处理低价商品责任人
  51. $map[] = ['process_lowprice_product.insert_time', '>=', $todayStart];
  52. $map[] = ['process_lowprice_product.insert_time', '<=', $todayEnd];
  53. $process_data = $LowPriceGoodsMemberModel
  54. ->join('process_lowprice_product', 'process_lowprice_product_member.lowprice_product_logid', '=', 'process_lowprice_product.id')
  55. ->where($map)
  56. ->where([
  57. 'process_lowprice_product.processing_status' => '1',
  58. 'process_lowprice_product_member.duty_type' => '1'
  59. ])
  60. ->groupBy('process_lowprice_product_member.employee_id') // 按员工ID分组
  61. ->select(
  62. 'process_lowprice_product_member.employee_id',
  63. DB::raw('count(*) as total_number') // 统计每个员工的数量
  64. )
  65. ->get();
  66. if (empty($process_data)) {
  67. return true;
  68. }
  69. // 转换为原来的数组格式
  70. $user_id_list = [];
  71. foreach ($process_data as $value) {
  72. $user_id_list[$value->employee_id] = [
  73. 'totle_number' => $value->total_number
  74. ];
  75. }
  76. // $user_id_list=['2'=>'10'];
  77. $this->send_low_price_goods_notice($user_id_list);
  78. break;
  79. case 'violation_product':
  80. $ViolationProductMemberModel = new ViolationProductMemberModel();
  81. //查询今日待处理禁止商品责任人
  82. $map[] = ['process_violation_product.insert_time', '>=', $todayStart];
  83. $map[] = ['process_violation_product.insert_time', '<=', $todayEnd];
  84. $process_data = $ViolationProductMemberModel
  85. ->join('process_violation_product', 'process_violation_product_member.lowprice_product_logid', '=', 'process_violation_product.id')
  86. ->where($map)
  87. ->where(['process_violation_product.processing_status' => '1', 'process_violation_product_member.duty_type' => '1'])
  88. ->groupBy('process_violation_product_member.employee_id') // 按员工ID分组
  89. ->select(
  90. 'process_violation_product_member.employee_id',
  91. DB::raw('count(*) as total_number') // 统计每个员工的数量
  92. )
  93. ->get();
  94. if (empty($process_data)) {
  95. return true;
  96. }
  97. // 转换为数组格式(如果需要原来的格式)
  98. $user_id_list = [];
  99. foreach ($process_data as $value) {
  100. $user_id_list[$value['employee_id']] = [
  101. 'totle_number' => $value['total_number']
  102. ];
  103. }
  104. // $user_id_list=['2'=>'10'];
  105. $this->send_violation_product($user_id_list);
  106. break;
  107. default:
  108. break;
  109. }
  110. } catch (\Exception $e) {
  111. Log::info('job_error', '订阅消息通知推送队列失败', ['data' => $this->message_data, 'error' => $e->getMessage()]);
  112. }
  113. }
  114. /**
  115. * 公众号消息订阅推送(低价挂网)
  116. * @author 唐远望
  117. * @version 1.0
  118. * @date 2026-03-04
  119. */
  120. private function send_low_price_goods_notice($user_id_list)
  121. {
  122. $EmployeeModel = new EmployeeModel();
  123. foreach ($user_id_list as $key => $totle_number) {
  124. $user_info = $EmployeeModel->join('personnel_employee_openid', 'personnel_employee_openid.employee_id', '=', 'personnel_employee.id')
  125. ->select(['personnel_employee.*', 'personnel_employee_openid.employee_id', 'personnel_employee_openid.openid'])
  126. ->where('personnel_employee.id', $key)->where([['personnel_employee.open_notice', '=', 0], ['personnel_employee.status', '=', 0]])->first();
  127. if (empty($user_info)) return true;
  128. if ($user_info['openid'] == '') return true;
  129. $data = [
  130. 'thing1' => '数据违规预警',
  131. 'thing2' => '低价挂网商品:共【' . $totle_number . '】条',
  132. 'time7' => time(),
  133. 'phrase9' => '待处理',
  134. ];
  135. $params = [
  136. 'openid' => $user_info['openid'],
  137. 'template_id' => 't559Iagds7Av-YcqwIpeAaS5gt7LuOKuIBDvVKlyfm8',
  138. 'miniprogram' => [
  139. 'appid' => config('wechat.mini.app_id'),
  140. 'pagepath' => 'pages/index/index'
  141. ],
  142. 'data' => $data,
  143. ];
  144. //发送模板消息
  145. $result = Official::sendSubscription($params);
  146. if (!empty($result) && isset($result['error'])) {
  147. Log::info('job_notice', '公众号消息订阅推送失败', ['data' => $params, 'error' => $result]);
  148. }
  149. }
  150. }
  151. /**
  152. * 公众号消息订阅推送(禁止挂网)
  153. * @author 唐远望
  154. * @version 1.0
  155. * @date 2026-03-04
  156. */
  157. private function send_violation_product($user_id_list)
  158. {
  159. $EmployeeModel = new EmployeeModel();
  160. foreach ($user_id_list as $key => $totle_number) {
  161. $user_info = $EmployeeModel->join('personnel_employee_openid', 'personnel_employee_openid.employee_id', '=', 'personnel_employee.id')
  162. ->select(['personnel_employee.*', 'personnel_employee_openid.employee_id', 'personnel_employee_openid.openid'])
  163. ->where('personnel_employee.id', $key)->where([['personnel_employee.open_notice', '=', 0], ['personnel_employee.status', '=', 0]])->first();
  164. if (empty($user_info)) return true;
  165. if ($user_info['openid'] == '') return true;
  166. $data = [
  167. 'thing1' => '数据违规预警',
  168. 'thing2' => '禁止挂网商品:共【' . $totle_number . '】条',
  169. 'time7' => strtotime(time(), 'Y:m:d H:i:s'),
  170. 'phrase9' => '待处理',
  171. ];
  172. $params = [
  173. 'openid' => $user_info['openid'],
  174. 'template_id' => 't559Iagds7Av-YcqwIpeAaS5gt7LuOKuIBDvVKlyfm8',
  175. 'miniprogram' => [
  176. 'appid' => config('wechat.mini.app_id'),
  177. 'pagepath' => 'pages/index/index'
  178. ],
  179. 'data' => $data,
  180. ];
  181. //发送模板消息
  182. $result = Official::sendSubscription($params);
  183. if (!empty($result) && isset($result['error'])) {
  184. Log::info('job_notice', '公众号消息订阅推送失败', ['data' => $params, 'error' => $result]);
  185. }
  186. }
  187. }
  188. public function failed(\Throwable $exception)
  189. {
  190. Log::info('job_error', '订阅消息通知推送队列完全失败', ['data' => $this->message_data, 'error' => $exception]);
  191. }
  192. }