UNPKG

angular-auth-oidc-client

Version:

An OpenID Connect Code Flow with PKCE,Implicit Flow client for Angular

165 lines 12.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable } from '@angular/core'; import { LoggerService } from './oidc.logger.service'; export class TokenHelperService { /** * @param {?} loggerService */ constructor(loggerService) { this.loggerService = loggerService; this.PARTS_OF_TOKEN = 3; } /** * @param {?} dataIdToken * @return {?} */ getTokenExpirationDate(dataIdToken) { if (!dataIdToken.hasOwnProperty('exp')) { return new Date(); } /** @type {?} */ const date = new Date(0); date.setUTCSeconds(dataIdToken.exp); return date; } /** * @param {?} token * @param {?} encoded * @return {?} */ getHeaderFromToken(token, encoded) { if (!this.tokenIsValid(token)) { return {}; } return this.getPartOfToken(token, 0, encoded); } /** * @param {?} token * @param {?} encoded * @return {?} */ getPayloadFromToken(token, encoded) { if (!this.tokenIsValid(token)) { return {}; } return this.getPartOfToken(token, 1, encoded); } /** * @param {?} token * @param {?} encoded * @return {?} */ getSignatureFromToken(token, encoded) { if (!this.tokenIsValid(token)) { return {}; } return this.getPartOfToken(token, 2, encoded); } /** * @private * @param {?} token * @param {?} index * @param {?} encoded * @return {?} */ getPartOfToken(token, index, encoded) { /** @type {?} */ const partOfToken = this.extractPartOfToken(token, index); if (encoded) { return partOfToken; } /** @type {?} */ const result = this.urlBase64Decode(partOfToken); return JSON.parse(result); } /** * @private * @param {?} str * @return {?} */ urlBase64Decode(str) { /** @type {?} */ let output = str.replace(/-/g, '+').replace(/_/g, '/'); switch (output.length % 4) { case 0: break; case 2: output += '=='; break; case 3: output += '='; break; default: throw Error('Illegal base64url string!'); } /** @type {?} */ const decoded = typeof window !== 'undefined' ? window.atob(output) : new Buffer(output, 'base64').toString('binary'); try { // Going backwards: from bytestream, to percent-encoding, to original string. return decodeURIComponent(decoded.split('') .map((/** * @param {?} c * @return {?} */ (c) => '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2))) .join('')); } catch (err) { return decoded; } } /** * @private * @param {?} token * @return {?} */ tokenIsValid(token) { if (!token) { this.loggerService.logError(`token '${token}' is not valid --> token falsy`); return false; } if (!((/** @type {?} */ (token))).includes('.')) { this.loggerService.logError(`token '${token}' is not valid --> no dots included`); return false; } /** @type {?} */ const parts = token.split('.'); if (parts.length !== this.PARTS_OF_TOKEN) { this.loggerService.logError(`token '${token}' is not valid --> token has t have exact three dots`); return false; } return true; } /** * @private * @param {?} token * @param {?} index * @return {?} */ extractPartOfToken(token, index) { return token.split('.')[index]; } } TokenHelperService.decorators = [ { type: Injectable } ]; /** @nocollapse */ TokenHelperService.ctorParameters = () => [ { type: LoggerService } ]; if (false) { /** * @type {?} * @private */ TokenHelperService.prototype.PARTS_OF_TOKEN; /** * @type {?} * @private */ TokenHelperService.prototype.loggerService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oidc-token-helper.service.js","sourceRoot":"ng://angular-auth-oidc-client/","sources":["lib/services/oidc-token-helper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { LoggerService } from './oidc.logger.service';\n\n@Injectable()\nexport class TokenHelperService {\n    private PARTS_OF_TOKEN = 3;\n    constructor(private readonly loggerService: LoggerService) {}\n\n    getTokenExpirationDate(dataIdToken: any): Date {\n        if (!dataIdToken.hasOwnProperty('exp')) {\n            return new Date();\n        }\n\n        const date = new Date(0); // The 0 here is the key, which sets the date to the epoch\n        date.setUTCSeconds(dataIdToken.exp);\n\n        return date;\n    }\n\n    getHeaderFromToken(token: any, encoded: boolean) {\n        if (!this.tokenIsValid(token)) {\n            return {};\n        }\n\n        return this.getPartOfToken(token, 0, encoded);\n    }\n\n    getPayloadFromToken(token: any, encoded: boolean) {\n        if (!this.tokenIsValid(token)) {\n            return {};\n        }\n\n        return this.getPartOfToken(token, 1, encoded);\n    }\n\n    getSignatureFromToken(token: any, encoded: boolean) {\n        if (!this.tokenIsValid(token)) {\n            return {};\n        }\n\n        return this.getPartOfToken(token, 2, encoded);\n    }\n\n    private getPartOfToken(token: string, index: number, encoded: boolean) {\n        const partOfToken = this.extractPartOfToken(token, index);\n\n        if (encoded) {\n            return partOfToken;\n        }\n\n        const result = this.urlBase64Decode(partOfToken);\n        return JSON.parse(result);\n    }\n\n    private urlBase64Decode(str: string) {\n        let output = str.replace(/-/g, '+').replace(/_/g, '/');\n        switch (output.length % 4) {\n            case 0:\n                break;\n            case 2:\n                output += '==';\n                break;\n            case 3:\n                output += '=';\n                break;\n            default:\n                throw Error('Illegal base64url string!');\n        }\n\n        const decoded = typeof window !== 'undefined' ? window.atob(output) : new Buffer(output, 'base64').toString('binary');\n\n        try {\n            // Going backwards: from bytestream, to percent-encoding, to original string.\n            return decodeURIComponent(decoded.split('')\n                .map((c: string) => '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2))\n                .join(''));\n        } catch (err) {\n            return decoded;\n        }\n    }\n\n    private tokenIsValid(token: string) {\n        if (!token) {\n            this.loggerService.logError(`token '${token}' is not valid --> token falsy`);\n            return false;\n        }\n\n        if (!(token as string).includes('.')) {\n            this.loggerService.logError(`token '${token}' is not valid --> no dots included`);\n            return false;\n        }\n\n        const parts = token.split('.');\n\n        if (parts.length !== this.PARTS_OF_TOKEN) {\n            this.loggerService.logError(`token '${token}' is not valid --> token has t have exact three dots`);\n            return false;\n        }\n\n        return true;\n    }\n\n    private extractPartOfToken(token: string, index: number) {\n        return token.split('.')[index];\n    }\n}\n"]}