diff --git a/api/controllers/SignupController.php b/api/controllers/SignupController.php index b7b5fcb..db0853d 100644 --- a/api/controllers/SignupController.php +++ b/api/controllers/SignupController.php @@ -52,20 +52,16 @@ class SignupController extends Controller { public function actionConfirm() { $model = new ConfirmEmailForm(); $model->load(Yii::$app->request->post()); - if (!$model->confirm()) { + if (!($jwt = $model->confirm())) { return [ 'success' => false, 'errors' => $this->normalizeModelErrors($model->getErrors()), ]; } - // TODO: не уверен, что логин должен быть здесь + нужно разобраться с параметрами установки куки авторизации и сессии - $activationCode = $model->getActivationCodeModel(); - $account = $activationCode->account; - Yii::$app->user->login($account); - return [ 'success' => true, + 'jwt' => $jwt, ]; } diff --git a/api/models/ConfirmEmailForm.php b/api/models/ConfirmEmailForm.php index e62641e..c9d454f 100644 --- a/api/models/ConfirmEmailForm.php +++ b/api/models/ConfirmEmailForm.php @@ -35,10 +35,14 @@ class ConfirmEmailForm extends BaseKeyConfirmationForm { $transaction->commit(); } catch (ErrorException $e) { $transaction->rollBack(); - throw $e; + if (YII_DEBUG) { + throw $e; + } else { + return false; + } } - return true; + return $account->getJWT(); } } diff --git a/tests/codeception/api/functional/EmailConfirmationCest.php b/tests/codeception/api/functional/EmailConfirmationCest.php index f503113..c3d563d 100644 --- a/tests/codeception/api/functional/EmailConfirmationCest.php +++ b/tests/codeception/api/functional/EmailConfirmationCest.php @@ -36,6 +36,7 @@ class EmailConfirmationCest { 'success' => true, ]); $I->cantSeeResponseJsonMatchesJsonPath('$.errors'); + $I->canSeeResponseJsonMatchesJsonPath('$.jwt'); } } diff --git a/tests/codeception/api/unit/models/ConfirmEmailFormTest.php b/tests/codeception/api/unit/models/ConfirmEmailFormTest.php index e101fdb..92b9029 100644 --- a/tests/codeception/api/unit/models/ConfirmEmailFormTest.php +++ b/tests/codeception/api/unit/models/ConfirmEmailFormTest.php @@ -34,7 +34,7 @@ class ConfirmEmailFormTest extends DbTestCase { $fixture = $this->emailActivations[0]; $model = $this->createModel($fixture['key']); $this->specify('expect true result', function() use ($model, $fixture) { - expect('model return successful result', $model->confirm())->true(); + expect('model return successful result', $model->confirm())->notEquals(false); expect('email activation key is not exist', EmailActivation::find()->andWhere(['key' => $fixture['key']])->exists())->false(); /** @var Account $user */ $user = Account::findOne($fixture['account_id']);