Files
hyperf_service/app/Amqp/Consumer/Refund/GoodOrderRefundFinishConsumer.php
2025-03-26 16:55:31 +08:00

68 lines
2.0 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Amqp\Consumer\Refund;
use App\Constants\Common\OrderCode;
use App\Exception\ErrException;
use App\Lib\Log;
use App\Service\Amqp\Refund\RefundGoodOrderFinishService;
use Exception;
use Hyperf\Amqp\Message\Type;
use Hyperf\Amqp\Result;
use Hyperf\Amqp\Annotation\Consumer;
use Hyperf\Amqp\Message\ConsumerMessage;
use Hyperf\Di\Annotation\Inject;
use PhpAmqpLib\Message\AMQPMessage;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
#[Consumer(exchange: 'GoodOrderRefundFinish', routingKey: 'GoodOrderRefundFinish', queue: 'GoodOrderRefundFinish.refund', name: "GoodOrderRefundFinishConsumer", nums: 1)]
class GoodOrderRefundFinishConsumer extends ConsumerMessage
{
/**
* @var Type|string 消息类型
*/
protected Type|string $type = Type::DIRECT;
/**
* @var Log
*/
#[Inject]
protected Log $log;
/**
* @param $data
* @param AMQPMessage $message
* @return Result
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
public function consumeMessage($data, AMQPMessage $message): Result
{
if (!$data['refund_order_sno'] || !$data['pay_type']) {
$this->log->error('GoodOrderRefundFinishConsumer:error:NoData:'.json_encode($data));
return Result::ACK;
}
$this->log->callbackLog('GoodOrderRefundFinishConsumer:success:'.json_encode($data));
try {
$service = new RefundGoodOrderFinishService();
$service->orderSno = $data['order_sno'];
$service->payType = (int)$data['pay_type'];
$service->callbackData = $data['callback_data'];
$service->orderType = OrderCode::ORDER_TYPE_GOOD;
$service->handle();
} catch (Exception|ErrException $e) {
$this->log->error('GoodOrderRefundFinishConsumer:error:'.$e->getMessage());
}
return Result::ACK;
}
}