109 lines
3.0 KiB
PHP
109 lines
3.0 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\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;
|
|
|
|
/**
|
|
* @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:'.json_encode($orderInfo->toArray()));
|
|
return Result::ACK;
|
|
}
|
|
|
|
try {
|
|
Db::beginTransaction();
|
|
|
|
$this->rollbackCoupon($orderType, $orderInfo);
|
|
|
|
$orderInfo->status = OrderCode::CANCEL;
|
|
if (!$orderInfo->save()) 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;
|
|
}
|
|
}
|