mirror of
https://github.com/elyby/accounts.git
synced 2025-01-13 15:32:08 +05:30
Добавлен внутренний API для получения информации об аккаунте
This commit is contained in:
parent
559c266748
commit
9a38481f7d
@ -9,6 +9,7 @@ use common\models\Account;
|
|||||||
use common\models\OauthScope as S;
|
use common\models\OauthScope as S;
|
||||||
use Yii;
|
use Yii;
|
||||||
use yii\helpers\ArrayHelper;
|
use yii\helpers\ArrayHelper;
|
||||||
|
use yii\web\BadRequestHttpException;
|
||||||
use yii\web\NotFoundHttpException;
|
use yii\web\NotFoundHttpException;
|
||||||
|
|
||||||
class AccountsController extends Controller {
|
class AccountsController extends Controller {
|
||||||
@ -26,6 +27,11 @@ class AccountsController extends Controller {
|
|||||||
'allow' => true,
|
'allow' => true,
|
||||||
'roles' => [S::ACCOUNT_BLOCK],
|
'roles' => [S::ACCOUNT_BLOCK],
|
||||||
],
|
],
|
||||||
|
[
|
||||||
|
'actions' => ['info'],
|
||||||
|
'allow' => true,
|
||||||
|
'roles' => [S::INTERNAL_ACCOUNT_INFO],
|
||||||
|
],
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
@ -34,6 +40,7 @@ class AccountsController extends Controller {
|
|||||||
public function verbs() {
|
public function verbs() {
|
||||||
return [
|
return [
|
||||||
'ban' => ['POST', 'DELETE'],
|
'ban' => ['POST', 'DELETE'],
|
||||||
|
'info' => ['GET'],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,6 +53,29 @@ class AccountsController extends Controller {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionInfo(int $id = null, string $username = null, string $uuid = null) {
|
||||||
|
if ($id !== null) {
|
||||||
|
$account = Account::findOne($id);
|
||||||
|
} elseif ($username !== null) {
|
||||||
|
$account = Account::findOne(['username' => $username]);
|
||||||
|
} elseif ($uuid !== null) {
|
||||||
|
$account = Account::findOne(['uuid' => $uuid]);
|
||||||
|
} else {
|
||||||
|
throw new BadRequestHttpException('One of the required get params must be presented.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($account === null) {
|
||||||
|
throw new NotFoundHttpException('User by provided param not found.');
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
'id' => $account->id,
|
||||||
|
'uuid' => $account->uuid,
|
||||||
|
'email' => $account->email,
|
||||||
|
'username' => $account->username,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
private function banAccount(Account $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());
|
||||||
|
@ -28,6 +28,11 @@ class OauthScope {
|
|||||||
* @owner machine
|
* @owner machine
|
||||||
*/
|
*/
|
||||||
const ACCOUNT_BLOCK = 'account_block';
|
const ACCOUNT_BLOCK = 'account_block';
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
* @owner machine
|
||||||
|
*/
|
||||||
|
const INTERNAL_ACCOUNT_INFO = 'internal_account_info';
|
||||||
|
|
||||||
public static function find(): OauthScopeQuery {
|
public static function find(): OauthScopeQuery {
|
||||||
return new OauthScopeQuery(static::queryScopes());
|
return new OauthScopeQuery(static::queryScopes());
|
||||||
|
@ -18,4 +18,9 @@ class InternalRoute extends BasePage {
|
|||||||
$this->actor->sendDELETE($this->getUrl());
|
$this->actor->sendDELETE($this->getUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function info(string $param, string $value) {
|
||||||
|
$this->route = '/internal/accounts/info';
|
||||||
|
$this->actor->sendGET($this->getUrl(), [$param => $value]);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
74
tests/codeception/api/functional/internal/InfoCest.php
Normal file
74
tests/codeception/api/functional/internal/InfoCest.php
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
<?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 InfoCest {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var InternalRoute
|
||||||
|
*/
|
||||||
|
private $route;
|
||||||
|
|
||||||
|
public function _before(FunctionalTester $I) {
|
||||||
|
$this->route = new InternalRoute($I);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetInfoById(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::INTERNAL_ACCOUNT_INFO]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->info('id', 1);
|
||||||
|
$this->expectSuccessResponse($I);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetInfoByUuid(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::INTERNAL_ACCOUNT_INFO]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->info('uuid', 'df936908-b2e1-544d-96f8-2977ec213022');
|
||||||
|
$this->expectSuccessResponse($I);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetInfoByUsername(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::INTERNAL_ACCOUNT_INFO]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->info('username', 'admin');
|
||||||
|
$this->expectSuccessResponse($I);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidParams(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::INTERNAL_ACCOUNT_INFO]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->info('', '');
|
||||||
|
$I->canSeeResponseCodeIs(400);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAccountNotFound(OauthSteps $I) {
|
||||||
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant([S::INTERNAL_ACCOUNT_INFO]);
|
||||||
|
$I->amBearerAuthenticated($accessToken);
|
||||||
|
|
||||||
|
$this->route->info('username', 'this-user-not-exists');
|
||||||
|
$I->canSeeResponseCodeIs(404);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param OauthSteps $I
|
||||||
|
*/
|
||||||
|
private function expectSuccessResponse(OauthSteps $I): void {
|
||||||
|
$I->canSeeResponseCodeIs(200);
|
||||||
|
$I->canSeeResponseIsJson();
|
||||||
|
$I->canSeeResponseContainsJson([
|
||||||
|
'id' => 1,
|
||||||
|
'uuid' => 'df936908-b2e1-544d-96f8-2977ec213022',
|
||||||
|
'email' => 'admin@ely.by',
|
||||||
|
'username' => 'Admin',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user