@auth0/angular-jwt
Advanced tools
Comparing version 4.1.1 to 4.1.2
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"JwtInterceptor":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":14,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":27,"character":5},"arguments":[{"__symbolic":"reference","name":"JWT_OPTIONS"}]}],null],"parameters":[{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"JwtHelperService"}]}],"isWhitelistedDomain":[{"__symbolic":"method"}],"isBlacklistedRoute":[{"__symbolic":"method"}],"handleInterception":[{"__symbolic":"method"}],"intercept":[{"__symbolic":"method"}]}},"JwtHelperService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":9,"character":15},"arguments":[{"__symbolic":"reference","name":"JWT_OPTIONS"}]}]],"parameters":[null]}],"urlBase64Decode":[{"__symbolic":"method"}],"b64decode":[{"__symbolic":"method"}],"b64DecodeUnicode":[{"__symbolic":"method"}],"decodeToken":[{"__symbolic":"method"}],"getTokenExpirationDate":[{"__symbolic":"method"}],"isTokenExpired":[{"__symbolic":"method"}]}},"JWT_OPTIONS":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":31},"arguments":["JWT_OPTIONS"]},"JwtModuleOptions":{"__symbolic":"interface"},"JwtModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":27,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":29,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"SkipSelf","line":29,"character":27}}]],"parameters":[{"__symbolic":"reference","name":"JwtModule"}]}]},"statics":{"forRoot":{"__symbolic":"function","parameters":["options"],"value":{"ngModule":{"__symbolic":"reference","name":"JwtModule"},"providers":[{"provide":{"__symbolic":"reference","module":"@angular/common/http","name":"HTTP_INTERCEPTORS","line":41,"character":19},"useClass":{"__symbolic":"reference","name":"JwtInterceptor"},"multi":true},{"__symbolic":"binop","operator":"||","left":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"jwtOptionsProvider"},"right":{"provide":{"__symbolic":"reference","name":"JWT_OPTIONS"},"useValue":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"config"}}},{"__symbolic":"reference","name":"JwtHelperService"}]}}}}},"origins":{"JwtInterceptor":"./lib/jwt.interceptor","JwtHelperService":"./lib/jwthelper.service","JWT_OPTIONS":"./lib/jwtoptions.token","JwtModuleOptions":"./lib/angular-jwt.module","JwtModule":"./lib/angular-jwt.module"},"importAs":"@auth0/angular-jwt"} | ||
{"__symbolic":"module","version":4,"metadata":{"JwtInterceptor":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":14,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":28,"character":5},"arguments":[{"__symbolic":"reference","name":"JWT_OPTIONS"}]}],null],"parameters":[{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"JwtHelperService"}]}],"isWhitelistedDomain":[{"__symbolic":"method"}],"isBlacklistedRoute":[{"__symbolic":"method"}],"handleInterception":[{"__symbolic":"method"}],"intercept":[{"__symbolic":"method"}]}},"JwtHelperService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":9,"character":15},"arguments":[{"__symbolic":"reference","name":"JWT_OPTIONS"}]}]],"parameters":[null]}],"urlBase64Decode":[{"__symbolic":"method"}],"b64decode":[{"__symbolic":"method"}],"b64DecodeUnicode":[{"__symbolic":"method"}],"decodeToken":[{"__symbolic":"method"}],"getTokenExpirationDate":[{"__symbolic":"method"}],"isTokenExpired":[{"__symbolic":"method"}]}},"JWT_OPTIONS":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":31},"arguments":["JWT_OPTIONS"]},"JwtModuleOptions":{"__symbolic":"interface"},"JwtModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":27,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":29,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"SkipSelf","line":29,"character":27}}]],"parameters":[{"__symbolic":"reference","name":"JwtModule"}]}]},"statics":{"forRoot":{"__symbolic":"function","parameters":["options"],"value":{"ngModule":{"__symbolic":"reference","name":"JwtModule"},"providers":[{"provide":{"__symbolic":"reference","module":"@angular/common/http","name":"HTTP_INTERCEPTORS","line":41,"character":19},"useClass":{"__symbolic":"reference","name":"JwtInterceptor"},"multi":true},{"__symbolic":"binop","operator":"||","left":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"jwtOptionsProvider"},"right":{"provide":{"__symbolic":"reference","name":"JWT_OPTIONS"},"useValue":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"config"}}},{"__symbolic":"reference","name":"JwtHelperService"}]}}}}},"origins":{"JwtInterceptor":"./lib/jwt.interceptor","JwtHelperService":"./lib/jwthelper.service","JWT_OPTIONS":"./lib/jwtoptions.token","JwtModuleOptions":"./lib/angular-jwt.module","JwtModule":"./lib/angular-jwt.module"},"importAs":"@auth0/angular-jwt"} |
@@ -317,2 +317,3 @@ (function (global, factory) { | ||
this.jwtHelper = jwtHelper; | ||
this.standardPorts = ["80", "443"]; | ||
this.tokenGetter = config.tokenGetter; | ||
@@ -331,8 +332,13 @@ this.headerName = config.headerName || "Authorization"; | ||
var requestUrl = url.parse(request.url, false, true); | ||
return (requestUrl.hostname === null || | ||
var hostName = requestUrl.hostname !== null | ||
? "" + requestUrl.hostname + (requestUrl.port && !this.standardPorts.includes(requestUrl.port) | ||
? ":" + requestUrl.port | ||
: "") | ||
: requestUrl.hostname; | ||
return (hostName === null || | ||
this.whitelistedDomains.findIndex(function (domain) { | ||
return typeof domain === "string" | ||
? domain === requestUrl.hostname | ||
? domain === hostName | ||
: domain instanceof RegExp | ||
? domain.test(requestUrl.hostname) | ||
? domain.test(hostName) | ||
: false; | ||
@@ -339,0 +345,0 @@ }) > -1); |
@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs/operators"),require("url"),require("rxjs"),require("@angular/common/http")):"function"==typeof define&&define.amd?define("@auth0/angular-jwt",["exports","@angular/core","rxjs/operators","url","rxjs","@angular/common/http"],t):t(((e=e||self).auth0=e.auth0||{},e.auth0["angular-jwt"]={}),e.ng.core,e.rxjs.operators,e.url,e.rxjs,e.ng.common.http)}(this,(function(e,t,r,o,n,i){"use strict"; | ||
and limitations under the License. | ||
***************************************************************************** */function a(e,t,r,o){var n,i=arguments.length,a=i<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,r):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,r,o);else for(var s=e.length-1;s>=0;s--)(n=e[s])&&(a=(i<3?n(a):i>3?n(t,r,a):n(t,r))||a);return i>3&&a&&Object.defineProperty(t,r,a),a}function s(e,t){return function(r,o){t(r,o,e)}}function u(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}var c=new t.InjectionToken("JWT_OPTIONS"),p=function(){function e(e){void 0===e&&(e=null),this.tokenGetter=e&&e.tokenGetter||function(){}}return e.prototype.urlBase64Decode=function(e){var t=e.replace(/-/g,"+").replace(/_/g,"/");switch(t.length%4){case 0:break;case 2:t+="==";break;case 3:t+="=";break;default:throw new Error("Illegal base64url string!")}return this.b64DecodeUnicode(t)},e.prototype.b64decode=function(e){var t="";if((e=String(e).replace(/=+$/,"")).length%4==1)throw new Error("'atob' failed: The string to be decoded is not correctly encoded.");for(var r=0,o=void 0,n=void 0,i=0;n=e.charAt(i++);~n&&(o=r%4?64*o+n:n,r++%4)?t+=String.fromCharCode(255&o>>(-2*r&6)):0)n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(n);return t},e.prototype.b64DecodeUnicode=function(e){return decodeURIComponent(Array.prototype.map.call(this.b64decode(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))},e.prototype.decodeToken=function(e){if(void 0===e&&(e=this.tokenGetter()),!e||""===e)return null;var t=e.split(".");if(3!==t.length)throw new Error("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.");var r=this.urlBase64Decode(t[1]);if(!r)throw new Error("Cannot decode the token.");return JSON.parse(r)},e.prototype.getTokenExpirationDate=function(e){var t;if(void 0===e&&(e=this.tokenGetter()),!(t=this.decodeToken(e))||!t.hasOwnProperty("exp"))return null;var r=new Date(0);return r.setUTCSeconds(t.exp),r},e.prototype.isTokenExpired=function(e,t){if(void 0===e&&(e=this.tokenGetter()),!e||""===e)return!0;var r=this.getTokenExpirationDate(e);return t=t||0,null!==r&&!(r.valueOf()>(new Date).valueOf()+1e3*t)},e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[c]}]}]},e=a([t.Injectable(),s(0,t.Inject(c)),u("design:paramtypes",[Object])],e)}(),d=function(){function e(e,t){this.jwtHelper=t,this.tokenGetter=e.tokenGetter,this.headerName=e.headerName||"Authorization",this.authScheme=e.authScheme||""===e.authScheme?e.authScheme:"Bearer ",this.whitelistedDomains=e.whitelistedDomains||[],this.blacklistedRoutes=e.blacklistedRoutes||[],this.throwNoTokenError=e.throwNoTokenError||!1,this.skipWhenExpired=e.skipWhenExpired}return e.prototype.isWhitelistedDomain=function(e){var t=o.parse(e.url,!1,!0);return null===t.hostname||this.whitelistedDomains.findIndex((function(e){return"string"==typeof e?e===t.hostname:e instanceof RegExp&&e.test(t.hostname)}))>-1},e.prototype.isBlacklistedRoute=function(e){var t=o.parse(e.url,!1,!0);return this.blacklistedRoutes.findIndex((function(r){if("string"==typeof r){var n=o.parse(r,!1,!0);return n.hostname===t.hostname&&n.path===t.path}return r instanceof RegExp&&r.test(e.url)}))>-1},e.prototype.handleInterception=function(e,t,r){var o,n=!1;if(!e&&this.throwNoTokenError)throw new Error("Could not get token from tokenGetter function.");return this.skipWhenExpired&&(n=!e||this.jwtHelper.isTokenExpired(e)),e&&n&&this.skipWhenExpired?t=t.clone():e&&(t=t.clone({setHeaders:(o={},o[this.headerName]=""+this.authScheme+e,o)})),r.handle(t)},e.prototype.intercept=function(e,t){var o=this;if(!this.isWhitelistedDomain(e)||this.isBlacklistedRoute(e))return t.handle(e);var i=this.tokenGetter(e);return i instanceof Promise?n.from(i).pipe(r.mergeMap((function(r){return o.handleInterception(r,e,t)}))):this.handleInterception(i,e,t)},e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[c]}]},{type:p}]},e=a([t.Injectable(),s(0,t.Inject(c)),u("design:paramtypes",[Object,p])],e)}(),l=function(){function e(e){if(e)throw new Error("JwtModule is already loaded. It should only be imported in your application's main module.")}var r;return r=e,e.forRoot=function(e){return{ngModule:r,providers:[{provide:i.HTTP_INTERCEPTORS,useClass:d,multi:!0},e.jwtOptionsProvider||{provide:c,useValue:e.config},p]}},e.ctorParameters=function(){return[{type:e,decorators:[{type:t.Optional},{type:t.SkipSelf}]}]},e=r=a([t.NgModule(),s(0,t.Optional()),s(0,t.SkipSelf()),u("design:paramtypes",[e])],e)}();e.JWT_OPTIONS=c,e.JwtHelperService=p,e.JwtInterceptor=d,e.JwtModule=l,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
***************************************************************************** */function a(e,t,r,o){var n,i=arguments.length,a=i<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,r):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,r,o);else for(var s=e.length-1;s>=0;s--)(n=e[s])&&(a=(i<3?n(a):i>3?n(t,r,a):n(t,r))||a);return i>3&&a&&Object.defineProperty(t,r,a),a}function s(e,t){return function(r,o){t(r,o,e)}}function u(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}var c=new t.InjectionToken("JWT_OPTIONS"),p=function(){function e(e){void 0===e&&(e=null),this.tokenGetter=e&&e.tokenGetter||function(){}}return e.prototype.urlBase64Decode=function(e){var t=e.replace(/-/g,"+").replace(/_/g,"/");switch(t.length%4){case 0:break;case 2:t+="==";break;case 3:t+="=";break;default:throw new Error("Illegal base64url string!")}return this.b64DecodeUnicode(t)},e.prototype.b64decode=function(e){var t="";if((e=String(e).replace(/=+$/,"")).length%4==1)throw new Error("'atob' failed: The string to be decoded is not correctly encoded.");for(var r=0,o=void 0,n=void 0,i=0;n=e.charAt(i++);~n&&(o=r%4?64*o+n:n,r++%4)?t+=String.fromCharCode(255&o>>(-2*r&6)):0)n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(n);return t},e.prototype.b64DecodeUnicode=function(e){return decodeURIComponent(Array.prototype.map.call(this.b64decode(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))},e.prototype.decodeToken=function(e){if(void 0===e&&(e=this.tokenGetter()),!e||""===e)return null;var t=e.split(".");if(3!==t.length)throw new Error("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.");var r=this.urlBase64Decode(t[1]);if(!r)throw new Error("Cannot decode the token.");return JSON.parse(r)},e.prototype.getTokenExpirationDate=function(e){var t;if(void 0===e&&(e=this.tokenGetter()),!(t=this.decodeToken(e))||!t.hasOwnProperty("exp"))return null;var r=new Date(0);return r.setUTCSeconds(t.exp),r},e.prototype.isTokenExpired=function(e,t){if(void 0===e&&(e=this.tokenGetter()),!e||""===e)return!0;var r=this.getTokenExpirationDate(e);return t=t||0,null!==r&&!(r.valueOf()>(new Date).valueOf()+1e3*t)},e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[c]}]}]},e=a([t.Injectable(),s(0,t.Inject(c)),u("design:paramtypes",[Object])],e)}(),d=function(){function e(e,t){this.jwtHelper=t,this.standardPorts=["80","443"],this.tokenGetter=e.tokenGetter,this.headerName=e.headerName||"Authorization",this.authScheme=e.authScheme||""===e.authScheme?e.authScheme:"Bearer ",this.whitelistedDomains=e.whitelistedDomains||[],this.blacklistedRoutes=e.blacklistedRoutes||[],this.throwNoTokenError=e.throwNoTokenError||!1,this.skipWhenExpired=e.skipWhenExpired}return e.prototype.isWhitelistedDomain=function(e){var t=o.parse(e.url,!1,!0),r=null!==t.hostname?t.hostname+(t.port&&!this.standardPorts.includes(t.port)?":"+t.port:""):t.hostname;return null===r||this.whitelistedDomains.findIndex((function(e){return"string"==typeof e?e===r:e instanceof RegExp&&e.test(r)}))>-1},e.prototype.isBlacklistedRoute=function(e){var t=o.parse(e.url,!1,!0);return this.blacklistedRoutes.findIndex((function(r){if("string"==typeof r){var n=o.parse(r,!1,!0);return n.hostname===t.hostname&&n.path===t.path}return r instanceof RegExp&&r.test(e.url)}))>-1},e.prototype.handleInterception=function(e,t,r){var o,n=!1;if(!e&&this.throwNoTokenError)throw new Error("Could not get token from tokenGetter function.");return this.skipWhenExpired&&(n=!e||this.jwtHelper.isTokenExpired(e)),e&&n&&this.skipWhenExpired?t=t.clone():e&&(t=t.clone({setHeaders:(o={},o[this.headerName]=""+this.authScheme+e,o)})),r.handle(t)},e.prototype.intercept=function(e,t){var o=this;if(!this.isWhitelistedDomain(e)||this.isBlacklistedRoute(e))return t.handle(e);var i=this.tokenGetter(e);return i instanceof Promise?n.from(i).pipe(r.mergeMap((function(r){return o.handleInterception(r,e,t)}))):this.handleInterception(i,e,t)},e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[c]}]},{type:p}]},e=a([t.Injectable(),s(0,t.Inject(c)),u("design:paramtypes",[Object,p])],e)}(),l=function(){function e(e){if(e)throw new Error("JwtModule is already loaded. It should only be imported in your application's main module.")}var r;return r=e,e.forRoot=function(e){return{ngModule:r,providers:[{provide:i.HTTP_INTERCEPTORS,useClass:d,multi:!0},e.jwtOptionsProvider||{provide:c,useValue:e.config},p]}},e.ctorParameters=function(){return[{type:e,decorators:[{type:t.Optional},{type:t.SkipSelf}]}]},e=r=a([t.NgModule(),s(0,t.Optional()),s(0,t.SkipSelf()),u("design:paramtypes",[e])],e)}();e.JWT_OPTIONS=c,e.JwtHelperService=p,e.JwtInterceptor=d,e.JwtModule=l,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=auth0-angular-jwt.umd.min.js.map |
# Change log | ||
## Version [4.1.0](https://github.com/auth0/angular2-jwt/tags/v4.1.2) (2020-05-16) | ||
[Full Changelog](https://github.com/auth0/angular2-jwt/compare/v4.1.1..v4.1.2) | ||
- Support domains with a port other than the default HTTP ports (HTTP: 80, HTTPS: 443) | ||
[#656](https://github.com/auth0/angular2-jwt/pull/656) | ||
## Version [4.1.1](https://github.com/auth0/angular2-jwt/tags/v4.1.1) (2020-05-15) | ||
[Full Changelog](https://github.com/auth0/angular2-jwt/compare/v4.1.0..v4.1.1) | ||
- Something went wrong pulishing `v4.1.0`, this version fixes that. | ||
## Version [4.1.0](https://github.com/auth0/angular2-jwt/tags/v4.1.0) (2020-05-15) | ||
[Full Changelog](https://github.com/auth0/angular2-jwt/compare/4.0.0..4.1.0) | ||
[Full Changelog](https://github.com/auth0/angular2-jwt/compare/4.0.0..v4.1.0) | ||
@@ -7,0 +20,0 @@ - Use blacklist domains regardless of their protocol [#644](https://github.com/auth0/angular2-jwt/pull/644) |
@@ -11,2 +11,3 @@ import { __decorate, __metadata, __param } from "tslib"; | ||
this.jwtHelper = jwtHelper; | ||
this.standardPorts = ["80", "443"]; | ||
this.tokenGetter = config.tokenGetter; | ||
@@ -25,7 +26,12 @@ this.headerName = config.headerName || "Authorization"; | ||
const requestUrl = parse(request.url, false, true); | ||
return (requestUrl.hostname === null || | ||
const hostName = requestUrl.hostname !== null | ||
? `${requestUrl.hostname}${requestUrl.port && !this.standardPorts.includes(requestUrl.port) | ||
? ":" + requestUrl.port | ||
: ""}` | ||
: requestUrl.hostname; | ||
return (hostName === null || | ||
this.whitelistedDomains.findIndex((domain) => typeof domain === "string" | ||
? domain === requestUrl.hostname | ||
? domain === hostName | ||
: domain instanceof RegExp | ||
? domain.test(requestUrl.hostname) | ||
? domain.test(hostName) | ||
: false) > -1); | ||
@@ -93,2 +99,2 @@ } | ||
export { JwtInterceptor }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwt.interceptor.js","sourceRoot":"ng://@auth0/angular-jwt/","sources":["lib/jwt.interceptor.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAOnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,KAAK,CAAC;AAC5B,OAAO,EAAE,IAAI,EAAc,MAAM,MAAM,CAAC;AAGxC,IAAa,cAAc,GAA3B,MAAa,cAAc;IAWzB,YACuB,MAAW,EACzB,SAA2B;QAA3B,cAAS,GAAT,SAAS,CAAkB;QAElC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,eAAe,CAAC;QACvD,IAAI,CAAC,UAAU;YACb,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,KAAK,EAAE;gBAC3C,CAAC,CAAC,MAAM,CAAC,UAAU;gBACnB,CAAC,CAAC,SAAS,CAAC;QAChB,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,kBAAkB,IAAI,EAAE,CAAC;QAC1D,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,IAAI,EAAE,CAAC;QACxD,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,IAAI,KAAK,CAAC;QAC3D,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,eAAe,CAAC;IAChD,CAAC;IAED,mBAAmB,CAAC,OAAyB;QAC3C,MAAM,UAAU,GAAQ,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAExD,OAAO,CACL,UAAU,CAAC,QAAQ,KAAK,IAAI;YAC5B,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAC3C,OAAO,MAAM,KAAK,QAAQ;gBACxB,CAAC,CAAC,MAAM,KAAK,UAAU,CAAC,QAAQ;gBAChC,CAAC,CAAC,MAAM,YAAY,MAAM;oBAC1B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;oBAClC,CAAC,CAAC,KAAK,CACV,GAAG,CAAC,CAAC,CACP,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,OAAyB;QAC1C,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAErD,OAAO,CACL,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,KAAsB,EAAE,EAAE;YAC1D,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;gBAC9C,OAAO,CACL,WAAW,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ;oBAC9C,WAAW,CAAC,IAAI,KAAK,YAAY,CAAC,IAAI,CACvC,CAAC;aACH;YAED,IAAI,KAAK,YAAY,MAAM,EAAE;gBAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;aAChC;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,GAAG,CAAC,CAAC,CACR,CAAC;IACJ,CAAC;IAED,kBAAkB,CAChB,KAAoB,EACpB,OAAyB,EACzB,IAAiB;QAEjB,IAAI,cAAc,GAAG,KAAK,CAAC;QAE3B,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,iBAAiB,EAAE;YACpC,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QAED,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACtE;QAED,IAAI,KAAK,IAAI,cAAc,IAAI,IAAI,CAAC,eAAe,EAAE;YACnD,OAAO,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;SAC3B;aAAM,IAAI,KAAK,EAAE;YAChB,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC;gBACtB,UAAU,EAAE;oBACV,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG,KAAK,EAAE;iBAChD;aACF,CAAC,CAAC;SACJ;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,SAAS,CACP,OAAyB,EACzB,IAAiB;QAEjB,IACE,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC;YAClC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAChC;YACA,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SAC7B;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAExC,IAAI,KAAK,YAAY,OAAO,EAAE;YAC5B,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CACrB,QAAQ,CAAC,CAAC,UAAyB,EAAE,EAAE;gBACrC,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;YAC5D,CAAC,CAAC,CACH,CAAC;SACH;aAAM;YACL,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;SACtD;IACH,CAAC;CACF,CAAA;;4CArGI,MAAM,SAAC,WAAW;YACD,gBAAgB;;AAbzB,cAAc;IAD1B,UAAU,EAAE;IAaR,WAAA,MAAM,CAAC,WAAW,CAAC,CAAA;6CACF,gBAAgB;GAbzB,cAAc,CAiH1B;SAjHY,cAAc","sourcesContent":["import { Injectable, Inject } from \"@angular/core\";\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n} from \"@angular/common/http\";\nimport { JwtHelperService } from \"./jwthelper.service\";\nimport { JWT_OPTIONS } from \"./jwtoptions.token\";\n\nimport { mergeMap } from \"rxjs/operators\";\nimport { parse } from \"url\";\nimport { from, Observable } from \"rxjs\";\n\n@Injectable()\nexport class JwtInterceptor implements HttpInterceptor {\n  tokenGetter: (\n    request?: HttpRequest<any>\n  ) => string | null | Promise<string | null>;\n  headerName: string;\n  authScheme: string;\n  whitelistedDomains: Array<string | RegExp>;\n  blacklistedRoutes: Array<string | RegExp>;\n  throwNoTokenError: boolean;\n  skipWhenExpired: boolean;\n\n  constructor(\n    @Inject(JWT_OPTIONS) config: any,\n    public jwtHelper: JwtHelperService\n  ) {\n    this.tokenGetter = config.tokenGetter;\n    this.headerName = config.headerName || \"Authorization\";\n    this.authScheme =\n      config.authScheme || config.authScheme === \"\"\n        ? config.authScheme\n        : \"Bearer \";\n    this.whitelistedDomains = config.whitelistedDomains || [];\n    this.blacklistedRoutes = config.blacklistedRoutes || [];\n    this.throwNoTokenError = config.throwNoTokenError || false;\n    this.skipWhenExpired = config.skipWhenExpired;\n  }\n\n  isWhitelistedDomain(request: HttpRequest<any>): boolean {\n    const requestUrl: any = parse(request.url, false, true);\n\n    return (\n      requestUrl.hostname === null ||\n      this.whitelistedDomains.findIndex((domain) =>\n        typeof domain === \"string\"\n          ? domain === requestUrl.hostname\n          : domain instanceof RegExp\n          ? domain.test(requestUrl.hostname)\n          : false\n      ) > -1\n    );\n  }\n\n  isBlacklistedRoute(request: HttpRequest<any>): boolean {\n    const requestedUrl = parse(request.url, false, true);\n\n    return (\n      this.blacklistedRoutes.findIndex((route: string | RegExp) => {\n        if (typeof route === \"string\") {\n          const parsedRoute = parse(route, false, true);\n          return (\n            parsedRoute.hostname === requestedUrl.hostname &&\n            parsedRoute.path === requestedUrl.path\n          );\n        }\n\n        if (route instanceof RegExp) {\n          return route.test(request.url);\n        }\n\n        return false;\n      }) > -1\n    );\n  }\n\n  handleInterception(\n    token: string | null,\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ) {\n    let tokenIsExpired = false;\n\n    if (!token && this.throwNoTokenError) {\n      throw new Error(\"Could not get token from tokenGetter function.\");\n    }\n\n    if (this.skipWhenExpired) {\n      tokenIsExpired = token ? this.jwtHelper.isTokenExpired(token) : true;\n    }\n\n    if (token && tokenIsExpired && this.skipWhenExpired) {\n      request = request.clone();\n    } else if (token) {\n      request = request.clone({\n        setHeaders: {\n          [this.headerName]: `${this.authScheme}${token}`,\n        },\n      });\n    }\n    return next.handle(request);\n  }\n\n  intercept(\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (\n      !this.isWhitelistedDomain(request) ||\n      this.isBlacklistedRoute(request)\n    ) {\n      return next.handle(request);\n    }\n    const token = this.tokenGetter(request);\n\n    if (token instanceof Promise) {\n      return from(token).pipe(\n        mergeMap((asyncToken: string | null) => {\n          return this.handleInterception(asyncToken, request, next);\n        })\n      );\n    } else {\n      return this.handleInterception(token, request, next);\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwt.interceptor.js","sourceRoot":"ng://@auth0/angular-jwt/","sources":["lib/jwt.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from \"@angular/core\";\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n} from \"@angular/common/http\";\nimport { JwtHelperService } from \"./jwthelper.service\";\nimport { JWT_OPTIONS } from \"./jwtoptions.token\";\n\nimport { mergeMap } from \"rxjs/operators\";\nimport { parse } from \"url\";\nimport { from, Observable } from \"rxjs\";\n\n@Injectable()\nexport class JwtInterceptor implements HttpInterceptor {\n  tokenGetter: (\n    request?: HttpRequest<any>\n  ) => string | null | Promise<string | null>;\n  headerName: string;\n  authScheme: string;\n  whitelistedDomains: Array<string | RegExp>;\n  blacklistedRoutes: Array<string | RegExp>;\n  throwNoTokenError: boolean;\n  skipWhenExpired: boolean;\n  standardPorts: string[] = [\"80\", \"443\"];\n\n  constructor(\n    @Inject(JWT_OPTIONS) config: any,\n    public jwtHelper: JwtHelperService\n  ) {\n    this.tokenGetter = config.tokenGetter;\n    this.headerName = config.headerName || \"Authorization\";\n    this.authScheme =\n      config.authScheme || config.authScheme === \"\"\n        ? config.authScheme\n        : \"Bearer \";\n    this.whitelistedDomains = config.whitelistedDomains || [];\n    this.blacklistedRoutes = config.blacklistedRoutes || [];\n    this.throwNoTokenError = config.throwNoTokenError || false;\n    this.skipWhenExpired = config.skipWhenExpired;\n  }\n\n  isWhitelistedDomain(request: HttpRequest<any>): boolean {\n    const requestUrl: any = parse(request.url, false, true);\n    const hostName =\n      requestUrl.hostname !== null\n        ? `${requestUrl.hostname}${\n            requestUrl.port && !this.standardPorts.includes(requestUrl.port)\n              ? \":\" + requestUrl.port\n              : \"\"\n          }`\n        : requestUrl.hostname;\n\n    return (\n      hostName === null ||\n      this.whitelistedDomains.findIndex((domain) =>\n        typeof domain === \"string\"\n          ? domain === hostName\n          : domain instanceof RegExp\n          ? domain.test(hostName)\n          : false\n      ) > -1\n    );\n  }\n\n  isBlacklistedRoute(request: HttpRequest<any>): boolean {\n    const requestedUrl = parse(request.url, false, true);\n\n    return (\n      this.blacklistedRoutes.findIndex((route: string | RegExp) => {\n        if (typeof route === \"string\") {\n          const parsedRoute = parse(route, false, true);\n          return (\n            parsedRoute.hostname === requestedUrl.hostname &&\n            parsedRoute.path === requestedUrl.path\n          );\n        }\n\n        if (route instanceof RegExp) {\n          return route.test(request.url);\n        }\n\n        return false;\n      }) > -1\n    );\n  }\n\n  handleInterception(\n    token: string | null,\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ) {\n    let tokenIsExpired = false;\n\n    if (!token && this.throwNoTokenError) {\n      throw new Error(\"Could not get token from tokenGetter function.\");\n    }\n\n    if (this.skipWhenExpired) {\n      tokenIsExpired = token ? this.jwtHelper.isTokenExpired(token) : true;\n    }\n\n    if (token && tokenIsExpired && this.skipWhenExpired) {\n      request = request.clone();\n    } else if (token) {\n      request = request.clone({\n        setHeaders: {\n          [this.headerName]: `${this.authScheme}${token}`,\n        },\n      });\n    }\n    return next.handle(request);\n  }\n\n  intercept(\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (\n      !this.isWhitelistedDomain(request) ||\n      this.isBlacklistedRoute(request)\n    ) {\n      return next.handle(request);\n    }\n    const token = this.tokenGetter(request);\n\n    if (token instanceof Promise) {\n      return from(token).pipe(\n        mergeMap((asyncToken: string | null) => {\n          return this.handleInterception(asyncToken, request, next);\n        })\n      );\n    } else {\n      return this.handleInterception(token, request, next);\n    }\n  }\n}\n"]} |
@@ -11,2 +11,3 @@ import { __decorate, __metadata, __param } from "tslib"; | ||
this.jwtHelper = jwtHelper; | ||
this.standardPorts = ["80", "443"]; | ||
this.tokenGetter = config.tokenGetter; | ||
@@ -25,8 +26,13 @@ this.headerName = config.headerName || "Authorization"; | ||
var requestUrl = parse(request.url, false, true); | ||
return (requestUrl.hostname === null || | ||
var hostName = requestUrl.hostname !== null | ||
? "" + requestUrl.hostname + (requestUrl.port && !this.standardPorts.includes(requestUrl.port) | ||
? ":" + requestUrl.port | ||
: "") | ||
: requestUrl.hostname; | ||
return (hostName === null || | ||
this.whitelistedDomains.findIndex(function (domain) { | ||
return typeof domain === "string" | ||
? domain === requestUrl.hostname | ||
? domain === hostName | ||
: domain instanceof RegExp | ||
? domain.test(requestUrl.hostname) | ||
? domain.test(hostName) | ||
: false; | ||
@@ -98,2 +104,2 @@ }) > -1); | ||
export { JwtInterceptor }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwt.interceptor.js","sourceRoot":"ng://@auth0/angular-jwt/","sources":["lib/jwt.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from \"@angular/core\";\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n} from \"@angular/common/http\";\nimport { JwtHelperService } from \"./jwthelper.service\";\nimport { JWT_OPTIONS } from \"./jwtoptions.token\";\n\nimport { mergeMap } from \"rxjs/operators\";\nimport { parse } from \"url\";\nimport { from, Observable } from \"rxjs\";\n\n@Injectable()\nexport class JwtInterceptor implements HttpInterceptor {\n  tokenGetter: (\n    request?: HttpRequest<any>\n  ) => string | null | Promise<string | null>;\n  headerName: string;\n  authScheme: string;\n  whitelistedDomains: Array<string | RegExp>;\n  blacklistedRoutes: Array<string | RegExp>;\n  throwNoTokenError: boolean;\n  skipWhenExpired: boolean;\n\n  constructor(\n    @Inject(JWT_OPTIONS) config: any,\n    public jwtHelper: JwtHelperService\n  ) {\n    this.tokenGetter = config.tokenGetter;\n    this.headerName = config.headerName || \"Authorization\";\n    this.authScheme =\n      config.authScheme || config.authScheme === \"\"\n        ? config.authScheme\n        : \"Bearer \";\n    this.whitelistedDomains = config.whitelistedDomains || [];\n    this.blacklistedRoutes = config.blacklistedRoutes || [];\n    this.throwNoTokenError = config.throwNoTokenError || false;\n    this.skipWhenExpired = config.skipWhenExpired;\n  }\n\n  isWhitelistedDomain(request: HttpRequest<any>): boolean {\n    const requestUrl: any = parse(request.url, false, true);\n\n    return (\n      requestUrl.hostname === null ||\n      this.whitelistedDomains.findIndex((domain) =>\n        typeof domain === \"string\"\n          ? domain === requestUrl.hostname\n          : domain instanceof RegExp\n          ? domain.test(requestUrl.hostname)\n          : false\n      ) > -1\n    );\n  }\n\n  isBlacklistedRoute(request: HttpRequest<any>): boolean {\n    const requestedUrl = parse(request.url, false, true);\n\n    return (\n      this.blacklistedRoutes.findIndex((route: string | RegExp) => {\n        if (typeof route === \"string\") {\n          const parsedRoute = parse(route, false, true);\n          return (\n            parsedRoute.hostname === requestedUrl.hostname &&\n            parsedRoute.path === requestedUrl.path\n          );\n        }\n\n        if (route instanceof RegExp) {\n          return route.test(request.url);\n        }\n\n        return false;\n      }) > -1\n    );\n  }\n\n  handleInterception(\n    token: string | null,\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ) {\n    let tokenIsExpired = false;\n\n    if (!token && this.throwNoTokenError) {\n      throw new Error(\"Could not get token from tokenGetter function.\");\n    }\n\n    if (this.skipWhenExpired) {\n      tokenIsExpired = token ? this.jwtHelper.isTokenExpired(token) : true;\n    }\n\n    if (token && tokenIsExpired && this.skipWhenExpired) {\n      request = request.clone();\n    } else if (token) {\n      request = request.clone({\n        setHeaders: {\n          [this.headerName]: `${this.authScheme}${token}`,\n        },\n      });\n    }\n    return next.handle(request);\n  }\n\n  intercept(\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (\n      !this.isWhitelistedDomain(request) ||\n      this.isBlacklistedRoute(request)\n    ) {\n      return next.handle(request);\n    }\n    const token = this.tokenGetter(request);\n\n    if (token instanceof Promise) {\n      return from(token).pipe(\n        mergeMap((asyncToken: string | null) => {\n          return this.handleInterception(asyncToken, request, next);\n        })\n      );\n    } else {\n      return this.handleInterception(token, request, next);\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jwt.interceptor.js","sourceRoot":"ng://@auth0/angular-jwt/","sources":["lib/jwt.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from \"@angular/core\";\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n} from \"@angular/common/http\";\nimport { JwtHelperService } from \"./jwthelper.service\";\nimport { JWT_OPTIONS } from \"./jwtoptions.token\";\n\nimport { mergeMap } from \"rxjs/operators\";\nimport { parse } from \"url\";\nimport { from, Observable } from \"rxjs\";\n\n@Injectable()\nexport class JwtInterceptor implements HttpInterceptor {\n  tokenGetter: (\n    request?: HttpRequest<any>\n  ) => string | null | Promise<string | null>;\n  headerName: string;\n  authScheme: string;\n  whitelistedDomains: Array<string | RegExp>;\n  blacklistedRoutes: Array<string | RegExp>;\n  throwNoTokenError: boolean;\n  skipWhenExpired: boolean;\n  standardPorts: string[] = [\"80\", \"443\"];\n\n  constructor(\n    @Inject(JWT_OPTIONS) config: any,\n    public jwtHelper: JwtHelperService\n  ) {\n    this.tokenGetter = config.tokenGetter;\n    this.headerName = config.headerName || \"Authorization\";\n    this.authScheme =\n      config.authScheme || config.authScheme === \"\"\n        ? config.authScheme\n        : \"Bearer \";\n    this.whitelistedDomains = config.whitelistedDomains || [];\n    this.blacklistedRoutes = config.blacklistedRoutes || [];\n    this.throwNoTokenError = config.throwNoTokenError || false;\n    this.skipWhenExpired = config.skipWhenExpired;\n  }\n\n  isWhitelistedDomain(request: HttpRequest<any>): boolean {\n    const requestUrl: any = parse(request.url, false, true);\n    const hostName =\n      requestUrl.hostname !== null\n        ? `${requestUrl.hostname}${\n            requestUrl.port && !this.standardPorts.includes(requestUrl.port)\n              ? \":\" + requestUrl.port\n              : \"\"\n          }`\n        : requestUrl.hostname;\n\n    return (\n      hostName === null ||\n      this.whitelistedDomains.findIndex((domain) =>\n        typeof domain === \"string\"\n          ? domain === hostName\n          : domain instanceof RegExp\n          ? domain.test(hostName)\n          : false\n      ) > -1\n    );\n  }\n\n  isBlacklistedRoute(request: HttpRequest<any>): boolean {\n    const requestedUrl = parse(request.url, false, true);\n\n    return (\n      this.blacklistedRoutes.findIndex((route: string | RegExp) => {\n        if (typeof route === \"string\") {\n          const parsedRoute = parse(route, false, true);\n          return (\n            parsedRoute.hostname === requestedUrl.hostname &&\n            parsedRoute.path === requestedUrl.path\n          );\n        }\n\n        if (route instanceof RegExp) {\n          return route.test(request.url);\n        }\n\n        return false;\n      }) > -1\n    );\n  }\n\n  handleInterception(\n    token: string | null,\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ) {\n    let tokenIsExpired = false;\n\n    if (!token && this.throwNoTokenError) {\n      throw new Error(\"Could not get token from tokenGetter function.\");\n    }\n\n    if (this.skipWhenExpired) {\n      tokenIsExpired = token ? this.jwtHelper.isTokenExpired(token) : true;\n    }\n\n    if (token && tokenIsExpired && this.skipWhenExpired) {\n      request = request.clone();\n    } else if (token) {\n      request = request.clone({\n        setHeaders: {\n          [this.headerName]: `${this.authScheme}${token}`,\n        },\n      });\n    }\n    return next.handle(request);\n  }\n\n  intercept(\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (\n      !this.isWhitelistedDomain(request) ||\n      this.isBlacklistedRoute(request)\n    ) {\n      return next.handle(request);\n    }\n    const token = this.tokenGetter(request);\n\n    if (token instanceof Promise) {\n      return from(token).pipe(\n        mergeMap((asyncToken: string | null) => {\n          return this.handleInterception(asyncToken, request, next);\n        })\n      );\n    } else {\n      return this.handleInterception(token, request, next);\n    }\n  }\n}\n"]} |
@@ -116,2 +116,3 @@ import { __decorate, __param, __metadata } from 'tslib'; | ||
this.jwtHelper = jwtHelper; | ||
this.standardPorts = ["80", "443"]; | ||
this.tokenGetter = config.tokenGetter; | ||
@@ -130,7 +131,12 @@ this.headerName = config.headerName || "Authorization"; | ||
const requestUrl = parse(request.url, false, true); | ||
return (requestUrl.hostname === null || | ||
const hostName = requestUrl.hostname !== null | ||
? `${requestUrl.hostname}${requestUrl.port && !this.standardPorts.includes(requestUrl.port) | ||
? ":" + requestUrl.port | ||
: ""}` | ||
: requestUrl.hostname; | ||
return (hostName === null || | ||
this.whitelistedDomains.findIndex((domain) => typeof domain === "string" | ||
? domain === requestUrl.hostname | ||
? domain === hostName | ||
: domain instanceof RegExp | ||
? domain.test(requestUrl.hostname) | ||
? domain.test(hostName) | ||
: false) > -1); | ||
@@ -137,0 +143,0 @@ } |
@@ -121,2 +121,3 @@ import { __decorate, __param, __metadata } from 'tslib'; | ||
this.jwtHelper = jwtHelper; | ||
this.standardPorts = ["80", "443"]; | ||
this.tokenGetter = config.tokenGetter; | ||
@@ -135,8 +136,13 @@ this.headerName = config.headerName || "Authorization"; | ||
var requestUrl = parse(request.url, false, true); | ||
return (requestUrl.hostname === null || | ||
var hostName = requestUrl.hostname !== null | ||
? "" + requestUrl.hostname + (requestUrl.port && !this.standardPorts.includes(requestUrl.port) | ||
? ":" + requestUrl.port | ||
: "") | ||
: requestUrl.hostname; | ||
return (hostName === null || | ||
this.whitelistedDomains.findIndex(function (domain) { | ||
return typeof domain === "string" | ||
? domain === requestUrl.hostname | ||
? domain === hostName | ||
: domain instanceof RegExp | ||
? domain.test(requestUrl.hostname) | ||
? domain.test(hostName) | ||
: false; | ||
@@ -143,0 +149,0 @@ }) > -1); |
@@ -13,2 +13,3 @@ import { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from "@angular/common/http"; | ||
skipWhenExpired: boolean; | ||
standardPorts: string[]; | ||
constructor(config: any, jwtHelper: JwtHelperService); | ||
@@ -15,0 +16,0 @@ isWhitelistedDomain(request: HttpRequest<any>): boolean; |
{ | ||
"name": "@auth0/angular-jwt", | ||
"version": "4.1.1", | ||
"version": "4.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
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
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
244002
1534
0