@auth0/angular-jwt
Advanced tools
Comparing version 5.1.1 to 5.1.2
@@ -90,8 +90,7 @@ (function (global, factory) { | ||
var _this = this; | ||
if (token === void 0) { token = null; } | ||
var _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(function (t) { return _this._decodeToken(t); }); | ||
if (token === void 0) { token = this.tokenGetter(); } | ||
if (token instanceof Promise) { | ||
return token.then(function (t) { return _this._decodeToken(t); }); | ||
} | ||
return this._decodeToken(_token); | ||
return this._decodeToken(token); | ||
}; | ||
@@ -114,8 +113,7 @@ JwtHelperService.prototype._decodeToken = function (token) { | ||
var _this = this; | ||
if (token === void 0) { token = null; } | ||
var _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(function (t) { return _this._getTokenExpirationDate(t); }); | ||
if (token === void 0) { token = this.tokenGetter(); } | ||
if (token instanceof Promise) { | ||
return token.then(function (t) { return _this._getTokenExpirationDate(t); }); | ||
} | ||
return this._getTokenExpirationDate(_token); | ||
return this._getTokenExpirationDate(token); | ||
}; | ||
@@ -134,8 +132,7 @@ JwtHelperService.prototype._getTokenExpirationDate = function (token) { | ||
var _this = this; | ||
if (token === void 0) { token = null; } | ||
var _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(function (t) { return _this._isTokenExpired(t, offsetSeconds); }); | ||
if (token === void 0) { token = this.tokenGetter(); } | ||
if (token instanceof Promise) { | ||
return token.then(function (t) { return _this._isTokenExpired(t, offsetSeconds); }); | ||
} | ||
return this._isTokenExpired(_token, offsetSeconds); | ||
return this._isTokenExpired(token, offsetSeconds); | ||
}; | ||
@@ -142,0 +139,0 @@ JwtHelperService.prototype._isTokenExpired = function (token, offsetSeconds) { |
# Change Log | ||
## [v5.1.2](https://github.com/auth0/angular2-jwt/tree/v5.1.2) (2022-12-20) | ||
[Full Changelog](https://github.com/auth0/angular2-jwt/compare/v5.1.1...v5.1.2) | ||
**Fixed** | ||
- Restore pre 5.1.1 behavior and fix types [\#759](https://github.com/auth0/angular2-jwt/pull/759) ([frederikprijck](https://github.com/frederikprijck)) | ||
## [v5.1.1](https://github.com/auth0/angular2-jwt/tree/v5.1.1) (2022-12-15) | ||
@@ -4,0 +10,0 @@ [Full Changelog](https://github.com/auth0/angular2-jwt/compare/v5.1.0...v5.1.1) |
@@ -62,8 +62,7 @@ // tslint:disable:no-bitwise | ||
} | ||
decodeToken(token = null) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._decodeToken(t)); | ||
decodeToken(token = this.tokenGetter()) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._decodeToken(t)); | ||
} | ||
return this._decodeToken(_token); | ||
return this._decodeToken(token); | ||
} | ||
@@ -84,8 +83,7 @@ _decodeToken(token) { | ||
} | ||
getTokenExpirationDate(token = null) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._getTokenExpirationDate(t)); | ||
getTokenExpirationDate(token = this.tokenGetter()) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._getTokenExpirationDate(t)); | ||
} | ||
return this._getTokenExpirationDate(_token); | ||
return this._getTokenExpirationDate(token); | ||
} | ||
@@ -102,8 +100,7 @@ _getTokenExpirationDate(token) { | ||
} | ||
isTokenExpired(token = null, offsetSeconds) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._isTokenExpired(t, offsetSeconds)); | ||
isTokenExpired(token = this.tokenGetter(), offsetSeconds) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._isTokenExpired(t, offsetSeconds)); | ||
} | ||
return this._isTokenExpired(_token, offsetSeconds); | ||
return this._isTokenExpired(token, offsetSeconds); | ||
} | ||
@@ -136,2 +133,2 @@ _isTokenExpired(token, offsetSeconds) { | ||
}] }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwthelper.service.js","sourceRoot":"","sources":["../../../../projects/angular-jwt/src/lib/jwthelper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpRequest } from '@angular/common/http';\n// tslint:disable:no-bitwise\n\nimport { Injectable, Inject } from '@angular/core';\nimport { JWT_OPTIONS } from './jwtoptions.token';\n\n@Injectable()\nexport class JwtHelperService {\n  tokenGetter: () => string | Promise<string>;\n\n  constructor(@Inject(JWT_OPTIONS) config = null) {\n    this.tokenGetter = (config && config.tokenGetter) || function () {};\n  }\n\n  public urlBase64Decode(str: string): string {\n    let output = str.replace(/-/g, '+').replace(/_/g, '/');\n    switch (output.length % 4) {\n      case 0: {\n        break;\n      }\n      case 2: {\n        output += '==';\n        break;\n      }\n      case 3: {\n        output += '=';\n        break;\n      }\n      default: {\n        throw new Error('Illegal base64url string!');\n      }\n    }\n    return this.b64DecodeUnicode(output);\n  }\n\n  // credits for decoder goes to https://github.com/atk\n  private b64decode(str: string): string {\n    const chars =\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\n    let output = '';\n\n    str = String(str).replace(/=+$/, '');\n\n    if (str.length % 4 === 1) {\n      throw new Error(\n        `'atob' failed: The string to be decoded is not correctly encoded.`\n      );\n    }\n\n    for (\n      // initialize result and counters\n      let bc = 0, bs: any, buffer: any, idx = 0;\n      // get next character\n      (buffer = str.charAt(idx++));\n      // character found in table? initialize bit storage and add its ascii value;\n      ~buffer &&\n      ((bs = bc % 4 ? bs * 64 + buffer : buffer),\n      // and if not first of each 4 characters,\n      // convert the first 8 bits to one ascii character\n      bc++ % 4)\n        ? (output += String.fromCharCode(255 & (bs >> ((-2 * bc) & 6))))\n        : 0\n    ) {\n      // try to find character in table (0-63, not found => -1)\n      buffer = chars.indexOf(buffer);\n    }\n    return output;\n  }\n\n  private b64DecodeUnicode(str: any) {\n    return decodeURIComponent(\n      Array.prototype.map\n        .call(this.b64decode(str), (c: any) => {\n          return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);\n        })\n        .join('')\n    );\n  }\n\n  public decodeToken<T = any>(token: string = null): T | Promise<T> {\n    const _token = token || this.tokenGetter();\n\n    if (_token instanceof Promise) {\n      return _token.then(t => this._decodeToken(t));\n    }\n\n    return this._decodeToken(_token);\n  }\n\n  private _decodeToken(token: string) {\n    if (!token || token === '') {\n      return null;\n    }\n\n    const parts = token.split('.');\n\n    if (parts.length !== 3) {\n      throw new Error(\n        `The inspected token doesn't appear to be a JWT. Check to make sure it has three parts and see https://jwt.io for more.`\n      );\n    }\n\n    const decoded = this.urlBase64Decode(parts[1]);\n    if (!decoded) {\n      throw new Error('Cannot decode the token.');\n    }\n\n    return JSON.parse(decoded);\n  }\n\n  public getTokenExpirationDate(\n    token: string = null\n  ): Date | null | Promise<Date> {\n\n    const _token = token || this.tokenGetter();\n\n    if (_token instanceof Promise) {\n      return _token.then(t => this._getTokenExpirationDate(t));\n    }\n\n    return this._getTokenExpirationDate(_token);\n  }\n\n  private _getTokenExpirationDate(token: string) {\n    let decoded: any;\n    decoded = this.decodeToken(token);\n\n    if (!decoded || !decoded.hasOwnProperty('exp')) {\n      return null;\n    }\n\n    const date = new Date(0);\n    date.setUTCSeconds(decoded.exp);\n\n    return date;\n  }\n\n  public isTokenExpired(\n    token: string = null,\n    offsetSeconds?: number\n  ): boolean | Promise<boolean> {\n    const _token = token || this.tokenGetter();\n\n    if (_token instanceof Promise) {\n      return _token.then(t => this._isTokenExpired(t, offsetSeconds));\n    }\n\n    return this._isTokenExpired(_token, offsetSeconds);\n  }\n\n  public _isTokenExpired(\n    token: string,\n    offsetSeconds?: number\n  ): boolean {\n    if (!token || token === '') {\n      return true;\n    }\n    const date = this.getTokenExpirationDate(token);\n    offsetSeconds = offsetSeconds || 0;\n\n    if (date === null) {\n      return false;\n    }\n\n    return !(date.valueOf() > new Date().valueOf() + offsetSeconds * 1000);\n  }\n\n  public getAuthScheme(\n    authScheme: Function | string | undefined,\n    request: HttpRequest<any>\n  ): string {\n    if (typeof authScheme === 'function') {\n      return authScheme(request);\n    }\n\n    return authScheme;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwthelper.service.js","sourceRoot":"","sources":["../../../../projects/angular-jwt/src/lib/jwthelper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpRequest } from '@angular/common/http';\n// tslint:disable:no-bitwise\n\nimport { Injectable, Inject } from '@angular/core';\nimport { JWT_OPTIONS } from './jwtoptions.token';\n\n@Injectable()\nexport class JwtHelperService {\n  tokenGetter: () => string | Promise<string>;\n\n  constructor(@Inject(JWT_OPTIONS) config: any = null) {\n    this.tokenGetter = (config && config.tokenGetter) || function () {};\n  }\n\n  public urlBase64Decode(str: string): string {\n    let output = str.replace(/-/g, '+').replace(/_/g, '/');\n    switch (output.length % 4) {\n      case 0: {\n        break;\n      }\n      case 2: {\n        output += '==';\n        break;\n      }\n      case 3: {\n        output += '=';\n        break;\n      }\n      default: {\n        throw new Error('Illegal base64url string!');\n      }\n    }\n    return this.b64DecodeUnicode(output);\n  }\n\n  // credits for decoder goes to https://github.com/atk\n  private b64decode(str: string): string {\n    const chars =\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\n    let output = '';\n\n    str = String(str).replace(/=+$/, '');\n\n    if (str.length % 4 === 1) {\n      throw new Error(\n        `'atob' failed: The string to be decoded is not correctly encoded.`\n      );\n    }\n\n    for (\n      // initialize result and counters\n      let bc = 0, bs: any, buffer: any, idx = 0;\n      // get next character\n      (buffer = str.charAt(idx++));\n      // character found in table? initialize bit storage and add its ascii value;\n      ~buffer &&\n      ((bs = bc % 4 ? bs * 64 + buffer : buffer),\n      // and if not first of each 4 characters,\n      // convert the first 8 bits to one ascii character\n      bc++ % 4)\n        ? (output += String.fromCharCode(255 & (bs >> ((-2 * bc) & 6))))\n        : 0\n    ) {\n      // try to find character in table (0-63, not found => -1)\n      buffer = chars.indexOf(buffer);\n    }\n    return output;\n  }\n\n  private b64DecodeUnicode(str: any) {\n    return decodeURIComponent(\n      Array.prototype.map\n        .call(this.b64decode(str), (c: any) => {\n          return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);\n        })\n        .join('')\n    );\n  }\n\n  public decodeToken<T = any>(token: string): T | null;\n  public decodeToken<T = any>(token: Promise<string>): Promise<T | null>;\n  public decodeToken<T = any>(): null | T | Promise<T | null>;\n  public decodeToken<T = any>(token: string | Promise<string> = this.tokenGetter()): null | T | Promise<T | null> {\n    if (token instanceof Promise) {\n      return token.then(t => this._decodeToken(t));\n    }\n\n    return this._decodeToken(token);\n  }\n\n  private _decodeToken<T = any>(token: string): null | T  {\n    if (!token || token === '') {\n      return null;\n    }\n\n    const parts = token.split('.');\n\n    if (parts.length !== 3) {\n      throw new Error(\n        `The inspected token doesn't appear to be a JWT. Check to make sure it has three parts and see https://jwt.io for more.`\n      );\n    }\n\n    const decoded = this.urlBase64Decode(parts[1]);\n    if (!decoded) {\n      throw new Error('Cannot decode the token.');\n    }\n\n    return JSON.parse(decoded);\n  }\n\n  public getTokenExpirationDate(token: string): Date | null;\n  public getTokenExpirationDate(token: Promise<string>): Promise<Date | null>;\n  public getTokenExpirationDate(): null | Date | Promise<Date | null>;\n  public getTokenExpirationDate(\n    token: string | Promise<string> = this.tokenGetter()\n  ): Date | null | Promise<Date | null> {\n    if (token instanceof Promise) {\n      return token.then(t => this._getTokenExpirationDate(t));\n    }\n\n    return this._getTokenExpirationDate(token);\n  }\n\n  private _getTokenExpirationDate(token: string): Date | null {\n    let decoded: any;\n    decoded = this.decodeToken(token);\n\n    if (!decoded || !decoded.hasOwnProperty('exp')) {\n      return null;\n    }\n\n    const date = new Date(0);\n    date.setUTCSeconds(decoded.exp);\n\n    return date;\n  }\n\n  public isTokenExpired(token?: undefined, offsetSeconds?: number): boolean | Promise<boolean>;\n  public isTokenExpired(token: string | null, offsetSeconds?: number): boolean;\n  public isTokenExpired(token: Promise<string>, offsetSeconds?: number): Promise<boolean>;\n  public isTokenExpired(\n    token: undefined | null | string | Promise<string> = this.tokenGetter(),\n    offsetSeconds?: number\n  ): boolean | Promise<boolean> {\n    if (token instanceof Promise) {\n      return token.then(t => this._isTokenExpired(t, offsetSeconds));\n    }\n\n    return this._isTokenExpired(token, offsetSeconds);\n  }\n\n  private _isTokenExpired(\n    token: string | null,\n    offsetSeconds?: number\n  ): boolean {\n    if (!token || token === '') {\n      return true;\n    }\n    const date = this.getTokenExpirationDate(token);\n    offsetSeconds = offsetSeconds || 0;\n\n    if (date === null) {\n      return false;\n    }\n\n    return !(date.valueOf() > new Date().valueOf() + offsetSeconds * 1000);\n  }\n\n  public getAuthScheme(\n    authScheme: Function | string | undefined,\n    request: HttpRequest<any>\n  ): string | undefined {\n    if (typeof authScheme === 'function') {\n      return authScheme(request);\n    }\n\n    return authScheme;\n  }\n}\n"]} |
@@ -68,8 +68,7 @@ import * as i0 from '@angular/core'; | ||
} | ||
decodeToken(token = null) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._decodeToken(t)); | ||
decodeToken(token = this.tokenGetter()) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._decodeToken(t)); | ||
} | ||
return this._decodeToken(_token); | ||
return this._decodeToken(token); | ||
} | ||
@@ -90,8 +89,7 @@ _decodeToken(token) { | ||
} | ||
getTokenExpirationDate(token = null) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._getTokenExpirationDate(t)); | ||
getTokenExpirationDate(token = this.tokenGetter()) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._getTokenExpirationDate(t)); | ||
} | ||
return this._getTokenExpirationDate(_token); | ||
return this._getTokenExpirationDate(token); | ||
} | ||
@@ -108,8 +106,7 @@ _getTokenExpirationDate(token) { | ||
} | ||
isTokenExpired(token = null, offsetSeconds) { | ||
const _token = token || this.tokenGetter(); | ||
if (_token instanceof Promise) { | ||
return _token.then(t => this._isTokenExpired(t, offsetSeconds)); | ||
isTokenExpired(token = this.tokenGetter(), offsetSeconds) { | ||
if (token instanceof Promise) { | ||
return token.then(t => this._isTokenExpired(t, offsetSeconds)); | ||
} | ||
return this._isTokenExpired(_token, offsetSeconds); | ||
return this._isTokenExpired(token, offsetSeconds); | ||
} | ||
@@ -116,0 +113,0 @@ _isTokenExpired(token, offsetSeconds) { |
@@ -9,11 +9,17 @@ import { HttpRequest } from '@angular/common/http'; | ||
private b64DecodeUnicode; | ||
decodeToken<T = any>(token?: string): T | Promise<T>; | ||
decodeToken<T = any>(token: string): T | null; | ||
decodeToken<T = any>(token: Promise<string>): Promise<T | null>; | ||
decodeToken<T = any>(): null | T | Promise<T | null>; | ||
private _decodeToken; | ||
getTokenExpirationDate(token?: string): Date | null | Promise<Date>; | ||
getTokenExpirationDate(token: string): Date | null; | ||
getTokenExpirationDate(token: Promise<string>): Promise<Date | null>; | ||
getTokenExpirationDate(): null | Date | Promise<Date | null>; | ||
private _getTokenExpirationDate; | ||
isTokenExpired(token?: string, offsetSeconds?: number): boolean | Promise<boolean>; | ||
_isTokenExpired(token: string, offsetSeconds?: number): boolean; | ||
getAuthScheme(authScheme: Function | string | undefined, request: HttpRequest<any>): string; | ||
isTokenExpired(token?: undefined, offsetSeconds?: number): boolean | Promise<boolean>; | ||
isTokenExpired(token: string | null, offsetSeconds?: number): boolean; | ||
isTokenExpired(token: Promise<string>, offsetSeconds?: number): Promise<boolean>; | ||
private _isTokenExpired; | ||
getAuthScheme(authScheme: Function | string | undefined, request: HttpRequest<any>): string | undefined; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<JwtHelperService, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<JwtHelperService>; | ||
} |
{ | ||
"name": "@auth0/angular-jwt", | ||
"version": "5.1.1", | ||
"version": "5.1.2", | ||
"description": "JSON Web Token helper library for Angular", | ||
@@ -5,0 +5,0 @@ "private": false, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
128767
947