mirror of
https://github.com/elyby/accounts.git
synced 2024-12-30 00:50:20 +05:30
dd2c4bc413
Все действия, связанные с аккаунтами, теперь вызываются через url `/api/v1/accounts/<id>/<action>`. Добавлена вменяемая система разграничения прав на основе RBAC. Теперь oAuth2 токены генерируются как случайная строка в 40 символов длинной, а не UUID. Исправлен баг с неправильным временем жизни токена в ответе успешного запроса аутентификации. Теперь все unit тесты можно успешно прогнать без наличия интернета.
96 lines
2.6 KiB
PHP
96 lines
2.6 KiB
PHP
<?php
|
|
namespace api\controllers;
|
|
|
|
use api\models\authentication\ConfirmEmailForm;
|
|
use api\models\authentication\RepeatAccountActivationForm;
|
|
use api\models\authentication\RegistrationForm;
|
|
use common\helpers\Error as E;
|
|
use Yii;
|
|
use yii\filters\AccessControl;
|
|
use yii\helpers\ArrayHelper;
|
|
|
|
class SignupController extends Controller {
|
|
|
|
public function behaviors(): array {
|
|
return ArrayHelper::merge(parent::behaviors(), [
|
|
'authenticator' => [
|
|
'except' => ['index', 'repeat-message', 'confirm'],
|
|
],
|
|
'access' => [
|
|
'class' => AccessControl::class,
|
|
'rules' => [
|
|
[
|
|
'actions' => ['index', 'repeat-message', 'confirm'],
|
|
'allow' => true,
|
|
'roles' => ['?'],
|
|
],
|
|
],
|
|
],
|
|
]);
|
|
}
|
|
|
|
public function verbs() {
|
|
return [
|
|
'register' => ['POST'],
|
|
'confirm' => ['POST'],
|
|
'new-message' => ['POST'],
|
|
];
|
|
}
|
|
|
|
public function actionIndex() {
|
|
$model = new RegistrationForm();
|
|
$model->load(Yii::$app->request->post());
|
|
if (!$model->signup()) {
|
|
return [
|
|
'success' => false,
|
|
'errors' => $model->getFirstErrors(),
|
|
];
|
|
}
|
|
|
|
return [
|
|
'success' => true,
|
|
];
|
|
}
|
|
|
|
public function actionRepeatMessage() {
|
|
$model = new RepeatAccountActivationForm();
|
|
$model->load(Yii::$app->request->post());
|
|
if (!$model->sendRepeatMessage()) {
|
|
$response = [
|
|
'success' => false,
|
|
'errors' => $model->getFirstErrors(),
|
|
];
|
|
|
|
if (ArrayHelper::getValue($response['errors'], 'email') === E::RECENTLY_SENT_MESSAGE) {
|
|
$activation = $model->getActivation();
|
|
$response['data'] = [
|
|
'canRepeatIn' => $activation->canRepeatIn(),
|
|
'repeatFrequency' => $activation->repeatTimeout,
|
|
];
|
|
}
|
|
|
|
return $response;
|
|
}
|
|
|
|
return [
|
|
'success' => true,
|
|
];
|
|
}
|
|
|
|
public function actionConfirm() {
|
|
$model = new ConfirmEmailForm();
|
|
$model->load(Yii::$app->request->post());
|
|
if (!($result = $model->confirm())) {
|
|
return [
|
|
'success' => false,
|
|
'errors' => $model->getFirstErrors(),
|
|
];
|
|
}
|
|
|
|
return array_merge([
|
|
'success' => true,
|
|
], $result->getAsResponse());
|
|
}
|
|
|
|
}
|