angular-simple-oidc
Version:
Angular Library implementing Open Id Connect specification. Code Flow, Refresh Tokens, Session Management, Discovery Document.
57 lines • 12.1 kB
JavaScript
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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC3E,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAC7E,OAAO,EACH,6BAA6B,EAC7B,sBAAsB,EACtB,eAAe,EACf,kBAAkB,GAErB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAE3D,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAGhF,MAAM,OAAO,kBAAkB;IAE3B,YAEuB,MAAiC,EACjC,YAAiC,EACjC,QAAyB,EACzB,WAA+B,EAC/B,mBAA+C,EAC/C,sBAAqD,EACrD,eAAuC,EACvC,MAAqB;QAPrB,WAAM,GAAN,MAAM,CAA2B;QACjC,iBAAY,GAAZ,YAAY,CAAqB;QACjC,aAAQ,GAAR,QAAQ,CAAiB;QACzB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,wBAAmB,GAAnB,mBAAmB,CAA4B;QAC/C,2BAAsB,GAAtB,sBAAsB,CAA+B;QACrD,oBAAe,GAAf,eAAe,CAAwB;QACvC,WAAM,GAAN,MAAM,CAAe;IACxC,CAAC;IAEE,2BAA2B;QAC9B,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CACvC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EACpC,IAAI,CAAC,CAAC,CAAC,EACP,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,EAAE,EAAE;YAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,gCAAgC,CAAC;gBAC3D,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,YAAY,EAAE,MAAM,CAAC,YAAY;gBACjC,YAAY,EAAE,UAAU,CAAC,YAAY;aACxC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,qCAAqC,EAC9E,EAAE,OAAO,EAAE,YAAY,EAAE,UAAU,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;YAEzD,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClD,CAAC,CAAC,EACF,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,EAC/C,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE;YACzB,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;YAE7F,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,gDAAgD,EACzF,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;YAEhC,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,aAAa,EAAE,MAAM,CAAC,cAAc,CAAC,CAAC;QACtF,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE;YACb,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,yCAAyC,EAClF,EAAE,WAAW,EAAE,MAAM,CAAC,WAAW,EAAE,IAAI,EAAE,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YAC/E,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QAChG,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,EACzE,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE;YACnB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC,CAAC;YAC9E,OAAO,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,MAAM,CAAC;iBACvC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,CACtE,CAAC;IACN,CAAC;;;YArDJ,UAAU;;;YAJF,aAAa,uBAQb,MAAM,SAAC,mBAAmB;YAX1B,mBAAmB;YALxB,eAAe;YACf,kBAAkB;YALb,0BAA0B;YAE/B,6BAA6B;YAC7B,sBAAsB;YAWjB,aAAa","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"]}