@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.
- package/README.md +24 -28
- package/esm2020/lib/authorize.guard.mjs +46 -46
- package/esm2020/lib/authorize.interceptor.mjs +63 -60
- package/esm2020/lib/authorize.service.mjs +134 -134
- package/esm2020/lib/login-menu/login-menu.component.mjs +35 -35
- package/esm2020/lib/shared-auth.module.mjs +44 -44
- package/esm2020/meshmakers-shared-auth.mjs +4 -4
- package/esm2020/public-api.mjs +9 -9
- package/fesm2015/meshmakers-shared-auth.mjs +297 -292
- package/fesm2015/meshmakers-shared-auth.mjs.map +1 -1
- package/fesm2020/meshmakers-shared-auth.mjs +289 -286
- package/fesm2020/meshmakers-shared-auth.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/authorize.guard.d.ts +16 -16
- package/lib/authorize.interceptor.d.ts +15 -15
- package/lib/authorize.service.d.ts +46 -46
- package/lib/login-menu/login-menu.component.d.ts +17 -17
- package/lib/shared-auth.module.d.ts +13 -13
- package/package.json +9 -4
- package/public-api.d.ts +5 -5
|
@@ -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.
|
|
127
|
-
AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.
|
|
128
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
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.
|
|
30
|
-
LoginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
31
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
32
|
-
type: Component,
|
|
33
|
-
args: [{ selector: 'app-login-menu', template: "<ul *ngIf=\"isAuthenticated | async\" class=\"navbar-nav\">\
|
|
34
|
-
}], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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.
|
|
26
|
-
SharedAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.
|
|
27
|
-
HttpClientModule, i1.OAuthModule], exports: [LoginMenuComponent] });
|
|
28
|
-
SharedAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.
|
|
29
|
-
HttpClientModule,
|
|
30
|
-
OAuthModule.forRoot()] });
|
|
31
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
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,
|
|
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==
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -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,
|
|
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==
|