monkey-front-core 0.0.348 → 0.0.349
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 +53 -51
- package/esm2020/lib/core/services/auth/monkeyecx-authentication.service.mjs +6 -1
- package/fesm2015/monkey-front-core.mjs +56 -50
- package/fesm2015/monkey-front-core.mjs.map +1 -1
- package/fesm2020/monkey-front-core.mjs +55 -50
- package/fesm2020/monkey-front-core.mjs.map +1 -1
- package/lib/core/services/auth/monkeyecx-authentication.service.d.ts +2 -0
- package/monkey-front-core-0.0.349.tgz +0 -0
- package/package.json +1 -1
- package/monkey-front-core-0.0.348.tgz +0 -0
|
@@ -1,85 +1,87 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./monkeyecx-authentication.service";
|
|
5
|
+
import * as i2 from "@angular/router";
|
|
4
6
|
let MonkeyEcxAuthGuardByRole = class MonkeyEcxAuthGuardByRole {
|
|
5
7
|
constructor() {
|
|
6
8
|
// not to do
|
|
7
9
|
}
|
|
8
10
|
static forRoles(roles, companyType, byExclusion) {
|
|
9
11
|
class RoleCheck {
|
|
10
|
-
constructor() {
|
|
12
|
+
constructor(monkeyecxAuthenticationService, router) {
|
|
13
|
+
this.monkeyecxAuthenticationService = monkeyecxAuthenticationService;
|
|
14
|
+
this.router = router;
|
|
11
15
|
this.tokenCredentials = null;
|
|
12
16
|
// not to do
|
|
13
17
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
navigateToErrorPage() {
|
|
19
|
+
let path = '/app/pages/forbidden';
|
|
20
|
+
if (companyType) {
|
|
21
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
22
|
+
}
|
|
23
|
+
this.router?.navigate([path.toLowerCase()]);
|
|
20
24
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
return tokenCredentials?.role || '';
|
|
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 || '';
|
|
34
36
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
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
|
+
}
|
|
45
53
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
if (found > -1) {
|
|
49
|
-
ret = true;
|
|
54
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
55
|
+
ret = true;
|
|
50
56
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
ret = true;
|
|
54
|
-
}
|
|
55
|
-
return ret;
|
|
56
|
-
} */
|
|
57
|
+
return ret;
|
|
58
|
+
}
|
|
57
59
|
async canActivate() {
|
|
58
60
|
console.log('roles');
|
|
59
61
|
console.log(roles);
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
62
|
+
if (!this.tokenCredentials) {
|
|
63
|
+
this.tokenCredentials = await this.monkeyecxAuthenticationService.getToken();
|
|
64
|
+
}
|
|
63
65
|
console.log('this.tokenCredentials');
|
|
64
66
|
console.log(this.tokenCredentials);
|
|
65
67
|
console.log('checando');
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
68
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
69
|
+
console.log('checou erro');
|
|
70
|
+
this.navigateToErrorPage();
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
71
73
|
console.log('checou ok');
|
|
72
74
|
return true;
|
|
73
75
|
}
|
|
74
76
|
}
|
|
75
|
-
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
77
|
+
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [{ token: i1.MonkeyEcxAuthenticationService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
76
78
|
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
77
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
78
80
|
type: Injectable,
|
|
79
81
|
args: [{
|
|
80
82
|
providedIn: 'root'
|
|
81
83
|
}]
|
|
82
|
-
}], ctorParameters: function () { return []; } });
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.MonkeyEcxAuthenticationService }, { type: i2.Router }]; } });
|
|
83
85
|
return RoleCheck;
|
|
84
86
|
}
|
|
85
87
|
};
|
|
@@ -89,4 +91,4 @@ MonkeyEcxAuthGuardByRole = __decorate([
|
|
|
89
91
|
})
|
|
90
92
|
], MonkeyEcxAuthGuardByRole);
|
|
91
93
|
export { MonkeyEcxAuthGuardByRole };
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;AAO3C,IAAa,wBAAwB,GAArC,MAAa,wBAAwB;IACnC;QACE,YAAY;IACd,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,KAAe,EAAE,WAAoB,EAAE,WAAqB;QAC1E,MAGM,SAAS;YAGb,YACU,8BAA8D,EAC9D,MAAc;gBADd,mCAA8B,GAA9B,8BAA8B,CAAgC;gBAC9D,WAAM,GAAN,MAAM,CAAQ;gBAJhB,qBAAgB,GAAQ,IAAI,CAAC;gBAMnC,YAAY;YACd,CAAC;YAEO,mBAAmB;gBACzB,IAAI,IAAI,GAAG,sBAAsB,CAAC;gBAClC,IAAI,WAAW,EAAE;oBACf,IAAI,GAAG,QAAQ,WAAW,kBAAkB,CAAC;iBAC9C;gBACD,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;YAC9C,CAAC;YAEO,OAAO;gBACb,MAAM,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC;gBAElC,IAAI,CAAC,gBAAgB;oBAAE,OAAO,EAAE,CAAC;gBACjC,IAAI,gBAAgB,EAAE,YAAY,KAAK,MAAM,EAAE;oBAC7C,OAAO,eAAe,CAAC;iBACxB;gBACD,IAAI,gBAAgB,EAAE,YAAY,KAAK,IAAI,EAAE;oBAC3C,OAAO,eAAe,CAAC;iBACxB;gBAED,OAAO,gBAAgB,EAAE,IAAI,IAAI,EAAE,CAAC;YACtC,CAAC;YAEO,qBAAqB,CAAC,KAAe;gBAC3C,IAAI,CAAC,KAAK,EAAE,MAAM;oBAAE,OAAO,IAAI,CAAC;gBAEhC,MAAM,KAAK,GAAG,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;gBAC7C,IAAI,GAAG,GAAG,KAAK,CAAC;gBAChB,IAAI,WAAW,EAAE;oBACf,GAAG,GAAG,IAAI,CAAC;oBACX,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;wBACd,GAAG,GAAG,KAAK,CAAC;qBACb;iBACF;qBAAM;oBACL,GAAG,GAAG,KAAK,CAAC;oBACZ,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;wBACd,GAAG,GAAG,IAAI,CAAC;qBACZ;iBACF;gBACD,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,eAAe,EAAE;oBACtE,GAAG,GAAG,IAAI,CAAC;iBACZ;gBACD,OAAO,GAAG,CAAC;YACb,CAAC;YAED,KAAK,CAAC,WAAW;gBACf,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;gBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACnB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;oBAC1B,IAAI,CAAC,gBAAgB,GAAG,MAAM,IAAI,CAAC,8BAA8B,CAAC,QAAQ,EAAE,CAAC;iBAC9E;gBACD,OAAO,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC;gBACrC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACnC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;gBACxB,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAE;oBACtC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;oBAC3B,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC3B,OAAO,KAAK,CAAC;iBACd;gBACD,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;gBAEzB,OAAO,IAAI,CAAC;YACd,CAAC;;8GAvEG,SAAS;kHAAT,SAAS,cAFD,MAAM;mGAEd,SAAS;0BAHd,UAAU;2BAAC;4BACV,UAAU,EAAE,MAAM;yBACnB;;QA2ED,OAAO,SAAS,CAAC;KAClB;CACF,CAAA;AArFY,wBAAwB;IAHpC,UAAU,CAAC;QACV,UAAU,EAAE,MAAM;KACnB,CAAC;GACW,wBAAwB,CAqFpC;SArFY,wBAAwB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { CanActivate, Router } from '@angular/router';\nimport { MonkeyEcxAuthenticationService } from './monkeyecx-authentication.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 monkeyecxAuthenticationService: MonkeyEcxAuthenticationService,\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.monkeyecxAuthenticationService.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"]}
|
|
@@ -46,6 +46,10 @@ export class MonkeyEcxAuthenticationService {
|
|
|
46
46
|
console.error('refreshToken needs to be declared!');
|
|
47
47
|
return null;
|
|
48
48
|
};
|
|
49
|
+
this.getToken = async () => {
|
|
50
|
+
console.error('getToken needs to be declared!');
|
|
51
|
+
return null;
|
|
52
|
+
};
|
|
49
53
|
// not to do
|
|
50
54
|
}
|
|
51
55
|
init(args) {
|
|
@@ -63,6 +67,7 @@ export class MonkeyEcxAuthenticationService {
|
|
|
63
67
|
this.getRequestWithHeadersOb = args?.getRequestWithHeadersOb.bind(this);
|
|
64
68
|
this.refreshShouldHappen = args?.refreshShouldHappen || this.refreshShouldHappen.bind(this);
|
|
65
69
|
this.refreshToken = args?.refreshToken || this.refreshToken.bind(this);
|
|
70
|
+
this.getToken = args?.getToken || this.getToken.bind(this);
|
|
66
71
|
}
|
|
67
72
|
}
|
|
68
73
|
MonkeyEcxAuthenticationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthenticationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -71,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
71
76
|
type: Injectable,
|
|
72
77
|
args: [{ providedIn: 'root' }]
|
|
73
78
|
}], ctorParameters: function () { return []; } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkeyecx-authentication.service.js","sourceRoot":"","sources":["../../../../../../../projects/monkey-front-core/src/lib/core/services/auth/monkeyecx-authentication.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport { HttpErrorResponse, HttpRequest } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\n\n@Injectable({ providedIn: 'root' })\nexport class MonkeyEcxAuthenticationService {\n  constructor() {\n    // not to do\n  }\n\n  hadAtLeastOneLogin = async () => {\n    console.error('hadAtLeastOneLogin needs to be declared!');\n    return null;\n  };\n\n  redirectApp = () => {\n    console.error('redirectApp needs to be declared!');\n    return null;\n  };\n\n  redirectLoginWelcomeBack = () => {\n    console.error('redirectLoginWelcomeBack needs to be declared!');\n    return null;\n  };\n\n  isAuthorized = async () => {\n    console.error('isAuthorized needs to be declared!');\n    return false;\n  };\n\n  isCompanyAuthorized = async () => {\n    console.error('isCompanyAuthorized needs to be declared!');\n    return false;\n  };\n\n  isTokenMandatory = (url: string): boolean => {\n    console.error('isTokenMandatory needs to be declared!');\n    return false;\n  };\n\n  getRequestWithHeaders = (request: HttpRequest<any>): HttpRequest<any> | any => {\n    console.error('getRequestWithHeaders needs to be declared!');\n    return null;\n  };\n\n  getRequestWithHeadersOb = (request: HttpRequest<any>): Observable<any> | any => {\n    console.error('getRequestWithHeadersOb needs to be declared!');\n    return null;\n  };\n\n  getRequestWithHeadersAsync = async (request: HttpRequest<any>) => {\n    console.error('getRequestWithHeadersAsync needs to be declared!');\n    return null;\n  };\n\n  refreshShouldHappen = (response: HttpErrorResponse): boolean => {\n    console.error('refreshShouldHappen needs to be declared!');\n    return false;\n  };\n\n  refreshToken = async () => {\n    console.error('refreshToken needs to be declared!');\n    return null;\n  };\n\n  getToken = async () => {\n    console.error('getToken needs to be declared!');\n    return null;\n  };\n\n  init(args: {\n    hadAtLeastOneLogin?: any;\n    redirectApp?: any;\n    redirectLoginWelcomeBack?: any;\n    isAuthorized?: any;\n    isTokenMandatory?: any;\n    isCompanyAuthorized?: any;\n    getRequestWithHeaders?: any;\n    getRequestWithHeadersAsync?: any;\n    getRequestWithHeadersOb?: any;\n    refreshShouldHappen?: any;\n    refreshToken?: any;\n    getToken?: any;\n  }) {\n    this.hadAtLeastOneLogin = args?.hadAtLeastOneLogin || this.hadAtLeastOneLogin.bind(this);\n    this.redirectApp = args?.redirectApp || this.redirectApp.bind(this);\n    this.redirectLoginWelcomeBack =\n      args?.redirectLoginWelcomeBack || this.redirectLoginWelcomeBack.bind(this);\n    this.isAuthorized = args?.isAuthorized || this.isAuthorized.bind(this);\n    this.isTokenMandatory = args?.isTokenMandatory || this.isTokenMandatory.bind(this);\n    this.isCompanyAuthorized = args?.isCompanyAuthorized || this.isCompanyAuthorized.bind(this);\n    this.getRequestWithHeaders =\n      args?.getRequestWithHeaders || this.getRequestWithHeaders.bind(this);\n    this.getRequestWithHeadersAsync =\n      args?.getRequestWithHeadersAsync || this.getRequestWithHeadersAsync.bind(this);\n    this.getRequestWithHeadersOb = args?.getRequestWithHeadersOb.bind(this);\n    this.refreshShouldHappen = args?.refreshShouldHappen || this.refreshShouldHappen.bind(this);\n    this.refreshToken = args?.refreshToken || this.refreshToken.bind(this);\n    this.getToken = args?.getToken || this.getToken.bind(this);\n  }\n}\n"]}
|
|
@@ -4032,6 +4032,10 @@ class MonkeyEcxAuthenticationService {
|
|
|
4032
4032
|
console.error('refreshToken needs to be declared!');
|
|
4033
4033
|
return null;
|
|
4034
4034
|
});
|
|
4035
|
+
this.getToken = () => __awaiter(this, void 0, void 0, function* () {
|
|
4036
|
+
console.error('getToken needs to be declared!');
|
|
4037
|
+
return null;
|
|
4038
|
+
});
|
|
4035
4039
|
// not to do
|
|
4036
4040
|
}
|
|
4037
4041
|
init(args) {
|
|
@@ -4049,6 +4053,7 @@ class MonkeyEcxAuthenticationService {
|
|
|
4049
4053
|
this.getRequestWithHeadersOb = args === null || args === void 0 ? void 0 : args.getRequestWithHeadersOb.bind(this);
|
|
4050
4054
|
this.refreshShouldHappen = (args === null || args === void 0 ? void 0 : args.refreshShouldHappen) || this.refreshShouldHappen.bind(this);
|
|
4051
4055
|
this.refreshToken = (args === null || args === void 0 ? void 0 : args.refreshToken) || this.refreshToken.bind(this);
|
|
4056
|
+
this.getToken = (args === null || args === void 0 ? void 0 : args.getToken) || this.getToken.bind(this);
|
|
4052
4057
|
}
|
|
4053
4058
|
}
|
|
4054
4059
|
MonkeyEcxAuthenticationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthenticationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -4117,81 +4122,82 @@ let MonkeyEcxAuthGuardByRole = class MonkeyEcxAuthGuardByRole {
|
|
|
4117
4122
|
}
|
|
4118
4123
|
static forRoles(roles, companyType, byExclusion) {
|
|
4119
4124
|
class RoleCheck {
|
|
4120
|
-
constructor() {
|
|
4125
|
+
constructor(monkeyecxAuthenticationService, router) {
|
|
4126
|
+
this.monkeyecxAuthenticationService = monkeyecxAuthenticationService;
|
|
4127
|
+
this.router = router;
|
|
4121
4128
|
this.tokenCredentials = null;
|
|
4122
4129
|
// not to do
|
|
4123
4130
|
}
|
|
4124
|
-
|
|
4125
|
-
|
|
4126
|
-
|
|
4127
|
-
|
|
4128
|
-
|
|
4129
|
-
|
|
4131
|
+
navigateToErrorPage() {
|
|
4132
|
+
var _a;
|
|
4133
|
+
let path = '/app/pages/forbidden';
|
|
4134
|
+
if (companyType) {
|
|
4135
|
+
path = `/app/${companyType}/pages/forbidden`;
|
|
4136
|
+
}
|
|
4137
|
+
(_a = this.router) === null || _a === void 0 ? void 0 : _a.navigate([path.toLowerCase()]);
|
|
4130
4138
|
}
|
|
4131
|
-
|
|
4132
|
-
|
|
4133
|
-
|
|
4134
|
-
|
|
4135
|
-
|
|
4136
|
-
|
|
4137
|
-
|
|
4138
|
-
|
|
4139
|
-
|
|
4140
|
-
|
|
4141
|
-
|
|
4142
|
-
|
|
4143
|
-
return tokenCredentials?.role || '';
|
|
4139
|
+
getRole() {
|
|
4140
|
+
const { tokenCredentials } = this;
|
|
4141
|
+
if (!tokenCredentials)
|
|
4142
|
+
return '';
|
|
4143
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === 'true') {
|
|
4144
|
+
return 'PROGRAM_ADMIN';
|
|
4145
|
+
}
|
|
4146
|
+
if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === true) {
|
|
4147
|
+
return 'PROGRAM_ADMIN';
|
|
4148
|
+
}
|
|
4149
|
+
return (tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.role) || '';
|
|
4144
4150
|
}
|
|
4145
|
-
|
|
4146
|
-
|
|
4147
|
-
|
|
4148
|
-
|
|
4149
|
-
|
|
4150
|
-
|
|
4151
|
-
|
|
4152
|
-
|
|
4153
|
-
|
|
4154
|
-
|
|
4151
|
+
allowedSecurityAccess(roles) {
|
|
4152
|
+
if (!(roles === null || roles === void 0 ? void 0 : roles.length))
|
|
4153
|
+
return true;
|
|
4154
|
+
const found = roles === null || roles === void 0 ? void 0 : roles.indexOf(this.getRole());
|
|
4155
|
+
let ret = false;
|
|
4156
|
+
if (byExclusion) {
|
|
4157
|
+
ret = true;
|
|
4158
|
+
if (found > -1) {
|
|
4159
|
+
ret = false;
|
|
4160
|
+
}
|
|
4161
|
+
}
|
|
4162
|
+
else {
|
|
4163
|
+
ret = false;
|
|
4164
|
+
if (found > -1) {
|
|
4165
|
+
ret = true;
|
|
4166
|
+
}
|
|
4155
4167
|
}
|
|
4156
|
-
|
|
4157
|
-
|
|
4158
|
-
if (found > -1) {
|
|
4159
|
-
ret = true;
|
|
4168
|
+
if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
|
|
4169
|
+
ret = true;
|
|
4160
4170
|
}
|
|
4161
|
-
|
|
4162
|
-
|
|
4163
|
-
ret = true;
|
|
4164
|
-
}
|
|
4165
|
-
return ret;
|
|
4166
|
-
} */
|
|
4171
|
+
return ret;
|
|
4172
|
+
}
|
|
4167
4173
|
canActivate() {
|
|
4168
4174
|
return __awaiter(this, void 0, void 0, function* () {
|
|
4169
4175
|
console.log('roles');
|
|
4170
4176
|
console.log(roles);
|
|
4171
|
-
|
|
4172
|
-
|
|
4173
|
-
|
|
4177
|
+
if (!this.tokenCredentials) {
|
|
4178
|
+
this.tokenCredentials = yield this.monkeyecxAuthenticationService.getToken();
|
|
4179
|
+
}
|
|
4174
4180
|
console.log('this.tokenCredentials');
|
|
4175
4181
|
console.log(this.tokenCredentials);
|
|
4176
4182
|
console.log('checando');
|
|
4177
|
-
|
|
4178
|
-
|
|
4179
|
-
|
|
4180
|
-
|
|
4181
|
-
|
|
4183
|
+
if (!this.allowedSecurityAccess(roles)) {
|
|
4184
|
+
console.log('checou erro');
|
|
4185
|
+
this.navigateToErrorPage();
|
|
4186
|
+
return false;
|
|
4187
|
+
}
|
|
4182
4188
|
console.log('checou ok');
|
|
4183
4189
|
return true;
|
|
4184
4190
|
});
|
|
4185
4191
|
}
|
|
4186
4192
|
}
|
|
4187
|
-
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4193
|
+
RoleCheck.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, deps: [{ token: MonkeyEcxAuthenticationService }, { token: i2$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4188
4194
|
RoleCheck.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, providedIn: 'root' });
|
|
4189
4195
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: RoleCheck, decorators: [{
|
|
4190
4196
|
type: Injectable,
|
|
4191
4197
|
args: [{
|
|
4192
4198
|
providedIn: 'root'
|
|
4193
4199
|
}]
|
|
4194
|
-
}], ctorParameters: function () { return []; } });
|
|
4200
|
+
}], ctorParameters: function () { return [{ type: MonkeyEcxAuthenticationService }, { type: i2$2.Router }]; } });
|
|
4195
4201
|
return RoleCheck;
|
|
4196
4202
|
}
|
|
4197
4203
|
};
|