修改分配医生

This commit is contained in:
wucongxing8150 2024-04-28 11:50:45 +08:00
parent 08f71a2d5b
commit 1fd14e5aca

View File

@ -52,85 +52,88 @@ class AssignDoctorDelayDirectConsumer extends ConsumerMessage
public function consumeMessage($data, AMQPMessage $message): string public function consumeMessage($data, AMQPMessage $message): string
{ {
return Result::ACK;
Log::getInstance('queue-AssignDoctor')->info(json_encode($data, JSON_UNESCAPED_UNICODE)); Log::getInstance('queue-AssignDoctor')->info(json_encode($data, JSON_UNESCAPED_UNICODE));
// 获取订单数据 // 检测执行次数并处理分配医生失败情况
$params = array(); Db::beginTransaction();
$params['order_inquiry_id'] = $data['order_inquiry_id']; try {
$order_inquiry = OrderInquiry::getOne($params); // 获取订单数据
if (empty($order_inquiry)) { $params = array();
Log::getInstance('queue-AssignDoctor')->error("未查询到对应订单数据"); $params['order_inquiry_id'] = $data['order_inquiry_id'];
return Result::DROP;// 销毁 $order_inquiry = OrderInquiry::getOne($params);
} if (empty($order_inquiry)) {
Log::getInstance('queue-AssignDoctor')->error("未查询到对应订单数据");
return Result::DROP;// 销毁
}
// 获取病例数据 // 检测执行次数
$params = array(); $Utils = new Utils();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id']; $redis_key = "assign_doctor_number_" . $data['order_inquiry_id'];
$order_inquiry_case = OrderInquiryCase::getOne($params); $res = $Utils->checkHandleNumber($redis_key);
if (empty($order_inquiry_case)){ if (!$res) {
Log::getInstance('queue-AssignDoctor')->error("患者病例错误"); Log::getInstance("queue-AssignDoctor")->error("超出最大执行次数或检测错误");
return Result::DROP;// 销毁
}
// 检测订单状态 // 处理分配医生失败
$res = $this->checkInquiryStatus($order_inquiry); $this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
if (!$res){
Log::getInstance('queue-AssignDoctor')->error("订单状态错误");
return Result::DROP;// 销毁
}
// 检测分配时间 Db::commit();
$pay_time = strtotime($order_inquiry['pay_time']); return Result::ACK;
$diff_time = time() - $pay_time; }else{
if ($diff_time < 0) { Db::commit();
Log::getInstance('queue-AssignDoctor')->error("支付时间错误"); }
return Result::DROP;// 销毁 }catch (\Throwable $e){
Db::rollBack();
Log::getInstance("queue-AssignDoctor")->error($e->getMessage());
return Result::REQUEUE;
} }
Db::beginTransaction(); Db::beginTransaction();
try { try {
// 检测当前是否符合系统问诊时间 // 获取病例数据
$params = array();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
$order_inquiry_case = OrderInquiryCase::getOne($params);
if (empty($order_inquiry_case)){
Log::getInstance('queue-AssignDoctor')->error("患者病例错误");
// 处理分配医生失败
$this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
Db::commit();
return Result::DROP;// 销毁
}
// 检测订单状态
$res = $this->checkInquiryStatus($order_inquiry);
if (!$res){
Log::getInstance('queue-AssignDoctor')->error("订单状态错误");
// 处理分配医生失败
$this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
Db::commit();
return Result::DROP;// 销毁
}
// 检测分配时间
$pay_time = strtotime($order_inquiry['pay_time']);
$diff_time = time() - $pay_time;
if ($diff_time < 0) {
Log::getInstance('queue-AssignDoctor')->error("支付时间错误");
// 处理分配医生失败
$this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
Db::commit();
return Result::DROP;// 销毁
}
// 检测当前是否符合系统问诊时间-非坐班时间,执行退款
$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']);
if (!$is_system_time_pass && $order_inquiry['inquiry_type'] == 4){ if (!$is_system_time_pass && $order_inquiry['inquiry_type'] == 4){
// 非坐班时间 // 处理分配医生失败
Log::getInstance("queue-AssignDoctor")->info("非坐班时间,执行退款"); $this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
// 检测执行次数
$Utils = new Utils();
$redis_key = "inquiryRefund" . $order_inquiry['inquiry_no'];
$res = $Utils->checkHandleNumber($redis_key);
if (!$res) {
Db::rollBack();
Log::getInstance("queue-CancelUnInquiryOrders")->error("超出最大执行次数或检测错误");
return Result::ACK;
}
$OrderService = new OrderService();
$OrderService->orderRefund($order_inquiry['inquiry_no'], "无可分配医生");
// 取消订单
$order_data = array();
$order_data['cancel_status'] = 1;
$order_data['cancel_time'] = date("Y-m-d H:i:s", time());
$order_data['cancel_remarks'] = "未分配到合适的医生";
$order_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['order_id'] = $order_inquiry['order_id'];
Order::edit($params, $order_data);
$save_data = array();
$save_data['inquiry_status'] = 7;
$save_data['cancel_time'] = date("Y-m-d H:i:s", time());
$save_data['cancel_reason'] = 3; // 取消订单原因1:医生未接诊 2:主动取消 3:无可分配医生 4:客服取消 5:支付超时)
$save_data['cancel_remarks'] = "未分配到合适的医生"; // 取消订单备注
$save_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
OrderInquiry::edit($params, $save_data);
Db::commit(); Db::commit();
@ -145,46 +148,10 @@ class AssignDoctorDelayDirectConsumer extends ConsumerMessage
return Result::ACK; return Result::ACK;
} }
// 检测分配时间 // 检测分配时间-超出10分钟执行退款
if ($diff_time > 600) { if ($diff_time > 600) {
Log::getInstance("queue-AssignDoctor")->info("超出10分钟执行退款"); // 处理分配医生失败
$this->handleAssignDoctorFail($order_inquiry['inquiry_no']);
// 检测执行次数
$Utils = new Utils();
$redis_key = "inquiryRefund" . $order_inquiry['inquiry_no'];
$res = $Utils->checkHandleNumber($redis_key);
if (!$res) {
Db::rollBack();
Log::getInstance("queue-CancelUnInquiryOrders")->error("超出最大执行次数或检测错误");
return Result::ACK;
}
$OrderService = new OrderService();
$OrderService->orderRefund($order_inquiry['inquiry_no'], "未分配到合适的医生");
// 取消订单
$order_data = array();
$order_data['cancel_status'] = 1;
$order_data['cancel_time'] = date("Y-m-d H:i:s", time());
$order_data['cancel_remarks'] = "未分配到合适的医生";
$order_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['order_id'] = $order_inquiry['order_id'];
Order::edit($params, $order_data);
$save_data = array();
$save_data['inquiry_status'] = 7;
$save_data['cancel_time'] = date("Y-m-d H:i:s", time());
$save_data['cancel_reason'] = 3; // 取消订单原因1:医生未接诊 2:主动取消 3:无可分配医生 4:客服取消 5:支付超时)
$save_data['cancel_remarks'] = "未分配到合适的医生"; // 取消订单备注
$save_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['order_inquiry_id'] = $order_inquiry['order_inquiry_id'];
OrderInquiry::edit($params, $save_data);
Log::getInstance("queue-AssignDoctor")->info("已退款");
Db::commit(); Db::commit();
@ -199,49 +166,18 @@ class AssignDoctorDelayDirectConsumer extends ConsumerMessage
return Result::ACK; return Result::ACK;
} }
// 检测执行次数 // 分配医生
$res = $this->checkHandleNumber($data['order_inquiry_id']); $UserDoctorService = new UserDoctorService();
if (!$res) { $doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type'],$order_inquiry['patient_id'],$is_system_time_pass);
// 超出执行次数后,不再进行分配,按照结束分配时间,重新加入队列。 if (empty($doctor_id)){
Log::getInstance("queue-AssignDoctor")->info("超出最大执行次数或检测错误");
Log::getInstance("queue-AssignDoctor")->info("重新加入延迟队列");
$queue_data = array(); $queue_data = array();
$queue_data['order_inquiry_id'] = $data['order_inquiry_id']; $queue_data['order_inquiry_id'] = $data['order_inquiry_id'];
// 5分钟-支付时间-1s1000支付 此时1004 5-1004-1000 // 5分钟-支付时间-1s1000支付 此时1004 5-1004-1000
$time = 1000 * (300- (time() - $pay_time) - 1); $time = 300- (time() - $pay_time) - 1;
$message = new AssignDoctorDelayDirectProducer($queue_data); $message = new AssignDoctorDelayDirectProducer($queue_data);
$message->setDelayMs($time); $message->setDelayMs(1000 * $time);
$producer = $this->container->get(Producer::class);
$res = $producer->produce($message);
if (!$res) {
Db::rollBack();
Log::getInstance("queue-AssignDoctor")->error("重新加入分配医生队列失败,重回队列");
return Result::REQUEUE;
}
Db::commit();
Log::getInstance("queue-AssignDoctor")->info("结束");
return Result::ACK;
}
Log::getInstance("queue-AssignDoctor")->info("分配医生");
$UserDoctorService = new UserDoctorService();
$doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type'],$order_inquiry['patient_id'],$is_system_time_pass);
if (empty($doctor_id)){
Log::getInstance("queue-AssignDoctor")->info("无合适医生");
Db::rollBack();
Log::getInstance("queue-AssignDoctor")->info("重新加入延迟队列");
$queue_data = array();
$queue_data['order_inquiry_id'] = $data['order_inquiry_id'];
$message = new AssignDoctorDelayDirectProducer($queue_data);
$message->setDelayMs(1000 * 60);
$producer = $this->container->get(Producer::class); $producer = $this->container->get(Producer::class);
$res = $producer->produce($message); $res = $producer->produce($message);
if (!$res) { if (!$res) {
@ -401,4 +337,36 @@ class AssignDoctorDelayDirectConsumer extends ConsumerMessage
return true; return true;
} }
/**
* 处理分配医生失败
* @param string $inquiry_no
* @return void
*/
protected function handleAssignDoctorFail(string $inquiry_no): void
{
$OrderService = new OrderService();
$OrderService->orderRefund($inquiry_no, "无可分配医生");
// 取消订单
$order_data = array();
$order_data['cancel_status'] = 1;
$order_data['cancel_time'] = date("Y-m-d H:i:s", time());
$order_data['cancel_remarks'] = "未分配到合适的医生";
$order_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['order_no'] = $inquiry_no;
Order::edit($params, $order_data);
$save_data = array();
$save_data['inquiry_status'] = 7;
$save_data['cancel_time'] = date("Y-m-d H:i:s", time());
$save_data['cancel_reason'] = 3; // 取消订单原因1:医生未接诊 2:主动取消 3:无可分配医生 4:客服取消 5:支付超时)
$save_data['cancel_remarks'] = "未分配到合适的医生"; // 取消订单备注
$save_data['updated_at'] = date("Y-m-d H:i:s", time());
$params = array();
$params['inquiry_no'] = $inquiry_no;
OrderInquiry::edit($params, $save_data);
}
} }