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

ngx-auth

Package Overview
Dependencies
Maintainers
1
Versions
18
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-auth - npm Package Compare versions

Comparing version 5.3.0 to 5.4.0

2

auth.service.d.ts

@@ -30,3 +30,3 @@ import { HttpRequest, HttpErrorResponse } from '@angular/common/http';

*/
abstract refreshShouldHappen(response: HttpErrorResponse): boolean;
abstract refreshShouldHappen(response: HttpErrorResponse, request?: HttpRequest<any>): boolean;
/**

@@ -33,0 +33,0 @@ * Verify that outgoing request is refresh-token,

(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/router'), require('rxjs/operators'), require('@angular/common/http'), require('rxjs')) :
typeof define === 'function' && define.amd ? define('ngx-auth', ['exports', '@angular/core', '@angular/router', 'rxjs/operators', '@angular/common/http', 'rxjs'], factory) :
(factory((global['ngx-auth'] = {}),global.ng.core,global.ng.router,global.rxjs.operators,global.ng.common.http,global.rxjs));
}(this, (function (exports,core,router,operators,http,rxjs) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/router'), require('rxjs/operators'), require('@angular/common/http'), require('rxjs')) :
typeof define === 'function' && define.amd ? define('ngx-auth', ['exports', '@angular/core', '@angular/common', '@angular/router', 'rxjs/operators', '@angular/common/http', 'rxjs'], factory) :
(factory((global['ngx-auth'] = {}),global.ng.core,global.ng.common,global.ng.router,global.rxjs.operators,global.ng.common.http,global.rxjs));
}(this, (function (exports,core,common,router,operators,http,rxjs) { 'use strict';

@@ -46,7 +46,9 @@ /**

* @export
* \@dynamic
*/
var PublicGuard = /** @class */ (function () {
function PublicGuard(authService, protectedFallbackPageUri, router$$1) {
function PublicGuard(authService, protectedFallbackPageUri, document, router$$1) {
this.authService = authService;
this.protectedFallbackPageUri = protectedFallbackPageUri;
this.document = document;
this.router = router$$1;

@@ -129,3 +131,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -144,2 +146,3 @@ else {

{ type: String, decorators: [{ type: core.Inject, args: [PROTECTED_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: core.Inject, args: [common.DOCUMENT,] }] },
{ type: router.Router }

@@ -162,7 +165,9 @@ ];

* @export
* \@dynamic
*/
var ProtectedGuard = /** @class */ (function () {
function ProtectedGuard(authService, publicFallbackPageUri, router$$1) {
function ProtectedGuard(authService, publicFallbackPageUri, document, router$$1) {
this.authService = authService;
this.publicFallbackPageUri = publicFallbackPageUri;
this.document = document;
this.router = router$$1;

@@ -248,3 +253,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -263,2 +268,3 @@ else {

{ type: String, decorators: [{ type: core.Inject, args: [PUBLIC_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: core.Inject, args: [common.DOCUMENT,] }] },
{ type: router.Router }

@@ -271,14 +277,14 @@ ];

/*! *****************************************************************************
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
Copyright (c) Microsoft Corporation.
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.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */

@@ -416,3 +422,3 @@ function __read(o, n) {

/** @type {?} */
var refreshShouldHappen = authService.refreshShouldHappen(res);
var refreshShouldHappen = authService.refreshShouldHappen(res, req);
if (refreshShouldHappen && !this.refreshInProgress) {

@@ -625,2 +631,2 @@ this.refreshInProgress = true;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.umd.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","node_modules/tslib/tslib.es6.js","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = Object.setPrototypeOf ||\r\n    ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n    function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = Object.assign || function __assign(t) {\r\n    for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n        s = arguments[i];\r\n        for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n    }\r\n    return t;\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)\r\n            t[p[i]] = s[p[i]];\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = y[op[0] & 2 ? \"return\" : op[0] ? \"throw\" : \"next\"]) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [0, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n    if (m) return m.call(o);\r\n    return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);  }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { if (o[n]) i[n] = function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; }; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator];\r\n    return m ? m.call(o) : typeof __values === \"function\" ? __values(o) : o[Symbol.iterator]();\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":["InjectionToken","router","map","Injectable","Inject","Router","Subject","switchMap","catchError","throwError","first","http","HttpClient","Injector","NgModule","HTTP_INTERCEPTORS"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.umd.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","node_modules/tslib/tslib.es6.js","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse, request?: HttpRequest<any>): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res, req);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":["InjectionToken","router","map","Injectable","Inject","DOCUMENT","Router","Subject","switchMap","catchError","throwError","first","http","HttpClient","Injector","NgModule","HTTP_INTERCEPTORS"],"mappings":"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"}

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/router"),require("rxjs/operators"),require("@angular/common/http"),require("rxjs")):"function"==typeof define&&define.amd?define("ngx-auth",["exports","@angular/core","@angular/router","rxjs/operators","@angular/common/http","rxjs"],t):t(e["ngx-auth"]={},e.ng.core,e.ng.router,e.rxjs.operators,e.ng.common.http,e.rxjs)}(this,function(e,t,r,o,i,u){"use strict";var n=function y(){},s=new t.InjectionToken("AUTH_SERVICE"),c=new t.InjectionToken("PUBLIC_FALLBACK_PAGE_URI"),a=new t.InjectionToken("PROTECTED_FALLBACK_PAGE_URI"),p=function(){function e(e,t,r){this.authService=e,this.protectedFallbackPageUri=t,this.router=r}return e.prototype.canActivate=function(e,t){var r=this;return this.authService.isAuthorized().pipe(o.map(function(e){return!(e&&!r.isProtectedPage(t))||(r.navigate(r.protectedFallbackPageUri),!1)}))},e.prototype.canActivateChild=function(e,t){return this.canActivate(e,t)},e.prototype.isProtectedPage=function(e){return e.url===this.protectedFallbackPageUri},e.prototype.navigate=function(e){e.startsWith("http")?window.location.href=e:this.router.navigateByUrl(e)},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:n,decorators:[{type:t.Inject,args:[s]}]},{type:String,decorators:[{type:t.Inject,args:[a]}]},{type:r.Router}]},e}(),h=function(){function e(e,t,r){this.authService=e,this.publicFallbackPageUri=t,this.router=r}return e.prototype.canActivate=function(e,t){var r=this;return this.authService.isAuthorized().pipe(o.map(function(e){return!(!e&&!r.isPublicPage(t))||(r.authService.setInterruptedUrl&&r.authService.setInterruptedUrl(t.url),r.navigate(r.publicFallbackPageUri),!1)}))},e.prototype.canActivateChild=function(e,t){return this.canActivate(e,t)},e.prototype.isPublicPage=function(e){return e.url===this.publicFallbackPageUri},e.prototype.navigate=function(e){e.startsWith("http")?window.location.href=e:this.router.navigateByUrl(e)},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:n,decorators:[{type:t.Inject,args:[s]}]},{type:String,decorators:[{type:t.Inject,args:[c]}]},{type:r.Router}]},e}();function f(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,i=r.call(e),u=[];try{for(;(void 0===t||0<t--)&&!(n=i.next()).done;)u.push(n.value)}catch(s){o={error:s}}finally{try{n&&!n.done&&(r=i["return"])&&r.call(i)}finally{if(o)throw o.error}}return u}var l=function(){function e(e){this.injector=e,this.refreshInProgress=!1,this.refreshSubject=new u.Subject}return e.prototype.intercept=function(e,t){return this.skipRequest(e)?t.handle(e):this.processIntercept(e,t)},e.prototype.processIntercept=function(e,t){var r=this,n=e.clone();return this.request(n).pipe(o.switchMap(function(e){return t.handle(e)}),o.catchError(function(e){return r.responseError(n,e)}))},e.prototype.request=function(e){return this.refreshInProgress?this.delayRequest(e):this.addToken(e)},e.prototype.responseError=function(e,t){var r=this,n=this.injector.get(s),o=n.refreshShouldHappen(t);return o&&!this.refreshInProgress&&(this.refreshInProgress=!0,n.refreshToken().subscribe(function(){r.refreshInProgress=!1,r.refreshSubject.next(!0)},function(){r.refreshInProgress=!1,r.refreshSubject.next(!1)})),o&&this.refreshInProgress?this.retryRequest(e,t):u.throwError(t)},e.prototype.addToken=function(r){var n=this.injector.get(s);return n.getAccessToken().pipe(o.map(function(e){if(e){var t=void 0;return t="function"==typeof n.getHeaders?n.getHeaders(e):{Authorization:"Bearer "+e},r.clone({setHeaders:t})}return r}),o.first())},e.prototype.delayRequest=function(t){var r=this;return this.refreshSubject.pipe(o.first(),o.switchMap(function(e){return e?r.addToken(t):u.throwError(t)}))},e.prototype.retryRequest=function(t,r){var n=this.injector.get(i.HttpClient);return this.refreshSubject.pipe(o.first(),o.switchMap(function(e){return e?n.request(t):u.throwError(r||t)}))},e.prototype.skipRequest=function(e){var t=this.exec("skipRequest",e),r=this.exec("verifyRefreshToken",e),n=this.exec("verifyTokenRequest",e.url);return t||r||n},e.prototype.exec=function(e){for(var t=[],r=1;r<arguments.length;r++)t[r-1]=arguments[r];var n=this.injector.get(s);if("function"==typeof n[e])return n[e].apply(n,function o(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(f(arguments[t]));return e}(t))},e.decorators=[{type:t.Injectable}],e.ctorParameters=function(){return[{type:t.Injector}]},e}(),d=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{providers:[p,h,l,{provide:i.HTTP_INTERCEPTORS,useClass:l,multi:!0}]}]}],e}();e.AuthService=n,e.PublicGuard=p,e.ProtectedGuard=h,e.AUTH_SERVICE=s,e.PUBLIC_FALLBACK_PAGE_URI=c,e.PROTECTED_FALLBACK_PAGE_URI=a,e.AuthModule=d,e.ɵa=l,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/router"),require("rxjs/operators"),require("@angular/common/http"),require("rxjs")):"function"==typeof define&&define.amd?define("ngx-auth",["exports","@angular/core","@angular/common","@angular/router","rxjs/operators","@angular/common/http","rxjs"],t):t(e["ngx-auth"]={},e.ng.core,e.ng.common,e.ng.router,e.rxjs.operators,e.ng.common.http,e.rxjs)}(this,function(e,t,r,n,o,i,s){"use strict";var c=function(){},u=new t.InjectionToken("AUTH_SERVICE"),a=new t.InjectionToken("PUBLIC_FALLBACK_PAGE_URI"),p=new t.InjectionToken("PROTECTED_FALLBACK_PAGE_URI"),h=(f.prototype.canActivate=function(e,t){var r=this;return this.authService.isAuthorized().pipe(o.map(function(e){return!(e&&!r.isProtectedPage(t))||(r.navigate(r.protectedFallbackPageUri),!1)}))},f.prototype.canActivateChild=function(e,t){return this.canActivate(e,t)},f.prototype.isProtectedPage=function(e){return e.url===this.protectedFallbackPageUri},f.prototype.navigate=function(e){e.startsWith("http")?this.document.location.href=e:this.router.navigateByUrl(e)},f.decorators=[{type:t.Injectable}],f.ctorParameters=function(){return[{type:c,decorators:[{type:t.Inject,args:[u]}]},{type:String,decorators:[{type:t.Inject,args:[p]}]},{type:Document,decorators:[{type:t.Inject,args:[r.DOCUMENT]}]},{type:n.Router}]},f);function f(e,t,r,n){this.authService=e,this.protectedFallbackPageUri=t,this.document=r,this.router=n}var l=(d.prototype.canActivate=function(e,t){var r=this;return this.authService.isAuthorized().pipe(o.map(function(e){return!(!e&&!r.isPublicPage(t))||(r.authService.setInterruptedUrl&&r.authService.setInterruptedUrl(t.url),r.navigate(r.publicFallbackPageUri),!1)}))},d.prototype.canActivateChild=function(e,t){return this.canActivate(e,t)},d.prototype.isPublicPage=function(e){return e.url===this.publicFallbackPageUri},d.prototype.navigate=function(e){e.startsWith("http")?this.document.location.href=e:this.router.navigateByUrl(e)},d.decorators=[{type:t.Injectable}],d.ctorParameters=function(){return[{type:c,decorators:[{type:t.Inject,args:[u]}]},{type:String,decorators:[{type:t.Inject,args:[a]}]},{type:Document,decorators:[{type:t.Inject,args:[r.DOCUMENT]}]},{type:n.Router}]},d);function d(e,t,r,n){this.authService=e,this.publicFallbackPageUri=t,this.document=r,this.router=n}function y(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,i=r.call(e),s=[];try{for(;(void 0===t||0<t--)&&!(n=i.next()).done;)s.push(n.value)}catch(c){o={error:c}}finally{try{n&&!n.done&&(r=i["return"])&&r.call(i)}finally{if(o)throw o.error}}return s}var g=(v.prototype.intercept=function(e,t){return this.skipRequest(e)?t.handle(e):this.processIntercept(e,t)},v.prototype.processIntercept=function(e,t){var r=this,n=e.clone();return this.request(n).pipe(o.switchMap(function(e){return t.handle(e)}),o.catchError(function(e){return r.responseError(n,e)}))},v.prototype.request=function(e){return this.refreshInProgress?this.delayRequest(e):this.addToken(e)},v.prototype.responseError=function(e,t){var r=this,n=this.injector.get(u),o=n.refreshShouldHappen(t,e);return o&&!this.refreshInProgress&&(this.refreshInProgress=!0,n.refreshToken().subscribe(function(){r.refreshInProgress=!1,r.refreshSubject.next(!0)},function(){r.refreshInProgress=!1,r.refreshSubject.next(!1)})),o&&this.refreshInProgress?this.retryRequest(e,t):s.throwError(t)},v.prototype.addToken=function(r){var n=this.injector.get(u);return n.getAccessToken().pipe(o.map(function(e){if(e){var t=void 0,t="function"==typeof n.getHeaders?n.getHeaders(e):{Authorization:"Bearer "+e};return r.clone({setHeaders:t})}return r}),o.first())},v.prototype.delayRequest=function(t){var r=this;return this.refreshSubject.pipe(o.first(),o.switchMap(function(e){return e?r.addToken(t):s.throwError(t)}))},v.prototype.retryRequest=function(t,r){var n=this.injector.get(i.HttpClient);return this.refreshSubject.pipe(o.first(),o.switchMap(function(e){return e?n.request(t):s.throwError(r||t)}))},v.prototype.skipRequest=function(e){var t=this.exec("skipRequest",e),r=this.exec("verifyRefreshToken",e),e=this.exec("verifyTokenRequest",e.url);return t||r||e},v.prototype.exec=function(e){for(var t=[],r=1;r<arguments.length;r++)t[r-1]=arguments[r];var n=this.injector.get(u);if("function"==typeof n[e])return n[e].apply(n,function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(y(arguments[t]));return e}(t))},v.decorators=[{type:t.Injectable}],v.ctorParameters=function(){return[{type:t.Injector}]},v);function v(e){this.injector=e,this.refreshInProgress=!1,this.refreshSubject=new s.Subject}var P=(I.decorators=[{type:t.NgModule,args:[{providers:[h,l,g,{provide:i.HTTP_INTERCEPTORS,useClass:g,multi:!0}]}]}],I);function I(){}e.AuthService=c,e.PublicGuard=h,e.ProtectedGuard=l,e.AUTH_SERVICE=u,e.PUBLIC_FALLBACK_PAGE_URI=a,e.PROTECTED_FALLBACK_PAGE_URI=p,e.AuthModule=P,e.ɵa=g,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=ngx-auth.umd.min.js.map

@@ -71,3 +71,3 @@ /**

/** @type {?} */
const refreshShouldHappen = authService.refreshShouldHappen(res);
const refreshShouldHappen = authService.refreshShouldHappen(res, req);
if (refreshShouldHappen && !this.refreshInProgress) {

@@ -186,2 +186,2 @@ this.refreshInProgress = true;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"ng://ngx-auth/","sources":["auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"ng://ngx-auth/","sources":["auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res, req);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n"]}

@@ -42,5 +42,6 @@ /**

* @param {?} response
* @param {?=} request
* @return {?}
*/
AuthService.prototype.refreshShouldHappen = function (response) { };
AuthService.prototype.refreshShouldHappen = function (response, request) { };
/**

@@ -91,2 +92,2 @@ * Verify that outgoing request is refresh-token,

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJhdXRoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFNQSxNQUFNLE9BQWdCLFdBQVc7Q0ErRGhDOzs7Ozs7OztJQXpEQyxxREFBb0Q7Ozs7Ozs7O0lBT3BELHVEQUFxRDs7Ozs7Ozs7SUFPckQscURBQWdEOzs7Ozs7Ozs7O0lBUWhELG9FQUEwRTs7Ozs7Ozs7SUFNMUUsa0VBQXdFOzs7Ozs7OztJQU14RSwyREFBaUU7Ozs7Ozs7Ozs7SUFRakUsd0RBQWtGOzs7Ozs7OztJQU1sRiw2REFBc0Q7Ozs7Ozs7Ozs7SUFRdEQsOERBQTBEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cFJlcXVlc3QsIEh0dHBFcnJvclJlc3BvbnNlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG4vKipcbiAqIEVzc2VudGlhbCBzZXJ2aWNlIGZvciBhdXRoZW50aWNhdGlvblxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQXV0aFNlcnZpY2Uge1xuXG4gIC8qKlxuICAgKiBDaGVjaywgaWYgdXNlciBhbHJlYWR5IGF1dGhvcml6ZWQuXG4gICAqIFNob3VsZCByZXR1cm4gT2JzZXJ2YWJsZSB3aXRoIHRydWUgb3IgZmFsc2UgdmFsdWVzXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgaXNBdXRob3JpemVkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgLyoqXG4gICAqIEdldCBhY2Nlc3MgdG9rZW5cbiAgICogU2hvdWxkIHJldHVybiBhY2Nlc3MgdG9rZW4gaW4gT2JzZXJ2YWJsZSBmcm9tIGUuZy5cbiAgICogbG9jYWxTdG9yYWdlXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0QWNjZXNzVG9rZW4oKTogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBGdW5jdGlvbiwgdGhhdCBzaG91bGQgcGVyZm9ybSByZWZyZXNoIHRva2VuXG4gICAqIFNob3VsZCBiZSBzdWNjZXNzZnVsbHkgY29tcGxldGVkIHNvIGludGVyY2VwdG9yXG4gICAqIGNhbiBleGVjdXRlIHBlbmRpbmcgcmVxdWVzdHMgb3IgcmV0cnkgb3JpZ2luYWwgb25lXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgcmVmcmVzaFRva2VuKCk6IE9ic2VydmFibGU8YW55PjtcblxuICAvKipcbiAgICogRnVuY3Rpb24sIGNoZWNrcyByZXNwb25zZSBvZiBmYWlsZWQgcmVxdWVzdCB0byBkZXRlcm1pbmUsXG4gICAqIHdoZXRoZXIgdG9rZW4gYmUgcmVmcmVzaGVkIG9yIG5vdC5cbiAgICpcbiAgICogRXNzZW50aWFsbHkgY2hlY2tzIHN0YXR1c1xuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHJlZnJlc2hTaG91bGRIYXBwZW4ocmVzcG9uc2U6IEh0dHBFcnJvclJlc3BvbnNlKTogYm9vbGVhbjtcblxuICAvKipcbiAgICogVmVyaWZ5IHRoYXQgb3V0Z29pbmcgcmVxdWVzdCBpcyByZWZyZXNoLXRva2VuLFxuICAgKiBzbyBpbnRlcmNlcHRvciB3b24ndCBpbnRlcmNlcHQgdGhpcyByZXF1ZXN0XG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgdmVyaWZ5UmVmcmVzaFRva2VuPyhyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+KTogYm9vbGVhbjtcblxuICAvKipcbiAgICogQ2hlY2tzIGlmIHJlcXVlc3QgbXVzdCBiZSBza2lwcGVkIGJ5IGludGVyY2VwdG9yLlxuICAgKiBVc2VmdWwgZm9yIHJlcXVlc3RzIHN1Y2ggYXMgcmVxdWVzdCB0b2tlbiB3aGljaCBkb2Vzbid0IHJlcXVpcmUgdG9rZW4gaW4gaGVhZGVyc1xuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHNraXBSZXF1ZXN0PyhyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+KTogYm9vbGVhbjtcblxuICAvKipcbiAgICogQWRkIHRva2VuIHRvIGhlYWRlcnMsIGRlcGVuZGVudCBvbiBzZXJ2ZXJcbiAgICogc2V0LXVwLCBieSBkZWZhdWx0IGFkZHMgYSBiZWFyZXIgdG9rZW4uXG4gICAqIENhbGxlZCBieSBpbnRlcmNlcHRvci5cbiAgICogVG8gY2hhbmdlIGJlaGF2aW9yLCBvdmVycmlkZSB0aGlzIG1ldGhvZC5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBnZXRIZWFkZXJzPyh0b2tlbjogc3RyaW5nKTogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIHwgc3RyaW5nW10gfTtcblxuICAvKipcbiAgICogU2F2ZXMgbGFzdCBpbnRlcnJ1cHRlZCB1cmwgaW5zaWRlIG9mIHRoZSBzZXJ2aWNlIGZvciBmdXJ0aGVyIHJldXNhZ2UsXG4gICAqIGUuZy4gcmVzdG9yaW5nIGludGVycnVwdGVkIHBhZ2UgYWZ0ZXIgbG9nZ2luZyBpblxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHNldEludGVycnVwdGVkVXJsPyh1cmw6IHN0cmluZyk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFZlcmlmeSB0aGF0IG91dGdvaW5nIHJlcXVlc3QgaXMgcmVmcmVzaC10b2tlbixcbiAgICogc28gaW50ZXJjZXB0b3Igd29uJ3QgaW50ZXJjZXB0IHRoaXMgcmVxdWVzdFxuICAgKiBAZGVwcmVjYXRlZCBEdWUgdG8gaWxsb2dpY2FsIG1lYW5pbmcvZnVuY3Rpb25hbGl0eSB0aGlzIG1ldGhvZCBpcyBkZXByZWNhdGVkXG4gICAqIEBzZWUgdmVyaWZ5UmVmcmVzaFRva2VuXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgdmVyaWZ5VG9rZW5SZXF1ZXN0Pyh1cmw6IHN0cmluZyk6IGJvb2xlYW47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJhdXRoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFNQSxNQUFNLE9BQWdCLFdBQVc7Q0ErRGhDOzs7Ozs7OztJQXpEQyxxREFBb0Q7Ozs7Ozs7O0lBT3BELHVEQUFxRDs7Ozs7Ozs7SUFPckQscURBQWdEOzs7Ozs7Ozs7OztJQVFoRCw2RUFBc0c7Ozs7Ozs7O0lBTXRHLGtFQUF3RTs7Ozs7Ozs7SUFNeEUsMkRBQWlFOzs7Ozs7Ozs7O0lBUWpFLHdEQUFrRjs7Ozs7Ozs7SUFNbEYsNkRBQXNEOzs7Ozs7Ozs7O0lBUXRELDhEQUEwRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBSZXF1ZXN0LCBIdHRwRXJyb3JSZXNwb25zZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBFc3NlbnRpYWwgc2VydmljZSBmb3IgYXV0aGVudGljYXRpb25cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEF1dGhTZXJ2aWNlIHtcblxuICAvKipcbiAgICogQ2hlY2ssIGlmIHVzZXIgYWxyZWFkeSBhdXRob3JpemVkLlxuICAgKiBTaG91bGQgcmV0dXJuIE9ic2VydmFibGUgd2l0aCB0cnVlIG9yIGZhbHNlIHZhbHVlc1xuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGlzQXV0aG9yaXplZCgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIC8qKlxuICAgKiBHZXQgYWNjZXNzIHRva2VuXG4gICAqIFNob3VsZCByZXR1cm4gYWNjZXNzIHRva2VuIGluIE9ic2VydmFibGUgZnJvbSBlLmcuXG4gICAqIGxvY2FsU3RvcmFnZVxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGdldEFjY2Vzc1Rva2VuKCk6IE9ic2VydmFibGU8c3RyaW5nPjtcblxuICAvKipcbiAgICogRnVuY3Rpb24sIHRoYXQgc2hvdWxkIHBlcmZvcm0gcmVmcmVzaCB0b2tlblxuICAgKiBTaG91bGQgYmUgc3VjY2Vzc2Z1bGx5IGNvbXBsZXRlZCBzbyBpbnRlcmNlcHRvclxuICAgKiBjYW4gZXhlY3V0ZSBwZW5kaW5nIHJlcXVlc3RzIG9yIHJldHJ5IG9yaWdpbmFsIG9uZVxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHJlZnJlc2hUb2tlbigpOiBPYnNlcnZhYmxlPGFueT47XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uLCBjaGVja3MgcmVzcG9uc2Ugb2YgZmFpbGVkIHJlcXVlc3QgdG8gZGV0ZXJtaW5lLFxuICAgKiB3aGV0aGVyIHRva2VuIGJlIHJlZnJlc2hlZCBvciBub3QuXG4gICAqXG4gICAqIEVzc2VudGlhbGx5IGNoZWNrcyBzdGF0dXNcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCByZWZyZXNoU2hvdWxkSGFwcGVuKHJlc3BvbnNlOiBIdHRwRXJyb3JSZXNwb25zZSwgcmVxdWVzdD86IEh0dHBSZXF1ZXN0PGFueT4pOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBWZXJpZnkgdGhhdCBvdXRnb2luZyByZXF1ZXN0IGlzIHJlZnJlc2gtdG9rZW4sXG4gICAqIHNvIGludGVyY2VwdG9yIHdvbid0IGludGVyY2VwdCB0aGlzIHJlcXVlc3RcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCB2ZXJpZnlSZWZyZXNoVG9rZW4/KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4pOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgcmVxdWVzdCBtdXN0IGJlIHNraXBwZWQgYnkgaW50ZXJjZXB0b3IuXG4gICAqIFVzZWZ1bCBmb3IgcmVxdWVzdHMgc3VjaCBhcyByZXF1ZXN0IHRva2VuIHdoaWNoIGRvZXNuJ3QgcmVxdWlyZSB0b2tlbiBpbiBoZWFkZXJzXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3Qgc2tpcFJlcXVlc3Q/KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4pOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBBZGQgdG9rZW4gdG8gaGVhZGVycywgZGVwZW5kZW50IG9uIHNlcnZlclxuICAgKiBzZXQtdXAsIGJ5IGRlZmF1bHQgYWRkcyBhIGJlYXJlciB0b2tlbi5cbiAgICogQ2FsbGVkIGJ5IGludGVyY2VwdG9yLlxuICAgKiBUbyBjaGFuZ2UgYmVoYXZpb3IsIG92ZXJyaWRlIHRoaXMgbWV0aG9kLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGdldEhlYWRlcnM/KHRva2VuOiBzdHJpbmcpOiB7IFtuYW1lOiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB9O1xuXG4gIC8qKlxuICAgKiBTYXZlcyBsYXN0IGludGVycnVwdGVkIHVybCBpbnNpZGUgb2YgdGhlIHNlcnZpY2UgZm9yIGZ1cnRoZXIgcmV1c2FnZSxcbiAgICogZS5nLiByZXN0b3JpbmcgaW50ZXJydXB0ZWQgcGFnZSBhZnRlciBsb2dnaW5nIGluXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3Qgc2V0SW50ZXJydXB0ZWRVcmw/KHVybDogc3RyaW5nKTogdm9pZDtcblxuICAvKipcbiAgICogVmVyaWZ5IHRoYXQgb3V0Z29pbmcgcmVxdWVzdCBpcyByZWZyZXNoLXRva2VuLFxuICAgKiBzbyBpbnRlcmNlcHRvciB3b24ndCBpbnRlcmNlcHQgdGhpcyByZXF1ZXN0XG4gICAqIEBkZXByZWNhdGVkIER1ZSB0byBpbGxvZ2ljYWwgbWVhbmluZy9mdW5jdGlvbmFsaXR5IHRoaXMgbWV0aG9kIGlzIGRlcHJlY2F0ZWRcbiAgICogQHNlZSB2ZXJpZnlSZWZyZXNoVG9rZW5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCB2ZXJpZnlUb2tlblJlcXVlc3Q/KHVybDogc3RyaW5nKTogYm9vbGVhbjtcbn1cbiJdfQ==

@@ -5,2 +5,3 @@ /**

*/
import { DOCUMENT } from '@angular/common';
import { Injectable, Inject } from '@angular/core';

@@ -18,2 +19,3 @@ import { Router } from '@angular/router';

* @export
* \@dynamic
*/

@@ -24,7 +26,9 @@ export class ProtectedGuard {

* @param {?} publicFallbackPageUri
* @param {?} document
* @param {?} router
*/
constructor(authService, publicFallbackPageUri, router) {
constructor(authService, publicFallbackPageUri, document, router) {
this.authService = authService;
this.publicFallbackPageUri = publicFallbackPageUri;
this.document = document;
this.router = router;

@@ -75,3 +79,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -90,2 +94,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PUBLIC_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -99,4 +104,6 @@ ];

/** @type {?} */
ProtectedGuard.prototype.document;
/** @type {?} */
ProtectedGuard.prototype.router;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdGVjdGVkLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwcm90ZWN0ZWQuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFDTCxNQUFNLEVBS1AsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7Ozs7OztBQVdsRSxNQUFNLE9BQU8sY0FBYzs7Ozs7O0lBRXpCLFlBQytCLFdBQXdCLEVBQ1gscUJBQTZCLEVBQy9ELE1BQWM7UUFGTyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNYLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBUTtRQUMvRCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQ3JCLENBQUM7Ozs7Ozs7SUFLRyxXQUFXLENBQ2hCLE1BQThCLEVBQzlCLEtBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUU7YUFDbkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFlBQXFCLEVBQUUsRUFBRTtZQUNsQyxJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDOUMsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLGlCQUFpQixFQUFFO29CQUN0QyxJQUFJLENBQUMsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztpQkFDL0M7Z0JBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztnQkFFMUMsT0FBTyxLQUFLLENBQUM7YUFDZDtZQUVELE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7Ozs7Ozs7SUFLTSxnQkFBZ0IsQ0FDckIsS0FBNkIsRUFDN0IsS0FBMEI7UUFFMUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN4QyxDQUFDOzs7Ozs7SUFLTyxZQUFZLENBQUMsS0FBMEI7UUFDN0MsT0FBTyxLQUFLLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztJQUNsRCxDQUFDOzs7Ozs7SUFLTyxRQUFRLENBQUMsR0FBVztRQUMxQixJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDMUIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDO1NBQzVCO2FBQU07WUFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNoQztJQUNILENBQUM7OztZQTFERixVQUFVOzs7O1lBWEYsV0FBVyx1QkFlZixNQUFNLFNBQUMsWUFBWTt5Q0FDbkIsTUFBTSxTQUFDLHdCQUF3QjtZQXpCbEMsTUFBTTs7OztJQXdCSixxQ0FBcUQ7O0lBQ3JELCtDQUF1RTs7SUFDdkUsZ0NBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBSb3V0ZXIsXG4gIENhbkFjdGl2YXRlLFxuICBDYW5BY3RpdmF0ZUNoaWxkLFxuICBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICBSb3V0ZXJTdGF0ZVNuYXBzaG90XG59IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IEF1dGhTZXJ2aWNlIH0gZnJvbSAnLi9hdXRoLnNlcnZpY2UnO1xuaW1wb3J0IHsgQVVUSF9TRVJWSUNFLCBQVUJMSUNfRkFMTEJBQ0tfUEFHRV9VUkkgfSBmcm9tICcuL3Rva2Vucyc7XG5cbi8qKlxuICogR3VhcmQsIGNoZWNrcyBhY2Nlc3MgdG9rZW4gYXZhaWxhYmlsaXR5IGFuZCBhbGxvd3Mgb3IgZGlzYWxsb3dzIGFjY2VzcyB0byBwYWdlLFxuICogYW5kIHJlZGlyZWN0cyBvdXRcbiAqXG4gKiB1c2FnZTogeyBwYXRoOiAndGVzdCcsIGNvbXBvbmVudDogVGVzdENvbXBvbmVudCwgY2FuQWN0aXZhdGU6IFsgQXV0aEd1YXJkIF0gfVxuICpcbiAqIEBleHBvcnRcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFByb3RlY3RlZEd1YXJkIGltcGxlbWVudHMgQ2FuQWN0aXZhdGUsIENhbkFjdGl2YXRlQ2hpbGQge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoQVVUSF9TRVJWSUNFKXByaXZhdGUgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLFxuICAgIEBJbmplY3QoUFVCTElDX0ZBTExCQUNLX1BBR0VfVVJJKSBwcml2YXRlIHB1YmxpY0ZhbGxiYWNrUGFnZVVyaTogc3RyaW5nLFxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBDYW5BY3RpdmF0ZSBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGUoXG4gICAgX3JvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICAgIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90XG4gICk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLmF1dGhTZXJ2aWNlLmlzQXV0aG9yaXplZCgpXG4gICAgICAucGlwZShtYXAoKGlzQXV0aG9yaXplZDogYm9vbGVhbikgPT4ge1xuICAgICAgICBpZiAoIWlzQXV0aG9yaXplZCAmJiAhdGhpcy5pc1B1YmxpY1BhZ2Uoc3RhdGUpKSB7XG4gICAgICAgICAgaWYgKHRoaXMuYXV0aFNlcnZpY2Uuc2V0SW50ZXJydXB0ZWRVcmwpIHtcbiAgICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0SW50ZXJydXB0ZWRVcmwoc3RhdGUudXJsKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICB0aGlzLm5hdmlnYXRlKHRoaXMucHVibGljRmFsbGJhY2tQYWdlVXJpKTtcblxuICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfSkpO1xuICB9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlQ2hpbGQgaGFuZGxlclxuICAgKi9cbiAgcHVibGljIGNhbkFjdGl2YXRlQ2hpbGQoXG4gICAgcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuY2FuQWN0aXZhdGUocm91dGUsIHN0YXRlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVjaywgaWYgY3VycmVudCBwYWdlIGlzIHB1YmxpYyBmYWxsYmFjayBwYWdlXG4gICAqL1xuICBwcml2YXRlIGlzUHVibGljUGFnZShzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBzdGF0ZS51cmwgPT09IHRoaXMucHVibGljRmFsbGJhY2tQYWdlVXJpO1xuICB9XG5cbiAgLyoqXG4gICAqIE5hdmlnYXRlIGF3YXkgZnJvbSB0aGUgYXBwIC8gcGF0aFxuICAgKi9cbiAgcHJpdmF0ZSBuYXZpZ2F0ZSh1cmw6IHN0cmluZyk6IHZvaWQge1xuICAgIGlmICh1cmwuc3RhcnRzV2l0aCgnaHR0cCcpKSB7XG4gICAgICB3aW5kb3cubG9jYXRpb24uaHJlZiA9IHVybDtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGVCeVVybCh1cmwpO1xuICAgIH1cbiAgfVxuXG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdGVjdGVkLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwcm90ZWN0ZWQuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsTUFBTSxFQUtQLE1BQU0saUJBQWlCLENBQUM7QUFFekIsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sVUFBVSxDQUFDOzs7Ozs7Ozs7O0FBWWxFLE1BQU0sT0FBTyxjQUFjOzs7Ozs7O0lBRXpCLFlBQytCLFdBQXdCLEVBQ1gscUJBQTZCLEVBQ3BDLFFBQWtCLEVBQzdDLE1BQWM7UUFITyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNYLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBUTtRQUNwQyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQzdDLFdBQU0sR0FBTixNQUFNLENBQVE7SUFDckIsQ0FBQzs7Ozs7OztJQUtHLFdBQVcsQ0FDaEIsTUFBOEIsRUFDOUIsS0FBMEI7UUFFMUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRTthQUNuQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsWUFBcUIsRUFBRSxFQUFFO1lBQ2xDLElBQUksQ0FBQyxZQUFZLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUM5QyxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLEVBQUU7b0JBQ3RDLElBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2lCQUMvQztnQkFFRCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2dCQUUxQyxPQUFPLEtBQUssQ0FBQzthQUNkO1lBRUQsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzs7Ozs7OztJQUtNLGdCQUFnQixDQUNyQixLQUE2QixFQUM3QixLQUEwQjtRQUUxQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7Ozs7OztJQUtPLFlBQVksQ0FBQyxLQUEwQjtRQUM3QyxPQUFPLEtBQUssQ0FBQyxHQUFHLEtBQUssSUFBSSxDQUFDLHFCQUFxQixDQUFDO0lBQ2xELENBQUM7Ozs7OztJQUtPLFFBQVEsQ0FBQyxHQUFXO1FBQzFCLElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMxQixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDO1NBQ25DO2FBQU07WUFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNoQztJQUNILENBQUM7OztZQTNERixVQUFVOzs7O1lBWkYsV0FBVyx1QkFnQmYsTUFBTSxTQUFDLFlBQVk7eUNBQ25CLE1BQU0sU0FBQyx3QkFBd0I7WUFDYSxRQUFRLHVCQUFwRCxNQUFNLFNBQUMsUUFBUTtZQTNCbEIsTUFBTTs7OztJQXlCSixxQ0FBcUQ7O0lBQ3JELCtDQUF1RTs7SUFDdkUsa0NBQXFEOztJQUNyRCxnQ0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIFJvdXRlcixcbiAgQ2FuQWN0aXZhdGUsXG4gIENhbkFjdGl2YXRlQ2hpbGQsXG4gIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gIFJvdXRlclN0YXRlU25hcHNob3Rcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuL2F1dGguc2VydmljZSc7XG5pbXBvcnQgeyBBVVRIX1NFUlZJQ0UsIFBVQkxJQ19GQUxMQkFDS19QQUdFX1VSSSB9IGZyb20gJy4vdG9rZW5zJztcblxuLyoqXG4gKiBHdWFyZCwgY2hlY2tzIGFjY2VzcyB0b2tlbiBhdmFpbGFiaWxpdHkgYW5kIGFsbG93cyBvciBkaXNhbGxvd3MgYWNjZXNzIHRvIHBhZ2UsXG4gKiBhbmQgcmVkaXJlY3RzIG91dFxuICpcbiAqIHVzYWdlOiB7IHBhdGg6ICd0ZXN0JywgY29tcG9uZW50OiBUZXN0Q29tcG9uZW50LCBjYW5BY3RpdmF0ZTogWyBBdXRoR3VhcmQgXSB9XG4gKlxuICogQGV4cG9ydFxuICogQGR5bmFtaWNcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFByb3RlY3RlZEd1YXJkIGltcGxlbWVudHMgQ2FuQWN0aXZhdGUsIENhbkFjdGl2YXRlQ2hpbGQge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoQVVUSF9TRVJWSUNFKXByaXZhdGUgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLFxuICAgIEBJbmplY3QoUFVCTElDX0ZBTExCQUNLX1BBR0VfVVJJKSBwcml2YXRlIHB1YmxpY0ZhbGxiYWNrUGFnZVVyaTogc3RyaW5nLFxuICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQ6IERvY3VtZW50LFxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBDYW5BY3RpdmF0ZSBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGUoXG4gICAgX3JvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICAgIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90XG4gICk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLmF1dGhTZXJ2aWNlLmlzQXV0aG9yaXplZCgpXG4gICAgICAucGlwZShtYXAoKGlzQXV0aG9yaXplZDogYm9vbGVhbikgPT4ge1xuICAgICAgICBpZiAoIWlzQXV0aG9yaXplZCAmJiAhdGhpcy5pc1B1YmxpY1BhZ2Uoc3RhdGUpKSB7XG4gICAgICAgICAgaWYgKHRoaXMuYXV0aFNlcnZpY2Uuc2V0SW50ZXJydXB0ZWRVcmwpIHtcbiAgICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2Uuc2V0SW50ZXJydXB0ZWRVcmwoc3RhdGUudXJsKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICB0aGlzLm5hdmlnYXRlKHRoaXMucHVibGljRmFsbGJhY2tQYWdlVXJpKTtcblxuICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfSkpO1xuICB9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlQ2hpbGQgaGFuZGxlclxuICAgKi9cbiAgcHVibGljIGNhbkFjdGl2YXRlQ2hpbGQoXG4gICAgcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuY2FuQWN0aXZhdGUocm91dGUsIHN0YXRlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVjaywgaWYgY3VycmVudCBwYWdlIGlzIHB1YmxpYyBmYWxsYmFjayBwYWdlXG4gICAqL1xuICBwcml2YXRlIGlzUHVibGljUGFnZShzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBzdGF0ZS51cmwgPT09IHRoaXMucHVibGljRmFsbGJhY2tQYWdlVXJpO1xuICB9XG5cbiAgLyoqXG4gICAqIE5hdmlnYXRlIGF3YXkgZnJvbSB0aGUgYXBwIC8gcGF0aFxuICAgKi9cbiAgcHJpdmF0ZSBuYXZpZ2F0ZSh1cmw6IHN0cmluZyk6IHZvaWQge1xuICAgIGlmICh1cmwuc3RhcnRzV2l0aCgnaHR0cCcpKSB7XG4gICAgICB0aGlzLmRvY3VtZW50LmxvY2F0aW9uLmhyZWYgPSB1cmw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwodXJsKTtcbiAgICB9XG4gIH1cblxufVxuIl19

@@ -5,2 +5,3 @@ /**

*/
import { DOCUMENT } from '@angular/common';
import { Injectable, Inject } from '@angular/core';

@@ -18,2 +19,3 @@ import { Router } from '@angular/router';

* @export
* \@dynamic
*/

@@ -24,7 +26,9 @@ export class PublicGuard {

* @param {?} protectedFallbackPageUri
* @param {?} document
* @param {?} router
*/
constructor(authService, protectedFallbackPageUri, router) {
constructor(authService, protectedFallbackPageUri, document, router) {
this.authService = authService;
this.protectedFallbackPageUri = protectedFallbackPageUri;
this.document = document;
this.router = router;

@@ -72,3 +76,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -87,2 +91,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PROTECTED_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -96,4 +101,6 @@ ];

/** @type {?} */
PublicGuard.prototype.document;
/** @type {?} */
PublicGuard.prototype.router;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwdWJsaWMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFHTCxNQUFNLEVBR1AsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7Ozs7OztBQVdyRSxNQUFNLE9BQU8sV0FBVzs7Ozs7O0lBRXRCLFlBQ2dDLFdBQXdCLEVBQ1Qsd0JBQWdDLEVBQ3JFLE1BQWM7UUFGUSxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNULDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBUTtRQUNyRSxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQ3JCLENBQUM7Ozs7Ozs7SUFLRyxXQUFXLENBQ2hCLE1BQThCLEVBQzlCLEtBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUU7YUFDbkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFlBQXFCLEVBQUUsRUFBRTtZQUNsQyxJQUFJLFlBQVksSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ2hELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLENBQUM7Z0JBRTdDLE9BQU8sS0FBSyxDQUFDO2FBQ2Q7WUFFRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDOzs7Ozs7O0lBS00sZ0JBQWdCLENBQ3JCLEtBQTZCLEVBQzdCLEtBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7Ozs7O0lBS08sZUFBZSxDQUFDLEtBQTBCO1FBQ2hELE9BQU8sS0FBSyxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMsd0JBQXdCLENBQUM7SUFDckQsQ0FBQzs7Ozs7O0lBS08sUUFBUSxDQUFDLEdBQVc7UUFDMUIsSUFBSSxHQUFHLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzFCLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztTQUM1QjthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDaEM7SUFDSCxDQUFDOzs7WUF0REYsVUFBVTs7OztZQVhGLFdBQVcsdUJBZWYsTUFBTSxTQUFDLFlBQVk7eUNBQ25CLE1BQU0sU0FBQywyQkFBMkI7WUF2QnJDLE1BQU07Ozs7SUFzQkosa0NBQXNEOztJQUN0RCwrQ0FBNkU7O0lBQzdFLDZCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQ2FuQWN0aXZhdGUsXG4gIENhbkFjdGl2YXRlQ2hpbGQsXG4gIFJvdXRlcixcbiAgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgUm91dGVyU3RhdGVTbmFwc2hvdFxufSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcbmltcG9ydCB7IEFVVEhfU0VSVklDRSwgUFJPVEVDVEVEX0ZBTExCQUNLX1BBR0VfVVJJIH0gZnJvbSAnLi90b2tlbnMnO1xuXG4vKipcbiAqIEd1YXJkLCBjaGVja3MgYWNjZXNzIHRva2VuIGF2YWlsYWJpbGl0eSBhbmQgYWxsb3dzIG9yIGRpc2FsbG93cyBhY2Nlc3MgdG8gcGFnZSxcbiAqIGFuZCByZWRpcmVjdHMgb3V0XG4gKlxuICogdXNhZ2U6IHsgcGF0aDogJ3Rlc3QnLCBjb21wb25lbnQ6IFRlc3RDb21wb25lbnQsIGNhbkFjdGl2YXRlOiBbIFB1YmxpY0d1YXJkIF0gfVxuICpcbiAqIEBleHBvcnRcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFB1YmxpY0d1YXJkIGltcGxlbWVudHMgQ2FuQWN0aXZhdGUsIENhbkFjdGl2YXRlQ2hpbGQge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoQVVUSF9TRVJWSUNFKSBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxcbiAgICBASW5qZWN0KFBST1RFQ1RFRF9GQUxMQkFDS19QQUdFX1VSSSkgcHJpdmF0ZSBwcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmk6IHN0cmluZyxcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyXG4gICkge31cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGUgaGFuZGxlclxuICAgKi9cbiAgcHVibGljIGNhbkFjdGl2YXRlKFxuICAgIF9yb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5pc0F1dGhvcml6ZWQoKVxuICAgICAgLnBpcGUobWFwKChpc0F1dGhvcml6ZWQ6IGJvb2xlYW4pID0+IHtcbiAgICAgICAgaWYgKGlzQXV0aG9yaXplZCAmJiAhdGhpcy5pc1Byb3RlY3RlZFBhZ2Uoc3RhdGUpKSB7XG4gICAgICAgICAgdGhpcy5uYXZpZ2F0ZSh0aGlzLnByb3RlY3RlZEZhbGxiYWNrUGFnZVVyaSk7XG5cbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH0pKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYW5BY3RpdmF0ZUNoaWxkIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZUNoaWxkKFxuICAgIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICAgIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90XG4gICk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLmNhbkFjdGl2YXRlKHJvdXRlLCBzdGF0ZSk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2ssIGlmIGN1cnJlbnQgcGFnZSBpcyBwcm90ZWN0ZWQgZmFsbGJhY2sgcGFnZVxuICAgKi9cbiAgcHJpdmF0ZSBpc1Byb3RlY3RlZFBhZ2Uoc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3QpOiBib29sZWFuIHtcbiAgICByZXR1cm4gc3RhdGUudXJsID09PSB0aGlzLnByb3RlY3RlZEZhbGxiYWNrUGFnZVVyaTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOYXZpZ2F0ZSBhd2F5IGZyb20gdGhlIGFwcCAvIHBhdGhcbiAgICovXG4gIHByaXZhdGUgbmF2aWdhdGUodXJsOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAodXJsLnN0YXJ0c1dpdGgoJ2h0dHAnKSkge1xuICAgICAgd2luZG93LmxvY2F0aW9uLmhyZWYgPSB1cmw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwodXJsKTtcbiAgICB9XG4gIH1cblxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwdWJsaWMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBR0wsTUFBTSxFQUdQLE1BQU0saUJBQWlCLENBQUM7QUFFekIsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLDJCQUEyQixFQUFFLE1BQU0sVUFBVSxDQUFDOzs7Ozs7Ozs7O0FBWXJFLE1BQU0sT0FBTyxXQUFXOzs7Ozs7O0lBRXRCLFlBQ2dDLFdBQXdCLEVBQ1Qsd0JBQWdDLEVBQzFDLFFBQWtCLEVBQzdDLE1BQWM7UUFIUSxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNULDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBUTtRQUMxQyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQzdDLFdBQU0sR0FBTixNQUFNLENBQVE7SUFDckIsQ0FBQzs7Ozs7OztJQUtHLFdBQVcsQ0FDaEIsTUFBOEIsRUFDOUIsS0FBMEI7UUFFMUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRTthQUNuQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsWUFBcUIsRUFBRSxFQUFFO1lBQ2xDLElBQUksWUFBWSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDaEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsQ0FBQztnQkFFN0MsT0FBTyxLQUFLLENBQUM7YUFDZDtZQUVELE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7Ozs7Ozs7SUFLTSxnQkFBZ0IsQ0FDckIsS0FBNkIsRUFDN0IsS0FBMEI7UUFFMUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN4QyxDQUFDOzs7Ozs7SUFLTyxlQUFlLENBQUMsS0FBMEI7UUFDaEQsT0FBTyxLQUFLLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyx3QkFBd0IsQ0FBQztJQUNyRCxDQUFDOzs7Ozs7SUFLTyxRQUFRLENBQUMsR0FBVztRQUMxQixJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDMUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztTQUNuQzthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDaEM7SUFDSCxDQUFDOzs7WUF2REYsVUFBVTs7OztZQVpGLFdBQVcsdUJBZ0JmLE1BQU0sU0FBQyxZQUFZO3lDQUNuQixNQUFNLFNBQUMsMkJBQTJCO1lBQ1UsUUFBUSx1QkFBcEQsTUFBTSxTQUFDLFFBQVE7WUF6QmxCLE1BQU07Ozs7SUF1Qkosa0NBQXNEOztJQUN0RCwrQ0FBNkU7O0lBQzdFLCtCQUFxRDs7SUFDckQsNkJBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRE9DVU1FTlQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBDYW5BY3RpdmF0ZSxcbiAgQ2FuQWN0aXZhdGVDaGlsZCxcbiAgUm91dGVyLFxuICBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICBSb3V0ZXJTdGF0ZVNuYXBzaG90XG59IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IEF1dGhTZXJ2aWNlIH0gZnJvbSAnLi9hdXRoLnNlcnZpY2UnO1xuaW1wb3J0IHsgQVVUSF9TRVJWSUNFLCBQUk9URUNURURfRkFMTEJBQ0tfUEFHRV9VUkkgfSBmcm9tICcuL3Rva2Vucyc7XG5cbi8qKlxuICogR3VhcmQsIGNoZWNrcyBhY2Nlc3MgdG9rZW4gYXZhaWxhYmlsaXR5IGFuZCBhbGxvd3Mgb3IgZGlzYWxsb3dzIGFjY2VzcyB0byBwYWdlLFxuICogYW5kIHJlZGlyZWN0cyBvdXRcbiAqXG4gKiB1c2FnZTogeyBwYXRoOiAndGVzdCcsIGNvbXBvbmVudDogVGVzdENvbXBvbmVudCwgY2FuQWN0aXZhdGU6IFsgUHVibGljR3VhcmQgXSB9XG4gKlxuICogQGV4cG9ydFxuICogQGR5bmFtaWNcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFB1YmxpY0d1YXJkIGltcGxlbWVudHMgQ2FuQWN0aXZhdGUsIENhbkFjdGl2YXRlQ2hpbGQge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoQVVUSF9TRVJWSUNFKSBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRoU2VydmljZSxcbiAgICBASW5qZWN0KFBST1RFQ1RFRF9GQUxMQkFDS19QQUdFX1VSSSkgcHJpdmF0ZSBwcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmk6IHN0cmluZyxcbiAgICBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIHJlYWRvbmx5IGRvY3VtZW50OiBEb2N1bWVudCxcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyXG4gICkge31cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGUgaGFuZGxlclxuICAgKi9cbiAgcHVibGljIGNhbkFjdGl2YXRlKFxuICAgIF9yb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5pc0F1dGhvcml6ZWQoKVxuICAgICAgLnBpcGUobWFwKChpc0F1dGhvcml6ZWQ6IGJvb2xlYW4pID0+IHtcbiAgICAgICAgaWYgKGlzQXV0aG9yaXplZCAmJiAhdGhpcy5pc1Byb3RlY3RlZFBhZ2Uoc3RhdGUpKSB7XG4gICAgICAgICAgdGhpcy5uYXZpZ2F0ZSh0aGlzLnByb3RlY3RlZEZhbGxiYWNrUGFnZVVyaSk7XG5cbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH0pKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYW5BY3RpdmF0ZUNoaWxkIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZUNoaWxkKFxuICAgIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LFxuICAgIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90XG4gICk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLmNhbkFjdGl2YXRlKHJvdXRlLCBzdGF0ZSk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2ssIGlmIGN1cnJlbnQgcGFnZSBpcyBwcm90ZWN0ZWQgZmFsbGJhY2sgcGFnZVxuICAgKi9cbiAgcHJpdmF0ZSBpc1Byb3RlY3RlZFBhZ2Uoc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3QpOiBib29sZWFuIHtcbiAgICByZXR1cm4gc3RhdGUudXJsID09PSB0aGlzLnByb3RlY3RlZEZhbGxiYWNrUGFnZVVyaTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOYXZpZ2F0ZSBhd2F5IGZyb20gdGhlIGFwcCAvIHBhdGhcbiAgICovXG4gIHByaXZhdGUgbmF2aWdhdGUodXJsOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAodXJsLnN0YXJ0c1dpdGgoJ2h0dHAnKSkge1xuICAgICAgdGhpcy5kb2N1bWVudC5sb2NhdGlvbi5ocmVmID0gdXJsO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKHVybCk7XG4gICAgfVxuICB9XG5cbn1cbiJdfQ==

@@ -108,3 +108,3 @@ /**

/** @type {?} */
var refreshShouldHappen = authService.refreshShouldHappen(res);
var refreshShouldHappen = authService.refreshShouldHappen(res, req);
if (refreshShouldHappen && !this.refreshInProgress) {

@@ -282,2 +282,2 @@ this.refreshInProgress = true;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"ng://ngx-auth/","sources":["auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"ng://ngx-auth/","sources":["auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res, req);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n"]}

@@ -54,5 +54,6 @@ /**

* @param {?} response
* @param {?=} request
* @return {?}
*/
AuthService.prototype.refreshShouldHappen = function (response) { };
AuthService.prototype.refreshShouldHappen = function (response, request) { };
/**

@@ -103,2 +104,2 @@ * Verify that outgoing request is refresh-token,

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJhdXRoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFNQTs7Ozs7SUFBQTtJQStEQSxDQUFDO0lBQUQsa0JBQUM7QUFBRCxDQUFDLEFBL0RELElBK0RDOzs7Ozs7Ozs7Ozs7O0lBekRDLHFEQUFvRDs7Ozs7Ozs7SUFPcEQsdURBQXFEOzs7Ozs7OztJQU9yRCxxREFBZ0Q7Ozs7Ozs7Ozs7SUFRaEQsb0VBQTBFOzs7Ozs7OztJQU0xRSxrRUFBd0U7Ozs7Ozs7O0lBTXhFLDJEQUFpRTs7Ozs7Ozs7OztJQVFqRSx3REFBa0Y7Ozs7Ozs7O0lBTWxGLDZEQUFzRDs7Ozs7Ozs7OztJQVF0RCw4REFBMEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwUmVxdWVzdCwgSHR0cEVycm9yUmVzcG9uc2UgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbi8qKlxuICogRXNzZW50aWFsIHNlcnZpY2UgZm9yIGF1dGhlbnRpY2F0aW9uXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBdXRoU2VydmljZSB7XG5cbiAgLyoqXG4gICAqIENoZWNrLCBpZiB1c2VyIGFscmVhZHkgYXV0aG9yaXplZC5cbiAgICogU2hvdWxkIHJldHVybiBPYnNlcnZhYmxlIHdpdGggdHJ1ZSBvciBmYWxzZSB2YWx1ZXNcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBpc0F1dGhvcml6ZWQoKTogT2JzZXJ2YWJsZTxib29sZWFuPjtcblxuICAvKipcbiAgICogR2V0IGFjY2VzcyB0b2tlblxuICAgKiBTaG91bGQgcmV0dXJuIGFjY2VzcyB0b2tlbiBpbiBPYnNlcnZhYmxlIGZyb20gZS5nLlxuICAgKiBsb2NhbFN0b3JhZ2VcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBnZXRBY2Nlc3NUb2tlbigpOiBPYnNlcnZhYmxlPHN0cmluZz47XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uLCB0aGF0IHNob3VsZCBwZXJmb3JtIHJlZnJlc2ggdG9rZW5cbiAgICogU2hvdWxkIGJlIHN1Y2Nlc3NmdWxseSBjb21wbGV0ZWQgc28gaW50ZXJjZXB0b3JcbiAgICogY2FuIGV4ZWN1dGUgcGVuZGluZyByZXF1ZXN0cyBvciByZXRyeSBvcmlnaW5hbCBvbmVcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCByZWZyZXNoVG9rZW4oKTogT2JzZXJ2YWJsZTxhbnk+O1xuXG4gIC8qKlxuICAgKiBGdW5jdGlvbiwgY2hlY2tzIHJlc3BvbnNlIG9mIGZhaWxlZCByZXF1ZXN0IHRvIGRldGVybWluZSxcbiAgICogd2hldGhlciB0b2tlbiBiZSByZWZyZXNoZWQgb3Igbm90LlxuICAgKlxuICAgKiBFc3NlbnRpYWxseSBjaGVja3Mgc3RhdHVzXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgcmVmcmVzaFNob3VsZEhhcHBlbihyZXNwb25zZTogSHR0cEVycm9yUmVzcG9uc2UpOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBWZXJpZnkgdGhhdCBvdXRnb2luZyByZXF1ZXN0IGlzIHJlZnJlc2gtdG9rZW4sXG4gICAqIHNvIGludGVyY2VwdG9yIHdvbid0IGludGVyY2VwdCB0aGlzIHJlcXVlc3RcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCB2ZXJpZnlSZWZyZXNoVG9rZW4/KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4pOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgcmVxdWVzdCBtdXN0IGJlIHNraXBwZWQgYnkgaW50ZXJjZXB0b3IuXG4gICAqIFVzZWZ1bCBmb3IgcmVxdWVzdHMgc3VjaCBhcyByZXF1ZXN0IHRva2VuIHdoaWNoIGRvZXNuJ3QgcmVxdWlyZSB0b2tlbiBpbiBoZWFkZXJzXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3Qgc2tpcFJlcXVlc3Q/KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4pOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBBZGQgdG9rZW4gdG8gaGVhZGVycywgZGVwZW5kZW50IG9uIHNlcnZlclxuICAgKiBzZXQtdXAsIGJ5IGRlZmF1bHQgYWRkcyBhIGJlYXJlciB0b2tlbi5cbiAgICogQ2FsbGVkIGJ5IGludGVyY2VwdG9yLlxuICAgKiBUbyBjaGFuZ2UgYmVoYXZpb3IsIG92ZXJyaWRlIHRoaXMgbWV0aG9kLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGdldEhlYWRlcnM/KHRva2VuOiBzdHJpbmcpOiB7IFtuYW1lOiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB9O1xuXG4gIC8qKlxuICAgKiBTYXZlcyBsYXN0IGludGVycnVwdGVkIHVybCBpbnNpZGUgb2YgdGhlIHNlcnZpY2UgZm9yIGZ1cnRoZXIgcmV1c2FnZSxcbiAgICogZS5nLiByZXN0b3JpbmcgaW50ZXJydXB0ZWQgcGFnZSBhZnRlciBsb2dnaW5nIGluXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3Qgc2V0SW50ZXJydXB0ZWRVcmw/KHVybDogc3RyaW5nKTogdm9pZDtcblxuICAvKipcbiAgICogVmVyaWZ5IHRoYXQgb3V0Z29pbmcgcmVxdWVzdCBpcyByZWZyZXNoLXRva2VuLFxuICAgKiBzbyBpbnRlcmNlcHRvciB3b24ndCBpbnRlcmNlcHQgdGhpcyByZXF1ZXN0XG4gICAqIEBkZXByZWNhdGVkIER1ZSB0byBpbGxvZ2ljYWwgbWVhbmluZy9mdW5jdGlvbmFsaXR5IHRoaXMgbWV0aG9kIGlzIGRlcHJlY2F0ZWRcbiAgICogQHNlZSB2ZXJpZnlSZWZyZXNoVG9rZW5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCB2ZXJpZnlUb2tlblJlcXVlc3Q/KHVybDogc3RyaW5nKTogYm9vbGVhbjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJhdXRoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFNQTs7Ozs7SUFBQTtJQStEQSxDQUFDO0lBQUQsa0JBQUM7QUFBRCxDQUFDLEFBL0RELElBK0RDOzs7Ozs7Ozs7Ozs7O0lBekRDLHFEQUFvRDs7Ozs7Ozs7SUFPcEQsdURBQXFEOzs7Ozs7OztJQU9yRCxxREFBZ0Q7Ozs7Ozs7Ozs7O0lBUWhELDZFQUFzRzs7Ozs7Ozs7SUFNdEcsa0VBQXdFOzs7Ozs7OztJQU14RSwyREFBaUU7Ozs7Ozs7Ozs7SUFRakUsd0RBQWtGOzs7Ozs7OztJQU1sRiw2REFBc0Q7Ozs7Ozs7Ozs7SUFRdEQsOERBQTBEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cFJlcXVlc3QsIEh0dHBFcnJvclJlc3BvbnNlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG4vKipcbiAqIEVzc2VudGlhbCBzZXJ2aWNlIGZvciBhdXRoZW50aWNhdGlvblxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQXV0aFNlcnZpY2Uge1xuXG4gIC8qKlxuICAgKiBDaGVjaywgaWYgdXNlciBhbHJlYWR5IGF1dGhvcml6ZWQuXG4gICAqIFNob3VsZCByZXR1cm4gT2JzZXJ2YWJsZSB3aXRoIHRydWUgb3IgZmFsc2UgdmFsdWVzXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgaXNBdXRob3JpemVkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgLyoqXG4gICAqIEdldCBhY2Nlc3MgdG9rZW5cbiAgICogU2hvdWxkIHJldHVybiBhY2Nlc3MgdG9rZW4gaW4gT2JzZXJ2YWJsZSBmcm9tIGUuZy5cbiAgICogbG9jYWxTdG9yYWdlXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0QWNjZXNzVG9rZW4oKTogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBGdW5jdGlvbiwgdGhhdCBzaG91bGQgcGVyZm9ybSByZWZyZXNoIHRva2VuXG4gICAqIFNob3VsZCBiZSBzdWNjZXNzZnVsbHkgY29tcGxldGVkIHNvIGludGVyY2VwdG9yXG4gICAqIGNhbiBleGVjdXRlIHBlbmRpbmcgcmVxdWVzdHMgb3IgcmV0cnkgb3JpZ2luYWwgb25lXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgcmVmcmVzaFRva2VuKCk6IE9ic2VydmFibGU8YW55PjtcblxuICAvKipcbiAgICogRnVuY3Rpb24sIGNoZWNrcyByZXNwb25zZSBvZiBmYWlsZWQgcmVxdWVzdCB0byBkZXRlcm1pbmUsXG4gICAqIHdoZXRoZXIgdG9rZW4gYmUgcmVmcmVzaGVkIG9yIG5vdC5cbiAgICpcbiAgICogRXNzZW50aWFsbHkgY2hlY2tzIHN0YXR1c1xuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHJlZnJlc2hTaG91bGRIYXBwZW4ocmVzcG9uc2U6IEh0dHBFcnJvclJlc3BvbnNlLCByZXF1ZXN0PzogSHR0cFJlcXVlc3Q8YW55Pik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFZlcmlmeSB0aGF0IG91dGdvaW5nIHJlcXVlc3QgaXMgcmVmcmVzaC10b2tlbixcbiAgICogc28gaW50ZXJjZXB0b3Igd29uJ3QgaW50ZXJjZXB0IHRoaXMgcmVxdWVzdFxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHZlcmlmeVJlZnJlc2hUb2tlbj8ocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55Pik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiByZXF1ZXN0IG11c3QgYmUgc2tpcHBlZCBieSBpbnRlcmNlcHRvci5cbiAgICogVXNlZnVsIGZvciByZXF1ZXN0cyBzdWNoIGFzIHJlcXVlc3QgdG9rZW4gd2hpY2ggZG9lc24ndCByZXF1aXJlIHRva2VuIGluIGhlYWRlcnNcbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBza2lwUmVxdWVzdD8ocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55Pik6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEFkZCB0b2tlbiB0byBoZWFkZXJzLCBkZXBlbmRlbnQgb24gc2VydmVyXG4gICAqIHNldC11cCwgYnkgZGVmYXVsdCBhZGRzIGEgYmVhcmVyIHRva2VuLlxuICAgKiBDYWxsZWQgYnkgaW50ZXJjZXB0b3IuXG4gICAqIFRvIGNoYW5nZSBiZWhhdmlvciwgb3ZlcnJpZGUgdGhpcyBtZXRob2QuXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0SGVhZGVycz8odG9rZW46IHN0cmluZyk6IHsgW25hbWU6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdIH07XG5cbiAgLyoqXG4gICAqIFNhdmVzIGxhc3QgaW50ZXJydXB0ZWQgdXJsIGluc2lkZSBvZiB0aGUgc2VydmljZSBmb3IgZnVydGhlciByZXVzYWdlLFxuICAgKiBlLmcuIHJlc3RvcmluZyBpbnRlcnJ1cHRlZCBwYWdlIGFmdGVyIGxvZ2dpbmcgaW5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBzZXRJbnRlcnJ1cHRlZFVybD8odXJsOiBzdHJpbmcpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBWZXJpZnkgdGhhdCBvdXRnb2luZyByZXF1ZXN0IGlzIHJlZnJlc2gtdG9rZW4sXG4gICAqIHNvIGludGVyY2VwdG9yIHdvbid0IGludGVyY2VwdCB0aGlzIHJlcXVlc3RcbiAgICogQGRlcHJlY2F0ZWQgRHVlIHRvIGlsbG9naWNhbCBtZWFuaW5nL2Z1bmN0aW9uYWxpdHkgdGhpcyBtZXRob2QgaXMgZGVwcmVjYXRlZFxuICAgKiBAc2VlIHZlcmlmeVJlZnJlc2hUb2tlblxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHZlcmlmeVRva2VuUmVxdWVzdD8odXJsOiBzdHJpbmcpOiBib29sZWFuO1xufVxuIl19

@@ -5,2 +5,3 @@ /**

*/
import { DOCUMENT } from '@angular/common';
import { Injectable, Inject } from '@angular/core';

@@ -18,7 +19,9 @@ import { Router } from '@angular/router';

* @export
* \@dynamic
*/
var ProtectedGuard = /** @class */ (function () {
function ProtectedGuard(authService, publicFallbackPageUri, router) {
function ProtectedGuard(authService, publicFallbackPageUri, document, router) {
this.authService = authService;
this.publicFallbackPageUri = publicFallbackPageUri;
this.document = document;
this.router = router;

@@ -104,3 +107,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -118,2 +121,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PUBLIC_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -130,4 +134,6 @@ ]; };

/** @type {?} */
ProtectedGuard.prototype.document;
/** @type {?} */
ProtectedGuard.prototype.router;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdGVjdGVkLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwcm90ZWN0ZWQuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFDTCxNQUFNLEVBS1AsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7Ozs7OztBQVVsRTtJQUdFLHdCQUMrQixXQUF3QixFQUNYLHFCQUE2QixFQUMvRCxNQUFjO1FBRk8sZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDWCwwQkFBcUIsR0FBckIscUJBQXFCLENBQVE7UUFDL0QsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUNyQixDQUFDO0lBRUo7O09BRUc7Ozs7Ozs7SUFDSSxvQ0FBVzs7Ozs7O0lBQWxCLFVBQ0UsTUFBOEIsRUFDOUIsS0FBMEI7UUFGNUIsaUJBa0JDO1FBZEMsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRTthQUNuQyxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQUMsWUFBcUI7WUFDOUIsSUFBSSxDQUFDLFlBQVksSUFBSSxDQUFDLEtBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzlDLElBQUksS0FBSSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsRUFBRTtvQkFDdEMsS0FBSSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQy9DO2dCQUVELEtBQUksQ0FBQyxRQUFRLENBQUMsS0FBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7Z0JBRTFDLE9BQU8sS0FBSyxDQUFDO2FBQ2Q7WUFFRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDO0lBRUQ7O09BRUc7Ozs7Ozs7SUFDSSx5Q0FBZ0I7Ozs7OztJQUF2QixVQUNFLEtBQTZCLEVBQzdCLEtBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVEOztPQUVHOzs7Ozs7SUFDSyxxQ0FBWTs7Ozs7SUFBcEIsVUFBcUIsS0FBMEI7UUFDN0MsT0FBTyxLQUFLLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztJQUNsRCxDQUFDO0lBRUQ7O09BRUc7Ozs7OztJQUNLLGlDQUFROzs7OztJQUFoQixVQUFpQixHQUFXO1FBQzFCLElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMxQixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxHQUFHLENBQUM7U0FDNUI7YUFBTTtZQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ2hDO0lBQ0gsQ0FBQzs7Z0JBMURGLFVBQVU7Ozs7Z0JBWEYsV0FBVyx1QkFlZixNQUFNLFNBQUMsWUFBWTs2Q0FDbkIsTUFBTSxTQUFDLHdCQUF3QjtnQkF6QmxDLE1BQU07O0lBZ0ZSLHFCQUFDO0NBQUEsQUE1REQsSUE0REM7U0EzRFksY0FBYzs7O0lBR3ZCLHFDQUFxRDs7SUFDckQsK0NBQXVFOztJQUN2RSxnQ0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIFJvdXRlcixcbiAgQ2FuQWN0aXZhdGUsXG4gIENhbkFjdGl2YXRlQ2hpbGQsXG4gIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gIFJvdXRlclN0YXRlU25hcHNob3Rcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuL2F1dGguc2VydmljZSc7XG5pbXBvcnQgeyBBVVRIX1NFUlZJQ0UsIFBVQkxJQ19GQUxMQkFDS19QQUdFX1VSSSB9IGZyb20gJy4vdG9rZW5zJztcblxuLyoqXG4gKiBHdWFyZCwgY2hlY2tzIGFjY2VzcyB0b2tlbiBhdmFpbGFiaWxpdHkgYW5kIGFsbG93cyBvciBkaXNhbGxvd3MgYWNjZXNzIHRvIHBhZ2UsXG4gKiBhbmQgcmVkaXJlY3RzIG91dFxuICpcbiAqIHVzYWdlOiB7IHBhdGg6ICd0ZXN0JywgY29tcG9uZW50OiBUZXN0Q29tcG9uZW50LCBjYW5BY3RpdmF0ZTogWyBBdXRoR3VhcmQgXSB9XG4gKlxuICogQGV4cG9ydFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgUHJvdGVjdGVkR3VhcmQgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSwgQ2FuQWN0aXZhdGVDaGlsZCB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChBVVRIX1NFUlZJQ0UpcHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgQEluamVjdChQVUJMSUNfRkFMTEJBQ0tfUEFHRV9VUkkpIHByaXZhdGUgcHVibGljRmFsbGJhY2tQYWdlVXJpOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxuICApIHt9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZShcbiAgICBfcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aFNlcnZpY2UuaXNBdXRob3JpemVkKClcbiAgICAgIC5waXBlKG1hcCgoaXNBdXRob3JpemVkOiBib29sZWFuKSA9PiB7XG4gICAgICAgIGlmICghaXNBdXRob3JpemVkICYmICF0aGlzLmlzUHVibGljUGFnZShzdGF0ZSkpIHtcbiAgICAgICAgICBpZiAodGhpcy5hdXRoU2VydmljZS5zZXRJbnRlcnJ1cHRlZFVybCkge1xuICAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5zZXRJbnRlcnJ1cHRlZFVybChzdGF0ZS51cmwpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHRoaXMubmF2aWdhdGUodGhpcy5wdWJsaWNGYWxsYmFja1BhZ2VVcmkpO1xuXG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGVDaGlsZCBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGVDaGlsZChcbiAgICByb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5jYW5BY3RpdmF0ZShyb3V0ZSwgc3RhdGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrLCBpZiBjdXJyZW50IHBhZ2UgaXMgcHVibGljIGZhbGxiYWNrIHBhZ2VcbiAgICovXG4gIHByaXZhdGUgaXNQdWJsaWNQYWdlKHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHN0YXRlLnVybCA9PT0gdGhpcy5wdWJsaWNGYWxsYmFja1BhZ2VVcmk7XG4gIH1cblxuICAvKipcbiAgICogTmF2aWdhdGUgYXdheSBmcm9tIHRoZSBhcHAgLyBwYXRoXG4gICAqL1xuICBwcml2YXRlIG5hdmlnYXRlKHVybDogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKHVybC5zdGFydHNXaXRoKCdodHRwJykpIHtcbiAgICAgIHdpbmRvdy5sb2NhdGlvbi5ocmVmID0gdXJsO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKHVybCk7XG4gICAgfVxuICB9XG5cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdGVjdGVkLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwcm90ZWN0ZWQuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsTUFBTSxFQUtQLE1BQU0saUJBQWlCLENBQUM7QUFFekIsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sVUFBVSxDQUFDOzs7Ozs7Ozs7O0FBV2xFO0lBR0Usd0JBQytCLFdBQXdCLEVBQ1gscUJBQTZCLEVBQ3BDLFFBQWtCLEVBQzdDLE1BQWM7UUFITyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNYLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBUTtRQUNwQyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQzdDLFdBQU0sR0FBTixNQUFNLENBQVE7SUFDckIsQ0FBQztJQUVKOztPQUVHOzs7Ozs7O0lBQ0ksb0NBQVc7Ozs7OztJQUFsQixVQUNFLE1BQThCLEVBQzlCLEtBQTBCO1FBRjVCLGlCQWtCQztRQWRDLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUU7YUFDbkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxVQUFDLFlBQXFCO1lBQzlCLElBQUksQ0FBQyxZQUFZLElBQUksQ0FBQyxLQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUM5QyxJQUFJLEtBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLEVBQUU7b0JBQ3RDLEtBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2lCQUMvQztnQkFFRCxLQUFJLENBQUMsUUFBUSxDQUFDLEtBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2dCQUUxQyxPQUFPLEtBQUssQ0FBQzthQUNkO1lBRUQsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztJQUVEOztPQUVHOzs7Ozs7O0lBQ0kseUNBQWdCOzs7Ozs7SUFBdkIsVUFDRSxLQUE2QixFQUM3QixLQUEwQjtRQUUxQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRDs7T0FFRzs7Ozs7O0lBQ0sscUNBQVk7Ozs7O0lBQXBCLFVBQXFCLEtBQTBCO1FBQzdDLE9BQU8sS0FBSyxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMscUJBQXFCLENBQUM7SUFDbEQsQ0FBQztJQUVEOztPQUVHOzs7Ozs7SUFDSyxpQ0FBUTs7Ozs7SUFBaEIsVUFBaUIsR0FBVztRQUMxQixJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDMUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztTQUNuQzthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDaEM7SUFDSCxDQUFDOztnQkEzREYsVUFBVTs7OztnQkFaRixXQUFXLHVCQWdCZixNQUFNLFNBQUMsWUFBWTs2Q0FDbkIsTUFBTSxTQUFDLHdCQUF3QjtnQkFDYSxRQUFRLHVCQUFwRCxNQUFNLFNBQUMsUUFBUTtnQkEzQmxCLE1BQU07O0lBa0ZSLHFCQUFDO0NBQUEsQUE3REQsSUE2REM7U0E1RFksY0FBYzs7O0lBR3ZCLHFDQUFxRDs7SUFDckQsK0NBQXVFOztJQUN2RSxrQ0FBcUQ7O0lBQ3JELGdDQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdGFibGUsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgUm91dGVyLFxuICBDYW5BY3RpdmF0ZSxcbiAgQ2FuQWN0aXZhdGVDaGlsZCxcbiAgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgUm91dGVyU3RhdGVTbmFwc2hvdFxufSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcbmltcG9ydCB7IEFVVEhfU0VSVklDRSwgUFVCTElDX0ZBTExCQUNLX1BBR0VfVVJJIH0gZnJvbSAnLi90b2tlbnMnO1xuXG4vKipcbiAqIEd1YXJkLCBjaGVja3MgYWNjZXNzIHRva2VuIGF2YWlsYWJpbGl0eSBhbmQgYWxsb3dzIG9yIGRpc2FsbG93cyBhY2Nlc3MgdG8gcGFnZSxcbiAqIGFuZCByZWRpcmVjdHMgb3V0XG4gKlxuICogdXNhZ2U6IHsgcGF0aDogJ3Rlc3QnLCBjb21wb25lbnQ6IFRlc3RDb21wb25lbnQsIGNhbkFjdGl2YXRlOiBbIEF1dGhHdWFyZCBdIH1cbiAqXG4gKiBAZXhwb3J0XG4gKiBAZHluYW1pY1xuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgUHJvdGVjdGVkR3VhcmQgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSwgQ2FuQWN0aXZhdGVDaGlsZCB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChBVVRIX1NFUlZJQ0UpcHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgQEluamVjdChQVUJMSUNfRkFMTEJBQ0tfUEFHRV9VUkkpIHByaXZhdGUgcHVibGljRmFsbGJhY2tQYWdlVXJpOiBzdHJpbmcsXG4gICAgQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudDogRG9jdW1lbnQsXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxuICApIHt9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZShcbiAgICBfcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aFNlcnZpY2UuaXNBdXRob3JpemVkKClcbiAgICAgIC5waXBlKG1hcCgoaXNBdXRob3JpemVkOiBib29sZWFuKSA9PiB7XG4gICAgICAgIGlmICghaXNBdXRob3JpemVkICYmICF0aGlzLmlzUHVibGljUGFnZShzdGF0ZSkpIHtcbiAgICAgICAgICBpZiAodGhpcy5hdXRoU2VydmljZS5zZXRJbnRlcnJ1cHRlZFVybCkge1xuICAgICAgICAgICAgdGhpcy5hdXRoU2VydmljZS5zZXRJbnRlcnJ1cHRlZFVybChzdGF0ZS51cmwpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHRoaXMubmF2aWdhdGUodGhpcy5wdWJsaWNGYWxsYmFja1BhZ2VVcmkpO1xuXG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGVDaGlsZCBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGVDaGlsZChcbiAgICByb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5jYW5BY3RpdmF0ZShyb3V0ZSwgc3RhdGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrLCBpZiBjdXJyZW50IHBhZ2UgaXMgcHVibGljIGZhbGxiYWNrIHBhZ2VcbiAgICovXG4gIHByaXZhdGUgaXNQdWJsaWNQYWdlKHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHN0YXRlLnVybCA9PT0gdGhpcy5wdWJsaWNGYWxsYmFja1BhZ2VVcmk7XG4gIH1cblxuICAvKipcbiAgICogTmF2aWdhdGUgYXdheSBmcm9tIHRoZSBhcHAgLyBwYXRoXG4gICAqL1xuICBwcml2YXRlIG5hdmlnYXRlKHVybDogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKHVybC5zdGFydHNXaXRoKCdodHRwJykpIHtcbiAgICAgIHRoaXMuZG9jdW1lbnQubG9jYXRpb24uaHJlZiA9IHVybDtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGVCeVVybCh1cmwpO1xuICAgIH1cbiAgfVxuXG59XG4iXX0=

@@ -5,2 +5,3 @@ /**

*/
import { DOCUMENT } from '@angular/common';
import { Injectable, Inject } from '@angular/core';

@@ -18,7 +19,9 @@ import { Router } from '@angular/router';

* @export
* \@dynamic
*/
var PublicGuard = /** @class */ (function () {
function PublicGuard(authService, protectedFallbackPageUri, router) {
function PublicGuard(authService, protectedFallbackPageUri, document, router) {
this.authService = authService;
this.protectedFallbackPageUri = protectedFallbackPageUri;
this.document = document;
this.router = router;

@@ -101,3 +104,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -115,2 +118,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PROTECTED_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -127,4 +131,6 @@ ]; };

/** @type {?} */
PublicGuard.prototype.document;
/** @type {?} */
PublicGuard.prototype.router;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwdWJsaWMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFHTCxNQUFNLEVBR1AsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7Ozs7OztBQVVyRTtJQUdFLHFCQUNnQyxXQUF3QixFQUNULHdCQUFnQyxFQUNyRSxNQUFjO1FBRlEsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDVCw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQVE7UUFDckUsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUNyQixDQUFDO0lBRUo7O09BRUc7Ozs7Ozs7SUFDSSxpQ0FBVzs7Ozs7O0lBQWxCLFVBQ0UsTUFBOEIsRUFDOUIsS0FBMEI7UUFGNUIsaUJBY0M7UUFWQyxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFO2FBQ25DLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBQyxZQUFxQjtZQUM5QixJQUFJLFlBQVksSUFBSSxDQUFDLEtBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ2hELEtBQUksQ0FBQyxRQUFRLENBQUMsS0FBSSxDQUFDLHdCQUF3QixDQUFDLENBQUM7Z0JBRTdDLE9BQU8sS0FBSyxDQUFDO2FBQ2Q7WUFFRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDO0lBRUQ7O09BRUc7Ozs7Ozs7SUFDSSxzQ0FBZ0I7Ozs7OztJQUF2QixVQUNFLEtBQTZCLEVBQzdCLEtBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVEOztPQUVHOzs7Ozs7SUFDSyxxQ0FBZTs7Ozs7SUFBdkIsVUFBd0IsS0FBMEI7UUFDaEQsT0FBTyxLQUFLLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyx3QkFBd0IsQ0FBQztJQUNyRCxDQUFDO0lBRUQ7O09BRUc7Ozs7OztJQUNLLDhCQUFROzs7OztJQUFoQixVQUFpQixHQUFXO1FBQzFCLElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMxQixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxHQUFHLENBQUM7U0FDNUI7YUFBTTtZQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ2hDO0lBQ0gsQ0FBQzs7Z0JBdERGLFVBQVU7Ozs7Z0JBWEYsV0FBVyx1QkFlZixNQUFNLFNBQUMsWUFBWTs2Q0FDbkIsTUFBTSxTQUFDLDJCQUEyQjtnQkF2QnJDLE1BQU07O0lBMEVSLGtCQUFDO0NBQUEsQUF4REQsSUF3REM7U0F2RFksV0FBVzs7O0lBR3BCLGtDQUFzRDs7SUFDdEQsK0NBQTZFOztJQUM3RSw2QkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIENhbkFjdGl2YXRlLFxuICBDYW5BY3RpdmF0ZUNoaWxkLFxuICBSb3V0ZXIsXG4gIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gIFJvdXRlclN0YXRlU25hcHNob3Rcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuL2F1dGguc2VydmljZSc7XG5pbXBvcnQgeyBBVVRIX1NFUlZJQ0UsIFBST1RFQ1RFRF9GQUxMQkFDS19QQUdFX1VSSSB9IGZyb20gJy4vdG9rZW5zJztcblxuLyoqXG4gKiBHdWFyZCwgY2hlY2tzIGFjY2VzcyB0b2tlbiBhdmFpbGFiaWxpdHkgYW5kIGFsbG93cyBvciBkaXNhbGxvd3MgYWNjZXNzIHRvIHBhZ2UsXG4gKiBhbmQgcmVkaXJlY3RzIG91dFxuICpcbiAqIHVzYWdlOiB7IHBhdGg6ICd0ZXN0JywgY29tcG9uZW50OiBUZXN0Q29tcG9uZW50LCBjYW5BY3RpdmF0ZTogWyBQdWJsaWNHdWFyZCBdIH1cbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQdWJsaWNHdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlLCBDYW5BY3RpdmF0ZUNoaWxkIHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KEFVVEhfU0VSVklDRSkgcHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgQEluamVjdChQUk9URUNURURfRkFMTEJBQ0tfUEFHRV9VUkkpIHByaXZhdGUgcHJvdGVjdGVkRmFsbGJhY2tQYWdlVXJpOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxuICApIHt9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZShcbiAgICBfcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aFNlcnZpY2UuaXNBdXRob3JpemVkKClcbiAgICAgIC5waXBlKG1hcCgoaXNBdXRob3JpemVkOiBib29sZWFuKSA9PiB7XG4gICAgICAgIGlmIChpc0F1dGhvcml6ZWQgJiYgIXRoaXMuaXNQcm90ZWN0ZWRQYWdlKHN0YXRlKSkge1xuICAgICAgICAgIHRoaXMubmF2aWdhdGUodGhpcy5wcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmkpO1xuXG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGVDaGlsZCBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGVDaGlsZChcbiAgICByb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5jYW5BY3RpdmF0ZShyb3V0ZSwgc3RhdGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrLCBpZiBjdXJyZW50IHBhZ2UgaXMgcHJvdGVjdGVkIGZhbGxiYWNrIHBhZ2VcbiAgICovXG4gIHByaXZhdGUgaXNQcm90ZWN0ZWRQYWdlKHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHN0YXRlLnVybCA9PT0gdGhpcy5wcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmk7XG4gIH1cblxuICAvKipcbiAgICogTmF2aWdhdGUgYXdheSBmcm9tIHRoZSBhcHAgLyBwYXRoXG4gICAqL1xuICBwcml2YXRlIG5hdmlnYXRlKHVybDogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKHVybC5zdGFydHNXaXRoKCdodHRwJykpIHtcbiAgICAgIHdpbmRvdy5sb2NhdGlvbi5ocmVmID0gdXJsO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKHVybCk7XG4gICAgfVxuICB9XG5cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLmd1YXJkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWF1dGgvIiwic291cmNlcyI6WyJwdWJsaWMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBR0wsTUFBTSxFQUdQLE1BQU0saUJBQWlCLENBQUM7QUFFekIsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLDJCQUEyQixFQUFFLE1BQU0sVUFBVSxDQUFDOzs7Ozs7Ozs7O0FBV3JFO0lBR0UscUJBQ2dDLFdBQXdCLEVBQ1Qsd0JBQWdDLEVBQzFDLFFBQWtCLEVBQzdDLE1BQWM7UUFIUSxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNULDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBUTtRQUMxQyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQzdDLFdBQU0sR0FBTixNQUFNLENBQVE7SUFDckIsQ0FBQztJQUVKOztPQUVHOzs7Ozs7O0lBQ0ksaUNBQVc7Ozs7OztJQUFsQixVQUNFLE1BQThCLEVBQzlCLEtBQTBCO1FBRjVCLGlCQWNDO1FBVkMsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksRUFBRTthQUNuQyxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQUMsWUFBcUI7WUFDOUIsSUFBSSxZQUFZLElBQUksQ0FBQyxLQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUNoRCxLQUFJLENBQUMsUUFBUSxDQUFDLEtBQUksQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO2dCQUU3QyxPQUFPLEtBQUssQ0FBQzthQUNkO1lBRUQsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztJQUVEOztPQUVHOzs7Ozs7O0lBQ0ksc0NBQWdCOzs7Ozs7SUFBdkIsVUFDRSxLQUE2QixFQUM3QixLQUEwQjtRQUUxQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRDs7T0FFRzs7Ozs7O0lBQ0sscUNBQWU7Ozs7O0lBQXZCLFVBQXdCLEtBQTBCO1FBQ2hELE9BQU8sS0FBSyxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMsd0JBQXdCLENBQUM7SUFDckQsQ0FBQztJQUVEOztPQUVHOzs7Ozs7SUFDSyw4QkFBUTs7Ozs7SUFBaEIsVUFBaUIsR0FBVztRQUMxQixJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDMUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztTQUNuQzthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDaEM7SUFDSCxDQUFDOztnQkF2REYsVUFBVTs7OztnQkFaRixXQUFXLHVCQWdCZixNQUFNLFNBQUMsWUFBWTs2Q0FDbkIsTUFBTSxTQUFDLDJCQUEyQjtnQkFDVSxRQUFRLHVCQUFwRCxNQUFNLFNBQUMsUUFBUTtnQkF6QmxCLE1BQU07O0lBNEVSLGtCQUFDO0NBQUEsQUF6REQsSUF5REM7U0F4RFksV0FBVzs7O0lBR3BCLGtDQUFzRDs7SUFDdEQsK0NBQTZFOztJQUM3RSwrQkFBcUQ7O0lBQ3JELDZCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdGFibGUsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQ2FuQWN0aXZhdGUsXG4gIENhbkFjdGl2YXRlQ2hpbGQsXG4gIFJvdXRlcixcbiAgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgUm91dGVyU3RhdGVTbmFwc2hvdFxufSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcbmltcG9ydCB7IEFVVEhfU0VSVklDRSwgUFJPVEVDVEVEX0ZBTExCQUNLX1BBR0VfVVJJIH0gZnJvbSAnLi90b2tlbnMnO1xuXG4vKipcbiAqIEd1YXJkLCBjaGVja3MgYWNjZXNzIHRva2VuIGF2YWlsYWJpbGl0eSBhbmQgYWxsb3dzIG9yIGRpc2FsbG93cyBhY2Nlc3MgdG8gcGFnZSxcbiAqIGFuZCByZWRpcmVjdHMgb3V0XG4gKlxuICogdXNhZ2U6IHsgcGF0aDogJ3Rlc3QnLCBjb21wb25lbnQ6IFRlc3RDb21wb25lbnQsIGNhbkFjdGl2YXRlOiBbIFB1YmxpY0d1YXJkIF0gfVxuICpcbiAqIEBleHBvcnRcbiAqIEBkeW5hbWljXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQdWJsaWNHdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlLCBDYW5BY3RpdmF0ZUNoaWxkIHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KEFVVEhfU0VSVklDRSkgcHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UsXG4gICAgQEluamVjdChQUk9URUNURURfRkFMTEJBQ0tfUEFHRV9VUkkpIHByaXZhdGUgcHJvdGVjdGVkRmFsbGJhY2tQYWdlVXJpOiBzdHJpbmcsXG4gICAgQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudDogRG9jdW1lbnQsXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxuICApIHt9XG5cbiAgLyoqXG4gICAqIENhbkFjdGl2YXRlIGhhbmRsZXJcbiAgICovXG4gIHB1YmxpYyBjYW5BY3RpdmF0ZShcbiAgICBfcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3RcbiAgKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aFNlcnZpY2UuaXNBdXRob3JpemVkKClcbiAgICAgIC5waXBlKG1hcCgoaXNBdXRob3JpemVkOiBib29sZWFuKSA9PiB7XG4gICAgICAgIGlmIChpc0F1dGhvcml6ZWQgJiYgIXRoaXMuaXNQcm90ZWN0ZWRQYWdlKHN0YXRlKSkge1xuICAgICAgICAgIHRoaXMubmF2aWdhdGUodGhpcy5wcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmkpO1xuXG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FuQWN0aXZhdGVDaGlsZCBoYW5kbGVyXG4gICAqL1xuICBwdWJsaWMgY2FuQWN0aXZhdGVDaGlsZChcbiAgICByb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgICBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdFxuICApOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5jYW5BY3RpdmF0ZShyb3V0ZSwgc3RhdGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrLCBpZiBjdXJyZW50IHBhZ2UgaXMgcHJvdGVjdGVkIGZhbGxiYWNrIHBhZ2VcbiAgICovXG4gIHByaXZhdGUgaXNQcm90ZWN0ZWRQYWdlKHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHN0YXRlLnVybCA9PT0gdGhpcy5wcm90ZWN0ZWRGYWxsYmFja1BhZ2VVcmk7XG4gIH1cblxuICAvKipcbiAgICogTmF2aWdhdGUgYXdheSBmcm9tIHRoZSBhcHAgLyBwYXRoXG4gICAqL1xuICBwcml2YXRlIG5hdmlnYXRlKHVybDogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKHVybC5zdGFydHNXaXRoKCdodHRwJykpIHtcbiAgICAgIHRoaXMuZG9jdW1lbnQubG9jYXRpb24uaHJlZiA9IHVybDtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGVCeVVybCh1cmwpO1xuICAgIH1cbiAgfVxuXG59XG4iXX0=
import { InjectionToken, Injectable, Inject, Injector, NgModule } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { Router } from '@angular/router';

@@ -40,2 +41,3 @@ import { map, first, switchMap, catchError } from 'rxjs/operators';

* @export
* \@dynamic
*/

@@ -46,7 +48,9 @@ class PublicGuard {

* @param {?} protectedFallbackPageUri
* @param {?} document
* @param {?} router
*/
constructor(authService, protectedFallbackPageUri, router) {
constructor(authService, protectedFallbackPageUri, document, router) {
this.authService = authService;
this.protectedFallbackPageUri = protectedFallbackPageUri;
this.document = document;
this.router = router;

@@ -94,3 +98,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -109,2 +113,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PROTECTED_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -124,2 +129,3 @@ ];

* @export
* \@dynamic
*/

@@ -130,7 +136,9 @@ class ProtectedGuard {

* @param {?} publicFallbackPageUri
* @param {?} document
* @param {?} router
*/
constructor(authService, publicFallbackPageUri, router) {
constructor(authService, publicFallbackPageUri, document, router) {
this.authService = authService;
this.publicFallbackPageUri = publicFallbackPageUri;
this.document = document;
this.router = router;

@@ -181,3 +189,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -196,2 +204,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PUBLIC_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -265,3 +274,3 @@ ];

/** @type {?} */
const refreshShouldHappen = authService.refreshShouldHappen(res);
const refreshShouldHappen = authService.refreshShouldHappen(res, req);
if (refreshShouldHappen && !this.refreshInProgress) {

@@ -400,2 +409,2 @@ this.refreshInProgress = true;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse, request?: HttpRequest<any>): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res, req);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;AAMA,MAAsB,WAAW;CA+DhC;;;;;;ACrED;AAEA,MAAa,YAAY,GAAG,IAAI,cAAc,CAAC,cAAc,CAAC;;AAC9D,MAAa,wBAAwB,GAAG,IAAI,cAAc,CAAC,0BAA0B,CAAC;;AACtF,MAAa,2BAA2B,GAAG,IAAI,cAAc,CAAC,6BAA6B,CAAC;;;;;;ACJ5F;;;;;;;;;AAyBA,MAAa,WAAW;;;;;;;IAEtB,YACgC,WAAwB,EACT,wBAAgC,EAC1C,QAAkB,EAC7C,MAAc;QAHQ,gBAAW,GAAX,WAAW,CAAa;QACT,6BAAwB,GAAxB,wBAAwB,CAAQ;QAC1C,aAAQ,GAAR,QAAQ,CAAU;QAC7C,WAAM,GAAN,MAAM,CAAQ;KACpB;;;;;;;IAKG,WAAW,CAChB,MAA8B,EAC9B,KAA0B;QAE1B,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE;aACnC,IAAI,CAAC,GAAG,CAAC,CAAC,YAAqB;YAC9B,IAAI,YAAY,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;gBAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;gBAE7C,OAAO,KAAK,CAAC;aACd;YAED,OAAO,IAAI,CAAC;SACb,CAAC,CAAC,CAAC;KACP;;;;;;;IAKM,gBAAgB,CACrB,KAA6B,EAC7B,KAA0B;QAE1B,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;KACvC;;;;;;IAKO,eAAe,CAAC,KAA0B;QAChD,OAAO,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,wBAAwB,CAAC;KACpD;;;;;;IAKO,QAAQ,CAAC,GAAW;QAC1B,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,CAAC;SACnC;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;SAChC;KACF;;;YAvDF,UAAU;;;;YAZF,WAAW,uBAgBf,MAAM,SAAC,YAAY;yCACnB,MAAM,SAAC,2BAA2B;YACU,QAAQ,uBAApD,MAAM,SAAC,QAAQ;YAzBlB,MAAM;;;;;;;ACLR;;;;;;;;;AAyBA,MAAa,cAAc;;;;;;;IAEzB,YAC+B,WAAwB,EACX,qBAA6B,EACpC,QAAkB,EAC7C,MAAc;QAHO,gBAAW,GAAX,WAAW,CAAa;QACX,0BAAqB,GAArB,qBAAqB,CAAQ;QACpC,aAAQ,GAAR,QAAQ,CAAU;QAC7C,WAAM,GAAN,MAAM,CAAQ;KACpB;;;;;;;IAKG,WAAW,CAChB,MAA8B,EAC9B,KAA0B;QAE1B,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE;aACnC,IAAI,CAAC,GAAG,CAAC,CAAC,YAAqB;YAC9B,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE;gBAC9C,IAAI,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE;oBACtC,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;iBAC/C;gBAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBAE1C,OAAO,KAAK,CAAC;aACd;YAED,OAAO,IAAI,CAAC;SACb,CAAC,CAAC,CAAC;KACP;;;;;;;IAKM,gBAAgB,CACrB,KAA6B,EAC7B,KAA0B;QAE1B,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;KACvC;;;;;;IAKO,YAAY,CAAC,KAA0B;QAC7C,OAAO,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,qBAAqB,CAAC;KACjD;;;;;;IAKO,QAAQ,CAAC,GAAW;QAC1B,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,CAAC;SACnC;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;SAChC;KACF;;;YA3DF,UAAU;;;;YAZF,WAAW,uBAgBf,MAAM,SAAC,YAAY;yCACnB,MAAM,SAAC,wBAAwB;YACa,QAAQ,uBAApD,MAAM,SAAC,QAAQ;YA3BlB,MAAM;;;;;;;ACHR,MAgBa,eAAe;;;;IAY1B,YAAoB,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;;;;QAP9B,sBAAiB,GAAG,KAAK,CAAC;;;;QAK1B,mBAAc,GAAqB,IAAI,OAAO,EAAW,CAAC;KAExB;;;;;;;IAKnC,SAAS,CACd,GAAqB,EACrB,QAAqB;QAErB,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE;YACzB,OAAO,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAC7B;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;KAC7C;;;;;;;IAKO,gBAAgB,CACtB,QAA0B,EAC1B,QAAqB;;cAEf,KAAK,GAAqB,QAAQ,CAAC,KAAK,EAAE;QAEhD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;aACvB,IAAI,CACH,SAAS,CAAC,CAAC,GAAqB,KAAK,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAC1D,UAAU,CAAC,CAAC,GAAsB,KAAK,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CACvE,CAAC;KACL;;;;;;;IAMO,OAAO,CAAC,GAAqB;QACnC,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;SAC/B;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;KAC3B;;;;;;;IAKO,aAAa,CACnB,GAAqB,EACrB,GAAsB;;cAEhB,WAAW,GACf,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAc,YAAY,CAAC;;cACxC,mBAAmB,GACvB,WAAW,CAAC,mBAAmB,CAAC,GAAG,EAAE,GAAG,CAAC;QAE3C,IAAI,mBAAmB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAClD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAE9B,WAAW;iBACR,YAAY,EAAE;iBACd,SAAS,CACR;gBACE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAChC,EACD;gBACE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACjC,CACF,CAAC;SACL;QAED,IAAI,mBAAmB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YACjD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;SACpC;QAED,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;KACxB;;;;;;IAKO,QAAQ,CAAC,GAAqB;;cAC9B,WAAW,GACf,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAc,YAAY,CAAC;QAE9C,OAAO,WAAW,CAAC,cAAc,EAAE;aAChC,IAAI,CACH,GAAG,CAAC,CAAC,KAAa;YAChB,IAAI,KAAK,EAAE;;oBACL,UAAiD;gBAErD,IAAI,OAAO,WAAW,CAAC,UAAU,KAAK,UAAU,EAAE;oBAChD,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;iBAC5C;qBAAM;oBACL,UAAU,GAAG,EAAE,aAAa,EAAE,UAAU,KAAK,EAAE,EAAE,CAAC;iBACnD;gBAED,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;aAClC;YAED,OAAO,GAAG,CAAC;SACZ,CAAC,EACF,KAAK,EAAE,CACR,CAAC;KACL;;;;;;;IAMO,YAAY,CAAC,GAAqB;QACxC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAC7B,KAAK,EAAE,EACP,SAAS,CAAC,CAAC,MAAe,KACxB,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,CAC9C,CACF,CAAC;KACH;;;;;;;;IAMO,YAAY,CAClB,GAAqB,EACrB,GAAsB;;cAEhB,IAAI,GACR,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAa,UAAU,CAAC;QAE3C,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAC7B,KAAK,EAAE,EACP,SAAS,CAAC,CAAC,MAAe,KACxB,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,GAAG,IAAI,GAAG,CAAC,CACpD,CACF,CAAC;KACH;;;;;;IAKO,WAAW,CAAC,GAAqB;;cACjC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC;;cAC3C,kBAAkB,GAAG,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC;;;cAGzD,kBAAkB,GAAG,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC,GAAG,CAAC;QAEnE,OAAO,WAAW,IAAI,kBAAkB,IAAI,kBAAkB,CAAC;KAChE;;;;;;;;IAMO,IAAI,CAAC,MAAc,EAAE,GAAG,IAAW;;cACnC,WAAW,GACf,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAc,YAAY,CAAC;QAE9C,IAAI,OAAO,WAAW,CAAC,MAAM,CAAC,KAAK,UAAU,EAAE;YAC7C,OAAO,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;SACrC;KACF;;;YAjLF,UAAU;;;;YAfU,QAAQ;;;;;;;ACA7B,MAmBa,UAAU;;;YAZtB,QAAQ,SAAC;gBACR,SAAS,EAAE;oBACT,WAAW;oBACX,cAAc;oBACd,eAAe;oBACf;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,QAAQ,EAAE,eAAe;wBACzB,KAAK,EAAE,IAAI;qBACZ;iBACF;aACF;;;;;;;;;;;;;;;"}
import { InjectionToken, Injectable, Inject, Injector, NgModule } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { Router } from '@angular/router';

@@ -48,7 +49,9 @@ import { map, first, switchMap, catchError } from 'rxjs/operators';

* @export
* \@dynamic
*/
var PublicGuard = /** @class */ (function () {
function PublicGuard(authService, protectedFallbackPageUri, router) {
function PublicGuard(authService, protectedFallbackPageUri, document, router) {
this.authService = authService;
this.protectedFallbackPageUri = protectedFallbackPageUri;
this.document = document;
this.router = router;

@@ -131,3 +134,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -145,2 +148,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PROTECTED_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -162,7 +166,9 @@ ]; };

* @export
* \@dynamic
*/
var ProtectedGuard = /** @class */ (function () {
function ProtectedGuard(authService, publicFallbackPageUri, router) {
function ProtectedGuard(authService, publicFallbackPageUri, document, router) {
this.authService = authService;
this.publicFallbackPageUri = publicFallbackPageUri;
this.document = document;
this.router = router;

@@ -248,3 +254,3 @@ }

if (url.startsWith('http')) {
window.location.href = url;
this.document.location.href = url;
}

@@ -262,2 +268,3 @@ else {

{ type: String, decorators: [{ type: Inject, args: [PUBLIC_FALLBACK_PAGE_URI,] }] },
{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: Router }

@@ -369,3 +376,3 @@ ]; };

/** @type {?} */
var refreshShouldHappen = authService.refreshShouldHappen(res);
var refreshShouldHappen = authService.refreshShouldHappen(res, req);
if (refreshShouldHappen && !this.refreshInProgress) {

@@ -565,2 +572,2 @@ this.refreshInProgress = true;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      window.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":[],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-auth.js.map","sources":["ng://ngx-auth/auth.service.ts","ng://ngx-auth/tokens.ts","ng://ngx-auth/public.guard.ts","ng://ngx-auth/protected.guard.ts","ng://ngx-auth/auth.interceptor.ts","ng://ngx-auth/auth.module.ts"],"sourcesContent":["import { HttpRequest, HttpErrorResponse } from '@angular/common/http';\nimport { Observable } from 'rxjs';\n\n/**\n * Essential service for authentication\n */\nexport abstract class AuthService {\n\n  /**\n   * Check, if user already authorized.\n   * Should return Observable with true or false values\n   */\n  public abstract isAuthorized(): Observable<boolean>;\n\n  /**\n   * Get access token\n   * Should return access token in Observable from e.g.\n   * localStorage\n   */\n  public abstract getAccessToken(): Observable<string>;\n\n  /**\n   * Function, that should perform refresh token\n   * Should be successfully completed so interceptor\n   * can execute pending requests or retry original one\n   */\n  public abstract refreshToken(): Observable<any>;\n\n  /**\n   * Function, checks response of failed request to determine,\n   * whether token be refreshed or not.\n   *\n   * Essentially checks status\n   */\n  public abstract refreshShouldHappen(response: HttpErrorResponse, request?: HttpRequest<any>): boolean;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   */\n  public abstract verifyRefreshToken?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   * Useful for requests such as request token which doesn't require token in headers\n   */\n  public abstract skipRequest?(request: HttpRequest<any>): boolean;\n\n  /**\n   * Add token to headers, dependent on server\n   * set-up, by default adds a bearer token.\n   * Called by interceptor.\n   * To change behavior, override this method.\n   */\n  public abstract getHeaders?(token: string): { [name: string]: string | string[] };\n\n  /**\n   * Saves last interrupted url inside of the service for further reusage,\n   * e.g. restoring interrupted page after logging in\n   */\n  public abstract setInterruptedUrl?(url: string): void;\n\n  /**\n   * Verify that outgoing request is refresh-token,\n   * so interceptor won't intercept this request\n   * @deprecated Due to illogical meaning/functionality this method is deprecated\n   * @see verifyRefreshToken\n   */\n  public abstract verifyTokenRequest?(url: string): boolean;\n}\n","import { InjectionToken } from '@angular/core';\n\nexport const AUTH_SERVICE = new InjectionToken('AUTH_SERVICE');\nexport const PUBLIC_FALLBACK_PAGE_URI = new InjectionToken('PUBLIC_FALLBACK_PAGE_URI');\nexport const PROTECTED_FALLBACK_PAGE_URI = new InjectionToken('PROTECTED_FALLBACK_PAGE_URI');\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  CanActivate,\n  CanActivateChild,\n  Router,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PROTECTED_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ PublicGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class PublicGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE) private authService: AuthService,\n    @Inject(PROTECTED_FALLBACK_PAGE_URI) private protectedFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (isAuthorized && !this.isProtectedPage(state)) {\n          this.navigate(this.protectedFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is protected fallback page\n   */\n  private isProtectedPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.protectedFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { DOCUMENT } from '@angular/common';\nimport { Injectable, Inject } from '@angular/core';\nimport {\n  Router,\n  CanActivate,\n  CanActivateChild,\n  ActivatedRouteSnapshot,\n  RouterStateSnapshot\n} from '@angular/router';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE, PUBLIC_FALLBACK_PAGE_URI } from './tokens';\n\n/**\n * Guard, checks access token availability and allows or disallows access to page,\n * and redirects out\n *\n * usage: { path: 'test', component: TestComponent, canActivate: [ AuthGuard ] }\n *\n * @export\n * @dynamic\n */\n@Injectable()\nexport class ProtectedGuard implements CanActivate, CanActivateChild {\n\n  constructor(\n    @Inject(AUTH_SERVICE)private authService: AuthService,\n    @Inject(PUBLIC_FALLBACK_PAGE_URI) private publicFallbackPageUri: string,\n    @Inject(DOCUMENT) private readonly document: Document,\n    private router: Router\n  ) {}\n\n  /**\n   * CanActivate handler\n   */\n  public canActivate(\n    _route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.authService.isAuthorized()\n      .pipe(map((isAuthorized: boolean) => {\n        if (!isAuthorized && !this.isPublicPage(state)) {\n          if (this.authService.setInterruptedUrl) {\n            this.authService.setInterruptedUrl(state.url);\n          }\n\n          this.navigate(this.publicFallbackPageUri);\n\n          return false;\n        }\n\n        return true;\n      }));\n  }\n\n  /**\n   * CanActivateChild handler\n   */\n  public canActivateChild(\n    route: ActivatedRouteSnapshot,\n    state: RouterStateSnapshot\n  ): Observable<boolean> {\n    return this.canActivate(route, state);\n  }\n\n  /**\n   * Check, if current page is public fallback page\n   */\n  private isPublicPage(state: RouterStateSnapshot): boolean {\n    return state.url === this.publicFallbackPageUri;\n  }\n\n  /**\n   * Navigate away from the app / path\n   */\n  private navigate(url: string): void {\n    if (url.startsWith('http')) {\n      this.document.location.href = url;\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n}\n","import { Injectable, Injector } from '@angular/core';\nimport {\n  HttpClient,\n  HttpEvent,\n  HttpInterceptor,\n  HttpHandler,\n  HttpRequest,\n  HttpErrorResponse\n} from '@angular/common/http';\nimport { Subject, Observable, throwError } from 'rxjs';\nimport { map, first, switchMap, catchError } from 'rxjs/operators';\n\nimport { AuthService } from './auth.service';\nimport { AUTH_SERVICE } from './tokens';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  /**\n   * Is refresh token is being executed\n   */\n  private refreshInProgress = false;\n\n  /**\n   * Notify all outstanding requests through this subject\n   */\n  private refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private injector: Injector) {}\n\n  /**\n   * Intercept an outgoing `HttpRequest`\n   */\n  public intercept(\n    req: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    if (this.skipRequest(req)) {\n      return delegate.handle(req);\n    }\n\n    return this.processIntercept(req, delegate);\n  }\n\n  /**\n   * Process all the requests via custom interceptors.\n   */\n  private processIntercept(\n    original: HttpRequest<any>,\n    delegate: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    const clone: HttpRequest<any> = original.clone();\n\n    return this.request(clone)\n      .pipe(\n        switchMap((req: HttpRequest<any>) => delegate.handle(req)),\n        catchError((res: HttpErrorResponse) => this.responseError(clone, res))\n      );\n  }\n\n  /**\n   * Request interceptor. Delays request if refresh is in progress\n   * otherwise adds token to the headers\n   */\n  private request(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    if (this.refreshInProgress) {\n      return this.delayRequest(req);\n    }\n\n    return this.addToken(req);\n  }\n\n  /**\n   * Failed request interceptor, check if it has to be processed with refresh\n   */\n  private responseError(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n    const refreshShouldHappen: boolean =\n      authService.refreshShouldHappen(res, req);\n\n    if (refreshShouldHappen && !this.refreshInProgress) {\n      this.refreshInProgress = true;\n\n      authService\n        .refreshToken()\n        .subscribe(\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(true);\n          },\n          () => {\n            this.refreshInProgress = false;\n            this.refreshSubject.next(false);\n          }\n        );\n    }\n\n    if (refreshShouldHappen && this.refreshInProgress) {\n      return this.retryRequest(req, res);\n    }\n\n    return throwError(res);\n  }\n\n  /**\n   * Add access token to headers or the request\n   */\n  private addToken(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    return authService.getAccessToken()\n      .pipe(\n        map((token: string) => {\n          if (token) {\n            let setHeaders: { [name: string]: string | string[] };\n\n            if (typeof authService.getHeaders === 'function') {\n              setHeaders = authService.getHeaders(token);\n            } else {\n              setHeaders = { Authorization: `Bearer ${token}` };\n            }\n\n            return req.clone({ setHeaders });\n          }\n\n          return req;\n        }),\n        first()\n      );\n  }\n\n  /**\n   * Delay request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private delayRequest(req: HttpRequest<any>): Observable<HttpRequest<any>> {\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? this.addToken(req) : throwError(req)\n      )\n    );\n  }\n\n  /**\n   * Retry request, by subscribing on refresh event, once it finished, process it\n   * otherwise throw error\n   */\n  private retryRequest(\n    req: HttpRequest<any>,\n    res: HttpErrorResponse\n  ): Observable<HttpEvent<any>> {\n    const http: HttpClient =\n      this.injector.get<HttpClient>(HttpClient);\n\n    return this.refreshSubject.pipe(\n      first(),\n      switchMap((status: boolean) =>\n        status ? http.request(req) : throwError(res || req)\n      )\n    );\n  }\n\n  /**\n   * Checks if request must be skipped by interceptor.\n   */\n  private skipRequest(req: HttpRequest<any>) {\n    const skipRequest = this.exec('skipRequest', req);\n    const verifyRefreshToken = this.exec('verifyRefreshToken', req);\n\n    // deprecated, will be removed soon\n    const verifyTokenRequest = this.exec('verifyTokenRequest', req.url);\n\n    return skipRequest || verifyRefreshToken || verifyTokenRequest;\n  }\n\n  /**\n   * Exec optional method, will be removed in upcoming updates.\n   * Temp method until `verifyTokenRequest` will be completely replaced with skipRequest\n   */\n  private exec(method: string, ...args: any[]) {\n    const authService: AuthService =\n      this.injector.get<AuthService>(AUTH_SERVICE);\n\n    if (typeof authService[method] === 'function') {\n      return authService[method](...args);\n    }\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\n\nimport { PublicGuard } from './public.guard';\nimport { ProtectedGuard } from './protected.guard';\nimport { AuthInterceptor } from './auth.interceptor';\n\n@NgModule({\n  providers: [\n    PublicGuard,\n    ProtectedGuard,\n    AuthInterceptor,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: AuthInterceptor,\n      multi: true,\n    }\n  ]\n})\nexport class AuthModule {\n}\n"],"names":[],"mappings":"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"}

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

{"__symbolic":"module","version":4,"metadata":{"AuthService":{"__symbolic":"class","members":{"isAuthorized":[{"__symbolic":"method"}],"getAccessToken":[{"__symbolic":"method"}],"refreshToken":[{"__symbolic":"method"}],"refreshShouldHappen":[{"__symbolic":"method"}],"verifyRefreshToken":[{"__symbolic":"method"}],"skipRequest":[{"__symbolic":"method"}],"getHeaders":[{"__symbolic":"method"}],"setInterruptedUrl":[{"__symbolic":"method"}],"verifyTokenRequest":[{"__symbolic":"method"}]}},"PublicGuard":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":22,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":26,"character":5},"arguments":[{"__symbolic":"reference","name":"AUTH_SERVICE"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":27,"character":5},"arguments":[{"__symbolic":"reference","name":"PROTECTED_FALLBACK_PAGE_URI"}]}],null],"parameters":[{"__symbolic":"reference","name":"AuthService"},{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":28,"character":20}]}],"canActivate":[{"__symbolic":"method"}],"canActivateChild":[{"__symbolic":"method"}],"isProtectedPage":[{"__symbolic":"method"}],"navigate":[{"__symbolic":"method"}]}},"ProtectedGuard":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":22,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":26,"character":5},"arguments":[{"__symbolic":"reference","name":"AUTH_SERVICE"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":27,"character":5},"arguments":[{"__symbolic":"reference","name":"PUBLIC_FALLBACK_PAGE_URI"}]}],null],"parameters":[{"__symbolic":"reference","name":"AuthService"},{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":28,"character":20}]}],"canActivate":[{"__symbolic":"method"}],"canActivateChild":[{"__symbolic":"method"}],"isPublicPage":[{"__symbolic":"method"}],"navigate":[{"__symbolic":"method"}]}},"AUTH_SERVICE":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":32},"arguments":["AUTH_SERVICE"]},"PUBLIC_FALLBACK_PAGE_URI":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":3,"character":44},"arguments":["PUBLIC_FALLBACK_PAGE_URI"]},"PROTECTED_FALLBACK_PAGE_URI":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":4,"character":47},"arguments":["PROTECTED_FALLBACK_PAGE_URI"]},"AuthModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"providers":[{"__symbolic":"reference","name":"PublicGuard"},{"__symbolic":"reference","name":"ProtectedGuard"},{"__symbolic":"reference","name":"ɵa"},{"provide":{"__symbolic":"reference","module":"@angular/common/http","name":"HTTP_INTERCEPTORS","line":13,"character":15},"useClass":{"__symbolic":"reference","name":"ɵa"},"multi":true}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":15,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":32}]}],"intercept":[{"__symbolic":"method"}],"processIntercept":[{"__symbolic":"method"}],"request":[{"__symbolic":"method"}],"responseError":[{"__symbolic":"method"}],"addToken":[{"__symbolic":"method"}],"delayRequest":[{"__symbolic":"method"}],"retryRequest":[{"__symbolic":"method"}],"skipRequest":[{"__symbolic":"method"}],"exec":[{"__symbolic":"method"}]}}},"origins":{"AuthService":"./auth.service","PublicGuard":"./public.guard","ProtectedGuard":"./protected.guard","AUTH_SERVICE":"./tokens","PUBLIC_FALLBACK_PAGE_URI":"./tokens","PROTECTED_FALLBACK_PAGE_URI":"./tokens","AuthModule":"./auth.module","ɵa":"./auth.interceptor"},"importAs":"ngx-auth"}
{"__symbolic":"module","version":4,"metadata":{"AuthService":{"__symbolic":"class","members":{"isAuthorized":[{"__symbolic":"method"}],"getAccessToken":[{"__symbolic":"method"}],"refreshToken":[{"__symbolic":"method"}],"refreshShouldHappen":[{"__symbolic":"method"}],"verifyRefreshToken":[{"__symbolic":"method"}],"skipRequest":[{"__symbolic":"method"}],"getHeaders":[{"__symbolic":"method"}],"setInterruptedUrl":[{"__symbolic":"method"}],"verifyTokenRequest":[{"__symbolic":"method"}]}},"PublicGuard":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":24,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":28,"character":5},"arguments":[{"__symbolic":"reference","name":"AUTH_SERVICE"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":29,"character":5},"arguments":[{"__symbolic":"reference","name":"PROTECTED_FALLBACK_PAGE_URI"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":30,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":30,"character":12}]}],null],"parameters":[{"__symbolic":"reference","name":"AuthService"},{"__symbolic":"reference","name":"string"},{"__symbolic":"error","message":"Could not resolve type","line":30,"character":49,"context":{"typeName":"Document"},"module":"./public.guard"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":31,"character":20}]}],"canActivate":[{"__symbolic":"method"}],"canActivateChild":[{"__symbolic":"method"}],"isProtectedPage":[{"__symbolic":"method"}],"navigate":[{"__symbolic":"method"}]}},"ProtectedGuard":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":24,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":28,"character":5},"arguments":[{"__symbolic":"reference","name":"AUTH_SERVICE"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":29,"character":5},"arguments":[{"__symbolic":"reference","name":"PUBLIC_FALLBACK_PAGE_URI"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":30,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":30,"character":12}]}],null],"parameters":[{"__symbolic":"reference","name":"AuthService"},{"__symbolic":"reference","name":"string"},{"__symbolic":"error","message":"Could not resolve type","line":30,"character":49,"context":{"typeName":"Document"},"module":"./protected.guard"},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":31,"character":20}]}],"canActivate":[{"__symbolic":"method"}],"canActivateChild":[{"__symbolic":"method"}],"isPublicPage":[{"__symbolic":"method"}],"navigate":[{"__symbolic":"method"}]}},"AUTH_SERVICE":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":2,"character":32},"arguments":["AUTH_SERVICE"]},"PUBLIC_FALLBACK_PAGE_URI":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":3,"character":44},"arguments":["PUBLIC_FALLBACK_PAGE_URI"]},"PROTECTED_FALLBACK_PAGE_URI":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":4,"character":47},"arguments":["PROTECTED_FALLBACK_PAGE_URI"]},"AuthModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"providers":[{"__symbolic":"reference","name":"PublicGuard"},{"__symbolic":"reference","name":"ProtectedGuard"},{"__symbolic":"reference","name":"ɵa"},{"provide":{"__symbolic":"reference","module":"@angular/common/http","name":"HTTP_INTERCEPTORS","line":13,"character":15},"useClass":{"__symbolic":"reference","name":"ɵa"},"multi":true}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":15,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":32}]}],"intercept":[{"__symbolic":"method"}],"processIntercept":[{"__symbolic":"method"}],"request":[{"__symbolic":"method"}],"responseError":[{"__symbolic":"method"}],"addToken":[{"__symbolic":"method"}],"delayRequest":[{"__symbolic":"method"}],"retryRequest":[{"__symbolic":"method"}],"skipRequest":[{"__symbolic":"method"}],"exec":[{"__symbolic":"method"}]}}},"origins":{"AuthService":"./auth.service","PublicGuard":"./public.guard","ProtectedGuard":"./protected.guard","AUTH_SERVICE":"./tokens","PUBLIC_FALLBACK_PAGE_URI":"./tokens","PROTECTED_FALLBACK_PAGE_URI":"./tokens","AuthModule":"./auth.module","ɵa":"./auth.interceptor"},"importAs":"ngx-auth"}
{
"name": "ngx-auth",
"version": "5.3.0",
"version": "5.4.0",
"description": "Angular 7+ Authentication module",

@@ -5,0 +5,0 @@ "repository": "https://github.com/serhiisol/ngx-auth",

@@ -11,2 +11,3 @@ import { Router, CanActivate, CanActivateChild, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';

* @export
* @dynamic
*/

@@ -16,4 +17,5 @@ export declare class ProtectedGuard implements CanActivate, CanActivateChild {

private publicFallbackPageUri;
private readonly document;
private router;
constructor(authService: AuthService, publicFallbackPageUri: string, router: Router);
constructor(authService: AuthService, publicFallbackPageUri: string, document: Document, router: Router);
/**

@@ -20,0 +22,0 @@ * CanActivate handler

@@ -11,2 +11,3 @@ import { CanActivate, CanActivateChild, Router, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';

* @export
* @dynamic
*/

@@ -16,4 +17,5 @@ export declare class PublicGuard implements CanActivate, CanActivateChild {

private protectedFallbackPageUri;
private readonly document;
private router;
constructor(authService: AuthService, protectedFallbackPageUri: string, router: Router);
constructor(authService: AuthService, protectedFallbackPageUri: string, document: Document, router: Router);
/**

@@ -20,0 +22,0 @@ * CanActivate handler

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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