增加延迟取消未接诊订单队列
This commit is contained in:
parent
e7bff9c66d
commit
7f7fd558c1
@ -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
|
||||||
|
|||||||
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -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();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user