@meshmakers/shared-auth 2.1.17-0 → 3.1.26-0

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 +0,0 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXplLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZXNobWFrZXJzL3NoYXJlZC1hdXRoL3NyYy9saWIvYXV0aG9yaXplLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLGVBQWUsRUFBRSxjQUFjLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFDakUsT0FBTyxFQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBUTNDLE1BQU0sT0FBTyxnQkFBZ0I7Q0FjNUI7QUFHRCxNQUFNLE9BQU8sZ0JBQWdCO0lBVzNCLFlBQThDLGdCQUFrQyxFQUFVLFlBQTBCO1FBQXRFLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFBVSxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQVY1RyxvQkFBZSxHQUE2QixJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2RSxZQUFPLEdBQTZCLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9ELGdCQUFXLEdBQTZCLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ25FLGNBQVMsR0FBNkIsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakUsY0FBUyxHQUFtQyxJQUFJLGVBQWUsQ0FBZ0IsSUFBSSxDQUFDLENBQUM7UUFDckYsZ0JBQVcsR0FBbUMsSUFBSSxlQUFlLENBQWdCLElBQUksQ0FBQyxDQUFDO1FBQ3ZGLFNBQUksR0FBa0MsSUFBSSxlQUFlLENBQWUsSUFBSSxDQUFDLENBQUM7UUFDOUUsa0JBQWEsR0FBOEIsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEUsbUJBQWMsR0FBOEIsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFH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Z0JBQWdCLGtCQVdQLGdCQUFnQjtpSEFYekIsZ0JBQWdCOzJGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVU7OzBCQVlJLE1BQU07MkJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3QsIEluamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIGZpcnN0VmFsdWVGcm9tLCBPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7ZmlsdGVyLCBtYXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7QXV0aENvbmZpZywgT0F1dGhTZXJ2aWNlfSBmcm9tIFwiYW5ndWxhci1vYXV0aDItb2lkY1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIElVc2VyIHtcbiAgbmFtZTogc3RyaW5nO1xuICByb2xlOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGNsYXNzIEF1dGhvcml6ZU9wdGlvbnMge1xuICB3ZWxsS25vd25TZXJ2aWNlVXJpcz86IHN0cmluZ1tdO1xuICAvLyBVcmwgb2YgdGhlIElkZW50aXR5IFByb3ZpZGVyXG4gIGlzc3Vlcj86IHN0cmluZztcbiAgLy8gVVJMIG9mIHRoZSBTUEEgdG8gcmVkaXJlY3QgdGhlIHVzZXIgdG8gYWZ0ZXIgbG9naW5cbiAgcmVkaXJlY3RVcmk/OiBzdHJpbmc7XG4gIHBvc3RMb2dvdXRSZWRpcmVjdFVyaT86IHN0cmluZztcbiAgLy8gVGhlIFNQQSdzIGlkLiBUaGUgU1BBIGlzIHJlZ2lzdGVyZWQgd2l0aCB0aGlzIGlkIGF0IHRoZSBhdXRoLXNlcnZlclxuICBjbGllbnRJZD86IHN0cmluZztcbiAgLy8gc2V0IHRoZSBzY29wZSBmb3IgdGhlIHBlcm1pc3Npb25zIHRoZSBjbGllbnQgc2hvdWxkIHJlcXVlc3RcbiAgLy8gVGhlIGZpcnN0IHRocmVlIGFyZSBkZWZpbmVkIGJ5IE9JREMuIFRoZSA0dGggaXMgYSB1c2UgY2FzZS1zcGVjaWZpYyBvbmVcbiAgc2NvcGU/OiBzdHJpbmc7XG4gIHNob3dEZWJ1Z0luZm9ybWF0aW9uPzogYm9vbGVhbjtcbiAgc2Vzc2lvbkNoZWNrc0VuYWJsZWQ/OiBib29sZWFuO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQXV0aG9yaXplU2VydmljZSB7XG4gIHByaXZhdGUgaXNBdXRoZW50aWNhdGVkOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcbiAgcHJpdmF0ZSBpc0FkbWluOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcbiAgcHJpdmF0ZSBpc0RldmVsb3BlcjogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG4gIHByaXZhdGUgaXNNYW5hZ2VyOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcbiAgcHJpdmF0ZSBhdXRob3JpdHk6IEJlaGF2aW9yU3ViamVjdDxzdHJpbmcgfCBudWxsPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nIHwgbnVsbD4obnVsbCk7XG4gIHByaXZhdGUgYWNjZXNzVG9rZW46IEJlaGF2aW9yU3ViamVjdDxzdHJpbmcgfCBudWxsPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nIHwgbnVsbD4obnVsbCk7XG4gIHByaXZhdGUgdXNlcjogQmVoYXZpb3JTdWJqZWN0PElVc2VyIHwgbnVsbD4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0PElVc2VyIHwgbnVsbD4obnVsbCk7XG4gIHByaXZhdGUgaXNJbml0aWFsaXplZCA6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3QoZmFsc2UpO1xuICBwcml2YXRlIGlzSW5pdGlhbGl6aW5nIDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG5cbiAgY29uc3RydWN0b3IoQEluamVjdChBdXRob3JpemVPcHRpb25zKSBwcml2YXRlIGF1dGhvcml6ZU9wdGlvbnM6IEF1dGhvcml6ZU9wdGlvbnMsIHByaXZhdGUgb2F1dGhTZXJ2aWNlOiBPQXV0aFNlcnZpY2UpIHtcbiAgICBjb25zb2xlLmRlYnVnKFwiQXV0aG9yaXplU2VydmljZTo6Y3JlYXRlZFwiKTtcblxuICAgIHRoaXMuZ2V0VXNlcigpLnN1YnNjcmliZShzID0+IHtcbiAgICAgIHRoaXMuaXNBdXRoZW50aWNhdGVkLm5leHQoISFzKTtcbiAgICAgIHRoaXMuaXNBZG1pbi5uZXh0KCEhcyAmJiAocy5yb2xlLmluY2x1ZGVzKFwiQWRtaW5pc3RyYXRvcnNcIikpKTtcbiAgICAgIHRoaXMuaXNEZXZlbG9wZXIubmV4dCghIXMgJiYgKHMucm9sZS5pbmNsdWRlcyhcIkRldmVsb3BlcnNcIikpKTtcbiAgICAgIHRoaXMuaXNNYW5hZ2VyLm5leHQoISFzICYmIHMucm9sZS5pbmNsdWRlcyhcIk1hbmFnZXJzXCIpKTtcbiAgICB9KTtcblxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmV2ZW50cy5zdWJzY3JpYmUoZSA9PiB7XG4gICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tY29uc29sZVxuICAgICAgY29uc29sZS5kZWJ1Zygnb2F1dGgvb2lkYyBldmVudCcsIGUpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5vYXV0aFNlcnZpY2UuZXZlbnRzXG4gICAgICAucGlwZShmaWx0ZXIoZSA9PiBlLnR5cGUgPT09ICdzZXNzaW9uX3Rlcm1pbmF0ZWQnKSlcbiAgICAgIC5zdWJzY3JpYmUoXyA9PiB7XG4gICAgICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1jb25zb2xlXG4gICAgICAgIGNvbnNvbGUuZGVidWcoJ1lvdXIgc2Vzc2lvbiBoYXMgYmVlbiB0ZXJtaW5hdGVkIScpO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHNcbiAgICAgIC5waXBlKGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ3Rva2VuX3JlY2VpdmVkJykpXG4gICAgICAuc3Vic2NyaWJlKF8gPT4ge1xuICAgICAgICB0aGlzLmxvYWRVc2VyKCk7XG4gICAgICB9KTtcblxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmV2ZW50c1xuICAgICAgLnBpcGUoZmlsdGVyKGUgPT4gZS50eXBlID09PSAnbG9nb3V0JykpXG4gICAgICAuc3Vic2NyaWJlKF8gPT4ge1xuICAgICAgICB0aGlzLmFjY2Vzc1Rva2VuLm5leHQobnVsbCk7XG4gICAgICAgIHRoaXMudXNlci5uZXh0KG51bGwpO1xuICAgICAgfSk7XG5cbiAgfVxuXG4gIHB1YmxpYyBnZXRSb2xlcygpOiBPYnNlcnZhYmxlPEFycmF5PHN0cmluZz4+e1xuICAgIHJldHVybiB0aGlzLmdldFVzZXIoKS5waXBlKFxuICAgICAgbWFwKHU9PiB1ICE9IG51bGwgPyB1LnJvbGUgOiBuZXcgQXJyYXk8c3RyaW5nPigpKVxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgZ2V0U2VydmljZVVyaXMoKTogQXJyYXk8c3RyaW5nPiB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMud2VsbEtub3duU2VydmljZVVyaXMgPz8gbnVsbDtcbiAgfVxuXG4gIHB1YmxpYyBnZXRBdXRob3JpdHkoKTogQmVoYXZpb3JTdWJqZWN0PHN0cmluZyB8IG51bGw+IHtcbiAgICByZXR1cm4gdGhpcy5hdXRob3JpdHk7XG4gIH1cblxuICBwdWJsaWMgZ2V0SXNBdXRoZW50aWNhdGVkKCk6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuaXNBdXRoZW50aWNhdGVkO1xuICB9XG5cbiAgcHVibGljIGdldElzQWRtaW4oKTogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5pc0FkbWluO1xuICB9XG5cbiAgcHVibGljIGdldElzRGV2ZWxvcGVyKCk6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuaXNEZXZlbG9wZXI7XG4gIH1cblxuICBwdWJsaWMgZ2V0SXNNYW5hZ2VyKCk6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuaXNNYW5hZ2VyO1xuICB9XG5cbiAgcHVibGljIGdldEFjY2Vzc1Rva2VuKCk6IEJlaGF2aW9yU3ViamVjdDxzdHJpbmcgfCBudWxsPiB7XG4gICAgcmV0dXJuIHRoaXMuYWNjZXNzVG9rZW47XG4gIH1cblxuICBwdWJsaWMgZ2V0VXNlcigpOiBCZWhhdmlvclN1YmplY3Q8SVVzZXIgfCBudWxsPiB7XG4gICAgcmV0dXJuIHRoaXMudXNlcjtcbiAgfVxuXG4gIHB1YmxpYyBsb2dpbigpIHtcbiAgICB0aGlzLm9hdXRoU2VydmljZS5pbml0SW1wbGljaXRGbG93KCk7XG4gIH1cblxuICBwdWJsaWMgbG9nb3V0KCkge1xuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmxvZ091dChmYWxzZSk7XG4gIH1cblxuXG4gIHB1YmxpYyBhc3luYyBpbml0aWFsaXplKCkge1xuXG4gICAgY29uc29sZS5kZWJ1ZyhcIkF1dGhvcml6ZVNlcnZpY2U6OmluaXRpYWxpemU6OnN0YXJ0ZWRcIik7XG5cbiAgICBpZiAoYXdhaXQgZmlyc3RWYWx1ZUZyb20odGhpcy5pc0luaXRpYWxpemluZykpIHtcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICBpZiAoYXdhaXQgZmlyc3RWYWx1ZUZyb20odGhpcy5pc0luaXRpYWxpemVkKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLmlzSW5pdGlhbGl6aW5nLm5leHQodHJ1ZSk7XG5cbiAgICBjb25zdCBjb25maWc6IEF1dGhDb25maWcgPSB7XG4gICAgICByZXNwb25zZVR5cGU6ICdjb2RlJyxcbiAgICAgIGlzc3VlcjogdGhpcy5hdXRob3JpemVPcHRpb25zLmlzc3VlcixcbiAgICAgIHJlZGlyZWN0VXJpOiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMucmVkaXJlY3RVcmksXG4gICAgICBwb3N0TG9nb3V0UmVkaXJlY3RVcmk6IHRoaXMuYXV0aG9yaXplT3B0aW9ucy5wb3N0TG9nb3V0UmVkaXJlY3RVcmksXG4gICAgICBjbGllbnRJZDogdGhpcy5hdXRob3JpemVPcHRpb25zLmNsaWVudElkLFxuICAgICAgc2NvcGU6IHRoaXMuYXV0aG9yaXplT3B0aW9ucy5zY29wZSxcbiAgICAgIHNob3dEZWJ1Z0luZm9ybWF0aW9uOiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMuc2hvd0RlYnVnSW5mb3JtYXRpb24sXG4gICAgICBzZXNzaW9uQ2hlY2tzRW5hYmxlZDogdGhpcy5hdXRob3JpemVPcHRpb25zLnNlc3Npb25DaGVja3NFbmFibGVkXG4gICAgfTtcblxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmNvbmZpZ3VyZShjb25maWcpO1xuICAgIHRoaXMub2F1dGhTZXJ2aWNlLnNldFN0b3JhZ2UobG9jYWxTdG9yYWdlKTtcbiAgICBhd2FpdCB0aGlzLm9hdXRoU2VydmljZS5sb2FkRGlzY292ZXJ5RG9jdW1lbnRBbmRUcnlMb2dpbigpO1xuXG4gICAgdGhpcy5vYXV0aFNlcnZpY2Uuc2V0dXBBdXRvbWF0aWNTaWxlbnRSZWZyZXNoKCk7XG5cbiAgICBpZiAodGhpcy5vYXV0aFNlcnZpY2UuaGFzVmFsaWRBY2Nlc3NUb2tlbigpKSB7XG4gICAgICB0aGlzLmxvYWRVc2VyKCk7XG4gICAgfVxuXG4gICAgdGhpcy5hdXRob3JpdHkubmV4dCh0aGlzLmF1dGhvcml6ZU9wdGlvbnMuaXNzdWVyID8/IG51bGwpO1xuICAgIHRoaXMuaXNJbml0aWFsaXppbmcubmV4dChmYWxzZSk7XG4gICAgdGhpcy5pc0luaXRpYWxpemVkLm5leHQodHJ1ZSk7XG5cbiAgICBjb25zb2xlLmRlYnVnKFwiQXV0aG9yaXplU2VydmljZTo6aW5pdGlhbGl6ZTo6ZG9uZVwiKTtcbiAgfVxuXG4gIHByaXZhdGUgbG9hZFVzZXIoKSB7XG4gICAgY29uc3QgY2xhaW1zID0gdGhpcy5vYXV0aFNlcnZpY2UuZ2V0SWRlbnRpdHlDbGFpbXMoKTtcbiAgICBpZiAoIWNsYWltcykge1xuICAgICAgY29uc29sZS5lcnJvcihcImNsYWltcyB3aGVyZSBudWxsIHdoZW4gbG9hZGluZyBpZGVudGl0eSBjbGFpbXNcIik7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgdXNlciA9IDxJVXNlcj5jbGFpbXM7XG4gICAgY29uc3QgYWNjZXNzVG9rZW4gPSB0aGlzLm9hdXRoU2VydmljZS5nZXRBY2Nlc3NUb2tlbigpO1xuICAgIHRoaXMudXNlci5uZXh0KHVzZXIpO1xuICAgIHRoaXMuYWNjZXNzVG9rZW4ubmV4dChhY2Nlc3NUb2tlbik7XG4gIH1cbn1cbiJdfQ==
@@ -1,35 +0,0 @@
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 +0,0 @@
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,325 +0,0 @@
1
- import { __awaiter } from 'tslib';
2
- import * as i0 from '@angular/core';
3
- import { Injectable, Inject, Component, NgModule } from '@angular/core';
4
- import { BehaviorSubject, firstValueFrom } from 'rxjs';
5
- import { filter, map } from 'rxjs/operators';
6
- import * as i1 from 'angular-oauth2-oidc';
7
- import { OAuthModule } from 'angular-oauth2-oidc';
8
- import * as i2 from '@angular/common';
9
- import { CommonModule } from '@angular/common';
10
- import { HttpClientModule } from '@angular/common/http';
11
- import * as i2$1 from '@angular/router';
12
-
13
- class AuthorizeOptions {
14
- }
15
- class AuthorizeService {
16
- constructor(authorizeOptions, oauthService) {
17
- this.authorizeOptions = authorizeOptions;
18
- this.oauthService = oauthService;
19
- this.isAuthenticated = new BehaviorSubject(false);
20
- this.isAdmin = new BehaviorSubject(false);
21
- this.isDeveloper = new BehaviorSubject(false);
22
- this.isManager = new BehaviorSubject(false);
23
- this.authority = new BehaviorSubject(null);
24
- this.accessToken = new BehaviorSubject(null);
25
- this.user = new BehaviorSubject(null);
26
- this.isInitialized = new BehaviorSubject(false);
27
- this.isInitializing = new BehaviorSubject(false);
28
- console.debug("AuthorizeService::created");
29
- this.getUser().subscribe(s => {
30
- this.isAuthenticated.next(!!s);
31
- this.isAdmin.next(!!s && (s.role.includes("Administrators")));
32
- this.isDeveloper.next(!!s && (s.role.includes("Developers")));
33
- this.isManager.next(!!s && s.role.includes("Managers"));
34
- });
35
- this.oauthService.events.subscribe(e => {
36
- // tslint:disable-next-line:no-console
37
- console.debug('oauth/oidc event', e);
38
- });
39
- this.oauthService.events
40
- .pipe(filter(e => e.type === 'session_terminated'))
41
- .subscribe(_ => {
42
- // tslint:disable-next-line:no-console
43
- console.debug('Your session has been terminated!');
44
- });
45
- this.oauthService.events
46
- .pipe(filter(e => e.type === 'token_received'))
47
- .subscribe(_ => {
48
- this.loadUser();
49
- });
50
- this.oauthService.events
51
- .pipe(filter(e => e.type === 'logout'))
52
- .subscribe(_ => {
53
- this.accessToken.next(null);
54
- this.user.next(null);
55
- });
56
- }
57
- getRoles() {
58
- return this.getUser().pipe(map(u => u != null ? u.role : new Array()));
59
- }
60
- getServiceUris() {
61
- var _a;
62
- return (_a = this.authorizeOptions.wellKnownServiceUris) !== null && _a !== void 0 ? _a : null;
63
- }
64
- getAuthority() {
65
- return this.authority;
66
- }
67
- getIsAuthenticated() {
68
- return this.isAuthenticated;
69
- }
70
- getIsAdmin() {
71
- return this.isAdmin;
72
- }
73
- getIsDeveloper() {
74
- return this.isDeveloper;
75
- }
76
- getIsManager() {
77
- return this.isManager;
78
- }
79
- getAccessToken() {
80
- return this.accessToken;
81
- }
82
- getUser() {
83
- return this.user;
84
- }
85
- login() {
86
- this.oauthService.initImplicitFlow();
87
- }
88
- logout() {
89
- this.oauthService.logOut(false);
90
- }
91
- initialize() {
92
- var _a;
93
- return __awaiter(this, void 0, void 0, function* () {
94
- console.debug("AuthorizeService::initialize::started");
95
- if (yield firstValueFrom(this.isInitializing)) {
96
- return;
97
- }
98
- if (yield firstValueFrom(this.isInitialized)) {
99
- return;
100
- }
101
- this.isInitializing.next(true);
102
- const config = {
103
- responseType: 'code',
104
- issuer: this.authorizeOptions.issuer,
105
- redirectUri: this.authorizeOptions.redirectUri,
106
- postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,
107
- clientId: this.authorizeOptions.clientId,
108
- scope: this.authorizeOptions.scope,
109
- showDebugInformation: this.authorizeOptions.showDebugInformation,
110
- sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled
111
- };
112
- this.oauthService.configure(config);
113
- this.oauthService.setStorage(localStorage);
114
- yield this.oauthService.loadDiscoveryDocumentAndTryLogin();
115
- this.oauthService.setupAutomaticSilentRefresh();
116
- if (this.oauthService.hasValidAccessToken()) {
117
- this.loadUser();
118
- }
119
- this.authority.next((_a = this.authorizeOptions.issuer) !== null && _a !== void 0 ? _a : null);
120
- this.isInitializing.next(false);
121
- this.isInitialized.next(true);
122
- console.debug("AuthorizeService::initialize::done");
123
- });
124
- }
125
- loadUser() {
126
- const claims = this.oauthService.getIdentityClaims();
127
- if (!claims) {
128
- console.error("claims where null when loading identity claims");
129
- return;
130
- }
131
- const user = claims;
132
- const accessToken = this.oauthService.getAccessToken();
133
- this.user.next(user);
134
- this.accessToken.next(accessToken);
135
- }
136
- }
137
- 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 });
138
- AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeService });
139
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeService, decorators: [{
140
- type: Injectable
141
- }], ctorParameters: function () {
142
- return [{ type: AuthorizeOptions, decorators: [{
143
- type: Inject,
144
- args: [AuthorizeOptions]
145
- }] }, { type: i1.OAuthService }];
146
- } });
147
-
148
- class LoginMenuComponent {
149
- constructor(authorizeService) {
150
- this.authorizeService = authorizeService;
151
- this.isAuthenticated = this.authorizeService.getIsAuthenticated();
152
- this.userName = this.authorizeService.getUser().pipe(map(u => u && u.name));
153
- this.isAdmin = this.authorizeService.getIsAdmin();
154
- }
155
- ngOnInit() {
156
- const isIFrame = window.self !== window.top;
157
- console.log("app-login-menu::created");
158
- this.isAuthenticated.subscribe(x => {
159
- console.log(`isAuthenticated changed to ${x} (iframe ${isIFrame})`);
160
- });
161
- }
162
- login() {
163
- this.authorizeService.login();
164
- }
165
- logout() {
166
- this.authorizeService.logout();
167
- }
168
- register() {
169
- }
170
- }
171
- LoginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: LoginMenuComponent, deps: [{ token: AuthorizeService }], target: i0.ɵɵFactoryTarget.Component });
172
- 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" }] });
173
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: LoginMenuComponent, decorators: [{
174
- type: Component,
175
- 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" }]
176
- }], ctorParameters: function () { return [{ type: AuthorizeService }]; } });
177
-
178
- class AuthorizeGuard {
179
- constructor(authorizeService, router) {
180
- this.authorizeService = authorizeService;
181
- this.router = router;
182
- }
183
- canActivate(next, state) {
184
- let url = state.url;
185
- return this.handleAuthorization(next, url);
186
- }
187
- canActivateChild(next, state) {
188
- return this.canActivate(next, state);
189
- }
190
- canDeactivate(component, currentRoute, currentState, nextState) {
191
- return true;
192
- }
193
- canLoad(route, segments) {
194
- return true;
195
- }
196
- handleAuthorization(route, url) {
197
- return __awaiter(this, void 0, void 0, function* () {
198
- yield this.authorizeService.initialize();
199
- const isAuthenticated = yield firstValueFrom(this.authorizeService.getIsAuthenticated());
200
- if (isAuthenticated) {
201
- const userRoles = yield firstValueFrom(this.authorizeService.getRoles());
202
- if (route.data['roles'] && !route.data['roles'].filter((value) => userRoles.includes(value))) {
203
- this.router.navigate(['']);
204
- return false;
205
- }
206
- return true;
207
- }
208
- else {
209
- this.authorizeService.login();
210
- }
211
- return false;
212
- });
213
- }
214
- }
215
- AuthorizeGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeGuard, deps: [{ token: AuthorizeService }, { token: i2$1.Router }], target: i0.ɵɵFactoryTarget.Injectable });
216
- AuthorizeGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeGuard });
217
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeGuard, decorators: [{
218
- type: Injectable
219
- }], ctorParameters: function () { return [{ type: AuthorizeService }, { type: i2$1.Router }]; } });
220
-
221
- class SharedAuthModule {
222
- static forRoot(authorizeOptions) {
223
- return {
224
- ngModule: SharedAuthModule,
225
- providers: [
226
- {
227
- provide: AuthorizeOptions,
228
- useValue: authorizeOptions
229
- },
230
- AuthorizeService,
231
- AuthorizeGuard
232
- ]
233
- };
234
- }
235
- }
236
- SharedAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
237
- SharedAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, declarations: [LoginMenuComponent], imports: [CommonModule,
238
- HttpClientModule, i1.OAuthModule], exports: [LoginMenuComponent] });
239
- SharedAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, imports: [CommonModule,
240
- HttpClientModule,
241
- OAuthModule.forRoot()] });
242
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: SharedAuthModule, decorators: [{
243
- type: NgModule,
244
- args: [{
245
- declarations: [LoginMenuComponent],
246
- exports: [LoginMenuComponent],
247
- providers: [],
248
- imports: [
249
- CommonModule,
250
- HttpClientModule,
251
- OAuthModule.forRoot()
252
- ]
253
- }]
254
- }] });
255
-
256
- class AuthorizeInterceptor {
257
- constructor(authorize) {
258
- this.authorize = authorize;
259
- this.accessToken = null;
260
- authorize.getAccessToken().subscribe(value => this.accessToken = value);
261
- }
262
- static isSameOriginUrl(req) {
263
- // It's an absolute url with the same origin.
264
- if (req.url.startsWith(`${window.location.origin}/`)) {
265
- return true;
266
- }
267
- // It's a protocol relative url with the same origin.
268
- // For example: //www.example.com/api/Products
269
- if (req.url.startsWith(`//${window.location.host}/`)) {
270
- return true;
271
- }
272
- // It's a relative url like /api/Products
273
- if (/^\/[^\/].*/.test(req.url)) {
274
- return true;
275
- }
276
- // It's an absolute or protocol relative url that
277
- // doesn't have the same origin.
278
- return false;
279
- }
280
- // Checks if there is an access_token available in the authorize service
281
- // and adds it to the request in case it's targeted at the same origin as the
282
- intercept(req, next) {
283
- return this.processRequestWithToken(this.accessToken, req, next);
284
- }
285
- // single page application.
286
- processRequestWithToken(token, req, next) {
287
- if (!!token && (AuthorizeInterceptor.isSameOriginUrl(req) || this.isKnownServiceUri(req))) {
288
- req = req.clone({
289
- setHeaders: {
290
- Authorization: `Bearer ${token}`
291
- }
292
- });
293
- }
294
- return next.handle(req);
295
- }
296
- isKnownServiceUri(req) {
297
- const serviceUris = this.authorize.getServiceUris();
298
- if (serviceUris) {
299
- for (let i = 0; i < serviceUris.length; i++) {
300
- if (req.url.startsWith(`${serviceUris[i]}`)) {
301
- return true;
302
- }
303
- }
304
- }
305
- // It's an absolute or protocol relative url that
306
- // doesn't have the same origin.
307
- return false;
308
- }
309
- }
310
- AuthorizeInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeInterceptor, deps: [{ token: AuthorizeService }], target: i0.ɵɵFactoryTarget.Injectable });
311
- AuthorizeInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeInterceptor });
312
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: AuthorizeInterceptor, decorators: [{
313
- type: Injectable
314
- }], ctorParameters: function () { return [{ type: AuthorizeService }]; } });
315
-
316
- /*
317
- * Public API Surface of shared-auth
318
- */
319
-
320
- /**
321
- * Generated bundle index. Do not edit.
322
- */
323
-
324
- export { AuthorizeGuard, AuthorizeInterceptor, AuthorizeOptions, AuthorizeService, LoginMenuComponent, SharedAuthModule };
325
- //# sourceMappingURL=meshmakers-shared-auth.mjs.map