进一步完成
This commit is contained in:
@@ -4,6 +4,7 @@ namespace app\queue\redis;
|
||||
|
||||
|
||||
use app\model\AlibabaSms;
|
||||
use app\model\ShopInfo;
|
||||
use support\Log;
|
||||
use support\think\Db;
|
||||
use Webman\RedisQueue\Consumer;
|
||||
@@ -28,12 +29,17 @@ class ApplySmsTemp implements Consumer
|
||||
// 查询没有提交审核的模版
|
||||
$temp = Db::table('sms_shop_template')->where(['id' => $shop_template_id])->where('status', 'in', [0, -2])->find();
|
||||
if($temp) {
|
||||
// 处理替换内容
|
||||
$templateContent_arr = ShopInfo::handleSmsTemplates($temp['content']);
|
||||
$templateContent_json = json_encode($templateContent_arr);
|
||||
$content = replace_placeholder_keys($temp['content'], $templateContent_arr);
|
||||
// 待申请
|
||||
if($temp['status'] == 0) {
|
||||
$data = [
|
||||
'TemplateName' => $temp['title'],
|
||||
'TemplateContent' => $temp['content'],
|
||||
'Remark' => !empty($temp['remark']) ? $temp['remark'] : '',
|
||||
'TemplateContent' => $content,
|
||||
'TemplateRule' => $templateContent_json,
|
||||
'Remark' => !empty($temp['scene_detail']) ? $temp['scene_detail'] : '',
|
||||
'TemplateType' => 2,
|
||||
'RelatedSignName' => config('cons.sms_sign'),
|
||||
];
|
||||
@@ -45,7 +51,8 @@ class ApplySmsTemp implements Consumer
|
||||
'TemplateCode' => $temp['template_code'],
|
||||
'TemplateName' => $temp['title'],
|
||||
'TemplateContent' => $temp['content'],
|
||||
'Remark' => !empty($temp['remark']) ? $temp['remark'] : '',
|
||||
'TemplateRule' => $templateContent_json,
|
||||
'Remark' => !empty($temp['scene_detail']) ? $temp['scene_detail'] : '',
|
||||
'TemplateType' => 2,
|
||||
'RelatedSignName' => config('cons.sms_sign'),
|
||||
];
|
||||
@@ -69,6 +76,7 @@ class ApplySmsTemp implements Consumer
|
||||
$update_data = [
|
||||
'status' => $status,
|
||||
'template_code' => $template_code,
|
||||
'content_json' => $templateContent_json,
|
||||
'fail_msg' => $fail_msg,
|
||||
'order_id' => $order_id,
|
||||
'update_time' => date('Y-m-d H:i:s'),
|
||||
|
||||
@@ -17,9 +17,53 @@ class BirthdayGiftSms implements Consumer
|
||||
public function consume($data)
|
||||
{
|
||||
Log::info('消息队列【生日有礼】接收到消息' . $data);
|
||||
if($data) {
|
||||
$record = Db::table('mk_birthday_gift_record')->where(['id' => $data])->find();
|
||||
if($record) {
|
||||
// 待发送
|
||||
if($record['push_status'] == 'wait_push') {
|
||||
$user = Db::table('tb_shop_user')->where(['id' => $record['user_id']])->find();
|
||||
if($user && !empty($user['phone'])) {
|
||||
// 检测余额
|
||||
$shop_money = Db::table('sms_shop_money')->where(['shop_id' => $record['main_shop_id']])->find();
|
||||
if($shop_money) {
|
||||
// 余额计算
|
||||
if($shop_money['money'] > config('cons.sms_price')) {
|
||||
$data = [
|
||||
'templateCode' => $record['template_code'],
|
||||
'templateParam' => $record['template_content'],
|
||||
'phoneNumbers' => $user['phone'],
|
||||
'signName' => config('cons.sms_sign'),
|
||||
];
|
||||
$res = AlibabaSms::main($data);
|
||||
if($res['Code'] == 'OK') {
|
||||
Db::table('mk_birthday_gift_record')->where(['id' => $record['id']])->update([
|
||||
'push_status' => 'await_push',
|
||||
'biz_id' => $res['BizId'],
|
||||
'push_time' => date('Y-m-d H:i:s'),
|
||||
]);
|
||||
}else {
|
||||
Db::table('mk_birthday_gift_record')->where(['id' => $record['id']])->update([
|
||||
'push_status' => 'failed',
|
||||
'push_time' => date('Y-m-d H:i:s'),
|
||||
]);
|
||||
}
|
||||
}else {
|
||||
Log::info('商户【' . $record['main_shop_id'] . '】余额不足');
|
||||
return false;
|
||||
}
|
||||
}else {
|
||||
Log::info('商户【' . $record['main_shop_id'] . '】余额为空');
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}else {
|
||||
Log::info('【生日有礼】时查询用户不存在---》' . $record['user_id']);
|
||||
}
|
||||
}
|
||||
}else {
|
||||
Log::info('生日有礼记录未查询到');
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -4,6 +4,7 @@ namespace app\queue\redis;
|
||||
|
||||
|
||||
use app\model\AlibabaSms;
|
||||
use app\model\ShopInfo;
|
||||
use support\Log;
|
||||
use support\think\Db;
|
||||
use Webman\RedisQueue\Consumer;
|
||||
@@ -17,10 +18,76 @@ class SendMarkSms implements Consumer
|
||||
public function consume($data)
|
||||
{
|
||||
Log::info('消息队列【发送营销短信】接收到消息' . $data);
|
||||
if($data) {
|
||||
// 发送任务
|
||||
$record = Db::table('sms_push_event')->where(['id' => $data, 'push_type' => 2])->find();
|
||||
if($record) {
|
||||
// 待发送
|
||||
if($record['status'] == 0) {
|
||||
// 范围用户
|
||||
if($record['user_type'] == 2) {
|
||||
$k_user_params = Db::table('sms_push_event_user')->where(['event_id' => $record['id']])->find();
|
||||
if($k_user_params) {
|
||||
$user_list = ShopInfo::getUserList($k_user_params);
|
||||
}else {
|
||||
Log::info('范围用户查找出错');
|
||||
return false;
|
||||
}
|
||||
}elseif ($record['status'] == 1) {
|
||||
// 全部用户
|
||||
$user_list = Db::table('tb_shop_user')->whereNotNull('phone')->select();
|
||||
$user_list = ShopInfo::evnuserlist($user_list);
|
||||
}
|
||||
$y_temp = Db::table('sms_shop_template')->where(['id' => $record['push_event_id']])->find();
|
||||
if($user_list && $y_temp) {
|
||||
foreach ($user_list as $k => $v) {
|
||||
// 检测余额
|
||||
$shop_money = Db::table('sms_shop_money')->where(['shop_id' => $record['shop_id']])->find();
|
||||
if($shop_money) {
|
||||
// 余额计算
|
||||
if($shop_money['money'] > config('cons.sms_price')) {
|
||||
$templateParam = replace_json_keys($record['json'], $y_temp['content_json']);
|
||||
$data = [
|
||||
'templateCode' => $record['template_code'],
|
||||
'templateParam' => $templateParam,
|
||||
'phoneNumbers' => $user_list['phone'],
|
||||
'signName' => config('cons.sms_sign'),
|
||||
];
|
||||
$res = AlibabaSms::main($data);
|
||||
Db::table('sms_push_event')->where(['id' => $record['id']])->update([
|
||||
'status' => '1',
|
||||
'update_time' => date('Y-m-d H:i:s'),
|
||||
'send_time' => date('Y-m-d H:i:s'),
|
||||
]);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
if($res['Code'] == 'OK') {
|
||||
Db::table('sms_push_event_record')->insert([
|
||||
'shop_id' => $record['shop_id'],
|
||||
'event_id' => $record['id'],
|
||||
'user_id' => $v['user_id'],
|
||||
'user_phone' => $v['phone'],
|
||||
'biz_id' => $res['BizId'],
|
||||
'send_time' => date('Y-m-d H:i:s'),
|
||||
'create_time' => date('Y-m-d H:i:s'),
|
||||
'status' => 1,
|
||||
]);
|
||||
}
|
||||
}else {
|
||||
Log::info('商户【' . $record['main_shop_id'] . '】余额不足');
|
||||
return false;
|
||||
}
|
||||
}else {
|
||||
Log::info('商户【' . $record['main_shop_id'] . '】余额为空');
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}else {
|
||||
Log::info('【发送营销短信】无目标用户---》' . $record['user_id']);
|
||||
}
|
||||
}
|
||||
}else {
|
||||
Log::info('发送营销短信未查询到');
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user