2017-01-21 04:24:30 +05:30
|
|
|
<?php
|
|
|
|
namespace api\controllers;
|
|
|
|
|
|
|
|
use api\filters\ActiveUserRule;
|
|
|
|
use api\models\profile\TwoFactorAuthForm;
|
|
|
|
use Yii;
|
|
|
|
use yii\filters\AccessControl;
|
|
|
|
use yii\helpers\ArrayHelper;
|
|
|
|
|
|
|
|
class TwoFactorAuthController extends Controller {
|
|
|
|
|
|
|
|
public $defaultAction = 'credentials';
|
|
|
|
|
|
|
|
public function behaviors() {
|
|
|
|
return ArrayHelper::merge(parent::behaviors(), [
|
|
|
|
'access' => [
|
|
|
|
'class' => AccessControl::class,
|
|
|
|
'rules' => [
|
|
|
|
[
|
|
|
|
'class' => ActiveUserRule::class,
|
|
|
|
'actions' => [
|
|
|
|
'credentials',
|
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function actionCredentials() {
|
|
|
|
$account = Yii::$app->user->identity;
|
|
|
|
$model = new TwoFactorAuthForm($account);
|
|
|
|
|
|
|
|
return $model->getCredentials();
|
|
|
|
}
|
|
|
|
|
2017-01-21 04:58:26 +05:30
|
|
|
public function actionActivate() {
|
|
|
|
$account = Yii::$app->user->identity;
|
|
|
|
$model = new TwoFactorAuthForm($account, ['scenario' => TwoFactorAuthForm::SCENARIO_ACTIVATE]);
|
|
|
|
if (!$model->activate()) {
|
|
|
|
return [
|
|
|
|
'success' => false,
|
|
|
|
'errors' => $model->getFirstErrors(),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
'success' => true,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function actionDisable() {
|
|
|
|
$account = Yii::$app->user->identity;
|
|
|
|
$model = new TwoFactorAuthForm($account, ['scenario' => TwoFactorAuthForm::SCENARIO_DISABLE]);
|
|
|
|
if (!$model->disable()) {
|
|
|
|
return [
|
|
|
|
'success' => false,
|
|
|
|
'errors' => $model->getFirstErrors(),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
'success' => true,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2017-01-21 04:24:30 +05:30
|
|
|
}
|