@meshmakers/shared-auth 0.0.0-0 → 2.0.2211-13005
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 +28 -28
- package/esm2020/lib/authorize.guard.mjs +24 -24
- package/esm2020/lib/authorize.interceptor.mjs +60 -60
- package/esm2020/lib/authorize.service.mjs +110 -110
- 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 +243 -243
- package/fesm2015/meshmakers-shared-auth.mjs.map +1 -1
- package/fesm2020/meshmakers-shared-auth.mjs +241 -241
- package/fesm2020/meshmakers-shared-auth.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/authorize.guard.d.ts +11 -11
- package/lib/authorize.interceptor.d.ts +15 -15
- package/lib/authorize.service.d.ts +39 -39
- package/lib/login-menu/login-menu.component.d.ts +17 -17
- package/lib/shared-auth.module.d.ts +13 -13
- package/package.json +1 -1
- package/public-api.d.ts +5 -5
package/README.md
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
# SharedAuth
|
|
2
|
-
|
|
3
|
-
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.0.1.
|
|
4
|
-
|
|
5
|
-
## Code scaffolding
|
|
6
|
-
|
|
7
|
-
Run `ng generate component component-name --project shared-auth` to generate a new component. You can also
|
|
8
|
-
use `ng generate directive|pipe|service|class|guard|interface|enum|module --project shared-auth`.
|
|
9
|
-
> Note: Don't forget to add `--project shared-auth` or else it will be added to the default project in
|
|
10
|
-
> your `angular.json` file.
|
|
11
|
-
|
|
12
|
-
## Build
|
|
13
|
-
|
|
14
|
-
Run `ng build shared-auth` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
15
|
-
|
|
16
|
-
## Publishing
|
|
17
|
-
|
|
18
|
-
After building your library with `ng build shared-auth`, go to the dist folder `cd dist/shared-auth` and
|
|
19
|
-
run `npm publish`.
|
|
20
|
-
|
|
21
|
-
## Running unit tests
|
|
22
|
-
|
|
23
|
-
Run `ng test shared-auth` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
24
|
-
|
|
25
|
-
## Further help
|
|
26
|
-
|
|
27
|
-
To get more help on the Angular CLI use `ng help` or go check out
|
|
28
|
-
the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md).
|
|
1
|
+
# SharedAuth
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.0.1.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project shared-auth` to generate a new component. You can also
|
|
8
|
+
use `ng generate directive|pipe|service|class|guard|interface|enum|module --project shared-auth`.
|
|
9
|
+
> Note: Don't forget to add `--project shared-auth` or else it will be added to the default project in
|
|
10
|
+
> your `angular.json` file.
|
|
11
|
+
|
|
12
|
+
## Build
|
|
13
|
+
|
|
14
|
+
Run `ng build shared-auth` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
15
|
+
|
|
16
|
+
## Publishing
|
|
17
|
+
|
|
18
|
+
After building your library with `ng build shared-auth`, go to the dist folder `cd dist/shared-auth` and
|
|
19
|
+
run `npm publish`.
|
|
20
|
+
|
|
21
|
+
## Running unit tests
|
|
22
|
+
|
|
23
|
+
Run `ng test shared-auth` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
24
|
+
|
|
25
|
+
## Further help
|
|
26
|
+
|
|
27
|
+
To get more help on the Angular CLI use `ng help` or go check out
|
|
28
|
+
the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md).
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { tap } from 'rxjs/operators';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "./authorize.service";
|
|
5
|
-
export class AuthorizeGuard {
|
|
6
|
-
constructor(authorize) {
|
|
7
|
-
this.authorize = authorize;
|
|
8
|
-
}
|
|
9
|
-
canActivate(_next, state) {
|
|
10
|
-
return this.authorize.getIsAuthenticated()
|
|
11
|
-
.pipe(tap(isAuthenticated => this.handleAuthorization(isAuthenticated)));
|
|
12
|
-
}
|
|
13
|
-
handleAuthorization(isAuthenticated) {
|
|
14
|
-
if (!isAuthenticated) {
|
|
15
|
-
this.authorize.login();
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
AuthorizeGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
20
|
-
AuthorizeGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard });
|
|
21
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard, decorators: [{
|
|
22
|
-
type: Injectable
|
|
23
|
-
}], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { tap } from 'rxjs/operators';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./authorize.service";
|
|
5
|
+
export class AuthorizeGuard {
|
|
6
|
+
constructor(authorize) {
|
|
7
|
+
this.authorize = authorize;
|
|
8
|
+
}
|
|
9
|
+
canActivate(_next, state) {
|
|
10
|
+
return this.authorize.getIsAuthenticated()
|
|
11
|
+
.pipe(tap(isAuthenticated => this.handleAuthorization(isAuthenticated)));
|
|
12
|
+
}
|
|
13
|
+
handleAuthorization(isAuthenticated) {
|
|
14
|
+
if (!isAuthenticated) {
|
|
15
|
+
this.authorize.login();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
AuthorizeGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
20
|
+
AuthorizeGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeGuard, decorators: [{
|
|
22
|
+
type: Injectable
|
|
23
|
+
}], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXplLmd1YXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWVzaG1ha2Vycy9zaGFyZWQtYXV0aC9zcmMvbGliL2F1dGhvcml6ZS5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBR3pDLE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBR25DLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLFlBQW9CLFNBQTJCO1FBQTNCLGNBQVMsR0FBVCxTQUFTLENBQWtCO0lBQy9DLENBQUM7SUFFRCxXQUFXLENBQ1QsS0FBNkIsRUFDN0IsS0FBMEI7UUFDMUIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFrQixFQUFFO2FBQ3ZDLElBQUksQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzdFLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxlQUF3QjtRQUNsRCxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDOzsyR0FmVSxjQUFjOytHQUFkLGNBQWM7MkZBQWQsY0FBYztrQkFEMUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7QWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgQ2FuQWN0aXZhdGUsIFJvdXRlclN0YXRlU25hcHNob3R9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7QXV0aG9yaXplU2VydmljZX0gZnJvbSAnLi9hdXRob3JpemUuc2VydmljZSc7XHJcbmltcG9ydCB7dGFwfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBBdXRob3JpemVHdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGF1dGhvcml6ZTogQXV0aG9yaXplU2VydmljZSkge1xyXG4gIH1cclxuXHJcbiAgY2FuQWN0aXZhdGUoXHJcbiAgICBfbmV4dDogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcclxuICAgIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogYW55IHtcclxuICAgIHJldHVybiB0aGlzLmF1dGhvcml6ZS5nZXRJc0F1dGhlbnRpY2F0ZWQoKVxyXG4gICAgICAucGlwZSh0YXAoaXNBdXRoZW50aWNhdGVkID0+IHRoaXMuaGFuZGxlQXV0aG9yaXphdGlvbihpc0F1dGhlbnRpY2F0ZWQpKSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGhhbmRsZUF1dGhvcml6YXRpb24oaXNBdXRoZW50aWNhdGVkOiBib29sZWFuKSB7XHJcbiAgICBpZiAoIWlzQXV0aGVudGljYXRlZCkge1xyXG4gICAgICB0aGlzLmF1dGhvcml6ZS5sb2dpbigpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,60 +1,60 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "./authorize.service";
|
|
4
|
-
export class AuthorizeInterceptor {
|
|
5
|
-
constructor(authorize) {
|
|
6
|
-
this.authorize = authorize;
|
|
7
|
-
authorize.getAccessToken().subscribe(value => this.accessToken = value);
|
|
8
|
-
}
|
|
9
|
-
static isSameOriginUrl(req) {
|
|
10
|
-
// It's an absolute url with the same origin.
|
|
11
|
-
if (req.url.startsWith(`${window.location.origin}/`)) {
|
|
12
|
-
return true;
|
|
13
|
-
}
|
|
14
|
-
// It's a protocol relative url with the same origin.
|
|
15
|
-
// For example: //www.example.com/api/Products
|
|
16
|
-
if (req.url.startsWith(`//${window.location.host}/`)) {
|
|
17
|
-
return true;
|
|
18
|
-
}
|
|
19
|
-
// It's a relative url like /api/Products
|
|
20
|
-
if (/^\/[^\/].*/.test(req.url)) {
|
|
21
|
-
return true;
|
|
22
|
-
}
|
|
23
|
-
// It's an absolute or protocol relative url that
|
|
24
|
-
// doesn't have the same origin.
|
|
25
|
-
return false;
|
|
26
|
-
}
|
|
27
|
-
// Checks if there is an access_token available in the authorize service
|
|
28
|
-
// and adds it to the request in case it's targeted at the same origin as the
|
|
29
|
-
intercept(req, next) {
|
|
30
|
-
return this.processRequestWithToken(this.accessToken, req, next);
|
|
31
|
-
}
|
|
32
|
-
// single page application.
|
|
33
|
-
processRequestWithToken(token, req, next) {
|
|
34
|
-
if (!!token && (AuthorizeInterceptor.isSameOriginUrl(req) || this.isKnownServiceUri(req))) {
|
|
35
|
-
req = req.clone({
|
|
36
|
-
setHeaders: {
|
|
37
|
-
Authorization: `Bearer ${token}`
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
return next.handle(req);
|
|
42
|
-
}
|
|
43
|
-
isKnownServiceUri(req) {
|
|
44
|
-
const serviceUris = this.authorize.getServiceUris();
|
|
45
|
-
for (let i = 0; i < serviceUris.length; i++) {
|
|
46
|
-
if (req.url.startsWith(`${serviceUris[i]}`)) {
|
|
47
|
-
return true;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
// It's an absolute or protocol relative url that
|
|
51
|
-
// doesn't have the same origin.
|
|
52
|
-
return false;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
AuthorizeInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
56
|
-
AuthorizeInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor });
|
|
57
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor, decorators: [{
|
|
58
|
-
type: Injectable
|
|
59
|
-
}], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./authorize.service";
|
|
4
|
+
export class AuthorizeInterceptor {
|
|
5
|
+
constructor(authorize) {
|
|
6
|
+
this.authorize = authorize;
|
|
7
|
+
authorize.getAccessToken().subscribe(value => this.accessToken = value);
|
|
8
|
+
}
|
|
9
|
+
static isSameOriginUrl(req) {
|
|
10
|
+
// It's an absolute url with the same origin.
|
|
11
|
+
if (req.url.startsWith(`${window.location.origin}/`)) {
|
|
12
|
+
return true;
|
|
13
|
+
}
|
|
14
|
+
// It's a protocol relative url with the same origin.
|
|
15
|
+
// For example: //www.example.com/api/Products
|
|
16
|
+
if (req.url.startsWith(`//${window.location.host}/`)) {
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
// It's a relative url like /api/Products
|
|
20
|
+
if (/^\/[^\/].*/.test(req.url)) {
|
|
21
|
+
return true;
|
|
22
|
+
}
|
|
23
|
+
// It's an absolute or protocol relative url that
|
|
24
|
+
// doesn't have the same origin.
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
// Checks if there is an access_token available in the authorize service
|
|
28
|
+
// and adds it to the request in case it's targeted at the same origin as the
|
|
29
|
+
intercept(req, next) {
|
|
30
|
+
return this.processRequestWithToken(this.accessToken, req, next);
|
|
31
|
+
}
|
|
32
|
+
// single page application.
|
|
33
|
+
processRequestWithToken(token, req, next) {
|
|
34
|
+
if (!!token && (AuthorizeInterceptor.isSameOriginUrl(req) || this.isKnownServiceUri(req))) {
|
|
35
|
+
req = req.clone({
|
|
36
|
+
setHeaders: {
|
|
37
|
+
Authorization: `Bearer ${token}`
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
return next.handle(req);
|
|
42
|
+
}
|
|
43
|
+
isKnownServiceUri(req) {
|
|
44
|
+
const serviceUris = this.authorize.getServiceUris();
|
|
45
|
+
for (let i = 0; i < serviceUris.length; i++) {
|
|
46
|
+
if (req.url.startsWith(`${serviceUris[i]}`)) {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
// It's an absolute or protocol relative url that
|
|
51
|
+
// doesn't have the same origin.
|
|
52
|
+
return false;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
AuthorizeInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor, deps: [{ token: i1.AuthorizeService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
56
|
+
AuthorizeInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor });
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeInterceptor, decorators: [{
|
|
58
|
+
type: Injectable
|
|
59
|
+
}], ctorParameters: function () { return [{ type: i1.AuthorizeService }]; } });
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXplLmludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWVzaG1ha2Vycy9zaGFyZWQtYXV0aC9zcmMvbGliL2F1dGhvcml6ZS5pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7QUFNekMsTUFBTSxPQUFPLG9CQUFvQjtJQUkvQixZQUFvQixTQUEyQjtRQUEzQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUU3QyxTQUFTLENBQUMsY0FBYyxFQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsQ0FBQztJQUUxRSxDQUFDO0lBRU8sTUFBTSxDQUFDLGVBQWUsQ0FBQyxHQUFRO1FBQ3JDLDZDQUE2QztRQUM3QyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3BELE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxxREFBcUQ7UUFDckQsOENBQThDO1FBQzlDLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsS0FBSyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxDQUFDLEVBQUU7WUFDcEQsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUVELHlDQUF5QztRQUN6QyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQzlCLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxpREFBaUQ7UUFDakQsZ0NBQWdDO1FBQ2hDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELHdFQUF3RTtJQUN4RSw2RUFBNkU7SUFFN0UsU0FBUyxDQUFDLEdBQXFCLEVBQUUsSUFBaUI7UUFDaEQsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUVELDJCQUEyQjtJQUNuQix1QkFBdUIsQ0FBQyxLQUFhLEVBQUUsR0FBcUIsRUFBRSxJQUFpQjtRQUNyRixJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUU7WUFDekYsR0FBRyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7Z0JBQ2QsVUFBVSxFQUFFO29CQUNWLGFBQWEsRUFBRSxVQUFVLEtBQUssRUFBRTtpQkFDakM7YUFDRixDQUFDLENBQUM7U0FDSjtRQUVELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRU8saUJBQWlCLENBQUMsR0FBUTtRQUVoQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBRXBELEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzNDLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFO2dCQUMzQyxPQUFPLElBQUksQ0FBQzthQUNiO1NBQ0Y7UUFFRCxpREFBaUQ7UUFDakQsZ0NBQWdDO1FBQ2hDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzs7aUhBakVVLG9CQUFvQjtxSEFBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBRGhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0h0dHBFdmVudCwgSHR0cEhhbmRsZXIsIEh0dHBJbnRlcmNlcHRvciwgSHR0cFJlcXVlc3R9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHtBdXRob3JpemVTZXJ2aWNlfSBmcm9tICcuL2F1dGhvcml6ZS5zZXJ2aWNlJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEF1dGhvcml6ZUludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcclxuXHJcbiAgYWNjZXNzVG9rZW46IHN0cmluZztcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRob3JpemU6IEF1dGhvcml6ZVNlcnZpY2UpIHtcclxuXHJcbiAgICBhdXRob3JpemUuZ2V0QWNjZXNzVG9rZW4oKS5zdWJzY3JpYmUodmFsdWUgPT4gdGhpcy5hY2Nlc3NUb2tlbiA9IHZhbHVlKTtcclxuXHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHN0YXRpYyBpc1NhbWVPcmlnaW5VcmwocmVxOiBhbnkpIHtcclxuICAgIC8vIEl0J3MgYW4gYWJzb2x1dGUgdXJsIHdpdGggdGhlIHNhbWUgb3JpZ2luLlxyXG4gICAgaWYgKHJlcS51cmwuc3RhcnRzV2l0aChgJHt3aW5kb3cubG9jYXRpb24ub3JpZ2lufS9gKSkge1xyXG4gICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH1cclxuXHJcbiAgICAvLyBJdCdzIGEgcHJvdG9jb2wgcmVsYXRpdmUgdXJsIHdpdGggdGhlIHNhbWUgb3JpZ2luLlxyXG4gICAgLy8gRm9yIGV4YW1wbGU6IC8vd3d3LmV4YW1wbGUuY29tL2FwaS9Qcm9kdWN0c1xyXG4gICAgaWYgKHJlcS51cmwuc3RhcnRzV2l0aChgLy8ke3dpbmRvdy5sb2NhdGlvbi5ob3N0fS9gKSkge1xyXG4gICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH1cclxuXHJcbiAgICAvLyBJdCdzIGEgcmVsYXRpdmUgdXJsIGxpa2UgL2FwaS9Qcm9kdWN0c1xyXG4gICAgaWYgKC9eXFwvW15cXC9dLiovLnRlc3QocmVxLnVybCkpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgLy8gSXQncyBhbiBhYnNvbHV0ZSBvciBwcm90b2NvbCByZWxhdGl2ZSB1cmwgdGhhdFxyXG4gICAgLy8gZG9lc24ndCBoYXZlIHRoZSBzYW1lIG9yaWdpbi5cclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcblxyXG4gIC8vIENoZWNrcyBpZiB0aGVyZSBpcyBhbiBhY2Nlc3NfdG9rZW4gYXZhaWxhYmxlIGluIHRoZSBhdXRob3JpemUgc2VydmljZVxyXG4gIC8vIGFuZCBhZGRzIGl0IHRvIHRoZSByZXF1ZXN0IGluIGNhc2UgaXQncyB0YXJnZXRlZCBhdCB0aGUgc2FtZSBvcmlnaW4gYXMgdGhlXHJcblxyXG4gIGludGVyY2VwdChyZXE6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xyXG4gICAgcmV0dXJuIHRoaXMucHJvY2Vzc1JlcXVlc3RXaXRoVG9rZW4odGhpcy5hY2Nlc3NUb2tlbiwgcmVxLCBuZXh0KTtcclxuICB9XHJcblxyXG4gIC8vIHNpbmdsZSBwYWdlIGFwcGxpY2F0aW9uLlxyXG4gIHByaXZhdGUgcHJvY2Vzc1JlcXVlc3RXaXRoVG9rZW4odG9rZW46IHN0cmluZywgcmVxOiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcikge1xyXG4gICAgaWYgKCEhdG9rZW4gJiYgKEF1dGhvcml6ZUludGVyY2VwdG9yLmlzU2FtZU9yaWdpblVybChyZXEpIHx8IHRoaXMuaXNLbm93blNlcnZpY2VVcmkocmVxKSkpIHtcclxuICAgICAgcmVxID0gcmVxLmNsb25lKHtcclxuICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7dG9rZW59YFxyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGlzS25vd25TZXJ2aWNlVXJpKHJlcTogYW55KSB7XHJcblxyXG4gICAgY29uc3Qgc2VydmljZVVyaXMgPSB0aGlzLmF1dGhvcml6ZS5nZXRTZXJ2aWNlVXJpcygpO1xyXG5cclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2VydmljZVVyaXMubGVuZ3RoOyBpKyspIHtcclxuICAgICAgaWYgKHJlcS51cmwuc3RhcnRzV2l0aChgJHtzZXJ2aWNlVXJpc1tpXX1gKSkge1xyXG4gICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgLy8gSXQncyBhbiBhYnNvbHV0ZSBvciBwcm90b2NvbCByZWxhdGl2ZSB1cmwgdGhhdFxyXG4gICAgLy8gZG9lc24ndCBoYXZlIHRoZSBzYW1lIG9yaWdpbi5cclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,110 +1,110 @@
|
|
|
1
|
-
import { Inject, Injectable } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject } from 'rxjs';
|
|
3
|
-
import { filter } 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.authority = new BehaviorSubject(null);
|
|
15
|
-
this.accessToken = new BehaviorSubject(null);
|
|
16
|
-
this.user = new BehaviorSubject(null);
|
|
17
|
-
console.debug("AuthorizeService::created");
|
|
18
|
-
this.getUser().subscribe(s => {
|
|
19
|
-
this.isAuthenticated.next(!!s);
|
|
20
|
-
this.isAdmin.next(!!s && s.role === "Administrators");
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
getServiceUris() {
|
|
24
|
-
return this.authorizeOptions.wellKnownServiceUris;
|
|
25
|
-
}
|
|
26
|
-
getAuthority() {
|
|
27
|
-
return this.authority;
|
|
28
|
-
}
|
|
29
|
-
getIsAuthenticated() {
|
|
30
|
-
return this.isAuthenticated;
|
|
31
|
-
}
|
|
32
|
-
getIsAdmin() {
|
|
33
|
-
return this.isAdmin;
|
|
34
|
-
}
|
|
35
|
-
getAccessToken() {
|
|
36
|
-
return this.accessToken;
|
|
37
|
-
}
|
|
38
|
-
getUser() {
|
|
39
|
-
return this.user;
|
|
40
|
-
}
|
|
41
|
-
login() {
|
|
42
|
-
this.oauthService.initImplicitFlow();
|
|
43
|
-
}
|
|
44
|
-
logout() {
|
|
45
|
-
this.oauthService.logOut(false);
|
|
46
|
-
}
|
|
47
|
-
initialize() {
|
|
48
|
-
console.debug("AuthorizeService::initialize::started");
|
|
49
|
-
const config = {
|
|
50
|
-
responseType: 'code',
|
|
51
|
-
issuer: this.authorizeOptions.issuer,
|
|
52
|
-
redirectUri: this.authorizeOptions.redirectUri,
|
|
53
|
-
postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,
|
|
54
|
-
clientId: this.authorizeOptions.clientId,
|
|
55
|
-
scope: this.authorizeOptions.scope,
|
|
56
|
-
showDebugInformation: this.authorizeOptions.showDebugInformation,
|
|
57
|
-
sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled
|
|
58
|
-
};
|
|
59
|
-
this.oauthService.configure(config);
|
|
60
|
-
this.oauthService.setStorage(localStorage);
|
|
61
|
-
this.oauthService.loadDiscoveryDocumentAndTryLogin();
|
|
62
|
-
this.oauthService.setupAutomaticSilentRefresh();
|
|
63
|
-
this.oauthService.events.subscribe(e => {
|
|
64
|
-
// tslint:disable-next-line:no-console
|
|
65
|
-
console.debug('oauth/oidc event', e);
|
|
66
|
-
});
|
|
67
|
-
this.oauthService.events
|
|
68
|
-
.pipe(filter(e => e.type === 'session_terminated'))
|
|
69
|
-
.subscribe(e => {
|
|
70
|
-
// tslint:disable-next-line:no-console
|
|
71
|
-
console.debug('Your session has been terminated!');
|
|
72
|
-
});
|
|
73
|
-
this.oauthService.events
|
|
74
|
-
.pipe(filter(e => e.type === 'token_received'))
|
|
75
|
-
.subscribe(e => {
|
|
76
|
-
this.loadUser();
|
|
77
|
-
});
|
|
78
|
-
this.oauthService.events
|
|
79
|
-
.pipe(filter(e => e.type === 'logout'))
|
|
80
|
-
.subscribe(e => {
|
|
81
|
-
this.accessToken.next(null);
|
|
82
|
-
this.user.next(null);
|
|
83
|
-
});
|
|
84
|
-
if (this.oauthService.hasValidAccessToken()) {
|
|
85
|
-
this.loadUser();
|
|
86
|
-
}
|
|
87
|
-
this.authority.next(this.authorizeOptions.issuer);
|
|
88
|
-
console.debug("AuthorizeService::initialize::done");
|
|
89
|
-
}
|
|
90
|
-
loadUser() {
|
|
91
|
-
const claims = this.oauthService.getIdentityClaims();
|
|
92
|
-
if (!claims) {
|
|
93
|
-
console.error("claims where null when loading identity claims");
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
const user = claims;
|
|
97
|
-
const accessToken = this.oauthService.getAccessToken();
|
|
98
|
-
this.user.next(user);
|
|
99
|
-
this.accessToken.next(accessToken);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
AuthorizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService, deps: [{ token: AuthorizeOptions }, { token: i1.OAuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
103
|
-
AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService });
|
|
104
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService, decorators: [{
|
|
105
|
-
type: Injectable
|
|
106
|
-
}], ctorParameters: function () { return [{ type: AuthorizeOptions, decorators: [{
|
|
107
|
-
type: Inject,
|
|
108
|
-
args: [AuthorizeOptions]
|
|
109
|
-
}] }, { type: i1.OAuthService }]; } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXplLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZXNobWFrZXJzL3NoYXJlZC1hdXRoL3NyYy9saWIvYXV0aG9yaXplLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUNyQyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7OztBQVF0QyxNQUFNLE9BQU8sZ0JBQWdCO0NBYzVCO0FBR0QsTUFBTSxPQUFPLGdCQUFnQjtJQU8zQixZQUE4QyxnQkFBa0MsRUFBVSxZQUEwQjtRQUF0RSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQVUsaUJBQVksR0FBWixZQUFZLENBQWM7UUFONUcsb0JBQWUsR0FBNkIsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkUsWUFBTyxHQUE2QixJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvRCxjQUFTLEdBQTRCLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQy9ELGdCQUFXLEdBQTRCLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pFLFNBQUksR0FBMkIsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7UUFHL0QsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQzNDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDM0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQy9CLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUks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QyxDQUFDO2FBQ3RDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO1FBRUwsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLG1CQUFtQixFQUFFLEVBQUU7WUFDM0MsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQ2pCO1FBRUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRWxELE9BQU8sQ0FBQyxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FBQztJQUV0RCxDQUFDO0lBRU8sUUFBUTtRQUNkLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUNyRCxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsT0FBTyxDQUFDLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO1lBQ2hFLE9BQU87U0FDUjtRQUVELE1BQU0sSUFBSSxHQUFVLE1BQU0sQ0FBQztRQUMzQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZELElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7OzZHQW5IVSxnQkFBZ0Isa0JBT1AsZ0JBQWdCO2lIQVB6QixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVTs7MEJBUUksTUFBTTsyQkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge2ZpbHRlcn0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHtBdXRoQ29uZmlnLCBPQXV0aFNlcnZpY2V9IGZyb20gXCJhbmd1bGFyLW9hdXRoMi1vaWRjXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVVzZXIge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJvbGU6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIEF1dGhvcml6ZU9wdGlvbnMge1xuICB3ZWxsS25vd25TZXJ2aWNlVXJpczogc3RyaW5nW107XG4gIC8vIFVybCBvZiB0aGUgSWRlbnRpdHkgUHJvdmlkZXJcbiAgaXNzdWVyOiBzdHJpbmc7XG4gIC8vIFVSTCBvZiB0aGUgU1BBIHRvIHJlZGlyZWN0IHRoZSB1c2VyIHRvIGFmdGVyIGxvZ2luXG4gIHJlZGlyZWN0VXJpOiBzdHJpbmc7XG4gIHBvc3RMb2dvdXRSZWRpcmVjdFVyaTogc3RyaW5nO1xuICAvLyBUaGUgU1BBJ3MgaWQuIFRoZSBTUEEgaXMgcmVnaXN0ZXJlZCB3aXRoIHRoaXMgaWQgYXQgdGhlIGF1dGgtc2VydmVyXG4gIGNsaWVudElkOiBzdHJpbmc7XG4gIC8vIHNldCB0aGUgc2NvcGUgZm9yIHRoZSBwZXJtaXNzaW9ucyB0aGUgY2xpZW50IHNob3VsZCByZXF1ZXN0XG4gIC8vIFRoZSBmaXJzdCB0aHJlZSBhcmUgZGVmaW5lZCBieSBPSURDLiBUaGUgNHRoIGlzIGEgdXNlIGNhc2Utc3BlY2lmaWMgb25lXG4gIHNjb3BlOiBzdHJpbmc7XG4gIHNob3dEZWJ1Z0luZm9ybWF0aW9uOiBib29sZWFuO1xuICBzZXNzaW9uQ2hlY2tzRW5hYmxlZDogYm9vbGVhbjtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEF1dGhvcml6ZVNlcnZpY2Uge1xuICBwcml2YXRlIGlzQXV0aGVudGljYXRlZDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG4gIHByaXZhdGUgaXNBZG1pbjogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG4gIHByaXZhdGUgYXV0aG9yaXR5OiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPiA9IG5ldyBCZWhhdmlvclN1YmplY3QobnVsbCk7XG4gIHByaXZhdGUgYWNjZXNzVG9rZW46IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChudWxsKTtcbiAgcHJpdmF0ZSB1c2VyOiBCZWhhdmlvclN1YmplY3Q8SVVzZXI+ID0gbmV3IEJlaGF2aW9yU3ViamVjdChudWxsKTtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KEF1dGhvcml6ZU9wdGlvbnMpIHByaXZhdGUgYXV0aG9yaXplT3B0aW9uczogQXV0aG9yaXplT3B0aW9ucywgcHJpdmF0ZSBvYXV0aFNlcnZpY2U6IE9BdXRoU2VydmljZSkge1xuICAgIGNvbnNvbGUuZGVidWcoXCJBdXRob3JpemVTZXJ2aWNlOjpjcmVhdGVkXCIpO1xuICAgIHRoaXMuZ2V0VXNlcigpLnN1YnNjcmliZShzID0+IHtcbiAgICAgIHRoaXMuaXNBdXRoZW50aWNhdGVkLm5leHQoISFzKTtcbiAgICAgIHRoaXMuaXNBZG1pbi5uZXh0KCEhcyAmJiBzLnJvbGUgPT09IFwiQWRtaW5pc3RyYXRvcnNcIik7XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0U2VydmljZVVyaXMoKTogQXJyYXk8c3RyaW5nPiB7XG4gICAgcmV0dXJuIHRoaXMuYXV0aG9yaXplT3B0aW9ucy53ZWxsS25vd25TZXJ2aWNlVXJpcztcbiAgfVxuXG4gIHB1YmxpYyBnZXRBdXRob3JpdHkoKTogQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4ge1xuICAgIHJldHVybiB0aGlzLmF1dGhvcml0eTtcbiAgfVxuXG4gIHB1YmxpYyBnZXRJc0F1dGhlbnRpY2F0ZWQoKTogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5pc0F1dGhlbnRpY2F0ZWQ7XG4gIH1cblxuICBwdWJsaWMgZ2V0SXNBZG1pbigpOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLmlzQWRtaW47XG4gIH1cblxuICBwdWJsaWMgZ2V0QWNjZXNzVG9rZW4oKTogQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4ge1xuICAgIHJldHVybiB0aGlzLmFjY2Vzc1Rva2VuO1xuICB9XG5cbiAgcHVibGljIGdldFVzZXIoKTogQmVoYXZpb3JTdWJqZWN0PElVc2VyPiB7XG4gICAgcmV0dXJuIHRoaXMudXNlcjtcbiAgfVxuXG4gIHB1YmxpYyBsb2dpbigpIHtcbiAgICB0aGlzLm9hdXRoU2VydmljZS5pbml0SW1wbGljaXRGbG93KCk7XG4gIH1cblxuICBwdWJsaWMgbG9nb3V0KCkge1xuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmxvZ091dChmYWxzZSk7XG4gIH1cblxuXG4gIHB1YmxpYyBpbml0aWFsaXplKCkge1xuXG4gICAgY29uc29sZS5kZWJ1ZyhcIkF1dGhvcml6ZVNlcnZpY2U6OmluaXRpYWxpemU6OnN0YXJ0ZWRcIik7XG5cbiAgICBjb25zdCBjb25maWc6IEF1dGhDb25maWcgPSB7XG4gICAgICByZXNwb25zZVR5cGU6ICdjb2RlJyxcbiAgICAgIGlzc3VlcjogdGhpcy5hdXRob3JpemVPcHRpb25zLmlzc3VlcixcbiAgICAgIHJlZGlyZWN0VXJpOiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMucmVkaXJlY3RVcmksXG4gICAgICBwb3N0TG9nb3V0UmVkaXJlY3RVcmk6IHRoaXMuYXV0aG9yaXplT3B0aW9ucy5wb3N0TG9nb3V0UmVkaXJlY3RVcmksXG4gICAgICBjbGllbnRJZDogdGhpcy5hdXRob3JpemVPcHRpb25zLmNsaWVudElkLFxuICAgICAgc2NvcGU6IHRoaXMuYXV0aG9yaXplT3B0aW9ucy5zY29wZSxcbiAgICAgIHNob3dEZWJ1Z0luZm9ybWF0aW9uOiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMuc2hvd0RlYnVnSW5mb3JtYXRpb24sXG4gICAgICBzZXNzaW9uQ2hlY2tzRW5hYmxlZDogdGhpcy5hdXRob3JpemVPcHRpb25zLnNlc3Npb25DaGVja3NFbmFibGVkXG4gICAgfTtcblxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmNvbmZpZ3VyZShjb25maWcpO1xuICAgIHRoaXMub2F1dGhTZXJ2aWNlLnNldFN0b3JhZ2UobG9jYWxTdG9yYWdlKTtcbiAgICB0aGlzLm9hdXRoU2VydmljZS5sb2FkRGlzY292ZXJ5RG9jdW1lbnRBbmRUcnlMb2dpbigpO1xuXG4gICAgdGhpcy5vYXV0aFNlcnZpY2Uuc2V0dXBBdXRvbWF0aWNTaWxlbnRSZWZyZXNoKCk7XG5cbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHMuc3Vic2NyaWJlKGUgPT4ge1xuICAgICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUuZGVidWcoJ29hdXRoL29pZGMgZXZlbnQnLCBlKTtcbiAgICB9KTtcblxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmV2ZW50c1xuICAgICAgLnBpcGUoZmlsdGVyKGUgPT4gZS50eXBlID09PSAnc2Vzc2lvbl90ZXJtaW5hdGVkJykpXG4gICAgICAuc3Vic2NyaWJlKGUgPT4ge1xuICAgICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tY29uc29sZVxuICAgICAgICBjb25zb2xlLmRlYnVnKCdZb3VyIHNlc3Npb24gaGFzIGJlZW4gdGVybWluYXRlZCEnKTtcbiAgICAgIH0pO1xuXG4gICAgdGhpcy5vYXV0aFNlcnZpY2UuZXZlbnRzXG4gICAgICAucGlwZShmaWx0ZXIoZSA9PiBlLnR5cGUgPT09ICd0b2tlbl9yZWNlaXZlZCcpKVxuICAgICAgLnN1YnNjcmliZShlID0+IHtcbiAgICAgICAgdGhpcy5sb2FkVXNlcigpO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHNcbiAgICAgIC5waXBlKGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ2xvZ291dCcpKVxuICAgICAgLnN1YnNjcmliZShlID0+IHtcbiAgICAgICAgdGhpcy5hY2Nlc3NUb2tlbi5uZXh0KG51bGwpO1xuICAgICAgICB0aGlzLnVzZXIubmV4dChudWxsKTtcbiAgICAgIH0pO1xuXG4gICAgaWYgKHRoaXMub2F1dGhTZXJ2aWNlLmhhc1ZhbGlkQWNjZXNzVG9rZW4oKSkge1xuICAgICAgdGhpcy5sb2FkVXNlcigpO1xuICAgIH1cblxuICAgIHRoaXMuYXV0aG9yaXR5Lm5leHQodGhpcy5hdXRob3JpemVPcHRpb25zLmlzc3Vlcik7XG5cbiAgICBjb25zb2xlLmRlYnVnKFwiQXV0aG9yaXplU2VydmljZTo6aW5pdGlhbGl6ZTo6ZG9uZVwiKTtcblxuICB9XG5cbiAgcHJpdmF0ZSBsb2FkVXNlcigpIHtcbiAgICBjb25zdCBjbGFpbXMgPSB0aGlzLm9hdXRoU2VydmljZS5nZXRJZGVudGl0eUNsYWltcygpO1xuICAgIGlmICghY2xhaW1zKSB7XG4gICAgICBjb25zb2xlLmVycm9yKFwiY2xhaW1zIHdoZXJlIG51bGwgd2hlbiBsb2FkaW5nIGlkZW50aXR5IGNsYWltc1wiKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB1c2VyID0gPElVc2VyPmNsYWltcztcbiAgICBjb25zdCBhY2Nlc3NUb2tlbiA9IHRoaXMub2F1dGhTZXJ2aWNlLmdldEFjY2Vzc1Rva2VuKCk7XG4gICAgdGhpcy51c2VyLm5leHQodXNlcik7XG4gICAgdGhpcy5hY2Nlc3NUb2tlbi5uZXh0KGFjY2Vzc1Rva2VuKTtcbiAgfVxufVxuIl19
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { filter } 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.authority = new BehaviorSubject(null);
|
|
15
|
+
this.accessToken = new BehaviorSubject(null);
|
|
16
|
+
this.user = new BehaviorSubject(null);
|
|
17
|
+
console.debug("AuthorizeService::created");
|
|
18
|
+
this.getUser().subscribe(s => {
|
|
19
|
+
this.isAuthenticated.next(!!s);
|
|
20
|
+
this.isAdmin.next(!!s && s.role === "Administrators");
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
getServiceUris() {
|
|
24
|
+
return this.authorizeOptions.wellKnownServiceUris;
|
|
25
|
+
}
|
|
26
|
+
getAuthority() {
|
|
27
|
+
return this.authority;
|
|
28
|
+
}
|
|
29
|
+
getIsAuthenticated() {
|
|
30
|
+
return this.isAuthenticated;
|
|
31
|
+
}
|
|
32
|
+
getIsAdmin() {
|
|
33
|
+
return this.isAdmin;
|
|
34
|
+
}
|
|
35
|
+
getAccessToken() {
|
|
36
|
+
return this.accessToken;
|
|
37
|
+
}
|
|
38
|
+
getUser() {
|
|
39
|
+
return this.user;
|
|
40
|
+
}
|
|
41
|
+
login() {
|
|
42
|
+
this.oauthService.initImplicitFlow();
|
|
43
|
+
}
|
|
44
|
+
logout() {
|
|
45
|
+
this.oauthService.logOut(false);
|
|
46
|
+
}
|
|
47
|
+
initialize() {
|
|
48
|
+
console.debug("AuthorizeService::initialize::started");
|
|
49
|
+
const config = {
|
|
50
|
+
responseType: 'code',
|
|
51
|
+
issuer: this.authorizeOptions.issuer,
|
|
52
|
+
redirectUri: this.authorizeOptions.redirectUri,
|
|
53
|
+
postLogoutRedirectUri: this.authorizeOptions.postLogoutRedirectUri,
|
|
54
|
+
clientId: this.authorizeOptions.clientId,
|
|
55
|
+
scope: this.authorizeOptions.scope,
|
|
56
|
+
showDebugInformation: this.authorizeOptions.showDebugInformation,
|
|
57
|
+
sessionChecksEnabled: this.authorizeOptions.sessionChecksEnabled
|
|
58
|
+
};
|
|
59
|
+
this.oauthService.configure(config);
|
|
60
|
+
this.oauthService.setStorage(localStorage);
|
|
61
|
+
this.oauthService.loadDiscoveryDocumentAndTryLogin();
|
|
62
|
+
this.oauthService.setupAutomaticSilentRefresh();
|
|
63
|
+
this.oauthService.events.subscribe(e => {
|
|
64
|
+
// tslint:disable-next-line:no-console
|
|
65
|
+
console.debug('oauth/oidc event', e);
|
|
66
|
+
});
|
|
67
|
+
this.oauthService.events
|
|
68
|
+
.pipe(filter(e => e.type === 'session_terminated'))
|
|
69
|
+
.subscribe(e => {
|
|
70
|
+
// tslint:disable-next-line:no-console
|
|
71
|
+
console.debug('Your session has been terminated!');
|
|
72
|
+
});
|
|
73
|
+
this.oauthService.events
|
|
74
|
+
.pipe(filter(e => e.type === 'token_received'))
|
|
75
|
+
.subscribe(e => {
|
|
76
|
+
this.loadUser();
|
|
77
|
+
});
|
|
78
|
+
this.oauthService.events
|
|
79
|
+
.pipe(filter(e => e.type === 'logout'))
|
|
80
|
+
.subscribe(e => {
|
|
81
|
+
this.accessToken.next(null);
|
|
82
|
+
this.user.next(null);
|
|
83
|
+
});
|
|
84
|
+
if (this.oauthService.hasValidAccessToken()) {
|
|
85
|
+
this.loadUser();
|
|
86
|
+
}
|
|
87
|
+
this.authority.next(this.authorizeOptions.issuer);
|
|
88
|
+
console.debug("AuthorizeService::initialize::done");
|
|
89
|
+
}
|
|
90
|
+
loadUser() {
|
|
91
|
+
const claims = this.oauthService.getIdentityClaims();
|
|
92
|
+
if (!claims) {
|
|
93
|
+
console.error("claims where null when loading identity claims");
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
const user = claims;
|
|
97
|
+
const accessToken = this.oauthService.getAccessToken();
|
|
98
|
+
this.user.next(user);
|
|
99
|
+
this.accessToken.next(accessToken);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
AuthorizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService, deps: [{ token: AuthorizeOptions }, { token: i1.OAuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
103
|
+
AuthorizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService });
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: AuthorizeService, decorators: [{
|
|
105
|
+
type: Injectable
|
|
106
|
+
}], ctorParameters: function () { return [{ type: AuthorizeOptions, decorators: [{
|
|
107
|
+
type: Inject,
|
|
108
|
+
args: [AuthorizeOptions]
|
|
109
|
+
}] }, { type: i1.OAuthService }]; } });
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXplLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZXNobWFrZXJzL3NoYXJlZC1hdXRoL3NyYy9saWIvYXV0aG9yaXplLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUNyQyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7OztBQVF0QyxNQUFNLE9BQU8sZ0JBQWdCO0NBYzVCO0FBR0QsTUFBTSxPQUFPLGdCQUFnQjtJQU8zQixZQUE4QyxnQkFBa0MsRUFBVSxZQUEwQjtRQUF0RSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQVUsaUJBQVksR0FBWixZQUFZLENBQWM7UUFONUcsb0JBQWUsR0FBNkIsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkUsWUFBTyxHQUE2QixJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvRCxjQUFTLEdBQTRCLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQy9ELGdCQUFXLEdBQTRCLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pFLFNBQUksR0FBMkIsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7UUFHL0QsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQzNDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDM0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQy9CLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUks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QyxDQUFDO2FBQ3RDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO1FBRUwsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLG1CQUFtQixFQUFFLEVBQUU7WUFDM0MsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQ2pCO1FBRUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRWxELE9BQU8sQ0FBQyxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FBQztJQUV0RCxDQUFDO0lBRU8sUUFBUTtRQUNkLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUNyRCxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsT0FBTyxDQUFDLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO1lBQ2hFLE9BQU87U0FDUjtRQUVELE1BQU0sSUFBSSxHQUFVLE1BQU0sQ0FBQztRQUMzQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZELElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7OzZHQW5IVSxnQkFBZ0Isa0JBT1AsZ0JBQWdCO2lIQVB6QixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVTs7MEJBUUksTUFBTTsyQkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0fSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHtmaWx0ZXJ9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHtBdXRoQ29uZmlnLCBPQXV0aFNlcnZpY2V9IGZyb20gXCJhbmd1bGFyLW9hdXRoMi1vaWRjXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElVc2VyIHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgcm9sZTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQXV0aG9yaXplT3B0aW9ucyB7XHJcbiAgd2VsbEtub3duU2VydmljZVVyaXM6IHN0cmluZ1tdO1xyXG4gIC8vIFVybCBvZiB0aGUgSWRlbnRpdHkgUHJvdmlkZXJcclxuICBpc3N1ZXI6IHN0cmluZztcclxuICAvLyBVUkwgb2YgdGhlIFNQQSB0byByZWRpcmVjdCB0aGUgdXNlciB0byBhZnRlciBsb2dpblxyXG4gIHJlZGlyZWN0VXJpOiBzdHJpbmc7XHJcbiAgcG9zdExvZ291dFJlZGlyZWN0VXJpOiBzdHJpbmc7XHJcbiAgLy8gVGhlIFNQQSdzIGlkLiBUaGUgU1BBIGlzIHJlZ2lzdGVyZWQgd2l0aCB0aGlzIGlkIGF0IHRoZSBhdXRoLXNlcnZlclxyXG4gIGNsaWVudElkOiBzdHJpbmc7XHJcbiAgLy8gc2V0IHRoZSBzY29wZSBmb3IgdGhlIHBlcm1pc3Npb25zIHRoZSBjbGllbnQgc2hvdWxkIHJlcXVlc3RcclxuICAvLyBUaGUgZmlyc3QgdGhyZWUgYXJlIGRlZmluZWQgYnkgT0lEQy4gVGhlIDR0aCBpcyBhIHVzZSBjYXNlLXNwZWNpZmljIG9uZVxyXG4gIHNjb3BlOiBzdHJpbmc7XHJcbiAgc2hvd0RlYnVnSW5mb3JtYXRpb246IGJvb2xlYW47XHJcbiAgc2Vzc2lvbkNoZWNrc0VuYWJsZWQ6IGJvb2xlYW47XHJcbn1cclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEF1dGhvcml6ZVNlcnZpY2Uge1xyXG4gIHByaXZhdGUgaXNBdXRoZW50aWNhdGVkOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcclxuICBwcml2YXRlIGlzQWRtaW46IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3QoZmFsc2UpO1xyXG4gIHByaXZhdGUgYXV0aG9yaXR5OiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPiA9IG5ldyBCZWhhdmlvclN1YmplY3QobnVsbCk7XHJcbiAgcHJpdmF0ZSBhY2Nlc3NUb2tlbjogQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KG51bGwpO1xyXG4gIHByaXZhdGUgdXNlcjogQmVoYXZpb3JTdWJqZWN0PElVc2VyPiA9IG5ldyBCZWhhdmlvclN1YmplY3QobnVsbCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoQXV0aG9yaXplT3B0aW9ucykgcHJpdmF0ZSBhdXRob3JpemVPcHRpb25zOiBBdXRob3JpemVPcHRpb25zLCBwcml2YXRlIG9hdXRoU2VydmljZTogT0F1dGhTZXJ2aWNlKSB7XHJcbiAgICBjb25zb2xlLmRlYnVnKFwiQXV0aG9yaXplU2VydmljZTo6Y3JlYXRlZFwiKTtcclxuICAgIHRoaXMuZ2V0VXNlcigpLnN1YnNjcmliZShzID0+IHtcclxuICAgICAgdGhpcy5pc0F1dGhlbnRpY2F0ZWQubmV4dCghIXMpO1xyXG4gICAgICB0aGlzLmlzQWRtaW4ubmV4dCghIXMgJiYgcy5yb2xlID09PSBcIkFkbWluaXN0cmF0b3JzXCIpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0U2VydmljZVVyaXMoKTogQXJyYXk8c3RyaW5nPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hdXRob3JpemVPcHRpb25zLndlbGxLbm93blNlcnZpY2VVcmlzO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldEF1dGhvcml0eSgpOiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hdXRob3JpdHk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0SXNBdXRoZW50aWNhdGVkKCk6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiB7XHJcbiAgICByZXR1cm4gdGhpcy5pc0F1dGhlbnRpY2F0ZWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0SXNBZG1pbigpOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4ge1xyXG4gICAgcmV0dXJuIHRoaXMuaXNBZG1pbjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXRBY2Nlc3NUb2tlbigpOiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hY2Nlc3NUb2tlbjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXRVc2VyKCk6IEJlaGF2aW9yU3ViamVjdDxJVXNlcj4ge1xyXG4gICAgcmV0dXJuIHRoaXMudXNlcjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBsb2dpbigpIHtcclxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmluaXRJbXBsaWNpdEZsb3coKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBsb2dvdXQoKSB7XHJcbiAgICB0aGlzLm9hdXRoU2VydmljZS5sb2dPdXQoZmFsc2UpO1xyXG4gIH1cclxuXHJcblxyXG4gIHB1YmxpYyBpbml0aWFsaXplKCkge1xyXG5cclxuICAgIGNvbnNvbGUuZGVidWcoXCJBdXRob3JpemVTZXJ2aWNlOjppbml0aWFsaXplOjpzdGFydGVkXCIpO1xyXG5cclxuICAgIGNvbnN0IGNvbmZpZzogQXV0aENvbmZpZyA9IHtcclxuICAgICAgcmVzcG9uc2VUeXBlOiAnY29kZScsXHJcbiAgICAgIGlzc3VlcjogdGhpcy5hdXRob3JpemVPcHRpb25zLmlzc3VlcixcclxuICAgICAgcmVkaXJlY3RVcmk6IHRoaXMuYXV0aG9yaXplT3B0aW9ucy5yZWRpcmVjdFVyaSxcclxuICAgICAgcG9zdExvZ291dFJlZGlyZWN0VXJpOiB0aGlzLmF1dGhvcml6ZU9wdGlvbnMucG9zdExvZ291dFJlZGlyZWN0VXJpLFxyXG4gICAgICBjbGllbnRJZDogdGhpcy5hdXRob3JpemVPcHRpb25zLmNsaWVudElkLFxyXG4gICAgICBzY29wZTogdGhpcy5hdXRob3JpemVPcHRpb25zLnNjb3BlLFxyXG4gICAgICBzaG93RGVidWdJbmZvcm1hdGlvbjogdGhpcy5hdXRob3JpemVPcHRpb25zLnNob3dEZWJ1Z0luZm9ybWF0aW9uLFxyXG4gICAgICBzZXNzaW9uQ2hlY2tzRW5hYmxlZDogdGhpcy5hdXRob3JpemVPcHRpb25zLnNlc3Npb25DaGVja3NFbmFibGVkXHJcbiAgICB9O1xyXG5cclxuICAgIHRoaXMub2F1dGhTZXJ2aWNlLmNvbmZpZ3VyZShjb25maWcpO1xyXG4gICAgdGhpcy5vYXV0aFNlcnZpY2Uuc2V0U3RvcmFnZShsb2NhbFN0b3JhZ2UpO1xyXG4gICAgdGhpcy5vYXV0aFNlcnZpY2UubG9hZERpc2NvdmVyeURvY3VtZW50QW5kVHJ5TG9naW4oKTtcclxuXHJcbiAgICB0aGlzLm9hdXRoU2VydmljZS5zZXR1cEF1dG9tYXRpY1NpbGVudFJlZnJlc2goKTtcclxuXHJcbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHMuc3Vic2NyaWJlKGUgPT4ge1xyXG4gICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tY29uc29sZVxyXG4gICAgICBjb25zb2xlLmRlYnVnKCdvYXV0aC9vaWRjIGV2ZW50JywgZSk7XHJcbiAgICB9KTtcclxuXHJcbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHNcclxuICAgICAgLnBpcGUoZmlsdGVyKGUgPT4gZS50eXBlID09PSAnc2Vzc2lvbl90ZXJtaW5hdGVkJykpXHJcbiAgICAgIC5zdWJzY3JpYmUoZSA9PiB7XHJcbiAgICAgICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWNvbnNvbGVcclxuICAgICAgICBjb25zb2xlLmRlYnVnKCdZb3VyIHNlc3Npb24gaGFzIGJlZW4gdGVybWluYXRlZCEnKTtcclxuICAgICAgfSk7XHJcblxyXG4gICAgdGhpcy5vYXV0aFNlcnZpY2UuZXZlbnRzXHJcbiAgICAgIC5waXBlKGZpbHRlcihlID0+IGUudHlwZSA9PT0gJ3Rva2VuX3JlY2VpdmVkJykpXHJcbiAgICAgIC5zdWJzY3JpYmUoZSA9PiB7XHJcbiAgICAgICAgdGhpcy5sb2FkVXNlcigpO1xyXG4gICAgICB9KTtcclxuXHJcbiAgICB0aGlzLm9hdXRoU2VydmljZS5ldmVudHNcclxuICAgICAgLnBpcGUoZmlsdGVyKGUgPT4gZS50eXBlID09PSAnbG9nb3V0JykpXHJcbiAgICAgIC5zdWJzY3JpYmUoZSA9PiB7XHJcbiAgICAgICAgdGhpcy5hY2Nlc3NUb2tlbi5uZXh0KG51bGwpO1xyXG4gICAgICAgIHRoaXMudXNlci5uZXh0KG51bGwpO1xyXG4gICAgICB9KTtcclxuXHJcbiAgICBpZiAodGhpcy5vYXV0aFNlcnZpY2UuaGFzVmFsaWRBY2Nlc3NUb2tlbigpKSB7XHJcbiAgICAgIHRoaXMubG9hZFVzZXIoKTtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmF1dGhvcml0eS5uZXh0KHRoaXMuYXV0aG9yaXplT3B0aW9ucy5pc3N1ZXIpO1xyXG5cclxuICAgIGNvbnNvbGUuZGVidWcoXCJBdXRob3JpemVTZXJ2aWNlOjppbml0aWFsaXplOjpkb25lXCIpO1xyXG5cclxuICB9XHJcblxyXG4gIHByaXZhdGUgbG9hZFVzZXIoKSB7XHJcbiAgICBjb25zdCBjbGFpbXMgPSB0aGlzLm9hdXRoU2VydmljZS5nZXRJZGVudGl0eUNsYWltcygpO1xyXG4gICAgaWYgKCFjbGFpbXMpIHtcclxuICAgICAgY29uc29sZS5lcnJvcihcImNsYWltcyB3aGVyZSBudWxsIHdoZW4gbG9hZGluZyBpZGVudGl0eSBjbGFpbXNcIik7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCB1c2VyID0gPElVc2VyPmNsYWltcztcclxuICAgIGNvbnN0IGFjY2Vzc1Rva2VuID0gdGhpcy5vYXV0aFNlcnZpY2UuZ2V0QWNjZXNzVG9rZW4oKTtcclxuICAgIHRoaXMudXNlci5uZXh0KHVzZXIpO1xyXG4gICAgdGhpcy5hY2Nlc3NUb2tlbi5uZXh0KGFjY2Vzc1Rva2VuKTtcclxuICB9XHJcbn1cclxuIl19
|