mirror of
				https://github.com/elyby/accounts.git
				synced 2025-05-31 14:11:46 +05:30 
			
		
		
		
	Refactor all JWT-related components Replace RS256 with ES256 as a preferred JWT algorithm
		
			
				
	
	
		
			151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| namespace api\controllers;
 | |
| 
 | |
| use api\models\authentication\ForgotPasswordForm;
 | |
| use api\models\authentication\LoginForm;
 | |
| use api\models\authentication\LogoutForm;
 | |
| use api\models\authentication\RecoverPasswordForm;
 | |
| use api\models\authentication\RefreshTokenForm;
 | |
| use common\helpers\Error as E;
 | |
| use common\helpers\StringHelper;
 | |
| use Yii;
 | |
| use yii\filters\AccessControl;
 | |
| use yii\helpers\ArrayHelper;
 | |
| 
 | |
| class AuthenticationController extends Controller {
 | |
| 
 | |
|     public function behaviors(): array {
 | |
|         return ArrayHelper::merge(parent::behaviors(), [
 | |
|             'authenticator' => [
 | |
|                 'only' => ['logout'],
 | |
|             ],
 | |
|             'access' => [
 | |
|                 'class' => AccessControl::class,
 | |
|                 'except' => ['refresh-token'],
 | |
|                 'rules' => [
 | |
|                     [
 | |
|                         'actions' => ['login', 'forgot-password', 'recover-password'],
 | |
|                         'allow' => true,
 | |
|                         'roles' => ['?'],
 | |
|                     ],
 | |
|                     [
 | |
|                         'actions' => ['logout'],
 | |
|                         'allow' => true,
 | |
|                         'roles' => ['@'],
 | |
|                     ],
 | |
|                 ],
 | |
|             ],
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     public function verbs() {
 | |
|         return [
 | |
|             'login' => ['POST'],
 | |
|             'logout' => ['POST'],
 | |
|             'forgot-password' => ['POST'],
 | |
|             'recover-password' => ['POST'],
 | |
|             'refresh-token' => ['POST'],
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     public function actionLogin() {
 | |
|         $model = new LoginForm();
 | |
|         $model->load(Yii::$app->request->post());
 | |
|         if (($result = $model->login()) === null) {
 | |
|             $data = [
 | |
|                 'success' => false,
 | |
|                 'errors' => $model->getFirstErrors(),
 | |
|             ];
 | |
| 
 | |
|             if (ArrayHelper::getValue($data['errors'], 'login') === E::ACCOUNT_NOT_ACTIVATED) {
 | |
|                 $data['data']['email'] = $model->getAccount()->email;
 | |
|             }
 | |
| 
 | |
|             return $data;
 | |
|         }
 | |
| 
 | |
|         return array_merge([
 | |
|             'success' => true,
 | |
|         ], $result->formatAsOAuth2Response());
 | |
|     }
 | |
| 
 | |
|     public function actionLogout() {
 | |
|         $form = new LogoutForm();
 | |
|         $form->logout();
 | |
| 
 | |
|         return [
 | |
|             'success' => true,
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     public function actionForgotPassword() {
 | |
|         $model = new ForgotPasswordForm();
 | |
|         $model->load(Yii::$app->request->post());
 | |
|         if ($model->forgotPassword() === false) {
 | |
|             $data = [
 | |
|                 'success' => false,
 | |
|                 'errors' => $model->getFirstErrors(),
 | |
|             ];
 | |
| 
 | |
|             if (ArrayHelper::getValue($data['errors'], 'login') === E::RECENTLY_SENT_MESSAGE) {
 | |
|                 $emailActivation = $model->getEmailActivation();
 | |
|                 $data['data'] = [
 | |
|                     'canRepeatIn' => $emailActivation->canRepeatIn(),
 | |
|                     'repeatFrequency' => $emailActivation->repeatTimeout,
 | |
|                 ];
 | |
|             }
 | |
| 
 | |
|             return $data;
 | |
|         }
 | |
| 
 | |
|         $emailActivation = $model->getEmailActivation();
 | |
|         $response = [
 | |
|             'success' => true,
 | |
|             'data' => [
 | |
|                 'canRepeatIn' => $emailActivation->canRepeatIn(),
 | |
|                 'repeatFrequency' => $emailActivation->repeatTimeout,
 | |
|             ],
 | |
|         ];
 | |
| 
 | |
|         if ($model->getLoginAttribute() !== 'email') {
 | |
|             $response['data']['emailMask'] = StringHelper::getEmailMask($model->getAccount()->email);
 | |
|         }
 | |
| 
 | |
|         return $response;
 | |
|     }
 | |
| 
 | |
|     public function actionRecoverPassword() {
 | |
|         $model = new RecoverPasswordForm();
 | |
|         $model->load(Yii::$app->request->post());
 | |
|         if (($result = $model->recoverPassword()) === null) {
 | |
|             return [
 | |
|                 'success' => false,
 | |
|                 'errors' => $model->getFirstErrors(),
 | |
|             ];
 | |
|         }
 | |
| 
 | |
|         return array_merge([
 | |
|             'success' => true,
 | |
|         ], $result->formatAsOAuth2Response());
 | |
|     }
 | |
| 
 | |
|     public function actionRefreshToken() {
 | |
|         $model = new RefreshTokenForm();
 | |
|         $model->load(Yii::$app->request->post());
 | |
|         if (($result = $model->renew()) === null) {
 | |
|             return [
 | |
|                 'success' => false,
 | |
|                 'errors' => $model->getFirstErrors(),
 | |
|             ];
 | |
|         }
 | |
| 
 | |
|         $response = $result->formatAsOAuth2Response();
 | |
|         unset($response['refresh_token']);
 | |
| 
 | |
|         return array_merge([
 | |
|             'success' => true,
 | |
|         ], $response);
 | |
|     }
 | |
| 
 | |
| }
 |