mirror of
https://github.com/elyby/accounts.git
synced 2025-01-12 15:02:27 +05:30
79bbc12206
Добавлен client_credentials grant для oAuth Рефакторинг структуры OauthScopes чтобы можно было разделить владельца прав на пользовательские и общие (машинные) Исправлена стилистика кода, внедряются фишки PHP 7.1
96 lines
2.7 KiB
PHP
96 lines
2.7 KiB
PHP
<?php
|
|
namespace api\modules\internal\models;
|
|
|
|
use api\models\base\ApiForm;
|
|
use api\modules\internal\helpers\Error as E;
|
|
use common\helpers\Amqp;
|
|
use common\models\Account;
|
|
use common\models\amqp\AccountBanned;
|
|
use PhpAmqpLib\Message\AMQPMessage;
|
|
use Yii;
|
|
use yii\base\ErrorException;
|
|
|
|
class BanForm extends ApiForm {
|
|
|
|
public const DURATION_FOREVER = -1;
|
|
|
|
/**
|
|
* Нереализованный функционал блокировки аккаунта на определённый период времени.
|
|
* Сейчас установка этого параметра ничего не даст, аккаунт будет заблокирован навечно,
|
|
* но, по задумке, здесь можно передать количество секунд, на которое будет
|
|
* заблокирован аккаунт пользователя.
|
|
*
|
|
* @var int
|
|
*/
|
|
public $duration = self::DURATION_FOREVER;
|
|
|
|
/**
|
|
* Нереализованный функционал указания причины блокировки аккаунта.
|
|
*
|
|
* @var string
|
|
*/
|
|
public $message = '';
|
|
|
|
/**
|
|
* @var Account
|
|
*/
|
|
private $account;
|
|
|
|
public function rules(): array {
|
|
return [
|
|
[['duration'], 'integer', 'min' => self::DURATION_FOREVER],
|
|
[['message'], 'string'],
|
|
[['account'], 'validateAccountActivity'],
|
|
];
|
|
}
|
|
|
|
public function getAccount(): Account {
|
|
return $this->account;
|
|
}
|
|
|
|
public function validateAccountActivity() {
|
|
if ($this->account->status === Account::STATUS_BANNED) {
|
|
$this->addError('account', E::ACCOUNT_ALREADY_BANNED);
|
|
}
|
|
}
|
|
|
|
public function ban(): bool {
|
|
if (!$this->validate()) {
|
|
return false;
|
|
}
|
|
|
|
$transaction = Yii::$app->db->beginTransaction();
|
|
|
|
$account = $this->account;
|
|
$account->status = Account::STATUS_BANNED;
|
|
if (!$account->save()) {
|
|
throw new ErrorException('Cannot ban account');
|
|
}
|
|
|
|
$this->createTask();
|
|
|
|
$transaction->commit();
|
|
|
|
return true;
|
|
}
|
|
|
|
public function createTask(): void {
|
|
$model = new AccountBanned();
|
|
$model->accountId = $this->account->id;
|
|
$model->duration = $this->duration;
|
|
$model->message = $this->message;
|
|
|
|
$message = Amqp::getInstance()->prepareMessage($model, [
|
|
'delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT,
|
|
]);
|
|
|
|
Amqp::sendToEventsExchange('accounts.account-banned', $message);
|
|
}
|
|
|
|
public function __construct(Account $account, array $config = []) {
|
|
$this->account = $account;
|
|
parent::__construct($config);
|
|
}
|
|
|
|
}
|