mirror of
https://github.com/elyby/accounts.git
synced 2024-11-30 10:42:16 +05:30
Реализована форма разблокировки аккаунта
This commit is contained in:
parent
b9e5e3a679
commit
6f81c38b7f
@ -4,6 +4,7 @@ namespace api\modules\internal\controllers;
|
|||||||
use api\components\ApiUser\AccessControl;
|
use api\components\ApiUser\AccessControl;
|
||||||
use api\controllers\Controller;
|
use api\controllers\Controller;
|
||||||
use api\modules\internal\models\BanForm;
|
use api\modules\internal\models\BanForm;
|
||||||
|
use api\modules\internal\models\PardonForm;
|
||||||
use common\models\Account;
|
use common\models\Account;
|
||||||
use common\models\OauthScope as S;
|
use common\models\OauthScope as S;
|
||||||
use Yii;
|
use Yii;
|
||||||
@ -30,8 +31,22 @@ class AccountsController extends Controller {
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function verbs() {
|
||||||
|
return [
|
||||||
|
'ban' => ['POST', 'DELETE'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
public function actionBan(int $accountId) {
|
public function actionBan(int $accountId) {
|
||||||
$account = $this->findAccount($accountId);
|
$account = $this->findAccount($accountId);
|
||||||
|
if (Yii::$app->request->isPost) {
|
||||||
|
return $this->banAccount($account);
|
||||||
|
} else {
|
||||||
|
return $this->pardonAccount($account);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function banAccount(Account $account) {
|
||||||
$model = new BanForm($account);
|
$model = new BanForm($account);
|
||||||
$model->load(Yii::$app->request->post());
|
$model->load(Yii::$app->request->post());
|
||||||
if (!$model->ban()) {
|
if (!$model->ban()) {
|
||||||
@ -46,6 +61,21 @@ class AccountsController extends Controller {
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function pardonAccount(Account $account) {
|
||||||
|
$model = new PardonForm($account);
|
||||||
|
$model->load(Yii::$app->request->post());
|
||||||
|
if (!$model->pardon()) {
|
||||||
|
return [
|
||||||
|
'success' => false,
|
||||||
|
'errors' => $model->getFirstErrors(),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'success' => true,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
private function findAccount(int $accountId): Account {
|
private function findAccount(int $accountId): Account {
|
||||||
$account = Account::findOne($accountId);
|
$account = Account::findOne($accountId);
|
||||||
if ($account === null) {
|
if ($account === null) {
|
||||||
|
@ -4,5 +4,6 @@ namespace api\modules\internal\helpers;
|
|||||||
final class Error {
|
final class Error {
|
||||||
|
|
||||||
public const ACCOUNT_ALREADY_BANNED = 'error.account_already_banned';
|
public const ACCOUNT_ALREADY_BANNED = 'error.account_already_banned';
|
||||||
|
public const ACCOUNT_NOT_BANNED = 'error.account_not_banned';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
72
api/modules/internal/models/PardonForm.php
Normal file
72
api/modules/internal/models/PardonForm.php
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
<?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\AccountPardoned;
|
||||||
|
use PhpAmqpLib\Message\AMQPMessage;
|
||||||
|
use Yii;
|
||||||
|
use yii\base\ErrorException;
|
||||||
|
|
||||||
|
class PardonForm extends ApiForm {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var Account
|
||||||
|
*/
|
||||||
|
private $account;
|
||||||
|
|
||||||
|
public function rules(): array {
|
||||||
|
return [
|
||||||
|
[['account'], 'validateAccountBanned'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAccount(): Account {
|
||||||
|
return $this->account;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateAccountBanned(): void {
|
||||||
|
if ($this->account->status !== Account::STATUS_BANNED) {
|
||||||
|
$this->addError('account', E::ACCOUNT_NOT_BANNED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function pardon(): bool {
|
||||||
|
if (!$this->validate()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transaction = Yii::$app->db->beginTransaction();
|
||||||
|
|
||||||
|
$account = $this->account;
|
||||||
|
$account->status = Account::STATUS_ACTIVE;
|
||||||
|
if (!$account->save()) {
|
||||||
|
throw new ErrorException('Cannot pardon account');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->createTask();
|
||||||
|
|
||||||
|
$transaction->commit();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function createTask(): void {
|
||||||
|
$model = new AccountPardoned();
|
||||||
|
$model->accountId = $this->account->id;
|
||||||
|
|
||||||
|
$message = Amqp::getInstance()->prepareMessage($model, [
|
||||||
|
'delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT,
|
||||||
|
]);
|
||||||
|
|
||||||
|
Amqp::sendToEventsExchange('accounts.account-pardoned', $message);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __construct(Account $account, array $config = []) {
|
||||||
|
$this->account = $account;
|
||||||
|
parent::__construct($config);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
10
common/models/amqp/AccountPardoned.php
Normal file
10
common/models/amqp/AccountPardoned.php
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?php
|
||||||
|
namespace common\models\amqp;
|
||||||
|
|
||||||
|
use yii\base\Object;
|
||||||
|
|
||||||
|
class AccountPardoned extends Object {
|
||||||
|
|
||||||
|
public $accountId;
|
||||||
|
|
||||||
|
}
|
@ -13,4 +13,9 @@ class InternalRoute extends BasePage {
|
|||||||
$this->actor->sendPOST($this->getUrl());
|
$this->actor->sendPOST($this->getUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function pardon($accountId) {
|
||||||
|
$this->route = '/internal/accounts/' . $accountId . '/ban';
|
||||||
|
$this->actor->sendDELETE($this->getUrl());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
47
tests/codeception/api/functional/internal/PardonCest.php
Normal file
47
tests/codeception/api/functional/internal/PardonCest.php
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
namespace tests\codeception\api\functional\internal;
|
||||||
|
|
||||||
|
use common\models\OauthScope as S;
|
||||||
|
use tests\codeception\api\_pages\InternalRoute;
|
||||||
|
use tests\codeception\api\functional\_steps\OauthSteps;
|
||||||
|
use tests\codeception\api\FunctionalTester;
|
||||||
|
|
||||||
|
class PardonCest {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var InternalRoute
|
||||||
|
*/
|
||||||
|
private $route;
|
||||||
|
|
||||||
|
public function _before(FunctionalTester $I) {
|
||||||
|
$this->route = new InternalRoute($I);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testPardonAccount(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::ACCOUNT_BLOCK]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->pardon(10);
|
||||||
|
$I->canSeeResponseCodeIs(200);
|
||||||
|
$I->canSeeResponseIsJson();
|
||||||
|
$I->canSeeResponseContainsJson([
|
||||||
|
'success' => true,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testPardonNotBannedAccount(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::ACCOUNT_BLOCK]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->pardon(1);
|
||||||
|
$I->canSeeResponseCodeIs(200);
|
||||||
|
$I->canSeeResponseIsJson();
|
||||||
|
$I->canSeeResponseContainsJson([
|
||||||
|
'success' => false,
|
||||||
|
'errors' => [
|
||||||
|
'account' => 'error.account_not_banned',
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,52 @@
|
|||||||
|
<?php
|
||||||
|
namespace tests\codeception\api\unit\modules\internal\models;
|
||||||
|
|
||||||
|
use api\modules\internal\helpers\Error as E;
|
||||||
|
use api\modules\internal\models\PardonForm;
|
||||||
|
use common\models\Account;
|
||||||
|
use tests\codeception\api\unit\TestCase;
|
||||||
|
|
||||||
|
class PardonFormTest extends TestCase {
|
||||||
|
|
||||||
|
public function testValidateAccountBanned() {
|
||||||
|
$account = new Account();
|
||||||
|
$account->status = Account::STATUS_BANNED;
|
||||||
|
$form = new PardonForm($account);
|
||||||
|
$form->validateAccountBanned();
|
||||||
|
$this->assertEmpty($form->getErrors('account'));
|
||||||
|
|
||||||
|
$account = new Account();
|
||||||
|
$account->status = Account::STATUS_ACTIVE;
|
||||||
|
$form = new PardonForm($account);
|
||||||
|
$form->validateAccountBanned();
|
||||||
|
$this->assertEquals([E::ACCOUNT_NOT_BANNED], $form->getErrors('account'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testPardon() {
|
||||||
|
/** @var Account|\PHPUnit_Framework_MockObject_MockObject $account */
|
||||||
|
$account = $this->getMockBuilder(Account::class)
|
||||||
|
->setMethods(['save'])
|
||||||
|
->getMock();
|
||||||
|
|
||||||
|
$account->expects($this->once())
|
||||||
|
->method('save')
|
||||||
|
->willReturn(true);
|
||||||
|
|
||||||
|
$account->status = Account::STATUS_BANNED;
|
||||||
|
$model = new PardonForm($account);
|
||||||
|
$this->assertTrue($model->pardon());
|
||||||
|
$this->assertEquals(Account::STATUS_ACTIVE, $account->status);
|
||||||
|
$this->tester->canSeeAmqpMessageIsCreated('events');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreateTask() {
|
||||||
|
$account = new Account();
|
||||||
|
$account->id = 3;
|
||||||
|
|
||||||
|
$model = new PardonForm($account);
|
||||||
|
$model->createTask();
|
||||||
|
$message = json_decode($this->tester->grabLastSentAmqpMessage('events')->body, true);
|
||||||
|
$this->assertSame(3, $message['accountId']);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user