monkey-front-core 0.0.340 → 0.0.342
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/index.mjs +2 -2
- package/esm2020/lib/core/services/auth/monkeyecx-auth-guard-role.service.mjs +73 -66
- package/fesm2015/monkey-front-core.mjs +75 -75
- package/fesm2015/monkey-front-core.mjs.map +1 -1
- package/fesm2020/monkey-front-core.mjs +72 -72
- package/fesm2020/monkey-front-core.mjs.map +1 -1
- package/lib/core/services/auth/index.d.ts +1 -1
- package/monkey-front-core-0.0.342.tgz +0 -0
- package/package.json +1 -1
- package/monkey-front-core-0.0.340.tgz +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from './monkeyecx-auth-guard-company.service';
|
|
2
2
|
export * from './monkeyecx-auth-guard-login.service';
|
|
3
|
-
export *
|
|
3
|
+
export * from './monkeyecx-auth-guard-role.service';
|
|
4
4
|
export * from './monkeyecx-auth-guard.service';
|
|
5
5
|
export * from './monkeyecx-authentication.service';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29yZS9zcmMvbGliL2NvcmUvc2VydmljZXMvYXV0aC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsb0NBQW9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL21vbmtleWVjeC1hdXRoLWd1YXJkLWNvbXBhbnkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL21vbmtleWVjeC1hdXRoLWd1YXJkLWxvZ2luLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9tb25rZXllY3gtYXV0aC1ndWFyZC1yb2xlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9tb25rZXllY3gtYXV0aC1ndWFyZC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9ua2V5ZWN4LWF1dGhlbnRpY2F0aW9uLnNlcnZpY2UnO1xuIl19
|
|
@@ -1,82 +1,89 @@
|
|
|
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";
|
|
4
5
|
import * as i2 from "@angular/router";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
navigateToErrorPage() {
|
|
14
|
-
let path = '/app/pages/forbidden';
|
|
15
|
-
if (companyType) {
|
|
16
|
-
path = `/app/${companyType}/pages/forbidden`;
|
|
6
|
+
let MonkeyEcxAuthGuardByRoleService = class MonkeyEcxAuthGuardByRoleService {
|
|
7
|
+
static forRoles(roles, companyType, byExclusion) {
|
|
8
|
+
class RoleCheck {
|
|
9
|
+
constructor(storageService, router) {
|
|
10
|
+
this.storageService = storageService;
|
|
11
|
+
this.router = router;
|
|
12
|
+
this.tokenCredentials = null;
|
|
13
|
+
// not to do
|
|
17
14
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
if (tokenCredentials?.programAdmin === 'true') {
|
|
25
|
-
return 'PROGRAM_ADMIN';
|
|
15
|
+
navigateToErrorPage() {
|
|
16
|
+
let path = '/app/pages/forbidden';
|
|
17
|
+
if (companyType) {
|
|
18
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
19
|
+
}
|
|
20
|
+
this.router?.navigate([path.toLowerCase()]);
|
|
26
21
|
}
|
|
27
|
-
|
|
28
|
-
|
|
22
|
+
getRole() {
|
|
23
|
+
const { tokenCredentials } = this;
|
|
24
|
+
if (!tokenCredentials)
|
|
25
|
+
return '';
|
|
26
|
+
if (tokenCredentials?.programAdmin === 'true') {
|
|
27
|
+
return 'PROGRAM_ADMIN';
|
|
28
|
+
}
|
|
29
|
+
if (tokenCredentials?.programAdmin === true) {
|
|
30
|
+
return 'PROGRAM_ADMIN';
|
|
31
|
+
}
|
|
32
|
+
return tokenCredentials?.role || '';
|
|
29
33
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
34
|
+
allowedSecurityAccess(roles) {
|
|
35
|
+
if (!roles?.length)
|
|
36
|
+
return true;
|
|
37
|
+
const found = roles?.indexOf(this.getRole());
|
|
38
|
+
let ret = false;
|
|
39
|
+
if (byExclusion) {
|
|
40
|
+
ret = true;
|
|
41
|
+
if (found > -1) {
|
|
42
|
+
ret = false;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
40
46
|
ret = false;
|
|
47
|
+
if (found > -1) {
|
|
48
|
+
ret = true;
|
|
49
|
+
}
|
|
41
50
|
}
|
|
42
|
-
|
|
43
|
-
else {
|
|
44
|
-
ret = false;
|
|
45
|
-
if (found > -1) {
|
|
51
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
46
52
|
ret = true;
|
|
47
53
|
}
|
|
54
|
+
return ret;
|
|
48
55
|
}
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
this.navigateToErrorPage();
|
|
66
|
-
return false;
|
|
56
|
+
async canActivate() {
|
|
57
|
+
console.log('roles');
|
|
58
|
+
console.log(roles);
|
|
59
|
+
if (!this.tokenCredentials) {
|
|
60
|
+
this.tokenCredentials = await this.storageService.getToken();
|
|
61
|
+
}
|
|
62
|
+
console.log('this.tokenCredentials');
|
|
63
|
+
console.log(this.tokenCredentials);
|
|
64
|
+
console.log('checando');
|
|
65
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
66
|
+
console.log('checou erro');
|
|
67
|
+
this.navigateToErrorPage();
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
console.log('checou ok');
|
|
71
|
+
return true;
|
|
67
72
|
}
|
|
68
|
-
console.log('checou ok');
|
|
69
|
-
return true;
|
|
70
73
|
}
|
|
74
|
+
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 });
|
|
75
|
+
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
77
|
+
type: Injectable,
|
|
78
|
+
args: [{
|
|
79
|
+
providedIn: 'root'
|
|
80
|
+
}]
|
|
81
|
+
}], ctorParameters: function () { return [{ type: i1.MonkeyEcxTokenStorageService }, { type: i2.Router }]; } });
|
|
82
|
+
return RoleCheck;
|
|
71
83
|
}
|
|
72
|
-
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 });
|
|
73
|
-
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
74
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
75
|
-
type: Injectable,
|
|
76
|
-
args: [{
|
|
77
|
-
providedIn: 'root'
|
|
78
|
-
}]
|
|
79
|
-
}], ctorParameters: function () { return [{ type: i1.MonkeyEcxTokenStorageService }, { type: i2.Router }]; } });
|
|
80
|
-
return RoleCheck;
|
|
81
84
|
};
|
|
82
|
-
|
|
85
|
+
MonkeyEcxAuthGuardByRoleService = __decorate([
|
|
86
|
+
Injectable({ providedIn: 'root' })
|
|
87
|
+
], MonkeyEcxAuthGuardByRoleService);
|
|
88
|
+
export { MonkeyEcxAuthGuardByRoleService };
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvcmUvc3JjL2xpYi9jb3JlL3NlcnZpY2VzL2F1dGgvbW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBSzNDLElBQWEsK0JBQStCLEdBQTVDLE1BQWEsK0JBQStCO0lBQzFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBZSxFQUFFLFdBQW9CLEVBQUUsV0FBcUI7UUFDMUUsTUFHTSxTQUFTO1lBR2IsWUFBb0IsY0FBNEMsRUFDeEQsTUFBYztnQkFERixtQkFBYyxHQUFkLGNBQWMsQ0FBOEI7Z0JBQ3hELFdBQU0sR0FBTixNQUFNLENBQVE7Z0JBSGQscUJBQWdCLEdBQVEsSUFBSSxDQUFDO2dCQUluQyxZQUFZO1lBQ2QsQ0FBQztZQUVPLG1CQUFtQjtnQkFDekIsSUFBSSxJQUFJLEdBQUcsc0JBQXNCLENBQUM7Z0JBQ2xDLElBQUksV0FBVyxFQUFFO29CQUNmLElBQUksR0FBRyxRQUFRLFdBQVcsa0JBQWtCLENBQUM7aUJBQzlDO2dCQUNELElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUM5QyxDQUFDO1lBRU8sT0FBTztnQkFDYixNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsR0FBRyxJQUFJLENBQUM7Z0JBRWxDLElBQUksQ0FBQyxnQkFBZ0I7b0JBQUUsT0FBTyxFQUFFLENBQUM7Z0JBQ2pDLElBQUksZ0JBQWdCLEVBQUUsWUFBWSxLQUFLLE1BQU0sRUFBRTtvQkFDN0MsT0FBTyxlQUFlLENBQUM7aUJBQ3hCO2dCQUNELElBQUksZ0JBQWdCLEVBQUUsWUFBWSxLQUFLLElBQUksRUFBRTtvQkFDM0MsT0FBTyxlQUFlLENBQUM7aUJBQ3hCO2dCQUVELE9BQU8sZ0JBQWdCLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUN0QyxDQUFDO1lBRU8scUJBQXFCLENBQUMsS0FBZTtnQkFDM0MsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNO29CQUFFLE9BQU8sSUFBSSxDQUFDO2dCQUVoQyxNQUFNLEtBQUssR0FBRyxLQUFLLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUM3QyxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUM7Z0JBQ2hCLElBQUksV0FBVyxFQUFFO29CQUNmLEdBQUcsR0FBRyxJQUFJLENBQUM7b0JBQ1gsSUFBSSxLQUFLLEdBQUcsQ0FBQyxDQUFDLEVBQUU7d0JBQ2QsR0FBRyxHQUFHLEtBQUssQ0FBQztxQkFDYjtpQkFDRjtxQkFBTTtvQkFDTCxHQUFHLEdBQUcsS0FBSyxDQUFDO29CQUNaLElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQyxFQUFFO3dCQUNkLEdBQUcsR0FBRyxJQUFJLENBQUM7cUJBQ1o7aUJBQ0Y7Z0JBQ0QsSUFBSSxDQUFDLEtBQUssSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFFO29CQUN0RSxHQUFHLEdBQUcsSUFBSSxDQUFDO2lCQUNaO2dCQUNELE9BQU8sR0FBRyxDQUFDO1lBQ2IsQ0FBQztZQUVELEtBQUssQ0FBQyxXQUFXO2dCQUNmLE9BQU8sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQ3JCLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ25CLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUU7b0JBQzFCLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUM7aUJBQzlEO2dCQUNELE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUMsQ0FBQztnQkFDckMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztnQkFDbkMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztnQkFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDdEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztvQkFDM0IsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7b0JBQzNCLE9BQU8sS0FBSyxDQUFDO2lCQUNkO2dCQUNELE9BQU8sQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7Z0JBRXpCLE9BQU8sSUFBSSxDQUFDO1lBQ2QsQ0FBQzs7OEdBckVHLFNBQVM7a0hBQVQsU0FBUyxjQUZELE1BQU07bUdBRWQsU0FBUzswQkFIZCxVQUFVOzJCQUFDOzRCQUNWLFVBQVUsRUFBRSxNQUFNO3lCQUNuQjs7UUF5RUQsT0FBTyxTQUFTLENBQUM7S0FDbEI7Q0FDRixDQUFBO0FBL0VZLCtCQUErQjtJQUQzQyxVQUFVLENBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLENBQUM7R0FDdEIsK0JBQStCLENBK0UzQztTQS9FWSwrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDYW5BY3RpdmF0ZSwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE1vbmtleUVjeFRva2VuU3RvcmFnZVNlcnZpY2UgfSBmcm9tICcuLi9zdG9yYWdlJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBNb25rZXlFY3hBdXRoR3VhcmRCeVJvbGVTZXJ2aWNlIHtcbiAgc3RhdGljIGZvclJvbGVzKHJvbGVzOiBzdHJpbmdbXSwgY29tcGFueVR5cGU/OiBzdHJpbmcsIGJ5RXhjbHVzaW9uPzogYm9vbGVhbikge1xuICAgIEBJbmplY3RhYmxlKHtcbiAgICAgIHByb3ZpZGVkSW46ICdyb290J1xuICAgIH0pXG4gICAgY2xhc3MgUm9sZUNoZWNrIGltcGxlbWVudHMgQ2FuQWN0aXZhdGUge1xuICAgICAgcHJpdmF0ZSB0b2tlbkNyZWRlbnRpYWxzOiBhbnkgPSBudWxsO1xuXG4gICAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHN0b3JhZ2VTZXJ2aWNlOiBNb25rZXlFY3hUb2tlblN0b3JhZ2VTZXJ2aWNlLFxuICAgICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcikge1xuICAgICAgICAvLyBub3QgdG8gZG9cbiAgICAgIH1cblxuICAgICAgcHJpdmF0ZSBuYXZpZ2F0ZVRvRXJyb3JQYWdlKCkge1xuICAgICAgICBsZXQgcGF0aCA9ICcvYXBwL3BhZ2VzL2ZvcmJpZGRlbic7XG4gICAgICAgIGlmIChjb21wYW55VHlwZSkge1xuICAgICAgICAgIHBhdGggPSBgL2FwcC8ke2NvbXBhbnlUeXBlfS9wYWdlcy9mb3JiaWRkZW5gO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMucm91dGVyPy5uYXZpZ2F0ZShbcGF0aC50b0xvd2VyQ2FzZSgpXSk7XG4gICAgICB9XG5cbiAgICAgIHByaXZhdGUgZ2V0Um9sZSgpOiBzdHJpbmcge1xuICAgICAgICBjb25zdCB7IHRva2VuQ3JlZGVudGlhbHMgfSA9IHRoaXM7XG5cbiAgICAgICAgaWYgKCF0b2tlbkNyZWRlbnRpYWxzKSByZXR1cm4gJyc7XG4gICAgICAgIGlmICh0b2tlbkNyZWRlbnRpYWxzPy5wcm9ncmFtQWRtaW4gPT09ICd0cnVlJykge1xuICAgICAgICAgIHJldHVybiAnUFJPR1JBTV9BRE1JTic7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHRva2VuQ3JlZGVudGlhbHM/LnByb2dyYW1BZG1pbiA9PT0gdHJ1ZSkge1xuICAgICAgICAgIHJldHVybiAnUFJPR1JBTV9BRE1JTic7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdG9rZW5DcmVkZW50aWFscz8ucm9sZSB8fCAnJztcbiAgICAgIH1cblxuICAgICAgcHJpdmF0ZSBhbGxvd2VkU2VjdXJpdHlBY2Nlc3Mocm9sZXM6IHN0cmluZ1tdKTogYm9vbGVhbiB7XG4gICAgICAgIGlmICghcm9sZXM/Lmxlbmd0aCkgcmV0dXJuIHRydWU7XG5cbiAgICAgICAgY29uc3QgZm91bmQgPSByb2xlcz8uaW5kZXhPZih0aGlzLmdldFJvbGUoKSk7XG4gICAgICAgIGxldCByZXQgPSBmYWxzZTtcbiAgICAgICAgaWYgKGJ5RXhjbHVzaW9uKSB7XG4gICAgICAgICAgcmV0ID0gdHJ1ZTtcbiAgICAgICAgICBpZiAoZm91bmQgPiAtMSkge1xuICAgICAgICAgICAgcmV0ID0gZmFsc2U7XG4gICAgICAgICAgfVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJldCA9IGZhbHNlO1xuICAgICAgICAgIGlmIChmb3VuZCA+IC0xKSB7XG4gICAgICAgICAgICByZXQgPSB0cnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoIXJvbGVzIHx8IHJvbGVzLmxlbmd0aCA9PT0gMCB8fCB0aGlzLmdldFJvbGUoKSA9PT0gJ1BST0dSQU1fQURNSU4nKSB7XG4gICAgICAgICAgcmV0ID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmV0O1xuICAgICAgfVxuXG4gICAgICBhc3luYyBjYW5BY3RpdmF0ZSgpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICAgICAgY29uc29sZS5sb2coJ3JvbGVzJyk7XG4gICAgICAgIGNvbnNvbGUubG9nKHJvbGVzKTtcbiAgICAgICAgaWYgKCF0aGlzLnRva2VuQ3JlZGVudGlhbHMpIHtcbiAgICAgICAgICB0aGlzLnRva2VuQ3JlZGVudGlhbHMgPSBhd2FpdCB0aGlzLnN0b3JhZ2VTZXJ2aWNlLmdldFRva2VuKCk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc29sZS5sb2coJ3RoaXMudG9rZW5DcmVkZW50aWFscycpO1xuICAgICAgICBjb25zb2xlLmxvZyh0aGlzLnRva2VuQ3JlZGVudGlhbHMpO1xuICAgICAgICBjb25zb2xlLmxvZygnY2hlY2FuZG8nKTtcbiAgICAgICAgaWYgKCF0aGlzLmFsbG93ZWRTZWN1cml0eUFjY2Vzcyhyb2xlcykpIHtcbiAgICAgICAgICBjb25zb2xlLmxvZygnY2hlY291IGVycm8nKTtcbiAgICAgICAgICB0aGlzLm5hdmlnYXRlVG9FcnJvclBhZ2UoKTtcbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgICAgY29uc29sZS5sb2coJ2NoZWNvdSBvaycpO1xuXG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBSb2xlQ2hlY2s7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4111,91 +4111,91 @@ 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
|
-
|
|
4115
|
-
|
|
4116
|
-
|
|
4117
|
-
|
|
4118
|
-
|
|
4119
|
-
|
|
4120
|
-
|
|
4121
|
-
|
|
4122
|
-
navigateToErrorPage() {
|
|
4123
|
-
var _a;
|
|
4124
|
-
let path = '/app/pages/forbidden';
|
|
4125
|
-
if (companyType) {
|
|
4126
|
-
path = `/app/${companyType}/pages/forbidden`;
|
|
4114
|
+
let MonkeyEcxAuthGuardByRoleService = class MonkeyEcxAuthGuardByRoleService {
|
|
4115
|
+
static forRoles(roles, companyType, byExclusion) {
|
|
4116
|
+
class RoleCheck {
|
|
4117
|
+
constructor(storageService, router) {
|
|
4118
|
+
this.storageService = storageService;
|
|
4119
|
+
this.router = router;
|
|
4120
|
+
this.tokenCredentials = null;
|
|
4121
|
+
// not to do
|
|
4127
4122
|
}
|
|
4128
|
-
(
|
|
4129
|
-
|
|
4130
|
-
|
|
4131
|
-
|
|
4132
|
-
|
|
4133
|
-
|
|
4134
|
-
|
|
4135
|
-
return 'PROGRAM_ADMIN';
|
|
4123
|
+
navigateToErrorPage() {
|
|
4124
|
+
var _a;
|
|
4125
|
+
let path = '/app/pages/forbidden';
|
|
4126
|
+
if (companyType) {
|
|
4127
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
4128
|
+
}
|
|
4129
|
+
(_a = this.router) === null || _a === void 0 ? void 0 : _a.navigate([path.toLowerCase()]);
|
|
4136
4130
|
}
|
|
4137
|
-
|
|
4138
|
-
|
|
4131
|
+
getRole() {
|
|
4132
|
+
const { tokenCredentials } = this;
|
|
4133
|
+
if (!tokenCredentials)
|
|
4134
|
+
return '';
|
|
4135
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === 'true') {
|
|
4136
|
+
return 'PROGRAM_ADMIN';
|
|
4137
|
+
}
|
|
4138
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === true) {
|
|
4139
|
+
return 'PROGRAM_ADMIN';
|
|
4140
|
+
}
|
|
4141
|
+
return (tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.role) || '';
|
|
4139
4142
|
}
|
|
4140
|
-
|
|
4141
|
-
|
|
4142
|
-
|
|
4143
|
-
|
|
4144
|
-
|
|
4145
|
-
|
|
4146
|
-
|
|
4147
|
-
|
|
4148
|
-
|
|
4149
|
-
|
|
4143
|
+
allowedSecurityAccess(roles) {
|
|
4144
|
+
if (!(roles === null || roles === void 0 ? void 0 : roles.length))
|
|
4145
|
+
return true;
|
|
4146
|
+
const found = roles === null || roles === void 0 ? void 0 : roles.indexOf(this.getRole());
|
|
4147
|
+
let ret = false;
|
|
4148
|
+
if (byExclusion) {
|
|
4149
|
+
ret = true;
|
|
4150
|
+
if (found > -1) {
|
|
4151
|
+
ret = false;
|
|
4152
|
+
}
|
|
4153
|
+
}
|
|
4154
|
+
else {
|
|
4150
4155
|
ret = false;
|
|
4156
|
+
if (found > -1) {
|
|
4157
|
+
ret = true;
|
|
4158
|
+
}
|
|
4151
4159
|
}
|
|
4152
|
-
|
|
4153
|
-
else {
|
|
4154
|
-
ret = false;
|
|
4155
|
-
if (found > -1) {
|
|
4160
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
4156
4161
|
ret = true;
|
|
4157
4162
|
}
|
|
4163
|
+
return ret;
|
|
4158
4164
|
}
|
|
4159
|
-
|
|
4160
|
-
|
|
4165
|
+
canActivate() {
|
|
4166
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
4167
|
+
console.log('roles');
|
|
4168
|
+
console.log(roles);
|
|
4169
|
+
if (!this.tokenCredentials) {
|
|
4170
|
+
this.tokenCredentials = yield this.storageService.getToken();
|
|
4171
|
+
}
|
|
4172
|
+
console.log('this.tokenCredentials');
|
|
4173
|
+
console.log(this.tokenCredentials);
|
|
4174
|
+
console.log('checando');
|
|
4175
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
4176
|
+
console.log('checou erro');
|
|
4177
|
+
this.navigateToErrorPage();
|
|
4178
|
+
return false;
|
|
4179
|
+
}
|
|
4180
|
+
console.log('checou ok');
|
|
4181
|
+
return true;
|
|
4182
|
+
});
|
|
4161
4183
|
}
|
|
4162
|
-
return ret;
|
|
4163
|
-
}
|
|
4164
|
-
canActivate() {
|
|
4165
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
4166
|
-
console.log('roles');
|
|
4167
|
-
console.log(roles);
|
|
4168
|
-
if (!this.tokenCredentials) {
|
|
4169
|
-
this.tokenCredentials = yield this.storageService.getToken();
|
|
4170
|
-
}
|
|
4171
|
-
console.log('this.tokenCredentials');
|
|
4172
|
-
console.log(this.tokenCredentials);
|
|
4173
|
-
console.log('checando');
|
|
4174
|
-
if (!this.allowedSecurityAccess(roles)) {
|
|
4175
|
-
console.log('checou erro');
|
|
4176
|
-
this.navigateToErrorPage();
|
|
4177
|
-
return false;
|
|
4178
|
-
}
|
|
4179
|
-
console.log('checou ok');
|
|
4180
|
-
return true;
|
|
4181
|
-
});
|
|
4182
4184
|
}
|
|
4185
|
+
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 });
|
|
4186
|
+
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
4187
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
4188
|
+
type: Injectable,
|
|
4189
|
+
args: [{
|
|
4190
|
+
providedIn: 'root'
|
|
4191
|
+
}]
|
|
4192
|
+
}], ctorParameters: function () { return [{ type: MonkeyEcxTokenStorageService }, { type: i2$2.Router }]; } });
|
|
4193
|
+
return RoleCheck;
|
|
4183
4194
|
}
|
|
4184
|
-
|
|
4185
|
-
|
|
4186
|
-
|
|
4187
|
-
|
|
4188
|
-
args: [{
|
|
4189
|
-
providedIn: 'root'
|
|
4190
|
-
}]
|
|
4191
|
-
}], ctorParameters: function () { return [{ type: MonkeyEcxTokenStorageService }, { type: i2$2.Router }]; } });
|
|
4192
|
-
return RoleCheck;
|
|
4193
|
-
};
|
|
4194
|
-
|
|
4195
|
-
var monkeyecxAuthGuardRole_service = /*#__PURE__*/Object.freeze({
|
|
4196
|
-
__proto__: null,
|
|
4197
|
-
forRoles: forRoles
|
|
4198
|
-
});
|
|
4195
|
+
};
|
|
4196
|
+
MonkeyEcxAuthGuardByRoleService = __decorate([
|
|
4197
|
+
Injectable({ providedIn: 'root' })
|
|
4198
|
+
], MonkeyEcxAuthGuardByRoleService);
|
|
4199
4199
|
|
|
4200
4200
|
class MonkeyEcxAuthGuard {
|
|
4201
4201
|
constructor(monkeyecxAuthenticationService) {
|
|
@@ -5662,5 +5662,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
5662
5662
|
* Generated bundle index. Do not edit.
|
|
5663
5663
|
*/
|
|
5664
5664
|
|
|
5665
|
-
export { AlertsComponent, AlertsModule, ClosedToMaintenanceComponent, ClosedToMaintenanceModule, CurrencyConfigComponent, CurrencyConfigModule, decoratorsUtils as DecoratorsUtils, Link, MonkeyEcxAlertsService, MonkeyEcxAuthGuard,
|
|
5665
|
+
export { AlertsComponent, AlertsModule, ClosedToMaintenanceComponent, ClosedToMaintenanceModule, CurrencyConfigComponent, CurrencyConfigModule, decoratorsUtils as DecoratorsUtils, Link, MonkeyEcxAlertsService, MonkeyEcxAuthGuard, MonkeyEcxAuthGuardByRoleService, MonkeyEcxAuthGuardCompany, MonkeyEcxAuthGuardLogin, MonkeyEcxAuthenticationService, MonkeyEcxBlobSecurePipe, MonkeyEcxCommonsService, MonkeyEcxConfigModule, MonkeyEcxConfigService, MonkeyEcxCookieStorageService, MonkeyEcxCoreCharts, MonkeyEcxCoreClearDecorators, MonkeyEcxCoreLog, MonkeyEcxCoreService, MonkeyEcxCoreServiceConstructor, MonkeyEcxCoreServicePaged, MonkeyEcxCoreServiceQueue, MonkeyEcxCurrencyConfigService, MonkeyEcxDirectivesModule, MonkeyEcxDiscoveryParamsService, MonkeyEcxDisplayFirstNamePipe, MonkeyEcxDisplayInitialsPipe, MonkeyEcxDragDropDirective, MonkeyEcxErrorConfigService, MonkeyEcxErrorHandlingModule, MonkeyEcxErrorHandlingService, MonkeyEcxFeatureByProgramDirective, MonkeyEcxFeatureDirective, MonkeyEcxFeatureToggleService, MonkeyEcxFormatAddressPipe, MonkeyEcxFormatBeaufityJSONPipe, MonkeyEcxFormatCurrency, MonkeyEcxFormatCurrencyPipe, MonkeyEcxFormatDateGroupPipe, MonkeyEcxFormatDateTimelapsePipe, MonkeyEcxFormatDateUnixTimelapsePipe, MonkeyEcxFormatDocumentPipe, MonkeyEcxFormatDocumentTypePipe, MonkeyEcxFormatNumberPipe, MonkeyEcxFormatPhonePipe, MonkeyEcxFormatSizePipe, MonkeyEcxFormatTaxPipe, MonkeyEcxFormatUpper, MonkeyEcxFormatValue, MonkeyEcxFormatZipCodePipe, MonkeyEcxHandlingService, MonkeyEcxHttpConfigErrorInterceptor, MonkeyEcxHttpConfigHeaderInterceptor, MonkeyEcxHttpConfigInterceptorModule, MonkeyEcxHttpConfigLoadingInProgressInterceptor, MonkeyEcxHttpConfigQueueInterceptor, MonkeyEcxHttpErrorHandlingService, MonkeyEcxLoggedHandlingService, MonkeyEcxLogsConfigService, MonkeyEcxMaintenanceConfigService, MonkeyEcxModel, MonkeyEcxOnlyAlphaNumericDirective, MonkeyEcxOnlyNumbersDirective, MonkeyEcxOthersErrorsHandlingService, MonkeyEcxPaginationService, MonkeyEcxPipesModule, MonkeyEcxPopoverDirective, MonkeyEcxPopoverOptionsDirective, MonkeyEcxProgressBarComponent, MonkeyEcxProgressBarModule, MonkeyEcxProgressBarService, MonkeyEcxRequestDownloadHandlingService, MonkeyEcxRequestDownloadedHandlingService, MonkeyEcxRequestPagedHandling, MonkeyEcxRequestQueueHandlingService, MonkeyEcxRequestQueueModalHandlingService, MonkeyEcxRequestScheduleService, MonkeyEcxSecurityConsoleConfigService, MonkeyEcxSecurityDirective, MonkeyEcxService, MonkeyEcxServiceDownload, MonkeyEcxServiceUpload, MonkeyEcxServiceWorkerConfigService, MonkeyEcxSpecificationSearch, MonkeyEcxTextTruncatePipe, MonkeyEcxTokenStorageService, MonkeyEcxTooltipDirective, MonkeyEcxTruncateQtdPipe, MonkeyEcxUtils, MonkeyEcxi18nConfigService, MonkeyFrontCoreModule, OpSearch, POPOVER_OPTIONS, statics as Statics, validateUtils as ValidateUtils, Validators, VersionChangedComponent, VersionChangedModule, comboValidator, dateRangeValidator, dateStartEndValidator, dateValidator, documentValidator, emailValidator, passwordConfirmValidator, registerValidator, index as store, trueValidator, urlValidator, valueGreaterThanZero, zipCodeValidator };
|
|
5666
5666
|
//# sourceMappingURL=monkey-front-core.mjs.map
|