monkey-front-core 0.0.355 → 0.0.356

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,27 +1,86 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
+ import * as i1 from "./monkeyecx-authentication.service";
4
+ import * as i2 from "@angular/router";
3
5
  export class MonkeyEcxAuthGuardByRole {
4
- constructor() {
6
+ constructor(monkeyecxAuthenticationService, router) {
7
+ this.monkeyecxAuthenticationService = monkeyecxAuthenticationService;
8
+ this.router = router;
9
+ this.securityCredentials = null;
10
+ this.tokenCredentials = null;
5
11
  // not to do
6
12
  }
7
- static forRoles(roles, companyType, byExclusion) {
8
- class RoleCheck {
9
- constructor() {
10
- // not to do
13
+ navigateToErrorPage() {
14
+ const { tokenCredentials } = this;
15
+ const companyType = tokenCredentials?.companyType;
16
+ let path = '/app/pages/forbidden';
17
+ if (companyType) {
18
+ path = `/app/${companyType}/pages/forbidden`;
19
+ }
20
+ this.router?.navigate([path.toLowerCase()]);
21
+ }
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 || '';
33
+ }
34
+ allowedSecurityAccess(roles, byExclusion) {
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 {
46
+ ret = false;
47
+ if (found > -1) {
48
+ ret = true;
49
+ }
50
+ }
51
+ if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
52
+ ret = true;
53
+ }
54
+ return ret;
55
+ }
56
+ async canActivate(route, state) {
57
+ this.securityCredentials = route.data?.securityCredentials;
58
+ console.log('this.securityCredentials');
59
+ console.log(this.securityCredentials);
60
+ if (this.securityCredentials) {
61
+ const { roles, byExclusion } = this.securityCredentials;
62
+ if (!this.tokenCredentials) {
63
+ this.tokenCredentials = await this.monkeyecxAuthenticationService.getToken();
11
64
  }
12
- async canActivate() {
13
- return true;
65
+ console.log('this.tokenCredentials');
66
+ console.log(this.tokenCredentials);
67
+ console.log('checando');
68
+ if (!this.allowedSecurityAccess(roles, byExclusion)) {
69
+ console.log('checou erro');
70
+ this.navigateToErrorPage();
71
+ return false;
14
72
  }
73
+ console.log('checou ok');
15
74
  }
16
- return RoleCheck;
75
+ return true;
17
76
  }
18
77
  }
19
- MonkeyEcxAuthGuardByRole.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
78
+ MonkeyEcxAuthGuardByRole.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, deps: [{ token: i1.MonkeyEcxAuthenticationService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
20
79
  MonkeyEcxAuthGuardByRole.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, providedIn: 'root' });
21
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, decorators: [{
22
81
  type: Injectable,
23
82
  args: [{
24
83
  providedIn: 'root'
25
84
  }]
26
- }], ctorParameters: function () { return []; } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvcmUvc3JjL2xpYi9jb3JlL3NlcnZpY2VzL2F1dGgvbW9ua2V5ZWN4LWF1dGgtZ3VhcmQtcm9sZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTNDLE1BQU0sT0FBTyx3QkFBd0I7SUFDbkM7UUFDRSxZQUFZO0lBQ2QsQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBZSxFQUFFLFdBQW9CLEVBQUUsV0FBcUI7UUFDMUUsTUFBTSxTQUFTO1lBQ2I7Z0JBQ0UsWUFBWTtZQUNkLENBQUM7WUFFRCxLQUFLLENBQUMsV0FBVztnQkFDZixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7U0FDRjtRQUVELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7O3FIQWpCVSx3QkFBd0I7eUhBQXhCLHdCQUF3QixjQUZ2QixNQUFNOzJGQUVQLHdCQUF3QjtrQkFIcEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDYW5BY3RpdmF0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIE1vbmtleUVjeEF1dGhHdWFyZEJ5Um9sZSB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIC8vIG5vdCB0byBkb1xuICB9XG5cbiAgc3RhdGljIGZvclJvbGVzKHJvbGVzOiBzdHJpbmdbXSwgY29tcGFueVR5cGU/OiBzdHJpbmcsIGJ5RXhjbHVzaW9uPzogYm9vbGVhbikge1xuICAgIGNsYXNzIFJvbGVDaGVjayBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcbiAgICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICAvLyBub3QgdG8gZG9cbiAgICAgIH1cblxuICAgICAgYXN5bmMgY2FuQWN0aXZhdGUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBSb2xlQ2hlY2s7XG4gIH1cbn1cblxuLyogQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTW9ua2V5RWN4QXV0aEd1YXJkQnlSb2xlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gbm90IHRvIGRvXG4gIH1cblxuICBzdGF0aWMgZm9yUm9sZXMocm9sZXM6IHN0cmluZ1tdLCBjb21wYW55VHlwZT86IHN0cmluZywgYnlFeGNsdXNpb24/OiBib29sZWFuKSB7XG4gICAgQEluamVjdGFibGUoe1xuICAgICAgcHJvdmlkZWRJbjogJ3Jvb3QnXG4gICAgfSlcbiAgICBjbGFzcyBSb2xlQ2hlY2sgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSB7XG4gICAgICBwcml2YXRlIHRva2VuQ3JlZGVudGlhbHM6IGFueSA9IG51bGw7XG5cbiAgICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIG1vbmtleWVjeEF1dGhlbnRpY2F0aW9uU2VydmljZTogTW9ua2V5RWN4QXV0aGVudGljYXRpb25TZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyXG4gICAgICApIHtcbiAgICAgICAgLy8gbm90IHRvIGRvXG4gICAgICB9XG5cbiAgICAgIHByaXZhdGUgbmF2aWdhdGVUb0Vycm9yUGFnZSgpIHtcbiAgICAgICAgbGV0IHBhdGggPSAnL2FwcC9wYWdlcy9mb3JiaWRkZW4nO1xuICAgICAgICBpZiAoY29tcGFueVR5cGUpIHtcbiAgICAgICAgICBwYXRoID0gYC9hcHAvJHtjb21wYW55VHlwZX0vcGFnZXMvZm9yYmlkZGVuYDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnJvdXRlcj8ubmF2aWdhdGUoW3BhdGgudG9Mb3dlckNhc2UoKV0pO1xuICAgICAgfVxuXG4gICAgICBwcml2YXRlIGdldFJvbGUoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgeyB0b2tlbkNyZWRlbnRpYWxzIH0gPSB0aGlzO1xuXG4gICAgICAgIGlmICghdG9rZW5DcmVkZW50aWFscykgcmV0dXJuICcnO1xuICAgICAgICBpZiAodG9rZW5DcmVkZW50aWFscz8ucHJvZ3JhbUFkbWluID09PSAndHJ1ZScpIHtcbiAgICAgICAgICByZXR1cm4gJ1BST0dSQU1fQURNSU4nO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0b2tlbkNyZWRlbnRpYWxzPy5wcm9ncmFtQWRtaW4gPT09IHRydWUpIHtcbiAgICAgICAgICByZXR1cm4gJ1BST0dSQU1fQURNSU4nO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRva2VuQ3JlZGVudGlhbHM/LnJvbGUgfHwgJyc7XG4gICAgICB9XG5cbiAgICAgIHByaXZhdGUgYWxsb3dlZFNlY3VyaXR5QWNjZXNzKHJvbGVzOiBzdHJpbmdbXSk6IGJvb2xlYW4ge1xuICAgICAgICBpZiAoIXJvbGVzPy5sZW5ndGgpIHJldHVybiB0cnVlO1xuXG4gICAgICAgIGNvbnN0IGZvdW5kID0gcm9sZXM/LmluZGV4T2YodGhpcy5nZXRSb2xlKCkpO1xuICAgICAgICBsZXQgcmV0ID0gZmFsc2U7XG4gICAgICAgIGlmIChieUV4Y2x1c2lvbikge1xuICAgICAgICAgIHJldCA9IHRydWU7XG4gICAgICAgICAgaWYgKGZvdW5kID4gLTEpIHtcbiAgICAgICAgICAgIHJldCA9IGZhbHNlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXQgPSBmYWxzZTtcbiAgICAgICAgICBpZiAoZm91bmQgPiAtMSkge1xuICAgICAgICAgICAgcmV0ID0gdHJ1ZTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFyb2xlcyB8fCByb2xlcy5sZW5ndGggPT09IDAgfHwgdGhpcy5nZXRSb2xlKCkgPT09ICdQUk9HUkFNX0FETUlOJykge1xuICAgICAgICAgIHJldCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHJldDtcbiAgICAgIH1cblxuICAgICAgYXN5bmMgY2FuQWN0aXZhdGUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgICAgIGNvbnNvbGUubG9nKCdyb2xlcycpO1xuICAgICAgICBjb25zb2xlLmxvZyhyb2xlcyk7XG4gICAgICAgIGlmICghdGhpcy50b2tlbkNyZWRlbnRpYWxzKSB7XG4gICAgICAgICAgdGhpcy50b2tlbkNyZWRlbnRpYWxzID0gYXdhaXQgdGhpcy5tb25rZXllY3hBdXRoZW50aWNhdGlvblNlcnZpY2UuZ2V0VG9rZW4oKTtcbiAgICAgICAgfVxuICAgICAgICBjb25zb2xlLmxvZygndGhpcy50b2tlbkNyZWRlbnRpYWxzJyk7XG4gICAgICAgIGNvbnNvbGUubG9nKHRoaXMudG9rZW5DcmVkZW50aWFscyk7XG4gICAgICAgIGNvbnNvbGUubG9nKCdjaGVjYW5kbycpO1xuICAgICAgICBpZiAoIXRoaXMuYWxsb3dlZFNlY3VyaXR5QWNjZXNzKHJvbGVzKSkge1xuICAgICAgICAgIGNvbnNvbGUubG9nKCdjaGVjb3UgZXJybycpO1xuICAgICAgICAgIHRoaXMubmF2aWdhdGVUb0Vycm9yUGFnZSgpO1xuICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgICAgICBjb25zb2xlLmxvZygnY2hlY291IG9rJyk7XG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIFJvbGVDaGVjaztcbiAgfVxufSAqL1xuIl19
85
+ }], ctorParameters: function () { return [{ type: i1.MonkeyEcxAuthenticationService }, { type: i2.Router }]; } });
86
+ //# 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 { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot } from '@angular/router';\nimport { MonkeyEcxAuthenticationService } from './monkeyecx-authentication.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class MonkeyEcxAuthGuardByRole implements CanActivate {\n  private securityCredentials: {\n    roles: string[],\n    byExclusion: boolean\n  } | null = null;\n\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    const { tokenCredentials } = this;\n    const companyType = tokenCredentials?.companyType;\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[], byExclusion: boolean): 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(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Promise<boolean> {\n    this.securityCredentials = route.data?.securityCredentials;\n    console.log('this.securityCredentials');\n    console.log(this.securityCredentials);\n    if (this.securityCredentials) {\n      const { roles, byExclusion } = this.securityCredentials;\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, byExclusion)) {\n        console.log('checou erro');\n        this.navigateToErrorPage();\n        return false;\n      }\n      console.log('checou ok');\n    }\n\n    return true;\n  }\n}\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"]}
@@ -4117,31 +4117,90 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
4117
4117
  }], ctorParameters: function () { return [{ type: MonkeyEcxAuthenticationService }]; } });
