From e756dbacd6fb793e2281701f1b86a919f7b25964 Mon Sep 17 00:00:00 2001 From: ErickSkrauch Date: Sun, 17 Jul 2016 19:54:33 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A2=D0=BE=D0=BA=D0=B5=D0=BD,=20=D0=B2=D1=8B?= =?UTF-8?q?=D0=BF=D0=B8=D1=81=D0=B0=D0=BD=D0=BD=D1=8B=D0=B9=20=D0=BD=D0=B0?= =?UTF-8?q?=20=D1=81=D0=B5=D1=81=D1=81=D0=B8=D1=8E=20=D0=B1=D0=B5=D0=B7=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=BF=D0=BE=D0=BC=D0=B8=D0=BD=D0=B0=D0=BD=D0=B8?= =?UTF-8?q?=D1=8F=20=D0=B4=D0=BE=D0=BB=D0=B6=D0=B5=D0=BD=20=D0=B8=D1=81?= =?UTF-8?q?=D1=82=D0=B5=D0=BA=D0=B0=D1=82=D1=8C=20=D0=B4=D0=BE=D0=BB=D1=8C?= =?UTF-8?q?=D1=88=D0=B5=20=D0=B2=D1=80=D0=B5=D0=BC=D0=B5=D0=BD=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/components/User/Component.php | 3 +++ api/models/authentication/LoginForm.php | 5 +---- .../api/unit/components/User/ComponentTest.php | 15 +++++++++++++-- 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/api/components/User/Component.php b/api/components/User/Component.php index 0cfbbcd..dd702cd 100644 --- a/api/components/User/Component.php +++ b/api/components/User/Component.php @@ -63,6 +63,9 @@ class Component extends YiiUserComponent { $token->addClaim(new SessionIdClaim($session->id)); } else { $session = null; + // Если мы не сохраняем сессию, то токен должен жить подольше, чтобы + // не прогорала сессия во время работы с аккаунтом + $token->addClaim(new Claim\Expiration(time() + 60 * 60 * 24 * 7)); } $jwt = $this->serializeToken($token); diff --git a/api/models/authentication/LoginForm.php b/api/models/authentication/LoginForm.php index 3462000..f7c0ce9 100644 --- a/api/models/authentication/LoginForm.php +++ b/api/models/authentication/LoginForm.php @@ -78,10 +78,7 @@ class LoginForm extends ApiForm { $account->save(); } - /** @var \api\components\User\Component $component */ - $component = Yii::$app->user; - - return $component->login($account, $this->rememberMe); + return Yii::$app->user->login($account, $this->rememberMe); } protected function getAccountClassName() { diff --git a/tests/codeception/api/unit/components/User/ComponentTest.php b/tests/codeception/api/unit/components/User/ComponentTest.php index 7f70b67..32cb2cf 100644 --- a/tests/codeception/api/unit/components/User/ComponentTest.php +++ b/tests/codeception/api/unit/components/User/ComponentTest.php @@ -9,6 +9,7 @@ use Codeception\Specify; use common\models\AccountSession; use Emarref\Jwt\Algorithm\AlgorithmInterface; use Emarref\Jwt\Claim\ClaimInterface; +use Emarref\Jwt\Claim\Expiration; use Emarref\Jwt\Token; use tests\codeception\api\unit\DbTestCase; use tests\codeception\common\_support\ProtectedCaller; @@ -50,8 +51,13 @@ class ComponentTest extends DbTestCase { $result = $this->component->login($account, false); expect($result)->isInstanceOf(LoginResult::class); expect($result->getSession())->null(); - expect(is_string($result->getJwt()))->true(); expect($result->getIdentity())->equals($account); + $jwt = $result->getJwt(); + expect(is_string($jwt))->true(); + $token = $this->component->parseToken($jwt); + $claim = $token->getPayload()->findClaimByName(Expiration::NAME); + // Токен выписывается на 7 дней, но мы проверим хотя бы на 2 суток + expect($claim->getValue())->greaterThan(time() + 60 * 60 * 24 * 2); }); $this->specify('success get LoginResult object with session value if rememberMe is true', function() { @@ -60,9 +66,14 @@ class ComponentTest extends DbTestCase { $result = $this->component->login($account, true); expect($result)->isInstanceOf(LoginResult::class); expect($result->getSession())->isInstanceOf(AccountSession::class); - expect(is_string($result->getJwt()))->true(); expect($result->getIdentity())->equals($account); expect($result->getSession()->refresh())->true(); + $jwt = $result->getJwt(); + expect(is_string($jwt))->true(); + $token = $this->component->parseToken($jwt); + $claim = $token->getPayload()->findClaimByName(Expiration::NAME); + // Токен выписывается на 1 час, т.к. в дальнейшем он будет рефрешиться + expect($claim->getValue())->lessOrEquals(time() + 3600); }); }