测试分配医生
This commit is contained in:
parent
5778f28563
commit
077d42def4
@ -60,41 +60,10 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
// 检测订单分配状态
|
$res = $this->checkInquiryStatus($order_inquiry);
|
||||||
if (!empty($order_inquiry['doctor_id'])) {
|
if (!$res){
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("分配医生队列执行失败:已分配医生");
|
Log::getInstance()->error("分配医生队列执行失败:订单状态错误");
|
||||||
return Result::DROP;// 销毁
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检测订单类型
|
|
||||||
if ($order_inquiry['inquiry_type'] != 2 && $order_inquiry['inquiry_type'] != 4) {
|
|
||||||
Db::rollBack();
|
|
||||||
Log::getInstance()->error("分配医生队列执行失败:订单非快速问诊、问诊购药类型");
|
|
||||||
return Result::DROP;// 销毁
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检测订单退款状态
|
|
||||||
if (in_array($order_inquiry['inquiry_refund_status'], [1, 2, 3])) {
|
|
||||||
Db::rollBack();
|
|
||||||
// 问诊订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭)
|
|
||||||
Log::getInstance()->error("分配医生队列执行失败:订单存在退款");
|
|
||||||
return Result::DROP;// 销毁
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检测订单状态
|
|
||||||
if ($order_inquiry['inquiry_status'] != 2) {
|
|
||||||
Db::rollBack();
|
|
||||||
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
|
||||||
Log::getInstance()->error("分配医生队列执行失败:订单状态错误:当前为" . $order_inquiry['inquiry_status'] . " 无法进行分配");
|
|
||||||
return Result::DROP;// 销毁
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检测订单支付状态
|
|
||||||
if ($order_inquiry['inquiry_pay_status'] != 2) {
|
|
||||||
Db::rollBack();
|
|
||||||
// 支付状态(1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款)
|
|
||||||
Log::getInstance()->error("分配医生队列执行失败:订单支付状态错误:当前为" . $order_inquiry['inquiry_pay_status'] . " 无法进行分配");
|
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,6 +76,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dump("超出5分钟,执行退款");
|
||||||
// 超出5分钟,执行退款
|
// 超出5分钟,执行退款
|
||||||
if ($diff_time > 300) {
|
if ($diff_time > 300) {
|
||||||
Log::getInstance()->error("分配医生队列执行失败:超出5分钟,执行退款");
|
Log::getInstance()->error("分配医生队列执行失败:超出5分钟,执行退款");
|
||||||
@ -128,6 +98,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
return Result::ACK;
|
return Result::ACK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dump("检测当前是否符合系统问诊时间");
|
||||||
// 检测当前是否符合系统问诊时间
|
// 检测当前是否符合系统问诊时间
|
||||||
$inquiryService = new InquiryService();
|
$inquiryService = new InquiryService();
|
||||||
$is_system_time_pass = $inquiryService->checkSystemInquiryTime($order_inquiry['inquiry_type']);
|
$is_system_time_pass = $inquiryService->checkSystemInquiryTime($order_inquiry['inquiry_type']);
|
||||||
@ -153,18 +124,22 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 分配医生
|
// 分配医生
|
||||||
|
dump("分配医生");
|
||||||
$UserDoctorService = new UserDoctorService();
|
$UserDoctorService = new UserDoctorService();
|
||||||
$doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type'],$order_inquiry['patient_id'],$is_system_time_pass);
|
$doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type'],$order_inquiry['patient_id'],$is_system_time_pass);
|
||||||
if (empty($doctor_id)){
|
if (empty($doctor_id)){
|
||||||
// 无合适医生
|
// 无合适医生
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
|
dump("目前没有合适医生");
|
||||||
Log::getInstance()->info("分配医生队列执行:目前没有合适医生");
|
Log::getInstance()->info("分配医生队列执行:目前没有合适医生");
|
||||||
$redis_value = $this->checkAssignCount($order_inquiry['order_inquiry_id']);
|
$redis_value = $this->checkAssignCount($order_inquiry['order_inquiry_id']);
|
||||||
|
dump("111");
|
||||||
|
dump($redis_value);
|
||||||
Log::getInstance()->info("分配医生队列执行:目前没有合适医生" . $redis_value);
|
Log::getInstance()->info("分配医生队列执行:目前没有合适医生" . $redis_value);
|
||||||
// 执行睡眠,防止重复执行队列
|
// 执行睡眠,防止重复执行队列
|
||||||
// 执行规则,第一次30秒,第二次30秒。以30的倍数增加
|
// 执行规则,第一次30秒,第二次30秒。以30的倍数增加
|
||||||
sleep($redis_value * 5);
|
sleep($redis_value * 5);
|
||||||
|
dump("重回队列");
|
||||||
Log::getInstance()->info("分配医生队列执行:重回队列");
|
Log::getInstance()->info("分配医生队列执行:重回队列");
|
||||||
return Result::REQUEUE; // 重回队列
|
return Result::REQUEUE; // 重回队列
|
||||||
}
|
}
|
||||||
@ -261,4 +236,48 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
|
|
||||||
return $redis_value;
|
return $redis_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检测订单状态
|
||||||
|
* @param array|object $order_inquiry
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
private function checkInquiryStatus(array|object $order_inquiry): bool
|
||||||
|
{
|
||||||
|
// 检测订单分配状态
|
||||||
|
if (!empty($order_inquiry['doctor_id'])) {
|
||||||
|
Log::getInstance()->error("分配医生队列执行失败:已分配医生");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检测订单类型
|
||||||
|
if ($order_inquiry['inquiry_type'] != 2 && $order_inquiry['inquiry_type'] != 4) {
|
||||||
|
Log::getInstance()->error("分配医生队列执行失败:订单非快速问诊、问诊购药类型");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检测订单退款状态
|
||||||
|
if (in_array($order_inquiry['inquiry_refund_status'], [1, 2, 3])) {
|
||||||
|
// 问诊订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭)
|
||||||
|
Log::getInstance()->error("分配医生队列执行失败:订单存在退款");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检测订单状态
|
||||||
|
if ($order_inquiry['inquiry_status'] != 2) {
|
||||||
|
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
||||||
|
Log::getInstance()->error("分配医生队列执行失败:订单状态错误:当前为" . $order_inquiry['inquiry_status'] . " 无法进行分配");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检测订单支付状态
|
||||||
|
if ($order_inquiry['inquiry_pay_status'] != 2) {
|
||||||
|
// 支付状态(1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款)
|
||||||
|
Log::getInstance()->error("分配医生队列执行失败:订单支付状态错误:当前为" . $order_inquiry['inquiry_pay_status'] . " 无法进行分配");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user