adb-shared 6.0.35 → 6.0.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -9,6 +9,7 @@ import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common/http";
10
10
  import * as i2 from "@angular/router";
11
11
  export class AdbUserService {
12
+ // hasEmitted = false;
12
13
  constructor(config, http, router) {
13
14
  this.config = config;
14
15
  this.http = http;
@@ -17,7 +18,6 @@ export class AdbUserService {
17
18
  this.userSubject = new BehaviorSubject(null);
18
19
  this.user$ = this.userSubject.asObservable();
19
20
  this.lastRefreshTime = 0;
20
- this.hasEmitted = false;
21
21
  this.config = { ...{ scope: 'roles', idleTime: 30, response_type: 'code' }, ...config };
22
22
  }
23
23
  init() {
@@ -36,7 +36,7 @@ export class AdbUserService {
36
36
  }
37
37
  this.router.events.subscribe(event => {
38
38
  if (event instanceof NavigationStart) {
39
- this.login();
39
+ this.login(event.url);
40
40
  }
41
41
  });
42
42
  }
@@ -45,14 +45,16 @@ export class AdbUserService {
45
45
  this.checkStatus();
46
46
  this.intervalId = setInterval(() => this.checkStatus(), 60 * 1000); // 60 seconds * 1000 milliseconds
47
47
  }
48
- login() {
49
- this.log('url when login', this.router.url);
50
- sessionStorage.setItem(UserModuleConstants.CURRENT_URL, this.router.url);
48
+ login(url = null) {
49
+ this.log('url when login', url);
50
+ if (url) {
51
+ sessionStorage.setItem(UserModuleConstants.CURRENT_URL, url);
52
+ }
51
53
  this.authorize();
52
54
  }
53
55
  logout() {
54
56
  clearInterval(this.intervalId);
55
- this.hasEmitted = false;
57
+ // this.hasEmitted = false;
56
58
  sessionStorage.clear();
57
59
  window.location.href = `${this.config.issuer}/connect/endsession?post_logout_redirect_uri=${this.config.postLogoutUrl}`;
58
60
  }
@@ -72,15 +74,20 @@ export class AdbUserService {
72
74
  console.log('token is about to timeout but we will refresh it because user has been active the last 5minutes');
73
75
  this.refreshToken();
74
76
  }
75
- this.log('hasEmitted', this.hasEmitted);
76
- if (!this.hasEmitted) {
77
- const user = this.getUser(accessToken);
78
- this.userSubject.next(user);
79
- this.hasEmitted = true;
80
- }
77
+ //NOTE: Might not be needed in this variant
78
+ // if (!this.hasEmitted) {
79
+ // const user = this.getUser(accessToken);
80
+ // this.userSubject.next(user);
81
+ // this.hasEmitted = true;
82
+ // }
81
83
  }
82
84
  }
83
85
  }
