UNPKG

angular-simple-oidc

Version:

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

87 lines 13.6 kB
import { Injectable, Inject } from '@angular/core'; import { TokenStorageService } from './token-storage.service'; import { map, tap, switchMap, take, shareReplay } from 'rxjs/operators'; import { OidcCodeFlowClient } from './oidc-code-flow-client.service'; import { TokenHelperService } from 'angular-simple-oidc/core'; import { RefreshTokenClient } from './refresh-token-client.service'; import { EndSessionClientService } from './end-session-client.service'; import { AUTH_CONFIG_SERVICE } from './providers'; import { ConfigService } from 'angular-simple-oidc/config'; import { EventsService } from 'angular-simple-oidc/events'; import { UserInfoClientService } from './user-info-client.service'; import { filterInstanceOf } from 'angular-simple-oidc/operators'; import { TokensReadyEvent } from './auth.events'; export class AuthService { constructor(oidcClient, tokenHelper, tokenStorage, refreshTokenClient, endSessionClient, config, events, userInfoClient) { this.oidcClient = oidcClient; this.tokenHelper = tokenHelper; this.tokenStorage = tokenStorage; this.refreshTokenClient = refreshTokenClient; this.endSessionClient = endSessionClient; this.config = config; this.events = events; this.userInfoClient = userInfoClient; this.userInfo$ = this.events$.pipe(filterInstanceOf(TokensReadyEvent), switchMap(() => this.userInfoClient.getUserInfo()), shareReplay()); } get isLoggedIn$() { return this.tokenStorage.currentState$ .pipe(map(({ accessToken, accessTokenExpiration }) => { if (!accessToken || this.tokenHelper.isTokenExpired(accessTokenExpiration)) { return false; } return true; })); } get accessToken$() { return this.tokenStorage.currentState$ .pipe(map(s => s.accessToken)); } get tokenExpiration$() { return this.tokenStorage.currentState$ .pipe(map(s => new Date(s.accessTokenExpiration))); } get refreshToken$() { return this.tokenStorage.currentState$ .pipe(map(s => s.refreshToken)); } get identityToken$() { return this.tokenStorage.currentState$ .pipe(map(s => s.identityToken)); } get identityTokenDecoded$() { return this.tokenStorage.currentState$ .pipe(map(s => s.decodedIdentityToken)); } get events$() { return this.events.events$; } get errors$() { return this.events.errors$; } startCodeFlow(options) { return this.oidcClient.startCodeFlow(options) .pipe(tap({ error: e => this.events.dispatchError(e) })); } refreshAccessToken() { return this.refreshTokenClient.requestTokenWithRefreshCode() .pipe(tap({ error: e => this.events.dispatchError(e) })); } endSession(postLogoutRedirectUri) { return this.config.current$ .pipe(take(1), switchMap(config => this.endSessionClient.logoutWithRedirect(postLogoutRedirectUri || config.baseUrl)), tap({ error: e => this.events.dispatchError(e) })); } } AuthService.decorators = [ { type: Injectable } ]; AuthService.ctorParameters = () => [ { type: OidcCodeFlowClient }, { type: TokenHelperService }, { type: TokenStorageService }, { type: RefreshTokenClient }, { type: EndSessionClientService }, { type: ConfigService, decorators: [{ type: Inject, args: [AUTH_CONFIG_SERVICE,] }] }, { type: EventsService }, { type: UserInfoClientService } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../projects/angular-simple-oidc/src/lib/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport { TokenStorageService } from './token-storage.service';\nimport { map, tap, switchMap, take, shareReplay } from 'rxjs/operators';\nimport { OidcCodeFlowClient } from './oidc-code-flow-client.service';\nimport { TokenHelperService, DecodedIdentityToken, LocalState, TokenRequestResult } from 'angular-simple-oidc/core';\nimport { RefreshTokenClient } from './refresh-token-client.service';\nimport { EndSessionClientService } from './end-session-client.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, SimpleOidcEvent, SimpleOidcErrorEvent } from 'angular-simple-oidc/events';\nimport { StartCodeFlowParameters, ClaimCollection } from './models';\nimport { UserInfoClientService } from './user-info-client.service';\nimport { filterInstanceOf } from 'angular-simple-oidc/operators';\nimport { TokensReadyEvent } from './auth.events';\n\n@Injectable()\nexport class AuthService {\n\n    public get isLoggedIn$(): Observable<boolean> {\n        return this.tokenStorage.currentState$\n            .pipe(\n                map(({ accessToken, accessTokenExpiration }) => {\n                    if (!accessToken || this.tokenHelper.isTokenExpired(accessTokenExpiration)) {\n                        return false;\n                    }\n\n                    return true;\n                })\n            );\n    }\n\n    public get accessToken$(): Observable<string> {\n        return this.tokenStorage.currentState$\n            .pipe(map(s => s.accessToken));\n    }\n\n    public get tokenExpiration$(): Observable<Date> {\n        return this.tokenStorage.currentState$\n            .pipe(map(s => new Date(s.accessTokenExpiration)));\n    }\n\n    public get refreshToken$(): Observable<string> {\n        return this.tokenStorage.currentState$\n            .pipe(map(s => s.refreshToken));\n    }\n\n    public get identityToken$(): Observable<string> {\n        return this.tokenStorage.currentState$\n            .pipe(map(s => s.identityToken));\n    }\n\n    public get identityTokenDecoded$(): Observable<DecodedIdentityToken> {\n        return this.tokenStorage.currentState$\n            .pipe(map(s => s.decodedIdentityToken));\n    }\n\n    public readonly userInfo$: Observable<ClaimCollection> = this.events$.pipe(\n        filterInstanceOf(TokensReadyEvent),\n        switchMap(() => this.userInfoClient.getUserInfo()),\n        shareReplay()\n    );\n\n    public get events$(): Observable<SimpleOidcEvent> {\n        return this.events.events$;\n    }\n\n    public get errors$(): Observable<SimpleOidcErrorEvent> {\n        return this.events.errors$;\n    }\n\n    constructor(\n        protected readonly oidcClient: OidcCodeFlowClient,\n        protected readonly tokenHelper: TokenHelperService,\n        protected readonly tokenStorage: TokenStorageService,\n        protected readonly refreshTokenClient: RefreshTokenClient,\n        protected readonly endSessionClient: EndSessionClientService,\n        @Inject(AUTH_CONFIG_SERVICE)\n        protected readonly config: ConfigService<AuthConfig>,\n        protected readonly events: EventsService,\n        protected readonly userInfoClient: UserInfoClientService\n    ) { }\n\n    public startCodeFlow(options?: StartCodeFlowParameters): Observable<LocalState> {\n        return this.oidcClient.startCodeFlow(options)\n            .pipe(tap({ error: e => this.events.dispatchError(e) }));\n    }\n\n    public refreshAccessToken(): Observable<TokenRequestResult> {\n        return this.refreshTokenClient.requestTokenWithRefreshCode()\n            .pipe(tap({ error: e => this.events.dispatchError(e) }));\n    }\n\n    public endSession(postLogoutRedirectUri?: string) {\n        return this.config.current$\n            .pipe(\n                take(1),\n                switchMap(config => this.endSessionClient.logoutWithRedirect(postLogoutRedirectUri || config.baseUrl)),\n                tap({ error: e => this.events.dispatchError(e) }),\n            );\n    }\n}\n"]}