@meshmakers/shared-auth 2.0.2304-13005 → 2.0.2304-23001

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.
@@ -1,134 +1,134 @@
1
- import { Inject, Injectable } from '@angular/core';
2
- import { BehaviorSubject, firstValueFrom } from 'rxjs';
3
- import { filter, map } from 'rxjs/operators';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "angular-oauth2-oidc";
6
- export class AuthorizeOptions {
7
- }
8
- export class AuthorizeService {
9
- constructor(authorizeOptions, oauthService) {
10
- this.authorizeOptions = authorizeOptions;
11
- this.oauthService = oauthService;
12
- this.isAuthenticated = new BehaviorSubject(false);
13
- this.isAdmin = new BehaviorSubject(false);
14
- this.isDeveloper = new BehaviorSubject(false);
15
- this.isManager = new BehaviorSubject(false);
16
- this.authority = new BehaviorSubject(null);
17
- this.accessToken = new BehaviorSubject(null);
18
- this.user = new BehaviorSubject(null);
19
- this.isInitialized = new BehaviorSubject(false);
20
- this.isInitializing = new BehaviorSubject(false);
21
- console.debug("AuthorizeService::created");
22
- this.getUser().subscribe(s => {
23
- this.isAuthenticated.next(!!s);
24
- this.isAdmin.next(!!s && (s.role.includes("Administrators")));
25
- this.isDeveloper.next(!!s && (s.role.includes("Developers")));
26
- this.isManager.next(!!s && s.role.includes("Managers"));
27
- });
28
- this.oauthService.events.subscribe(e => {
29
- // tslint:disable-next-line:no-console
30
- console.debug('oauth/oidc event', e);
31
- });
32
- this.oauthService.events
33
- .pipe(filter(e => e.type === 'session_terminated'))
34
- .subscribe(_ => {
35
- // tslint:disable-next-line:no-console
36
- console.debug('Your session has been terminated!');
37
- });
38
- this.oauthService.events
39
- .pipe(filter(e => e.type === 'token_received'))
40
- .subscribe(_ => {
41
- this.loadUser();
42
- });
43
- this.oauthService.events
44
- .pipe(filter(e => e.type === 'logout'))
45
- .subscribe(_ => {
46
- this.accessToken.next(null);
47
- this.user.next(null);
48
- });
49
- }
50
- getRoles() {
51
- return this.getUser().pipe(map(u => u.role));
52
- }
53
- getServiceUris() {
54
- return this.authorizeOptions.wellKnownServiceUris;
55
- }
56
- getAuthority() {
57
- return this.authority;
58
- }
59
- getIsAuthenticated() {
60
- return this.isAuthenticated;
61
- }
62
- getIsAdmin() {
63
- return this.isAdmin;
64
- }
65
- getIsDeveloper() {
66
- return this.isDeveloper;
67
- }
68
- getIsManager() {
69
- return this.isManager;
70
- }
71
- getAccessToken() {
72
- return this.accessToken;
73
- }
74
- getUser() {
75
- return this.user;
76
- }
77
- login() {
78
- this.oauthService.initImplicitFlow();
79
- }
80
- logout() {
81
- this.oauthService.logOut(false);
82
- }
83
- async initialize() {
84
- console.debug("AuthorizeService::initialize::started");
85
- if (await firstValueFrom(this.isInitializing)) {
86
- return;
87
- }
88
- if (await firstValueFrom(this.isInitialized)) {
89
- return;
90
- }
91
- this.isInitializing.next(true);
92
- const config = {
93
- responseType: 'code',
94
- issuer: this.authorizeOptions.issuer,
95
- redirectUri: this.authorizeOptions.redirectUri,
96
- postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,
97
- clientId: this.authorizeOptions.clientId,
98
- scope: this.authorizeOptions.scope,
99
- showDebugInformation: this.authorizeOptions.showDebugInformation,
100
- sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled
101
- };
102
- this.oauthService.configure(config);
103
- this.oauthService.setStorage(localStorage);
104
- await this.oauthService.loadDiscoveryDocumentAndTryLogin();
105
- this.oauthService.setupAutomaticSilentRefresh();
106
- if (this.oauthService.hasValidAccessToken()) {
107
- this.loadUser();
108
- }
109
- this.authority.next(this.authorizeOptions.issuer);
110
- this.isInitializing.next(false);
111
- this.isInitialized.next(true);
112
- console.debug("AuthorizeService::initialize::done");
113
- }
114
- loadUser() {
115
- const claims = this.oauthService.getIdentityClaims();
116
- if (!claims) {
117
- console.error("claims where null when loading identity claims");
118
- return;
119
- }
120
- const user = claims;
121
- const accessToken = this.oauthService.getAccessToken();
122
- this.user.next(user);
123
- this.accessToken.next(accessToken);
124
- }
125
- }
126
- AuthorizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: AuthorizeService, deps: [{ token: AuthorizeOptions }, { token: i1.OAuthService }], target: i0.ɵɵFactoryTarget.Injectable });
127
- AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: AuthorizeService });
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: AuthorizeService, decorators: [{
129
- type: Injectable
130
- }], ctorParameters: function () { return [{ type: AuthorizeOptions, decorators: [{
131
- type: Inject,
132
- args: [AuthorizeOptions]
133
- }] }, { type: i1.OAuthService }]; } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authorize.service.js","sourceRoot":"","sources":["../../../../../projects/meshmakers/shared-auth/src/lib/authorize.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\r\nimport {BehaviorSubject, firstValueFrom, Observable} from 'rxjs';\r\nimport {filter, map} from 'rxjs/operators';\r\nimport {AuthConfig, OAuthService} from \"angular-oauth2-oidc\";\r\n\r\nexport interface IUser {\r\n  name: string;\r\n  role: string[];\r\n}\r\n\r\nexport class AuthorizeOptions {\r\n  wellKnownServiceUris: string[];\r\n  // Url of the Identity Provider\r\n  issuer: string;\r\n  // URL of the SPA to redirect the user to after login\r\n  redirectUri: string;\r\n  postLogoutRedirectUri: string;\r\n  // The SPA's id. The SPA is registered with this id at the auth-server\r\n  clientId: string;\r\n  // set the scope for the permissions the client should request\r\n  // The first three are defined by OIDC. The 4th is a use case-specific one\r\n  scope: string;\r\n  showDebugInformation: boolean;\r\n  sessionChecksEnabled: boolean;\r\n}\r\n\r\n@Injectable()\r\nexport class AuthorizeService {\r\n  private isAuthenticated: BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n  private isAdmin: BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n  private isDeveloper: BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n  private isManager: BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n  private authority: BehaviorSubject<string> = new BehaviorSubject(null);\r\n  private accessToken: BehaviorSubject<string> = new BehaviorSubject(null);\r\n  private user: BehaviorSubject<IUser> = new BehaviorSubject(null);\r\n  private isInitialized : BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n  private isInitializing : BehaviorSubject<boolean> = new BehaviorSubject(false);\r\n\r\n  constructor(@Inject(AuthorizeOptions) private authorizeOptions: AuthorizeOptions, private oauthService: OAuthService) {\r\n    console.debug(\"AuthorizeService::created\");\r\n\r\n    this.getUser().subscribe(s => {\r\n      this.isAuthenticated.next(!!s);\r\n      this.isAdmin.next(!!s && (s.role.includes(\"Administrators\")));\r\n      this.isDeveloper.next(!!s && (s.role.includes(\"Developers\")));\r\n      this.isManager.next(!!s && s.role.includes(\"Managers\"));\r\n    });\r\n\r\n    this.oauthService.events.subscribe(e => {\r\n      // tslint:disable-next-line:no-console\r\n      console.debug('oauth/oidc event', e);\r\n    });\r\n\r\n    this.oauthService.events\r\n      .pipe(filter(e => e.type === 'session_terminated'))\r\n      .subscribe(_ => {\r\n        // tslint:disable-next-line:no-console\r\n        console.debug('Your session has been terminated!');\r\n      });\r\n\r\n    this.oauthService.events\r\n      .pipe(filter(e => e.type === 'token_received'))\r\n      .subscribe(_ => {\r\n        this.loadUser();\r\n      });\r\n\r\n    this.oauthService.events\r\n      .pipe(filter(e => e.type === 'logout'))\r\n      .subscribe(_ => {\r\n        this.accessToken.next(null);\r\n        this.user.next(null);\r\n      });\r\n\r\n  }\r\n\r\n  public getRoles(): Observable<Array<string>>{\r\n    return this.getUser().pipe(\r\n      map(u=> u.role)\r\n    );\r\n  }\r\n\r\n  public getServiceUris(): Array<string> {\r\n    return this.authorizeOptions.wellKnownServiceUris;\r\n  }\r\n\r\n  public getAuthority(): BehaviorSubject<string> {\r\n    return this.authority;\r\n  }\r\n\r\n  public getIsAuthenticated(): BehaviorSubject<boolean> {\r\n    return this.isAuthenticated;\r\n  }\r\n\r\n  public getIsAdmin(): BehaviorSubject<boolean> {\r\n    return this.isAdmin;\r\n  }\r\n\r\n  public getIsDeveloper(): BehaviorSubject<boolean> {\r\n    return this.isDeveloper;\r\n  }\r\n\r\n  public getIsManager(): BehaviorSubject<boolean> {\r\n    return this.isManager;\r\n  }\r\n\r\n  public getAccessToken(): BehaviorSubject<string> {\r\n    return this.accessToken;\r\n  }\r\n\r\n  public getUser(): BehaviorSubject<IUser> {\r\n    return this.user;\r\n  }\r\n\r\n  public login() {\r\n    this.oauthService.initImplicitFlow();\r\n  }\r\n\r\n  public logout() {\r\n    this.oauthService.logOut(false);\r\n  }\r\n\r\n\r\n  public async initialize() {\r\n\r\n    console.debug(\"AuthorizeService::initialize::started\");\r\n\r\n    if (await firstValueFrom(this.isInitializing)) {\r\n      return\r\n    }\r\n    if (await firstValueFrom(this.isInitialized)) {\r\n      return;\r\n    }\r\n    this.isInitializing.next(true);\r\n\r\n    const config: AuthConfig = {\r\n      responseType: 'code',\r\n      issuer: this.authorizeOptions.issuer,\r\n      redirectUri: this.authorizeOptions.redirectUri,\r\n      postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,\r\n      clientId: this.authorizeOptions.clientId,\r\n      scope: this.authorizeOptions.scope,\r\n      showDebugInformation: this.authorizeOptions.showDebugInformation,\r\n      sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled\r\n    };\r\n\r\n    this.oauthService.configure(config);\r\n    this.oauthService.setStorage(localStorage);\r\n    await this.oauthService.loadDiscoveryDocumentAndTryLogin();\r\n\r\n    this.oauthService.setupAutomaticSilentRefresh();\r\n\r\n    if (this.oauthService.hasValidAccessToken()) {\r\n      this.loadUser();\r\n    }\r\n\r\n    this.authority.next(this.authorizeOptions.issuer);\r\n    this.isInitializing.next(false);\r\n    this.isInitialized.next(true);\r\n\r\n    console.debug(\"AuthorizeService::initialize::done\");\r\n  }\r\n\r\n  private loadUser() {\r\n    const claims = this.oauthService.getIdentityClaims();\r\n    if (!claims) {\r\n      console.error(\"claims where null when loading identity claims\");\r\n      return;\r\n    }\r\n\r\n    const user = <IUser>claims;\r\n    const accessToken = this.oauthService.getAccessToken();\r\n    this.user.next(user);\r\n    this.accessToken.next(accessToken);\r\n  }\r\n}\r\n"]}
1
+ import { Inject, Injectable } from '@angular/core';
2
+ import { BehaviorSubject, firstValueFrom } from 'rxjs';
3
+ import { filter, map } from 'rxjs/operators';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "angular-oauth2-oidc";
6
+ export class AuthorizeOptions {
7
+ }
8
+ export class AuthorizeService {
9
+ constructor(authorizeOptions, oauthService) {
10
+ this.authorizeOptions = authorizeOptions;
11
+ this.oauthService = oauthService;
12
+ this.isAuthenticated = new BehaviorSubject(false);
13
+ this.isAdmin = new BehaviorSubject(false);
14
+ this.isDeveloper = new BehaviorSubject(false);
15
+ this.isManager = new BehaviorSubject(false);
16
+ this.authority = new BehaviorSubject(null);
17
+ this.accessToken = new BehaviorSubject(null);
18
+ this.user = new BehaviorSubject(null);
19
+ this.isInitialized = new BehaviorSubject(false);
20
+ this.isInitializing = new BehaviorSubject(false);
21
+ console.debug("AuthorizeService::created");
22
+ this.getUser().subscribe(s => {
23
+ this.isAuthenticated.next(!!s);
24
+ this.isAdmin.next(!!s && (s.role.includes("Administrators")));
25
+ this.isDeveloper.next(!!s && (s.role.includes("Developers")));
26
+ this.isManager.next(!!s && s.role.includes("Managers"));
27
+ });
28
+ this.oauthService.events.subscribe(e => {
29
+ // tslint:disable-next-line:no-console
30
+ console.debug('oauth/oidc event', e);
31
+ });
32
+ this.oauthService.events
33
+ .pipe(filter(e => e.type === 'session_terminated'))
34
+ .subscribe(_ => {
35
+ // tslint:disable-next-line:no-console
36
+ console.debug('Your session has been terminated!');
37
+ });
38
+ this.oauthService.events
39
+ .pipe(filter(e => e.type === 'token_received'))
40
+ .subscribe(_ => {
41
+ this.loadUser();
42
+ });
43
+ this.oauthService.events
44
+ .pipe(filter(e => e.type === 'logout'))
45
+ .subscribe(_ => {
46
+ this.accessToken.next(null);
47
+ this.user.next(null);
48
+ });
49
+ }
50
+ getRoles() {
51
+ return this.getUser().pipe(map(u => u != null ? u.role : new Array()));
52
+ }
53
+ getServiceUris() {
54
+ return this.authorizeOptions.wellKnownServiceUris ?? null;
55
+ }
56
+ getAuthority() {
57
+ return this.authority;
58
+ }
59
+ getIsAuthenticated() {
60
+ return this.isAuthenticated;
61
+ }
62
+ getIsAdmin() {
63
+ return this.isAdmin;
64
+ }
65
+ getIsDeveloper() {
66
+ return this.isDeveloper;
67
+ }
68
+ getIsManager() {
69
+ return this.isManager;
70
+ }
71
+ getAccessToken() {
72
+ return this.accessToken;
73
+ }
74
+ getUser() {
75
+ return this.user;
76
+ }
77
+ login() {
78
+ this.oauthService.initImplicitFlow();
79
+ }
80
+ logout() {
81
+ this.oauthService.logOut(false);
82
+ }
83
+ async initialize() {
84
+ console.debug("AuthorizeService::initialize::started");
85
+ if (await firstValueFrom(this.isInitializing)) {
86
+ return;
87
+ }
88
+ if (await firstValueFrom(this.isInitialized)) {
89
+ return;
90
+ }
91
+ this.isInitializing.next(true);
92
+ const config = {
93
+ responseType: 'code',
94
+ issuer: this.authorizeOptions.issuer,
95
+ redirectUri: this.authorizeOptions.redirectUri,
96
+ postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,
97
+ clientId: this.authorizeOptions.clientId,
98
+ scope: this.authorizeOptions.scope,
99
+ showDebugInformation: this.authorizeOptions.showDebugInformation,
100
+ sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled
101
+ };
102
+ this.oauthService.configure(config);
103
+ this.oauthService.setStorage(localStorage);
104
+ await this.oauthService.loadDiscoveryDocumentAndTryLogin();
105
+ this.oauthService.setupAutomaticSilentRefresh();
106
+ if (this.oauthService.hasValidAccessToken()) {
107
+ this.loadUser();
108
+ }
109
+ this.authority.next(this.authorizeOptions.issuer ?? null);
110
+ this.isInitializing.next(false);
111
+ this.isInitialized.next(true);
112
+ console.debug("AuthorizeService::initialize::done");
113
+ }
114
+ loadUser() {
115
+ const claims = this.oauthService.getIdentityClaims();
116
+ if (!claims) {
117
+ console.error("claims where null when loading identity claims");
118
+ return;
119
+ }
120
+ const user = claims;
121
+ const accessToken = this.oauthService.getAccessToken();
122
+ this.user.next(user);
123
+ this.accessToken.next(accessToken);
124
+ }
125
+ }
126
+ AuthorizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeService, deps: [{ token: AuthorizeOptions }, { token: i1.OAuthService }], target: i0.ɵɵFactoryTarget.Injectable });
127
+ AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeService });
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeService, decorators: [{
129
+ type: Injectable
130
+ }], ctorParameters: function () { return [{ type: AuthorizeOptions, decorators: [{
131
+ type: Inject,
132
+ args: [AuthorizeOptions]
133
+ }] }, { type: i1.OAuthService }]; } });
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authorize.service.js","sourceRoot":"","sources":["../../../../../projects/meshmakers/shared-auth/src/lib/authorize.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {BehaviorSubject, firstValueFrom, Observable} from 'rxjs';\nimport {filter, map} from 'rxjs/operators';\nimport {AuthConfig, OAuthService} from \"angular-oauth2-oidc\";\n\nexport interface IUser {\n  name: string;\n  role: string[];\n}\n\nexport class AuthorizeOptions {\n  wellKnownServiceUris?: string[];\n  // Url of the Identity Provider\n  issuer?: string;\n  // URL of the SPA to redirect the user to after login\n  redirectUri?: string;\n  postLogoutRedirectUri?: string;\n  // The SPA's id. The SPA is registered with this id at the auth-server\n  clientId?: string;\n  // set the scope for the permissions the client should request\n  // The first three are defined by OIDC. The 4th is a use case-specific one\n  scope?: string;\n  showDebugInformation?: boolean;\n  sessionChecksEnabled?: boolean;\n}\n\n@Injectable()\nexport class AuthorizeService {\n  private isAuthenticated: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private isAdmin: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private isDeveloper: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private isManager: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private authority: BehaviorSubject<string | null> = new BehaviorSubject<string | null>(null);\n  private accessToken: BehaviorSubject<string | null> = new BehaviorSubject<string | null>(null);\n  private user: BehaviorSubject<IUser | null> = new BehaviorSubject<IUser | null>(null);\n  private isInitialized : BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private isInitializing : BehaviorSubject<boolean> = new BehaviorSubject(false);\n\n  constructor(@Inject(AuthorizeOptions) private authorizeOptions: AuthorizeOptions, private oauthService: OAuthService) {\n    console.debug(\"AuthorizeService::created\");\n\n    this.getUser().subscribe(s => {\n      this.isAuthenticated.next(!!s);\n      this.isAdmin.next(!!s && (s.role.includes(\"Administrators\")));\n      this.isDeveloper.next(!!s && (s.role.includes(\"Developers\")));\n      this.isManager.next(!!s && s.role.includes(\"Managers\"));\n    });\n\n    this.oauthService.events.subscribe(e => {\n      // tslint:disable-next-line:no-console\n      console.debug('oauth/oidc event', e);\n    });\n\n    this.oauthService.events\n      .pipe(filter(e => e.type === 'session_terminated'))\n      .subscribe(_ => {\n        // tslint:disable-next-line:no-console\n        console.debug('Your session has been terminated!');\n      });\n\n    this.oauthService.events\n      .pipe(filter(e => e.type === 'token_received'))\n      .subscribe(_ => {\n        this.loadUser();\n      });\n\n    this.oauthService.events\n      .pipe(filter(e => e.type === 'logout'))\n      .subscribe(_ => {\n        this.accessToken.next(null);\n        this.user.next(null);\n      });\n\n  }\n\n  public getRoles(): Observable<Array<string>>{\n    return this.getUser().pipe(\n      map(u=> u != null ? u.role : new Array<string>())\n    );\n  }\n\n  public getServiceUris(): Array<string> | null {\n    return this.authorizeOptions.wellKnownServiceUris ?? null;\n  }\n\n  public getAuthority(): BehaviorSubject<string | null> {\n    return this.authority;\n  }\n\n  public getIsAuthenticated(): BehaviorSubject<boolean> {\n    return this.isAuthenticated;\n  }\n\n  public getIsAdmin(): BehaviorSubject<boolean> {\n    return this.isAdmin;\n  }\n\n  public getIsDeveloper(): BehaviorSubject<boolean> {\n    return this.isDeveloper;\n  }\n\n  public getIsManager(): BehaviorSubject<boolean> {\n    return this.isManager;\n  }\n\n  public getAccessToken(): BehaviorSubject<string | null> {\n    return this.accessToken;\n  }\n\n  public getUser(): BehaviorSubject<IUser | null> {\n    return this.user;\n  }\n\n  public login() {\n    this.oauthService.initImplicitFlow();\n  }\n\n  public logout() {\n    this.oauthService.logOut(false);\n  }\n\n\n  public async initialize() {\n\n    console.debug(\"AuthorizeService::initialize::started\");\n\n    if (await firstValueFrom(this.isInitializing)) {\n      return\n    }\n    if (await firstValueFrom(this.isInitialized)) {\n      return;\n    }\n    this.isInitializing.next(true);\n\n    const config: AuthConfig = {\n      responseType: 'code',\n      issuer: this.authorizeOptions.issuer,\n      redirectUri: this.authorizeOptions.redirectUri,\n      postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,\n      clientId: this.authorizeOptions.clientId,\n      scope: this.authorizeOptions.scope,\n      showDebugInformation: this.authorizeOptions.showDebugInformation,\n      sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled\n    };\n\n    this.oauthService.configure(config);\n    this.oauthService.setStorage(localStorage);\n    await this.oauthService.loadDiscoveryDocumentAndTryLogin();\n\n    this.oauthService.setupAutomaticSilentRefresh();\n\n    if (this.oauthService.hasValidAccessToken()) {\n      this.loadUser();\n    }\n\n    this.authority.next(this.authorizeOptions.issuer ?? null);\n    this.isInitializing.next(false);\n    this.isInitialized.next(true);\n\n    console.debug(\"AuthorizeService::initialize::done\");\n  }\n\n  private loadUser() {\n    const claims = this.oauthService.getIdentityClaims();\n    if (!claims) {\n      console.error(\"claims where null when loading identity claims\");\n      return;\n    }\n\n    const user = <IUser>claims;\n    const accessToken = this.oauthService.getAccessToken();\n    this.user.next(user);\n    this.accessToken.next(accessToken);\n  }\n}\n"]}
@@ -1,35 +1,35 @@
1
- import { Component } from '@angular/core';
2
- import { map } from 'rxjs/operators';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../authorize.service";
5
- import * as i2 from "@angular/common";
6
- export class LoginMenuComponent {
7
- constructor(authorizeService) {
8
- this.authorizeService = authorizeService;
9
- }
10
- ngOnInit() {
11
- const isIFrame = window.self !== window.top;
12
- console.log("app-login-menu::created");
13
- this.isAuthenticated = this.authorizeService.getIsAuthenticated();
14
- this.userName = this.authorizeService.getUser().pipe(map(u => u && u.name));
15
- this.isAdmin = this.authorizeService.getIsAdmin();
16
- this.isAuthenticated.subscribe(x => {
17
- console.log(`isAuthenticated changed to ${x} (iframe ${isIFrame})`);
18
- });
19
- }
20
- login() {
21
- this.authorizeService.login();
22
- }
23
- logout() {
24
- this.authorizeService.logout();
25
- }
26
- register() {
27
- }
28
- }
29
- LoginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: LoginMenuComponent, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Component });
30
- LoginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.3", type: LoginMenuComponent, selector: "app-login-menu", ngImport: i0, template: "<ul *ngIf=\"isAuthenticated | async\" class=\"navbar-nav\">\r\n <li class=\"nav-item dropdown\">\r\n <a aria-expanded=\"false\" aria-haspopup=\"true\" class=\"nav-link dropdown-toggle\" data-toggle=\"dropdown\" href=\"#\"\r\n id=\"navbarDropdownLogin\" role=\"button\">\r\n {{ userName | async }} <b class=\"caret\"></b>\r\n </a>\r\n <div aria-labelledby=\"navbarDropdown\" class=\"dropdown-menu\">\r\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Grants\">Client Application Access</a>-->\r\n <!--<a class=\"dropdown-item\" [routerLink]='[\"/authentication/profile\"]' title=\"Manage\">Manage</a>-->\r\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Diagnostics\">Diagnostics</a>-->\r\n <div class=\"dropdown-divider\"></div>\r\n <a (click)='logout()' class=\"dropdown-item\" routerLink=\"\" title=\"Logout\">Logout</a>\r\n </div>\r\n </li>\r\n</ul>\r\n<ul *ngIf=\"!(isAuthenticated | async)\" class=\"navbar-nav\">\r\n <li class=\"nav-item\">\r\n <a (click)='register()' class=\"nav-link\" routerLink=\"\">Register</a>\r\n </li>\r\n <li class=\"nav-item\">\r\n <a (click)='login()' class=\"nav-link\" routerLink=\"\">Login</a>\r\n </li>\r\n</ul>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] });
31
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: LoginMenuComponent, decorators: [{
32
- type: Component,
33
- args: [{ selector: 'app-login-menu', template: "<ul *ngIf=\"isAuthenticated | async\" class=\"navbar-nav\">\r\n <li class=\"nav-item dropdown\">\r\n <a aria-expanded=\"false\" aria-haspopup=\"true\" class=\"nav-link dropdown-toggle\" data-toggle=\"dropdown\" href=\"#\"\r\n id=\"navbarDropdownLogin\" role=\"button\">\r\n {{ userName | async }} <b class=\"caret\"></b>\r\n </a>\r\n <div aria-labelledby=\"navbarDropdown\" class=\"dropdown-menu\">\r\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Grants\">Client Application Access</a>-->\r\n <!--<a class=\"dropdown-item\" [routerLink]='[\"/authentication/profile\"]' title=\"Manage\">Manage</a>-->\r\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Diagnostics\">Diagnostics</a>-->\r\n <div class=\"dropdown-divider\"></div>\r\n <a (click)='logout()' class=\"dropdown-item\" routerLink=\"\" title=\"Logout\">Logout</a>\r\n </div>\r\n </li>\r\n</ul>\r\n<ul *ngIf=\"!(isAuthenticated | async)\" class=\"navbar-nav\">\r\n <li class=\"nav-item\">\r\n <a (click)='register()' class=\"nav-link\" routerLink=\"\">Register</a>\r\n </li>\r\n <li class=\"nav-item\">\r\n <a (click)='login()' class=\"nav-link\" routerLink=\"\">Login</a>\r\n </li>\r\n</ul>\r\n" }]
34
- }], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tbWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZXNobWFrZXJzL3NoYXJlZC1hdXRoL3NyYy9saWIvbG9naW4tbWVudS9sb2dpbi1tZW51LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21lc2htYWtlcnMvc2hhcmVkLWF1dGgvc3JjL2xpYi9sb2dpbi1tZW51L2xvZ2luLW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUdoRCxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFPbkMsTUFBTSxPQUFPLGtCQUFrQjtJQUs3QixZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUN0RCxDQUFDO0lBRUQsUUFBUTtRQUNOLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLEdBQUcsQ0FBQztRQUU1QyxPQUFPLENBQUMsR0FBRyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFFdkMsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztRQUNsRSxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxDQUFDO1FBRWxELElBQUksQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBRWpDLE9BQU8sQ0FBQyxHQUFHLENBQUMsOEJBQThCLENBQUMsWUFBWSxRQUFRLEdBQUcsQ0FBQyxDQUFDO1FBQ3RFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLE1BQU07UUFDWCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVNLFFBQVE7SUFFZixDQUFDOzsrR0FqQ1Usa0JBQWtCO21HQUFsQixrQkFBa0Isc0RDVi9CLG95Q0F1QkE7MkZEYmEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0F1dGhvcml6ZVNlcnZpY2V9IGZyb20gJy4uL2F1dGhvcml6ZS5zZXJ2aWNlJztcclxuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGV9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtbG9naW4tbWVudScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2xvZ2luLW1lbnUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2xvZ2luLW1lbnUuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMb2dpbk1lbnVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHB1YmxpYyBpc0F1dGhlbnRpY2F0ZWQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPjtcclxuICBwdWJsaWMgdXNlck5hbWU6IE9ic2VydmFibGU8c3RyaW5nPjtcclxuICBwdWJsaWMgaXNBZG1pbjogT2JzZXJ2YWJsZTxib29sZWFuPjtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRob3JpemVTZXJ2aWNlOiBBdXRob3JpemVTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIGNvbnN0IGlzSUZyYW1lID0gd2luZG93LnNlbGYgIT09IHdpbmRvdy50b3A7XHJcblxyXG4gICAgY29uc29sZS5sb2coXCJhcHAtbG9naW4tbWVudTo6Y3JlYXRlZFwiKTtcclxuXHJcbiAgICB0aGlzLmlzQXV0aGVudGljYXRlZCA9IHRoaXMuYXV0aG9yaXplU2VydmljZS5nZXRJc0F1dGhlbnRpY2F0ZWQoKTtcclxuICAgIHRoaXMudXNlck5hbWUgPSB0aGlzLmF1dGhvcml6ZVNlcnZpY2UuZ2V0VXNlcigpLnBpcGUobWFwKHUgPT4gdSAmJiB1Lm5hbWUpKTtcclxuICAgIHRoaXMuaXNBZG1pbiA9IHRoaXMuYXV0aG9yaXplU2VydmljZS5nZXRJc0FkbWluKCk7XHJcblxyXG4gICAgdGhpcy5pc0F1dGhlbnRpY2F0ZWQuc3Vic2NyaWJlKHggPT4ge1xyXG5cclxuICAgICAgY29uc29sZS5sb2coYGlzQXV0aGVudGljYXRlZCBjaGFuZ2VkIHRvICR7eH0gKGlmcmFtZSAke2lzSUZyYW1lfSlgKTtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGxvZ2luKCkge1xyXG4gICAgdGhpcy5hdXRob3JpemVTZXJ2aWNlLmxvZ2luKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbG9nb3V0KCkge1xyXG4gICAgdGhpcy5hdXRob3JpemVTZXJ2aWNlLmxvZ291dCgpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJlZ2lzdGVyKCkge1xyXG5cclxuICB9XHJcbn1cclxuIiwiPHVsICpuZ0lmPVwiaXNBdXRoZW50aWNhdGVkIHwgYXN5bmNcIiBjbGFzcz1cIm5hdmJhci1uYXZcIj5cclxuICA8bGkgY2xhc3M9XCJuYXYtaXRlbSBkcm9wZG93blwiPlxyXG4gICAgPGEgYXJpYS1leHBhbmRlZD1cImZhbHNlXCIgYXJpYS1oYXNwb3B1cD1cInRydWVcIiBjbGFzcz1cIm5hdi1saW5rIGRyb3Bkb3duLXRvZ2dsZVwiIGRhdGEtdG9nZ2xlPVwiZHJvcGRvd25cIiBocmVmPVwiI1wiXHJcbiAgICAgICBpZD1cIm5hdmJhckRyb3Bkb3duTG9naW5cIiByb2xlPVwiYnV0dG9uXCI+XHJcbiAgICAgIHt7IHVzZXJOYW1lIHwgYXN5bmMgfX0gPGIgY2xhc3M9XCJjYXJldFwiPjwvYj5cclxuICAgIDwvYT5cclxuICAgIDxkaXYgYXJpYS1sYWJlbGxlZGJ5PVwibmF2YmFyRHJvcGRvd25cIiBjbGFzcz1cImRyb3Bkb3duLW1lbnVcIj5cclxuICAgICAgPCEtLTxhIGNsYXNzPVwiZHJvcGRvd24taXRlbVwiIGFzcC1hY3Rpb249XCJJbmRleFwiIGFzcC1hcmVhPVwiQXV0aGVudGljYXRpb25cIiBhc3AtY29udHJvbGxlcj1cIkdyYW50c1wiPkNsaWVudCBBcHBsaWNhdGlvbiBBY2Nlc3M8L2E+LS0+XHJcbiAgICAgIDwhLS08YSBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIiBbcm91dGVyTGlua109J1tcIi9hdXRoZW50aWNhdGlvbi9wcm9maWxlXCJdJyB0aXRsZT1cIk1hbmFnZVwiPk1hbmFnZTwvYT4tLT5cclxuICAgICAgPCEtLTxhIGNsYXNzPVwiZHJvcGRvd24taXRlbVwiIGFzcC1hY3Rpb249XCJJbmRleFwiIGFzcC1hcmVhPVwiQXV0aGVudGljYXRpb25cIiBhc3AtY29udHJvbGxlcj1cIkRpYWdub3N0aWNzXCI+RGlhZ25vc3RpY3M8L2E+LS0+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJkcm9wZG93bi1kaXZpZGVyXCI+PC9kaXY+XHJcbiAgICAgIDxhIChjbGljayk9J2xvZ291dCgpJyBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIiByb3V0ZXJMaW5rPVwiXCIgdGl0bGU9XCJMb2dvdXRcIj5Mb2dvdXQ8L2E+XHJcbiAgICA8L2Rpdj5cclxuICA8L2xpPlxyXG48L3VsPlxyXG48dWwgKm5nSWY9XCIhKGlzQXV0aGVudGljYXRlZCB8IGFzeW5jKVwiIGNsYXNzPVwibmF2YmFyLW5hdlwiPlxyXG4gIDxsaSBjbGFzcz1cIm5hdi1pdGVtXCI+XHJcbiAgICA8YSAoY2xpY2spPSdyZWdpc3RlcigpJyBjbGFzcz1cIm5hdi1saW5rXCIgcm91dGVyTGluaz1cIlwiPlJlZ2lzdGVyPC9hPlxyXG4gIDwvbGk+XHJcbiAgPGxpIGNsYXNzPVwibmF2LWl0ZW1cIj5cclxuICAgIDxhIChjbGljayk9J2xvZ2luKCknIGNsYXNzPVwibmF2LWxpbmtcIiByb3V0ZXJMaW5rPVwiXCI+TG9naW48L2E+XHJcbiAgPC9saT5cclxuPC91bD5cclxuIl19
1
+ import { Component } from '@angular/core';
2
+ import { map } from 'rxjs/operators';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../authorize.service";
5
+ import * as i2 from "@angular/common";
6
+ export class LoginMenuComponent {
7
+ constructor(authorizeService) {
8
+ this.authorizeService = authorizeService;
9
+ this.isAuthenticated = this.authorizeService.getIsAuthenticated();
10
+ this.userName = this.authorizeService.getUser().pipe(map(u => u && u.name));
11
+ this.isAdmin = this.authorizeService.getIsAdmin();
12
+ }
13
+ ngOnInit() {
14
+ const isIFrame = window.self !== window.top;
15
+ console.log("app-login-menu::created");
16
+ this.isAuthenticated.subscribe(x => {
17
+ console.log(`isAuthenticated changed to ${x} (iframe ${isIFrame})`);
18
+ });
19
+ }
20
+ login() {
21
+ this.authorizeService.login();
22
+ }
23
+ logout() {
24
+ this.authorizeService.logout();
25
+ }
26
+ register() {
27
+ }
28
+ }
29
+ LoginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: LoginMenuComponent, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Component });
30
+ LoginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: LoginMenuComponent, selector: "app-login-menu", ngImport: i0, template: "<ul *ngIf=\"isAuthenticated | async\" class=\"navbar-nav\">\n <li class=\"nav-item dropdown\">\n <a aria-expanded=\"false\" aria-haspopup=\"true\" class=\"nav-link dropdown-toggle\" data-toggle=\"dropdown\" href=\"#\"\n id=\"navbarDropdownLogin\" role=\"button\">\n {{ userName | async }} <b class=\"caret\"></b>\n </a>\n <div aria-labelledby=\"navbarDropdown\" class=\"dropdown-menu\">\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Grants\">Client Application Access</a>-->\n <!--<a class=\"dropdown-item\" [routerLink]='[\"/authentication/profile\"]' title=\"Manage\">Manage</a>-->\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Diagnostics\">Diagnostics</a>-->\n <div class=\"dropdown-divider\"></div>\n <a (click)='logout()' class=\"dropdown-item\" routerLink=\"\" title=\"Logout\">Logout</a>\n </div>\n </li>\n</ul>\n<ul *ngIf=\"!(isAuthenticated | async)\" class=\"navbar-nav\">\n <li class=\"nav-item\">\n <a (click)='register()' class=\"nav-link\" routerLink=\"\">Register</a>\n </li>\n <li class=\"nav-item\">\n <a (click)='login()' class=\"nav-link\" routerLink=\"\">Login</a>\n </li>\n</ul>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] });
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: LoginMenuComponent, decorators: [{
32
+ type: Component,
33
+ args: [{ selector: 'app-login-menu', template: "<ul *ngIf=\"isAuthenticated | async\" class=\"navbar-nav\">\n <li class=\"nav-item dropdown\">\n <a aria-expanded=\"false\" aria-haspopup=\"true\" class=\"nav-link dropdown-toggle\" data-toggle=\"dropdown\" href=\"#\"\n id=\"navbarDropdownLogin\" role=\"button\">\n {{ userName | async }} <b class=\"caret\"></b>\n </a>\n <div aria-labelledby=\"navbarDropdown\" class=\"dropdown-menu\">\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Grants\">Client Application Access</a>-->\n <!--<a class=\"dropdown-item\" [routerLink]='[\"/authentication/profile\"]' title=\"Manage\">Manage</a>-->\n <!--<a class=\"dropdown-item\" asp-action=\"Index\" asp-area=\"Authentication\" asp-controller=\"Diagnostics\">Diagnostics</a>-->\n <div class=\"dropdown-divider\"></div>\n <a (click)='logout()' class=\"dropdown-item\" routerLink=\"\" title=\"Logout\">Logout</a>\n </div>\n </li>\n</ul>\n<ul *ngIf=\"!(isAuthenticated | async)\" class=\"navbar-nav\">\n <li class=\"nav-item\">\n <a (click)='register()' class=\"nav-link\" routerLink=\"\">Register</a>\n </li>\n <li class=\"nav-item\">\n <a (click)='login()' class=\"nav-link\" routerLink=\"\">Login</a>\n </li>\n</ul>\n" }]
34
+ }], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tbWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZXNobWFrZXJzL3NoYXJlZC1hdXRoL3NyYy9saWIvbG9naW4tbWVudS9sb2dpbi1tZW51LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21lc2htYWtlcnMvc2hhcmVkLWF1dGgvc3JjL2xpYi9sb2dpbi1tZW51L2xvZ2luLW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUdoRCxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFPbkMsTUFBTSxPQUFPLGtCQUFrQjtJQUs3QixZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNwRCxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQ2xFLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDNUUsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDcEQsQ0FBQztJQUVELFFBQVE7UUFDTixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsSUFBSSxLQUFLLE1BQU0sQ0FBQyxHQUFHLENBQUM7UUFFNUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBRXZDLElBQUksQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBRWpDLE9BQU8sQ0FBQyxHQUFHLENBQUMsOEJBQThCLENBQUMsWUFBWSxRQUFRLEdBQUcsQ0FBQyxDQUFDO1FBQ3RFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLE1BQU07UUFDWCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVNLFFBQVE7SUFFZixDQUFDOzsrR0FoQ1Usa0JBQWtCO21HQUFsQixrQkFBa0Isc0RDVi9CLHN2Q0F1QkE7MkZEYmEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBdXRob3JpemVTZXJ2aWNlfSBmcm9tICcuLi9hdXRob3JpemUuc2VydmljZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtbG9naW4tbWVudScsXG4gIHRlbXBsYXRlVXJsOiAnLi9sb2dpbi1tZW51LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbG9naW4tbWVudS5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgTG9naW5NZW51Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHVibGljIGlzQXV0aGVudGljYXRlZDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+O1xuICBwdWJsaWMgdXNlck5hbWU6IE9ic2VydmFibGU8c3RyaW5nIHwgbnVsbD47XG4gIHB1YmxpYyBpc0FkbWluOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYXV0aG9yaXplU2VydmljZTogQXV0aG9yaXplU2VydmljZSkge1xuICAgIHRoaXMuaXNBdXRoZW50aWNhdGVkID0gdGhpcy5hdXRob3JpemVTZXJ2aWNlLmdldElzQXV0aGVudGljYXRlZCgpO1xuICAgIHRoaXMudXNlck5hbWUgPSB0aGlzLmF1dGhvcml6ZVNlcnZpY2UuZ2V0VXNlcigpLnBpcGUobWFwKHUgPT4gdSAmJiB1Lm5hbWUpKTtcbiAgICB0aGlzLmlzQWRtaW4gPSB0aGlzLmF1dGhvcml6ZVNlcnZpY2UuZ2V0SXNBZG1pbigpO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgaXNJRnJhbWUgPSB3aW5kb3cuc2VsZiAhPT0gd2luZG93LnRvcDtcblxuICAgIGNvbnNvbGUubG9nKFwiYXBwLWxvZ2luLW1lbnU6OmNyZWF0ZWRcIik7XG5cbiAgICB0aGlzLmlzQXV0aGVudGljYXRlZC5zdWJzY3JpYmUoeCA9PiB7XG5cbiAgICAgIGNvbnNvbGUubG9nKGBpc0F1dGhlbnRpY2F0ZWQgY2hhbmdlZCB0byAke3h9IChpZnJhbWUgJHtpc0lGcmFtZX0pYCk7XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgbG9naW4oKSB7XG4gICAgdGhpcy5hdXRob3JpemVTZXJ2aWNlLmxvZ2luKCk7XG4gIH1cblxuICBwdWJsaWMgbG9nb3V0KCkge1xuICAgIHRoaXMuYXV0aG9yaXplU2VydmljZS5sb2dvdXQoKTtcbiAgfVxuXG4gIHB1YmxpYyByZWdpc3RlcigpIHtcblxuICB9XG59XG4iLCI8dWwgKm5nSWY9XCJpc0F1dGhlbnRpY2F0ZWQgfCBhc3luY1wiIGNsYXNzPVwibmF2YmFyLW5hdlwiPlxuICA8bGkgY2xhc3M9XCJuYXYtaXRlbSBkcm9wZG93blwiPlxuICAgIDxhIGFyaWEtZXhwYW5kZWQ9XCJmYWxzZVwiIGFyaWEtaGFzcG9wdXA9XCJ0cnVlXCIgY2xhc3M9XCJuYXYtbGluayBkcm9wZG93bi10b2dnbGVcIiBkYXRhLXRvZ2dsZT1cImRyb3Bkb3duXCIgaHJlZj1cIiNcIlxuICAgICAgIGlkPVwibmF2YmFyRHJvcGRvd25Mb2dpblwiIHJvbGU9XCJidXR0b25cIj5cbiAgICAgIHt7IHVzZXJOYW1lIHwgYXN5bmMgfX0gPGIgY2xhc3M9XCJjYXJldFwiPjwvYj5cbiAgICA8L2E+XG4gICAgPGRpdiBhcmlhLWxhYmVsbGVkYnk9XCJuYXZiYXJEcm9wZG93blwiIGNsYXNzPVwiZHJvcGRvd24tbWVudVwiPlxuICAgICAgPCEtLTxhIGNsYXNzPVwiZHJvcGRvd24taXRlbVwiIGFzcC1hY3Rpb249XCJJbmRleFwiIGFzcC1hcmVhPVwiQXV0aGVudGljYXRpb25cIiBhc3AtY29udHJvbGxlcj1cIkdyYW50c1wiPkNsaWVudCBBcHBsaWNhdGlvbiBBY2Nlc3M8L2E+LS0+XG4gICAgICA8IS0tPGEgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCIgW3JvdXRlckxpbmtdPSdbXCIvYXV0aGVudGljYXRpb24vcHJvZmlsZVwiXScgdGl0bGU9XCJNYW5hZ2VcIj5NYW5hZ2U8L2E+LS0+XG4gICAgICA8IS0tPGEgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCIgYXNwLWFjdGlvbj1cIkluZGV4XCIgYXNwLWFyZWE9XCJBdXRoZW50aWNhdGlvblwiIGFzcC1jb250cm9sbGVyPVwiRGlhZ25vc3RpY3NcIj5EaWFnbm9zdGljczwvYT4tLT5cbiAgICAgIDxkaXYgY2xhc3M9XCJkcm9wZG93bi1kaXZpZGVyXCI+PC9kaXY+XG4gICAgICA8YSAoY2xpY2spPSdsb2dvdXQoKScgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCIgcm91dGVyTGluaz1cIlwiIHRpdGxlPVwiTG9nb3V0XCI+TG9nb3V0PC9hPlxuICAgIDwvZGl2PlxuICA8L2xpPlxuPC91bD5cbjx1bCAqbmdJZj1cIiEoaXNBdXRoZW50aWNhdGVkIHwgYXN5bmMpXCIgY2xhc3M9XCJuYXZiYXItbmF2XCI+XG4gIDxsaSBjbGFzcz1cIm5hdi1pdGVtXCI+XG4gICAgPGEgKGNsaWNrKT0ncmVnaXN0ZXIoKScgY2xhc3M9XCJuYXYtbGlua1wiIHJvdXRlckxpbms9XCJcIj5SZWdpc3RlcjwvYT5cbiAgPC9saT5cbiAgPGxpIGNsYXNzPVwibmF2LWl0ZW1cIj5cbiAgICA8YSAoY2xpY2spPSdsb2dpbigpJyBjbGFzcz1cIm5hdi1saW5rXCIgcm91dGVyTGluaz1cIlwiPkxvZ2luPC9hPlxuICA8L2xpPlxuPC91bD5cbiJdfQ==
@@ -1,44 +1,44 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from "@angular/common";
3
- import { HttpClientModule } from "@angular/common/http";
4
- import { LoginMenuComponent } from "./login-menu/login-menu.component";
5
- import { AuthorizeOptions, AuthorizeService } from "./authorize.service";
6
- import { OAuthModule } from "angular-oauth2-oidc";
7
- import { AuthorizeGuard } from "./authorize.guard";
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "angular-oauth2-oidc";
10
- export class SharedAuthModule {
11
- static forRoot(authorizeOptions) {
12
- return {
13
- ngModule: SharedAuthModule,
14
- providers: [
15
- {
16
- provide: AuthorizeOptions,
17
- useValue: authorizeOptions
18
- },
19
- AuthorizeService,
20
- AuthorizeGuard
21
- ]
22
- };
23
- }
24
- }
25
- SharedAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SharedAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
26
- SharedAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: SharedAuthModule, declarations: [LoginMenuComponent], imports: [CommonModule,
27
- HttpClientModule, i1.OAuthModule], exports: [LoginMenuComponent] });
28
- SharedAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SharedAuthModule, imports: [CommonModule,
29
- HttpClientModule,
30
- OAuthModule.forRoot()] });
31
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SharedAuthModule, decorators: [{
32
- type: NgModule,
33
- args: [{
34
- declarations: [LoginMenuComponent],
35
- exports: [LoginMenuComponent],
36
- providers: [],
37
- imports: [
38
- CommonModule,
39
- HttpClientModule,
40
- OAuthModule.forRoot()
41
- ]
42
- }]
43
- }] });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLWF1dGgubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWVzaG1ha2Vycy9zaGFyZWQtYXV0aC9zcmMvbGliL3NoYXJlZC1hdXRoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDckUsT0FBTyxFQUFDLGdCQUFnQixFQUFFLGdCQUFnQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDdkUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ2hELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBWWpELE1BQU0sT0FBTyxnQkFBZ0I7SUFDM0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxnQkFBa0M7UUFDL0MsT0FBTztZQUNMLFFBQVEsRUFBRSxnQkFBZ0I7WUFDMUIsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxnQkFBZ0I7b0JBQ3pCLFFBQVEsRUFBRSxnQkFBZ0I7aUJBQzNCO2dCQUNELGdCQUFnQjtnQkFDaEIsY0FBYzthQUNmO1NBQ0YsQ0FBQTtJQUNILENBQUM7OzZHQWJVLGdCQUFnQjs4R0FBaEIsZ0JBQWdCLGlCQVRaLGtCQUFrQixhQUkvQixZQUFZO1FBQ1osZ0JBQWdCLDZCQUpSLGtCQUFrQjs4R0FRakIsZ0JBQWdCLFlBTHpCLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVyxDQUFDLE9BQU8sRUFBRTsyRkFHWixnQkFBZ0I7a0JBVjVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUM3QixTQUFTLEVBQUUsRUFBRTtvQkFDYixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFdBQVcsQ0FBQyxPQUFPLEVBQUU7cUJBQ3RCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7SHR0cENsaWVudE1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7TG9naW5NZW51Q29tcG9uZW50fSBmcm9tIFwiLi9sb2dpbi1tZW51L2xvZ2luLW1lbnUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QXV0aG9yaXplT3B0aW9ucywgQXV0aG9yaXplU2VydmljZX0gZnJvbSBcIi4vYXV0aG9yaXplLnNlcnZpY2VcIjtcclxuaW1wb3J0IHtPQXV0aE1vZHVsZX0gZnJvbSBcImFuZ3VsYXItb2F1dGgyLW9pZGNcIjtcclxuaW1wb3J0IHtBdXRob3JpemVHdWFyZH0gZnJvbSBcIi4vYXV0aG9yaXplLmd1YXJkXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0xvZ2luTWVudUNvbXBvbmVudF0sXHJcbiAgZXhwb3J0czogW0xvZ2luTWVudUNvbXBvbmVudF0sXHJcbiAgcHJvdmlkZXJzOiBbXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBIdHRwQ2xpZW50TW9kdWxlLFxyXG4gICAgT0F1dGhNb2R1bGUuZm9yUm9vdCgpXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2hhcmVkQXV0aE1vZHVsZSB7XHJcbiAgc3RhdGljIGZvclJvb3QoYXV0aG9yaXplT3B0aW9uczogQXV0aG9yaXplT3B0aW9ucyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8U2hhcmVkQXV0aE1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IFNoYXJlZEF1dGhNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIHtcclxuICAgICAgICAgIHByb3ZpZGU6IEF1dGhvcml6ZU9wdGlvbnMsXHJcbiAgICAgICAgICB1c2VWYWx1ZTogYXV0aG9yaXplT3B0aW9uc1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgQXV0aG9yaXplU2VydmljZSxcclxuICAgICAgICBBdXRob3JpemVHdWFyZFxyXG4gICAgICBdXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from "@angular/common";
3
+ import { HttpClientModule } from "@angular/common/http";
4
+ import { LoginMenuComponent } from "./login-menu/login-menu.component";
5
+ import { AuthorizeOptions, AuthorizeService } from "./authorize.service";
6
+ import { OAuthModule } from "angular-oauth2-oidc";
7
+ import { AuthorizeGuard } from "./authorize.guard";
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "angular-oauth2-oidc";
10
+ export class SharedAuthModule {
11
+ static forRoot(authorizeOptions) {
12
+ return {
13
+ ngModule: SharedAuthModule,
14
+ providers: [
15
+ {
16
+ provide: AuthorizeOptions,
17
+ useValue: authorizeOptions
18
+ },
19
+ AuthorizeService,
20
+ AuthorizeGuard
21
+ ]
22
+ };
23
+ }
24
+ }
25
+ SharedAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
26
+ SharedAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, declarations: [LoginMenuComponent], imports: [CommonModule,
27
+ HttpClientModule, i1.OAuthModule], exports: [LoginMenuComponent] });
28
+ SharedAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, imports: [CommonModule,
29
+ HttpClientModule,
30
+ OAuthModule.forRoot()] });
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, decorators: [{
32
+ type: NgModule,
33
+ args: [{
34
+ declarations: [LoginMenuComponent],
35
+ exports: [LoginMenuComponent],
36
+ providers: [],
37
+ imports: [
38
+ CommonModule,
39
+ HttpClientModule,
40
+ OAuthModule.forRoot()
41
+ ]
42
+ }]
43
+ }] });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLWF1dGgubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWVzaG1ha2Vycy9zaGFyZWQtYXV0aC9zcmMvbGliL3NoYXJlZC1hdXRoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDckUsT0FBTyxFQUFDLGdCQUFnQixFQUFFLGdCQUFnQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDdkUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ2hELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBWWpELE1BQU0sT0FBTyxnQkFBZ0I7SUFDM0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxnQkFBa0M7UUFDL0MsT0FBTztZQUNMLFFBQVEsRUFBRSxnQkFBZ0I7WUFDMUIsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxnQkFBZ0I7b0JBQ3pCLFFBQVEsRUFBRSxnQkFBZ0I7aUJBQzNCO2dCQUNELGdCQUFnQjtnQkFDaEIsY0FBYzthQUNmO1NBQ0YsQ0FBQTtJQUNILENBQUM7OzZHQWJVLGdCQUFnQjs4R0FBaEIsZ0JBQWdCLGlCQVRaLGtCQUFrQixhQUkvQixZQUFZO1FBQ1osZ0JBQWdCLDZCQUpSLGtCQUFrQjs4R0FRakIsZ0JBQWdCLFlBTHpCLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVyxDQUFDLE9BQU8sRUFBRTsyRkFHWixnQkFBZ0I7a0JBVjVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUM3QixTQUFTLEVBQUUsRUFBRTtvQkFDYixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFdBQVcsQ0FBQyxPQUFPLEVBQUU7cUJBQ3RCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHtIdHRwQ2xpZW50TW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcbmltcG9ydCB7TG9naW5NZW51Q29tcG9uZW50fSBmcm9tIFwiLi9sb2dpbi1tZW51L2xvZ2luLW1lbnUuY29tcG9uZW50XCI7XG5pbXBvcnQge0F1dGhvcml6ZU9wdGlvbnMsIEF1dGhvcml6ZVNlcnZpY2V9IGZyb20gXCIuL2F1dGhvcml6ZS5zZXJ2aWNlXCI7XG5pbXBvcnQge09BdXRoTW9kdWxlfSBmcm9tIFwiYW5ndWxhci1vYXV0aDItb2lkY1wiO1xuaW1wb3J0IHtBdXRob3JpemVHdWFyZH0gZnJvbSBcIi4vYXV0aG9yaXplLmd1YXJkXCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0xvZ2luTWVudUNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtMb2dpbk1lbnVDb21wb25lbnRdLFxuICBwcm92aWRlcnM6IFtdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEh0dHBDbGllbnRNb2R1bGUsXG4gICAgT0F1dGhNb2R1bGUuZm9yUm9vdCgpXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgU2hhcmVkQXV0aE1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KGF1dGhvcml6ZU9wdGlvbnM6IEF1dGhvcml6ZU9wdGlvbnMpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFNoYXJlZEF1dGhNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IFNoYXJlZEF1dGhNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IEF1dGhvcml6ZU9wdGlvbnMsXG4gICAgICAgICAgdXNlVmFsdWU6IGF1dGhvcml6ZU9wdGlvbnNcbiAgICAgICAgfSxcbiAgICAgICAgQXV0aG9yaXplU2VydmljZSxcbiAgICAgICAgQXV0aG9yaXplR3VhcmRcbiAgICAgIF1cbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzaG1ha2Vycy1zaGFyZWQtYXV0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21lc2htYWtlcnMvc2hhcmVkLWF1dGgvc3JjL21lc2htYWtlcnMtc2hhcmVkLWF1dGgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -1,9 +1,9 @@
1
- /*
2
- * Public API Surface of shared-auth
3
- */
4
- export * from './lib/authorize.service';
5
- export * from './lib/login-menu/login-menu.component';
6
- export * from './lib/shared-auth.module';
7
- export * from './lib/authorize.interceptor';
8
- export * from './lib/authorize.guard';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21lc2htYWtlcnMvc2hhcmVkLWF1dGgvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc2hhcmVkLWF1dGhcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRob3JpemUuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xvZ2luLW1lbnUvbG9naW4tbWVudS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaGFyZWQtYXV0aC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRob3JpemUuaW50ZXJjZXB0b3InO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRob3JpemUuZ3VhcmQnO1xyXG4iXX0=
1
+ /*
2
+ * Public API Surface of shared-auth
3
+ */
4
+ export * from './lib/authorize.service';
5
+ export * from './lib/login-menu/login-menu.component';
6
+ export * from './lib/shared-auth.module';
7
+ export * from './lib/authorize.interceptor';
8
+ export * from './lib/authorize.guard';
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21lc2htYWtlcnMvc2hhcmVkLWF1dGgvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHNoYXJlZC1hdXRoXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aG9yaXplLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9naW4tbWVudS9sb2dpbi1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zaGFyZWQtYXV0aC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aG9yaXplLmludGVyY2VwdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dGhvcml6ZS5ndWFyZCc7XG5cbiJdfQ==