UNPKG

angular-simple-oidc

Version:

Angular Library implementing Open Id Connect specification. Code Flow, Refresh Tokens, Session Management, Discovery Document.

57 lines 12.1 kB
import { Injectable, Inject } from '@angular/core'; import { switchMap, take, map, withLatestFrom, tap } from 'rxjs/operators'; import { TokenEndpointClientService } from './token-endpoint-client.service'; import { RefreshTokenValidationService, TokenValidationService, TokenUrlService, TokenHelperService, } from 'angular-simple-oidc/core'; import { TokensValidatedEvent, TokensReadyEvent } from './auth.events'; import { TokenStorageService } from './token-storage.service'; import { AUTH_CONFIG_SERVICE } from './providers'; import { ConfigService } from 'angular-simple-oidc/config'; import { EventsService, SimpleOidcInfoEvent } from 'angular-simple-oidc/events'; export class RefreshTokenClient { constructor(config, tokenStorage, tokenUrl, tokenHelper, tokenEndpointClient, refreshTokenValidation, tokenValidation, events) { this.config = config; this.tokenStorage = tokenStorage; this.tokenUrl = tokenUrl; this.tokenHelper = tokenHelper; this.tokenEndpointClient = tokenEndpointClient; this.refreshTokenValidation = refreshTokenValidation; this.tokenValidation = tokenValidation; this.events = events; } requestTokenWithRefreshCode() { return this.tokenStorage.currentState$.pipe(withLatestFrom(this.config.current$), take(1), switchMap(([localState, config]) => { const payload = this.tokenUrl.createRefreshTokenRequestPayload({ clientId: config.clientId, clientSecret: config.clientSecret, refreshToken: localState.refreshToken }); this.events.dispatch(new SimpleOidcInfoEvent(`Refreshing token using refresh code`, { payload, refreshToken: localState.refreshToken })); return this.tokenEndpointClient.call(payload); }), withLatestFrom(this.tokenStorage.currentState$), tap(([result, localState]) => { const originalToken = this.tokenHelper.getPayloadFromToken(localState.originalIdentityToken); this.events.dispatch(new SimpleOidcInfoEvent(`Validating new Identity Token against original`, { result, originalToken })); this.refreshTokenValidation.validateIdToken(originalToken, result.decodedIdToken); }), tap(([result]) => { this.events.dispatch(new SimpleOidcInfoEvent(`Validating access token against at_hash`, { accessToken: result.accessToken, hash: result.decodedIdToken.at_hash })); this.tokenValidation.validateAccessToken(result.accessToken, result.decodedIdToken.at_hash); }), tap(([result]) => this.events.dispatch(new TokensValidatedEvent(result))), switchMap(([result]) => { this.events.dispatch(new SimpleOidcInfoEvent(`Storing new tokens..`, result)); return this.tokenStorage.storeTokens(result) .pipe(map(() => result)); }), tap((result) => this.events.dispatch(new TokensReadyEvent(result)))); } } RefreshTokenClient.decorators = [ { type: Injectable } ]; RefreshTokenClient.ctorParameters = () => [ { type: ConfigService, decorators: [{ type: Inject, args: [AUTH_CONFIG_SERVICE,] }] }, { type: TokenStorageService }, { type: TokenUrlService }, { type: TokenHelperService }, { type: TokenEndpointClientService }, { type: RefreshTokenValidationService }, { type: TokenValidationService }, { type: EventsService } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresh-token-client.service.js","sourceRoot":"","sources":["../../../../projects/angular-simple-oidc/src/lib/refresh-token-client.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport { switchMap, take, map, withLatestFrom, tap } from 'rxjs/operators';\nimport { TokenEndpointClientService } from './token-endpoint-client.service';\nimport {\n    RefreshTokenValidationService,\n    TokenValidationService,\n    TokenUrlService,\n    TokenHelperService,\n    TokenRequestResult,\n} from 'angular-simple-oidc/core';\nimport { TokensValidatedEvent, TokensReadyEvent } from './auth.events';\nimport { TokenStorageService } from './token-storage.service';\nimport { Observable } from 'rxjs';\nimport { AUTH_CONFIG_SERVICE } from './providers';\nimport { ConfigService } from 'angular-simple-oidc/config';\nimport { AuthConfig } from './config/models';\nimport { EventsService, SimpleOidcInfoEvent } from 'angular-simple-oidc/events';\n\n@Injectable()\nexport class RefreshTokenClient {\n\n    constructor(\n        @Inject(AUTH_CONFIG_SERVICE)\n        protected readonly config: ConfigService<AuthConfig>,\n        protected readonly tokenStorage: TokenStorageService,\n        protected readonly tokenUrl: TokenUrlService,\n        protected readonly tokenHelper: TokenHelperService,\n        protected readonly tokenEndpointClient: TokenEndpointClientService,\n        protected readonly refreshTokenValidation: RefreshTokenValidationService,\n        protected readonly tokenValidation: TokenValidationService,\n        protected readonly events: EventsService,\n    ) { }\n\n    public requestTokenWithRefreshCode(): Observable<TokenRequestResult> {\n        return this.tokenStorage.currentState$.pipe(\n            withLatestFrom(this.config.current$),\n            take(1),\n            switchMap(([localState, config]) => {\n                const payload = this.tokenUrl.createRefreshTokenRequestPayload({\n                    clientId: config.clientId,\n                    clientSecret: config.clientSecret,\n                    refreshToken: localState.refreshToken\n                });\n\n                this.events.dispatch(new SimpleOidcInfoEvent(`Refreshing token using refresh code`,\n                    { payload, refreshToken: localState.refreshToken }));\n\n                return this.tokenEndpointClient.call(payload);\n            }),\n            withLatestFrom(this.tokenStorage.currentState$),\n            tap(([result, localState]) => {\n                const originalToken = this.tokenHelper.getPayloadFromToken(localState.originalIdentityToken);\n\n                this.events.dispatch(new SimpleOidcInfoEvent(`Validating new Identity Token against original`,\n                    { result, originalToken }));\n\n                this.refreshTokenValidation.validateIdToken(originalToken, result.decodedIdToken);\n            }),\n            tap(([result]) => {\n                this.events.dispatch(new SimpleOidcInfoEvent(`Validating access token against at_hash`,\n                    { accessToken: result.accessToken, hash: result.decodedIdToken.at_hash }));\n                this.tokenValidation.validateAccessToken(result.accessToken, result.decodedIdToken.at_hash);\n            }),\n            tap(([result]) => this.events.dispatch(new TokensValidatedEvent(result))),\n            switchMap(([result]) => {\n                this.events.dispatch(new SimpleOidcInfoEvent(`Storing new tokens..`, result));\n                return this.tokenStorage.storeTokens(result)\n                    .pipe(map(() => result));\n            }),\n            tap((result) => this.events.dispatch(new TokensReadyEvent(result))),\n        );\n    }\n}\n"]}