From b64537beed0ed94fa6a47ef0291ceef58508b064 Mon Sep 17 00:00:00 2001 From: Dmitry Nehaychik <4dmitr@gmail.com> Date: Tue, 11 Sep 2018 16:37:24 +0300 Subject: [PATCH] fix(auth): fix `isAuthenticatedOrRefresh` to not refresh token with no value --- src/framework/auth/services/auth.service.ts | 2 +- src/framework/auth/services/auth.spec.ts | 22 ++++++++++++++++++--- 2 files changed, 20 insertions(+), 4 deletions(-) diff --git a/src/framework/auth/services/auth.service.ts b/src/framework/auth/services/auth.service.ts index de464dc837..69822c6a64 100644 --- a/src/framework/auth/services/auth.service.ts +++ b/src/framework/auth/services/auth.service.ts @@ -51,7 +51,7 @@ export class NbAuthService { return this.getToken() .pipe( switchMap(token => { - if (!token.isValid()) { + if (!token.isValid() && token.getValue()) { return this.refreshToken(token.getOwnerStrategyName(), token) .pipe( switchMap(res => { diff --git a/src/framework/auth/services/auth.spec.ts b/src/framework/auth/services/auth.spec.ts index 09809821b7..020a43dd78 100644 --- a/src/framework/auth/services/auth.spec.ts +++ b/src/framework/auth/services/auth.spec.ts @@ -31,7 +31,8 @@ describe('auth-service', () => { const resp200 = new HttpResponse({body: {}, status: 200}); const testToken = nbAuthCreateToken(NbAuthSimpleToken, testTokenValue, ownerStrategyName); - const emptyToken = nbAuthCreateToken(NbAuthSimpleToken, null, ownerStrategyName); + const invalidToken = nbAuthCreateToken(NbAuthSimpleToken, null, ownerStrategyName); + const emptyToken = nbAuthCreateToken(NbAuthSimpleToken, null, null); const failResult = new NbAuthResult(false, resp401, @@ -168,7 +169,7 @@ describe('auth-service', () => { spyOn(tokenService, 'get') .and - .returnValues(observableOf(emptyToken), observableOf(testToken)); + .returnValues(observableOf(invalidToken), observableOf(testToken)); authService.isAuthenticatedOrRefresh() .pipe(first()) @@ -187,7 +188,22 @@ describe('auth-service', () => { spyOn(tokenService, 'get') .and - .returnValues(observableOf(emptyToken), observableOf(emptyToken)); + .returnValues(observableOf(invalidToken), observableOf(invalidToken)); + + authService.isAuthenticatedOrRefresh() + .pipe(first()) + .subscribe((isAuth: boolean) => { + expect(spy).toHaveBeenCalled(); + expect(isAuth).toBeFalsy(); + done(); + }); + }, + ); + + it('isAuthenticatedOrRefresh, token doesn\'t exist, strategy refreshToken called, returns false', (done) => { + const spy = spyOn(tokenService, 'get') + .and + .returnValue(observableOf(emptyToken)); authService.isAuthenticatedOrRefresh() .pipe(first())