mirror of
				https://github.com/elyby/accounts.git
				synced 2025-05-31 14:11:46 +05:30 
			
		
		
		
	
		
			
				
	
	
		
			150 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
		
			4.3 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) {
 | 
						|
                /** @var \common\models\confirmations\ForgotPassword $emailActivation */
 | 
						|
                $emailActivation = $model->getEmailActivation();
 | 
						|
                $data['data'] = [
 | 
						|
                    'canRepeatIn' => $emailActivation->canResendAt()->getTimestamp(),
 | 
						|
                ];
 | 
						|
            }
 | 
						|
 | 
						|
            return $data;
 | 
						|
        }
 | 
						|
 | 
						|
        $emailActivation = $model->getEmailActivation();
 | 
						|
        $response = [
 | 
						|
            'success' => true,
 | 
						|
            'data' => [
 | 
						|
                'canRepeatIn' => $emailActivation->canResendAt()->getTimestamp(),
 | 
						|
            ],
 | 
						|
        ];
 | 
						|
 | 
						|
        if (strpos($model->login, '@') === false) {
 | 
						|
            $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);
 | 
						|
    }
 | 
						|
 | 
						|
}
 |