angular-simple-oidc
Version:
Angular Library implementing Open Id Connect specification. Code Flow, Refresh Tokens, Session Management, Discovery Document.
87 lines • 13.6 kB
JavaScript
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"]}