Files
hyperf_service/app/Amqp/Consumer/CancelOrderConsumer.php
2025-03-27 10:03:11 +08:00

120 lines
3.3 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Amqp\Consumer;
use App\Constants\Common\CouponCode;
use App\Constants\Common\OrderCode;
use App\Lib\Log;
use App\Model\Order;
use App\Model\OrderGood;
use App\Model\UserCoupon;
use App\Service\ServiceTrait\Api\CouponTrait;
use App\Service\ServiceTrait\Api\OrderTrait;
use Exception;
use Hyperf\Amqp\Message\ConsumerDelayedMessageTrait;
use Hyperf\Amqp\Message\ProducerDelayedMessageTrait;
use Hyperf\Amqp\Message\Type;
use Hyperf\Amqp\Result;
use Hyperf\Amqp\Annotation\Consumer;
use Hyperf\Amqp\Message\ConsumerMessage;
use Hyperf\DbConnection\Db;
use Hyperf\Di\Annotation\Inject;
use PhpAmqpLib\Message\AMQPMessage;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
#[Consumer(exchange: 'OrderCancel', routingKey: 'OrderCancel', queue: 'OrderCancel.delay', name: "CancelOrderConsumer", nums: 1)]
class CancelOrderConsumer extends ConsumerMessage
{
use ProducerDelayedMessageTrait,ConsumerDelayedMessageTrait;
use OrderTrait;
use CouponTrait;
/**
* @var Type|string 消息类型
*/
protected Type|string $type = Type::DIRECT;
/**
* @var Log $log
*/
#[Inject]
protected Log $log;
/**
* @var Order
*/
#[Inject]
protected Order $orderModel;
/**
* @var UserCoupon
*/
#[Inject]
protected UserCoupon $userCouponModel;
/**
* @var OrderGood
*/
#[Inject]
protected OrderGood $orderGoodModel;
/**
* @param $data
* @param AMQPMessage $message
* @return Result
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
public function consumeMessage($data, AMQPMessage $message): Result
{
if (!$data['order_id'] || !$data['type']) {
$this->log->error('CancelOrderConsumer:error:NoData:'.json_encode($data));
return Result::ACK;
}
$orderId = (int)$data['order_id'];
$orderType = (int)$data['type'];
$orderInfo = match ($orderType) {
OrderCode::ORDER_TYPE_GOOD => $this->orderModel->getInfoById($orderId),
default => null,
};
if (empty($orderInfo)) {
$this->log->debug('CancelOrderConsumer:error:NoOrderData:'.json_encode($data));
return Result::ACK;
}
if ($orderInfo->status != OrderCode::WAIT_PAY) {
$this->log->debug('CancelOrderConsumer:error:orderStatusError:order_id:'.$orderId.':order_status:'.$orderInfo->status);
return Result::ACK;
}
try {
Db::beginTransaction();
$this->rollbackCoupon($orderType, $orderInfo);
$orderInfo->status = OrderCode::CANCEL;
$updateGoods = $this->orderGoodModel->where('order_id',$orderInfo->id)->update([
'status' => OrderCode::CANCEL,
]);
if (!$orderInfo->save() || !$updateGoods) throw new Exception('CancelOrderConsumer:error:orderStatusSaveError:'.json_encode($orderInfo->toArray()));
Db::commit();
}catch (Exception $e){
Db::rollback();
$this->log->debug($e->getMessage());
return Result::ACK;
}
$this->sendStockMq($orderInfo->id,OrderCode::CANCEL);
return Result::ACK;
}
}