4118
4118
 
4119
4119
  class MonkeyEcxAuthGuardByRole {
4120
- constructor() {
4120
+ constructor(monkeyecxAuthenticationService, router) {
4121
+ this.monkeyecxAuthenticationService = monkeyecxAuthenticationService;
4122
+ this.router = router;
4123
+ this.securityCredentials = null;
4124
+ this.tokenCredentials = null;
4121
4125
  // not to do
4122
4126
  }
4123
- static forRoles(roles, companyType, byExclusion) {
4124
- class RoleCheck {
4125
- constructor() {
4126
- // not to do
4127
+ navigateToErrorPage() {
4128
+ var _a;
4129
+ const { tokenCredentials } = this;
4130
+ const companyType = tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.companyType;
4131
+ let path = '/app/pages/forbidden';
4132
+ if (companyType) {
4133
+ path = `/app/${companyType}/pages/forbidden`;
4134
+ }
4135
+ (_a = this.router) === null || _a === void 0 ? void 0 : _a.navigate([path.toLowerCase()]);
4136
+ }
4137
+ getRole() {
4138
+ const { tokenCredentials } = this;
4139
+ if (!tokenCredentials)
4140
+ return '';
4141
+ if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === 'true') {
4142
+ return 'PROGRAM_ADMIN';
4143
+ }
4144
+ if ((tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.programAdmin) === true) {
4145
+ return 'PROGRAM_ADMIN';
4146
+ }
4147
+ return (tokenCredentials === null || tokenCredentials === void 0 ? void 0 : tokenCredentials.role) || '';
4148
+ }
4149
+ allowedSecurityAccess(roles, byExclusion) {
4150
+ if (!(roles === null || roles === void 0 ? void 0 : roles.length))
4151
+ return true;
4152
+ const found = roles === null || roles === void 0 ? void 0 : roles.indexOf(this.getRole());
4153
+ let ret = false;
4154
+ if (byExclusion) {
4155
+ ret = true;
4156
+ if (found > -1) {
4157
+ ret = false;
4127
4158
  }
4128
- canActivate() {
4129
- return __awaiter(this, void 0, void 0, function* () {
4130
- return true;
4131
- });
4159
+ }
4160
+ else {
4161
+ ret = false;
4162
+ if (found > -1) {
4163
+ ret = true;
4132
4164
  }
4133
4165
  }
4134
- return RoleCheck;
4166
+ if (!roles || roles.length === 0 || this.getRole() === 'PROGRAM_ADMIN') {
4167
+ ret = true;
4168
+ }
4169
+ return ret;
4170
+ }
4171
+ canActivate(route, state) {
4172
+ var _a;
4173
+ return __awaiter(this, void 0, void 0, function* () {
4174
+ this.securityCredentials = (_a = route.data) === null || _a === void 0 ? void 0 : _a.securityCredentials;
4175
+ console.log('this.securityCredentials');
4176
+ console.log(this.securityCredentials);
4177
+ if (this.securityCredentials) {
4178
+ const { roles, byExclusion } = this.securityCredentials;
4179
+ if (!this.tokenCredentials) {
4180
+ this.tokenCredentials = yield this.monkeyecxAuthenticationService.getToken();
4181
+ }
4182
+ console.log('this.tokenCredentials');
4183
+ console.log(this.tokenCredentials);
4184
+ console.log('checando');
4185
+ if (!this.allowedSecurityAccess(roles, byExclusion)) {
4186
+ console.log('checou erro');
4187
+ this.navigateToErrorPage();
4188
+ return false;
4189
+ }
4190
+ console.log('checou ok');
4191
+ }
4192
+ return true;
4193
+ });
4135
4194
  }
4136
4195
  }
4137
- MonkeyEcxAuthGuardByRole.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
4196
+ MonkeyEcxAuthGuardByRole.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, deps: [{ token: MonkeyEcxAuthenticationService }, { token: i2$2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
4138
4197
  MonkeyEcxAuthGuardByRole.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, providedIn: 'root' });
4139
4198
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MonkeyEcxAuthGuardByRole, decorators: [{
4140
4199
  type: Injectable,
4141
4200
  args: [{
4142
4201
  providedIn: 'root'
4143
4202
  }]
4144
- }], ctorParameters: function () { return []; } });
4203
+ }], ctorParameters: function () { return [{ type: MonkeyEcxAuthenticationService }, { type: i2$2.Router }]; } });
4145
4204
 
4146
4205
  class MonkeyEcxAuthGuard {
4147
4206
  constructor(monkeyecxAuthenticationService) {