monkey-front-core 0.0.344 → 0.0.346
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/esm2020/lib/core/services/auth/monkeyecx-auth-guard-role.service.mjs +88 -13
- package/fesm2015/monkey-front-core.mjs +86 -14
- package/fesm2015/monkey-front-core.mjs.map +1 -1
- package/fesm2020/monkey-front-core.mjs +83 -12
- package/fesm2020/monkey-front-core.mjs.map +1 -1
- package/monkey-front-core-0.0.346.tgz +0 -0
- package/package.json +1 -1
- package/lib/core/services/auth/monkeyecx-auth-guard-role.service.d.ts +0 -7
- package/monkey-front-core-0.0.344.tgz +0 -0
|
@@ -1,19 +1,94 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
1
2
|
import { Injectable } from '@angular/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
|
|
4
|
+
import * as i1 from "../storage/monkeyecx-token-storage.service";
|
|
5
|
+
import * as i2 from "@angular/router";
|
|
6
|
+
let MonkeyEcxAuthGuardByRole = class MonkeyEcxAuthGuardByRole {
|
|
4
7
|
constructor() {
|
|
5
8
|
// not to do
|
|
6
9
|
}
|
|
7
|
-
|
|
8
|
-
|
|
10
|
+
static forRoles(roles, companyType, byExclusion) {
|
|
11
|
+
class RoleCheck {
|
|
12
|
+
constructor(storageService, router) {
|
|
13
|
+
this.storageService = storageService;
|
|
14
|
+
this.router = router;
|
|
15
|
+
this.tokenCredentials = null;
|
|
16
|
+
// not to do
|
|
17
|
+
}
|
|
18
|
+
navigateToErrorPage() {
|
|
19
|
+
let path = '/app/pages/forbidden';
|
|
20
|
+
if (companyType) {
|
|
21
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
22
|
+
}
|
|
23
|
+
this.router?.navigate([path.toLowerCase()]);
|
|
24
|
+
}
|
|
25
|
+
getRole() {
|
|
26
|
+
const { tokenCredentials } = this;
|
|
27
|
+
if (!tokenCredentials)
|
|
28
|
+
return '';
|
|
29
|
+
if (tokenCredentials?.programAdmin === 'true') {
|
|
30
|
+
return 'PROGRAM_ADMIN';
|
|
31
|
+
}
|
|
32
|
+
if (tokenCredentials?.programAdmin === true) {
|
|
33
|
+
return 'PROGRAM_ADMIN';
|
|
34
|
+
}
|
|
35
|
+
return tokenCredentials?.role || '';
|
|
36
|
+
}
|
|
37
|
+
allowedSecurityAccess(roles) {
|
|
38
|
+
if (!roles?.length)
|
|
39
|
+
return true;
|
|
40
|
+
const found = roles?.indexOf(this.getRole());
|
|
41
|
+
let ret = false;
|
|
42
|
+
if (byExclusion) {
|
|
43
|
+
ret = true;
|
|
44
|
+
if (found > -1) {
|
|
45
|
+
ret = false;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
ret = false;
|
|
50
|
+
if (found > -1) {
|
|
51
|
+
ret = true;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
55
|
+
ret = true;
|
|
56
|
+
}
|
|
57
|
+
return ret;
|
|
58
|
+
}
|
|
59
|
+
async canActivate() {
|
|
60
|
+
console.log('roles');
|
|
61
|
+
console.log(roles);
|
|
62
|
+
if (!this.tokenCredentials) {
|
|
63
|
+
this.tokenCredentials = await this.storageService.getToken();
|
|
64
|
+
}
|
|
65
|
+
console.log('this.tokenCredentials');
|
|
66
|
+
console.log(this.tokenCredentials);
|
|
67
|
+
console.log('checando');
|
|
68
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
69
|
+
console.log('checou erro');
|
|
70
|
+
this.navigateToErrorPage();
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
console.log('checou ok');
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [{ token: i1.MonkeyEcxTokenStorageService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
78
|
+
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
80
|
+
type: Injectable,
|
|
81
|
+
args: [{
|
|
82
|
+
providedIn: 'root'
|
|
83
|
+
}]
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.MonkeyEcxTokenStorageService }, { type: i2.Router }]; } });
|
|
85
|
+
return RoleCheck;
|
|
9
86
|
}
|
|
10
|
-
}
|
|
11
|
-
MonkeyEcxAuthGuardByRole
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
}], ctorParameters: function () { return []; } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvcmUvc3JjL2xpYi9jb3JlL3NlcnZpY2VzL2F1dGgvbW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyx3QkFBd0I7SUFDbkM7UUFDRSxZQUFZO0lBQ2QsQ0FBQztJQUVELEtBQUssQ0FBQyxXQUFXO1FBQ2YsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDOztxSEFQVSx3QkFBd0I7eUhBQXhCLHdCQUF3QixjQUZ2QixNQUFNOzJGQUVQLHdCQUF3QjtrQkFIcEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIE1vbmtleUVjeEF1dGhHdWFyZEJ5Um9sZSB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIC8vIG5vdCB0byBkb1xuICB9XG5cbiAgYXN5bmMgY2FuQWN0aXZhdGUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qIEBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgTW9ua2V5RWN4QXV0aEd1YXJkQnlSb2xlU2VydmljZSB7XG4gIHN0YXRpYyBmb3JSb2xlcyhyb2xlczogc3RyaW5nW10sIGNvbXBhbnlUeXBlPzogc3RyaW5nLCBieUV4Y2x1c2lvbj86IGJvb2xlYW4pIHtcbiAgICBASW5qZWN0YWJsZSh7XG4gICAgICBwcm92aWRlZEluOiAncm9vdCdcbiAgICB9KVxuICAgIGNsYXNzIFJvbGVDaGVjayBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcbiAgICAgIHByaXZhdGUgdG9rZW5DcmVkZW50aWFsczogYW55ID0gbnVsbDtcblxuICAgICAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yYWdlU2VydmljZTogTW9ua2V5RWN4VG9rZW5TdG9yYWdlU2VydmljZSxcbiAgICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXIpIHtcbiAgICAgICAgLy8gbm90IHRvIGRvXG4gICAgICB9XG5cbiAgICAgIHByaXZhdGUgbmF2aWdhdGVUb0Vycm9yUGFnZSgpIHtcbiAgICAgICAgbGV0IHBhdGggPSAnL2FwcC9wYWdlcy9mb3JiaWRkZW4nO1xuICAgICAgICBpZiAoY29tcGFueVR5cGUpIHtcbiAgICAgICAgICBwYXRoID0gYC9hcHAvJHtjb21wYW55VHlwZX0vcGFnZXMvZm9yYmlkZGVuYDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnJvdXRlcj8ubmF2aWdhdGUoW3BhdGgudG9Mb3dlckNhc2UoKV0pO1xuICAgICAgfVxuXG4gICAgICBwcml2YXRlIGdldFJvbGUoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgeyB0b2tlbkNyZWRlbnRpYWxzIH0gPSB0aGlzO1xuXG4gICAgICAgIGlmICghdG9rZW5DcmVkZW50aWFscykgcmV0dXJuICcnO1xuICAgICAgICBpZiAodG9rZW5DcmVkZW50aWFscz8ucHJvZ3JhbUFkbWluID09PSAndHJ1ZScpIHtcbiAgICAgICAgICByZXR1cm4gJ1BST0dSQU1fQURNSU4nO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0b2tlbkNyZWRlbnRpYWxzPy5wcm9ncmFtQWRtaW4gPT09IHRydWUpIHtcbiAgICAgICAgICByZXR1cm4gJ1BST0dSQU1fQURNSU4nO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRva2VuQ3JlZGVudGlhbHM/LnJvbGUgfHwgJyc7XG4gICAgICB9XG5cbiAgICAgIHByaXZhdGUgYWxsb3dlZFNlY3VyaXR5QWNjZXNzKHJvbGVzOiBzdHJpbmdbXSk6IGJvb2xlYW4ge1xuICAgICAgICBpZiAoIXJvbGVzPy5sZW5ndGgpIHJldHVybiB0cnVlO1xuXG4gICAgICAgIGNvbnN0IGZvdW5kID0gcm9sZXM/LmluZGV4T2YodGhpcy5nZXRSb2xlKCkpO1xuICAgICAgICBsZXQgcmV0ID0gZmFsc2U7XG4gICAgICAgIGlmIChieUV4Y2x1c2lvbikge1xuICAgICAgICAgIHJldCA9IHRydWU7XG4gICAgICAgICAgaWYgKGZvdW5kID4gLTEpIHtcbiAgICAgICAgICAgIHJldCA9IGZhbHNlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXQgPSBmYWxzZTtcbiAgICAgICAgICBpZiAoZm91bmQgPiAtMSkge1xuICAgICAgICAgICAgcmV0ID0gdHJ1ZTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFyb2xlcyB8fCByb2xlcy5sZW5ndGggPT09IDAgfHwgdGhpcy5nZXRSb2xlKCkgPT09ICdQUk9HUkFNX0FETUlOJykge1xuICAgICAgICAgIHJldCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHJldDtcbiAgICAgIH1cblxuICAgICAgYXN5bmMgY2FuQWN0aXZhdGUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgICAgIGNvbnNvbGUubG9nKCdyb2xlcycpO1xuICAgICAgICBjb25zb2xlLmxvZyhyb2xlcyk7XG4gICAgICAgIGlmICghdGhpcy50b2tlbkNyZWRlbnRpYWxzKSB7XG4gICAgICAgICAgdGhpcy50b2tlbkNyZWRlbnRpYWxzID0gYXdhaXQgdGhpcy5zdG9yYWdlU2VydmljZS5nZXRUb2tlbigpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnNvbGUubG9nKCd0aGlzLnRva2VuQ3JlZGVudGlhbHMnKTtcbiAgICAgICAgY29uc29sZS5sb2codGhpcy50b2tlbkNyZWRlbnRpYWxzKTtcbiAgICAgICAgY29uc29sZS5sb2coJ2NoZWNhbmRvJyk7XG4gICAgICAgIGlmICghdGhpcy5hbGxvd2VkU2VjdXJpdHlBY2Nlc3Mocm9sZXMpKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coJ2NoZWNvdSBlcnJvJyk7XG4gICAgICAgICAgdGhpcy5uYXZpZ2F0ZVRvRXJyb3JQYWdlKCk7XG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgICAgIGNvbnNvbGUubG9nKCdjaGVjb3Ugb2snKTtcblxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gUm9sZUNoZWNrO1xuICB9XG59XG4qL1xuIl19
|
|
87
|
+
};
|
|
88
|
+
MonkeyEcxAuthGuardByRole = __decorate([
|
|
89
|
+
Injectable({
|
|
90
|
+
providedIn: 'root'
|
|
91
|
+
})
|
|
92
|
+
], MonkeyEcxAuthGuardByRole);
|
|
93
|
+
export { MonkeyEcxAuthGuardByRole };
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkeyecx-auth-guard-role.service.js","sourceRoot":"","sources":["../../../../../../../projects/monkey-front-core/src/lib/core/services/auth/monkeyecx-auth-guard-role.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { CanActivate, Router } from '@angular/router';\nimport { MonkeyEcxTokenStorageService } from '../storage/monkeyecx-token-storage.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class MonkeyEcxAuthGuardByRole {\n  constructor() {\n    // not to do\n  }\n\n  static forRoles(roles: string[], companyType?: string, byExclusion?: boolean) {\n    @Injectable({\n      providedIn: 'root'\n    })\n    class RoleCheck implements CanActivate {\n      private tokenCredentials: any = null;\n\n      constructor(\n        private storageService: MonkeyEcxTokenStorageService,\n        private router: Router\n      ) {\n        // not to do\n      }\n\n      private navigateToErrorPage() {\n        let path = '/app/pages/forbidden';\n        if (companyType) {\n          path = `/app/${companyType}/pages/forbidden`;\n        }\n        this.router?.navigate([path.toLowerCase()]);\n      }\n\n      private getRole(): string {\n        const { tokenCredentials } = this;\n\n        if (!tokenCredentials) return '';\n        if (tokenCredentials?.programAdmin === 'true') {\n          return 'PROGRAM_ADMIN';\n        }\n        if (tokenCredentials?.programAdmin === true) {\n          return 'PROGRAM_ADMIN';\n        }\n\n        return tokenCredentials?.role || '';\n      }\n\n      private allowedSecurityAccess(roles: string[]): boolean {\n        if (!roles?.length) return true;\n\n        const found = roles?.indexOf(this.getRole());\n        let ret = false;\n        if (byExclusion) {\n          ret = true;\n          if (found > -1) {\n            ret = false;\n          }\n        } else {\n          ret = false;\n          if (found > -1) {\n            ret = true;\n          }\n        }\n        if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {\n          ret = true;\n        }\n        return ret;\n      }\n\n      async canActivate(): Promise<boolean> {\n        console.log('roles');\n        console.log(roles);\n        if (!this.tokenCredentials) {\n          this.tokenCredentials = await this.storageService.getToken();\n        }\n        console.log('this.tokenCredentials');\n        console.log(this.tokenCredentials);\n        console.log('checando');\n        if (!this.allowedSecurityAccess(roles)) {\n          console.log('checou erro');\n          this.navigateToErrorPage();\n          return false;\n        }\n        console.log('checou ok');\n\n        return true;\n      }\n    }\n\n    return RoleCheck;\n  }\n}\n\n/* @Injectable({ providedIn: 'root' })\nexport class MonkeyEcxAuthGuardByRoleService {\n  static forRoles(roles: string[], companyType?: string, byExclusion?: boolean) {\n    @Injectable({\n      providedIn: 'root'\n    })\n    class RoleCheck implements CanActivate {\n      private tokenCredentials: any = null;\n\n      constructor(private storageService: MonkeyEcxTokenStorageService,\n      private router: Router) {\n        // not to do\n      }\n\n      private navigateToErrorPage() {\n        let path = '/app/pages/forbidden';\n        if (companyType) {\n          path = `/app/${companyType}/pages/forbidden`;\n        }\n        this.router?.navigate([path.toLowerCase()]);\n      }\n\n      private getRole(): string {\n        const { tokenCredentials } = this;\n\n        if (!tokenCredentials) return '';\n        if (tokenCredentials?.programAdmin === 'true') {\n          return 'PROGRAM_ADMIN';\n        }\n        if (tokenCredentials?.programAdmin === true) {\n          return 'PROGRAM_ADMIN';\n        }\n\n        return tokenCredentials?.role || '';\n      }\n\n      private allowedSecurityAccess(roles: string[]): boolean {\n        if (!roles?.length) return true;\n\n        const found = roles?.indexOf(this.getRole());\n        let ret = false;\n        if (byExclusion) {\n          ret = true;\n          if (found > -1) {\n            ret = false;\n          }\n        } else {\n          ret = false;\n          if (found > -1) {\n            ret = true;\n          }\n        }\n        if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {\n          ret = true;\n        }\n        return ret;\n      }\n\n      async canActivate(): Promise<boolean> {\n        console.log('roles');\n        console.log(roles);\n        if (!this.tokenCredentials) {\n          this.tokenCredentials = await this.storageService.getToken();\n        }\n        console.log('this.tokenCredentials');\n        console.log(this.tokenCredentials);\n        console.log('checando');\n        if (!this.allowedSecurityAccess(roles)) {\n          console.log('checou erro');\n          this.navigateToErrorPage();\n          return false;\n        }\n        console.log('checou ok');\n\n        return true;\n      }\n    }\n\n    return RoleCheck;\n  }\n}\n*/\n"]}
|
|
@@ -4111,24 +4111,96 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
4111
4111
|
args: [{ providedIn: 'root' }]
|
|
4112
4112
|
}], ctorParameters: function () { return [{ type: MonkeyEcxAuthenticationService }]; } });
|
|
4113
4113
|
|
|
4114
|
-
class MonkeyEcxAuthGuardByRole {
|
|
4114
|
+
let MonkeyEcxAuthGuardByRole = class MonkeyEcxAuthGuardByRole {
|
|
4115
4115
|
constructor() {
|
|
4116
4116
|
// not to do
|
|
4117
4117
|
}
|
|
4118
|
-
|
|
4119
|
-
|
|
4120
|
-
|
|
4121
|
-
|
|
4118
|
+
static forRoles(roles, companyType, byExclusion) {
|
|
4119
|
+
class RoleCheck {
|
|
4120
|
+
constructor(storageService, router) {
|
|
4121
|
+
this.storageService = storageService;
|
|
4122
|
+
this.router = router;
|
|
4123
|
+
this.tokenCredentials = null;
|
|
4124
|
+
// not to do
|
|
4125
|
+
}
|
|
4126
|
+
navigateToErrorPage() {
|
|
4127
|
+
var _a;
|
|
4128
|
+
let path = '/app/pages/forbidden';
|
|
4129
|
+
if (companyType) {
|
|
4130
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
4131
|
+
}
|
|
4132
|
+
(_a = this.router) === null || _a === void 0 ? void 0 : _a.navigate([path.toLowerCase()]);
|
|
4133
|
+
}
|
|
4134
|
+
getRole() {
|
|
4135
|
+
const { tokenCredentials } = this;
|
|
4136
|
+
if (!tokenCredentials)
|
|
4137
|
+
return '';
|
|
4138
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === 'true') {
|
|
4139
|
+
return 'PROGRAM_ADMIN';
|
|
4140
|
+
}
|
|
4141
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === true) {
|
|
4142
|
+
return 'PROGRAM_ADMIN';
|
|
4143
|
+
}
|
|
4144
|
+
return (tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.role) || '';
|
|
4145
|
+
}
|
|
4146
|
+
allowedSecurityAccess(roles) {
|
|
4147
|
+
if (!(roles === null || roles === void 0 ? void 0 : roles.length))
|
|
4148
|
+
return true;
|
|
4149
|
+
const found = roles === null || roles === void 0 ? void 0 : roles.indexOf(this.getRole());
|
|
4150
|
+
let ret = false;
|
|
4151
|
+
if (byExclusion) {
|
|
4152
|
+
ret = true;
|
|
4153
|
+
if (found > -1) {
|
|
4154
|
+
ret = false;
|
|
4155
|
+
}
|
|
4156
|
+
}
|
|
4157
|
+
else {
|
|
4158
|
+
ret = false;
|
|
4159
|
+
if (found > -1) {
|
|
4160
|
+
ret = true;
|
|
4161
|
+
}
|
|
4162
|
+
}
|
|
4163
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
4164
|
+
ret = true;
|
|
4165
|
+
}
|
|
4166
|
+
return ret;
|
|
4167
|
+
}
|
|
4168
|
+
canActivate() {
|
|
4169
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
4170
|
+
console.log('roles');
|
|
4171
|
+
console.log(roles);
|
|
4172
|
+
if (!this.tokenCredentials) {
|
|
4173
|
+
this.tokenCredentials = yield this.storageService.getToken();
|
|
4174
|
+
}
|
|
4175
|
+
console.log('this.tokenCredentials');
|
|
4176
|
+
console.log(this.tokenCredentials);
|
|
4177
|
+
console.log('checando');
|
|
4178
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
4179
|
+
console.log('checou erro');
|
|
4180
|
+
this.navigateToErrorPage();
|
|
4181
|
+
return false;
|
|
4182
|
+
}
|
|
4183
|
+
console.log('checou ok');
|
|
4184
|
+
return true;
|
|
4185
|
+
});
|
|
4186
|
+
}
|
|
4187
|
+
}
|
|
4188
|
+
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [{ token: MonkeyEcxTokenStorageService }, { token: i2$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4189
|
+
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
4190
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
4191
|
+
type: Injectable,
|
|
4192
|
+
args: [{
|
|
4193
|
+
providedIn: 'root'
|
|
4194
|
+
}]
|
|
4195
|
+
}], ctorParameters: function () { return [{ type: MonkeyEcxTokenStorageService }, { type: i2$2.Router }]; } });
|
|
4196
|
+
return RoleCheck;
|
|
4122
4197
|
}
|
|
4123
|
-
}
|
|
4124
|
-
MonkeyEcxAuthGuardByRole
|
|
4125
|
-
|
|
4126
|
-
|
|
4127
|
-
|
|
4128
|
-
|
|
4129
|
-
providedIn: 'root'
|
|
4130
|
-
}]
|
|
4131
|
-
}], ctorParameters: function () { return []; } });
|
|
4198
|
+
};
|
|
4199
|
+
MonkeyEcxAuthGuardByRole = __decorate([
|
|
4200
|
+
Injectable({
|
|
4201
|
+
providedIn: 'root'
|
|
4202
|
+
})
|
|
4203
|
+
], MonkeyEcxAuthGuardByRole);
|
|
4132
4204
|
|
|
4133
4205
|
class MonkeyEcxAuthGuard {
|
|
4134
4206
|
constructor(monkeyecxAuthenticationService) {
|