angular-simple-oidc
Version:
Angular Library implementing Open Id Connect specification. Code Flow, Refresh Tokens, Session Management, Discovery Document.
103 lines • 17.1 kB
JavaScript
import { Injectable, Inject } from '@angular/core';
import { TokenStorageKeys } from 'angular-simple-oidc/core';
import { of, BehaviorSubject } from 'rxjs';
import { LOCAL_STORAGE_REF } from './providers';
// @dynamic
export class TokenStorageService {
constructor(localStorage) {
this.localStorage = localStorage;
this.localStateSubject = new BehaviorSubject(this.getCurrentLocalState());
}
get currentState$() {
return this.localStateSubject.asObservable();
}
get storage() {
return this.localStorage;
}
storePreAuthorizationState(authState) {
this.storage.setItem(TokenStorageKeys.Nonce, authState.nonce);
this.storage.setItem(TokenStorageKeys.State, authState.state);
this.storage.setItem(TokenStorageKeys.CodeVerifier, authState.codeVerifier);
this.storage.setItem(TokenStorageKeys.PreRedirectUrl, authState.preRedirectUrl);
const state = this.getCurrentLocalState();
this.localStateSubject.next(state);
return of(state);
}
clearPreAuthorizationState() {
this.storage.removeItem(TokenStorageKeys.Nonce);
this.storage.removeItem(TokenStorageKeys.State);
this.storage.removeItem(TokenStorageKeys.CodeVerifier);
this.storage.removeItem(TokenStorageKeys.PreRedirectUrl);
const state = this.getCurrentLocalState();
this.localStateSubject.next(state);
return of(state);
}
storeAuthorizationCode(authorizationCode, sessionState) {
this.storage.setItem(TokenStorageKeys.AuthorizationCode, authorizationCode);
if (sessionState) {
this.storage.setItem(TokenStorageKeys.SessionState, sessionState);
}
const state = this.getCurrentLocalState();
this.localStateSubject.next(state);
return of(state);
}
storeOriginalIdToken(idToken) {
this.storage.setItem(TokenStorageKeys.OriginalIdentityToken, idToken);
const state = this.getCurrentLocalState();
this.localStateSubject.next(state);
return of(state);
}
storeTokens(tokens) {
this.storage.setItem(TokenStorageKeys.IdentityToken, tokens.idToken);
this.storeJSON(TokenStorageKeys.IdentityTokenDecoded, tokens.decodedIdToken);
this.storage.setItem(TokenStorageKeys.AccessToken, tokens.accessToken);
if (tokens.accessTokenExpiresAt) {
this.storage.setItem(TokenStorageKeys.AccessTokenExpiration, tokens.accessTokenExpiresAt.toString());
}
if (tokens.refreshToken) {
this.storage.setItem(TokenStorageKeys.RefreshToken, tokens.refreshToken);
}
const state = this.getCurrentLocalState();
this.localStateSubject.next(state);
return of(state);
}
removeAll() {
for (const k of Object.keys(TokenStorageKeys)) {
// We can't use clear since we could
// potentially delete keys which are not owned by us
this.storage.removeItem(TokenStorageKeys[k]);
}
return of(this.getCurrentLocalState());
}
getCurrentLocalState() {
const state = {
nonce: this.storage.getItem(TokenStorageKeys.Nonce),
state: this.storage.getItem(TokenStorageKeys.State),
codeVerifier: this.storage.getItem(TokenStorageKeys.CodeVerifier),
authorizationCode: this.storage.getItem(TokenStorageKeys.AuthorizationCode),
sessionState: this.storage.getItem(TokenStorageKeys.SessionState),
identityToken: this.storage.getItem(TokenStorageKeys.IdentityToken),
originalIdentityToken: this.storage.getItem(TokenStorageKeys.OriginalIdentityToken),
accessToken: this.storage.getItem(TokenStorageKeys.AccessToken),
accessTokenExpiration: parseInt(this.storage.getItem(TokenStorageKeys.AccessTokenExpiration), 10),
refreshToken: this.storage.getItem(TokenStorageKeys.RefreshToken),
preRedirectUrl: this.storage.getItem(TokenStorageKeys.PreRedirectUrl),
decodedIdentityToken: this.readJSON(TokenStorageKeys.IdentityTokenDecoded)
};
return state;
}
storeJSON(key, obj) {
this.storage.setItem(key, JSON.stringify(obj));
}
readJSON(key) {
const json = this.storage.getItem(key);
return json ? JSON.parse(json) : null;
}
}
TokenStorageService.decorators = [
{ type: Injectable }
];
TokenStorageService.ctorParameters = () => [
{ type: Storage, decorators: [{ type: Inject, args: [LOCAL_STORAGE_REF,] }] }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token-storage.service.js","sourceRoot":"","sources":["../../../../projects/angular-simple-oidc/src/lib/token-storage.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport {\n    TokenStorageKeys,\n    LocalState,\n    TokenRequestResult,\n    DecodedIdentityToken\n} from 'angular-simple-oidc/core';\nimport { of, BehaviorSubject } from 'rxjs';\nimport { LOCAL_STORAGE_REF } from './providers';\n\n// @dynamic\n@Injectable()\nexport class TokenStorageService {\n\n    public get currentState$() {\n        return this.localStateSubject.asObservable();\n    }\n\n    protected get storage() {\n        return this.localStorage;\n    }\n\n    protected readonly localStateSubject = new BehaviorSubject<LocalState>(this.getCurrentLocalState());\n\n    constructor(\n        @Inject(LOCAL_STORAGE_REF)\n        private readonly localStorage: Storage,\n    ) { }\n\n    public storePreAuthorizationState(authState: {\n        nonce: string,\n        state: string,\n        codeVerifier: string,\n        preRedirectUrl: string,\n    }) {\n        this.storage.setItem(TokenStorageKeys.Nonce, authState.nonce);\n        this.storage.setItem(TokenStorageKeys.State, authState.state);\n        this.storage.setItem(TokenStorageKeys.CodeVerifier, authState.codeVerifier);\n        this.storage.setItem(TokenStorageKeys.PreRedirectUrl, authState.preRedirectUrl);\n        const state = this.getCurrentLocalState();\n        this.localStateSubject.next(state);\n        return of(state);\n    }\n\n    public clearPreAuthorizationState() {\n        this.storage.removeItem(TokenStorageKeys.Nonce);\n        this.storage.removeItem(TokenStorageKeys.State);\n        this.storage.removeItem(TokenStorageKeys.CodeVerifier);\n        this.storage.removeItem(TokenStorageKeys.PreRedirectUrl);\n        const state = this.getCurrentLocalState();\n        this.localStateSubject.next(state);\n        return of(state);\n    }\n\n    public storeAuthorizationCode(authorizationCode: string, sessionState?: string) {\n        this.storage.setItem(TokenStorageKeys.AuthorizationCode, authorizationCode);\n\n        if (sessionState) {\n            this.storage.setItem(TokenStorageKeys.SessionState, sessionState);\n        }\n\n        const state = this.getCurrentLocalState();\n        this.localStateSubject.next(state);\n        return of(state);\n    }\n\n    public storeOriginalIdToken(idToken: string) {\n        this.storage.setItem(TokenStorageKeys.OriginalIdentityToken, idToken);\n        const state = this.getCurrentLocalState();\n        this.localStateSubject.next(state);\n        return of(state);\n    }\n\n    public storeTokens(tokens: TokenRequestResult) {\n        this.storage.setItem(TokenStorageKeys.IdentityToken, tokens.idToken);\n        this.storeJSON(TokenStorageKeys.IdentityTokenDecoded, tokens.decodedIdToken);\n\n        this.storage.setItem(TokenStorageKeys.AccessToken, tokens.accessToken);\n        if (tokens.accessTokenExpiresAt) {\n            this.storage.setItem(TokenStorageKeys.AccessTokenExpiration,\n                tokens.accessTokenExpiresAt.toString());\n        }\n\n        if (tokens.refreshToken) {\n            this.storage.setItem(TokenStorageKeys.RefreshToken, tokens.refreshToken);\n        }\n\n        const state = this.getCurrentLocalState();\n        this.localStateSubject.next(state);\n        return of(state);\n    }\n\n    public removeAll() {\n        for (const k of Object.keys(TokenStorageKeys)) {\n            // We can't use clear since we could\n            // potentially delete keys which are not owned by us\n            this.storage.removeItem(TokenStorageKeys[k]);\n        }\n        return of(this.getCurrentLocalState());\n    }\n\n    protected getCurrentLocalState() {\n        const state: LocalState = {\n            nonce: this.storage.getItem(TokenStorageKeys.Nonce),\n            state: this.storage.getItem(TokenStorageKeys.State),\n            codeVerifier: this.storage.getItem(TokenStorageKeys.CodeVerifier),\n            authorizationCode: this.storage.getItem(TokenStorageKeys.AuthorizationCode),\n            sessionState: this.storage.getItem(TokenStorageKeys.SessionState),\n            identityToken: this.storage.getItem(TokenStorageKeys.IdentityToken),\n            originalIdentityToken: this.storage.getItem(TokenStorageKeys.OriginalIdentityToken),\n            accessToken: this.storage.getItem(TokenStorageKeys.AccessToken),\n            accessTokenExpiration: parseInt(this.storage.getItem(TokenStorageKeys.AccessTokenExpiration), 10),\n            refreshToken: this.storage.getItem(TokenStorageKeys.RefreshToken),\n            preRedirectUrl: this.storage.getItem(TokenStorageKeys.PreRedirectUrl),\n            decodedIdentityToken: this.readJSON<DecodedIdentityToken>(TokenStorageKeys.IdentityTokenDecoded)\n        };\n        return state;\n    }\n\n    protected storeJSON<T>(key: string, obj: T) {\n        this.storage.setItem(key, JSON.stringify(obj));\n    }\n\n    protected readJSON<T>(key: string) {\n        const json = this.storage.getItem(key);\n        return json ? JSON.parse(json) as T : null;\n    }\n}\n"]}