Files
hyperf_service/app/Amqp/Consumer/Order/GoodOrderFinishSuccessorConsumer.php
2025-04-01 18:06:14 +08:00

51 lines
1.3 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Amqp\Consumer\Order;
use App\Lib\Log;
use App\Service\Amqp\Order\GoodOrderFinishSuccessorService;
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;
#[Consumer(exchange: 'GoodOrderFinish', routingKey: 'GoodOrderFinish', queue: 'GoodOrderFinish.successor', name: "GoodOrderFinishSuccessorConsumer", nums: 1)]
class GoodOrderFinishSuccessorConsumer extends ConsumerMessage
{
/**
* @var Type|string 消息类型
*/
protected Type|string $type = Type::DIRECT;
/**
* @var Log
*/
#[Inject]
protected Log $log;
public function consumeMessage($data, AMQPMessage $message): Result
{
if (!$data['order_id']) {
$this->log->error('GoodOrderFinishSuccessorConsumer:error:NoData:'.json_encode($data));
return Result::ACK;
}
try {
$service = new GoodOrderFinishSuccessorService();
$service->orderId = (int)$data['order_id'];
$service->handle();
} catch (Exception $e) {
$this->log->error('GoodOrderFinishSuccessorConsumer:error:'.$e->getMessage().':data:'.json_encode($data));
}
return Result::ACK;
}
}