84 lines
2.9 KiB
PHP
84 lines
2.9 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Amqp\Consumer;
|
|
|
|
use App\Amqp\Producer\DetectionCompleteDelayDirectProducer;
|
|
use App\Exception\BusinessException;
|
|
use App\Model\OrderDetection;
|
|
use App\Services\InquiryService;
|
|
use App\Utils\Log;
|
|
use Hyperf\Amqp\Message\ConsumerDelayedMessageTrait;
|
|
use Hyperf\Amqp\Message\ProducerDelayedMessageTrait;
|
|
use Hyperf\Amqp\Message\Type;
|
|
use Hyperf\Amqp\Producer;
|
|
use Hyperf\Amqp\Result;
|
|
use Hyperf\Amqp\Annotation\Consumer;
|
|
use Hyperf\Amqp\Message\ConsumerMessage;
|
|
use Hyperf\DbConnection\Db;
|
|
use PhpAmqpLib\Message\AMQPMessage;
|
|
|
|
#[Consumer(nums: 1)]
|
|
class DetectionCompleteDelayDirectConsumer extends ConsumerMessage
|
|
{
|
|
use ProducerDelayedMessageTrait;
|
|
use ConsumerDelayedMessageTrait;
|
|
|
|
protected string $exchange = 'amqp.delay.direct';
|
|
|
|
protected ?string $queue = 'detection.complete.delay.queue';
|
|
|
|
protected string $type = Type::DIRECT; //Type::FANOUT;
|
|
|
|
protected string|array $routingKey = 'DetectionComplete';
|
|
|
|
public function consumeMessage($data, AMQPMessage $message): string
|
|
{
|
|
Log::getInstance("queue-DetectionComplete")->info("开始:" . json_encode($data, JSON_UNESCAPED_UNICODE));
|
|
|
|
// 获取检测订单数据
|
|
$params = array();
|
|
$params['detection_no'] = $data['detection_no'];
|
|
$order_detection = OrderDetection::getOne($params);
|
|
if (empty($order_detection)){
|
|
Log::getInstance("queue-DoctorNotYetInquiry")->error("非法订单");
|
|
return Result::ACK;
|
|
}
|
|
|
|
try {
|
|
// 检测当前医生是否和患者存在未完成问诊订单
|
|
$InquiryService = new InquiryService();
|
|
$order_inquiry = $InquiryService->checkPatientDoctorProgressInquiry($order_detection['user_id'],$order_detection['doctor_id']);
|
|
if (!empty($order_inquiry)){
|
|
// 存在未完成订单
|
|
// 获取现在时间距离订单结束时间的时间差
|
|
$time_diff = $InquiryService->getInquiryFinishTimeDiff($order_inquiry);
|
|
|
|
// 计算时间并重新加入队列
|
|
$queue_data = array();
|
|
$queue_data['order_inquiry_id'] = $data['order_inquiry_id'];
|
|
|
|
$message = new DetectionCompleteDelayDirectProducer($queue_data);
|
|
$message->setDelayMs(1000 * $time_diff);
|
|
$producer = $this->container->get(Producer::class);
|
|
$res = $producer->produce($message);
|
|
if (!$res) {
|
|
Db::rollBack();
|
|
Log::getInstance()->error("处理用户优惠卷过期队列 执行失败:未到过期时间,重新添加队列失败");
|
|
return Result::REQUEUE;
|
|
}
|
|
|
|
return Result::DROP;
|
|
}
|
|
|
|
}catch (\Throwable $e){
|
|
Log::getInstance("queue-DoctorNotYetInquiry")->error($e->getMessage());
|
|
return Result::DROP; // 重回队列
|
|
}
|
|
|
|
|
|
return Result::ACK;
|
|
}
|
|
}
|