Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

angular-oauth2-oidc

Package Overview
Dependencies
Maintainers
1
Versions
95
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-oauth2-oidc - npm Package Compare versions

Comparing version 9.0.0 to 9.0.1

16

bundles/angular-oauth2-oidc.umd.min.js

@@ -1,2 +0,16 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/common/http"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("angular-oauth2-oidc",["exports","@angular/core","@angular/common","@angular/common/http","rxjs","rxjs/operators"],t):t((e=e||self)["angular-oauth2-oidc"]={},e.ng.core,e.ng.common,e.ng.common.http,e.rxjs,e.rxjs.operators)}(this,function(e,t,n,r,o,i){"use strict";var s=function(e,t){return(s=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])})(e,t)};function a(e,t){function n(){this.constructor=e}s(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function c(e,t,n,r){var o,i=arguments.length,s=i<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(s=(i<3?o(s):i>3?o(t,n,s):o(t,n))||s);return i>3&&s&&Object.defineProperty(t,n,s),s}function u(e,t){return function(n,r){t(n,r,e)}}function l(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function h(e,t,n,r){return new(n||(n=Promise))(function(o,i){function s(e){try{c(r.next(e))}catch(t){i(t)}}function a(e){try{c(r["throw"](e))}catch(t){i(t)}}function c(e){e.done?o(e.value):new n(function(t){t(e.value)}).then(s,a)}c((r=r.apply(e,t||[])).next())})}function d(e,t){var n,r,o,i,s={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return i={next:a(0),"throw":a(1),"return":a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(n)throw new TypeError("Generator is already executing.");for(;s;)try{if(n=1,r&&(o=2&i[0]?r["return"]:i[0]?r["throw"]||((o=r["return"])&&o.call(r),0):r.next)&&!(o=o.call(r,i[1])).done)return o;switch(r=0,o&&(i=[2&i[0],o.value]),i[0]){case 0:case 1:o=i;break;case 4:return s.label++,{value:i[1],done:!1};case 5:s.label++,r=i[1],i=[0];continue;case 7:i=s.ops.pop(),s.trys.pop();continue;default:if(!(o=(o=s.trys).length>0&&o[o.length-1])&&(6===i[0]||2===i[0])){s=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]<o[3])){s.label=i[1];break}if(6===i[0]&&s.label<o[1]){s.label=o[1],o=i;break}if(o&&s.label<o[2]){s.label=o[2],s.ops.push(i);break}o[2]&&s.ops.pop(),s.trys.pop();continue}i=t.call(e,s)}catch(a){i=[6,a],r=0}finally{n=o=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}function p(e){var t="function"==typeof Symbol&&e[Symbol.iterator],n=0;return t?t.call(e):{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}}}function f(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,i=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=i.next()).done;)s.push(r.value)}catch(a){o={error:a}}finally{try{r&&!r.done&&(n=i["return"])&&n.call(i)}finally{if(o)throw o.error}}return s}var g=function(){return function(){this.preventClearHashAfterLogin=!1}}(),m=function(){return function(){}}(),v=function(){return function(){}}(),y=function(){function e(){this.data=new Map}return e.prototype.getItem=function(e){return this.data.get(e)},e.prototype.removeItem=function(e){this.data["delete"](e)},e.prototype.setItem=function(e,t){this.data.set(e,t)},e=c([t.Injectable()],e)}(),k=function(){return function(){}}();function w(e){var t=e.replace(/\-/g,"+").replace(/\_/g,"/");return decodeURIComponent(atob(t).split("").map(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)}).join(""))}function _(e){return btoa(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}var b=function(){return function(){}}(),T=function(){function e(){}return e.prototype.validateAtHash=function(e){return h(this,void 0,void 0,function(){var t,n,r,o,i;return d(this,function(s){switch(s.label){case 0:return t=this.inferHashAlgorithm(e.idTokenHeader),[4,this.calcHash(e.accessToken,t)];case 1:return n=s.sent(),r=n.substr(0,n.length/2),o=_(r),i=e.idTokenClaims.at_hash.replace(/=/g,""),o!==i&&(console.error("exptected at_hash: "+o),console.error("actual at_hash: "+i)),[2,o===i]}})})},e.prototype.inferHashAlgorithm=function(e){var t=e.alg;if(!t.match(/^.S[0-9]{3}$/))throw new Error("Algorithm not supported: "+t);return"sha-"+t.substr(2)},e}(),S=function(){function e(){}return e.prototype.getHashFragmentParams=function(e){var t=e||window.location.hash;if(0!==(t=decodeURIComponent(t)).indexOf("#"))return{};var n=t.indexOf("?");return t=n>-1?t.substr(n+1):t.substr(1),this.parseQueryString(t)},e.prototype.parseQueryString=function(e){var t,n,r,o,i,s,a,c={};if(null===e)return c;t=e.split("&");for(var u=0;u<t.length;u++)-1===(r=(n=t[u]).indexOf("="))?(o=n,i=null):(o=n.substr(0,r),i=n.substr(r+1)),s=decodeURIComponent(o),a=decodeURIComponent(i),"/"===s.substr(0,1)&&(s=s.substr(1)),c[s]=a;return c},e=c([t.Injectable()],e)}(),I=function(){return function(e){this.type=e}}(),C=function(e){function t(t,n){void 0===n&&(n=null);var r=e.call(this,t)||this;return r.info=n,r}return a(t,e),t}(I),A=function(e){function t(t,n){void 0===n&&(n=null);var r=e.call(this,t)||this;return r.info=n,r}return a(t,e),t}(I),H=function(e){function t(t,n,r){void 0===r&&(r=null);var o=e.call(this,t)||this;return o.reason=n,o.params=r,o}return a(t,e),t}(I),E=function(){return function(e){this.clientId="",this.redirectUri="",this.postLogoutRedirectUri="",this.loginUrl="",this.scope="openid profile",this.resource="",this.rngUrl="",this.oidc=!0,this.requestAccessToken=!0,this.options=null,this.issuer="",this.logoutUrl="",this.clearHashAfterLogin=!0,this.tokenEndpoint=null,this.userinfoEndpoint=null,this.responseType="",this.showDebugInformation=!1,this.silentRefreshRedirectUri="",this.silentRefreshMessagePrefix="",this.silentRefreshShowIFrame=!1,this.siletRefreshTimeout=2e4,this.silentRefreshTimeout=2e4,this.dummyClientSecret=null,this.requireHttps="remoteOnly",this.strictDiscoveryDocumentValidation=!0,this.jwks=null,this.customQueryParams=null,this.silentRefreshIFrameName="angular-oauth-oidc-silent-refresh-iframe",this.timeoutFactor=.75,this.sessionChecksEnabled=!1,this.sessionCheckIntervall=3e3,this.sessionCheckIFrameUrl=null,this.sessionCheckIFrameName="angular-oauth-oidc-check-session-iframe",this.disableAtHashCheck=!1,this.skipSubjectCheck=!1,this.useIdTokenHintForSilentRefresh=!1,this.skipIssuerCheck=!1,this.nonceStateSeparator=";",this.useHttpBasicAuth=!1,this.waitForTokenInMsec=0,this.disablePKCE=!1,this.openUri=function(e){location.href=e},e&&Object.assign(this,e)}}(),P=function(){function e(){}return e.prototype.encodeKey=function(e){return encodeURIComponent(e)},e.prototype.encodeValue=function(e){return encodeURIComponent(e)},e.prototype.decodeKey=function(e){return decodeURIComponent(e)},e.prototype.decodeValue=function(e){return decodeURIComponent(e)},e}(),U=function(){return function(){}}(),x=function(){function e(){}return e.prototype.calcHash=function(e,t){return h(this,void 0,void 0,function(){var n,r,o;return d(this,function(i){switch(i.label){case 0:return n=new TextEncoder,r=n.encode(e),[4,window.crypto.subtle.digest(t,r)];case 1:return o=i.sent(),[2,this.toHashString(o)]}})})},e.prototype.toHashString=function(e){var t,n,r=new Uint8Array(e),o="";try{for(var i=p(r),s=i.next();!s.done;s=i.next()){var a=s.value;o+=String.fromCharCode(a)}}catch(c){t={error:c}}finally{try{s&&!s.done&&(n=i["return"])&&n.call(i)}finally{if(t)throw t.error}}return o},e=c([t.Injectable()],e)}(),j=function(e){function n(t,n,r,i,s,a,c,u){var l=e.call(this)||this;l.ngZone=t,l.http=n,l.config=s,l.urlHelper=a,l.logger=c,l.crypto=u,l.discoveryDocumentLoaded=!1,l.state="",l.eventsSubject=new o.Subject,l.discoveryDocumentLoadedSubject=new o.Subject,l.grantTypesSupported=[],l.inImplicitFlow=!1,l.debug("angular-oauth2-oidc v8-beta"),l.discoveryDocumentLoaded$=l.discoveryDocumentLoadedSubject.asObservable(),l.events=l.eventsSubject.asObservable(),i&&(l.tokenValidationHandler=i),s&&l.configure(s);try{r?l.setStorage(r):"undefined"!=typeof sessionStorage&&l.setStorage(sessionStorage)}catch(h){console.error("No OAuthStorage provided and cannot access default (sessionStorage).Consider providing a custom OAuthStorage implementation in your module.",h)}return l.setupRefreshTimer(),l}return a(n,e),n.prototype.configure=function(e){Object.assign(this,new E,e),this.config=Object.assign({},new E,e),this.sessionChecksEnabled&&this.setupSessionCheck(),this.configChanged()},n.prototype.configChanged=function(){this.setupRefreshTimer()},n.prototype.restartSessionChecksIfStillLoggedIn=function(){this.hasValidIdToken()&&this.initSessionCheck()},n.prototype.restartRefreshTimerIfStillLoggedIn=function(){this.setupExpirationTimers()},n.prototype.setupSessionCheck=function(){var e=this;this.events.pipe(i.filter(function(e){return"token_received"===e.type})).subscribe(function(t){e.initSessionCheck()})},n.prototype.setupAutomaticSilentRefresh=function(e,t,n){var r=this;void 0===e&&(e={}),void 0===n&&(n=!0);var o=!0;this.events.pipe(i.tap(function(e){"token_received"===e.type?o=!0:"logout"===e.type&&(o=!1)}),i.filter(function(e){return"token_expires"===e.type}),i.debounceTime(1e3)).subscribe(function(i){null!=t&&"any"!==t&&i.info!==t||!o||r.refreshInternal(e,n)["catch"](function(e){r.debug("Automatic silent refresh did not work")})}),this.restartRefreshTimerIfStillLoggedIn()},n.prototype.refreshInternal=function(e,t){return this.silentRefreshRedirectUri||"code"!==this.responseType?this.silentRefresh(e,t):this.refreshToken()},n.prototype.loadDiscoveryDocumentAndTryLogin=function(e){var t=this;return void 0===e&&(e=null),this.loadDiscoveryDocument().then(function(n){return t.tryLogin(e)})},n.prototype.loadDiscoveryDocumentAndLogin=function(e){var t=this;return void 0===e&&(e=null),e||(e={state:""}),this.loadDiscoveryDocumentAndTryLogin(e).then(function(e){return!(!t.hasValidIdToken()||!t.hasValidAccessToken())||("code"===t.responseType?t.initCodeFlow():t.initImplicitFlow(),!1)})},n.prototype.debug=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];this.showDebugInformation&&this.logger.debug.apply(this.logger,e)},n.prototype.validateUrlFromDiscoveryDocument=function(e){var t=[],n=this.validateUrlForHttps(e),r=this.validateUrlAgainstIssuer(e);return n||t.push("https for all urls required. Also for urls received by discovery."),r||t.push("Every url in discovery document has to start with the issuer url.Also see property strictDiscoveryDocumentValidation."),t},n.prototype.validateUrlForHttps=function(e){if(!e)return!0;var t=e.toLowerCase();return!1===this.requireHttps||(!(!t.match(/^http:\/\/localhost($|[:\/])/)&&!t.match(/^http:\/\/localhost($|[:\/])/)||"remoteOnly"!==this.requireHttps)||t.startsWith("https://"))},n.prototype.assertUrlNotNullAndCorrectProtocol=function(e,t){if(!e)throw new Error("'"+t+"' should not be null");if(!this.validateUrlForHttps(e))throw new Error("'"+t+"' must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).")},n.prototype.validateUrlAgainstIssuer=function(e){return!this.strictDiscoveryDocumentValidation||(!e||e.toLowerCase().startsWith(this.issuer.toLowerCase()))},n.prototype.setupRefreshTimer=function(){var e=this;"undefined"!=typeof window?((this.hasValidIdToken()||this.hasValidAccessToken())&&(this.clearAccessTokenTimer(),this.clearIdTokenTimer(),this.setupExpirationTimers()),this.tokenReceivedSubscription&&this.tokenReceivedSubscription.unsubscribe(),this.tokenReceivedSubscription=this.events.pipe(i.filter(function(e){return"token_received"===e.type})).subscribe(function(t){e.clearAccessTokenTimer(),e.clearIdTokenTimer(),e.setupExpirationTimers()})):this.debug("timer not supported on this plattform")},n.prototype.setupExpirationTimers=function(){this.hasValidAccessToken()&&this.setupAccessTokenTimer(),this.hasValidIdToken()&&this.setupIdTokenTimer()},n.prototype.setupAccessTokenTimer=function(){var e=this,t=this.getAccessTokenExpiration(),n=this.getAccessTokenStoredAt(),r=this.calcTimeout(n,t);this.ngZone.runOutsideAngular(function(){e.accessTokenTimeoutSubscription=o.of(new A("token_expires","access_token")).pipe(i.delay(r)).subscribe(function(t){e.ngZone.run(function(){e.eventsSubject.next(t)})})})},n.prototype.setupIdTokenTimer=function(){var e=this,t=this.getIdTokenExpiration(),n=this.getIdTokenStoredAt(),r=this.calcTimeout(n,t);this.ngZone.runOutsideAngular(function(){e.idTokenTimeoutSubscription=o.of(new A("token_expires","id_token")).pipe(i.delay(r)).subscribe(function(t){e.ngZone.run(function(){e.eventsSubject.next(t)})})})},n.prototype.clearAccessTokenTimer=function(){this.accessTokenTimeoutSubscription&&this.accessTokenTimeoutSubscription.unsubscribe()},n.prototype.clearIdTokenTimer=function(){this.idTokenTimeoutSubscription&&this.idTokenTimeoutSubscription.unsubscribe()},n.prototype.calcTimeout=function(e,t){var n=Date.now(),r=(t-e)*this.timeoutFactor-(n-e);return Math.max(0,r)},n.prototype.setStorage=function(e){this._storage=e,this.configChanged()},n.prototype.loadDiscoveryDocument=function(e){var t=this;return void 0===e&&(e=null),new Promise(function(n,r){e||((e=t.issuer||"").endsWith("/")||(e+="/"),e+=".well-known/openid-configuration"),t.validateUrlForHttps(e)?t.http.get(e).subscribe(function(e){if(!t.validateDiscoveryDocument(e))return t.eventsSubject.next(new H("discovery_document_validation_error",null)),void r("discovery_document_validation_error");t.loginUrl=e.authorization_endpoint,t.logoutUrl=e.end_session_endpoint||t.logoutUrl,t.grantTypesSupported=e.grant_types_supported,t.issuer=e.issuer,t.tokenEndpoint=e.token_endpoint,t.userinfoEndpoint=e.userinfo_endpoint||t.userinfoEndpoint,t.jwksUri=e.jwks_uri,t.sessionCheckIFrameUrl=e.check_session_iframe||t.sessionCheckIFrameUrl,t.discoveryDocumentLoaded=!0,t.discoveryDocumentLoadedSubject.next(e),t.sessionChecksEnabled&&t.restartSessionChecksIfStillLoggedIn(),t.loadJwks().then(function(r){var o=new C("discovery_document_loaded",{discoveryDocument:e,jwks:r});t.eventsSubject.next(o),n(o)})["catch"](function(e){t.eventsSubject.next(new H("discovery_document_load_error",e)),r(e)})},function(e){t.logger.error("error loading discovery document",e),t.eventsSubject.next(new H("discovery_document_load_error",e)),r(e)}):r("issuer must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).")})},n.prototype.loadJwks=function(){var e=this;return new Promise(function(t,n){e.jwksUri?e.http.get(e.jwksUri).subscribe(function(n){e.jwks=n,e.eventsSubject.next(new C("discovery_document_loaded")),t(n)},function(t){e.logger.error("error loading jwks",t),e.eventsSubject.next(new H("jwks_load_error",t)),n(t)}):t(null)})},n.prototype.validateDiscoveryDocument=function(e){var t;return this.skipIssuerCheck||e.issuer===this.issuer?(t=this.validateUrlFromDiscoveryDocument(e.authorization_endpoint)).length>0?(this.logger.error("error validating authorization_endpoint in discovery document",t),!1):(t=this.validateUrlFromDiscoveryDocument(e.end_session_endpoint)).length>0?(this.logger.error("error validating end_session_endpoint in discovery document",t),!1):((t=this.validateUrlFromDiscoveryDocument(e.token_endpoint)).length>0&&this.logger.error("error validating token_endpoint in discovery document",t),(t=this.validateUrlFromDiscoveryDocument(e.userinfo_endpoint)).length>0?(this.logger.error("error validating userinfo_endpoint in discovery document",t),!1):(t=this.validateUrlFromDiscoveryDocument(e.jwks_uri)).length>0?(this.logger.error("error validating jwks_uri in discovery document",t),!1):(this.sessionChecksEnabled&&!e.check_session_iframe&&this.logger.warn("sessionChecksEnabled is activated but discovery document does not contain a check_session_iframe field"),!0)):(this.logger.error("invalid issuer in discovery document","expected: "+this.issuer,"current: "+e.issuer),!1)},n.prototype.fetchTokenUsingPasswordFlowAndLoadUserProfile=function(e,t,n){var o=this;return void 0===n&&(n=new r.HttpHeaders),this.fetchTokenUsingPasswordFlow(e,t,n).then(function(){return o.loadUserProfile()})},n.prototype.loadUserProfile=function(){var e=this;if(!this.hasValidAccessToken())throw new Error("Can not load User Profile without access_token");if(!this.validateUrlForHttps(this.userinfoEndpoint))throw new Error("userinfoEndpoint must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");return new Promise(function(t,n){var o=(new r.HttpHeaders).set("Authorization","Bearer "+e.getAccessToken());e.http.get(e.userinfoEndpoint,{headers:o}).subscribe(function(r){e.debug("userinfo received",r);var o=e.getIdentityClaims()||{};if(e.skipSubjectCheck||!e.oidc||o.sub&&r.sub===o.sub)r=Object.assign({},o,r),e._storage.setItem("id_token_claims_obj",JSON.stringify(r)),e.eventsSubject.next(new C("user_profile_loaded")),t(r);else{n("if property oidc is true, the received user-id (sub) has to be the user-id of the user that has logged in with oidc.\nif you are not using oidc but just oauth2 password flow set oidc to false")}},function(t){e.logger.error("error loading user info",t),e.eventsSubject.next(new H("user_profile_load_error",t)),n(t)})})},n.prototype.fetchTokenUsingPasswordFlow=function(e,t,n){var o=this;return void 0===n&&(n=new r.HttpHeaders),this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint"),new Promise(function(i,s){var a,c,u=new r.HttpParams({encoder:new P}).set("grant_type","password").set("scope",o.scope).set("username",e).set("password",t);if(o.useHttpBasicAuth){var l=btoa(o.clientId+":"+o.dummyClientSecret);n=n.set("Authorization","Basic "+l)}if(o.useHttpBasicAuth||(u=u.set("client_id",o.clientId)),!o.useHttpBasicAuth&&o.dummyClientSecret&&(u=u.set("client_secret",o.dummyClientSecret)),o.customQueryParams)try{for(var h=p(Object.getOwnPropertyNames(o.customQueryParams)),d=h.next();!d.done;d=h.next()){var f=d.value;u=u.set(f,o.customQueryParams[f])}}catch(g){a={error:g}}finally{try{d&&!d.done&&(c=h["return"])&&c.call(h)}finally{if(a)throw a.error}}n=n.set("Content-Type","application/x-www-form-urlencoded"),o.http.post(o.tokenEndpoint,u,{headers:n}).subscribe(function(e){o.debug("tokenResponse",e),o.storeAccessTokenResponse(e.access_token,e.refresh_token,e.expires_in,e.scope),o.eventsSubject.next(new C("token_received")),i(e)},function(e){o.logger.error("Error performing password flow",e),o.eventsSubject.next(new H("token_error",e)),s(e)})})},n.prototype.refreshToken=function(){var e=this;return this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint"),new Promise(function(t,n){var s,a,c=(new r.HttpParams).set("grant_type","refresh_token").set("scope",e.scope).set("refresh_token",e._storage.getItem("refresh_token")),u=(new r.HttpHeaders).set("Content-Type","application/x-www-form-urlencoded");if(e.useHttpBasicAuth){var l=btoa(e.clientId+":"+e.dummyClientSecret);u=u.set("Authorization","Basic "+l)}if(e.useHttpBasicAuth||(c=c.set("client_id",e.clientId)),!e.useHttpBasicAuth&&e.dummyClientSecret&&(c=c.set("client_secret",e.dummyClientSecret)),e.customQueryParams)try{for(var h=p(Object.getOwnPropertyNames(e.customQueryParams)),d=h.next();!d.done;d=h.next()){var f=d.value;c=c.set(f,e.customQueryParams[f])}}catch(g){s={error:g}}finally{try{d&&!d.done&&(a=h["return"])&&a.call(h)}finally{if(s)throw s.error}}e.http.post(e.tokenEndpoint,c,{headers:u}).pipe(i.switchMap(function(t){return t.id_token?o.from(e.processIdToken(t.id_token,t.access_token,!0)).pipe(i.tap(function(t){return e.storeIdToken(t)}),i.map(function(e){return t})):o.of(t)})).subscribe(function(n){e.debug("refresh tokenResponse",n),e.storeAccessTokenResponse(n.access_token,n.refresh_token,n.expires_in,n.scope),e.eventsSubject.next(new C("token_received")),e.eventsSubject.next(new C("token_refreshed")),t(n)},function(t){e.logger.error("Error refreshing token",t),e.eventsSubject.next(new H("token_refresh_error",t)),n(t)})})},n.prototype.removeSilentRefreshEventListener=function(){this.silentRefreshPostMessageEventListener&&(window.removeEventListener("message",this.silentRefreshPostMessageEventListener),this.silentRefreshPostMessageEventListener=null)},n.prototype.setupSilentRefreshEventListener=function(){var e=this;this.removeSilentRefreshEventListener(),this.silentRefreshPostMessageEventListener=function(t){var n=e.processMessageEventMessage(t);e.tryLogin({customHashFragment:n,preventClearHashAfterLogin:!0,customRedirectUri:e.silentRefreshRedirectUri||e.redirectUri})["catch"](function(t){return e.debug("tryLogin during silent refresh failed",t)})},window.addEventListener("message",this.silentRefreshPostMessageEventListener)},n.prototype.silentRefresh=function(e,t){var n=this;void 0===e&&(e={}),void 0===t&&(t=!0);var r=this.getIdentityClaims()||{};if(this.useIdTokenHintForSilentRefresh&&this.hasValidIdToken()&&(e.id_token_hint=this.getIdToken()),!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");if("undefined"==typeof document)throw new Error("silent refresh is not supported on this platform");var s=document.getElementById(this.silentRefreshIFrameName);s&&document.body.removeChild(s),this.silentRefreshSubject=r.sub;var a=document.createElement("iframe");a.id=this.silentRefreshIFrameName,this.setupSilentRefreshEventListener();var c=this.silentRefreshRedirectUri||this.redirectUri;this.createLoginUrl(null,null,c,t,e).then(function(e){a.setAttribute("src",e),n.silentRefreshShowIFrame||(a.style.display="none"),document.body.appendChild(a)});var u=this.events.pipe(i.filter(function(e){return e instanceof H}),i.first()),l=this.events.pipe(i.filter(function(e){return"token_received"===e.type}),i.first()),h=o.of(new H("silent_refresh_timeout",null)).pipe(i.delay(this.silentRefreshTimeout));return o.race([u,l,h]).pipe(i.map(function(e){if(e instanceof H)throw"silent_refresh_timeout"===e.type?n.eventsSubject.next(e):(e=new H("silent_refresh_error",e),n.eventsSubject.next(e)),e;return"token_received"===e.type&&(e=new C("silently_refreshed"),n.eventsSubject.next(e)),e})).toPromise()},n.prototype.initImplicitFlowInPopup=function(e){return this.initLoginFlowInPopup(e)},n.prototype.initLoginFlowInPopup=function(e){var t=this;return e=e||{},this.createLoginUrl(null,null,this.silentRefreshRedirectUri,!1,{display:"popup"}).then(function(n){return new Promise(function(r,o){var i,s=window.open(n,"_blank",t.calculatePopupFeatures(e));s?i=window.setInterval(function(){s&&!s.closed||(a(),o(new H("popup_closed",{})))},500):o(new H("popup_blocked",{}));var a=function(){window.clearInterval(i),window.removeEventListener("message",c),null!==s&&s.close(),s=null},c=function(e){var n=t.processMessageEventMessage(e);n&&null!==n?t.tryLogin({customHashFragment:n,preventClearHashAfterLogin:!0,customRedirectUri:t.silentRefreshRedirectUri}).then(function(){a(),r()},function(e){a(),o(e)}):console.log("false event firing")};window.addEventListener("message",c)})})},n.prototype.calculatePopupFeatures=function(e){var t=e.height||470,n=e.width||500,r=window.screenLeft+(window.outerWidth-n)/2;return"location=no,toolbar=no,width="+n+",height="+t+",top="+(window.screenTop+(window.outerHeight-t)/2)+",left="+r},n.prototype.processMessageEventMessage=function(e){var t="#";if(this.silentRefreshMessagePrefix&&(t+=this.silentRefreshMessagePrefix),e&&e.data&&"string"==typeof e.data){var n=e.data;if(n.startsWith(t))return"#"+n.substr(t.length)}},n.prototype.canPerformSessionCheck=function(){return!!this.sessionChecksEnabled&&(this.sessionCheckIFrameUrl?this.getSessionState()?"undefined"!=typeof document:(console.warn("sessionChecksEnabled is activated but there is no session_state"),!1):(console.warn("sessionChecksEnabled is activated but there is no sessionCheckIFrameUrl"),!1))},n.prototype.setupSessionCheckEventListener=function(){var e=this;this.removeSessionCheckEventListener(),this.sessionCheckEventListener=function(t){var n=t.origin.toLowerCase(),r=e.issuer.toLowerCase();if(e.debug("sessionCheckEventListener"),r.startsWith(n)){switch(t.data){case"unchanged":e.handleSessionUnchanged();break;case"changed":e.ngZone.run(function(){e.handleSessionChange()});break;case"error":e.ngZone.run(function(){e.handleSessionError()})}e.debug("got info from session check inframe",t)}else e.debug("sessionCheckEventListener","wrong origin",n,"expected",r)},this.ngZone.runOutsideAngular(function(){window.addEventListener("message",e.sessionCheckEventListener)})},n.prototype.handleSessionUnchanged=function(){this.debug("session check","session unchanged")},n.prototype.handleSessionChange=function(){var e=this;this.eventsSubject.next(new A("session_changed")),this.stopSessionCheckTimer(),this.silentRefreshRedirectUri?(this.silentRefresh()["catch"](function(t){return e.debug("silent refresh failed after session changed")}),this.waitForSilentRefreshAfterSessionChange()):(this.eventsSubject.next(new A("session_terminated")),this.logOut(!0))},n.prototype.waitForSilentRefreshAfterSessionChange=function(){var e=this;this.events.pipe(i.filter(function(e){return"silently_refreshed"===e.type||"silent_refresh_timeout"===e.type||"silent_refresh_error"===e.type}),i.first()).subscribe(function(t){"silently_refreshed"!==t.type&&(e.debug("silent refresh did not work after session changed"),e.eventsSubject.next(new A("session_terminated")),e.logOut(!0))})},n.prototype.handleSessionError=function(){this.stopSessionCheckTimer(),this.eventsSubject.next(new A("session_error"))},n.prototype.removeSessionCheckEventListener=function(){this.sessionCheckEventListener&&(window.removeEventListener("message",this.sessionCheckEventListener),this.sessionCheckEventListener=null)},n.prototype.initSessionCheck=function(){if(this.canPerformSessionCheck()){var e=document.getElementById(this.sessionCheckIFrameName);e&&document.body.removeChild(e);var t=document.createElement("iframe");t.id=this.sessionCheckIFrameName,this.setupSessionCheckEventListener();var n=this.sessionCheckIFrameUrl;t.setAttribute("src",n),t.style.display="none",document.body.appendChild(t),this.startSessionCheckTimer()}},n.prototype.startSessionCheckTimer=function(){var e=this;this.stopSessionCheckTimer(),this.ngZone.runOutsideAngular(function(){e.sessionCheckTimer=setInterval(e.checkSession.bind(e),e.sessionCheckIntervall)})},n.prototype.stopSessionCheckTimer=function(){this.sessionCheckTimer&&(clearInterval(this.sessionCheckTimer),this.sessionCheckTimer=null)},n.prototype.checkSession=function(){var e=document.getElementById(this.sessionCheckIFrameName);e||this.logger.warn("checkSession did not find iframe",this.sessionCheckIFrameName);var t=this.getSessionState();t||this.stopSessionCheckTimer();var n=this.clientId+" "+t;e.contentWindow.postMessage(n,this.issuer)},n.prototype.createLoginUrl=function(e,t,n,r,o){return void 0===e&&(e=""),void 0===t&&(t=""),void 0===n&&(n=""),void 0===r&&(r=!1),void 0===o&&(o={}),h(this,void 0,void 0,function(){var i,s,a,c,u,l,h,g,m,v,y,k,w,_,b,T,S,I;return d(this,function(d){switch(d.label){case 0:return u=this,l=n||this.redirectUri,[4,this.createAndSaveNonce()];case 1:if(h=d.sent(),e=e?h+this.config.nonceStateSeparator+e:h,!this.requestAccessToken&&!this.oidc)throw new Error("Either requestAccessToken or oidc or both must be true");return this.config.responseType?this.responseType=this.config.responseType:this.oidc&&this.requestAccessToken?this.responseType="id_token token":this.oidc&&!this.requestAccessToken?this.responseType="id_token":this.responseType="token",g=u.loginUrl.indexOf("?")>-1?"&":"?",m=u.scope,this.oidc&&!m.match(/(^|\s)openid($|\s)/)&&(m="openid "+m),v=u.loginUrl+g+"response_type="+encodeURIComponent(u.responseType)+"&client_id="+encodeURIComponent(u.clientId)+"&state="+encodeURIComponent(e)+"&redirect_uri="+encodeURIComponent(l)+"&scope="+encodeURIComponent(m),"code"!==this.responseType||this.disablePKCE?[3,3]:[4,this.createChallangeVerifierPairForPKCE()];case 2:y=f.apply(void 0,[d.sent(),2]),k=y[0],w=y[1],this._storage.setItem("PKCI_verifier",w),v+="&code_challenge="+k,v+="&code_challenge_method=S256",d.label=3;case 3:t&&(v+="&login_hint="+encodeURIComponent(t)),u.resource&&(v+="&resource="+encodeURIComponent(u.resource)),u.oidc&&(v+="&nonce="+encodeURIComponent(h)),r&&(v+="&prompt=none");try{for(_=p(Object.keys(o)),b=_.next();!b.done;b=_.next())I=b.value,v+="&"+encodeURIComponent(I)+"="+encodeURIComponent(o[I])}catch(C){i={error:C}}finally{try{b&&!b.done&&(s=_["return"])&&s.call(_)}finally{if(i)throw i.error}}if(this.customQueryParams)try{for(T=p(Object.getOwnPropertyNames(this.customQueryParams)),S=T.next();!S.done;S=T.next())I=S.value,v+="&"+I+"="+encodeURIComponent(this.customQueryParams[I])}catch(A){a={error:A}}finally{try{S&&!S.done&&(c=T["return"])&&c.call(T)}finally{if(a)throw a.error}}return[2,v]}})})},n.prototype.initImplicitFlowInternal=function(e,t){var n=this;if(void 0===e&&(e=""),void 0===t&&(t=""),!this.inImplicitFlow){if(this.inImplicitFlow=!0,!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");var r={},o=null;"string"==typeof t?o=t:"object"==typeof t&&(r=t),this.createLoginUrl(e,o,null,!1,r).then(this.config.openUri)["catch"](function(e){console.error("Error in initImplicitFlow",e),n.inImplicitFlow=!1})}},n.prototype.initImplicitFlow=function(e,t){var n=this;void 0===e&&(e=""),void 0===t&&(t=""),""!==this.loginUrl?this.initImplicitFlowInternal(e,t):this.events.pipe(i.filter(function(e){return"discovery_document_loaded"===e.type})).subscribe(function(r){return n.initImplicitFlowInternal(e,t)})},n.prototype.resetImplicitFlow=function(){this.inImplicitFlow=!1},n.prototype.callOnTokenReceivedIfExists=function(e){if(e.onTokenReceived){var t={idClaims:this.getIdentityClaims(),idToken:this.getIdToken(),accessToken:this.getAccessToken(),state:this.state};e.onTokenReceived(t)}},n.prototype.storeAccessTokenResponse=function(e,t,n,r){if(this._storage.setItem("access_token",e),r&&this._storage.setItem("granted_scopes",JSON.stringify(r.split("+"))),this._storage.setItem("access_token_stored_at",""+Date.now()),n){var o=1e3*n,i=(new Date).getTime()+o;this._storage.setItem("expires_at",""+i)}t&&this._storage.setItem("refresh_token",t)},n.prototype.tryLogin=function(e){return void 0===e&&(e=null),"code"===this.config.responseType?this.tryLoginCodeFlow(e).then(function(e){return!0}):this.tryLoginImplicitFlow(e)},n.prototype.parseQueryString=function(e){return e&&0!==e.length?("?"===e.charAt(0)&&(e=e.substr(1)),this.urlHelper.parseQueryString(e)):{}},n.prototype.tryLoginCodeFlow=function(e){var t=this;void 0===e&&(e=null);(e=e||{}).customHashFragment?e.customHashFragment.substring(1):window.location.search;var n=this.getCodePartsFromUrl(window.location.search),r=n.code,o=n.state;if(!e.preventClearHashAfterLogin){var i=location.href.replace(/[&\?]code=[^&\$]*/,"").replace(/[&\?]scope=[^&\$]*/,"").replace(/[&\?]state=[^&\$]*/,"").replace(/[&\?]session_state=[^&\$]*/,"");history.replaceState(null,window.name,i)}var s=f(this.parseState(o),2),a=s[0],c=s[1];if(this.state=c,n.error){this.debug("error trying to login"),this.handleLoginError({},n);var u=new H("code_error",{},n);return this.eventsSubject.next(u),Promise.reject(u)}if(!a)return Promise.resolve();if(!this.validateNonce(a)){var l=new H("invalid_nonce_in_state",null);return this.eventsSubject.next(l),Promise.reject(l)}return r?new Promise(function(n,o){t.getTokenFromCode(r,e).then(function(e){n()})["catch"](function(e){o(e)})}):Promise.resolve()},n.prototype.getCodePartsFromUrl=function(e){return e&&0!==e.length?("?"===e.charAt(0)&&(e=e.substr(1)),this.urlHelper.parseQueryString(e)):this.urlHelper.getHashFragmentParams()},n.prototype.getTokenFromCode=function(e,t){var n=(new r.HttpParams).set("grant_type","authorization_code").set("code",e).set("redirect_uri",t.customRedirectUri||this.redirectUri);if(!this.disablePKCE){var o=this._storage.getItem("PKCI_verifier");o?n=n.set("code_verifier",o):console.warn("No PKCI verifier found in oauth storage!")}return this.fetchAndProcessToken(n)},n.prototype.fetchAndProcessToken=function(e){var t=this;this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint");var n=(new r.HttpHeaders).set("Content-Type","application/x-www-form-urlencoded");if(this.useHttpBasicAuth){var o=btoa(this.clientId+":"+this.dummyClientSecret);n=n.set("Authorization","Basic "+o)}return this.useHttpBasicAuth||(e=e.set("client_id",this.clientId)),!this.useHttpBasicAuth&&this.dummyClientSecret&&(e=e.set("client_secret",this.dummyClientSecret)),new Promise(function(r,o){var i,s;if(t.customQueryParams)try{for(var a=p(Object.getOwnPropertyNames(t.customQueryParams)),c=a.next();!c.done;c=a.next()){var u=c.value;e=e.set(u,t.customQueryParams[u])}}catch(l){i={error:l}}finally{try{c&&!c.done&&(s=a["return"])&&s.call(a)}finally{if(i)throw i.error}}t.http.post(t.tokenEndpoint,e,{headers:n}).subscribe(function(e){t.debug("refresh tokenResponse",e),t.storeAccessTokenResponse(e.access_token,e.refresh_token,e.expires_in,e.scope),t.oidc&&e.id_token?t.processIdToken(e.id_token,e.access_token).then(function(n){t.storeIdToken(n),t.eventsSubject.next(new C("token_received")),t.eventsSubject.next(new C("token_refreshed")),r(e)})["catch"](function(e){t.eventsSubject.next(new H("token_validation_error",e)),console.error("Error validating tokens"),console.error(e),o(e)}):(t.eventsSubject.next(new C("token_received")),t.eventsSubject.next(new C("token_refreshed")),r(e))},function(e){console.error("Error getting token",e),t.eventsSubject.next(new H("token_refresh_error",e)),o(e)})})},n.prototype.tryLoginImplicitFlow=function(e){var t,n=this;void 0===e&&(e=null),t=(e=e||{}).customHashFragment?this.urlHelper.getHashFragmentParams(e.customHashFragment):this.urlHelper.getHashFragmentParams(),this.debug("parsed url",t);var r=t.state,o=f(this.parseState(r),2),i=o[0],s=o[1];if(this.state=s,t.error){this.debug("error trying to login"),this.handleLoginError(e,t);var a=new H("token_error",{},t);return this.eventsSubject.next(a),Promise.reject(a)}var c=t.access_token,u=t.id_token,l=t.session_state,h=t.scope;if(!this.requestAccessToken&&!this.oidc)return Promise.reject("Either requestAccessToken or oidc (or both) must be true.");if(this.requestAccessToken&&!c)return Promise.resolve(!1);if(this.requestAccessToken&&!e.disableOAuth2StateCheck&&!r)return Promise.resolve(!1);if(this.oidc&&!u)return Promise.resolve(!1);if((this.sessionChecksEnabled&&!l&&this.logger.warn("session checks (Session Status Change Notification) were activated in the configuration but the id_token does not contain a session_state claim"),this.requestAccessToken&&!e.disableOAuth2StateCheck)&&!this.validateNonce(i)){var d=new H("invalid_nonce_in_state",null);return this.eventsSubject.next(d),Promise.reject(d)}return this.requestAccessToken&&this.storeAccessTokenResponse(c,null,t.expires_in||this.fallbackAccessTokenExpirationTimeInSec,h),this.oidc?this.processIdToken(u,c).then(function(t){return e.validationHandler?e.validationHandler({accessToken:c,idClaims:t.idTokenClaims,idToken:t.idToken,state:r}).then(function(e){return t}):t}).then(function(t){return n.storeIdToken(t),n.storeSessionState(l),n.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash=""),n.eventsSubject.next(new C("token_received")),n.callOnTokenReceivedIfExists(e),n.inImplicitFlow=!1,!0})["catch"](function(e){return n.eventsSubject.next(new H("token_validation_error",e)),n.logger.error("Error validating tokens"),n.logger.error(e),Promise.reject(e)}):(this.eventsSubject.next(new C("token_received")),this.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash=""),this.callOnTokenReceivedIfExists(e),Promise.resolve(!0))},n.prototype.parseState=function(e){var t=e,n="";if(e){var r=e.indexOf(this.config.nonceStateSeparator);r>-1&&(t=e.substr(0,r),n=e.substr(r+this.config.nonceStateSeparator.length))}return[t,n]},n.prototype.validateNonce=function(e){var t=this._storage.getItem("nonce");if(t!==e){return console.error("Validating access_token failed, wrong state/nonce.",t,e),!1}return!0},n.prototype.storeIdToken=function(e){this._storage.setItem("id_token",e.idToken),this._storage.setItem("id_token_claims_obj",e.idTokenClaimsJson),this._storage.setItem("id_token_expires_at",""+e.idTokenExpiresAt),this._storage.setItem("id_token_stored_at",""+Date.now())},n.prototype.storeSessionState=function(e){this._storage.setItem("session_state",e)},n.prototype.getSessionState=function(){return this._storage.getItem("session_state")},n.prototype.handleLoginError=function(e,t){e.onLoginError&&e.onLoginError(t),this.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash="")},n.prototype.processIdToken=function(e,t,n){var r=this;void 0===n&&(n=!1);var o=e.split("."),i=w(this.padBase64(o[0])),s=JSON.parse(i),a=w(this.padBase64(o[1])),c=JSON.parse(a),u=this._storage.getItem("nonce");if(Array.isArray(c.aud)){if(c.aud.every(function(e){return e!==r.clientId})){var l="Wrong audience: "+c.aud.join(",");return this.logger.warn(l),Promise.reject(l)}}else if(c.aud!==this.clientId){l="Wrong audience: "+c.aud;return this.logger.warn(l),Promise.reject(l)}if(!c.sub){l="No sub claim in id_token";return this.logger.warn(l),Promise.reject(l)}if(this.sessionChecksEnabled&&this.silentRefreshSubject&&this.silentRefreshSubject!==c.sub){l="After refreshing, we got an id_token for another user (sub). Expected sub: "+this.silentRefreshSubject+", received sub: "+c.sub;return this.logger.warn(l),Promise.reject(l)}if(!c.iat){l="No iat claim in id_token";return this.logger.warn(l),Promise.reject(l)}if(!this.skipIssuerCheck&&c.iss!==this.issuer){l="Wrong issuer: "+c.iss;return this.logger.warn(l),Promise.reject(l)}if(!n&&c.nonce!==u){l="Wrong nonce: "+c.nonce;return this.logger.warn(l),Promise.reject(l)}if(this.hasOwnProperty("responseType")&&"code"===this.responseType&&(this.disableAtHashCheck=!0),!this.disableAtHashCheck&&this.requestAccessToken&&!c.at_hash){l="An at_hash is needed!";return this.logger.warn(l),Promise.reject(l)}var h=Date.now(),d=1e3*c.iat,p=1e3*c.exp,f=1e3*(this.clockSkewInSec||600);if(d-f>=h||p+f<=h){l="Token has expired";return console.error(l),console.error({now:h,issuedAtMSec:d,expiresAtMSec:p}),Promise.reject(l)}var g={accessToken:t,idToken:e,jwks:this.jwks,idTokenClaims:c,idTokenHeader:s,loadKeys:function(){return r.loadJwks()}};return this.disableAtHashCheck?this.checkSignature(g).then(function(t){return{idToken:e,idTokenClaims:c,idTokenClaimsJson:a,idTokenHeader:s,idTokenHeaderJson:i,idTokenExpiresAt:p}}):this.checkAtHash(g).then(function(t){if(!r.disableAtHashCheck&&r.requestAccessToken&&!t){var n="Wrong at_hash";return r.logger.warn(n),Promise.reject(n)}return r.checkSignature(g).then(function(t){var n=!r.disableAtHashCheck,o={idToken:e,idTokenClaims:c,idTokenClaimsJson:a,idTokenHeader:s,idTokenHeaderJson:i,idTokenExpiresAt:p};return n?r.checkAtHash(g).then(function(e){if(r.requestAccessToken&&!e){var t="Wrong at_hash";return r.logger.warn(t),Promise.reject(t)}return o}):o})})},n.prototype.getIdentityClaims=function(){var e=this._storage.getItem("id_token_claims_obj");return e?JSON.parse(e):null},n.prototype.getGrantedScopes=function(){var e=this._storage.getItem("granted_scopes");return e?JSON.parse(e):null},n.prototype.getIdToken=function(){return this._storage?this._storage.getItem("id_token"):null},n.prototype.padBase64=function(e){for(;e.length%4!=0;)e+="=";return e},n.prototype.getAccessToken=function(){return this._storage?this._storage.getItem("access_token"):null},n.prototype.getRefreshToken=function(){return this._storage?this._storage.getItem("refresh_token"):null},n.prototype.getAccessTokenExpiration=function(){return this._storage.getItem("expires_at")?parseInt(this._storage.getItem("expires_at"),10):null},n.prototype.getAccessTokenStoredAt=function(){return parseInt(this._storage.getItem("access_token_stored_at"),10)},n.prototype.getIdTokenStoredAt=function(){return parseInt(this._storage.getItem("id_token_stored_at"),10)},n.prototype.getIdTokenExpiration=function(){return this._storage.getItem("id_token_expires_at")?parseInt(this._storage.getItem("id_token_expires_at"),10):null},n.prototype.hasValidAccessToken=function(){if(this.getAccessToken()){var e=this._storage.getItem("expires_at"),t=new Date;return!(e&&parseInt(e,10)<t.getTime())}return!1},n.prototype.hasValidIdToken=function(){if(this.getIdToken()){var e=this._storage.getItem("id_token_expires_at"),t=new Date;return!(e&&parseInt(e,10)<t.getTime())}return!1},n.prototype.authorizationHeader=function(){return"Bearer "+this.getAccessToken()},n.prototype.logOut=function(e){void 0===e&&(e=!1);var t=this.getIdToken();if(this._storage.removeItem("access_token"),this._storage.removeItem("id_token"),this._storage.removeItem("refresh_token"),this._storage.removeItem("nonce"),this._storage.removeItem("expires_at"),this._storage.removeItem("id_token_claims_obj"),this._storage.removeItem("id_token_expires_at"),this._storage.removeItem("id_token_stored_at"),this._storage.removeItem("access_token_stored_at"),this._storage.removeItem("granted_scopes"),this._storage.removeItem("session_state"),this.silentRefreshSubject=null,this.eventsSubject.next(new A("logout")),this.logoutUrl&&!e&&(t||this.postLogoutRedirectUri)){var n;if(!this.validateUrlForHttps(this.logoutUrl))throw new Error("logoutUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");if(this.logoutUrl.indexOf("{{")>-1)n=this.logoutUrl.replace(/\{\{id_token\}\}/,t).replace(/\{\{client_id\}\}/,this.clientId);else{var o=new r.HttpParams;t&&(o=o.set("id_token_hint",t));var i=this.postLogoutRedirectUri||this.redirectUri;i&&(o=o.set("post_logout_redirect_uri",i)),n=this.logoutUrl+(this.logoutUrl.indexOf("?")>-1?"&":"?")+o.toString()}this.config.openUri(n)}},n.prototype.createAndSaveNonce=function(){var e=this;return this.createNonce().then(function(t){return e._storage.setItem("nonce",t),t})},n.prototype.ngOnDestroy=function(){this.clearAccessTokenTimer(),this.clearIdTokenTimer(),this.removeSilentRefreshEventListener();var e=document.getElementById(this.silentRefreshIFrameName);e&&e.remove(),this.stopSessionCheckTimer(),this.removeSessionCheckEventListener();var t=document.getElementById(this.sessionCheckIFrameName);t&&t.remove()},n.prototype.createNonce=function(){var e=this;return new Promise(function(t){if(e.rngUrl)throw new Error("createNonce with rng-web-api has not been implemented so far");var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~",r=45,o="",i="undefined"==typeof self?null:self.crypto||self.msCrypto;if(i){var s=new Uint8Array(r);i.getRandomValues(s),s=s.map(function(e){return n.charCodeAt(e%n.length)}),o=String.fromCharCode.apply(null,s)}else for(;0<r--;)o+=n[Math.random()*n.length|0];t(_(o))})},n.prototype.checkAtHash=function(e){return h(this,void 0,void 0,function(){return d(this,function(t){return this.tokenValidationHandler?[2,this.tokenValidationHandler.validateAtHash(e)]:(this.logger.warn("No tokenValidationHandler configured. Cannot check at_hash."),[2,!0])})})},n.prototype.checkSignature=function(e){return this.tokenValidationHandler?this.tokenValidationHandler.validateSignature(e):(this.logger.warn("No tokenValidationHandler configured. Cannot check signature."),Promise.resolve(null))},n.prototype.initLoginFlow=function(e,t){return void 0===e&&(e=""),void 0===t&&(t={}),"code"===this.responseType?this.initCodeFlow(e,t):this.initImplicitFlow(e,t)},n.prototype.initCodeFlow=function(e,t){var n=this;void 0===e&&(e=""),void 0===t&&(t={}),""!==this.loginUrl?this.initCodeFlowInternal(e,t):this.events.pipe(i.filter(function(e){return"discovery_document_loaded"===e.type})).subscribe(function(r){return n.initCodeFlowInternal(e,t)})},n.prototype.initCodeFlowInternal=function(e,t){if(void 0===e&&(e=""),void 0===t&&(t={}),!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");this.createLoginUrl(e,"",null,!1,t).then(this.config.openUri)["catch"](function(e){console.error("Error in initAuthorizationCodeFlow"),console.error(e)})},n.prototype.createChallangeVerifierPairForPKCE=function(){return h(this,void 0,void 0,function(){var e,t;return d(this,function(n){switch(n.label){case 0:if(!this.crypto)throw new Error("PKCI support for code flow needs a CryptoHander. Did you import the OAuthModule using forRoot() ?");return[4,this.createNonce()];case 1:return e=n.sent(),[4,this.crypto.calcHash(e,"sha-256")];case 2:return t=n.sent(),[2,[_(t),e]]}})})},n=c([t.Injectable(),u(2,t.Optional()),u(3,t.Optional()),u(4,t.Optional()),u(7,t.Optional()),l("design:paramtypes",[t.NgZone,r.HttpClient,v,b,E,S,m,U])],n)}(E),R=function(){return function(){}}(),L=function(){return function(){}}(),F=function(){return function(){}}(),O=function(){function e(){}return e.prototype.handleError=function(e){return o.throwError(e)},e}(),D=function(){function e(e,t,n,r){this.authStorage=e,this.oAuthService=t,this.errorHandler=n,this.moduleConfig=r}return e.prototype.checkUrl=function(e){return this.moduleConfig.resourceServer.customUrlValidation?this.moduleConfig.resourceServer.customUrlValidation(e):!this.moduleConfig.resourceServer.allowedUrls||!!this.moduleConfig.resourceServer.allowedUrls.find(function(t){return e.startsWith(t)})},e.prototype.intercept=function(e,t){var n=this,r=e.url.toLowerCase();return this.moduleConfig&&this.moduleConfig.resourceServer&&this.checkUrl(r)?this.moduleConfig.resourceServer.sendAccessToken?o.merge(o.of(this.oAuthService.getAccessToken()).pipe(i.filter(function(e){return!!e})),this.oAuthService.events.pipe(i.filter(function(e){return"token_received"===e.type}),i.timeout(this.oAuthService.waitForTokenInMsec||0),i.catchError(function(e){return o.of(null)}),i.map(function(e){return n.oAuthService.getAccessToken()}))).pipe(i.take(1),i.mergeMap(function(r){if(r){var o="Bearer "+r,s=e.headers.set("Authorization",o);e=e.clone({headers:s})}return t.handle(e).pipe(i.catchError(function(e){return n.errorHandler.handleError(e)}))})):t.handle(e).pipe(i.catchError(function(e){return n.errorHandler.handleError(e)})):t.handle(e)},e=c([t.Injectable(),u(3,t.Optional()),l("design:paramtypes",[v,j,F,R])],e)}(),N=function(){function e(){}return e.prototype.validateSignature=function(e){return Promise.resolve(null)},e.prototype.validateAtHash=function(e){return Promise.resolve(!0)},e}();function V(){return console}function M(){return"undefined"!=typeof sessionStorage?sessionStorage:new y}var q=function(){function e(){}var o;return o=e,e.forRoot=function(e,t){return void 0===e&&(e=null),void 0===t&&(t=N),{ngModule:o,providers:[j,S,{provide:m,useFactory:V},{provide:v,useFactory:M},{provide:b,useClass:t},{provide:U,useClass:x},{provide:F,useClass:O},{provide:R,useValue:e},{provide:r.HTTP_INTERCEPTORS,useClass:D,multi:!0}]}},e=o=c([t.NgModule({imports:[n.CommonModule],declarations:[],exports:[]})],e)}(),B="PLEASE READ THIS CAREFULLY:\n\nBeginning with angular-oauth2-oidc version 9, the JwksValidationHandler\nhas been moved to an library of its own. If you need it for implementing\nOAuth2/OIDC **implicit flow**, please install it using npm:\n\n npm i angular-oauth2-oidc-jwks --save\n\nAfter that, you can import it into your application:\n\n import { JwksValidationHandler } from 'angular-oauth2-oidc-jwks';\n\nPlease note, that this dependency is not needed for the **code flow**,\nwhich is nowadays the **recommented** one for single page applications.\nThis also results in smaller bundle sizes.\n",Q=function(e){function t(){var t=e.call(this)||this;return console.error(B),t}return a(t,e),t}(N),J=new t.InjectionToken("AUTH_CONFIG");e.AUTH_CONFIG=J,e.AbstractValidationHandler=T,e.AuthConfig=E,e.DefaultOAuthInterceptor=D,e.JwksValidationHandler=Q,e.LoginOptions=g,e.MemoryStorage=y,e.NullValidationHandler=N,e.OAuthErrorEvent=H,e.OAuthEvent=I,e.OAuthInfoEvent=A,e.OAuthLogger=m,e.OAuthModule=q,e.OAuthModuleConfig=R,e.OAuthNoopResourceServerErrorHandler=O,e.OAuthResourceServerConfig=L,e.OAuthResourceServerErrorHandler=F,e.OAuthService=j,e.OAuthStorage=v,e.OAuthSuccessEvent=C,e.ReceivedTokens=k,e.UrlHelperService=S,e.ValidationHandler=b,e.ɵa=U,e.ɵb=x,e.ɵc=V,e.ɵd=M,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/common/http"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("angular-oauth2-oidc",["exports","@angular/core","@angular/common","@angular/common/http","rxjs","rxjs/operators"],t):t((e=e||self)["angular-oauth2-oidc"]={},e.ng.core,e.ng.common,e.ng.common.http,e.rxjs,e.rxjs.operators)}(this,(function(e,t,n,r,o,i){"use strict";
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */var s=function(e,t){return(s=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])})(e,t)};function a(e,t){function n(){this.constructor=e}s(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function c(e,t,n,r){var o,i=arguments.length,s=i<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(s=(i<3?o(s):i>3?o(t,n,s):o(t,n))||s);return i>3&&s&&Object.defineProperty(t,n,s),s}function u(e,t){return function(n,r){t(n,r,e)}}function l(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function h(e,t,n,r){return new(n||(n=Promise))((function(o,i){function s(e){try{c(r.next(e))}catch(e){i(e)}}function a(e){try{c(r.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(s,a)}c((r=r.apply(e,t||[])).next())}))}function d(e,t){var n,r,o,i,s={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(n)throw new TypeError("Generator is already executing.");for(;s;)try{if(n=1,r&&(o=2&i[0]?r.return:i[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,i[1])).done)return o;switch(r=0,o&&(i=[2&i[0],o.value]),i[0]){case 0:case 1:o=i;break;case 4:return s.label++,{value:i[1],done:!1};case 5:s.label++,r=i[1],i=[0];continue;case 7:i=s.ops.pop(),s.trys.pop();continue;default:if(!(o=(o=s.trys).length>0&&o[o.length-1])&&(6===i[0]||2===i[0])){s=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]<o[3])){s.label=i[1];break}if(6===i[0]&&s.label<o[1]){s.label=o[1],o=i;break}if(o&&s.label<o[2]){s.label=o[2],s.ops.push(i);break}o[2]&&s.ops.pop(),s.trys.pop();continue}i=t.call(e,s)}catch(e){i=[6,e],r=0}finally{n=o=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}function p(e){var t="function"==typeof Symbol&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function f(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,i=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=i.next()).done;)s.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(n=i.return)&&n.call(i)}finally{if(o)throw o.error}}return s}var g=function(){this.preventClearHashAfterLogin=!1},m=function(){},v=function(){},y=function(){function e(){this.data=new Map}return e.prototype.getItem=function(e){return this.data.get(e)},e.prototype.removeItem=function(e){this.data.delete(e)},e.prototype.setItem=function(e,t){this.data.set(e,t)},e=c([t.Injectable()],e)}(),k=function(){};function w(e){var t=e.replace(/\-/g,"+").replace(/\_/g,"/");return decodeURIComponent(atob(t).split("").map((function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}function _(e){return btoa(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}var b=function(){},T=function(){function e(){}return e.prototype.validateAtHash=function(e){return h(this,void 0,void 0,(function(){var t,n,r,o,i;return d(this,(function(s){switch(s.label){case 0:return t=this.inferHashAlgorithm(e.idTokenHeader),[4,this.calcHash(e.accessToken,t)];case 1:return n=s.sent(),r=n.substr(0,n.length/2),o=_(r),i=e.idTokenClaims.at_hash.replace(/=/g,""),o!==i&&(console.error("exptected at_hash: "+o),console.error("actual at_hash: "+i)),[2,o===i]}}))}))},e.prototype.inferHashAlgorithm=function(e){var t=e.alg;if(!t.match(/^.S[0-9]{3}$/))throw new Error("Algorithm not supported: "+t);return"sha-"+t.substr(2)},e}(),S=function(){function e(){}return e.prototype.getHashFragmentParams=function(e){var t=e||window.location.hash;if(0!==(t=decodeURIComponent(t)).indexOf("#"))return{};var n=t.indexOf("?");return t=n>-1?t.substr(n+1):t.substr(1),this.parseQueryString(t)},e.prototype.parseQueryString=function(e){var t,n,r,o,i,s,a,c={};if(null===e)return c;t=e.split("&");for(var u=0;u<t.length;u++)-1===(r=(n=t[u]).indexOf("="))?(o=n,i=null):(o=n.substr(0,r),i=n.substr(r+1)),s=decodeURIComponent(o),a=decodeURIComponent(i),"/"===s.substr(0,1)&&(s=s.substr(1)),c[s]=a;return c},e=c([t.Injectable()],e)}(),I=function(e){this.type=e},C=function(e){function t(t,n){void 0===n&&(n=null);var r=e.call(this,t)||this;return r.info=n,r}return a(t,e),t}(I),A=function(e){function t(t,n){void 0===n&&(n=null);var r=e.call(this,t)||this;return r.info=n,r}return a(t,e),t}(I),H=function(e){function t(t,n,r){void 0===r&&(r=null);var o=e.call(this,t)||this;return o.reason=n,o.params=r,o}return a(t,e),t}(I),E=function(e){this.clientId="",this.redirectUri="",this.postLogoutRedirectUri="",this.loginUrl="",this.scope="openid profile",this.resource="",this.rngUrl="",this.oidc=!0,this.requestAccessToken=!0,this.options=null,this.issuer="",this.logoutUrl="",this.clearHashAfterLogin=!0,this.tokenEndpoint=null,this.userinfoEndpoint=null,this.responseType="",this.showDebugInformation=!1,this.silentRefreshRedirectUri="",this.silentRefreshMessagePrefix="",this.silentRefreshShowIFrame=!1,this.siletRefreshTimeout=2e4,this.silentRefreshTimeout=2e4,this.dummyClientSecret=null,this.requireHttps="remoteOnly",this.strictDiscoveryDocumentValidation=!0,this.jwks=null,this.customQueryParams=null,this.silentRefreshIFrameName="angular-oauth-oidc-silent-refresh-iframe",this.timeoutFactor=.75,this.sessionChecksEnabled=!1,this.sessionCheckIntervall=3e3,this.sessionCheckIFrameUrl=null,this.sessionCheckIFrameName="angular-oauth-oidc-check-session-iframe",this.disableAtHashCheck=!1,this.skipSubjectCheck=!1,this.useIdTokenHintForSilentRefresh=!1,this.skipIssuerCheck=!1,this.nonceStateSeparator=";",this.useHttpBasicAuth=!1,this.waitForTokenInMsec=0,this.disablePKCE=!1,this.openUri=function(e){location.href=e},e&&Object.assign(this,e)},P=function(){function e(){}return e.prototype.encodeKey=function(e){return encodeURIComponent(e)},e.prototype.encodeValue=function(e){return encodeURIComponent(e)},e.prototype.decodeKey=function(e){return decodeURIComponent(e)},e.prototype.decodeValue=function(e){return decodeURIComponent(e)},e}(),U=function(){},j=function(){function e(){}return e.prototype.calcHash=function(e,t){return h(this,void 0,void 0,(function(){var n,r,o;return d(this,(function(i){switch(i.label){case 0:return n=new TextEncoder,r=n.encode(e),[4,window.crypto.subtle.digest(t,r)];case 1:return o=i.sent(),[2,this.toHashString(o)]}}))}))},e.prototype.toHashString=function(e){var t,n,r=new Uint8Array(e),o="";try{for(var i=p(r),s=i.next();!s.done;s=i.next()){var a=s.value;o+=String.fromCharCode(a)}}catch(e){t={error:e}}finally{try{s&&!s.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}return o},e=c([t.Injectable()],e)}(),x=function(e){function n(t,n,r,i,s,a,c,u){var l=e.call(this)||this;l.ngZone=t,l.http=n,l.config=s,l.urlHelper=a,l.logger=c,l.crypto=u,l.discoveryDocumentLoaded=!1,l.state="",l.eventsSubject=new o.Subject,l.discoveryDocumentLoadedSubject=new o.Subject,l.grantTypesSupported=[],l.inImplicitFlow=!1,l.debug("angular-oauth2-oidc v8-beta"),l.discoveryDocumentLoaded$=l.discoveryDocumentLoadedSubject.asObservable(),l.events=l.eventsSubject.asObservable(),i&&(l.tokenValidationHandler=i),s&&l.configure(s);try{r?l.setStorage(r):"undefined"!=typeof sessionStorage&&l.setStorage(sessionStorage)}catch(e){console.error("No OAuthStorage provided and cannot access default (sessionStorage).Consider providing a custom OAuthStorage implementation in your module.",e)}return l.setupRefreshTimer(),l}return a(n,e),n.prototype.configure=function(e){Object.assign(this,new E,e),this.config=Object.assign({},new E,e),this.sessionChecksEnabled&&this.setupSessionCheck(),this.configChanged()},n.prototype.configChanged=function(){this.setupRefreshTimer()},n.prototype.restartSessionChecksIfStillLoggedIn=function(){this.hasValidIdToken()&&this.initSessionCheck()},n.prototype.restartRefreshTimerIfStillLoggedIn=function(){this.setupExpirationTimers()},n.prototype.setupSessionCheck=function(){var e=this;this.events.pipe(i.filter((function(e){return"token_received"===e.type}))).subscribe((function(t){e.initSessionCheck()}))},n.prototype.setupAutomaticSilentRefresh=function(e,t,n){var r=this;void 0===e&&(e={}),void 0===n&&(n=!0);var o=!0;this.events.pipe(i.tap((function(e){"token_received"===e.type?o=!0:"logout"===e.type&&(o=!1)})),i.filter((function(e){return"token_expires"===e.type})),i.debounceTime(1e3)).subscribe((function(i){null!=t&&"any"!==t&&i.info!==t||!o||r.refreshInternal(e,n).catch((function(e){r.debug("Automatic silent refresh did not work")}))})),this.restartRefreshTimerIfStillLoggedIn()},n.prototype.refreshInternal=function(e,t){return this.silentRefreshRedirectUri||"code"!==this.responseType?this.silentRefresh(e,t):this.refreshToken()},n.prototype.loadDiscoveryDocumentAndTryLogin=function(e){var t=this;return void 0===e&&(e=null),this.loadDiscoveryDocument().then((function(n){return t.tryLogin(e)}))},n.prototype.loadDiscoveryDocumentAndLogin=function(e){var t=this;return void 0===e&&(e=null),e||(e={state:""}),this.loadDiscoveryDocumentAndTryLogin(e).then((function(e){return!(!t.hasValidIdToken()||!t.hasValidAccessToken())||("code"===t.responseType?t.initCodeFlow():t.initImplicitFlow(),!1)}))},n.prototype.debug=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];this.showDebugInformation&&this.logger.debug.apply(this.logger,e)},n.prototype.validateUrlFromDiscoveryDocument=function(e){var t=[],n=this.validateUrlForHttps(e),r=this.validateUrlAgainstIssuer(e);return n||t.push("https for all urls required. Also for urls received by discovery."),r||t.push("Every url in discovery document has to start with the issuer url.Also see property strictDiscoveryDocumentValidation."),t},n.prototype.validateUrlForHttps=function(e){if(!e)return!0;var t=e.toLowerCase();return!1===this.requireHttps||(!(!t.match(/^http:\/\/localhost($|[:\/])/)&&!t.match(/^http:\/\/localhost($|[:\/])/)||"remoteOnly"!==this.requireHttps)||t.startsWith("https://"))},n.prototype.assertUrlNotNullAndCorrectProtocol=function(e,t){if(!e)throw new Error("'"+t+"' should not be null");if(!this.validateUrlForHttps(e))throw new Error("'"+t+"' must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).")},n.prototype.validateUrlAgainstIssuer=function(e){return!this.strictDiscoveryDocumentValidation||(!e||e.toLowerCase().startsWith(this.issuer.toLowerCase()))},n.prototype.setupRefreshTimer=function(){var e=this;"undefined"!=typeof window?((this.hasValidIdToken()||this.hasValidAccessToken())&&(this.clearAccessTokenTimer(),this.clearIdTokenTimer(),this.setupExpirationTimers()),this.tokenReceivedSubscription&&this.tokenReceivedSubscription.unsubscribe(),this.tokenReceivedSubscription=this.events.pipe(i.filter((function(e){return"token_received"===e.type}))).subscribe((function(t){e.clearAccessTokenTimer(),e.clearIdTokenTimer(),e.setupExpirationTimers()}))):this.debug("timer not supported on this plattform")},n.prototype.setupExpirationTimers=function(){this.hasValidAccessToken()&&this.setupAccessTokenTimer(),this.hasValidIdToken()&&this.setupIdTokenTimer()},n.prototype.setupAccessTokenTimer=function(){var e=this,t=this.getAccessTokenExpiration(),n=this.getAccessTokenStoredAt(),r=this.calcTimeout(n,t);this.ngZone.runOutsideAngular((function(){e.accessTokenTimeoutSubscription=o.of(new A("token_expires","access_token")).pipe(i.delay(r)).subscribe((function(t){e.ngZone.run((function(){e.eventsSubject.next(t)}))}))}))},n.prototype.setupIdTokenTimer=function(){var e=this,t=this.getIdTokenExpiration(),n=this.getIdTokenStoredAt(),r=this.calcTimeout(n,t);this.ngZone.runOutsideAngular((function(){e.idTokenTimeoutSubscription=o.of(new A("token_expires","id_token")).pipe(i.delay(r)).subscribe((function(t){e.ngZone.run((function(){e.eventsSubject.next(t)}))}))}))},n.prototype.clearAccessTokenTimer=function(){this.accessTokenTimeoutSubscription&&this.accessTokenTimeoutSubscription.unsubscribe()},n.prototype.clearIdTokenTimer=function(){this.idTokenTimeoutSubscription&&this.idTokenTimeoutSubscription.unsubscribe()},n.prototype.calcTimeout=function(e,t){var n=Date.now(),r=(t-e)*this.timeoutFactor-(n-e);return Math.max(0,r)},n.prototype.setStorage=function(e){this._storage=e,this.configChanged()},n.prototype.loadDiscoveryDocument=function(e){var t=this;return void 0===e&&(e=null),new Promise((function(n,r){e||((e=t.issuer||"").endsWith("/")||(e+="/"),e+=".well-known/openid-configuration"),t.validateUrlForHttps(e)?t.http.get(e).subscribe((function(e){if(!t.validateDiscoveryDocument(e))return t.eventsSubject.next(new H("discovery_document_validation_error",null)),void r("discovery_document_validation_error");t.loginUrl=e.authorization_endpoint,t.logoutUrl=e.end_session_endpoint||t.logoutUrl,t.grantTypesSupported=e.grant_types_supported,t.issuer=e.issuer,t.tokenEndpoint=e.token_endpoint,t.userinfoEndpoint=e.userinfo_endpoint||t.userinfoEndpoint,t.jwksUri=e.jwks_uri,t.sessionCheckIFrameUrl=e.check_session_iframe||t.sessionCheckIFrameUrl,t.discoveryDocumentLoaded=!0,t.discoveryDocumentLoadedSubject.next(e),t.sessionChecksEnabled&&t.restartSessionChecksIfStillLoggedIn(),t.loadJwks().then((function(r){var o=new C("discovery_document_loaded",{discoveryDocument:e,jwks:r});t.eventsSubject.next(o),n(o)})).catch((function(e){t.eventsSubject.next(new H("discovery_document_load_error",e)),r(e)}))}),(function(e){t.logger.error("error loading discovery document",e),t.eventsSubject.next(new H("discovery_document_load_error",e)),r(e)})):r("issuer must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).")}))},n.prototype.loadJwks=function(){var e=this;return new Promise((function(t,n){e.jwksUri?e.http.get(e.jwksUri).subscribe((function(n){e.jwks=n,e.eventsSubject.next(new C("discovery_document_loaded")),t(n)}),(function(t){e.logger.error("error loading jwks",t),e.eventsSubject.next(new H("jwks_load_error",t)),n(t)})):t(null)}))},n.prototype.validateDiscoveryDocument=function(e){var t;return this.skipIssuerCheck||e.issuer===this.issuer?(t=this.validateUrlFromDiscoveryDocument(e.authorization_endpoint)).length>0?(this.logger.error("error validating authorization_endpoint in discovery document",t),!1):(t=this.validateUrlFromDiscoveryDocument(e.end_session_endpoint)).length>0?(this.logger.error("error validating end_session_endpoint in discovery document",t),!1):((t=this.validateUrlFromDiscoveryDocument(e.token_endpoint)).length>0&&this.logger.error("error validating token_endpoint in discovery document",t),(t=this.validateUrlFromDiscoveryDocument(e.userinfo_endpoint)).length>0?(this.logger.error("error validating userinfo_endpoint in discovery document",t),!1):(t=this.validateUrlFromDiscoveryDocument(e.jwks_uri)).length>0?(this.logger.error("error validating jwks_uri in discovery document",t),!1):(this.sessionChecksEnabled&&!e.check_session_iframe&&this.logger.warn("sessionChecksEnabled is activated but discovery document does not contain a check_session_iframe field"),!0)):(this.logger.error("invalid issuer in discovery document","expected: "+this.issuer,"current: "+e.issuer),!1)},n.prototype.fetchTokenUsingPasswordFlowAndLoadUserProfile=function(e,t,n){var o=this;return void 0===n&&(n=new r.HttpHeaders),this.fetchTokenUsingPasswordFlow(e,t,n).then((function(){return o.loadUserProfile()}))},n.prototype.loadUserProfile=function(){var e=this;if(!this.hasValidAccessToken())throw new Error("Can not load User Profile without access_token");if(!this.validateUrlForHttps(this.userinfoEndpoint))throw new Error("userinfoEndpoint must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");return new Promise((function(t,n){var o=(new r.HttpHeaders).set("Authorization","Bearer "+e.getAccessToken());e.http.get(e.userinfoEndpoint,{headers:o}).subscribe((function(r){e.debug("userinfo received",r);var o=e.getIdentityClaims()||{};if(e.skipSubjectCheck||!e.oidc||o.sub&&r.sub===o.sub)r=Object.assign({},o,r),e._storage.setItem("id_token_claims_obj",JSON.stringify(r)),e.eventsSubject.next(new C("user_profile_loaded")),t(r);else{n("if property oidc is true, the received user-id (sub) has to be the user-id of the user that has logged in with oidc.\nif you are not using oidc but just oauth2 password flow set oidc to false")}}),(function(t){e.logger.error("error loading user info",t),e.eventsSubject.next(new H("user_profile_load_error",t)),n(t)}))}))},n.prototype.fetchTokenUsingPasswordFlow=function(e,t,n){var o=this;return void 0===n&&(n=new r.HttpHeaders),this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint"),new Promise((function(i,s){var a,c,u=new r.HttpParams({encoder:new P}).set("grant_type","password").set("scope",o.scope).set("username",e).set("password",t);if(o.useHttpBasicAuth){var l=btoa(o.clientId+":"+o.dummyClientSecret);n=n.set("Authorization","Basic "+l)}if(o.useHttpBasicAuth||(u=u.set("client_id",o.clientId)),!o.useHttpBasicAuth&&o.dummyClientSecret&&(u=u.set("client_secret",o.dummyClientSecret)),o.customQueryParams)try{for(var h=p(Object.getOwnPropertyNames(o.customQueryParams)),d=h.next();!d.done;d=h.next()){var f=d.value;u=u.set(f,o.customQueryParams[f])}}catch(e){a={error:e}}finally{try{d&&!d.done&&(c=h.return)&&c.call(h)}finally{if(a)throw a.error}}n=n.set("Content-Type","application/x-www-form-urlencoded"),o.http.post(o.tokenEndpoint,u,{headers:n}).subscribe((function(e){o.debug("tokenResponse",e),o.storeAccessTokenResponse(e.access_token,e.refresh_token,e.expires_in,e.scope),o.eventsSubject.next(new C("token_received")),i(e)}),(function(e){o.logger.error("Error performing password flow",e),o.eventsSubject.next(new H("token_error",e)),s(e)}))}))},n.prototype.refreshToken=function(){var e=this;return this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint"),new Promise((function(t,n){var s,a,c=(new r.HttpParams).set("grant_type","refresh_token").set("scope",e.scope).set("refresh_token",e._storage.getItem("refresh_token")),u=(new r.HttpHeaders).set("Content-Type","application/x-www-form-urlencoded");if(e.useHttpBasicAuth){var l=btoa(e.clientId+":"+e.dummyClientSecret);u=u.set("Authorization","Basic "+l)}if(e.useHttpBasicAuth||(c=c.set("client_id",e.clientId)),!e.useHttpBasicAuth&&e.dummyClientSecret&&(c=c.set("client_secret",e.dummyClientSecret)),e.customQueryParams)try{for(var h=p(Object.getOwnPropertyNames(e.customQueryParams)),d=h.next();!d.done;d=h.next()){var f=d.value;c=c.set(f,e.customQueryParams[f])}}catch(e){s={error:e}}finally{try{d&&!d.done&&(a=h.return)&&a.call(h)}finally{if(s)throw s.error}}e.http.post(e.tokenEndpoint,c,{headers:u}).pipe(i.switchMap((function(t){return t.id_token?o.from(e.processIdToken(t.id_token,t.access_token,!0)).pipe(i.tap((function(t){return e.storeIdToken(t)})),i.map((function(e){return t}))):o.of(t)}))).subscribe((function(n){e.debug("refresh tokenResponse",n),e.storeAccessTokenResponse(n.access_token,n.refresh_token,n.expires_in,n.scope),e.eventsSubject.next(new C("token_received")),e.eventsSubject.next(new C("token_refreshed")),t(n)}),(function(t){e.logger.error("Error refreshing token",t),e.eventsSubject.next(new H("token_refresh_error",t)),n(t)}))}))},n.prototype.removeSilentRefreshEventListener=function(){this.silentRefreshPostMessageEventListener&&(window.removeEventListener("message",this.silentRefreshPostMessageEventListener),this.silentRefreshPostMessageEventListener=null)},n.prototype.setupSilentRefreshEventListener=function(){var e=this;this.removeSilentRefreshEventListener(),this.silentRefreshPostMessageEventListener=function(t){var n=e.processMessageEventMessage(t);e.tryLogin({customHashFragment:n,preventClearHashAfterLogin:!0,customRedirectUri:e.silentRefreshRedirectUri||e.redirectUri}).catch((function(t){return e.debug("tryLogin during silent refresh failed",t)}))},window.addEventListener("message",this.silentRefreshPostMessageEventListener)},n.prototype.silentRefresh=function(e,t){var n=this;void 0===e&&(e={}),void 0===t&&(t=!0);var r=this.getIdentityClaims()||{};if(this.useIdTokenHintForSilentRefresh&&this.hasValidIdToken()&&(e.id_token_hint=this.getIdToken()),!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");if("undefined"==typeof document)throw new Error("silent refresh is not supported on this platform");var s=document.getElementById(this.silentRefreshIFrameName);s&&document.body.removeChild(s),this.silentRefreshSubject=r.sub;var a=document.createElement("iframe");a.id=this.silentRefreshIFrameName,this.setupSilentRefreshEventListener();var c=this.silentRefreshRedirectUri||this.redirectUri;this.createLoginUrl(null,null,c,t,e).then((function(e){a.setAttribute("src",e),n.silentRefreshShowIFrame||(a.style.display="none"),document.body.appendChild(a)}));var u=this.events.pipe(i.filter((function(e){return e instanceof H})),i.first()),l=this.events.pipe(i.filter((function(e){return"token_received"===e.type})),i.first()),h=o.of(new H("silent_refresh_timeout",null)).pipe(i.delay(this.silentRefreshTimeout));return o.race([u,l,h]).pipe(i.map((function(e){if(e instanceof H)throw"silent_refresh_timeout"===e.type?n.eventsSubject.next(e):(e=new H("silent_refresh_error",e),n.eventsSubject.next(e)),e;return"token_received"===e.type&&(e=new C("silently_refreshed"),n.eventsSubject.next(e)),e}))).toPromise()},n.prototype.initImplicitFlowInPopup=function(e){return this.initLoginFlowInPopup(e)},n.prototype.initLoginFlowInPopup=function(e){var t=this;return e=e||{},this.createLoginUrl(null,null,this.silentRefreshRedirectUri,!1,{display:"popup"}).then((function(n){return new Promise((function(r,o){var i,s=window.open(n,"_blank",t.calculatePopupFeatures(e));s?i=window.setInterval((function(){s&&!s.closed||(a(),o(new H("popup_closed",{})))}),500):o(new H("popup_blocked",{}));var a=function(){window.clearInterval(i),window.removeEventListener("message",c),null!==s&&s.close(),s=null},c=function(e){var n=t.processMessageEventMessage(e);n&&null!==n?t.tryLogin({customHashFragment:n,preventClearHashAfterLogin:!0,customRedirectUri:t.silentRefreshRedirectUri}).then((function(){a(),r()}),(function(e){a(),o(e)})):console.log("false event firing")};window.addEventListener("message",c)}))}))},n.prototype.calculatePopupFeatures=function(e){var t=e.height||470,n=e.width||500,r=window.screenLeft+(window.outerWidth-n)/2;return"location=no,toolbar=no,width="+n+",height="+t+",top="+(window.screenTop+(window.outerHeight-t)/2)+",left="+r},n.prototype.processMessageEventMessage=function(e){var t="#";if(this.silentRefreshMessagePrefix&&(t+=this.silentRefreshMessagePrefix),e&&e.data&&"string"==typeof e.data){var n=e.data;if(n.startsWith(t))return"#"+n.substr(t.length)}},n.prototype.canPerformSessionCheck=function(){return!!this.sessionChecksEnabled&&(this.sessionCheckIFrameUrl?this.getSessionState()?"undefined"!=typeof document:(console.warn("sessionChecksEnabled is activated but there is no session_state"),!1):(console.warn("sessionChecksEnabled is activated but there is no sessionCheckIFrameUrl"),!1))},n.prototype.setupSessionCheckEventListener=function(){var e=this;this.removeSessionCheckEventListener(),this.sessionCheckEventListener=function(t){var n=t.origin.toLowerCase(),r=e.issuer.toLowerCase();if(e.debug("sessionCheckEventListener"),r.startsWith(n)){switch(t.data){case"unchanged":e.handleSessionUnchanged();break;case"changed":e.ngZone.run((function(){e.handleSessionChange()}));break;case"error":e.ngZone.run((function(){e.handleSessionError()}))}e.debug("got info from session check inframe",t)}else e.debug("sessionCheckEventListener","wrong origin",n,"expected",r)},this.ngZone.runOutsideAngular((function(){window.addEventListener("message",e.sessionCheckEventListener)}))},n.prototype.handleSessionUnchanged=function(){this.debug("session check","session unchanged")},n.prototype.handleSessionChange=function(){var e=this;this.eventsSubject.next(new A("session_changed")),this.stopSessionCheckTimer(),this.silentRefreshRedirectUri?(this.silentRefresh().catch((function(t){return e.debug("silent refresh failed after session changed")})),this.waitForSilentRefreshAfterSessionChange()):(this.eventsSubject.next(new A("session_terminated")),this.logOut(!0))},n.prototype.waitForSilentRefreshAfterSessionChange=function(){var e=this;this.events.pipe(i.filter((function(e){return"silently_refreshed"===e.type||"silent_refresh_timeout"===e.type||"silent_refresh_error"===e.type})),i.first()).subscribe((function(t){"silently_refreshed"!==t.type&&(e.debug("silent refresh did not work after session changed"),e.eventsSubject.next(new A("session_terminated")),e.logOut(!0))}))},n.prototype.handleSessionError=function(){this.stopSessionCheckTimer(),this.eventsSubject.next(new A("session_error"))},n.prototype.removeSessionCheckEventListener=function(){this.sessionCheckEventListener&&(window.removeEventListener("message",this.sessionCheckEventListener),this.sessionCheckEventListener=null)},n.prototype.initSessionCheck=function(){if(this.canPerformSessionCheck()){var e=document.getElementById(this.sessionCheckIFrameName);e&&document.body.removeChild(e);var t=document.createElement("iframe");t.id=this.sessionCheckIFrameName,this.setupSessionCheckEventListener();var n=this.sessionCheckIFrameUrl;t.setAttribute("src",n),t.style.display="none",document.body.appendChild(t),this.startSessionCheckTimer()}},n.prototype.startSessionCheckTimer=function(){var e=this;this.stopSessionCheckTimer(),this.ngZone.runOutsideAngular((function(){e.sessionCheckTimer=setInterval(e.checkSession.bind(e),e.sessionCheckIntervall)}))},n.prototype.stopSessionCheckTimer=function(){this.sessionCheckTimer&&(clearInterval(this.sessionCheckTimer),this.sessionCheckTimer=null)},n.prototype.checkSession=function(){var e=document.getElementById(this.sessionCheckIFrameName);e||this.logger.warn("checkSession did not find iframe",this.sessionCheckIFrameName);var t=this.getSessionState();t||this.stopSessionCheckTimer();var n=this.clientId+" "+t;e.contentWindow.postMessage(n,this.issuer)},n.prototype.createLoginUrl=function(e,t,n,r,o){return void 0===e&&(e=""),void 0===t&&(t=""),void 0===n&&(n=""),void 0===r&&(r=!1),void 0===o&&(o={}),h(this,void 0,void 0,(function(){var i,s,a,c,u,l,h,g,m,v,y,k,w,_,b,T,S,I;return d(this,(function(d){switch(d.label){case 0:return i=this,s=n||this.redirectUri,[4,this.createAndSaveNonce()];case 1:if(a=d.sent(),e=e?a+this.config.nonceStateSeparator+e:a,!this.requestAccessToken&&!this.oidc)throw new Error("Either requestAccessToken or oidc or both must be true");return this.config.responseType?this.responseType=this.config.responseType:this.oidc&&this.requestAccessToken?this.responseType="id_token token":this.oidc&&!this.requestAccessToken?this.responseType="id_token":this.responseType="token",c=i.loginUrl.indexOf("?")>-1?"&":"?",u=i.scope,this.oidc&&!u.match(/(^|\s)openid($|\s)/)&&(u="openid "+u),l=i.loginUrl+c+"response_type="+encodeURIComponent(i.responseType)+"&client_id="+encodeURIComponent(i.clientId)+"&state="+encodeURIComponent(e)+"&redirect_uri="+encodeURIComponent(s)+"&scope="+encodeURIComponent(u),"code"!==this.responseType||this.disablePKCE?[3,3]:[4,this.createChallangeVerifierPairForPKCE()];case 2:h=f.apply(void 0,[d.sent(),2]),g=h[0],m=h[1],this._storage.setItem("PKCI_verifier",m),l+="&code_challenge="+g,l+="&code_challenge_method=S256",d.label=3;case 3:t&&(l+="&login_hint="+encodeURIComponent(t)),i.resource&&(l+="&resource="+encodeURIComponent(i.resource)),i.oidc&&(l+="&nonce="+encodeURIComponent(a)),r&&(l+="&prompt=none");try{for(v=p(Object.keys(o)),y=v.next();!y.done;y=v.next())_=y.value,l+="&"+encodeURIComponent(_)+"="+encodeURIComponent(o[_])}catch(e){b={error:e}}finally{try{y&&!y.done&&(T=v.return)&&T.call(v)}finally{if(b)throw b.error}}if(this.customQueryParams)try{for(k=p(Object.getOwnPropertyNames(this.customQueryParams)),w=k.next();!w.done;w=k.next())_=w.value,l+="&"+_+"="+encodeURIComponent(this.customQueryParams[_])}catch(e){S={error:e}}finally{try{w&&!w.done&&(I=k.return)&&I.call(k)}finally{if(S)throw S.error}}return[2,l]}}))}))},n.prototype.initImplicitFlowInternal=function(e,t){var n=this;if(void 0===e&&(e=""),void 0===t&&(t=""),!this.inImplicitFlow){if(this.inImplicitFlow=!0,!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");var r={},o=null;"string"==typeof t?o=t:"object"==typeof t&&(r=t),this.createLoginUrl(e,o,null,!1,r).then(this.config.openUri).catch((function(e){console.error("Error in initImplicitFlow",e),n.inImplicitFlow=!1}))}},n.prototype.initImplicitFlow=function(e,t){var n=this;void 0===e&&(e=""),void 0===t&&(t=""),""!==this.loginUrl?this.initImplicitFlowInternal(e,t):this.events.pipe(i.filter((function(e){return"discovery_document_loaded"===e.type}))).subscribe((function(r){return n.initImplicitFlowInternal(e,t)}))},n.prototype.resetImplicitFlow=function(){this.inImplicitFlow=!1},n.prototype.callOnTokenReceivedIfExists=function(e){if(e.onTokenReceived){var t={idClaims:this.getIdentityClaims(),idToken:this.getIdToken(),accessToken:this.getAccessToken(),state:this.state};e.onTokenReceived(t)}},n.prototype.storeAccessTokenResponse=function(e,t,n,r){if(this._storage.setItem("access_token",e),r&&this._storage.setItem("granted_scopes",JSON.stringify(r.split("+"))),this._storage.setItem("access_token_stored_at",""+Date.now()),n){var o=1e3*n,i=(new Date).getTime()+o;this._storage.setItem("expires_at",""+i)}t&&this._storage.setItem("refresh_token",t)},n.prototype.tryLogin=function(e){return void 0===e&&(e=null),"code"===this.config.responseType?this.tryLoginCodeFlow(e).then((function(e){return!0})):this.tryLoginImplicitFlow(e)},n.prototype.parseQueryString=function(e){return e&&0!==e.length?("?"===e.charAt(0)&&(e=e.substr(1)),this.urlHelper.parseQueryString(e)):{}},n.prototype.tryLoginCodeFlow=function(e){var t=this;void 0===e&&(e=null);(e=e||{}).customHashFragment?e.customHashFragment.substring(1):window.location.search;var n=this.getCodePartsFromUrl(window.location.search),r=n.code,o=n.state;if(!e.preventClearHashAfterLogin){var i=location.href.replace(/[&\?]code=[^&\$]*/,"").replace(/[&\?]scope=[^&\$]*/,"").replace(/[&\?]state=[^&\$]*/,"").replace(/[&\?]session_state=[^&\$]*/,"");history.replaceState(null,window.name,i)}var s=f(this.parseState(o),2),a=s[0],c=s[1];if(this.state=c,n.error){this.debug("error trying to login"),this.handleLoginError({},n);var u=new H("code_error",{},n);return this.eventsSubject.next(u),Promise.reject(u)}if(!a)return Promise.resolve();if(!this.validateNonce(a)){var l=new H("invalid_nonce_in_state",null);return this.eventsSubject.next(l),Promise.reject(l)}return r?new Promise((function(n,o){t.getTokenFromCode(r,e).then((function(e){n()})).catch((function(e){o(e)}))})):Promise.resolve()},n.prototype.getCodePartsFromUrl=function(e){return e&&0!==e.length?("?"===e.charAt(0)&&(e=e.substr(1)),this.urlHelper.parseQueryString(e)):this.urlHelper.getHashFragmentParams()},n.prototype.getTokenFromCode=function(e,t){var n=(new r.HttpParams).set("grant_type","authorization_code").set("code",e).set("redirect_uri",t.customRedirectUri||this.redirectUri);if(!this.disablePKCE){var o=this._storage.getItem("PKCI_verifier");o?n=n.set("code_verifier",o):console.warn("No PKCI verifier found in oauth storage!")}return this.fetchAndProcessToken(n)},n.prototype.fetchAndProcessToken=function(e){var t=this;this.assertUrlNotNullAndCorrectProtocol(this.tokenEndpoint,"tokenEndpoint");var n=(new r.HttpHeaders).set("Content-Type","application/x-www-form-urlencoded");if(this.useHttpBasicAuth){var o=btoa(this.clientId+":"+this.dummyClientSecret);n=n.set("Authorization","Basic "+o)}return this.useHttpBasicAuth||(e=e.set("client_id",this.clientId)),!this.useHttpBasicAuth&&this.dummyClientSecret&&(e=e.set("client_secret",this.dummyClientSecret)),new Promise((function(r,o){var i,s;if(t.customQueryParams)try{for(var a=p(Object.getOwnPropertyNames(t.customQueryParams)),c=a.next();!c.done;c=a.next()){var u=c.value;e=e.set(u,t.customQueryParams[u])}}catch(e){i={error:e}}finally{try{c&&!c.done&&(s=a.return)&&s.call(a)}finally{if(i)throw i.error}}t.http.post(t.tokenEndpoint,e,{headers:n}).subscribe((function(e){t.debug("refresh tokenResponse",e),t.storeAccessTokenResponse(e.access_token,e.refresh_token,e.expires_in,e.scope),t.oidc&&e.id_token?t.processIdToken(e.id_token,e.access_token).then((function(n){t.storeIdToken(n),t.eventsSubject.next(new C("token_received")),t.eventsSubject.next(new C("token_refreshed")),r(e)})).catch((function(e){t.eventsSubject.next(new H("token_validation_error",e)),console.error("Error validating tokens"),console.error(e),o(e)})):(t.eventsSubject.next(new C("token_received")),t.eventsSubject.next(new C("token_refreshed")),r(e))}),(function(e){console.error("Error getting token",e),t.eventsSubject.next(new H("token_refresh_error",e)),o(e)}))}))},n.prototype.tryLoginImplicitFlow=function(e){var t,n=this;void 0===e&&(e=null),t=(e=e||{}).customHashFragment?this.urlHelper.getHashFragmentParams(e.customHashFragment):this.urlHelper.getHashFragmentParams(),this.debug("parsed url",t);var r=t.state,o=f(this.parseState(r),2),i=o[0],s=o[1];if(this.state=s,t.error){this.debug("error trying to login"),this.handleLoginError(e,t);var a=new H("token_error",{},t);return this.eventsSubject.next(a),Promise.reject(a)}var c=t.access_token,u=t.id_token,l=t.session_state,h=t.scope;if(!this.requestAccessToken&&!this.oidc)return Promise.reject("Either requestAccessToken or oidc (or both) must be true.");if(this.requestAccessToken&&!c)return Promise.resolve(!1);if(this.requestAccessToken&&!e.disableOAuth2StateCheck&&!r)return Promise.resolve(!1);if(this.oidc&&!u)return Promise.resolve(!1);if((this.sessionChecksEnabled&&!l&&this.logger.warn("session checks (Session Status Change Notification) were activated in the configuration but the id_token does not contain a session_state claim"),this.requestAccessToken&&!e.disableOAuth2StateCheck)&&!this.validateNonce(i)){var d=new H("invalid_nonce_in_state",null);return this.eventsSubject.next(d),Promise.reject(d)}return this.requestAccessToken&&this.storeAccessTokenResponse(c,null,t.expires_in||this.fallbackAccessTokenExpirationTimeInSec,h),this.oidc?this.processIdToken(u,c).then((function(t){return e.validationHandler?e.validationHandler({accessToken:c,idClaims:t.idTokenClaims,idToken:t.idToken,state:r}).then((function(e){return t})):t})).then((function(t){return n.storeIdToken(t),n.storeSessionState(l),n.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash=""),n.eventsSubject.next(new C("token_received")),n.callOnTokenReceivedIfExists(e),n.inImplicitFlow=!1,!0})).catch((function(e){return n.eventsSubject.next(new H("token_validation_error",e)),n.logger.error("Error validating tokens"),n.logger.error(e),Promise.reject(e)})):(this.eventsSubject.next(new C("token_received")),this.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash=""),this.callOnTokenReceivedIfExists(e),Promise.resolve(!0))},n.prototype.parseState=function(e){var t=e,n="";if(e){var r=e.indexOf(this.config.nonceStateSeparator);r>-1&&(t=e.substr(0,r),n=e.substr(r+this.config.nonceStateSeparator.length))}return[t,n]},n.prototype.validateNonce=function(e){var t=this._storage.getItem("nonce");if(t!==e){return console.error("Validating access_token failed, wrong state/nonce.",t,e),!1}return!0},n.prototype.storeIdToken=function(e){this._storage.setItem("id_token",e.idToken),this._storage.setItem("id_token_claims_obj",e.idTokenClaimsJson),this._storage.setItem("id_token_expires_at",""+e.idTokenExpiresAt),this._storage.setItem("id_token_stored_at",""+Date.now())},n.prototype.storeSessionState=function(e){this._storage.setItem("session_state",e)},n.prototype.getSessionState=function(){return this._storage.getItem("session_state")},n.prototype.handleLoginError=function(e,t){e.onLoginError&&e.onLoginError(t),this.clearHashAfterLogin&&!e.preventClearHashAfterLogin&&(location.hash="")},n.prototype.processIdToken=function(e,t,n){var r=this;void 0===n&&(n=!1);var o=e.split("."),i=w(this.padBase64(o[0])),s=JSON.parse(i),a=w(this.padBase64(o[1])),c=JSON.parse(a),u=this._storage.getItem("nonce");if(Array.isArray(c.aud)){if(c.aud.every((function(e){return e!==r.clientId}))){var l="Wrong audience: "+c.aud.join(",");return this.logger.warn(l),Promise.reject(l)}}else if(c.aud!==this.clientId){l="Wrong audience: "+c.aud;return this.logger.warn(l),Promise.reject(l)}if(!c.sub){l="No sub claim in id_token";return this.logger.warn(l),Promise.reject(l)}if(this.sessionChecksEnabled&&this.silentRefreshSubject&&this.silentRefreshSubject!==c.sub){l="After refreshing, we got an id_token for another user (sub). Expected sub: "+this.silentRefreshSubject+", received sub: "+c.sub;return this.logger.warn(l),Promise.reject(l)}if(!c.iat){l="No iat claim in id_token";return this.logger.warn(l),Promise.reject(l)}if(!this.skipIssuerCheck&&c.iss!==this.issuer){l="Wrong issuer: "+c.iss;return this.logger.warn(l),Promise.reject(l)}if(!n&&c.nonce!==u){l="Wrong nonce: "+c.nonce;return this.logger.warn(l),Promise.reject(l)}if(this.hasOwnProperty("responseType")&&"code"===this.responseType&&(this.disableAtHashCheck=!0),!this.disableAtHashCheck&&this.requestAccessToken&&!c.at_hash){l="An at_hash is needed!";return this.logger.warn(l),Promise.reject(l)}var h=Date.now(),d=1e3*c.iat,p=1e3*c.exp,f=1e3*(this.clockSkewInSec||600);if(d-f>=h||p+f<=h){l="Token has expired";return console.error(l),console.error({now:h,issuedAtMSec:d,expiresAtMSec:p}),Promise.reject(l)}var g={accessToken:t,idToken:e,jwks:this.jwks,idTokenClaims:c,idTokenHeader:s,loadKeys:function(){return r.loadJwks()}};return this.disableAtHashCheck?this.checkSignature(g).then((function(t){return{idToken:e,idTokenClaims:c,idTokenClaimsJson:a,idTokenHeader:s,idTokenHeaderJson:i,idTokenExpiresAt:p}})):this.checkAtHash(g).then((function(t){if(!r.disableAtHashCheck&&r.requestAccessToken&&!t){var n="Wrong at_hash";return r.logger.warn(n),Promise.reject(n)}return r.checkSignature(g).then((function(t){var n=!r.disableAtHashCheck,o={idToken:e,idTokenClaims:c,idTokenClaimsJson:a,idTokenHeader:s,idTokenHeaderJson:i,idTokenExpiresAt:p};return n?r.checkAtHash(g).then((function(e){if(r.requestAccessToken&&!e){var t="Wrong at_hash";return r.logger.warn(t),Promise.reject(t)}return o})):o}))}))},n.prototype.getIdentityClaims=function(){var e=this._storage.getItem("id_token_claims_obj");return e?JSON.parse(e):null},n.prototype.getGrantedScopes=function(){var e=this._storage.getItem("granted_scopes");return e?JSON.parse(e):null},n.prototype.getIdToken=function(){return this._storage?this._storage.getItem("id_token"):null},n.prototype.padBase64=function(e){for(;e.length%4!=0;)e+="=";return e},n.prototype.getAccessToken=function(){return this._storage?this._storage.getItem("access_token"):null},n.prototype.getRefreshToken=function(){return this._storage?this._storage.getItem("refresh_token"):null},n.prototype.getAccessTokenExpiration=function(){return this._storage.getItem("expires_at")?parseInt(this._storage.getItem("expires_at"),10):null},n.prototype.getAccessTokenStoredAt=function(){return parseInt(this._storage.getItem("access_token_stored_at"),10)},n.prototype.getIdTokenStoredAt=function(){return parseInt(this._storage.getItem("id_token_stored_at"),10)},n.prototype.getIdTokenExpiration=function(){return this._storage.getItem("id_token_expires_at")?parseInt(this._storage.getItem("id_token_expires_at"),10):null},n.prototype.hasValidAccessToken=function(){if(this.getAccessToken()){var e=this._storage.getItem("expires_at"),t=new Date;return!(e&&parseInt(e,10)<t.getTime())}return!1},n.prototype.hasValidIdToken=function(){if(this.getIdToken()){var e=this._storage.getItem("id_token_expires_at"),t=new Date;return!(e&&parseInt(e,10)<t.getTime())}return!1},n.prototype.authorizationHeader=function(){return"Bearer "+this.getAccessToken()},n.prototype.logOut=function(e){void 0===e&&(e=!1);var t=this.getIdToken();if(this._storage.removeItem("access_token"),this._storage.removeItem("id_token"),this._storage.removeItem("refresh_token"),this._storage.removeItem("nonce"),this._storage.removeItem("expires_at"),this._storage.removeItem("id_token_claims_obj"),this._storage.removeItem("id_token_expires_at"),this._storage.removeItem("id_token_stored_at"),this._storage.removeItem("access_token_stored_at"),this._storage.removeItem("granted_scopes"),this._storage.removeItem("session_state"),this.silentRefreshSubject=null,this.eventsSubject.next(new A("logout")),this.logoutUrl&&!e&&(t||this.postLogoutRedirectUri)){var n;if(!this.validateUrlForHttps(this.logoutUrl))throw new Error("logoutUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");if(this.logoutUrl.indexOf("{{")>-1)n=this.logoutUrl.replace(/\{\{id_token\}\}/,t).replace(/\{\{client_id\}\}/,this.clientId);else{var o=new r.HttpParams;t&&(o=o.set("id_token_hint",t));var i=this.postLogoutRedirectUri||this.redirectUri;i&&(o=o.set("post_logout_redirect_uri",i)),n=this.logoutUrl+(this.logoutUrl.indexOf("?")>-1?"&":"?")+o.toString()}this.config.openUri(n)}},n.prototype.createAndSaveNonce=function(){var e=this;return this.createNonce().then((function(t){return e._storage.setItem("nonce",t),t}))},n.prototype.ngOnDestroy=function(){this.clearAccessTokenTimer(),this.clearIdTokenTimer(),this.removeSilentRefreshEventListener();var e=document.getElementById(this.silentRefreshIFrameName);e&&e.remove(),this.stopSessionCheckTimer(),this.removeSessionCheckEventListener();var t=document.getElementById(this.sessionCheckIFrameName);t&&t.remove()},n.prototype.createNonce=function(){var e=this;return new Promise((function(t){if(e.rngUrl)throw new Error("createNonce with rng-web-api has not been implemented so far");var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~",r=45,o="",i="undefined"==typeof self?null:self.crypto||self.msCrypto;if(i){var s=new Uint8Array(r);i.getRandomValues(s),s=s.map((function(e){return n.charCodeAt(e%n.length)})),o=String.fromCharCode.apply(null,s)}else for(;0<r--;)o+=n[Math.random()*n.length|0];t(_(o))}))},n.prototype.checkAtHash=function(e){return h(this,void 0,void 0,(function(){return d(this,(function(t){return this.tokenValidationHandler?[2,this.tokenValidationHandler.validateAtHash(e)]:(this.logger.warn("No tokenValidationHandler configured. Cannot check at_hash."),[2,!0])}))}))},n.prototype.checkSignature=function(e){return this.tokenValidationHandler?this.tokenValidationHandler.validateSignature(e):(this.logger.warn("No tokenValidationHandler configured. Cannot check signature."),Promise.resolve(null))},n.prototype.initLoginFlow=function(e,t){return void 0===e&&(e=""),void 0===t&&(t={}),"code"===this.responseType?this.initCodeFlow(e,t):this.initImplicitFlow(e,t)},n.prototype.initCodeFlow=function(e,t){var n=this;void 0===e&&(e=""),void 0===t&&(t={}),""!==this.loginUrl?this.initCodeFlowInternal(e,t):this.events.pipe(i.filter((function(e){return"discovery_document_loaded"===e.type}))).subscribe((function(r){return n.initCodeFlowInternal(e,t)}))},n.prototype.initCodeFlowInternal=function(e,t){if(void 0===e&&(e=""),void 0===t&&(t={}),!this.validateUrlForHttps(this.loginUrl))throw new Error("loginUrl must use HTTPS (with TLS), or config value for property 'requireHttps' must be set to 'false' and allow HTTP (without TLS).");this.createLoginUrl(e,"",null,!1,t).then(this.config.openUri).catch((function(e){console.error("Error in initAuthorizationCodeFlow"),console.error(e)}))},n.prototype.createChallangeVerifierPairForPKCE=function(){return h(this,void 0,void 0,(function(){var e,t;return d(this,(function(n){switch(n.label){case 0:if(!this.crypto)throw new Error("PKCI support for code flow needs a CryptoHander. Did you import the OAuthModule using forRoot() ?");return[4,this.createNonce()];case 1:return e=n.sent(),[4,this.crypto.calcHash(e,"sha-256")];case 2:return t=n.sent(),[2,[_(t),e]]}}))}))},n.ctorParameters=function(){return[{type:t.NgZone},{type:r.HttpClient},{type:v,decorators:[{type:t.Optional}]},{type:b,decorators:[{type:t.Optional}]},{type:E,decorators:[{type:t.Optional}]},{type:S},{type:m},{type:U,decorators:[{type:t.Optional}]}]},n=c([t.Injectable(),u(2,t.Optional()),u(3,t.Optional()),u(4,t.Optional()),u(7,t.Optional()),l("design:paramtypes",[t.NgZone,r.HttpClient,v,b,E,S,m,U])],n)}(E),R=function(){},L=function(){},F=function(){},O=function(){function e(){}return e.prototype.handleError=function(e){return o.throwError(e)},e}(),D=function(){function e(e,t,n,r){this.authStorage=e,this.oAuthService=t,this.errorHandler=n,this.moduleConfig=r}return e.prototype.checkUrl=function(e){return this.moduleConfig.resourceServer.customUrlValidation?this.moduleConfig.resourceServer.customUrlValidation(e):!this.moduleConfig.resourceServer.allowedUrls||!!this.moduleConfig.resourceServer.allowedUrls.find((function(t){return e.startsWith(t)}))},e.prototype.intercept=function(e,t){var n=this,r=e.url.toLowerCase();return this.moduleConfig&&this.moduleConfig.resourceServer&&this.checkUrl(r)?this.moduleConfig.resourceServer.sendAccessToken?o.merge(o.of(this.oAuthService.getAccessToken()).pipe(i.filter((function(e){return!!e}))),this.oAuthService.events.pipe(i.filter((function(e){return"token_received"===e.type})),i.timeout(this.oAuthService.waitForTokenInMsec||0),i.catchError((function(e){return o.of(null)})),i.map((function(e){return n.oAuthService.getAccessToken()})))).pipe(i.take(1),i.mergeMap((function(r){if(r){var o="Bearer "+r,s=e.headers.set("Authorization",o);e=e.clone({headers:s})}return t.handle(e).pipe(i.catchError((function(e){return n.errorHandler.handleError(e)})))}))):t.handle(e).pipe(i.catchError((function(e){return n.errorHandler.handleError(e)}))):t.handle(e)},e.ctorParameters=function(){return[{type:v},{type:x},{type:F},{type:R,decorators:[{type:t.Optional}]}]},e=c([t.Injectable(),u(3,t.Optional()),l("design:paramtypes",[v,x,F,R])],e)}(),N=function(){function e(){}return e.prototype.validateSignature=function(e){return Promise.resolve(null)},e.prototype.validateAtHash=function(e){return Promise.resolve(!0)},e}();function V(){return console}function M(){return"undefined"!=typeof sessionStorage?sessionStorage:new y}var q=function(){function e(){}var o;return o=e,e.forRoot=function(e,t){return void 0===e&&(e=null),void 0===t&&(t=N),{ngModule:o,providers:[x,S,{provide:m,useFactory:V},{provide:v,useFactory:M},{provide:b,useClass:t},{provide:U,useClass:j},{provide:F,useClass:O},{provide:R,useValue:e},{provide:r.HTTP_INTERCEPTORS,useClass:D,multi:!0}]}},e=o=c([t.NgModule({imports:[n.CommonModule],declarations:[],exports:[]})],e)}(),B=function(e){function t(){var t=e.call(this)||this;return console.error("PLEASE READ THIS CAREFULLY:\n\nBeginning with angular-oauth2-oidc version 9, the JwksValidationHandler\nhas been moved to an library of its own. If you need it for implementing\nOAuth2/OIDC **implicit flow**, please install it using npm:\n\n npm i angular-oauth2-oidc-jwks --save\n\nAfter that, you can import it into your application:\n\n import { JwksValidationHandler } from 'angular-oauth2-oidc-jwks';\n\nPlease note, that this dependency is not needed for the **code flow**,\nwhich is nowadays the **recommented** one for single page applications.\nThis also results in smaller bundle sizes.\n"),t}return a(t,e),t}(N),Q=new t.InjectionToken("AUTH_CONFIG");e.AUTH_CONFIG=Q,e.AbstractValidationHandler=T,e.AuthConfig=E,e.DefaultOAuthInterceptor=D,e.JwksValidationHandler=B,e.LoginOptions=g,e.MemoryStorage=y,e.NullValidationHandler=N,e.OAuthErrorEvent=H,e.OAuthEvent=I,e.OAuthInfoEvent=A,e.OAuthLogger=m,e.OAuthModule=q,e.OAuthModuleConfig=R,e.OAuthNoopResourceServerErrorHandler=O,e.OAuthResourceServerConfig=L,e.OAuthResourceServerErrorHandler=F,e.OAuthService=x,e.OAuthStorage=v,e.OAuthSuccessEvent=C,e.ReceivedTokens=k,e.UrlHelperService=S,e.ValidationHandler=b,e.ɵa=U,e.ɵb=j,e.ɵc=V,e.ɵd=M,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=angular-oauth2-oidc.umd.min.js.map

4

esm2015/angular-oauth-oidc.module.js

@@ -1,3 +0,3 @@

import * as tslib_1 from "tslib";
var OAuthModule_1;
import { __decorate } from "tslib";
import { OAuthStorage, OAuthLogger } from './types';

@@ -41,3 +41,3 @@ import { NgModule } from '@angular/core';

};
OAuthModule = OAuthModule_1 = tslib_1.__decorate([
OAuthModule = OAuthModule_1 = __decorate([
NgModule({

@@ -44,0 +44,0 @@ imports: [CommonModule],

@@ -10,4 +10,4 @@ /**

import * as i2 from "@angular/common";
var OAuthModuleNgFactory = i0.ɵcmf(i1.OAuthModule, [], function (_l) { return i0.ɵmod([i0.ɵmpd(512, i0.ComponentFactoryResolver, i0.ɵCodegenComponentFactoryResolver, [[8, []], [3, i0.ComponentFactoryResolver], i0.NgModuleRef]), i0.ɵmpd(4608, i2.NgLocalization, i2.NgLocaleLocalization, [i0.LOCALE_ID, [2, i2.ɵangular_packages_common_common_a]]), i0.ɵmpd(1073742336, i2.CommonModule, i2.CommonModule, []), i0.ɵmpd(1073742336, i1.OAuthModule, i1.OAuthModule, [])]); });
var OAuthModuleNgFactory = i0.ɵcmf(i1.OAuthModule, [], function (_l) { return i0.ɵmod([i0.ɵmpd(512, i0.ComponentFactoryResolver, i0.ɵCodegenComponentFactoryResolver, [[8, []], [3, i0.ComponentFactoryResolver], i0.NgModuleRef]), i0.ɵmpd(4608, i2.NgLocalization, i2.NgLocaleLocalization, [i0.LOCALE_ID]), i0.ɵmpd(1073742336, i2.CommonModule, i2.CommonModule, []), i0.ɵmpd(1073742336, i1.OAuthModule, i1.OAuthModule, [])]); });
export { OAuthModuleNgFactory as OAuthModuleNgFactory };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1vYXV0aC1vaWRjLm1vZHVsZS5uZ2ZhY3RvcnkuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLW9hdXRoMi1vaWRjLyIsInNvdXJjZXMiOlsiYW5ndWxhci1vYXV0aC1vaWRjLm1vZHVsZS5uZ2ZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGkwIGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0ICogYXMgaTEgZnJvbSAnLi9hbmd1bGFyLW9hdXRoLW9pZGMubW9kdWxlJztcbmltcG9ydCAqIGFzIGkyIGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5leHBvcnQgY29uc3QgT0F1dGhNb2R1bGVOZ0ZhY3Rvcnk6aTAuTmdNb2R1bGVGYWN0b3J5PGkxLk9BdXRoTW9kdWxlPiA9IChudWxsIGFzIGFueSk7XG52YXIgX2RlY2wwXzA6aTIuTmdDbGFzcyA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xOmkyLk5nQ29tcG9uZW50T3V0bGV0ID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI6aTIuTmdGb3JPZjxhbnk+ID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzM6aTIuTmdJZiA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF80OmkyLk5nVGVtcGxhdGVPdXRsZXQgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfNTppMi5OZ1N0eWxlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzY6aTIuTmdTd2l0Y2ggPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfNzppMi5OZ1N3aXRjaENhc2UgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfODppMi5OZ1N3aXRjaERlZmF1bHQgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfOTppMi5OZ1BsdXJhbCA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xMDppMi5OZ1BsdXJhbENhc2UgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTE6aTIuQXN5bmNQaXBlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzEyOmkyLlVwcGVyQ2FzZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTM6aTIuTG93ZXJDYXNlUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xNDppMi5Kc29uUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xNTppMi5TbGljZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTY6aTIuRGVjaW1hbFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTc6aTIuUGVyY2VudFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTg6aTIuVGl0bGVDYXNlUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xOTppMi5DdXJyZW5jeVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjA6aTIuRGF0ZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjE6aTIuSTE4blBsdXJhbFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjI6aTIuSTE4blNlbGVjdFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjM6aTIuS2V5VmFsdWVQaXBlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI0OmkyLkNvbW1vbk1vZHVsZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8yNTppMC5UZW1wbGF0ZVJlZjxhbnk+ID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI2OmkwLkVsZW1lbnRSZWY8YW55PiA9ICg8YW55PihudWxsIGFzIGFueSkpO1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1vYXV0aC1vaWRjLm1vZHVsZS5uZ2ZhY3RvcnkuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLW9hdXRoMi1vaWRjLyIsInNvdXJjZXMiOlsiYW5ndWxhci1vYXV0aC1vaWRjLm1vZHVsZS5uZ2ZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGkwIGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0ICogYXMgaTEgZnJvbSAnLi9hbmd1bGFyLW9hdXRoLW9pZGMubW9kdWxlJztcbmltcG9ydCAqIGFzIGkyIGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5leHBvcnQgY29uc3QgT0F1dGhNb2R1bGVOZ0ZhY3Rvcnk6aTAuTmdNb2R1bGVGYWN0b3J5PGkxLk9BdXRoTW9kdWxlPiA9IChudWxsIGFzIGFueSk7XG52YXIgX2RlY2wwXzA6aTIuTmdDbGFzcyA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xOmkyLk5nQ29tcG9uZW50T3V0bGV0ID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI6aTIuTmdGb3JPZjxhbnksYW55PiA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8zOmkyLk5nSWY8YW55PiA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF80OmkyLk5nVGVtcGxhdGVPdXRsZXQgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfNTppMi5OZ1N0eWxlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzY6aTIuTmdTd2l0Y2ggPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfNzppMi5OZ1N3aXRjaENhc2UgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfODppMi5OZ1N3aXRjaERlZmF1bHQgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfOTppMi5OZ1BsdXJhbCA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xMDppMi5OZ1BsdXJhbENhc2UgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTE6aTIuQXN5bmNQaXBlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzEyOmkyLlVwcGVyQ2FzZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTM6aTIuTG93ZXJDYXNlUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xNDppMi5Kc29uUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xNTppMi5TbGljZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTY6aTIuRGVjaW1hbFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTc6aTIuUGVyY2VudFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMTg6aTIuVGl0bGVDYXNlUGlwZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8xOTppMi5DdXJyZW5jeVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjA6aTIuRGF0ZVBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjE6aTIuSTE4blBsdXJhbFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjI6aTIuSTE4blNlbGVjdFBpcGUgPSAoPGFueT4obnVsbCBhcyBhbnkpKTtcbnZhciBfZGVjbDBfMjM6aTIuS2V5VmFsdWVQaXBlID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI0OmkyLkNvbW1vbk1vZHVsZSA9ICg8YW55PihudWxsIGFzIGFueSkpO1xudmFyIF9kZWNsMF8yNTppMC5UZW1wbGF0ZVJlZjxhbnk+ID0gKDxhbnk+KG51bGwgYXMgYW55KSk7XG52YXIgX2RlY2wwXzI2OmkwLkVsZW1lbnRSZWY8YW55PiA9ICg8YW55PihudWxsIGFzIGFueSkpO1xuIl19

@@ -1,1 +0,1 @@

{"moduleName":null,"summaries":[{"symbol":{"__symbol":0,"members":[]},"metadata":{"__symbolic":"class","statics":{"forRoot":{"__symbolic":"function","parameters":["config","validationHandlerClass"],"value":{"ngModule":{"__symbol":0,"members":[]},"providers":[{"__symbol":1,"members":[]},{"__symbol":2,"members":[]},{"provide":{"__symbol":3,"members":[]},"useFactory":{"__symbol":4,"members":[]}},{"provide":{"__symbol":5,"members":[]},"useFactory":{"__symbol":6,"members":[]}},{"provide":{"__symbol":7,"members":[]},"useClass":{"__symbolic":"reference","name":"validationHandlerClass"}},{"provide":{"__symbol":8,"members":[]},"useClass":{"__symbol":9,"members":[]}},{"provide":{"__symbol":10,"members":[]},"useClass":{"__symbol":11,"members":[]}},{"provide":{"__symbol":12,"members":[]},"useValue":{"__symbolic":"reference","name":"config"}},{"provide":{"__symbol":13,"members":[]},"useClass":{"__symbol":14,"members":[]},"multi":true}]},"defaults":[null,{"__symbol":15,"members":[]}]}}},"type":{"summaryKind":2,"type":{"reference":{"__symbol":0,"members":[]},"diDeps":[],"lifecycleHooks":[]},"entryComponents":[],"providers":[{"provider":{"token":{"identifier":{"reference":{"__symbol":16,"members":[]}}},"useClass":{"reference":{"__symbol":17,"members":[]},"diDeps":[{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":false,"token":{"identifier":{"reference":{"__symbol":18,"members":[]}}}},{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":true,"token":{"identifier":{"reference":{"__symbol":19,"members":[]}}}}],"lifecycleHooks":[]},"useFactory":null,"deps":[{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":false,"token":{"identifier":{"reference":{"__symbol":18,"members":[]}}}},{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":true,"token":{"identifier":{"reference":{"__symbol":19,"members":[]}}}}],"multi":false},"module":{"reference":{"__symbol":20,"members":[]},"diDeps":[],"lifecycleHooks":[]}}],"modules":[{"reference":{"__symbol":20,"members":[]},"diDeps":[],"lifecycleHooks":[]},{"reference":{"__symbol":0,"members":[]},"diDeps":[],"lifecycleHooks":[]}],"exportedDirectives":[],"exportedPipes":[]}}],"symbols":[{"__symbol":0,"name":"OAuthModule","filePath":"./angular-oauth-oidc.module"},{"__symbol":1,"name":"OAuthService","filePath":"./oauth-service"},{"__symbol":2,"name":"UrlHelperService","filePath":"./url-helper.service"},{"__symbol":3,"name":"OAuthLogger","filePath":"./types"},{"__symbol":4,"name":"createDefaultLogger","filePath":"./factories"},{"__symbol":5,"name":"OAuthStorage","filePath":"./types"},{"__symbol":6,"name":"createDefaultStorage","filePath":"./factories"},{"__symbol":7,"name":"ValidationHandler","filePath":"./token-validation/validation-handler"},{"__symbol":8,"name":"HashHandler","filePath":"./token-validation/hash-handler"},{"__symbol":9,"name":"DefaultHashHandler","filePath":"./token-validation/hash-handler"},{"__symbol":10,"name":"OAuthResourceServerErrorHandler","filePath":"./interceptors/resource-server-error-handler"},{"__symbol":11,"name":"OAuthNoopResourceServerErrorHandler","filePath":"./interceptors/resource-server-error-handler"},{"__symbol":12,"name":"OAuthModuleConfig","filePath":"./oauth-module.config"},{"__symbol":13,"name":"HTTP_INTERCEPTORS","filePath":"@angular/common/http/http"},{"__symbol":14,"name":"DefaultOAuthInterceptor","filePath":"./interceptors/default-oauth.interceptor"},{"__symbol":15,"name":"NullValidationHandler","filePath":"./token-validation/null-validation-handler"},{"__symbol":16,"name":"NgLocalization","filePath":"@angular/common"},{"__symbol":17,"name":"NgLocaleLocalization","filePath":"@angular/common"},{"__symbol":18,"name":"LOCALE_ID","filePath":"@angular/core"},{"__symbol":19,"name":"ɵangular_packages_common_common_a","filePath":"@angular/common"},{"__symbol":20,"name":"CommonModule","filePath":"@angular/common"}]}
{"moduleName":null,"summaries":[{"symbol":{"__symbol":0,"members":[]},"metadata":{"__symbolic":"class","statics":{"forRoot":{"__symbolic":"function","parameters":["config","validationHandlerClass"],"value":{"ngModule":{"__symbol":0,"members":[]},"providers":[{"__symbol":1,"members":[]},{"__symbol":2,"members":[]},{"provide":{"__symbol":3,"members":[]},"useFactory":{"__symbol":4,"members":[]}},{"provide":{"__symbol":5,"members":[]},"useFactory":{"__symbol":6,"members":[]}},{"provide":{"__symbol":7,"members":[]},"useClass":{"__symbolic":"reference","name":"validationHandlerClass"}},{"provide":{"__symbol":8,"members":[]},"useClass":{"__symbol":9,"members":[]}},{"provide":{"__symbol":10,"members":[]},"useClass":{"__symbol":11,"members":[]}},{"provide":{"__symbol":12,"members":[]},"useValue":{"__symbolic":"reference","name":"config"}},{"provide":{"__symbol":13,"members":[]},"useClass":{"__symbol":14,"members":[]},"multi":true}]},"defaults":[null,{"__symbol":15,"members":[]}]}}},"type":{"summaryKind":2,"type":{"reference":{"__symbol":0,"members":[]},"diDeps":[],"lifecycleHooks":[]},"entryComponents":[],"providers":[{"provider":{"token":{"identifier":{"reference":{"__symbol":16,"members":[]}}},"useClass":{"reference":{"__symbol":17,"members":[]},"diDeps":[{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":false,"token":{"identifier":{"reference":{"__symbol":18,"members":[]}}}}],"lifecycleHooks":[]},"useFactory":null,"deps":[{"isAttribute":false,"isHost":false,"isSelf":false,"isSkipSelf":false,"isOptional":false,"token":{"identifier":{"reference":{"__symbol":18,"members":[]}}}}],"multi":false},"module":{"reference":{"__symbol":19,"members":[]},"diDeps":[],"lifecycleHooks":[]}}],"modules":[{"reference":{"__symbol":19,"members":[]},"diDeps":[],"lifecycleHooks":[]},{"reference":{"__symbol":0,"members":[]},"diDeps":[],"lifecycleHooks":[]}],"exportedDirectives":[],"exportedPipes":[]}}],"symbols":[{"__symbol":0,"name":"OAuthModule","filePath":"./angular-oauth-oidc.module"},{"__symbol":1,"name":"OAuthService","filePath":"./oauth-service"},{"__symbol":2,"name":"UrlHelperService","filePath":"./url-helper.service"},{"__symbol":3,"name":"OAuthLogger","filePath":"./types"},{"__symbol":4,"name":"createDefaultLogger","filePath":"./factories"},{"__symbol":5,"name":"OAuthStorage","filePath":"./types"},{"__symbol":6,"name":"createDefaultStorage","filePath":"./factories"},{"__symbol":7,"name":"ValidationHandler","filePath":"./token-validation/validation-handler"},{"__symbol":8,"name":"HashHandler","filePath":"./token-validation/hash-handler"},{"__symbol":9,"name":"DefaultHashHandler","filePath":"./token-validation/hash-handler"},{"__symbol":10,"name":"OAuthResourceServerErrorHandler","filePath":"./interceptors/resource-server-error-handler"},{"__symbol":11,"name":"OAuthNoopResourceServerErrorHandler","filePath":"./interceptors/resource-server-error-handler"},{"__symbol":12,"name":"OAuthModuleConfig","filePath":"./oauth-module.config"},{"__symbol":13,"name":"HTTP_INTERCEPTORS","filePath":"@angular/common/http/http"},{"__symbol":14,"name":"DefaultOAuthInterceptor","filePath":"./interceptors/default-oauth.interceptor"},{"__symbol":15,"name":"NullValidationHandler","filePath":"./token-validation/null-validation-handler"},{"__symbol":16,"name":"NgLocalization","filePath":"@angular/common"},{"__symbol":17,"name":"NgLocaleLocalization","filePath":"@angular/common"},{"__symbol":18,"name":"LOCALE_ID","filePath":"@angular/core"},{"__symbol":19,"name":"CommonModule","filePath":"@angular/common"}]}

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate, __metadata, __param } from "tslib";
import { Injectable, Optional } from '@angular/core';

@@ -49,6 +49,12 @@ import { of, merge } from 'rxjs';

};
DefaultOAuthInterceptor = tslib_1.__decorate([
DefaultOAuthInterceptor.ctorParameters = () => [
{ type: OAuthStorage },
{ type: OAuthService },
{ type: OAuthResourceServerErrorHandler },
{ type: OAuthModuleConfig, decorators: [{ type: Optional }] }
];
DefaultOAuthInterceptor = __decorate([
Injectable(),
tslib_1.__param(3, Optional()),
tslib_1.__metadata("design:paramtypes", [OAuthStorage,
__param(3, Optional()),
__metadata("design:paramtypes", [OAuthStorage,
OAuthService,

@@ -59,2 +65,2 @@ OAuthResourceServerErrorHandler,

export { DefaultOAuthInterceptor };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItb2F1dGgyLW9pZGMvIiwic291cmNlcyI6WyJpbnRlcmNlcHRvcnMvZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRckQsT0FBTyxFQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFHaEQsSUFBYSx1QkFBdUIsR0FBcEMsTUFBYSx1QkFBdUI7SUFFaEMsWUFDWSxXQUF5QixFQUN6QixZQUEwQixFQUMxQixZQUE2QyxFQUNqQyxZQUErQjtRQUgzQyxnQkFBVyxHQUFYLFdBQVcsQ0FBYztRQUN6QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUMxQixpQkFBWSxHQUFaLFlBQVksQ0FBaUM7UUFDakMsaUJBQVksR0FBWixZQUFZLENBQW1CO0lBQ25ELENBQUM7SUFFRyxRQUFRLENBQUMsR0FBVztRQUN4QixJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLG1CQUFtQixFQUFFO1lBQ3RELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDcEU7UUFFRCxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRTtZQUM5QyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ3RGO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUVJLFNBQVMsQ0FDZCxHQUFxQixFQUNyQixJQUFpQjtRQUVqQixNQUFNLEdBQUcsR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBR2xDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ2xGLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUN6QjtRQUVELE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLGVBQWUsQ0FBQztRQUV6RSxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ3BCLE9BQU8sSUFBSTtpQkFDUixNQUFNLENBQUMsR0FBRyxDQUFDO2lCQUNYLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDaEU7UUFFRCxPQUFPLEtBQUssQ0FDVixFQUFFLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FDekMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUN0QyxFQUNELElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDM0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxnQkFBZ0IsQ0FBQyxFQUN4QyxPQUFPLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxrQkFBa0IsSUFBSSxDQUFDLENBQUMsRUFDbEQsVUFBVSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsMEJBQTBCO1FBQ3JELEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FDN0MsQ0FDRixDQUFDLElBQUksQ0FDSixJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQ1AsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ2YsSUFBSSxLQUFLLEVBQUU7Z0JBQ1QsTUFBTSxNQUFNLEdBQUcsU0FBUyxHQUFHLEtBQUssQ0FBQztnQkFDakMsTUFBTSxPQUFPLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBZSxFQUFFLE1BQU0sQ0FBQyxDQUFDO2dCQUN6RCxHQUFHLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7YUFDOUI7WUFFRCxPQUFPLElBQUk7aUJBQ1IsTUFBTSxDQUFDLEdBQUcsQ0FBQztpQkFDWCxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO0NBQ0YsQ0FBQTtBQWpFWSx1QkFBdUI7SUFEbkMsVUFBVSxFQUFFO0lBT0osbUJBQUEsUUFBUSxFQUFFLENBQUE7NkNBSFUsWUFBWTtRQUNYLFlBQVk7UUFDWiwrQkFBK0I7UUFDbkIsaUJBQWlCO0dBTjlDLHVCQUF1QixDQWlFbkM7U0FqRVksdUJBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7XHJcbiAgSHR0cEV2ZW50LFxyXG4gIEh0dHBIYW5kbGVyLFxyXG4gIEh0dHBJbnRlcmNlcHRvcixcclxuICBIdHRwUmVxdWVzdCxcclxufSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mLCBtZXJnZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yLCBmaWx0ZXIsIG1hcCwgdGFrZSwgbWVyZ2VNYXAsIHRpbWVvdXQgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcbmltcG9ydCB7IE9BdXRoUmVzb3VyY2VTZXJ2ZXJFcnJvckhhbmRsZXIgfSBmcm9tICcuL3Jlc291cmNlLXNlcnZlci1lcnJvci1oYW5kbGVyJztcclxuaW1wb3J0IHsgT0F1dGhNb2R1bGVDb25maWcgfSBmcm9tICcuLi9vYXV0aC1tb2R1bGUuY29uZmlnJztcclxuaW1wb3J0IHsgT0F1dGhTdG9yYWdlIH0gZnJvbSAnLi4vdHlwZXMnO1xyXG5pbXBvcnQgeyBPQXV0aFNlcnZpY2UgfSBmcm9tICcuLi9vYXV0aC1zZXJ2aWNlJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIERlZmF1bHRPQXV0aEludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwcml2YXRlIGF1dGhTdG9yYWdlOiBPQXV0aFN0b3JhZ2UsXHJcbiAgICAgICAgcHJpdmF0ZSBvQXV0aFNlcnZpY2U6IE9BdXRoU2VydmljZSxcclxuICAgICAgICBwcml2YXRlIGVycm9ySGFuZGxlcjogT0F1dGhSZXNvdXJjZVNlcnZlckVycm9ySGFuZGxlcixcclxuICAgICAgICBAT3B0aW9uYWwoKSBwcml2YXRlIG1vZHVsZUNvbmZpZzogT0F1dGhNb2R1bGVDb25maWdcclxuICAgICkgeyB9XHJcblxyXG4gICAgcHJpdmF0ZSBjaGVja1VybCh1cmw6IHN0cmluZyk6IGJvb2xlYW4ge1xyXG4gICAgICAgIGlmICh0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5jdXN0b21VcmxWYWxpZGF0aW9uKSB7XHJcbiAgICAgICAgICAgIHJldHVybiB0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5jdXN0b21VcmxWYWxpZGF0aW9uKHVybCk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAodGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIuYWxsb3dlZFVybHMpIHtcclxuICAgICAgICAgICAgcmV0dXJuICEhdGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIuYWxsb3dlZFVybHMuZmluZCh1ID0+IHVybC5zdGFydHNXaXRoKHUpKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG5cclxuICBwdWJsaWMgaW50ZXJjZXB0KFxyXG4gICAgcmVxOiBIdHRwUmVxdWVzdDxhbnk+LFxyXG4gICAgbmV4dDogSHR0cEhhbmRsZXJcclxuICApOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICBjb25zdCB1cmwgPSByZXEudXJsLnRvTG93ZXJDYXNlKCk7XHJcblxyXG5cclxuICAgIGlmICghdGhpcy5tb2R1bGVDb25maWcgfHwgIXRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyIHx8ICF0aGlzLmNoZWNrVXJsKHVybCkpIHtcclxuICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3Qgc2VuZEFjY2Vzc1Rva2VuID0gdGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIuc2VuZEFjY2Vzc1Rva2VuO1xyXG5cclxuICAgIGlmICghc2VuZEFjY2Vzc1Rva2VuKSB7XHJcbiAgICAgIHJldHVybiBuZXh0XHJcbiAgICAgICAgLmhhbmRsZShyZXEpXHJcbiAgICAgICAgLnBpcGUoY2F0Y2hFcnJvcihlcnIgPT4gdGhpcy5lcnJvckhhbmRsZXIuaGFuZGxlRXJyb3IoZXJyKSkpO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBtZXJnZShcclxuICAgICAgb2YodGhpcy5vQXV0aFNlcnZpY2UuZ2V0QWNjZXNzVG9rZW4oKSkucGlwZShcclxuICAgICAgICBmaWx0ZXIodG9rZW4gPT4gdG9rZW4gPyB0cnVlIDogZmFsc2UpLFxyXG4gICAgICApLFxyXG4gICAgICB0aGlzLm9BdXRoU2VydmljZS5ldmVudHMucGlwZShcclxuICAgICAgICBmaWx0ZXIoZSA9PiBlLnR5cGUgPT09ICd0b2tlbl9yZWNlaXZlZCcpLFxyXG4gICAgICAgIHRpbWVvdXQodGhpcy5vQXV0aFNlcnZpY2Uud2FpdEZvclRva2VuSW5Nc2VjIHx8IDApLFxyXG4gICAgICAgIGNhdGNoRXJyb3IoXyA9PiBvZihudWxsKSksIC8vIHRpbWVvdXQgaXMgbm90IGFuIGVycm9yXHJcbiAgICAgICAgbWFwKF8gPT4gdGhpcy5vQXV0aFNlcnZpY2UuZ2V0QWNjZXNzVG9rZW4oKSksXHJcbiAgICAgICksXHJcbiAgICApLnBpcGUoXHJcbiAgICAgIHRha2UoMSksXHJcbiAgICAgIG1lcmdlTWFwKHRva2VuID0+IHtcclxuICAgICAgICBpZiAodG9rZW4pIHtcclxuICAgICAgICAgIGNvbnN0IGhlYWRlciA9ICdCZWFyZXIgJyArIHRva2VuO1xyXG4gICAgICAgICAgY29uc3QgaGVhZGVycyA9IHJlcS5oZWFkZXJzLnNldCgnQXV0aG9yaXphdGlvbicsIGhlYWRlcik7XHJcbiAgICAgICAgICByZXEgPSByZXEuY2xvbmUoeyBoZWFkZXJzIH0pO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIG5leHRcclxuICAgICAgICAgIC5oYW5kbGUocmVxKVxyXG4gICAgICAgICAgLnBpcGUoY2F0Y2hFcnJvcihlcnIgPT4gdGhpcy5lcnJvckhhbmRsZXIuaGFuZGxlRXJyb3IoZXJyKSkpO1xyXG4gICAgICB9KSxcclxuICAgICk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItb2F1dGgyLW9pZGMvIiwic291cmNlcyI6WyJpbnRlcmNlcHRvcnMvZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRckQsT0FBTyxFQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFHaEQsSUFBYSx1QkFBdUIsR0FBcEMsTUFBYSx1QkFBdUI7SUFFaEMsWUFDWSxXQUF5QixFQUN6QixZQUEwQixFQUMxQixZQUE2QyxFQUNqQyxZQUErQjtRQUgzQyxnQkFBVyxHQUFYLFdBQVcsQ0FBYztRQUN6QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUMxQixpQkFBWSxHQUFaLFlBQVksQ0FBaUM7UUFDakMsaUJBQVksR0FBWixZQUFZLENBQW1CO0lBQ25ELENBQUM7SUFFRyxRQUFRLENBQUMsR0FBVztRQUN4QixJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLG1CQUFtQixFQUFFO1lBQ3RELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDcEU7UUFF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QixpQkFBaUI7R0FOOUMsdUJBQXVCLENBaUVuQztTQWpFWSx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHtcclxuICBIdHRwRXZlbnQsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEludGVyY2VwdG9yLFxyXG4gIEh0dHBSZXF1ZXN0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YsIG1lcmdlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGNhdGNoRXJyb3IsIGZpbHRlciwgbWFwLCB0YWtlLCBtZXJnZU1hcCwgdGltZW91dCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgT0F1dGhSZXNvdXJjZVNlcnZlckVycm9ySGFuZGxlciB9IGZyb20gJy4vcmVzb3VyY2Utc2VydmVyLWVycm9yLWhhbmRsZXInO1xyXG5pbXBvcnQgeyBPQXV0aE1vZHVsZUNvbmZpZyB9IGZyb20gJy4uL29hdXRoLW1vZHVsZS5jb25maWcnO1xyXG5pbXBvcnQgeyBPQXV0aFN0b3JhZ2UgfSBmcm9tICcuLi90eXBlcyc7XHJcbmltcG9ydCB7IE9BdXRoU2VydmljZSB9IGZyb20gJy4uL29hdXRoLXNlcnZpY2UnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRGVmYXVsdE9BdXRoSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgYXV0aFN0b3JhZ2U6IE9BdXRoU3RvcmFnZSxcclxuICAgICAgICBwcml2YXRlIG9BdXRoU2VydmljZTogT0F1dGhTZXJ2aWNlLFxyXG4gICAgICAgIHByaXZhdGUgZXJyb3JIYW5kbGVyOiBPQXV0aFJlc291cmNlU2VydmVyRXJyb3JIYW5kbGVyLFxyXG4gICAgICAgIEBPcHRpb25hbCgpIHByaXZhdGUgbW9kdWxlQ29uZmlnOiBPQXV0aE1vZHVsZUNvbmZpZ1xyXG4gICAgKSB7IH1cclxuXHJcbiAgICBwcml2YXRlIGNoZWNrVXJsKHVybDogc3RyaW5nKTogYm9vbGVhbiB7XHJcbiAgICAgICAgaWYgKHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24odXJsKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmICh0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscykge1xyXG4gICAgICAgICAgICByZXR1cm4gISF0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscy5maW5kKHUgPT4gdXJsLnN0YXJ0c1dpdGgodSkpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gIHB1YmxpYyBpbnRlcmNlcHQoXHJcbiAgICByZXE6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIGNvbnN0IHVybCA9IHJlcS51cmwudG9Mb3dlckNhc2UoKTtcclxuXHJcblxyXG4gICAgaWYgKCF0aGlzLm1vZHVsZUNvbmZpZyB8fCAhdGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIgfHwgIXRoaXMuY2hlY2tVcmwodXJsKSkge1xyXG4gICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxKTtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBzZW5kQWNjZXNzVG9rZW4gPSB0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5zZW5kQWNjZXNzVG9rZW47XHJcblxyXG4gICAgaWYgKCFzZW5kQWNjZXNzVG9rZW4pIHtcclxuICAgICAgcmV0dXJuIG5leHRcclxuICAgICAgICAuaGFuZGxlKHJlcSlcclxuICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG1lcmdlKFxyXG4gICAgICBvZih0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKS5waXBlKFxyXG4gICAgICAgIGZpbHRlcih0b2tlbiA9PiB0b2tlbiA/IHRydWUgOiBmYWxzZSksXHJcbiAgICAgICksXHJcbiAgICAgIHRoaXMub0F1dGhTZXJ2aWNlLmV2ZW50cy5waXBlKFxyXG4gICAgICAgIGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ3Rva2VuX3JlY2VpdmVkJyksXHJcbiAgICAgICAgdGltZW91dCh0aGlzLm9BdXRoU2VydmljZS53YWl0Rm9yVG9rZW5Jbk1zZWMgfHwgMCksXHJcbiAgICAgICAgY2F0Y2hFcnJvcihfID0+IG9mKG51bGwpKSwgLy8gdGltZW91dCBpcyBub3QgYW4gZXJyb3JcclxuICAgICAgICBtYXAoXyA9PiB0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKSxcclxuICAgICAgKSxcclxuICAgICkucGlwZShcclxuICAgICAgdGFrZSgxKSxcclxuICAgICAgbWVyZ2VNYXAodG9rZW4gPT4ge1xyXG4gICAgICAgIGlmICh0b2tlbikge1xyXG4gICAgICAgICAgY29uc3QgaGVhZGVyID0gJ0JlYXJlciAnICsgdG9rZW47XHJcbiAgICAgICAgICBjb25zdCBoZWFkZXJzID0gcmVxLmhlYWRlcnMuc2V0KCdBdXRob3JpemF0aW9uJywgaGVhZGVyKTtcclxuICAgICAgICAgIHJlcSA9IHJlcS5jbG9uZSh7IGhlYWRlcnMgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbmV4dFxyXG4gICAgICAgICAgLmhhbmRsZShyZXEpXHJcbiAgICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICAgIH0pLFxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __awaiter, __decorate } from "tslib";
import { Injectable } from '@angular/core';

@@ -10,3 +10,3 @@ /**

calcHash(valueToHash, algorithm) {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return __awaiter(this, void 0, void 0, function* () {
const encoder = new TextEncoder();

@@ -27,3 +27,3 @@ const data = encoder.encode(valueToHash);

};
DefaultHashHandler = tslib_1.__decorate([
DefaultHashHandler = __decorate([
Injectable()

@@ -30,0 +30,0 @@ ], DefaultHashHandler);

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __awaiter } from "tslib";
import { base64UrlEncode } from '../base64-helper';

@@ -19,3 +19,3 @@ /**

validateAtHash(params) {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return __awaiter(this, void 0, void 0, function* () {
let hashAlg = this.inferHashAlgorithm(params.idTokenHeader);

@@ -22,0 +22,0 @@ let tokenHash = yield this.calcHash(params.accessToken, hashAlg); // sha256(accessToken, { asString: true });

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate } from "tslib";
import { Injectable } from "@angular/core";

@@ -47,3 +47,3 @@ /**

};
MemoryStorage = tslib_1.__decorate([
MemoryStorage = __decorate([
Injectable()

@@ -58,2 +58,2 @@ ], MemoryStorage);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"ng://angular-oauth2-oidc/","sources":["types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,YAAY;IAAzB;QA8CE;;;;;WAKG;QACH,+BAA0B,GAAI,KAAK,CAAC;IAQtC,CAAC;CAAA;AAED;;;;;GAKG;AACH,MAAM,OAAgB,WAAW;CAMhC;AAED;;;;;GAKG;AACH,MAAM,OAAgB,YAAY;CAIjC;AAGD,IAAa,aAAa,GAA1B,MAAa,aAAa;IAD1B;QAEU,SAAI,GAAG,IAAI,GAAG,EAAkB,CAAC;IAc3C,CAAC;IAZC,OAAO,CAAC,GAAW;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,OAAO,CAAC,GAAW,EAAE,IAAY;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;CAEF,CAAA;AAfY,aAAa;IADzB,UAAU,EAAE;GACA,aAAa,CAezB;SAfY,aAAa;AAiB1B;;;GAGG;AACH,MAAM,OAAO,cAAc;CAK1B","sourcesContent":["import { Injectable } from \"@angular/core\";\r\n\r\n/**\r\n * Additional options that can be passed to tryLogin.\r\n */\r\nexport class LoginOptions {\r\n  /**\r\n   * Is called, after a token has been received and\r\n   * successfully validated.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onTokenReceived?: (receivedTokens: ReceivedTokens) => void;\r\n\r\n  /**\r\n   * Hook, to validate the received tokens.\r\n   *\r\n   * Deprecated:  Use property ``tokenValidationHandler`` on OAuthService instead.\r\n   */\r\n  validationHandler?: (receivedTokens: ReceivedTokens) => Promise<any>;\r\n\r\n  /**\r\n   * Called when tryLogin detects that the auth server\r\n   * included an error message into the hash fragment.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onLoginError?: (params: object) => void;\r\n\r\n  /**\r\n   * A custom hash fragment to be used instead of the\r\n   * actual one. This is used for silent refreshes, to\r\n   * pass the iframes hash fragment to this method, and\r\n   * is also used by popup flows in the same manner.\r\n   * This can be used with code flow, where is must be set\r\n   * to a hash symbol followed by the querystring. The\r\n   * question mark is optional, but may be present following\r\n   * the hash symbol.\r\n   */\r\n  customHashFragment?: string;\r\n\r\n  /**\r\n   * Set this to true to disable the oauth2 state\r\n   * check which is a best practice to avoid\r\n   * security attacks.\r\n   * As OIDC defines a nonce check that includes\r\n   * this, this can be set to true when only doing\r\n   * OIDC.\r\n   */\r\n  disableOAuth2StateCheck?: boolean;\r\n\r\n  /**\r\n   * Normally, you want to clear your hash fragment after\r\n   * the lib read the token(s) so that they are not displayed\r\n   * anymore in the url. If not, set this to true. For code flow\r\n   * this controls removing query string values.\r\n   */\r\n  preventClearHashAfterLogin? = false;\r\n\r\n  /**\r\n   * Set this for code flow if you used a custom redirect Uri\r\n   * when retrieving the code. This is used internally for silent\r\n   * refresh and popup flows.\r\n   */\r\n  customRedirectUri?: string;\r\n}\r\n\r\n/**\r\n * Defines the logging interface the OAuthService uses\r\n * internally. Is compatible with the `console` object,\r\n * but you can provide your own implementation as well\r\n * through dependency injection.\r\n */\r\nexport abstract class OAuthLogger {\r\n  abstract debug(message?: any, ...optionalParams: any[]): void;\r\n  abstract info(message?: any, ...optionalParams: any[]): void;\r\n  abstract log(message?: any, ...optionalParams: any[]): void;\r\n  abstract warn(message?: any, ...optionalParams: any[]): void;\r\n  abstract error(message?: any, ...optionalParams: any[]): void;\r\n}\r\n\r\n/**\r\n * Defines a simple storage that can be used for\r\n * storing the tokens at client side.\r\n * Is compatible to localStorage and sessionStorage,\r\n * but you can also create your own implementations.\r\n */\r\nexport abstract class OAuthStorage {\r\n  abstract getItem(key: string): string | null;\r\n  abstract removeItem(key: string): void;\r\n  abstract setItem(key: string, data: string): void;\r\n}\r\n\r\n@Injectable()\r\nexport class MemoryStorage implements OAuthStorage {\r\n  private data = new Map<string, string>();\r\n\r\n  getItem(key: string): string {\r\n    return this.data.get(key);\r\n  }\r\n\r\n  removeItem(key: string): void {\r\n    this.data.delete(key);\r\n  }\r\n\r\n  setItem(key: string, data: string): void {\r\n    this.data.set(key, data);\r\n  }\r\n\r\n}\r\n\r\n/**\r\n * Represents the received tokens, the received state\r\n * and the parsed claims from the id-token.\r\n */\r\nexport class ReceivedTokens {\r\n  idToken: string;\r\n  accessToken: string;\r\n  idClaims?: object;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the parsed and validated id_token.\r\n */\r\nexport interface ParsedIdToken {\r\n  idToken: string;\r\n  idTokenClaims: object;\r\n  idTokenHeader: object;\r\n  idTokenClaimsJson: string;\r\n  idTokenHeaderJson: string;\r\n  idTokenExpiresAt: number;\r\n}\r\n\r\n/**\r\n * Represents the response from the token endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#TokenEndpoint\r\n */\r\nexport interface TokenResponse {\r\n  access_token: string;\r\n  id_token: string; \r\n  token_type: string;\r\n  expires_in: number;\r\n  refresh_token: string;\r\n  scope: string;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the response from the user info endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#UserInfo\r\n */\r\nexport interface UserInfo {\r\n  sub: string;\r\n  [key: string]: any;\r\n}\r\n\r\n/**\r\n * Represents an OpenID Connect discovery document\r\n */\r\nexport interface OidcDiscoveryDoc {\r\n  issuer: string;\r\n  authorization_endpoint: string;\r\n  token_endpoint: string;\r\n  token_endpoint_auth_methods_supported: string[];\r\n  token_endpoint_auth_signing_alg_values_supported: string[];\r\n  userinfo_endpoint: string;\r\n  check_session_iframe: string;\r\n  end_session_endpoint: string;\r\n  jwks_uri: string;\r\n  registration_endpoint: string;\r\n  scopes_supported: string[];\r\n  response_types_supported: string[];\r\n  acr_values_supported: string[];\r\n  response_modes_supported: string[];\r\n  grant_types_supported: string[];\r\n  subject_types_supported: string[];\r\n  userinfo_signing_alg_values_supported: string[];\r\n  userinfo_encryption_alg_values_supported: string[];\r\n  userinfo_encryption_enc_values_supported: string[];\r\n  id_token_signing_alg_values_supported: string[];\r\n  id_token_encryption_alg_values_supported: string[];\r\n  id_token_encryption_enc_values_supported: string[];\r\n  request_object_signing_alg_values_supported: string[];\r\n  display_values_supported: string[];\r\n  claim_types_supported: string[];\r\n  claims_supported: string[];\r\n  claims_parameter_supported: boolean;\r\n  service_documentation: string;\r\n  ui_locales_supported: string[];\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"ng://angular-oauth2-oidc/","sources":["types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,YAAY;IAAzB;QA8CE;;;;;WAKG;QACH,+BAA0B,GAAI,KAAK,CAAC;IAQtC,CAAC;CAAA;AAED;;;;;GAKG;AACH,MAAM,OAAgB,WAAW;CAMhC;AAED;;;;;GAKG;AACH,MAAM,OAAgB,YAAY;CAIjC;AAGD,IAAa,aAAa,GAA1B,MAAa,aAAa;IAA1B;QACU,SAAI,GAAG,IAAI,GAAG,EAAkB,CAAC;IAc3C,CAAC;IAZC,OAAO,CAAC,GAAW;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,OAAO,CAAC,GAAW,EAAE,IAAY;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;CAEF,CAAA;AAfY,aAAa;IADzB,UAAU,EAAE;GACA,aAAa,CAezB;SAfY,aAAa;AAiB1B;;;GAGG;AACH,MAAM,OAAO,cAAc;CAK1B","sourcesContent":["import { Injectable } from \"@angular/core\";\r\n\r\n/**\r\n * Additional options that can be passed to tryLogin.\r\n */\r\nexport class LoginOptions {\r\n  /**\r\n   * Is called, after a token has been received and\r\n   * successfully validated.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onTokenReceived?: (receivedTokens: ReceivedTokens) => void;\r\n\r\n  /**\r\n   * Hook, to validate the received tokens.\r\n   *\r\n   * Deprecated:  Use property ``tokenValidationHandler`` on OAuthService instead.\r\n   */\r\n  validationHandler?: (receivedTokens: ReceivedTokens) => Promise<any>;\r\n\r\n  /**\r\n   * Called when tryLogin detects that the auth server\r\n   * included an error message into the hash fragment.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onLoginError?: (params: object) => void;\r\n\r\n  /**\r\n   * A custom hash fragment to be used instead of the\r\n   * actual one. This is used for silent refreshes, to\r\n   * pass the iframes hash fragment to this method, and\r\n   * is also used by popup flows in the same manner.\r\n   * This can be used with code flow, where is must be set\r\n   * to a hash symbol followed by the querystring. The\r\n   * question mark is optional, but may be present following\r\n   * the hash symbol.\r\n   */\r\n  customHashFragment?: string;\r\n\r\n  /**\r\n   * Set this to true to disable the oauth2 state\r\n   * check which is a best practice to avoid\r\n   * security attacks.\r\n   * As OIDC defines a nonce check that includes\r\n   * this, this can be set to true when only doing\r\n   * OIDC.\r\n   */\r\n  disableOAuth2StateCheck?: boolean;\r\n\r\n  /**\r\n   * Normally, you want to clear your hash fragment after\r\n   * the lib read the token(s) so that they are not displayed\r\n   * anymore in the url. If not, set this to true. For code flow\r\n   * this controls removing query string values.\r\n   */\r\n  preventClearHashAfterLogin? = false;\r\n\r\n  /**\r\n   * Set this for code flow if you used a custom redirect Uri\r\n   * when retrieving the code. This is used internally for silent\r\n   * refresh and popup flows.\r\n   */\r\n  customRedirectUri?: string;\r\n}\r\n\r\n/**\r\n * Defines the logging interface the OAuthService uses\r\n * internally. Is compatible with the `console` object,\r\n * but you can provide your own implementation as well\r\n * through dependency injection.\r\n */\r\nexport abstract class OAuthLogger {\r\n  abstract debug(message?: any, ...optionalParams: any[]): void;\r\n  abstract info(message?: any, ...optionalParams: any[]): void;\r\n  abstract log(message?: any, ...optionalParams: any[]): void;\r\n  abstract warn(message?: any, ...optionalParams: any[]): void;\r\n  abstract error(message?: any, ...optionalParams: any[]): void;\r\n}\r\n\r\n/**\r\n * Defines a simple storage that can be used for\r\n * storing the tokens at client side.\r\n * Is compatible to localStorage and sessionStorage,\r\n * but you can also create your own implementations.\r\n */\r\nexport abstract class OAuthStorage {\r\n  abstract getItem(key: string): string | null;\r\n  abstract removeItem(key: string): void;\r\n  abstract setItem(key: string, data: string): void;\r\n}\r\n\r\n@Injectable()\r\nexport class MemoryStorage implements OAuthStorage {\r\n  private data = new Map<string, string>();\r\n\r\n  getItem(key: string): string {\r\n    return this.data.get(key);\r\n  }\r\n\r\n  removeItem(key: string): void {\r\n    this.data.delete(key);\r\n  }\r\n\r\n  setItem(key: string, data: string): void {\r\n    this.data.set(key, data);\r\n  }\r\n\r\n}\r\n\r\n/**\r\n * Represents the received tokens, the received state\r\n * and the parsed claims from the id-token.\r\n */\r\nexport class ReceivedTokens {\r\n  idToken: string;\r\n  accessToken: string;\r\n  idClaims?: object;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the parsed and validated id_token.\r\n */\r\nexport interface ParsedIdToken {\r\n  idToken: string;\r\n  idTokenClaims: object;\r\n  idTokenHeader: object;\r\n  idTokenClaimsJson: string;\r\n  idTokenHeaderJson: string;\r\n  idTokenExpiresAt: number;\r\n}\r\n\r\n/**\r\n * Represents the response from the token endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#TokenEndpoint\r\n */\r\nexport interface TokenResponse {\r\n  access_token: string;\r\n  id_token: string; \r\n  token_type: string;\r\n  expires_in: number;\r\n  refresh_token: string;\r\n  scope: string;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the response from the user info endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#UserInfo\r\n */\r\nexport interface UserInfo {\r\n  sub: string;\r\n  [key: string]: any;\r\n}\r\n\r\n/**\r\n * Represents an OpenID Connect discovery document\r\n */\r\nexport interface OidcDiscoveryDoc {\r\n  issuer: string;\r\n  authorization_endpoint: string;\r\n  token_endpoint: string;\r\n  token_endpoint_auth_methods_supported: string[];\r\n  token_endpoint_auth_signing_alg_values_supported: string[];\r\n  userinfo_endpoint: string;\r\n  check_session_iframe: string;\r\n  end_session_endpoint: string;\r\n  jwks_uri: string;\r\n  registration_endpoint: string;\r\n  scopes_supported: string[];\r\n  response_types_supported: string[];\r\n  acr_values_supported: string[];\r\n  response_modes_supported: string[];\r\n  grant_types_supported: string[];\r\n  subject_types_supported: string[];\r\n  userinfo_signing_alg_values_supported: string[];\r\n  userinfo_encryption_alg_values_supported: string[];\r\n  userinfo_encryption_enc_values_supported: string[];\r\n  id_token_signing_alg_values_supported: string[];\r\n  id_token_encryption_alg_values_supported: string[];\r\n  id_token_encryption_enc_values_supported: string[];\r\n  request_object_signing_alg_values_supported: string[];\r\n  display_values_supported: string[];\r\n  claim_types_supported: string[];\r\n  claims_supported: string[];\r\n  claims_parameter_supported: boolean;\r\n  service_documentation: string;\r\n  ui_locales_supported: string[];\r\n}\r\n"]}

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate } from "tslib";
import { Injectable } from '@angular/core';

@@ -47,3 +47,3 @@ let UrlHelperService = class UrlHelperService {

};
UrlHelperService = tslib_1.__decorate([
UrlHelperService = __decorate([
Injectable()

@@ -50,0 +50,0 @@ ], UrlHelperService);

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate } from "tslib";
import { OAuthStorage, OAuthLogger } from './types';

@@ -45,3 +45,3 @@ import { NgModule } from '@angular/core';

var OAuthModule_1;
OAuthModule = OAuthModule_1 = tslib_1.__decorate([
OAuthModule = OAuthModule_1 = __decorate([
NgModule({

@@ -48,0 +48,0 @@ imports: [CommonModule],

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __extends } from "tslib";
var OAuthEvent = /** @class */ (function () {

@@ -10,3 +10,3 @@ function OAuthEvent(type) {

var OAuthSuccessEvent = /** @class */ (function (_super) {
tslib_1.__extends(OAuthSuccessEvent, _super);
__extends(OAuthSuccessEvent, _super);
function OAuthSuccessEvent(type, info) {

@@ -22,3 +22,3 @@ if (info === void 0) { info = null; }

var OAuthInfoEvent = /** @class */ (function (_super) {
tslib_1.__extends(OAuthInfoEvent, _super);
__extends(OAuthInfoEvent, _super);
function OAuthInfoEvent(type, info) {

@@ -34,3 +34,3 @@ if (info === void 0) { info = null; }

var OAuthErrorEvent = /** @class */ (function (_super) {
tslib_1.__extends(OAuthErrorEvent, _super);
__extends(OAuthErrorEvent, _super);
function OAuthErrorEvent(type, reason, params) {

@@ -46,2 +46,2 @@ if (params === void 0) { params = null; }

export { OAuthErrorEvent };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1vYXV0aDItb2lkYy8iLCJzb3VyY2VzIjpbImV2ZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBeUJBO0lBQ0Usb0JBQXFCLElBQWU7UUFBZixTQUFJLEdBQUosSUFBSSxDQUFXO0lBQUcsQ0FBQztJQUMxQyxpQkFBQztBQUFELENBQUMsQUFGRCxJQUVDOztBQUVEO0lBQXVDLDZDQUFVO0lBQy9DLDJCQUFZLElBQWUsRUFBVyxJQUFnQjtRQUFoQixxQkFBQSxFQUFBLFdBQWdCO1FBQXRELFlBQ0Usa0JBQU0sSUFBSSxDQUFDLFNBQ1o7UUFGcUMsVUFBSSxHQUFKLElBQUksQ0FBWTs7SUFFdEQsQ0FBQztJQUNILHdCQUFDO0FBQUQsQ0FBQyxBQUpELENBQXVDLFVBQVUsR0FJaEQ7O0FBRUQ7SUFBb0MsMENBQVU7SUFDNUMsd0JBQVksSUFBZSxFQUFXLElBQWdCO1FBQWhCLHFCQUFBLEVBQUEsV0FBZ0I7UUFBdEQsWUFDRSxrQkFBTSxJQUFJLENBQUMsU0FDWjtRQUZxQyxVQUFJLEdBQUosSUFBSSxDQUFZOztJQUV0RCxDQUFDO0lBQ0gscUJBQUM7QUFBRCxDQUFDLEFBSkQsQ0FBb0MsVUFBVSxHQUk3Qzs7QUFFRDtJQUFxQywyQ0FBVTtJQUM3Qyx5QkFDRSxJQUFlLEVBQ04sTUFBYyxFQUNkLE1BQXFCO1FBQXJCLHVCQUFBLEVBQUEsYUFBcUI7UUFIaEMsWUFLRSxrQkFBTSxJQUFJLENBQUMsU0FDWjtRQUpVLFlBQU0sR0FBTixNQUFNLENBQVE7UUFDZCxZQUFNLEdBQU4sTUFBTSxDQUFlOztJQUdoQyxDQUFDO0lBQ0gsc0JBQUM7QUFBRCxDQUFDLEFBUkQsQ0FBcUMsVUFBVSxHQVE5QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEV2ZW50VHlwZSA9XHJcbiAgfCAnZGlzY292ZXJ5X2RvY3VtZW50X2xvYWRlZCdcclxuICB8ICdqd2tzX2xvYWRfZXJyb3InXHJcbiAgfCAnaW52YWxpZF9ub25jZV9pbl9zdGF0ZSdcclxuICB8ICdkaXNjb3ZlcnlfZG9jdW1lbnRfbG9hZF9lcnJvcidcclxuICB8ICdkaXNjb3ZlcnlfZG9jdW1lbnRfdmFsaWRhdGlvbl9lcnJvcidcclxuICB8ICd1c2VyX3Byb2ZpbGVfbG9hZGVkJ1xyXG4gIHwgJ3VzZXJfcHJvZmlsZV9sb2FkX2Vycm9yJ1xyXG4gIHwgJ3Rva2VuX3JlY2VpdmVkJ1xyXG4gIHwgJ3Rva2VuX2Vycm9yJ1xyXG4gIHwgJ2NvZGVfZXJyb3InXHJcbiAgfCAndG9rZW5fcmVmcmVzaGVkJ1xyXG4gIHwgJ3Rva2VuX3JlZnJlc2hfZXJyb3InXHJcbiAgfCAnc2lsZW50X3JlZnJlc2hfZXJyb3InXHJcbiAgfCAnc2lsZW50bHlfcmVmcmVzaGVkJ1xyXG4gIHwgJ3NpbGVudF9yZWZyZXNoX3RpbWVvdXQnXHJcbiAgfCAndG9rZW5fdmFsaWRhdGlvbl9lcnJvcidcclxuICB8ICd0b2tlbl9leHBpcmVzJ1xyXG4gIHwgJ3Nlc3Npb25fY2hhbmdlZCdcclxuICB8ICdzZXNzaW9uX2Vycm9yJ1xyXG4gIHwgJ3Nlc3Npb25fdGVybWluYXRlZCdcclxuICB8ICdsb2dvdXQnXHJcbiAgfCAncG9wdXBfY2xvc2VkJ1xyXG4gIHwgJ3BvcHVwX2Jsb2NrZWQnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE9BdXRoRXZlbnQge1xyXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IHR5cGU6IEV2ZW50VHlwZSkge31cclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIE9BdXRoU3VjY2Vzc0V2ZW50IGV4dGVuZHMgT0F1dGhFdmVudCB7XHJcbiAgY29uc3RydWN0b3IodHlwZTogRXZlbnRUeXBlLCByZWFkb25seSBpbmZvOiBhbnkgPSBudWxsKSB7XHJcbiAgICBzdXBlcih0eXBlKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBPQXV0aEluZm9FdmVudCBleHRlbmRzIE9BdXRoRXZlbnQge1xyXG4gIGNvbnN0cnVjdG9yKHR5cGU6IEV2ZW50VHlwZSwgcmVhZG9ubHkgaW5mbzogYW55ID0gbnVsbCkge1xyXG4gICAgc3VwZXIodHlwZSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgT0F1dGhFcnJvckV2ZW50IGV4dGVuZHMgT0F1dGhFdmVudCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICB0eXBlOiBFdmVudFR5cGUsXHJcbiAgICByZWFkb25seSByZWFzb246IG9iamVjdCxcclxuICAgIHJlYWRvbmx5IHBhcmFtczogb2JqZWN0ID0gbnVsbFxyXG4gICkge1xyXG4gICAgc3VwZXIodHlwZSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1vYXV0aDItb2lkYy8iLCJzb3VyY2VzIjpbImV2ZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBeUJBO0lBQ0Usb0JBQXFCLElBQWU7UUFBZixTQUFJLEdBQUosSUFBSSxDQUFXO0lBQUcsQ0FBQztJQUMxQyxpQkFBQztBQUFELENBQUMsQUFGRCxJQUVDOztBQUVEO0lBQXVDLHFDQUFVO0lBQy9DLDJCQUFZLElBQWUsRUFBVyxJQUFnQjtRQUFoQixxQkFBQSxFQUFBLFdBQWdCO1FBQXRELFlBQ0Usa0JBQU0sSUFBSSxDQUFDLFNBQ1o7UUFGcUMsVUFBSSxHQUFKLElBQUksQ0FBWTs7SUFFdEQsQ0FBQztJQUNILHdCQUFDO0FBQUQsQ0FBQyxBQUpELENBQXVDLFVBQVUsR0FJaEQ7O0FBRUQ7SUFBb0Msa0NBQVU7SUFDNUMsd0JBQVksSUFBZSxFQUFXLElBQWdCO1FBQWhCLHFCQUFBLEVBQUEsV0FBZ0I7UUFBdEQsWUFDRSxrQkFBTSxJQUFJLENBQUMsU0FDWjtRQUZxQyxVQUFJLEdBQUosSUFBSSxDQUFZOztJQUV0RCxDQUFDO0lBQ0gscUJBQUM7QUFBRCxDQUFDLEFBSkQsQ0FBb0MsVUFBVSxHQUk3Qzs7QUFFRDtJQUFxQyxtQ0FBVTtJQUM3Qyx5QkFDRSxJQUFlLEVBQ04sTUFBYyxFQUNkLE1BQXFCO1FBQXJCLHVCQUFBLEVBQUEsYUFBcUI7UUFIaEMsWUFLRSxrQkFBTSxJQUFJLENBQUMsU0FDWjtRQUpVLFlBQU0sR0FBTixNQUFNLENBQVE7UUFDZCxZQUFNLEdBQU4sTUFBTSxDQUFlOztJQUdoQyxDQUFDO0lBQ0gsc0JBQUM7QUFBRCxDQUFDLEFBUkQsQ0FBcUMsVUFBVSxHQVE5QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEV2ZW50VHlwZSA9XHJcbiAgfCAnZGlzY292ZXJ5X2RvY3VtZW50X2xvYWRlZCdcclxuICB8ICdqd2tzX2xvYWRfZXJyb3InXHJcbiAgfCAnaW52YWxpZF9ub25jZV9pbl9zdGF0ZSdcclxuICB8ICdkaXNjb3ZlcnlfZG9jdW1lbnRfbG9hZF9lcnJvcidcclxuICB8ICdkaXNjb3ZlcnlfZG9jdW1lbnRfdmFsaWRhdGlvbl9lcnJvcidcclxuICB8ICd1c2VyX3Byb2ZpbGVfbG9hZGVkJ1xyXG4gIHwgJ3VzZXJfcHJvZmlsZV9sb2FkX2Vycm9yJ1xyXG4gIHwgJ3Rva2VuX3JlY2VpdmVkJ1xyXG4gIHwgJ3Rva2VuX2Vycm9yJ1xyXG4gIHwgJ2NvZGVfZXJyb3InXHJcbiAgfCAndG9rZW5fcmVmcmVzaGVkJ1xyXG4gIHwgJ3Rva2VuX3JlZnJlc2hfZXJyb3InXHJcbiAgfCAnc2lsZW50X3JlZnJlc2hfZXJyb3InXHJcbiAgfCAnc2lsZW50bHlfcmVmcmVzaGVkJ1xyXG4gIHwgJ3NpbGVudF9yZWZyZXNoX3RpbWVvdXQnXHJcbiAgfCAndG9rZW5fdmFsaWRhdGlvbl9lcnJvcidcclxuICB8ICd0b2tlbl9leHBpcmVzJ1xyXG4gIHwgJ3Nlc3Npb25fY2hhbmdlZCdcclxuICB8ICdzZXNzaW9uX2Vycm9yJ1xyXG4gIHwgJ3Nlc3Npb25fdGVybWluYXRlZCdcclxuICB8ICdsb2dvdXQnXHJcbiAgfCAncG9wdXBfY2xvc2VkJ1xyXG4gIHwgJ3BvcHVwX2Jsb2NrZWQnO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE9BdXRoRXZlbnQge1xyXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IHR5cGU6IEV2ZW50VHlwZSkge31cclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIE9BdXRoU3VjY2Vzc0V2ZW50IGV4dGVuZHMgT0F1dGhFdmVudCB7XHJcbiAgY29uc3RydWN0b3IodHlwZTogRXZlbnRUeXBlLCByZWFkb25seSBpbmZvOiBhbnkgPSBudWxsKSB7XHJcbiAgICBzdXBlcih0eXBlKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBPQXV0aEluZm9FdmVudCBleHRlbmRzIE9BdXRoRXZlbnQge1xyXG4gIGNvbnN0cnVjdG9yKHR5cGU6IEV2ZW50VHlwZSwgcmVhZG9ubHkgaW5mbzogYW55ID0gbnVsbCkge1xyXG4gICAgc3VwZXIodHlwZSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgT0F1dGhFcnJvckV2ZW50IGV4dGVuZHMgT0F1dGhFdmVudCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICB0eXBlOiBFdmVudFR5cGUsXHJcbiAgICByZWFkb25seSByZWFzb246IG9iamVjdCxcclxuICAgIHJlYWRvbmx5IHBhcmFtczogb2JqZWN0ID0gbnVsbFxyXG4gICkge1xyXG4gICAgc3VwZXIodHlwZSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate, __metadata, __param } from "tslib";
import { Injectable, Optional } from '@angular/core';

@@ -49,6 +49,12 @@ import { of, merge } from 'rxjs';

};
DefaultOAuthInterceptor = tslib_1.__decorate([
DefaultOAuthInterceptor.ctorParameters = function () { return [
{ type: OAuthStorage },
{ type: OAuthService },
{ type: OAuthResourceServerErrorHandler },
{ type: OAuthModuleConfig, decorators: [{ type: Optional }] }
]; };
DefaultOAuthInterceptor = __decorate([
Injectable(),
tslib_1.__param(3, Optional()),
tslib_1.__metadata("design:paramtypes", [OAuthStorage,
__param(3, Optional()),
__metadata("design:paramtypes", [OAuthStorage,
OAuthService,

@@ -61,2 +67,2 @@ OAuthResourceServerErrorHandler,

export { DefaultOAuthInterceptor };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItb2F1dGgyLW9pZGMvIiwic291cmNlcyI6WyJpbnRlcmNlcHRvcnMvZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRckQsT0FBTyxFQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFHaEQ7SUFFSSxpQ0FDWSxXQUF5QixFQUN6QixZQUEwQixFQUMxQixZQUE2QyxFQUNqQyxZQUErQjtRQUgzQyxnQkFBVyxHQUFYLFdBQVcsQ0FBYztRQUN6QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUMxQixpQkFBWSxHQUFaLFlBQVksQ0FBaUM7UUFDakMsaUJBQVksR0FBWixZQUFZLENBQW1CO0lBQ25ELENBQUM7SUFFRywwQ0FBUSxHQUFoQixVQUFpQixHQUFXO1FBQ3hCLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLEVBQUU7WUFDdEQsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNwRTtRQUVELElBQUksSUFBSSxDQUFDLFlBQVks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K0JBQStCO1lBQ25CLGlCQUFpQjtPQU45Qyx1QkFBdUIsQ0FpRW5DO0lBQUQsOEJBQUM7Q0FBQSxBQWpFRCxJQWlFQztTQWpFWSx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHtcclxuICBIdHRwRXZlbnQsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEludGVyY2VwdG9yLFxyXG4gIEh0dHBSZXF1ZXN0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YsIG1lcmdlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGNhdGNoRXJyb3IsIGZpbHRlciwgbWFwLCB0YWtlLCBtZXJnZU1hcCwgdGltZW91dCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgT0F1dGhSZXNvdXJjZVNlcnZlckVycm9ySGFuZGxlciB9IGZyb20gJy4vcmVzb3VyY2Utc2VydmVyLWVycm9yLWhhbmRsZXInO1xyXG5pbXBvcnQgeyBPQXV0aE1vZHVsZUNvbmZpZyB9IGZyb20gJy4uL29hdXRoLW1vZHVsZS5jb25maWcnO1xyXG5pbXBvcnQgeyBPQXV0aFN0b3JhZ2UgfSBmcm9tICcuLi90eXBlcyc7XHJcbmltcG9ydCB7IE9BdXRoU2VydmljZSB9IGZyb20gJy4uL29hdXRoLXNlcnZpY2UnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRGVmYXVsdE9BdXRoSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgYXV0aFN0b3JhZ2U6IE9BdXRoU3RvcmFnZSxcclxuICAgICAgICBwcml2YXRlIG9BdXRoU2VydmljZTogT0F1dGhTZXJ2aWNlLFxyXG4gICAgICAgIHByaXZhdGUgZXJyb3JIYW5kbGVyOiBPQXV0aFJlc291cmNlU2VydmVyRXJyb3JIYW5kbGVyLFxyXG4gICAgICAgIEBPcHRpb25hbCgpIHByaXZhdGUgbW9kdWxlQ29uZmlnOiBPQXV0aE1vZHVsZUNvbmZpZ1xyXG4gICAgKSB7IH1cclxuXHJcbiAgICBwcml2YXRlIGNoZWNrVXJsKHVybDogc3RyaW5nKTogYm9vbGVhbiB7XHJcbiAgICAgICAgaWYgKHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24odXJsKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmICh0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscykge1xyXG4gICAgICAgICAgICByZXR1cm4gISF0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscy5maW5kKHUgPT4gdXJsLnN0YXJ0c1dpdGgodSkpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gIHB1YmxpYyBpbnRlcmNlcHQoXHJcbiAgICByZXE6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIGNvbnN0IHVybCA9IHJlcS51cmwudG9Mb3dlckNhc2UoKTtcclxuXHJcblxyXG4gICAgaWYgKCF0aGlzLm1vZHVsZUNvbmZpZyB8fCAhdGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIgfHwgIXRoaXMuY2hlY2tVcmwodXJsKSkge1xyXG4gICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxKTtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBzZW5kQWNjZXNzVG9rZW4gPSB0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5zZW5kQWNjZXNzVG9rZW47XHJcblxyXG4gICAgaWYgKCFzZW5kQWNjZXNzVG9rZW4pIHtcclxuICAgICAgcmV0dXJuIG5leHRcclxuICAgICAgICAuaGFuZGxlKHJlcSlcclxuICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG1lcmdlKFxyXG4gICAgICBvZih0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKS5waXBlKFxyXG4gICAgICAgIGZpbHRlcih0b2tlbiA9PiB0b2tlbiA/IHRydWUgOiBmYWxzZSksXHJcbiAgICAgICksXHJcbiAgICAgIHRoaXMub0F1dGhTZXJ2aWNlLmV2ZW50cy5waXBlKFxyXG4gICAgICAgIGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ3Rva2VuX3JlY2VpdmVkJyksXHJcbiAgICAgICAgdGltZW91dCh0aGlzLm9BdXRoU2VydmljZS53YWl0Rm9yVG9rZW5Jbk1zZWMgfHwgMCksXHJcbiAgICAgICAgY2F0Y2hFcnJvcihfID0+IG9mKG51bGwpKSwgLy8gdGltZW91dCBpcyBub3QgYW4gZXJyb3JcclxuICAgICAgICBtYXAoXyA9PiB0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKSxcclxuICAgICAgKSxcclxuICAgICkucGlwZShcclxuICAgICAgdGFrZSgxKSxcclxuICAgICAgbWVyZ2VNYXAodG9rZW4gPT4ge1xyXG4gICAgICAgIGlmICh0b2tlbikge1xyXG4gICAgICAgICAgY29uc3QgaGVhZGVyID0gJ0JlYXJlciAnICsgdG9rZW47XHJcbiAgICAgICAgICBjb25zdCBoZWFkZXJzID0gcmVxLmhlYWRlcnMuc2V0KCdBdXRob3JpemF0aW9uJywgaGVhZGVyKTtcclxuICAgICAgICAgIHJlcSA9IHJlcS5jbG9uZSh7IGhlYWRlcnMgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbmV4dFxyXG4gICAgICAgICAgLmhhbmRsZShyZXEpXHJcbiAgICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICAgIH0pLFxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItb2F1dGgyLW9pZGMvIiwic291cmNlcyI6WyJpbnRlcmNlcHRvcnMvZGVmYXVsdC1vYXV0aC5pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFRckQsT0FBTyxFQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFHaEQ7SUFFSSxpQ0FDWSxXQUF5QixFQUN6QixZQUEwQixFQUMxQixZQUE2QyxFQUNqQyxZQUErQjtRQUgzQyxnQkFBVyxHQUFYLFdBQVcsQ0FBYztRQUN6QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUMxQixpQkFBWSxHQUFaLFlBQVksQ0FBaUM7UUFDakMsaUJBQVksR0FBWixZQUFZLENBQW1CO0lBQ25ELENBQUM7SUFFRywwQ0FBUSxHQUFoQixVQUFpQixHQUFXO1FBQ3hCLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLEVBQUU7WUFDdEQsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNwRTtRQUVELElBQUksSUFBSSxDQUFDLFlBQVks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QyxVQUFVLEVBQUU7UUFPSixXQUFBLFFBQVEsRUFBRSxDQUFBO3lDQUhVLFlBQVk7WUFDWCxZQUFZO1lBQ1osK0JBQStCO1lBQ25CLGlCQUFpQjtPQU45Qyx1QkFBdUIsQ0FpRW5DO0lBQUQsOEJBQUM7Q0FBQSxBQWpFRCxJQWlFQztTQWpFWSx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHtcclxuICBIdHRwRXZlbnQsXHJcbiAgSHR0cEhhbmRsZXIsXHJcbiAgSHR0cEludGVyY2VwdG9yLFxyXG4gIEh0dHBSZXF1ZXN0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YsIG1lcmdlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGNhdGNoRXJyb3IsIGZpbHRlciwgbWFwLCB0YWtlLCBtZXJnZU1hcCwgdGltZW91dCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgT0F1dGhSZXNvdXJjZVNlcnZlckVycm9ySGFuZGxlciB9IGZyb20gJy4vcmVzb3VyY2Utc2VydmVyLWVycm9yLWhhbmRsZXInO1xyXG5pbXBvcnQgeyBPQXV0aE1vZHVsZUNvbmZpZyB9IGZyb20gJy4uL29hdXRoLW1vZHVsZS5jb25maWcnO1xyXG5pbXBvcnQgeyBPQXV0aFN0b3JhZ2UgfSBmcm9tICcuLi90eXBlcyc7XHJcbmltcG9ydCB7IE9BdXRoU2VydmljZSB9IGZyb20gJy4uL29hdXRoLXNlcnZpY2UnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRGVmYXVsdE9BdXRoSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgYXV0aFN0b3JhZ2U6IE9BdXRoU3RvcmFnZSxcclxuICAgICAgICBwcml2YXRlIG9BdXRoU2VydmljZTogT0F1dGhTZXJ2aWNlLFxyXG4gICAgICAgIHByaXZhdGUgZXJyb3JIYW5kbGVyOiBPQXV0aFJlc291cmNlU2VydmVyRXJyb3JIYW5kbGVyLFxyXG4gICAgICAgIEBPcHRpb25hbCgpIHByaXZhdGUgbW9kdWxlQ29uZmlnOiBPQXV0aE1vZHVsZUNvbmZpZ1xyXG4gICAgKSB7IH1cclxuXHJcbiAgICBwcml2YXRlIGNoZWNrVXJsKHVybDogc3RyaW5nKTogYm9vbGVhbiB7XHJcbiAgICAgICAgaWYgKHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMubW9kdWxlQ29uZmlnLnJlc291cmNlU2VydmVyLmN1c3RvbVVybFZhbGlkYXRpb24odXJsKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmICh0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscykge1xyXG4gICAgICAgICAgICByZXR1cm4gISF0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5hbGxvd2VkVXJscy5maW5kKHUgPT4gdXJsLnN0YXJ0c1dpdGgodSkpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gIHB1YmxpYyBpbnRlcmNlcHQoXHJcbiAgICByZXE6IEh0dHBSZXF1ZXN0PGFueT4sXHJcbiAgICBuZXh0OiBIdHRwSGFuZGxlclxyXG4gICk6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcclxuICAgIGNvbnN0IHVybCA9IHJlcS51cmwudG9Mb3dlckNhc2UoKTtcclxuXHJcblxyXG4gICAgaWYgKCF0aGlzLm1vZHVsZUNvbmZpZyB8fCAhdGhpcy5tb2R1bGVDb25maWcucmVzb3VyY2VTZXJ2ZXIgfHwgIXRoaXMuY2hlY2tVcmwodXJsKSkge1xyXG4gICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxKTtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBzZW5kQWNjZXNzVG9rZW4gPSB0aGlzLm1vZHVsZUNvbmZpZy5yZXNvdXJjZVNlcnZlci5zZW5kQWNjZXNzVG9rZW47XHJcblxyXG4gICAgaWYgKCFzZW5kQWNjZXNzVG9rZW4pIHtcclxuICAgICAgcmV0dXJuIG5leHRcclxuICAgICAgICAuaGFuZGxlKHJlcSlcclxuICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG1lcmdlKFxyXG4gICAgICBvZih0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKS5waXBlKFxyXG4gICAgICAgIGZpbHRlcih0b2tlbiA9PiB0b2tlbiA/IHRydWUgOiBmYWxzZSksXHJcbiAgICAgICksXHJcbiAgICAgIHRoaXMub0F1dGhTZXJ2aWNlLmV2ZW50cy5waXBlKFxyXG4gICAgICAgIGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ3Rva2VuX3JlY2VpdmVkJyksXHJcbiAgICAgICAgdGltZW91dCh0aGlzLm9BdXRoU2VydmljZS53YWl0Rm9yVG9rZW5Jbk1zZWMgfHwgMCksXHJcbiAgICAgICAgY2F0Y2hFcnJvcihfID0+IG9mKG51bGwpKSwgLy8gdGltZW91dCBpcyBub3QgYW4gZXJyb3JcclxuICAgICAgICBtYXAoXyA9PiB0aGlzLm9BdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpKSxcclxuICAgICAgKSxcclxuICAgICkucGlwZShcclxuICAgICAgdGFrZSgxKSxcclxuICAgICAgbWVyZ2VNYXAodG9rZW4gPT4ge1xyXG4gICAgICAgIGlmICh0b2tlbikge1xyXG4gICAgICAgICAgY29uc3QgaGVhZGVyID0gJ0JlYXJlciAnICsgdG9rZW47XHJcbiAgICAgICAgICBjb25zdCBoZWFkZXJzID0gcmVxLmhlYWRlcnMuc2V0KCdBdXRob3JpemF0aW9uJywgaGVhZGVyKTtcclxuICAgICAgICAgIHJlcSA9IHJlcS5jbG9uZSh7IGhlYWRlcnMgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbmV4dFxyXG4gICAgICAgICAgLmhhbmRsZShyZXEpXHJcbiAgICAgICAgICAucGlwZShjYXRjaEVycm9yKGVyciA9PiB0aGlzLmVycm9ySGFuZGxlci5oYW5kbGVFcnJvcihlcnIpKSk7XHJcbiAgICAgIH0pLFxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIl19

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __awaiter, __decorate, __generator, __values } from "tslib";
import { Injectable } from '@angular/core';

@@ -16,5 +16,5 @@ /**

DefaultHashHandler.prototype.calcHash = function (valueToHash, algorithm) {
return tslib_1.__awaiter(this, void 0, void 0, function () {
return __awaiter(this, void 0, void 0, function () {
var encoder, data, hashArray;
return tslib_1.__generator(this, function (_a) {
return __generator(this, function (_a) {
switch (_a.label) {

@@ -37,3 +37,3 @@ case 0:

try {
for (var byteArray_1 = tslib_1.__values(byteArray), byteArray_1_1 = byteArray_1.next(); !byteArray_1_1.done; byteArray_1_1 = byteArray_1.next()) {
for (var byteArray_1 = __values(byteArray), byteArray_1_1 = byteArray_1.next(); !byteArray_1_1.done; byteArray_1_1 = byteArray_1.next()) {
var e = byteArray_1_1.value;

@@ -52,3 +52,3 @@ result += String.fromCharCode(e);

};
DefaultHashHandler = tslib_1.__decorate([
DefaultHashHandler = __decorate([
Injectable()

@@ -59,2 +59,2 @@ ], DefaultHashHandler);

export { DefaultHashHandler };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzaC1oYW5kbGVyLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1vYXV0aDItb2lkYy8iLCJzb3VyY2VzIjpbInRva2VuLXZhbGlkYXRpb24vaGFzaC1oYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDOztFQUVFO0FBQ0Y7SUFBQTtJQUVBLENBQUM7SUFBRCxrQkFBQztBQUFELENBQUMsQUFGRCxJQUVDOztBQUdEO0lBQUE7SUF1Q0EsQ0FBQztJQXJDUyxxQ0FBUSxHQUFkLFVBQWUsV0FBbUIsRUFBRSxTQUFpQjs7Ozs7O3dCQUMzQyxPQUFPLEdBQUcsSUFBSSxXQUFXLEVBQUUsQ0FBQzt3QkFDNUIsSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7d0JBQ3ZCLHFCQUFNLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLEVBQUE7O3dCQUE5RCxTQUFTLEdBQUcsU0FBa0Q7d0JBQ3BFLHNCQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEVBQUM7Ozs7S0FDdkM7SUFFRCx5Q0FBWSxHQUFaLFVBQWEsTUFBbUI7O1FBQzlCLElBQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3pDLElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQzs7WUFDaEIsS0FBYyxJQUFBLGNBQUEsaUJBQUEsU0FBUyxDQUFBLG9DQUFBLDJEQUFFO2dCQUFwQixJQUFJLENBQUMsc0JBQUE7Z0JBQ1IsTUFBTSxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDbEM7Ozs7Ozs7OztRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFoQlEsa0JBQWtCO1FBRDlCLFVBQVUsRUFBRTtPQUNBLGtCQUFrQixDQXVDOUI7SUFBRCx5QkFBQztDQUFBLEFBdkNELElBdUNDO1NBdkNZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBBYnN0cmFjdGlvbiBmb3IgY3J5cHRvIGFsZ29yaXRobXNcclxuKi9cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEhhc2hIYW5kbGVyIHtcclxuICAgIGFic3RyYWN0IGNhbGNIYXNoKHZhbHVlVG9IYXNoOiBzdHJpbmcsIGFsZ29yaXRobTogc3RyaW5nKTogUHJvbWlzZTxzdHJpbmc+O1xyXG59XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBEZWZhdWx0SGFzaEhhbmRsZXIgaW1wbGVtZW50cyBIYXNoSGFuZGxlciB7XHJcblxyXG4gICAgYXN5bmMgY2FsY0hhc2godmFsdWVUb0hhc2g6IHN0cmluZywgYWxnb3JpdGhtOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xyXG4gICAgICAgIGNvbnN0IGVuY29kZXIgPSBuZXcgVGV4dEVuY29kZXIoKTtcclxuICAgICAgICBjb25zdCBkYXRhID0gZW5jb2Rlci5lbmNvZGUodmFsdWVUb0hhc2gpO1xyXG4gICAgICAgIGNvbnN0IGhhc2hBcnJheSA9IGF3YWl0IHdpbmRvdy5jcnlwdG8uc3VidGxlLmRpZ2VzdChhbGdvcml0aG0sIGRhdGEpO1xyXG4gICAgICAgIHJldHVybiB0aGlzLnRvSGFzaFN0cmluZyhoYXNoQXJyYXkpO1xyXG4gICAgfVxyXG5cclxuICAgIHRvSGFzaFN0cmluZyhidWZmZXI6IEFycmF5QnVmZmVyKSB7XHJcbiAgICAgIGNvbnN0IGJ5dGVBcnJheSA9IG5ldyBVaW50OEFycmF5KGJ1ZmZlcik7XHJcbiAgICAgIGxldCByZXN1bHQgPSAnJztcclxuICAgICAgZm9yIChsZXQgZSBvZiBieXRlQXJyYXkpIHtcclxuICAgICAgICByZXN1bHQgKz0gU3RyaW5nLmZyb21DaGFyQ29kZShlKTtcclxuICAgICAgfVxyXG4gICAgICByZXR1cm4gcmVzdWx0O1xyXG4gICAgfVxyXG5cclxuICAgIC8vIGhleFN0cmluZyhidWZmZXIpIHtcclxuICAgIC8vICAgICBjb25zdCBieXRlQXJyYXkgPSBuZXcgVWludDhBcnJheShidWZmZXIpO1xyXG4gICAgLy8gICAgIGNvbnN0IGhleENvZGVzID0gWy4uLmJ5dGVBcnJheV0ubWFwKHZhbHVlID0+IHtcclxuICAgIC8vICAgICAgIGNvbnN0IGhleENvZGUgPSB2YWx1ZS50b1N0cmluZygxNik7XHJcbiAgICAvLyAgICAgICBjb25zdCBwYWRkZWRIZXhDb2RlID0gaGV4Q29kZS5wYWRTdGFydCgyLCAnMCcpO1xyXG4gICAgLy8gICAgICAgcmV0dXJuIHBhZGRlZEhleENvZGU7XHJcbiAgICAvLyAgICAgfSk7XHJcbiAgICAgIFxyXG4gICAgLy8gICAgIHJldHVybiBoZXhDb2Rlcy5qb2luKCcnKTtcclxuICAgIC8vICAgfVxyXG4gICAgXHJcbiAgICAgIC8vIHRvSGFzaFN0cmluZyhoZXhTdHJpbmc6IHN0cmluZykge1xyXG4gICAgICAvLyAgIGxldCByZXN1bHQgPSAnJztcclxuICAgICAgLy8gICBmb3IgKGxldCBpID0gMDsgaSA8IGhleFN0cmluZy5sZW5ndGg7IGkgKz0gMikge1xyXG4gICAgICAvLyAgICAgbGV0IGhleERpZ2l0ID0gaGV4U3RyaW5nLmNoYXJBdChpKSArIGhleFN0cmluZy5jaGFyQXQoaSArIDEpO1xyXG4gICAgICAvLyAgICAgbGV0IG51bSA9IHBhcnNlSW50KGhleERpZ2l0LCAxNik7XHJcbiAgICAgIC8vICAgICByZXN1bHQgKz0gU3RyaW5nLmZyb21DaGFyQ29kZShudW0pO1xyXG4gICAgICAvLyAgIH1cclxuICAgICAgLy8gICByZXR1cm4gcmVzdWx0O1xyXG4gICAgICAvLyB9XHJcblxyXG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzaC1oYW5kbGVyLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1vYXV0aDItb2lkYy8iLCJzb3VyY2VzIjpbInRva2VuLXZhbGlkYXRpb24vaGFzaC1oYW5kbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDOztFQUVFO0FBQ0Y7SUFBQTtJQUVBLENBQUM7SUFBRCxrQkFBQztBQUFELENBQUMsQUFGRCxJQUVDOztBQUdEO0lBQUE7SUF1Q0EsQ0FBQztJQXJDUyxxQ0FBUSxHQUFkLFVBQWUsV0FBbUIsRUFBRSxTQUFpQjs7Ozs7O3dCQUMzQyxPQUFPLEdBQUcsSUFBSSxXQUFXLEVBQUUsQ0FBQzt3QkFDNUIsSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7d0JBQ3ZCLHFCQUFNLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLEVBQUE7O3dCQUE5RCxTQUFTLEdBQUcsU0FBa0Q7d0JBQ3BFLHNCQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEVBQUM7Ozs7S0FDdkM7SUFFRCx5Q0FBWSxHQUFaLFVBQWEsTUFBbUI7O1FBQzlCLElBQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3pDLElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQzs7WUFDaEIsS0FBYyxJQUFBLGNBQUEsU0FBQSxTQUFTLENBQUEsb0NBQUEsMkRBQUU7Z0JBQXBCLElBQUksQ0FBQyxzQkFBQTtnQkFDUixNQUFNLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNsQzs7Ozs7Ozs7O1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQWhCUSxrQkFBa0I7UUFEOUIsVUFBVSxFQUFFO09BQ0Esa0JBQWtCLENBdUM5QjtJQUFELHlCQUFDO0NBQUEsQUF2Q0QsSUF1Q0M7U0F2Q1ksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIEFic3RyYWN0aW9uIGZvciBjcnlwdG8gYWxnb3JpdGhtc1xyXG4qL1xyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgSGFzaEhhbmRsZXIge1xyXG4gICAgYWJzdHJhY3QgY2FsY0hhc2godmFsdWVUb0hhc2g6IHN0cmluZywgYWxnb3JpdGhtOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz47XHJcbn1cclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIERlZmF1bHRIYXNoSGFuZGxlciBpbXBsZW1lbnRzIEhhc2hIYW5kbGVyIHtcclxuXHJcbiAgICBhc3luYyBjYWxjSGFzaCh2YWx1ZVRvSGFzaDogc3RyaW5nLCBhbGdvcml0aG06IHN0cmluZyk6IFByb21pc2U8c3RyaW5nPiB7XHJcbiAgICAgICAgY29uc3QgZW5jb2RlciA9IG5ldyBUZXh0RW5jb2RlcigpO1xyXG4gICAgICAgIGNvbnN0IGRhdGEgPSBlbmNvZGVyLmVuY29kZSh2YWx1ZVRvSGFzaCk7XHJcbiAgICAgICAgY29uc3QgaGFzaEFycmF5ID0gYXdhaXQgd2luZG93LmNyeXB0by5zdWJ0bGUuZGlnZXN0KGFsZ29yaXRobSwgZGF0YSk7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMudG9IYXNoU3RyaW5nKGhhc2hBcnJheSk7XHJcbiAgICB9XHJcblxyXG4gICAgdG9IYXNoU3RyaW5nKGJ1ZmZlcjogQXJyYXlCdWZmZXIpIHtcclxuICAgICAgY29uc3QgYnl0ZUFycmF5ID0gbmV3IFVpbnQ4QXJyYXkoYnVmZmVyKTtcclxuICAgICAgbGV0IHJlc3VsdCA9ICcnO1xyXG4gICAgICBmb3IgKGxldCBlIG9mIGJ5dGVBcnJheSkge1xyXG4gICAgICAgIHJlc3VsdCArPSBTdHJpbmcuZnJvbUNoYXJDb2RlKGUpO1xyXG4gICAgICB9XHJcbiAgICAgIHJldHVybiByZXN1bHQ7XHJcbiAgICB9XHJcblxyXG4gICAgLy8gaGV4U3RyaW5nKGJ1ZmZlcikge1xyXG4gICAgLy8gICAgIGNvbnN0IGJ5dGVBcnJheSA9IG5ldyBVaW50OEFycmF5KGJ1ZmZlcik7XHJcbiAgICAvLyAgICAgY29uc3QgaGV4Q29kZXMgPSBbLi4uYnl0ZUFycmF5XS5tYXAodmFsdWUgPT4ge1xyXG4gICAgLy8gICAgICAgY29uc3QgaGV4Q29kZSA9IHZhbHVlLnRvU3RyaW5nKDE2KTtcclxuICAgIC8vICAgICAgIGNvbnN0IHBhZGRlZEhleENvZGUgPSBoZXhDb2RlLnBhZFN0YXJ0KDIsICcwJyk7XHJcbiAgICAvLyAgICAgICByZXR1cm4gcGFkZGVkSGV4Q29kZTtcclxuICAgIC8vICAgICB9KTtcclxuICAgICAgXHJcbiAgICAvLyAgICAgcmV0dXJuIGhleENvZGVzLmpvaW4oJycpO1xyXG4gICAgLy8gICB9XHJcbiAgICBcclxuICAgICAgLy8gdG9IYXNoU3RyaW5nKGhleFN0cmluZzogc3RyaW5nKSB7XHJcbiAgICAgIC8vICAgbGV0IHJlc3VsdCA9ICcnO1xyXG4gICAgICAvLyAgIGZvciAobGV0IGkgPSAwOyBpIDwgaGV4U3RyaW5nLmxlbmd0aDsgaSArPSAyKSB7XHJcbiAgICAgIC8vICAgICBsZXQgaGV4RGlnaXQgPSBoZXhTdHJpbmcuY2hhckF0KGkpICsgaGV4U3RyaW5nLmNoYXJBdChpICsgMSk7XHJcbiAgICAgIC8vICAgICBsZXQgbnVtID0gcGFyc2VJbnQoaGV4RGlnaXQsIDE2KTtcclxuICAgICAgLy8gICAgIHJlc3VsdCArPSBTdHJpbmcuZnJvbUNoYXJDb2RlKG51bSk7XHJcbiAgICAgIC8vICAgfVxyXG4gICAgICAvLyAgIHJldHVybiByZXN1bHQ7XHJcbiAgICAgIC8vIH1cclxuXHJcbn0iXX0=

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __extends } from "tslib";
import { NullValidationHandler } from './null-validation-handler';

@@ -10,3 +10,3 @@ var err = "PLEASE READ THIS CAREFULLY:\n\nBeginning with angular-oauth2-oidc version 9, the JwksValidationHandler\nhas been moved to an library of its own. If you need it for implementing\nOAuth2/OIDC **implicit flow**, please install it using npm:\n\n npm i angular-oauth2-oidc-jwks --save\n\nAfter that, you can import it into your application:\n\n import { JwksValidationHandler } from 'angular-oauth2-oidc-jwks';\n\nPlease note, that this dependency is not needed for the **code flow**,\nwhich is nowadays the **recommented** one for single page applications.\nThis also results in smaller bundle sizes.\n";

var JwksValidationHandler = /** @class */ (function (_super) {
tslib_1.__extends(JwksValidationHandler, _super);
__extends(JwksValidationHandler, _super);
function JwksValidationHandler() {

@@ -20,2 +20,2 @@ var _this = _super.call(this) || this;

export { JwksValidationHandler };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiandrcy12YWxpZGF0aW9uLWhhbmRsZXIuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLW9hdXRoMi1vaWRjLyIsInNvdXJjZXMiOlsidG9rZW4tdmFsaWRhdGlvbi9qd2tzLXZhbGlkYXRpb24taGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFbEUsSUFBTSxHQUFHLEdBQUcsMGxCQWVYLENBQUM7QUFFRjs7OztHQUlHO0FBQ0g7SUFBMkMsaURBQXFCO0lBRTlEO1FBQUEsWUFDRSxpQkFBTyxTQUVSO1FBREMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQzs7SUFDckIsQ0FBQztJQUVILDRCQUFDO0FBQUQsQ0FBQyxBQVBELENBQTJDLHFCQUFxQixHQU8vRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE51bGxWYWxpZGF0aW9uSGFuZGxlciB9IGZyb20gJy4vbnVsbC12YWxpZGF0aW9uLWhhbmRsZXInO1xyXG5cclxuY29uc3QgZXJyID0gYFBMRUFTRSBSRUFEIFRISVMgQ0FSRUZVTExZOlxyXG5cclxuQmVnaW5uaW5nIHdpdGggYW5ndWxhci1vYXV0aDItb2lkYyB2ZXJzaW9uIDksIHRoZSBKd2tzVmFsaWRhdGlvbkhhbmRsZXJcclxuaGFzIGJlZW4gbW92ZWQgdG8gYW4gbGlicmFyeSBvZiBpdHMgb3duLiBJZiB5b3UgbmVlZCBpdCBmb3IgaW1wbGVtZW50aW5nXHJcbk9BdXRoMi9PSURDICoqaW1wbGljaXQgZmxvdyoqLCBwbGVhc2UgaW5zdGFsbCBpdCB1c2luZyBucG06XHJcblxyXG4gIG5wbSBpIGFuZ3VsYXItb2F1dGgyLW9pZGMtandrcyAtLXNhdmVcclxuXHJcbkFmdGVyIHRoYXQsIHlvdSBjYW4gaW1wb3J0IGl0IGludG8geW91ciBhcHBsaWNhdGlvbjpcclxuXHJcbiAgaW1wb3J0IHsgSndrc1ZhbGlkYXRpb25IYW5kbGVyIH0gZnJvbSAnYW5ndWxhci1vYXV0aDItb2lkYy1qd2tzJztcclxuXHJcblBsZWFzZSBub3RlLCB0aGF0IHRoaXMgZGVwZW5kZW5jeSBpcyBub3QgbmVlZGVkIGZvciB0aGUgKipjb2RlIGZsb3cqKixcclxud2hpY2ggaXMgbm93YWRheXMgdGhlICoqcmVjb21tZW50ZWQqKiBvbmUgZm9yIHNpbmdsZSBwYWdlIGFwcGxpY2F0aW9ucy5cclxuVGhpcyBhbHNvIHJlc3VsdHMgaW4gc21hbGxlciBidW5kbGUgc2l6ZXMuXHJcbmA7XHJcblxyXG4vKipcclxuICogVGhpcyBpcyBqdXN0IGEgZHVtbXkgb2YgdGhlIEp3a3NWYWxpZGF0aW9uSGFuZGxlclxyXG4gKiB0ZWxsaW5nIHRoZSB1c2VycyB0aGF0IHRoZSByZWFsIG9uZSBoYXMgYmVlbiBtb3ZlZFxyXG4gKiB0byBhbiBsaWJyYXJ5IG9mIGl0cyBvd24sIG5hbWVseSBhbmd1bGFyLW9hdXRoMi1vaWRjLXV0aWxzXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgSndrc1ZhbGlkYXRpb25IYW5kbGVyIGV4dGVuZHMgTnVsbFZhbGlkYXRpb25IYW5kbGVyIHtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgY29uc29sZS5lcnJvcihlcnIpO1xyXG4gIH1cclxuXHJcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiandrcy12YWxpZGF0aW9uLWhhbmRsZXIuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLW9hdXRoMi1vaWRjLyIsInNvdXJjZXMiOlsidG9rZW4tdmFsaWRhdGlvbi9qd2tzLXZhbGlkYXRpb24taGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFbEUsSUFBTSxHQUFHLEdBQUcsMGxCQWVYLENBQUM7QUFFRjs7OztHQUlHO0FBQ0g7SUFBMkMseUNBQXFCO0lBRTlEO1FBQUEsWUFDRSxpQkFBTyxTQUVSO1FBREMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQzs7SUFDckIsQ0FBQztJQUVILDRCQUFDO0FBQUQsQ0FBQyxBQVBELENBQTJDLHFCQUFxQixHQU8vRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE51bGxWYWxpZGF0aW9uSGFuZGxlciB9IGZyb20gJy4vbnVsbC12YWxpZGF0aW9uLWhhbmRsZXInO1xyXG5cclxuY29uc3QgZXJyID0gYFBMRUFTRSBSRUFEIFRISVMgQ0FSRUZVTExZOlxyXG5cclxuQmVnaW5uaW5nIHdpdGggYW5ndWxhci1vYXV0aDItb2lkYyB2ZXJzaW9uIDksIHRoZSBKd2tzVmFsaWRhdGlvbkhhbmRsZXJcclxuaGFzIGJlZW4gbW92ZWQgdG8gYW4gbGlicmFyeSBvZiBpdHMgb3duLiBJZiB5b3UgbmVlZCBpdCBmb3IgaW1wbGVtZW50aW5nXHJcbk9BdXRoMi9PSURDICoqaW1wbGljaXQgZmxvdyoqLCBwbGVhc2UgaW5zdGFsbCBpdCB1c2luZyBucG06XHJcblxyXG4gIG5wbSBpIGFuZ3VsYXItb2F1dGgyLW9pZGMtandrcyAtLXNhdmVcclxuXHJcbkFmdGVyIHRoYXQsIHlvdSBjYW4gaW1wb3J0IGl0IGludG8geW91ciBhcHBsaWNhdGlvbjpcclxuXHJcbiAgaW1wb3J0IHsgSndrc1ZhbGlkYXRpb25IYW5kbGVyIH0gZnJvbSAnYW5ndWxhci1vYXV0aDItb2lkYy1qd2tzJztcclxuXHJcblBsZWFzZSBub3RlLCB0aGF0IHRoaXMgZGVwZW5kZW5jeSBpcyBub3QgbmVlZGVkIGZvciB0aGUgKipjb2RlIGZsb3cqKixcclxud2hpY2ggaXMgbm93YWRheXMgdGhlICoqcmVjb21tZW50ZWQqKiBvbmUgZm9yIHNpbmdsZSBwYWdlIGFwcGxpY2F0aW9ucy5cclxuVGhpcyBhbHNvIHJlc3VsdHMgaW4gc21hbGxlciBidW5kbGUgc2l6ZXMuXHJcbmA7XHJcblxyXG4vKipcclxuICogVGhpcyBpcyBqdXN0IGEgZHVtbXkgb2YgdGhlIEp3a3NWYWxpZGF0aW9uSGFuZGxlclxyXG4gKiB0ZWxsaW5nIHRoZSB1c2VycyB0aGF0IHRoZSByZWFsIG9uZSBoYXMgYmVlbiBtb3ZlZFxyXG4gKiB0byBhbiBsaWJyYXJ5IG9mIGl0cyBvd24sIG5hbWVseSBhbmd1bGFyLW9hdXRoMi1vaWRjLXV0aWxzXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgSndrc1ZhbGlkYXRpb25IYW5kbGVyIGV4dGVuZHMgTnVsbFZhbGlkYXRpb25IYW5kbGVyIHtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgY29uc29sZS5lcnJvcihlcnIpO1xyXG4gIH1cclxuXHJcbn0iXX0=

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __awaiter, __generator } from "tslib";
import { base64UrlEncode } from '../base64-helper';

@@ -25,5 +25,5 @@ /**

AbstractValidationHandler.prototype.validateAtHash = function (params) {
return tslib_1.__awaiter(this, void 0, void 0, function () {
return __awaiter(this, void 0, void 0, function () {
var hashAlg, tokenHash, leftMostHalf, atHash, claimsAtHash;
return tslib_1.__generator(this, function (_a) {
return __generator(this, function (_a) {
switch (_a.label) {

@@ -30,0 +30,0 @@ case 0:

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate } from "tslib";
import { Injectable } from "@angular/core";

@@ -56,3 +56,3 @@ /**

};
MemoryStorage = tslib_1.__decorate([
MemoryStorage = __decorate([
Injectable()

@@ -73,2 +73,2 @@ ], MemoryStorage);

export { ReceivedTokens };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"ng://angular-oauth2-oidc/","sources":["types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C;;GAEG;AACH;IAAA;QA8CE;;;;;WAKG;QACH,+BAA0B,GAAI,KAAK,CAAC;IAQtC,CAAC;IAAD,mBAAC;AAAD,CAAC,AA5DD,IA4DC;;AAED;;;;;GAKG;AACH;IAAA;IAMA,CAAC;IAAD,kBAAC;AAAD,CAAC,AAND,IAMC;;AAED;;;;;GAKG;AACH;IAAA;IAIA,CAAC;IAAD,mBAAC;AAAD,CAAC,AAJD,IAIC;;AAGD;IADA;QAEU,SAAI,GAAG,IAAI,GAAG,EAAkB,CAAC;IAc3C,CAAC;IAZC,+BAAO,GAAP,UAAQ,GAAW;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,kCAAU,GAAV,UAAW,GAAW;QACpB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,+BAAO,GAAP,UAAQ,GAAW,EAAE,IAAY;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;IAbU,aAAa;QADzB,UAAU,EAAE;OACA,aAAa,CAezB;IAAD,oBAAC;CAAA,AAfD,IAeC;SAfY,aAAa;AAiB1B;;;GAGG;AACH;IAAA;IAKA,CAAC;IAAD,qBAAC;AAAD,CAAC,AALD,IAKC","sourcesContent":["import { Injectable } from \"@angular/core\";\r\n\r\n/**\r\n * Additional options that can be passed to tryLogin.\r\n */\r\nexport class LoginOptions {\r\n  /**\r\n   * Is called, after a token has been received and\r\n   * successfully validated.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onTokenReceived?: (receivedTokens: ReceivedTokens) => void;\r\n\r\n  /**\r\n   * Hook, to validate the received tokens.\r\n   *\r\n   * Deprecated:  Use property ``tokenValidationHandler`` on OAuthService instead.\r\n   */\r\n  validationHandler?: (receivedTokens: ReceivedTokens) => Promise<any>;\r\n\r\n  /**\r\n   * Called when tryLogin detects that the auth server\r\n   * included an error message into the hash fragment.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onLoginError?: (params: object) => void;\r\n\r\n  /**\r\n   * A custom hash fragment to be used instead of the\r\n   * actual one. This is used for silent refreshes, to\r\n   * pass the iframes hash fragment to this method, and\r\n   * is also used by popup flows in the same manner.\r\n   * This can be used with code flow, where is must be set\r\n   * to a hash symbol followed by the querystring. The\r\n   * question mark is optional, but may be present following\r\n   * the hash symbol.\r\n   */\r\n  customHashFragment?: string;\r\n\r\n  /**\r\n   * Set this to true to disable the oauth2 state\r\n   * check which is a best practice to avoid\r\n   * security attacks.\r\n   * As OIDC defines a nonce check that includes\r\n   * this, this can be set to true when only doing\r\n   * OIDC.\r\n   */\r\n  disableOAuth2StateCheck?: boolean;\r\n\r\n  /**\r\n   * Normally, you want to clear your hash fragment after\r\n   * the lib read the token(s) so that they are not displayed\r\n   * anymore in the url. If not, set this to true. For code flow\r\n   * this controls removing query string values.\r\n   */\r\n  preventClearHashAfterLogin? = false;\r\n\r\n  /**\r\n   * Set this for code flow if you used a custom redirect Uri\r\n   * when retrieving the code. This is used internally for silent\r\n   * refresh and popup flows.\r\n   */\r\n  customRedirectUri?: string;\r\n}\r\n\r\n/**\r\n * Defines the logging interface the OAuthService uses\r\n * internally. Is compatible with the `console` object,\r\n * but you can provide your own implementation as well\r\n * through dependency injection.\r\n */\r\nexport abstract class OAuthLogger {\r\n  abstract debug(message?: any, ...optionalParams: any[]): void;\r\n  abstract info(message?: any, ...optionalParams: any[]): void;\r\n  abstract log(message?: any, ...optionalParams: any[]): void;\r\n  abstract warn(message?: any, ...optionalParams: any[]): void;\r\n  abstract error(message?: any, ...optionalParams: any[]): void;\r\n}\r\n\r\n/**\r\n * Defines a simple storage that can be used for\r\n * storing the tokens at client side.\r\n * Is compatible to localStorage and sessionStorage,\r\n * but you can also create your own implementations.\r\n */\r\nexport abstract class OAuthStorage {\r\n  abstract getItem(key: string): string | null;\r\n  abstract removeItem(key: string): void;\r\n  abstract setItem(key: string, data: string): void;\r\n}\r\n\r\n@Injectable()\r\nexport class MemoryStorage implements OAuthStorage {\r\n  private data = new Map<string, string>();\r\n\r\n  getItem(key: string): string {\r\n    return this.data.get(key);\r\n  }\r\n\r\n  removeItem(key: string): void {\r\n    this.data.delete(key);\r\n  }\r\n\r\n  setItem(key: string, data: string): void {\r\n    this.data.set(key, data);\r\n  }\r\n\r\n}\r\n\r\n/**\r\n * Represents the received tokens, the received state\r\n * and the parsed claims from the id-token.\r\n */\r\nexport class ReceivedTokens {\r\n  idToken: string;\r\n  accessToken: string;\r\n  idClaims?: object;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the parsed and validated id_token.\r\n */\r\nexport interface ParsedIdToken {\r\n  idToken: string;\r\n  idTokenClaims: object;\r\n  idTokenHeader: object;\r\n  idTokenClaimsJson: string;\r\n  idTokenHeaderJson: string;\r\n  idTokenExpiresAt: number;\r\n}\r\n\r\n/**\r\n * Represents the response from the token endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#TokenEndpoint\r\n */\r\nexport interface TokenResponse {\r\n  access_token: string;\r\n  id_token: string; \r\n  token_type: string;\r\n  expires_in: number;\r\n  refresh_token: string;\r\n  scope: string;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the response from the user info endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#UserInfo\r\n */\r\nexport interface UserInfo {\r\n  sub: string;\r\n  [key: string]: any;\r\n}\r\n\r\n/**\r\n * Represents an OpenID Connect discovery document\r\n */\r\nexport interface OidcDiscoveryDoc {\r\n  issuer: string;\r\n  authorization_endpoint: string;\r\n  token_endpoint: string;\r\n  token_endpoint_auth_methods_supported: string[];\r\n  token_endpoint_auth_signing_alg_values_supported: string[];\r\n  userinfo_endpoint: string;\r\n  check_session_iframe: string;\r\n  end_session_endpoint: string;\r\n  jwks_uri: string;\r\n  registration_endpoint: string;\r\n  scopes_supported: string[];\r\n  response_types_supported: string[];\r\n  acr_values_supported: string[];\r\n  response_modes_supported: string[];\r\n  grant_types_supported: string[];\r\n  subject_types_supported: string[];\r\n  userinfo_signing_alg_values_supported: string[];\r\n  userinfo_encryption_alg_values_supported: string[];\r\n  userinfo_encryption_enc_values_supported: string[];\r\n  id_token_signing_alg_values_supported: string[];\r\n  id_token_encryption_alg_values_supported: string[];\r\n  id_token_encryption_enc_values_supported: string[];\r\n  request_object_signing_alg_values_supported: string[];\r\n  display_values_supported: string[];\r\n  claim_types_supported: string[];\r\n  claims_supported: string[];\r\n  claims_parameter_supported: boolean;\r\n  service_documentation: string;\r\n  ui_locales_supported: string[];\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"ng://angular-oauth2-oidc/","sources":["types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C;;GAEG;AACH;IAAA;QA8CE;;;;;WAKG;QACH,+BAA0B,GAAI,KAAK,CAAC;IAQtC,CAAC;IAAD,mBAAC;AAAD,CAAC,AA5DD,IA4DC;;AAED;;;;;GAKG;AACH;IAAA;IAMA,CAAC;IAAD,kBAAC;AAAD,CAAC,AAND,IAMC;;AAED;;;;;GAKG;AACH;IAAA;IAIA,CAAC;IAAD,mBAAC;AAAD,CAAC,AAJD,IAIC;;AAGD;IAAA;QACU,SAAI,GAAG,IAAI,GAAG,EAAkB,CAAC;IAc3C,CAAC;IAZC,+BAAO,GAAP,UAAQ,GAAW;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,kCAAU,GAAV,UAAW,GAAW;QACpB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,+BAAO,GAAP,UAAQ,GAAW,EAAE,IAAY;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;IAbU,aAAa;QADzB,UAAU,EAAE;OACA,aAAa,CAezB;IAAD,oBAAC;CAAA,AAfD,IAeC;SAfY,aAAa;AAiB1B;;;GAGG;AACH;IAAA;IAKA,CAAC;IAAD,qBAAC;AAAD,CAAC,AALD,IAKC","sourcesContent":["import { Injectable } from \"@angular/core\";\r\n\r\n/**\r\n * Additional options that can be passed to tryLogin.\r\n */\r\nexport class LoginOptions {\r\n  /**\r\n   * Is called, after a token has been received and\r\n   * successfully validated.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onTokenReceived?: (receivedTokens: ReceivedTokens) => void;\r\n\r\n  /**\r\n   * Hook, to validate the received tokens.\r\n   *\r\n   * Deprecated:  Use property ``tokenValidationHandler`` on OAuthService instead.\r\n   */\r\n  validationHandler?: (receivedTokens: ReceivedTokens) => Promise<any>;\r\n\r\n  /**\r\n   * Called when tryLogin detects that the auth server\r\n   * included an error message into the hash fragment.\r\n   *\r\n   * Deprecated:  Use property ``events`` on OAuthService instead.\r\n   */\r\n  onLoginError?: (params: object) => void;\r\n\r\n  /**\r\n   * A custom hash fragment to be used instead of the\r\n   * actual one. This is used for silent refreshes, to\r\n   * pass the iframes hash fragment to this method, and\r\n   * is also used by popup flows in the same manner.\r\n   * This can be used with code flow, where is must be set\r\n   * to a hash symbol followed by the querystring. The\r\n   * question mark is optional, but may be present following\r\n   * the hash symbol.\r\n   */\r\n  customHashFragment?: string;\r\n\r\n  /**\r\n   * Set this to true to disable the oauth2 state\r\n   * check which is a best practice to avoid\r\n   * security attacks.\r\n   * As OIDC defines a nonce check that includes\r\n   * this, this can be set to true when only doing\r\n   * OIDC.\r\n   */\r\n  disableOAuth2StateCheck?: boolean;\r\n\r\n  /**\r\n   * Normally, you want to clear your hash fragment after\r\n   * the lib read the token(s) so that they are not displayed\r\n   * anymore in the url. If not, set this to true. For code flow\r\n   * this controls removing query string values.\r\n   */\r\n  preventClearHashAfterLogin? = false;\r\n\r\n  /**\r\n   * Set this for code flow if you used a custom redirect Uri\r\n   * when retrieving the code. This is used internally for silent\r\n   * refresh and popup flows.\r\n   */\r\n  customRedirectUri?: string;\r\n}\r\n\r\n/**\r\n * Defines the logging interface the OAuthService uses\r\n * internally. Is compatible with the `console` object,\r\n * but you can provide your own implementation as well\r\n * through dependency injection.\r\n */\r\nexport abstract class OAuthLogger {\r\n  abstract debug(message?: any, ...optionalParams: any[]): void;\r\n  abstract info(message?: any, ...optionalParams: any[]): void;\r\n  abstract log(message?: any, ...optionalParams: any[]): void;\r\n  abstract warn(message?: any, ...optionalParams: any[]): void;\r\n  abstract error(message?: any, ...optionalParams: any[]): void;\r\n}\r\n\r\n/**\r\n * Defines a simple storage that can be used for\r\n * storing the tokens at client side.\r\n * Is compatible to localStorage and sessionStorage,\r\n * but you can also create your own implementations.\r\n */\r\nexport abstract class OAuthStorage {\r\n  abstract getItem(key: string): string | null;\r\n  abstract removeItem(key: string): void;\r\n  abstract setItem(key: string, data: string): void;\r\n}\r\n\r\n@Injectable()\r\nexport class MemoryStorage implements OAuthStorage {\r\n  private data = new Map<string, string>();\r\n\r\n  getItem(key: string): string {\r\n    return this.data.get(key);\r\n  }\r\n\r\n  removeItem(key: string): void {\r\n    this.data.delete(key);\r\n  }\r\n\r\n  setItem(key: string, data: string): void {\r\n    this.data.set(key, data);\r\n  }\r\n\r\n}\r\n\r\n/**\r\n * Represents the received tokens, the received state\r\n * and the parsed claims from the id-token.\r\n */\r\nexport class ReceivedTokens {\r\n  idToken: string;\r\n  accessToken: string;\r\n  idClaims?: object;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the parsed and validated id_token.\r\n */\r\nexport interface ParsedIdToken {\r\n  idToken: string;\r\n  idTokenClaims: object;\r\n  idTokenHeader: object;\r\n  idTokenClaimsJson: string;\r\n  idTokenHeaderJson: string;\r\n  idTokenExpiresAt: number;\r\n}\r\n\r\n/**\r\n * Represents the response from the token endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#TokenEndpoint\r\n */\r\nexport interface TokenResponse {\r\n  access_token: string;\r\n  id_token: string; \r\n  token_type: string;\r\n  expires_in: number;\r\n  refresh_token: string;\r\n  scope: string;\r\n  state?: string;\r\n}\r\n\r\n/**\r\n * Represents the response from the user info endpoint\r\n * http://openid.net/specs/openid-connect-core-1_0.html#UserInfo\r\n */\r\nexport interface UserInfo {\r\n  sub: string;\r\n  [key: string]: any;\r\n}\r\n\r\n/**\r\n * Represents an OpenID Connect discovery document\r\n */\r\nexport interface OidcDiscoveryDoc {\r\n  issuer: string;\r\n  authorization_endpoint: string;\r\n  token_endpoint: string;\r\n  token_endpoint_auth_methods_supported: string[];\r\n  token_endpoint_auth_signing_alg_values_supported: string[];\r\n  userinfo_endpoint: string;\r\n  check_session_iframe: string;\r\n  end_session_endpoint: string;\r\n  jwks_uri: string;\r\n  registration_endpoint: string;\r\n  scopes_supported: string[];\r\n  response_types_supported: string[];\r\n  acr_values_supported: string[];\r\n  response_modes_supported: string[];\r\n  grant_types_supported: string[];\r\n  subject_types_supported: string[];\r\n  userinfo_signing_alg_values_supported: string[];\r\n  userinfo_encryption_alg_values_supported: string[];\r\n  userinfo_encryption_enc_values_supported: string[];\r\n  id_token_signing_alg_values_supported: string[];\r\n  id_token_encryption_alg_values_supported: string[];\r\n  id_token_encryption_enc_values_supported: string[];\r\n  request_object_signing_alg_values_supported: string[];\r\n  display_values_supported: string[];\r\n  claim_types_supported: string[];\r\n  claims_supported: string[];\r\n  claims_parameter_supported: boolean;\r\n  service_documentation: string;\r\n  ui_locales_supported: string[];\r\n}\r\n"]}

@@ -1,2 +0,2 @@

import * as tslib_1 from "tslib";
import { __decorate } from "tslib";
import { Injectable } from '@angular/core';

@@ -48,3 +48,3 @@ var UrlHelperService = /** @class */ (function () {

};
UrlHelperService = tslib_1.__decorate([
UrlHelperService = __decorate([
Injectable()

@@ -51,0 +51,0 @@ ], UrlHelperService);

@@ -188,7 +188,7 @@ import { NgZone, OnDestroy } from '@angular/core';

width?: number;
}): Promise<{}>;
}): Promise<unknown>;
initLoginFlowInPopup(options?: {
height?: number;
width?: number;
}): Promise<{}>;
}): Promise<unknown>;
protected calculatePopupFeatures(options: {

@@ -195,0 +195,0 @@ height?: number;

@@ -7,7 +7,8 @@ {

},
"version": "9.0.0",
"version": "9.0.1",
"repository": "manfredsteyer/angular-oauth2-oidc",
"peerDependencies": {
"@angular/common": ">=9.0.0",
"@angular/core": ">=9.0.0"
"@angular/common": ">=8.0.0",
"@angular/core": ">=8.0.0",
"tslib": "^1.10.0"
},

@@ -23,6 +24,3 @@ "main": "bundles/angular-oauth2-oidc.umd.js",

"metadata": "angular-oauth2-oidc.metadata.json",
"sideEffects": false,
"dependencies": {
"tslib": "^1.9.0"
}
"sideEffects": false
}

Sorry, the diff of this file is too big to display

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 too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc