|
@@ -13,6 +13,8 @@ use App\Models\Manager\Process\LowPriceGoodsMember as LowPriceGoodsMemberModel;
|
|
|
use App\Models\Manager\Process\LowPriceGoods as LowPriceGoodsModel;
|
|
use App\Models\Manager\Process\LowPriceGoods as LowPriceGoodsModel;
|
|
|
use App\Models\Manager\Process\ViolationProductMember as ViolationProductMemberModel;
|
|
use App\Models\Manager\Process\ViolationProductMember as ViolationProductMemberModel;
|
|
|
use App\Models\Manager\Process\ViolationProduct as ViolationProductModel;
|
|
use App\Models\Manager\Process\ViolationProduct as ViolationProductModel;
|
|
|
|
|
+use App\Models\Manager\Process\ViolationStore as ViolationStoreModel;
|
|
|
|
|
+use App\Models\Manager\Process\ViolationStoreMember as ViolationStoreMemberModel;
|
|
|
use Illuminate\Support\Carbon;
|
|
use Illuminate\Support\Carbon;
|
|
|
use App\Facades\Servers\Sms\VerifyCode as Sms;
|
|
use App\Facades\Servers\Sms\VerifyCode as Sms;
|
|
|
|
|
|
|
@@ -46,12 +48,16 @@ class SubSmsJobs implements ShouldQueue
|
|
|
{
|
|
{
|
|
|
try {
|
|
try {
|
|
|
$notice_type = $this->message_data['notice_type'];
|
|
$notice_type = $this->message_data['notice_type'];
|
|
|
|
|
+ $company_id = $this->message_data['company_id'];
|
|
|
switch ($notice_type) {
|
|
switch ($notice_type) {
|
|
|
case 'low_price_goods':
|
|
case 'low_price_goods':
|
|
|
- $this->send_low_price_goods_notice();
|
|
|
|
|
|
|
+ $this->send_low_price_goods_notice($company_id);
|
|
|
break;
|
|
break;
|
|
|
case 'violation_product':
|
|
case 'violation_product':
|
|
|
- $this->send_violation_product();
|
|
|
|
|
|
|
+ $this->send_violation_product($company_id);
|
|
|
|
|
+ break;
|
|
|
|
|
+ case 'violation_store':
|
|
|
|
|
+ $this->send_violation_store($company_id);
|
|
|
break;
|
|
break;
|
|
|
default:
|
|
default:
|
|
|
break;
|
|
break;
|
|
@@ -67,20 +73,21 @@ class SubSmsJobs implements ShouldQueue
|
|
|
* @version 1.0
|
|
* @version 1.0
|
|
|
* @date 2026-03-04
|
|
* @date 2026-03-04
|
|
|
*/
|
|
*/
|
|
|
- private function send_low_price_goods_notice()
|
|
|
|
|
|
|
+ private function send_low_price_goods_notice($company_id)
|
|
|
{
|
|
{
|
|
|
$LowPriceGoodsMemberModel = new LowPriceGoodsMemberModel();
|
|
$LowPriceGoodsMemberModel = new LowPriceGoodsMemberModel();
|
|
|
$LowPriceGoodsModel = new LowPriceGoodsModel();
|
|
$LowPriceGoodsModel = new LowPriceGoodsModel();
|
|
|
//获取今日待处理的商品记录
|
|
//获取今日待处理的商品记录
|
|
|
$todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
|
|
$todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
|
|
|
$todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
|
|
$todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
|
|
|
- $lowprice_ids = $LowPriceGoodsModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd]])->pluck('id')->toArray();
|
|
|
|
|
|
|
+ $lowprice_ids = $LowPriceGoodsModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
|
|
|
if (empty($lowprice_ids)) return true;
|
|
if (empty($lowprice_ids)) return true;
|
|
|
//获取开启了通知服务的用户
|
|
//获取开启了通知服务的用户
|
|
|
$usert_list = $LowPriceGoodsMemberModel
|
|
$usert_list = $LowPriceGoodsMemberModel
|
|
|
->whereIn('lowprice_product_logid', $lowprice_ids)
|
|
->whereIn('lowprice_product_logid', $lowprice_ids)
|
|
|
->join('personnel_employee', 'process_lowprice_product_member.employee_id', '=', 'personnel_employee.id')
|
|
->join('personnel_employee', 'process_lowprice_product_member.employee_id', '=', 'personnel_employee.id')
|
|
|
->where('personnel_employee.open_notice', 0)
|
|
->where('personnel_employee.open_notice', 0)
|
|
|
|
|
+ ->where('personnel_employee.company_id', $company_id)
|
|
|
->where([['personnel_employee.mobile', '!=', ''], ['personnel_employee.mobile', '!=', null]])
|
|
->where([['personnel_employee.mobile', '!=', ''], ['personnel_employee.mobile', '!=', null]])
|
|
|
->select(['process_lowprice_product_member.*', 'personnel_employee.mobile'])
|
|
->select(['process_lowprice_product_member.*', 'personnel_employee.mobile'])
|
|
|
->get()->toArray();
|
|
->get()->toArray();
|
|
@@ -112,20 +119,21 @@ class SubSmsJobs implements ShouldQueue
|
|
|
* @version 1.0
|
|
* @version 1.0
|
|
|
* @date 2026-03-04
|
|
* @date 2026-03-04
|
|
|
*/
|
|
*/
|
|
|
- private function send_violation_product()
|
|
|
|
|
|
|
+ private function send_violation_product($company_id)
|
|
|
{
|
|
{
|
|
|
$ViolationProductMemberModel = new ViolationProductMemberModel();
|
|
$ViolationProductMemberModel = new ViolationProductMemberModel();
|
|
|
$ViolationProductModel = new ViolationProductModel();
|
|
$ViolationProductModel = new ViolationProductModel();
|
|
|
//获取今日待处理的商品记录
|
|
//获取今日待处理的商品记录
|
|
|
$todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
|
|
$todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
|
|
|
$todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
|
|
$todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
|
|
|
- $violation_price_ids = $ViolationProductModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd]])->pluck('id')->toArray();
|
|
|
|
|
|
|
+ $violation_price_ids = $ViolationProductModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
|
|
|
if (empty($violation_price_ids)) return true;
|
|
if (empty($violation_price_ids)) return true;
|
|
|
//获取开启了通知服务的用户
|
|
//获取开启了通知服务的用户
|
|
|
$usert_list = $ViolationProductMemberModel
|
|
$usert_list = $ViolationProductMemberModel
|
|
|
->whereIn('violation_product_logid', $violation_price_ids)
|
|
->whereIn('violation_product_logid', $violation_price_ids)
|
|
|
->join('personnel_employee', 'process_violation_product_member.employee_id', '=', 'personnel_employee.id')
|
|
->join('personnel_employee', 'process_violation_product_member.employee_id', '=', 'personnel_employee.id')
|
|
|
->where('personnel_employee.open_notice', 0)
|
|
->where('personnel_employee.open_notice', 0)
|
|
|
|
|
+ ->where('personnel_employee.company_id', $company_id)
|
|
|
->where([['personnel_employee.mobile', '!=', ''], ['personnel_employee.mobile', '!=', null]])
|
|
->where([['personnel_employee.mobile', '!=', ''], ['personnel_employee.mobile', '!=', null]])
|
|
|
->select(['process_violation_product_member.*', 'personnel_employee.mobile'])
|
|
->select(['process_violation_product_member.*', 'personnel_employee.mobile'])
|
|
|
->get()->toArray();
|
|
->get()->toArray();
|
|
@@ -142,7 +150,52 @@ class SubSmsJobs implements ShouldQueue
|
|
|
$user_data[$user_id]['log_ids'][] = $value['violation_product_logid'];
|
|
$user_data[$user_id]['log_ids'][] = $value['violation_product_logid'];
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
- $sms_tpl_id = config('verifycode.aliyun_process_process_violation_product.sms_tpl');
|
|
|
|
|
|
|
+ $sms_tpl_id = config('verifycode.aliyun_process_violation_product.sms_tpl');
|
|
|
|
|
+ //发送短信
|
|
|
|
|
+ foreach ($user_data as $key => $value) {
|
|
|
|
|
+ $phone = $value['mobile'];
|
|
|
|
|
+ $totle_number = count($value['log_ids']);
|
|
|
|
|
+ Sms::sendContent($phone, ['totle_number' => $totle_number], $sms_tpl_id);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 短信消息消息订阅推送(禁止店铺)
|
|
|
|
|
+ * @author 唐远望
|
|
|
|
|
+ * @version 1.0
|
|
|
|
|
+ * @date 2026-03-04
|
|
|
|
|
+ */
|
|
|
|
|
+ private function send_violation_store($company_id){
|
|
|
|
|
+ $ViolationStoreMemberModel = new ViolationStoreMemberModel();
|
|
|
|
|
+ $ViolationStoreModel = new ViolationStoreModel();
|
|
|
|
|
+ //获取今日待处理的店铺记录
|
|
|
|
|
+ $todayStart = Carbon::today()->startOfDay()->getTimestamp(); // 今天开始时间 00:00:00
|
|
|
|
|
+ $todayEnd = Carbon::today()->endOfDay()->getTimestamp(); // 今天结束时间 23:59:59
|
|
|
|
|
+ $violation_price_ids = $ViolationStoreModel->where([['insert_time', '>=', $todayStart], ['insert_time', '<=', $todayEnd], ['company_id', '=', $company_id]])->pluck('id')->toArray();
|
|
|
|
|
+ if (empty($violation_price_ids)) return true;
|
|
|
|
|
+ //获取开启了通知服务的用户
|
|
|
|
|
+ $usert_list = $ViolationStoreMemberModel
|
|
|
|
|
+ ->whereIn('violation_store_logid', $violation_price_ids)
|
|
|
|
|
+ ->join('personnel_employee', 'process_violation_store_member.employee_id', '=', 'personnel_employee.id')
|
|
|
|
|
+ ->where('personnel_employee.open_notice', 0)
|
|
|
|
|
+ ->where('personnel_employee.company_id', $company_id)
|
|
|
|
|
+ ->where([['personnel_employee.mobile', '!=', ''], ['personnel_employee.mobile', '!=', null]])
|
|
|
|
|
+ ->select(['process_violation_store_member.*', 'personnel_employee.mobile'])
|
|
|
|
|
+ ->get()->toArray();
|
|
|
|
|
+ if (empty($usert_list)) return true;
|
|
|
|
|
+ //按用户统计待处理的商品数量
|
|
|
|
|
+ $user_data = [];
|
|
|
|
|
+ foreach ($usert_list as $key => $value) {
|
|
|
|
|
+ $user_id = $value['employee_id'];
|
|
|
|
|
+ if (!isset($user_data[$user_id])) {
|
|
|
|
|
+ $user_data[$user_id]['employee_id'] = $user_id;
|
|
|
|
|
+ $user_data[$user_id]['mobile'] = $value['mobile'];
|
|
|
|
|
+ $user_data[$user_id]['log_ids'][] = $value['violation_store_logid'];
|
|
|
|
|
+ } else {
|
|
|
|
|
+ $user_data[$user_id]['log_ids'][] = $value['violation_store_logid'];
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ $sms_tpl_id = config('verifycode.aliyun_process_violation_store.sms_tpl');
|
|
|
//发送短信
|
|
//发送短信
|
|
|
foreach ($user_data as $key => $value) {
|
|
foreach ($user_data as $key => $value) {
|
|
|
$phone = $value['mobile'];
|
|
$phone = $value['mobile'];
|
|
@@ -150,7 +203,6 @@ class SubSmsJobs implements ShouldQueue
|
|
|
Sms::sendContent($phone, ['totle_number' => $totle_number], $sms_tpl_id);
|
|
Sms::sendContent($phone, ['totle_number' => $totle_number], $sms_tpl_id);
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function failed(\Throwable $exception)
|
|
public function failed(\Throwable $exception)
|