增加延迟取消未接诊订单队列

This commit is contained in:
wucongxing 2023-03-28 09:51:08 +08:00
parent e7bff9c66d
commit 7f7fd558c1
3 changed files with 63 additions and 63 deletions

View File

@ -4,6 +4,8 @@ declare(strict_types=1);
namespace App\Amqp\Consumer; namespace App\Amqp\Consumer;
use App\Amqp\Producer\CancelUnpayOrdersDelayDirectProducer;
use App\Constants\HttpEnumCode;
use App\Model\OrderInquiry; use App\Model\OrderInquiry;
use App\Model\UserDoctor; use App\Model\UserDoctor;
use App\Services\ImService; use App\Services\ImService;
@ -13,6 +15,7 @@ use App\Utils\Log;
use Extend\TencentIm\Message; use Extend\TencentIm\Message;
use Extend\Wechat\WechatPay; use Extend\Wechat\WechatPay;
use GuzzleHttp\Exception\GuzzleException; use GuzzleHttp\Exception\GuzzleException;
use Hyperf\Amqp\Producer;
use Hyperf\Amqp\Result; use Hyperf\Amqp\Result;
use Hyperf\Amqp\Annotation\Consumer; use Hyperf\Amqp\Annotation\Consumer;
use Hyperf\Amqp\Message\ConsumerMessage; use Hyperf\Amqp\Message\ConsumerMessage;
@ -106,16 +109,17 @@ class AssignDoctorConsumer extends ConsumerMessage
if ($diff_time > 300) { if ($diff_time > 300) {
Log::getInstance()->error("分配医生队列执行失败:超出5分钟执行退款"); Log::getInstance()->error("分配医生队列执行失败:超出5分钟执行退款");
$InquiryService = new InquiryService();
// 检测问诊订单执行退款次数 // 检测问诊订单执行退款次数
Log::getInstance()->info("检测问诊订单执行退款次数"); Log::getInstance()->info("检测问诊订单执行退款次数");
$res = $this->checkInquiryRefundCount($order_inquiry['order_inquiry_id']); $res = $InquiryService->checkInquiryRefundCount($order_inquiry['order_inquiry_id']);
if (!$res){ if (!$res){
Db::rollBack(); Db::rollBack();
Log::getInstance()->error("分配医生队列执行失败原因:超出最大退款次数"); Log::getInstance()->error("分配医生队列执行失败原因:超出最大退款次数");
return Result::ACK; return Result::ACK;
} }
$InquiryService = new InquiryService();
$InquiryService->inquiryRefund($order_inquiry['order_inquiry_id'], "暂无医生接诊"); $InquiryService->inquiryRefund($order_inquiry['order_inquiry_id'], "暂无医生接诊");
return Result::ACK; return Result::ACK;
@ -137,13 +141,27 @@ class AssignDoctorConsumer extends ConsumerMessage
} }
// 更改数据库 // 更改数据库
$data = array(); $save_data = array();
$data['doctor_id'] = $doctor_id; $save_data['doctor_id'] = $doctor_id;
$data['inquiry_status'] = 3; // 待接诊 $save_data['inquiry_status'] = 3; // 待接诊
$params = array(); $params = array();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id']; $params['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
OrderInquiry::edit($params, $data); OrderInquiry::edit($params, $save_data);
// 加入未接诊取消订单延迟队列
$data = array();
$data['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
$message = new CancelUnpayOrdersDelayDirectProducer($data);
// 快速/购药-5分钟
$message->setDelayMs(1000 * 60 * 5);
$producer = $this->container->get(Producer::class);
$res = $producer->produce($message);
if (!$res) {
Db::rollBack();
Log::getInstance()->error("分配医生队列执行失败:加入未接诊取消订单延迟队列失败");
return Result::ACK;
}
Db::commit(); Db::commit();
Log::getInstance()->error("分配医生 队列执行成功"); Log::getInstance()->error("分配医生 队列执行成功");
@ -196,45 +214,6 @@ class AssignDoctorConsumer extends ConsumerMessage
return Result::ACK; return Result::ACK;
} }
/**
* 检测问诊订单执行退款次数
* @param string $order_inquiry_id
* @return bool
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
private function checkInquiryRefundCount(string $order_inquiry_id): bool
{
Log::getInstance()->info("检测问诊订单执行退款次数");
try {
$redis = $this->container->get(Redis::class);
$redis_key = "inquiryRefund" . $order_inquiry_id;
$redis_value = $redis->get($redis_key);
if(empty($redis_value)){
$redis->set($redis_key, 1,60 * 60 * 24 * 5);
return true;
}
// 判断退款次数
if ($redis_value > 3) {
Log::getInstance()->error("问诊订单执行退款次数过多");
// 加入短信队列,通知管理员
return false;
}
$redis->incr($redis_key);
} catch (\Exception $e) {
Log::getInstance()->error("检测问诊订单执行退款次数失败:抛出异常" . $e->getMessage());
}
Log::getInstance()->info("检测问诊订单执行退款次数成功");
return true;
}
/** /**
* 检测问诊订单分配次数 * 检测问诊订单分配次数
* @param string $order_inquiry_id * @param string $order_inquiry_id

View File

@ -17,6 +17,8 @@ use Hyperf\Amqp\Annotation\Consumer;
use Hyperf\Amqp\Message\ConsumerMessage; use Hyperf\Amqp\Message\ConsumerMessage;
use Hyperf\DbConnection\Db; use Hyperf\DbConnection\Db;
use PhpAmqpLib\Message\AMQPMessage; use PhpAmqpLib\Message\AMQPMessage;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
/** /**
* 取消未接诊问诊订单 * 取消未接诊问诊订单
@ -35,6 +37,13 @@ class CancelUnInquiryOrdersDelayDirectConsumer extends ConsumerMessage
protected string|array $routingKey = 'CancelUnInquiryOrders'; protected string|array $routingKey = 'CancelUnInquiryOrders';
/**
* @param $data
* @param AMQPMessage $message
* @return string
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
public function consumeMessage($data, AMQPMessage $message): string public function consumeMessage($data, AMQPMessage $message): string
{ {
Log::getInstance()->error("开始执行 取消未接诊问诊订单 队列:" . json_encode($data, JSON_UNESCAPED_UNICODE)); Log::getInstance()->error("开始执行 取消未接诊问诊订单 队列:" . json_encode($data, JSON_UNESCAPED_UNICODE));
@ -82,16 +91,16 @@ class CancelUnInquiryOrdersDelayDirectConsumer extends ConsumerMessage
} }
// 取消问诊订单 // 取消问诊订单
$data = array(); $save_data = array();
$data['inquiry_status'] = 7; $save_data['inquiry_status'] = 7;
$data['cancel_time'] = date("Y-m-d H:i:s", time()); $save_data['cancel_time'] = date("Y-m-d H:i:s", time());
$data['cancel_reason'] = 1; // 取消订单原因1:医生未接诊 2:主动取消 3:无可分配医生 4:客服取消 5:支付超时) $save_data['cancel_reason'] = 1; // 取消订单原因1:医生未接诊 2:主动取消 3:无可分配医生 4:客服取消 5:支付超时)
$data['cancel_remarks'] = "医生未接诊"; // 取消订单备注 $save_data['cancel_remarks'] = "医生未接诊"; // 取消订单备注
$data['updated_at'] = date("Y-m-d H:i:s", time()); $save_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array(); $params = array();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id']; $params['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
OrderInquiry::edit($params, $data); OrderInquiry::edit($params, $save_data);
// 恢复优惠卷 // 恢复优惠卷
if (!empty($order_inquiry['coupon_amount_total']) && $order_inquiry['coupon_amount_total'] > 0) { if (!empty($order_inquiry['coupon_amount_total']) && $order_inquiry['coupon_amount_total'] > 0) {
@ -101,40 +110,37 @@ class CancelUnInquiryOrdersDelayDirectConsumer extends ConsumerMessage
$order_inquiry_coupon = OrderInquiryCoupon::getOne($params); $order_inquiry_coupon = OrderInquiryCoupon::getOne($params);
if (!empty($order_inquiry_coupon)) { if (!empty($order_inquiry_coupon)) {
// 恢复优惠卷 // 恢复优惠卷
$data = array(); $save_data = array();
$data['user_coupon_status'] = 0; $save_data['user_coupon_status'] = 0;
$data['coupon_use_date'] = date('Y-m-d H:i:s', time()); $save_data['coupon_use_date'] = date('Y-m-d H:i:s', time());
$params = array(); $params = array();
$params['user_coupon_id'] = $order_inquiry_coupon['user_coupon_id']; $params['user_coupon_id'] = $order_inquiry_coupon['user_coupon_id'];
UserCoupon::edit($params, $data); UserCoupon::edit($params, $save_data);
} }
} }
// 支付状态 // 订单退款
if ($order_inquiry['inquiry_pay_status'] == 2) { if ($order_inquiry['inquiry_pay_status'] == 2) {
// 检测订单退款次数
// 检测问诊订单执行退款次数 // 检测问诊订单执行退款次数
$InquiryService = new InquiryService(); $InquiryService = new InquiryService();
$res = $InquiryService->checkInquiryRefundCount($order_inquiry['order_inquiry_i d']); $res = $InquiryService->checkInquiryRefundCount($order_inquiry['order_inquiry_id']);
if (!$res){ if (!$res){
Db::rollBack(); Db::rollBack();
Log::getInstance()->error("取消未接诊问诊订单失败:超出最大退款次数"); Log::getInstance()->error("取消未接诊问诊订单失败:超出最大退款次数");
return Result::ACK; return Result::ACK;
} }
$InquiryService->inquiryRefund($order_inquiry['order_inquiry_id'], "暂无医生接诊"); $InquiryService->inquiryRefund($order_inquiry['order_inquiry_id'], "医生接诊");
return Result::ACK; return Result::ACK;
} }
// 订单退款
Db::commit(); Db::commit();
} catch (\Exception $e) { } catch (\Exception $e) {
Db::rollBack(); Db::rollBack();
Log::getInstance()->error("取消未接诊问诊订单失败:" . $e->getMessage()); Log::getInstance()->error("取消未接诊问诊订单失败:" . $e->getMessage());
return Result::ACK; return Result::REQUEUE;
} }

View File

@ -272,6 +272,21 @@ class InquiryService extends BaseService
return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败"); return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败");
} }
// 加入未接诊取消订单延迟队列
if (!empty($request_params['doctor_id']) && ($request_params['inquiry_type'] == 1 || $request_params['inquiry_type'] == 3)){
$data = array();
$data['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
$message = new CancelUnpayOrdersDelayDirectProducer($data);
// 快速/购药-5分钟
$message->setDelayMs(1000 * 60 * 60 * 24);
$producer = $this->container->get(Producer::class);
$res = $producer->produce($message);
if (!$res) {
Db::rollBack();
return fail(HttpEnumCode::SERVER_ERROR, "订单创建失败");
}
}
Db::commit(); Db::commit();
} catch (\Exception $e) { } catch (\Exception $e) {
Db::rollBack(); Db::rollBack();