86
+ //TODO: make it not exported by the module
87
+ _internalTriggerUserEvent(token) {
88
+ const user = this.getUser(token);
89
+ this.userSubject.next(user);
90
+ }
84
91
  refreshToken() {
85
92
  const body = `client_id=${encodeURIComponent(this.config.clientId)}&` +
86
93
  `grant_type=${encodeURIComponent("refresh_token")}&` +
@@ -199,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
199
206
  type: Inject,
200
207
  args: [ADB_USER_SERVICE_CONFIG]
201
208
  }] }, { type: i1.HttpClient }, { type: i2.Router }] });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-user.service.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-user/adb-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, OnDestroy } from '@angular/core';\r\nimport { ADB_USER_SERVICE_CONFIG, AdbUserServiceConfig } from './adb-user-service-config';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { addSeconds, format } from 'date-fns';\r\nimport { UserModuleConstants } from './user-constants';\r\nimport { NavigationStart, Router } from '@angular/router';\r\n\r\n\r\n@Injectable()\r\nexport class AdbUserService implements OnDestroy {\r\n\r\n  private subscriptions = new Subscription();\r\n  private userSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\r\n  user$ = this.userSubject.asObservable();\r\n\r\n  lastRefreshTime = 0;\r\n  intervalId: any;\r\n  hasEmitted = false;\r\n\r\n  constructor(\r\n    @Inject(ADB_USER_SERVICE_CONFIG) public config: AdbUserServiceConfig,\r\n    private http: HttpClient,\r\n    private router: Router) {\r\n    this.config = { ...{ scope: 'roles', idleTime: 30, response_type: 'code' }, ...config };\r\n  }\r\n\r\n  init(): void {\r\n    const accessToken = sessionStorage.getItem(UserModuleConstants.ACCESS_TOKEN);\r\n    if (accessToken) {\r\n      const user = this.getUser(accessToken);\r\n      this.userSubject.next(user);\r\n      this.startMainLoop();\r\n    } else if (this.config.autoLogin) {\r\n      //NOTE: Avoid re-triggering login if we're in the middle of the auth-callback handling\r\n      const urlParams = new URLSearchParams(window.location.search);\r\n      if (urlParams.has('code')) {\r\n        this.log('Detected auth callback, skipping init login.');\r\n        return;\r\n      }\r\n      this.router.events.subscribe(event => {\r\n        if (event instanceof NavigationStart) {\r\n          this.login();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  startMainLoop() {\r\n    this.checkStatus();\r\n    this.intervalId = setInterval(() => this.checkStatus(), 60 * 1000); // 60 seconds * 1000 milliseconds\r\n  }\r\n\r\n  private login(): void {\r\n    this.log('url when login', this.router.url);\r\n    sessionStorage.setItem(UserModuleConstants.CURRENT_URL, this.router.url);\r\n    this.authorize();\r\n  }\r\n\r\n  logout(): void {\r\n    clearInterval(this.intervalId);\r\n    this.hasEmitted = false;\r\n    sessionStorage.clear();\r\n    window.location.href = `${this.config.issuer}/connect/endsession?post_logout_redirect_uri=${this.config.postLogoutUrl}`;\r\n  }\r\n\r\n  private checkStatus(): void {\r\n    this.log('checkStatus runs')\r\n    const accessToken = sessionStorage.getItem(UserModuleConstants.ACCESS_TOKEN);\r\n    if (accessToken) {\r\n      this.log('has accesstoken')\r\n      const timeToLive = this.getTokenTimeToLive();\r\n      this.log('timeToLive', timeToLive)\r\n      if (timeToLive === 0) {\r\n        sessionStorage.removeItem(UserModuleConstants.ACCESS_TOKEN);\r\n        this.authorize();\r\n      } else {\r\n        if (this.getTokenTimeToLive() <= 60 && this.hasUserBeenActive() && this.canRefreshToken()) {\r\n          console.log('token is about to timeout but we will refresh it because user has been active the last 5minutes');\r\n          this.refreshToken();\r\n        }\r\n        this.log('hasEmitted', this.hasEmitted);\r\n        if (!this.hasEmitted) {\r\n          const user = this.getUser(accessToken);\r\n          this.userSubject.next(user);\r\n          this.hasEmitted = true;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private refreshToken() {\r\n    const body = `client_id=${encodeURIComponent(this.config.clientId)}&` +\r\n      `grant_type=${encodeURIComponent(\"refresh_token\")}&` +\r\n      `refresh_token=${encodeURIComponent(sessionStorage.getItem(UserModuleConstants.REFRESH_TOKEN))}`;\r\n    this.http.post<any>(`${this.config.issuer}/connect/token`, body, { headers: new HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded' }) }).subscribe({\r\n      next: response => {\r\n        this.setTokensInSession(response);\r\n      }\r\n    });\r\n    this.lastRefreshTime = Date.now();\r\n  }\r\n\r\n  setTokensInSession(params: any): void {\r\n    if (params.refresh_token) {\r\n      sessionStorage.setItem(UserModuleConstants.REFRESH_TOKEN, params.refresh_token);\r\n    }\r\n    if (params.access_token) {\r\n      sessionStorage.setItem(UserModuleConstants.ACCESS_TOKEN, params.access_token);\r\n    }\r\n    if (params.expires_in) {\r\n      const expireTime = addSeconds(new Date(), params.expires_in);\r\n      sessionStorage.setItem(UserModuleConstants.TOKEN_EXPIRES, format(expireTime, 'yyyy-MM-dd HH:mm:ss'));\r\n    }\r\n  }\r\n\r\n  async authorize() {\r\n    const codeVerifier = Array.from(crypto.getRandomValues(new Uint8Array(64)), byte =>\r\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'[(byte as number) % 62]\r\n    ).join('');\r\n    sessionStorage.setItem(UserModuleConstants.CODE_VERIFIER, codeVerifier);\r\n\r\n    const encoder = new TextEncoder();\r\n    const data = encoder.encode(codeVerifier);\r\n    const hashBuffer = await crypto.subtle.digest('SHA-256', data);\r\n    const hashArray = new Uint8Array(hashBuffer);\r\n    let codeChallenge = btoa(String.fromCharCode(...hashArray));\r\n    codeChallenge = codeChallenge.replace(/=/g, '')\r\n      .replace(/\\+/g, '-')\r\n      .replace(/\\//g, '_');\r\n\r\n    const params = {\r\n      response_type: this.config.responseType,\r\n      client_id: this.config.clientId,\r\n      redirect_uri: this.config.redirectUrl,\r\n      scope: this.config.scope,\r\n      code_challenge: codeChallenge,\r\n      code_challenge_method: 'S256'\r\n    };\r\n    const url = new URL(this.config.issuer + '/connect/authorize');\r\n    url.search = this.addQueryParams(params).toString();\r\n    window.location.href = url.toString();\r\n  }\r\n\r\n\r\n  private addQueryParams(object: any): URLSearchParams {\r\n    if (!object) {\r\n      return null;\r\n    }\r\n    const urlParams = new URLSearchParams();\r\n    for (const prop in object) {\r\n      urlParams.append(prop, object[prop]);\r\n    }\r\n    return urlParams;\r\n  }\r\n\r\n  private getTokenTimeToLive(): number {\r\n    const expires = sessionStorage.getItem(UserModuleConstants.TOKEN_EXPIRES);\r\n    if (expires) {\r\n      const expireDate = new Date(expires);\r\n      const now = new Date();\r\n      const timeToLive = Math.floor((expireDate.getTime() - now.getTime()) / 1000);\r\n      return timeToLive < 0 ? 0 : timeToLive;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  //Cooldown for avoiding infinite refresh\r\n  private canRefreshToken(): boolean {\r\n    const now = Date.now();\r\n    if (now - this.lastRefreshTime > (2 * 60 * 1000)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private hasUserBeenActive(): boolean {\r\n    const lastActive = sessionStorage.getItem(UserModuleConstants.USER_LAST_ACTIVE);\r\n    if (!lastActive) {\r\n      return false;\r\n    }\r\n    const timeSinceLastActive = Date.now() - parseInt(lastActive, 10);\r\n    const idleTimeMs = this.config.idleTime * 60 * 1000;\r\n    return timeSinceLastActive <= idleTimeMs;\r\n  }\r\n\r\n  log(message: string, ...optionalParams: any[]): void {\r\n    if (this.config?.log) {\r\n      if (optionalParams?.length > 0) {\r\n        console.log(message, optionalParams);\r\n      } else {\r\n        console.log(message);\r\n      }\r\n    }\r\n  }\r\n\r\n  getUser(token: string): any {\r\n    try {\r\n      const [header, payload, signature] = token.split('.');\r\n      const base64Url = payload.replace(/-/g, '+').replace(/_/g, '/');\r\n      const decodedPayload = atob(base64Url);\r\n      const parsedPayload = JSON.parse(decodedPayload);\r\n      return parsedPayload;\r\n    } catch (error) {\r\n      console.error('Error decoding JWT', error);\r\n      return null;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n}"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-user.service.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-user/adb-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, OnDestroy } from '@angular/core';\r\nimport { ADB_USER_SERVICE_CONFIG, AdbUserServiceConfig } from './adb-user-service-config';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { addSeconds, format } from 'date-fns';\r\nimport { UserModuleConstants } from './user-constants';\r\nimport { NavigationStart, Router } from '@angular/router';\r\n\r\n\r\n@Injectable()\r\nexport class AdbUserService implements OnDestroy {\r\n\r\n  private subscriptions = new Subscription();\r\n  private userSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\r\n  user$ = this.userSubject.asObservable();\r\n\r\n  lastRefreshTime = 0;\r\n  intervalId: any;\r\n  // hasEmitted = false;\r\n\r\n  constructor(\r\n    @Inject(ADB_USER_SERVICE_CONFIG) public config: AdbUserServiceConfig,\r\n    private http: HttpClient,\r\n    private router: Router) {\r\n    this.config = { ...{ scope: 'roles', idleTime: 30, response_type: 'code' }, ...config };\r\n  }\r\n\r\n  init(): void {\r\n    const accessToken = sessionStorage.getItem(UserModuleConstants.ACCESS_TOKEN);\r\n    if (accessToken) {\r\n      const user = this.getUser(accessToken);\r\n      this.userSubject.next(user);\r\n      this.startMainLoop();\r\n    } else if (this.config.autoLogin) {\r\n      //NOTE: Avoid re-triggering login if we're in the middle of the auth-callback handling\r\n      const urlParams = new URLSearchParams(window.location.search);\r\n      if (urlParams.has('code')) {\r\n        this.log('Detected auth callback, skipping init login.');\r\n        return;\r\n      }\r\n      this.router.events.subscribe(event => {\r\n        if (event instanceof NavigationStart) {\r\n          this.login(event.url);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  startMainLoop() {\r\n    this.checkStatus();\r\n    this.intervalId = setInterval(() => this.checkStatus(), 60 * 1000); // 60 seconds * 1000 milliseconds\r\n  }\r\n\r\n  private login(url: string = null): void {\r\n    this.log('url when login', url);\r\n    if (url) {\r\n      sessionStorage.setItem(UserModuleConstants.CURRENT_URL, url);\r\n    }\r\n    this.authorize();\r\n  }\r\n\r\n  logout(): void {\r\n    clearInterval(this.intervalId);\r\n    // this.hasEmitted = false;\r\n    sessionStorage.clear();\r\n    window.location.href = `${this.config.issuer}/connect/endsession?post_logout_redirect_uri=${this.config.postLogoutUrl}`;\r\n  }\r\n\r\n  private checkStatus(): void {\r\n    this.log('checkStatus runs')\r\n    const accessToken = sessionStorage.getItem(UserModuleConstants.ACCESS_TOKEN);\r\n    if (accessToken) {\r\n      this.log('has accesstoken')\r\n      const timeToLive = this.getTokenTimeToLive();\r\n      this.log('timeToLive', timeToLive)\r\n      if (timeToLive === 0) {\r\n        sessionStorage.removeItem(UserModuleConstants.ACCESS_TOKEN);\r\n        this.authorize();\r\n      } else {\r\n        if (this.getTokenTimeToLive() <= 60 && this.hasUserBeenActive() && this.canRefreshToken()) {\r\n          console.log('token is about to timeout but we will refresh it because user has been active the last 5minutes');\r\n          this.refreshToken();\r\n        }\r\n        //NOTE: Might not be needed in this variant\r\n        // if (!this.hasEmitted) {\r\n        //   const user = this.getUser(accessToken);\r\n        //   this.userSubject.next(user);\r\n        //   this.hasEmitted = true;\r\n        // }\r\n      }\r\n    }\r\n  }\r\n  \r\n  //TODO: make it not exported by the module\r\n  _internalTriggerUserEvent(token:string):void{\r\n      const user = this.getUser(token);\r\n      this.userSubject.next(user);\r\n\r\n  }\r\n\r\n  private refreshToken() {\r\n    const body = `client_id=${encodeURIComponent(this.config.clientId)}&` +\r\n      `grant_type=${encodeURIComponent(\"refresh_token\")}&` +\r\n      `refresh_token=${encodeURIComponent(sessionStorage.getItem(UserModuleConstants.REFRESH_TOKEN))}`;\r\n    this.http.post<any>(`${this.config.issuer}/connect/token`, body, { headers: new HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded' }) }).subscribe({\r\n      next: response => {\r\n        this.setTokensInSession(response);\r\n      }\r\n    });\r\n    this.lastRefreshTime = Date.now();\r\n  }\r\n\r\n  setTokensInSession(params: any): void {\r\n    if (params.refresh_token) {\r\n      sessionStorage.setItem(UserModuleConstants.REFRESH_TOKEN, params.refresh_token);\r\n    }\r\n    if (params.access_token) {\r\n      sessionStorage.setItem(UserModuleConstants.ACCESS_TOKEN, params.access_token);\r\n    }\r\n    if (params.expires_in) {\r\n      const expireTime = addSeconds(new Date(), params.expires_in);\r\n      sessionStorage.setItem(UserModuleConstants.TOKEN_EXPIRES, format(expireTime, 'yyyy-MM-dd HH:mm:ss'));\r\n    }\r\n  }\r\n\r\n  async authorize() {\r\n    const codeVerifier = Array.from(crypto.getRandomValues(new Uint8Array(64)), byte =>\r\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'[(byte as number) % 62]\r\n    ).join('');\r\n    sessionStorage.setItem(UserModuleConstants.CODE_VERIFIER, codeVerifier);\r\n\r\n    const encoder = new TextEncoder();\r\n    const data = encoder.encode(codeVerifier);\r\n    const hashBuffer = await crypto.subtle.digest('SHA-256', data);\r\n    const hashArray = new Uint8Array(hashBuffer);\r\n    let codeChallenge = btoa(String.fromCharCode(...hashArray));\r\n    codeChallenge = codeChallenge.replace(/=/g, '')\r\n      .replace(/\\+/g, '-')\r\n      .replace(/\\//g, '_');\r\n\r\n    const params = {\r\n      response_type: this.config.responseType,\r\n      client_id: this.config.clientId,\r\n      redirect_uri: this.config.redirectUrl,\r\n      scope: this.config.scope,\r\n      code_challenge: codeChallenge,\r\n      code_challenge_method: 'S256'\r\n    };\r\n    const url = new URL(this.config.issuer + '/connect/authorize');\r\n    url.search = this.addQueryParams(params).toString();\r\n    window.location.href = url.toString();\r\n  }\r\n\r\n\r\n  private addQueryParams(object: any): URLSearchParams {\r\n    if (!object) {\r\n      return null;\r\n    }\r\n    const urlParams = new URLSearchParams();\r\n    for (const prop in object) {\r\n      urlParams.append(prop, object[prop]);\r\n    }\r\n    return urlParams;\r\n  }\r\n\r\n  private getTokenTimeToLive(): number {\r\n    const expires = sessionStorage.getItem(UserModuleConstants.TOKEN_EXPIRES);\r\n    if (expires) {\r\n      const expireDate = new Date(expires);\r\n      const now = new Date();\r\n      const timeToLive = Math.floor((expireDate.getTime() - now.getTime()) / 1000);\r\n      return timeToLive < 0 ? 0 : timeToLive;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  //Cooldown for avoiding infinite refresh\r\n  private canRefreshToken(): boolean {\r\n    const now = Date.now();\r\n    if (now - this.lastRefreshTime > (2 * 60 * 1000)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private hasUserBeenActive(): boolean {\r\n    const lastActive = sessionStorage.getItem(UserModuleConstants.USER_LAST_ACTIVE);\r\n    if (!lastActive) {\r\n      return false;\r\n    }\r\n    const timeSinceLastActive = Date.now() - parseInt(lastActive, 10);\r\n    const idleTimeMs = this.config.idleTime * 60 * 1000;\r\n    return timeSinceLastActive <= idleTimeMs;\r\n  }\r\n\r\n  log(message: string, ...optionalParams: any[]): void {\r\n    if (this.config?.log) {\r\n      if (optionalParams?.length > 0) {\r\n        console.log(message, optionalParams);\r\n      } else {\r\n        console.log(message);\r\n      }\r\n    }\r\n  }\r\n\r\n  getUser(token: string): any {\r\n    try {\r\n      const [header, payload, signature] = token.split('.');\r\n      const base64Url = payload.replace(/-/g, '+').replace(/_/g, '/');\r\n      const decodedPayload = atob(base64Url);\r\n      const parsedPayload = JSON.parse(decodedPayload);\r\n      return parsedPayload;\r\n    } catch (error) {\r\n      console.error('Error decoding JWT', error);\r\n      return null;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.unsubscribe();\r\n  }\r\n\r\n}"]}
@@ -26,6 +26,7 @@ export class AuthCallbackComponent {
26
26
  next: response => {
27
27
  this.adbUserService.setTokensInSession(response);
28
28
  let requestedUrl = sessionStorage.getItem(UserModuleConstants.CURRENT_URL) ?? null;
29
+ this.adbUserService._internalTriggerUserEvent(response.access_token);
29
30
  this.adbUserService.log('redirect url in auth-callback', requestedUrl);
30
31
  if (requestedUrl) {
31
32
  this.router.navigate([requestedUrl], { replaceUrl: true }).then(() => {
@@ -53,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
53
54
  template: '<div class="loading-dead-spinner"></div>'
54
55
  }]
55
56
  }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.HttpClient }, { type: i3.AdbUserService }] });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXVzZXIvYXV0aC1jYWxsYmFjay5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRXBDLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7QUFNdkQsTUFBTSxPQUFPLHFCQUFxQjtJQUU5QixZQUNZLGNBQThCLEVBQzlCLE1BQWMsRUFDZCxJQUFnQixFQUNoQixjQUE4QjtRQUg5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBTGxDLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUtHLENBQUM7SUFFL0MsUUFBUTtRQUNKLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN6RSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztnQkFDdEIsTUFBTSxJQUFJLEdBQUcsK0JBQStCO29CQUN4QyxTQUFTLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRTtvQkFDbEQsa0JBQWtCLGtCQUFrQixDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDLENBQUMsRUFBRTtvQkFDakcsaUJBQWlCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxFQUFFO29CQUM3RSxjQUFjLGtCQUFrQixDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7Z0JBRTVFLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFNLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsRUFBRSxJQUFJLEVBQzFFLEVBQUUsT0FBTyxFQUFFLElBQUksV0FBVyxDQUFDLEVBQUUsY0FBYyxFQUFFLG1DQUFtQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDO29CQUM3RixJQUFJLEVBQUUsUUFBUSxDQUFDLEVBQUU7d0JBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDakQsSUFBSSxZQUFZLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsSUFBSSxJQUFJLENBQUM7d0JBQ25GLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLCtCQUErQixFQUFDLFlBQVksQ0FBQyxDQUFDO3dCQUN0RSxJQUFJLFlBQVksRUFBRSxDQUFDOzRCQUNmLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDLEVBQUUsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO2dDQUNqRSxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFDOzRCQUN4QyxDQUFDLENBQUMsQ0FBQzs0QkFDSCxjQUFjLENBQUMsVUFBVSxDQUFDLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO3dCQUMvRCxDQUFDOzZCQUFJLENBQUM7NEJBQ0YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUU7Z0NBQ3hELElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxFQUFFLENBQUM7NEJBQ3hDLENBQUMsQ0FBQyxDQUFDOzRCQUFBLENBQUM7d0JBQ1IsQ0FBQztvQkFDTCxDQUFDO2lCQUNKLENBQUMsQ0FBQztZQUNYLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztpSUFyQ1EscUJBQXFCO3FIQUFyQixxQkFBcUIsb0RBRnBCLDBDQUEwQzs7MkZBRTNDLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsMENBQTBDO2lCQUN2RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUsIFJvdXRlciB9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEhlYWRlcnMgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcclxuaW1wb3J0IHsgVXNlck1vZHVsZUNvbnN0YW50cyB9IGZyb20gXCIuL3VzZXItY29uc3RhbnRzXCI7XHJcbmltcG9ydCB7IEFkYlVzZXJTZXJ2aWNlIH0gZnJvbSBcIi4vYWRiLXVzZXIuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICB0ZW1wbGF0ZTogJzxkaXYgY2xhc3M9XCJsb2FkaW5nLWRlYWQtc3Bpbm5lclwiPjwvZGl2PidcclxufSlcclxuZXhwb3J0IGNsYXNzIEF1dGhDYWxsYmFja0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgICBwcml2YXRlIHN1YnNjcmlwdGlvbnMgPSBuZXcgU3Vic2NyaXB0aW9uKCk7XHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwcml2YXRlIGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcclxuICAgICAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyLFxyXG4gICAgICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCxcclxuICAgICAgICBwcml2YXRlIGFkYlVzZXJTZXJ2aWNlOiBBZGJVc2VyU2VydmljZSkgeyB9XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb25zLmFkZCh0aGlzLmFjdGl2YXRlZFJvdXRlLnF1ZXJ5UGFyYW1NYXAuc3Vic2NyaWJlKHFQYXJtYXMgPT4ge1xyXG4gICAgICAgICAgICBpZiAocVBhcm1hcy5oYXMoJ2NvZGUnKSkge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgYm9keSA9IGBncmFudF90eXBlPWF1dGhvcml6YXRpb25fY29kZWAgK1xyXG4gICAgICAgICAgICAgICAgICAgIGAmY29kZT0ke2VuY29kZVVSSUNvbXBvbmVudChxUGFybWFzLmdldCgnY29kZScpKX1gICtcclxuICAgICAgICAgICAgICAgICAgICBgJmNvZGVfdmVyaWZpZXI9JHtlbmNvZGVVUklDb21wb25lbnQoc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbShVc2VyTW9kdWxlQ29uc3RhbnRzLkNPREVfVkVSSUZJRVIpKX1gICtcclxuICAgICAgICAgICAgICAgICAgICBgJnJlZGlyZWN0X3VyaT0ke2VuY29kZVVSSUNvbXBvbmVudCh0aGlzLmFkYlVzZXJTZXJ2aWNlLmNvbmZpZy5yZWRpcmVjdFVybCl9YCArXHJcbiAgICAgICAgICAgICAgICAgICAgYCZjbGllbnRfaWQ9JHtlbmNvZGVVUklDb21wb25lbnQodGhpcy5hZGJVc2VyU2VydmljZS5jb25maWcuY2xpZW50SWQpfWA7XHJcblxyXG4gICAgICAgICAgICAgICAgdGhpcy5odHRwLnBvc3Q8YW55PihgJHt0aGlzLmFkYlVzZXJTZXJ2aWNlLmNvbmZpZy5pc3N1ZXJ9L2Nvbm5lY3QvdG9rZW5gLCBib2R5LFxyXG4gICAgICAgICAgICAgICAgICAgIHsgaGVhZGVyczogbmV3IEh0dHBIZWFkZXJzKHsgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnIH0pIH0pLnN1YnNjcmliZSh7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIG5leHQ6IHJlc3BvbnNlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuYWRiVXNlclNlcnZpY2Uuc2V0VG9rZW5zSW5TZXNzaW9uKHJlc3BvbnNlKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxldCByZXF1ZXN0ZWRVcmwgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKFVzZXJNb2R1bGVDb25zdGFudHMuQ1VSUkVOVF9VUkwpID8/IG51bGw7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmFkYlVzZXJTZXJ2aWNlLmxvZygncmVkaXJlY3QgdXJsIGluIGF1dGgtY2FsbGJhY2snLHJlcXVlc3RlZFVybCk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAocmVxdWVzdGVkVXJsKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoW3JlcXVlc3RlZFVybF0sIHsgcmVwbGFjZVVybDogdHJ1ZSB9KS50aGVuKCgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5hZGJVc2VyU2VydmljZS5zdGFydE1haW5Mb29wKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2Vzc2lvblN0b3JhZ2UucmVtb3ZlSXRlbShVc2VyTW9kdWxlQ29uc3RhbnRzLkNVUlJFTlRfVVJMKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1lbHNle1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnLyddLCB7IHJlcGxhY2VVcmw6IHRydWUgfSkudGhlbigoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuYWRiVXNlclNlcnZpY2Uuc3RhcnRNYWluTG9vcCgpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pOztcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSkpO1xyXG4gICAgfVxyXG59Il19
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLXVzZXIvYXV0aC1jYWxsYmFjay5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRXBDLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7QUFNdkQsTUFBTSxPQUFPLHFCQUFxQjtJQUU5QixZQUNZLGNBQThCLEVBQzlCLE1BQWMsRUFDZCxJQUFnQixFQUNoQixjQUE4QjtRQUg5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBTGxDLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUtHLENBQUM7SUFFL0MsUUFBUTtRQUNKLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN6RSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztnQkFDdEIsTUFBTSxJQUFJLEdBQUcsK0JBQStCO29CQUN4QyxTQUFTLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRTtvQkFDbEQsa0JBQWtCLGtCQUFrQixDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDLENBQUMsRUFBRTtvQkFDakcsaUJBQWlCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxFQUFFO29CQUM3RSxjQUFjLGtCQUFrQixDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7Z0JBRTVFLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFNLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsRUFBRSxJQUFJLEVBQzFFLEVBQUUsT0FBTyxFQUFFLElBQUksV0FBVyxDQUFDLEVBQUUsY0FBYyxFQUFFLG1DQUFtQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDO29CQUM3RixJQUFJLEVBQUUsUUFBUSxDQUFDLEVBQUU7d0JBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUMsQ0FBQzt3QkFDakQsSUFBSSxZQUFZLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsSUFBSSxJQUFJLENBQUM7d0JBQ25GLElBQUksQ0FBQyxjQUFjLENBQUMseUJBQXlCLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO3dCQUNyRSxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQywrQkFBK0IsRUFBQyxZQUFZLENBQUMsQ0FBQzt3QkFDdEUsSUFBSSxZQUFZLEVBQUUsQ0FBQzs0QkFDZixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQyxFQUFFLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRTtnQ0FDakUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQzs0QkFDeEMsQ0FBQyxDQUFDLENBQUM7NEJBQ0gsY0FBYyxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsQ0FBQzt3QkFDL0QsQ0FBQzs2QkFBSSxDQUFDOzRCQUNGLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO2dDQUN4RCxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFDOzRCQUN4QyxDQUFDLENBQUMsQ0FBQzs0QkFBQSxDQUFDO3dCQUNSLENBQUM7b0JBQ0wsQ0FBQztpQkFDSixDQUFDLENBQUM7WUFDWCxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7aUlBdENRLHFCQUFxQjtxSEFBckIscUJBQXFCLG9EQUZwQiwwQ0FBMEM7OzJGQUUzQyxxQkFBcUI7a0JBSGpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDBDQUEwQztpQkFDdkQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlLCBSb3V0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvcm91dGVyXCI7XHJcbmltcG9ydCB7IEh0dHBDbGllbnQsIEh0dHBIZWFkZXJzIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IFVzZXJNb2R1bGVDb25zdGFudHMgfSBmcm9tIFwiLi91c2VyLWNvbnN0YW50c1wiO1xyXG5pbXBvcnQgeyBBZGJVc2VyU2VydmljZSB9IGZyb20gXCIuL2FkYi11c2VyLnNlcnZpY2VcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgdGVtcGxhdGU6ICc8ZGl2IGNsYXNzPVwibG9hZGluZy1kZWFkLXNwaW5uZXJcIj48L2Rpdj4nXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBdXRoQ2FsbGJhY2tDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgcHJpdmF0ZSBzdWJzY3JpcHRpb25zID0gbmV3IFN1YnNjcmlwdGlvbigpO1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJpdmF0ZSBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsXHJcbiAgICAgICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcixcclxuICAgICAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsXHJcbiAgICAgICAgcHJpdmF0ZSBhZGJVc2VyU2VydmljZTogQWRiVXNlclNlcnZpY2UpIHsgfVxyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5hZGQodGhpcy5hY3RpdmF0ZWRSb3V0ZS5xdWVyeVBhcmFtTWFwLnN1YnNjcmliZShxUGFybWFzID0+IHtcclxuICAgICAgICAgICAgaWYgKHFQYXJtYXMuaGFzKCdjb2RlJykpIHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGJvZHkgPSBgZ3JhbnRfdHlwZT1hdXRob3JpemF0aW9uX2NvZGVgICtcclxuICAgICAgICAgICAgICAgICAgICBgJmNvZGU9JHtlbmNvZGVVUklDb21wb25lbnQocVBhcm1hcy5nZXQoJ2NvZGUnKSl9YCArXHJcbiAgICAgICAgICAgICAgICAgICAgYCZjb2RlX3ZlcmlmaWVyPSR7ZW5jb2RlVVJJQ29tcG9uZW50KHNlc3Npb25TdG9yYWdlLmdldEl0ZW0oVXNlck1vZHVsZUNvbnN0YW50cy5DT0RFX1ZFUklGSUVSKSl9YCArXHJcbiAgICAgICAgICAgICAgICAgICAgYCZyZWRpcmVjdF91cmk9JHtlbmNvZGVVUklDb21wb25lbnQodGhpcy5hZGJVc2VyU2VydmljZS5jb25maWcucmVkaXJlY3RVcmwpfWAgK1xyXG4gICAgICAgICAgICAgICAgICAgIGAmY2xpZW50X2lkPSR7ZW5jb2RlVVJJQ29tcG9uZW50KHRoaXMuYWRiVXNlclNlcnZpY2UuY29uZmlnLmNsaWVudElkKX1gO1xyXG5cclxuICAgICAgICAgICAgICAgIHRoaXMuaHR0cC5wb3N0PGFueT4oYCR7dGhpcy5hZGJVc2VyU2VydmljZS5jb25maWcuaXNzdWVyfS9jb25uZWN0L3Rva2VuYCwgYm9keSxcclxuICAgICAgICAgICAgICAgICAgICB7IGhlYWRlcnM6IG5ldyBIdHRwSGVhZGVycyh7ICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJyB9KSB9KS5zdWJzY3JpYmUoe1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBuZXh0OiByZXNwb25zZSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmFkYlVzZXJTZXJ2aWNlLnNldFRva2Vuc0luU2Vzc2lvbihyZXNwb25zZSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZXQgcmVxdWVzdGVkVXJsID0gc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbShVc2VyTW9kdWxlQ29uc3RhbnRzLkNVUlJFTlRfVVJMKSA/PyBudWxsO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5hZGJVc2VyU2VydmljZS5faW50ZXJuYWxUcmlnZ2VyVXNlckV2ZW50KHJlc3BvbnNlLmFjY2Vzc190b2tlbik7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmFkYlVzZXJTZXJ2aWNlLmxvZygncmVkaXJlY3QgdXJsIGluIGF1dGgtY2FsbGJhY2snLHJlcXVlc3RlZFVybCk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAocmVxdWVzdGVkVXJsKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoW3JlcXVlc3RlZFVybF0sIHsgcmVwbGFjZVVybDogdHJ1ZSB9KS50aGVuKCgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5hZGJVc2VyU2VydmljZS5zdGFydE1haW5Mb29wKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2Vzc2lvblN0b3JhZ2UucmVtb3ZlSXRlbShVc2VyTW9kdWxlQ29uc3RhbnRzLkNVUlJFTlRfVVJMKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1lbHNle1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsnLyddLCB7IHJlcGxhY2VVcmw6IHRydWUgfSkudGhlbigoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuYWRiVXNlclNlcnZpY2Uuc3RhcnRNYWluTG9vcCgpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pOztcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSkpO1xyXG4gICAgfVxyXG59Il19
@@ -2041,6 +2041,7 @@ class UserModuleConstants {
2041
2041
  }
2042
2042
 
2043
2043
  class AdbUserService {
2044
+ // hasEmitted = false;
2044
2045
  constructor(config, http, router) {
2045
2046
  this.config = config;
2046
2047
  this.http = http;
@@ -2049,7 +2050,6 @@ class AdbUserService {
2049
2050
  this.userSubject = new BehaviorSubject(null);
2050
2051
  this.user$ = this.userSubject.asObservable();
2051
2052
  this.lastRefreshTime = 0;
2052
- this.hasEmitted = false;
2053
2053
  this.config = { ...{ scope: 'roles', idleTime: 30, response_type: 'code' }, ...config };
2054
2054
  }
2055
2055
  init() {
@@ -2068,7 +2068,7 @@ class AdbUserService {
2068
2068
  }
2069
2069
  this.router.events.subscribe(event => {
2070
2070
  if (event instanceof NavigationStart) {
2071
- this.login();
2071
+ this.login(event.url);
2072
2072
  }
2073
2073
  });
2074
2074
  }
@@ -2077,14 +2077,16 @@ class AdbUserService {
2077
2077
  this.checkStatus();
2078
2078
  this.intervalId = setInterval(() => this.checkStatus(), 60 * 1000); // 60 seconds * 1000 milliseconds
2079
2079
  }
2080
- login() {
2081
- this.log('url when login', this.router.url);
2082
- sessionStorage.setItem(UserModuleConstants.CURRENT_URL, this.router.url);
2080
+ login(url = null) {
2081
+ this.log('url when login', url);
2082
+ if (url) {
2083
+ sessionStorage.setItem(UserModuleConstants.CURRENT_URL, url);
2084
+ }
2083
2085
  this.authorize();
2084
2086
  }
2085
2087
  logout() {
2086
2088
  clearInterval(this.intervalId);
2087
- this.hasEmitted = false;
2089
+ // this.hasEmitted = false;
2088
2090
  sessionStorage.clear();
2089
2091
  window.location.href = `${this.config.issuer}/connect/endsession?post_logout_redirect_uri=${this.config.postLogoutUrl}`;
2090
2092
  }
@@ -2104,15 +2106,20 @@ class AdbUserService {
2104
2106
  console.log('token is about to timeout but we will refresh it because user has been active the last 5minutes');
2105
2107
  this.refreshToken();
2106
2108
  }
2107
- this.log('hasEmitted', this.hasEmitted);
2108
- if (!this.hasEmitted) {
2109
- const user = this.getUser(accessToken);
2110
- this.userSubject.next(user);
2111
- this.hasEmitted = true;
2112
- }
2109
+ //NOTE: Might not be needed in this variant
2110
+ // if (!this.hasEmitted) {
2111
+ // const user = this.getUser(accessToken);
2112
+ // this.userSubject.next(user);
2113
+ // this.hasEmitted = true;
2114
+ // }
2113
2115
  }
2114
2116
  }
2115
2117
  }
2118
+ //TODO: make it not exported by the module
2119
+ _internalTriggerUserEvent(token) {
2120
+ const user = this.getUser(token);
2121
+ this.userSubject.next(user);
2122
+ }
2116
2123
  refreshToken() {
2117
2124
  const body = `client_id=${encodeURIComponent(this.config.clientId)}&` +
2118
2125
  `grant_type=${encodeURIComponent("refresh_token")}&` +
@@ -2252,6 +2259,7 @@ class AuthCallbackComponent {
2252
2259
  next: response => {
2253
2260
  this.adbUserService.setTokensInSession(response);
2254
2261
  let requestedUrl = sessionStorage.getItem(UserModuleConstants.CURRENT_URL) ?? null;
2262
+ this.adbUserService._internalTriggerUserEvent(response.access_token);
2255
2263
  this.adbUserService.log('redirect url in auth-callback', requestedUrl);
2256
2264
  if (requestedUrl) {
2257
2265
  this.router.navigate([requestedUrl], { replaceUrl: true }).then(() => {