修改退款时数据错误
This commit is contained in:
parent
cfba03797e
commit
63faac8c42
@ -31,9 +31,15 @@ use Psr\Container\NotFoundExceptionInterface;
|
|||||||
class AssignDoctorConsumer extends ConsumerMessage
|
class AssignDoctorConsumer extends ConsumerMessage
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
* @param $data
|
||||||
|
* [
|
||||||
|
* "order_inquiry_id":"问诊订单id"
|
||||||
|
* ]
|
||||||
|
* @param AMQPMessage $message
|
||||||
|
* @return string
|
||||||
* @throws ContainerExceptionInterface
|
* @throws ContainerExceptionInterface
|
||||||
* @throws NotFoundExceptionInterface
|
|
||||||
* @throws GuzzleException
|
* @throws GuzzleException
|
||||||
|
* @throws NotFoundExceptionInterface
|
||||||
*/
|
*/
|
||||||
public function consumeMessage($data, AMQPMessage $message): string
|
public function consumeMessage($data, AMQPMessage $message): string
|
||||||
{
|
{
|
||||||
@ -48,21 +54,21 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
$order_inquiry = OrderInquiry::getOne($params);
|
$order_inquiry = OrderInquiry::getOne($params);
|
||||||
if (empty($order_inquiry)) {
|
if (empty($order_inquiry)) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("队列执行失败原因:未查询到对应订单数据");
|
Log::getInstance()->error("分配医生队列执行失败原因:未查询到对应订单数据");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
// 检测订单分配状态
|
// 检测订单分配状态
|
||||||
if (!empty($order_inquiry['doctor_id'])) {
|
if (!empty($order_inquiry['doctor_id'])) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("队列执行失败原因:已分配医生");
|
Log::getInstance()->error("分配医生队列执行失败原因:已分配医生");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
// 检测订单类型
|
// 检测订单类型
|
||||||
if ($order_inquiry['inquiry_type'] != 2 && $order_inquiry['inquiry_type'] != 4) {
|
if ($order_inquiry['inquiry_type'] != 2 && $order_inquiry['inquiry_type'] != 4) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("队列执行失败原因:订单非快速问诊、问诊购药类型");
|
Log::getInstance()->error("分配医生队列执行失败原因:订单非快速问诊、问诊购药类型");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,7 +76,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
if (in_array($order_inquiry['inquiry_refund_status'], [1, 2, 3])) {
|
if (in_array($order_inquiry['inquiry_refund_status'], [1, 2, 3])) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
// 问诊订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭)
|
// 问诊订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭)
|
||||||
Log::getInstance()->error("队列执行失败原因:订单存在退款");
|
Log::getInstance()->error("分配医生队列执行失败原因:订单存在退款");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,7 +84,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
if ($order_inquiry['inquiry_status'] != 2) {
|
if ($order_inquiry['inquiry_status'] != 2) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
||||||
Log::getInstance()->info("订单状态错误:当前为" . $order_inquiry['inquiry_status'] . " 无法进行分配");
|
Log::getInstance()->info("分配医生队列执行失败原因:订单状态错误:当前为" . $order_inquiry['inquiry_status'] . " 无法进行分配");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,7 +92,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
if ($order_inquiry['inquiry_pay_status'] != 2) {
|
if ($order_inquiry['inquiry_pay_status'] != 2) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
// 支付状态(1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款)
|
// 支付状态(1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款)
|
||||||
Log::getInstance()->info("订单支付状态错误:当前为" . $order_inquiry['inquiry_pay_status'] . " 无法进行分配");
|
Log::getInstance()->info("分配医生队列执行失败原因:订单支付状态错误:当前为" . $order_inquiry['inquiry_pay_status'] . " 无法进行分配");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,7 +101,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
$diff_time = time() - $pay_time;
|
$diff_time = time() - $pay_time;
|
||||||
if ($diff_time < 0) {
|
if ($diff_time < 0) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->info("订单支付状态错误:时间计算错误");
|
Log::getInstance()->info("分配医生队列执行失败原因:订单支付状态错误:时间计算错误");
|
||||||
return Result::DROP;// 销毁
|
return Result::DROP;// 销毁
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,14 +109,14 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
|
|
||||||
if ($diff_time > 300) {
|
if ($diff_time > 300) {
|
||||||
// 超出5分钟,执行退款
|
// 超出5分钟,执行退款
|
||||||
Log::getInstance()->info("超出5分钟,执行退款");
|
Log::getInstance()->info("分配医生队列执行失败原因:超出5分钟,执行退款");
|
||||||
|
|
||||||
$redis_key = "inquiryRefund" . $order_inquiry['order_inquiry_id'];
|
$redis_key = "inquiryRefund" . $order_inquiry['order_inquiry_id'];
|
||||||
$redis_value = $redis->get($redis_key);
|
$redis_value = $redis->get($redis_key);
|
||||||
if (!empty($redis_value)) {
|
if (!empty($redis_value)) {
|
||||||
// 判断退款次数
|
// 判断退款次数
|
||||||
if ($redis_value >= 3) {
|
if ($redis_value >= 3) {
|
||||||
Log::getInstance()->info("退款取消,退款失败次数过多");
|
Log::getInstance()->info("分配医生队列执行失败原因:退款取消,退款失败次数过多");
|
||||||
|
|
||||||
// 加入短信队列
|
// 加入短信队列
|
||||||
|
|
||||||
@ -129,7 +135,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
$redis->set($redis_key, $redis_value);
|
$redis->set($redis_key, $redis_value);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("队列执行失败原因:退款失败,原因:" . $e->getMessage());
|
Log::getInstance()->error("分配医生队列执行失败原因:退款失败,原因:" . $e->getMessage());
|
||||||
return Result::REQUEUE; // 重回队列
|
return Result::REQUEUE; // 重回队列
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -139,7 +145,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
$doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type']);
|
$doctor_id = $UserDoctorService->getInquiryAssignDoctor($order_inquiry['inquiry_type']);
|
||||||
if (empty($doctor_id)) {
|
if (empty($doctor_id)) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("重回队列,目前没有合适医生");
|
Log::getInstance()->error("分配医生队列执行失败原因:重回队列,目前没有合适医生");
|
||||||
|
|
||||||
$redis_key = "AssignDoctor" . $order_inquiry['order_inquiry_id'];
|
$redis_key = "AssignDoctor" . $order_inquiry['order_inquiry_id'];
|
||||||
$redis_value = $redis->get($redis_key);
|
$redis_value = $redis->get($redis_key);
|
||||||
@ -173,7 +179,7 @@ class AssignDoctorConsumer extends ConsumerMessage
|
|||||||
|
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
Db::rollBack();
|
Db::rollBack();
|
||||||
Log::getInstance()->error("队列执行失败原因:" . $e->getMessage());
|
Log::getInstance()->error("分配医生队列执行失败原因:" . $e->getMessage());
|
||||||
return Result::REQUEUE; // 重回队列
|
return Result::REQUEUE; // 重回队列
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -86,6 +86,11 @@ class UserPatientController extends AbstractController
|
|||||||
*/
|
*/
|
||||||
public function putShoppingCart(): ResponseInterface
|
public function putShoppingCart(): ResponseInterface
|
||||||
{
|
{
|
||||||
|
if (!in_array("1", [2, 3, 4, 5])) {
|
||||||
|
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
||||||
|
dump(111);
|
||||||
|
}
|
||||||
|
die;
|
||||||
$request = $this->container->get(UserPatientRequest::class);
|
$request = $this->container->get(UserPatientRequest::class);
|
||||||
$request->scene('putShoppingCart')->validateResolved();
|
$request->scene('putShoppingCart')->validateResolved();
|
||||||
|
|
||||||
|
|||||||
@ -685,7 +685,7 @@ class InquiryService extends BaseService
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 检测问诊订单状态
|
// 检测问诊订单状态
|
||||||
if (!in_array($order_inquiry['inquiry_status'], [2, 3, 4, 5])) {
|
if (!in_array($order_inquiry['inquiry_status'], [2, 3, 4, 5,7])) {
|
||||||
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
// 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消)
|
||||||
throw new BusinessException("订单状态错误");
|
throw new BusinessException("订单状态错误");
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user