51 lines
1.3 KiB
PHP
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;
|
|
}
|
|
}
|