mirror of
https://github.com/elyby/accounts.git
synced 2024-11-30 02:32:26 +05:30
61 lines
1.6 KiB
PHP
61 lines
1.6 KiB
PHP
<?php
|
||
namespace console\controllers;
|
||
|
||
use Ely\Amqp\ControllerTrait;
|
||
use PhpAmqpLib\Message\AMQPMessage;
|
||
use Yii;
|
||
use yii\console\Controller;
|
||
use yii\db\Exception as YiiDbException;
|
||
use yii\helpers\ArrayHelper;
|
||
use yii\helpers\Inflector;
|
||
use yii\helpers\StringHelper;
|
||
|
||
abstract class AmqpController extends Controller {
|
||
use ControllerTrait {
|
||
callback as _callback;
|
||
}
|
||
|
||
public final function actionIndex() {
|
||
$this->start();
|
||
}
|
||
|
||
public function getRoutesMap() {
|
||
return [];
|
||
}
|
||
|
||
/**
|
||
* Переопределяем метод callback, чтобы избержать логгирования в консоль ошибок,
|
||
* связанных с обвалом того или иного соединения. Это нормально, PHP рождён умирать,
|
||
* а не работать 24/7 в качестве демона.
|
||
*
|
||
* @param AMQPMessage $msg
|
||
* @throws YiiDbException
|
||
*/
|
||
public function callback(AMQPMessage $msg) {
|
||
try {
|
||
$this->_callback($msg);
|
||
} catch (YiiDbException $e) {
|
||
if (StringHelper::startsWith($e->getMessage(), 'Error while sending QUERY packet')) {
|
||
exit(self::EXIT_CODE_ERROR);
|
||
}
|
||
|
||
throw $e;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* @inheritdoc
|
||
*/
|
||
protected function getConnection() {
|
||
return Yii::$app->amqp->getConnection();
|
||
}
|
||
|
||
/**
|
||
* @inheritdoc
|
||
*/
|
||
protected function buildRouteActionName($route) {
|
||
return ArrayHelper::getValue($this->getRoutesMap(), $route, 'route' . Inflector::camelize($route));
|
||
}
|
||
|
||
}
|