@gipisistemas/ng-core 1.1.7 → 1.1.8
Sign up to get free protection for your applications and to get access to all the features.
- package/bundles/gipisistemas-ng-core.umd.js +2261 -2168
- package/bundles/gipisistemas-ng-core.umd.js.map +1 -1
- package/bundles/gipisistemas-ng-core.umd.min.js +8 -8
- package/bundles/gipisistemas-ng-core.umd.min.js.map +1 -1
- package/core/guards/auth.guard.d.ts +3 -1
- package/core/guards/permission.guard.d.ts +5 -4
- package/core/interceptors/auth.interceptor.d.ts +2 -2
- package/core/services/authentication.service.d.ts +8 -9
- package/core.d.ts +0 -1
- package/esm2015/core/guards/auth.guard.js +16 -19
- package/esm2015/core/guards/permission.guard.js +31 -22
- package/esm2015/core/interceptors/auth.interceptor.js +7 -5
- package/esm2015/core/services/authentication.service.js +40 -34
- package/esm2015/core.js +1 -2
- package/esm2015/gipi-components.js +4 -1
- package/esm2015/shared/components/input/input.component.js +7 -2
- package/esm2015/shared/components/select-entity/select-entity.component.js +1 -1
- package/esm2015/shared/components/select-enum/select-enum.component.js +8 -3
- package/esm2015/shared/gipi-components/form-field/form-field.component.js +3 -3
- package/esm2015/shared/gipi-components/input-currency/input-currency.component.js +1 -1
- package/esm2015/shared/gipi-components/input-monthpicker/input-monthpicker.component.js +1 -1
- package/esm2015/shared/gipi-components/input-select/input-select.component.js +1 -1
- package/esm2015/shared/gipi-components/skeleton/skeleton.component.js +44 -0
- package/esm2015/shared/gipi-components/skeleton/skeleton.directive.js +79 -0
- package/esm2015/shared/shared.module.js +7 -3
- package/esm5/core/guards/auth.guard.js +16 -20
- package/esm5/core/guards/permission.guard.js +31 -23
- package/esm5/core/interceptors/auth.interceptor.js +7 -5
- package/esm5/core/services/authentication.service.js +41 -46
- package/esm5/core.js +1 -2
- package/esm5/gipi-components.js +4 -1
- package/esm5/shared/components/input/input.component.js +7 -2
- package/esm5/shared/components/select-entity/select-entity.component.js +1 -1
- package/esm5/shared/components/select-enum/select-enum.component.js +8 -3
- package/esm5/shared/gipi-components/form-field/form-field.component.js +3 -3
- package/esm5/shared/gipi-components/input-currency/input-currency.component.js +1 -1
- package/esm5/shared/gipi-components/input-monthpicker/input-monthpicker.component.js +1 -1
- package/esm5/shared/gipi-components/input-select/input-select.component.js +1 -1
- package/esm5/shared/gipi-components/skeleton/skeleton.component.js +46 -0
- package/esm5/shared/gipi-components/skeleton/skeleton.directive.js +81 -0
- package/esm5/shared/shared.module.js +7 -3
- package/fesm2015/gipisistemas-ng-core.js +4172 -4069
- package/fesm2015/gipisistemas-ng-core.js.map +1 -1
- package/fesm5/gipisistemas-ng-core.js +2260 -2168
- package/fesm5/gipisistemas-ng-core.js.map +1 -1
- package/gipi-components.d.ts +2 -0
- package/gipisistemas-ng-core.metadata.json +1 -1
- package/package.json +1 -1
- package/shared/components/input/input.component.d.ts +1 -0
- package/shared/components/select-enum/select-enum.component.d.ts +1 -0
- package/shared/gipi-components/skeleton/skeleton.component.d.ts +9 -0
- package/shared/gipi-components/skeleton/skeleton.directive.d.ts +15 -0
- package/core/guards/public.guard.d.ts +0 -11
- package/esm2015/core/guards/public.guard.js +0 -44
- package/esm5/core/guards/public.guard.js +0 -46
@@ -1,11 +1,13 @@
|
|
1
|
+
import { MatDialog } from '@angular/material/dialog';
|
1
2
|
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router, RouterStateSnapshot } from '@angular/router';
|
2
3
|
import { Observable } from 'rxjs';
|
3
4
|
import { BaseUser } from '../models/base-user.model';
|
4
5
|
import { AuthenticationService } from '../services/authentication.service';
|
5
6
|
export declare class AuthGuard implements CanActivate, CanActivateChild {
|
6
7
|
private _router;
|
8
|
+
private _matDialog;
|
7
9
|
private _authenticationService;
|
8
|
-
constructor(_router: Router, _authenticationService: AuthenticationService<BaseUser>);
|
10
|
+
constructor(_router: Router, _matDialog: MatDialog, _authenticationService: AuthenticationService<BaseUser>);
|
9
11
|
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean>;
|
10
12
|
canActivateChild(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean>;
|
11
13
|
}
|
@@ -1,14 +1,15 @@
|
|
1
|
+
import { MatDialog } from '@angular/material/dialog';
|
1
2
|
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router, RouterStateSnapshot } from '@angular/router';
|
2
3
|
import { Observable } from 'rxjs';
|
3
4
|
import { BaseUser } from '../models/base-user.model';
|
4
5
|
import { AuthenticationService } from '../services/authentication.service';
|
5
|
-
import { MenuDTO } from './../models/dto/menu.dto';
|
6
6
|
export declare class PermissionGuard implements CanActivate, CanActivateChild {
|
7
7
|
private _router;
|
8
|
+
private _matDialog;
|
8
9
|
private _authenticationService;
|
9
|
-
constructor(_router: Router, _authenticationService: AuthenticationService<BaseUser>);
|
10
|
+
constructor(_router: Router, _matDialog: MatDialog, _authenticationService: AuthenticationService<BaseUser>);
|
11
|
+
private _hasAuthority;
|
12
|
+
private _hasPermission;
|
10
13
|
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean>;
|
11
|
-
hasAuthority(user: any, permission: string): boolean;
|
12
|
-
hasPermission(menuList: MenuDTO[], url: string): boolean;
|
13
14
|
canActivateChild(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean>;
|
14
15
|
}
|
@@ -3,7 +3,7 @@ import { Observable } from 'rxjs';
|
|
3
3
|
import { BaseUser } from '../models/base-user.model';
|
4
4
|
import { AuthenticationService } from '../services/authentication.service';
|
5
5
|
export declare class AuthInterceptor implements HttpInterceptor {
|
6
|
-
private
|
7
|
-
constructor(
|
6
|
+
private _authenticationService;
|
7
|
+
constructor(_authenticationService: AuthenticationService<BaseUser>);
|
8
8
|
intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>>;
|
9
9
|
}
|
@@ -1,23 +1,22 @@
|
|
1
1
|
import { HttpClient, HttpHeaders } from '@angular/common/http';
|
2
2
|
import { Router } from '@angular/router';
|
3
|
-
import {
|
3
|
+
import { Observable } from 'rxjs';
|
4
4
|
import { BaseUser } from '../models/base-user.model';
|
5
5
|
import { TokenDTO } from '../models/dto/token.dto';
|
6
6
|
import { AbstractService } from './abstract.service';
|
7
7
|
export declare class AuthenticationService<U extends BaseUser> extends AbstractService {
|
8
8
|
protected router: Router;
|
9
9
|
protected http: HttpClient;
|
10
|
-
|
11
|
-
token
|
10
|
+
private _tokenSubject$;
|
11
|
+
token$: Observable<TokenDTO<U>>;
|
12
12
|
constructor(router: Router, http: HttpClient);
|
13
|
-
login(
|
14
|
-
logout():
|
15
|
-
removeToken(): void;
|
13
|
+
login(username: string, password: string): Observable<TokenDTO<U>>;
|
14
|
+
logout(): void;
|
16
15
|
refreshToken(additionalParams?: Map<any, any>): Observable<TokenDTO<U>>;
|
17
16
|
revokeToken(token?: TokenDTO<U>): Observable<any>;
|
17
|
+
protected setSession(token: TokenDTO<U>): TokenDTO<U>;
|
18
|
+
removeSession(): void;
|
18
19
|
isValidToken(token: TokenDTO<U>): boolean;
|
19
|
-
|
20
|
-
get tokenValue(): TokenDTO<U>;
|
21
|
-
get tokenValueLocalStorage(): TokenDTO<U>;
|
20
|
+
get token(): TokenDTO<U>;
|
22
21
|
protected buildHeaders(): HttpHeaders;
|
23
22
|
}
|
package/core.d.ts
CHANGED
@@ -8,7 +8,6 @@ export * from './core/core.module';
|
|
8
8
|
export * from './core/enums/local-time.enum';
|
9
9
|
export * from './core/guards/auth.guard';
|
10
10
|
export * from './core/guards/permission.guard';
|
11
|
-
export * from './core/guards/public.guard';
|
12
11
|
export * from './core/interceptors/auth.interceptor';
|
13
12
|
export * from './core/interceptors/error.interceptor';
|
14
13
|
export * from './core/models/abstract.model';
|
@@ -1,33 +1,28 @@
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
2
2
|
import { Injectable } from '@angular/core';
|
3
|
+
import { MatDialog } from '@angular/material/dialog';
|
3
4
|
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router, RouterStateSnapshot } from '@angular/router';
|
4
5
|
import { of } from 'rxjs';
|
5
|
-
import { map } from 'rxjs/operators';
|
6
6
|
import { AuthenticationService } from '../services/authentication.service';
|
7
|
-
import { ObjectUtil } from '../utils/object.util';
|
8
7
|
import * as i0 from "@angular/core";
|
9
8
|
import * as i1 from "@angular/router";
|
10
|
-
import * as i2 from "
|
9
|
+
import * as i2 from "@angular/material/dialog";
|
10
|
+
import * as i3 from "../services/authentication.service";
|
11
11
|
let AuthGuard = class AuthGuard {
|
12
|
-
constructor(_router, _authenticationService) {
|
12
|
+
constructor(_router, _matDialog, _authenticationService) {
|
13
13
|
this._router = _router;
|
14
|
+
this._matDialog = _matDialog;
|
14
15
|
this._authenticationService = _authenticationService;
|
15
16
|
}
|
16
17
|
canActivate(route, state) {
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
this._authenticationService.removeToken();
|
24
|
-
}
|
25
|
-
this._router.navigate(['oauth/login'], { queryParams: { returnUrl: state.url } });
|
26
|
-
return false;
|
27
|
-
}));
|
18
|
+
const token = this._authenticationService.token;
|
19
|
+
if (!this._authenticationService.isValidToken(token)) {
|
20
|
+
this._authenticationService.removeSession();
|
21
|
+
this._matDialog.closeAll();
|
22
|
+
this._router.navigate(['oauth/login']);
|
23
|
+
return of(false);
|
28
24
|
}
|
29
|
-
|
30
|
-
return of(false);
|
25
|
+
return of(true);
|
31
26
|
}
|
32
27
|
canActivateChild(route, state) {
|
33
28
|
return this.canActivate(route, state);
|
@@ -35,13 +30,15 @@ let AuthGuard = class AuthGuard {
|
|
35
30
|
};
|
36
31
|
AuthGuard.ctorParameters = () => [
|
37
32
|
{ type: Router },
|
33
|
+
{ type: MatDialog },
|
38
34
|
{ type: AuthenticationService }
|
39
35
|
];
|
40
|
-
AuthGuard.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function AuthGuard_Factory() { return new AuthGuard(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i2.AuthenticationService)); }, token: AuthGuard, providedIn: "root" });
|
36
|
+
AuthGuard.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function AuthGuard_Factory() { return new AuthGuard(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i2.MatDialog), i0.ɵɵinject(i3.AuthenticationService)); }, token: AuthGuard, providedIn: "root" });
|
41
37
|
AuthGuard = __decorate([
|
42
38
|
Injectable({ providedIn: 'root' }),
|
43
39
|
__metadata("design:paramtypes", [Router,
|
40
|
+
MatDialog,
|
44
41
|
AuthenticationService])
|
45
42
|
], AuthGuard);
|
46
43
|
export { AuthGuard };
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BnaXBpc2lzdGVtYXMvbmctY29yZS8iLCJzb3VyY2VzIjpbImNvcmUvZ3VhcmRzL2F1dGguZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDckgsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUl0QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7Ozs7QUFFM0UsSUFBYSxTQUFTLEdBQXRCLE1BQWEsU0FBUztJQUVsQixZQUNZLE9BQWUsRUFDZixVQUFxQixFQUNyQixzQkFBdUQ7UUFGdkQsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUNmLGVBQVUsR0FBVixVQUFVLENBQVc7UUFDckIsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUFpQztJQUMvRCxDQUFDO0lBRUwsV0FBVyxDQUFDLEtBQTZCLEVBQUUsS0FBMEI7UUFDakUsTUFBTSxLQUFLLEdBQXVCLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUM7UUFDcEUsSUFBSSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDbEQsSUFBSSxDQUFDLHNCQUFzQixDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzVDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1lBQ3ZDLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BCO1FBRUQsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEtBQTZCLEVBQUUsS0FBMEI7UUFDdEUsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMxQyxDQUFDO0NBRUosQ0FBQTs7WUFyQndCLE1BQU07WUFDSCxTQUFTO1lBQ0cscUJBQXFCOzs7QUFMaEQsU0FBUztJQURyQixVQUFVLENBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLENBQUM7cUNBSVYsTUFBTTtRQUNILFNBQVM7UUFDRyxxQkFBcUI7R0FMaEQsU0FBUyxDQXdCckI7U0F4QlksU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBDYW5BY3RpdmF0ZSwgQ2FuQWN0aXZhdGVDaGlsZCwgUm91dGVyLCBSb3V0ZXJTdGF0ZVNuYXBzaG90IH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IEJhc2VVc2VyIH0gZnJvbSAnLi4vbW9kZWxzL2Jhc2UtdXNlci5tb2RlbCc7XG5pbXBvcnQgeyBUb2tlbkRUTyB9IGZyb20gJy4uL21vZGVscy9kdG8vdG9rZW4uZHRvJztcbmltcG9ydCB7IEF1dGhlbnRpY2F0aW9uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2F1dGhlbnRpY2F0aW9uLnNlcnZpY2UnO1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBBdXRoR3VhcmQgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSwgQ2FuQWN0aXZhdGVDaGlsZCB7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBfcm91dGVyOiBSb3V0ZXIsXG4gICAgICAgIHByaXZhdGUgX21hdERpYWxvZzogTWF0RGlhbG9nLFxuICAgICAgICBwcml2YXRlIF9hdXRoZW50aWNhdGlvblNlcnZpY2U6IEF1dGhlbnRpY2F0aW9uU2VydmljZTxCYXNlVXNlcj4sXG4gICAgKSB7IH1cblxuICAgIGNhbkFjdGl2YXRlKHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBzdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgICAgICBjb25zdCB0b2tlbjogVG9rZW5EVE88QmFzZVVzZXI+ID0gdGhpcy5fYXV0aGVudGljYXRpb25TZXJ2aWNlLnRva2VuO1xuICAgICAgICBpZiAoIXRoaXMuX2F1dGhlbnRpY2F0aW9uU2VydmljZS5pc1ZhbGlkVG9rZW4odG9rZW4pKSB7XG4gICAgICAgICAgICB0aGlzLl9hdXRoZW50aWNhdGlvblNlcnZpY2UucmVtb3ZlU2Vzc2lvbigpO1xuICAgICAgICAgICAgdGhpcy5fbWF0RGlhbG9nLmNsb3NlQWxsKCk7XG4gICAgICAgICAgICB0aGlzLl9yb3V0ZXIubmF2aWdhdGUoWydvYXV0aC9sb2dpbiddKTtcbiAgICAgICAgICAgIHJldHVybiBvZihmYWxzZSk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gb2YodHJ1ZSk7XG4gICAgfVxuXG4gICAgY2FuQWN0aXZhdGVDaGlsZChyb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3QpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FuQWN0aXZhdGUocm91dGUsIHN0YXRlKTtcbiAgICB9XG5cbn1cbiJdfQ==
|
@@ -1,60 +1,69 @@
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
2
2
|
import { Injectable } from '@angular/core';
|
3
|
+
import { MatDialog } from '@angular/material/dialog';
|
3
4
|
import { ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router, RouterStateSnapshot } from '@angular/router';
|
4
5
|
import { of } from 'rxjs';
|
5
|
-
import { map } from 'rxjs/operators';
|
6
6
|
import { AuthenticationService } from '../services/authentication.service';
|
7
|
+
import { ArrayUtil } from '../utils/array.util';
|
7
8
|
import { ObjectUtil } from '../utils/object.util';
|
8
|
-
import {
|
9
|
+
import { StringUtil } from '../utils/string.util';
|
9
10
|
import * as i0 from "@angular/core";
|
10
11
|
import * as i1 from "@angular/router";
|
11
|
-
import * as i2 from "
|
12
|
+
import * as i2 from "@angular/material/dialog";
|
13
|
+
import * as i3 from "../services/authentication.service";
|
12
14
|
let PermissionGuard = class PermissionGuard {
|
13
|
-
constructor(_router, _authenticationService) {
|
15
|
+
constructor(_router, _matDialog, _authenticationService) {
|
14
16
|
this._router = _router;
|
17
|
+
this._matDialog = _matDialog;
|
15
18
|
this._authenticationService = _authenticationService;
|
16
19
|
}
|
17
|
-
|
18
|
-
if (
|
19
|
-
return
|
20
|
-
if (this._authenticationService.isValidToken(token)
|
21
|
-
&& (!this.hasPermission(token.user.menuList, state.url) && !this.hasAuthority(token.user, route.data.authority))) {
|
22
|
-
this._router.navigate(['errors/403']);
|
23
|
-
return false;
|
24
|
-
}
|
25
|
-
return true;
|
26
|
-
}));
|
20
|
+
_hasAuthority(user, permission) {
|
21
|
+
if (ObjectUtil.isNull(user) || StringUtil.isEmpty(permission)) {
|
22
|
+
return false;
|
27
23
|
}
|
28
|
-
this._router.navigate(['errors/403']);
|
29
|
-
return of(false);
|
30
|
-
}
|
31
|
-
hasAuthority(user, permission) {
|
32
24
|
return !!user.authorities.find(authority => authority.authority.match(permission));
|
33
25
|
}
|
34
|
-
|
26
|
+
_hasPermission(menuList, url) {
|
35
27
|
for (const menu of menuList) {
|
36
28
|
if (url.split('/').pop() === menu.route) {
|
37
29
|
return true;
|
38
30
|
}
|
39
31
|
else if (!ArrayUtil.isEmpty(menu.menuList)) {
|
40
|
-
return this.
|
32
|
+
return this._hasPermission(menu.menuList, url);
|
41
33
|
}
|
42
34
|
}
|
43
35
|
return false;
|
44
36
|
}
|
37
|
+
canActivate(route, state) {
|
38
|
+
const token = this._authenticationService.token;
|
39
|
+
if (!this._authenticationService.isValidToken(token)) {
|
40
|
+
this._authenticationService.removeSession();
|
41
|
+
this._matDialog.closeAll();
|
42
|
+
this._router.navigate(['oauth/login']);
|
43
|
+
return of(false);
|
44
|
+
}
|
45
|
+
const hasPermission = this._hasPermission(token.user.menuList, state.url) && this._hasAuthority(token.user, route.data.authority);
|
46
|
+
if (!hasPermission) {
|
47
|
+
this._router.navigate(['errors/403']);
|
48
|
+
return of(false);
|
49
|
+
}
|
50
|
+
return of(true);
|
51
|
+
}
|
45
52
|
canActivateChild(route, state) {
|
46
53
|
return this.canActivate(route, state);
|
47
54
|
}
|
48
55
|
};
|
49
56
|
PermissionGuard.ctorParameters = () => [
|
50
57
|
{ type: Router },
|
58
|
+
{ type: MatDialog },
|
51
59
|
{ type: AuthenticationService }
|
52
60
|
];
|
53
|
-
PermissionGuard.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function PermissionGuard_Factory() { return new PermissionGuard(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i2.AuthenticationService)); }, token: PermissionGuard, providedIn: "root" });
|
61
|
+
PermissionGuard.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function PermissionGuard_Factory() { return new PermissionGuard(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i2.MatDialog), i0.ɵɵinject(i3.AuthenticationService)); }, token: PermissionGuard, providedIn: "root" });
|
54
62
|
PermissionGuard = __decorate([
|
55
63
|
Injectable({ providedIn: 'root' }),
|
56
64
|
__metadata("design:paramtypes", [Router,
|
65
|
+
MatDialog,
|
57
66
|
AuthenticationService])
|
58
67
|
], PermissionGuard);
|
59
68
|
export { PermissionGuard };
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVybWlzc2lvbi5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BnaXBpc2lzdGVtYXMvbmctY29yZS8iLCJzb3VyY2VzIjpbImNvcmUvZ3VhcmRzL3Blcm1pc3Npb24uZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDckgsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUt0QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDaEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7QUFFbEQsSUFBYSxlQUFlLEdBQTVCLE1BQWEsZUFBZTtJQUV4QixZQUNZLE9BQWUsRUFDZixVQUFxQixFQUNyQixzQkFBdUQ7UUFGdkQsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUNmLGVBQVUsR0FBVixVQUFVLENBQVc7UUFDckIsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUFpQztJQUMvRCxDQUFDO0lBRUcsYUFBYSxDQUFDLElBQWMsRUFBRSxVQUFrQjtRQUNwRCxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUMzRCxPQUFPLEtBQUssQ0FBQztTQUNoQjtRQUNELE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRU8sY0FBYyxDQUFDLFFBQW1CLEVBQUUsR0FBVztRQUNuRCxLQUFLLE1BQU0sSUFBSSxJQUFJLFFBQVEsRUFBRTtZQUN6QixJQUFJLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssSUFBSSxDQUFDLEtBQUssRUFBRTtnQkFDckMsT0FBTyxJQUFJLENBQUM7YUFDZjtpQkFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUU7Z0JBQzFDLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO2FBQ2xEO1NBQ0o7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNqQixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQTZCLEVBQUUsS0FBMEI7UUFDakUsTUFBTSxLQUFLLEdBQXVCLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUM7UUFDcEUsSUFBSSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDbEQsSUFBSSxDQUFDLHNCQUFzQixDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzVDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1lBQ3ZDLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BCO1FBRUQsTUFBTSxhQUFhLEdBQVksSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDM0ksSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUNoQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7WUFDdEMsT0FBTyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDcEI7UUFFRCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBNkIsRUFBRSxLQUEwQjtRQUN0RSxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzFDLENBQUM7Q0FFSixDQUFBOztZQTdDd0IsTUFBTTtZQUNILFNBQVM7WUFDRyxxQkFBcUI7OztBQUxoRCxlQUFlO0lBRDNCLFVBQVUsQ0FBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsQ0FBQztxQ0FJVixNQUFNO1FBQ0gsU0FBUztRQUNHLHFCQUFxQjtHQUxoRCxlQUFlLENBZ0QzQjtTQWhEWSxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIENhbkFjdGl2YXRlLCBDYW5BY3RpdmF0ZUNoaWxkLCBSb3V0ZXIsIFJvdXRlclN0YXRlU25hcHNob3QgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgQmFzZVVzZXIgfSBmcm9tICcuLi9tb2RlbHMvYmFzZS11c2VyLm1vZGVsJztcbmltcG9ydCB7IE1lbnVEVE8gfSBmcm9tICcuLi9tb2RlbHMvZHRvL21lbnUuZHRvJztcbmltcG9ydCB7IFRva2VuRFRPIH0gZnJvbSAnLi4vbW9kZWxzL2R0by90b2tlbi5kdG8nO1xuaW1wb3J0IHsgQXV0aGVudGljYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvYXV0aGVudGljYXRpb24uc2VydmljZSc7XG5pbXBvcnQgeyBBcnJheVV0aWwgfSBmcm9tICcuLi91dGlscy9hcnJheS51dGlsJztcbmltcG9ydCB7IE9iamVjdFV0aWwgfSBmcm9tICcuLi91dGlscy9vYmplY3QudXRpbCc7XG5pbXBvcnQgeyBTdHJpbmdVdGlsIH0gZnJvbSAnLi4vdXRpbHMvc3RyaW5nLnV0aWwnO1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBQZXJtaXNzaW9uR3VhcmQgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSwgQ2FuQWN0aXZhdGVDaGlsZCB7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBfcm91dGVyOiBSb3V0ZXIsXG4gICAgICAgIHByaXZhdGUgX21hdERpYWxvZzogTWF0RGlhbG9nLFxuICAgICAgICBwcml2YXRlIF9hdXRoZW50aWNhdGlvblNlcnZpY2U6IEF1dGhlbnRpY2F0aW9uU2VydmljZTxCYXNlVXNlcj5cbiAgICApIHsgfVxuXG4gICAgcHJpdmF0ZSBfaGFzQXV0aG9yaXR5KHVzZXI6IEJhc2VVc2VyLCBwZXJtaXNzaW9uOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICAgICAgaWYgKE9iamVjdFV0aWwuaXNOdWxsKHVzZXIpIHx8IFN0cmluZ1V0aWwuaXNFbXB0eShwZXJtaXNzaW9uKSkge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiAhIXVzZXIuYXV0aG9yaXRpZXMuZmluZChhdXRob3JpdHkgPT4gYXV0aG9yaXR5LmF1dGhvcml0eS5tYXRjaChwZXJtaXNzaW9uKSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfaGFzUGVybWlzc2lvbihtZW51TGlzdDogTWVudURUT1tdLCB1cmw6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgICAgICBmb3IgKGNvbnN0IG1lbnUgb2YgbWVudUxpc3QpIHtcbiAgICAgICAgICAgIGlmICh1cmwuc3BsaXQoJy8nKS5wb3AoKSA9PT0gbWVudS5yb3V0ZSkge1xuICAgICAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIGlmICghQXJyYXlVdGlsLmlzRW1wdHkobWVudS5tZW51TGlzdCkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5faGFzUGVybWlzc2lvbihtZW51Lm1lbnVMaXN0LCB1cmwpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBjYW5BY3RpdmF0ZShyb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgc3RhdGU6IFJvdXRlclN0YXRlU25hcHNob3QpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgY29uc3QgdG9rZW46IFRva2VuRFRPPEJhc2VVc2VyPiA9IHRoaXMuX2F1dGhlbnRpY2F0aW9uU2VydmljZS50b2tlbjtcbiAgICAgICAgaWYgKCF0aGlzLl9hdXRoZW50aWNhdGlvblNlcnZpY2UuaXNWYWxpZFRva2VuKHRva2VuKSkge1xuICAgICAgICAgICAgdGhpcy5fYXV0aGVudGljYXRpb25TZXJ2aWNlLnJlbW92ZVNlc3Npb24oKTtcbiAgICAgICAgICAgIHRoaXMuX21hdERpYWxvZy5jbG9zZUFsbCgpO1xuICAgICAgICAgICAgdGhpcy5fcm91dGVyLm5hdmlnYXRlKFsnb2F1dGgvbG9naW4nXSk7XG4gICAgICAgICAgICByZXR1cm4gb2YoZmFsc2UpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaGFzUGVybWlzc2lvbjogYm9vbGVhbiA9IHRoaXMuX2hhc1Blcm1pc3Npb24odG9rZW4udXNlci5tZW51TGlzdCwgc3RhdGUudXJsKSAmJiB0aGlzLl9oYXNBdXRob3JpdHkodG9rZW4udXNlciwgcm91dGUuZGF0YS5hdXRob3JpdHkpO1xuICAgICAgICBpZiAoIWhhc1Blcm1pc3Npb24pIHtcbiAgICAgICAgICAgIHRoaXMuX3JvdXRlci5uYXZpZ2F0ZShbJ2Vycm9ycy80MDMnXSk7XG4gICAgICAgICAgICByZXR1cm4gb2YoZmFsc2UpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG9mKHRydWUpO1xuICAgIH1cblxuICAgIGNhbkFjdGl2YXRlQ2hpbGQocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgICAgIHJldHVybiB0aGlzLmNhbkFjdGl2YXRlKHJvdXRlLCBzdGF0ZSk7XG4gICAgfVxuXG59XG4iXX0=
|
@@ -1,13 +1,15 @@
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
2
2
|
import { Injectable } from '@angular/core';
|
3
3
|
import { AuthenticationService } from '../services/authentication.service';
|
4
|
+
import { ObjectUtil } from '../utils/object.util';
|
5
|
+
import { StringUtil } from '../utils/string.util';
|
4
6
|
let AuthInterceptor = class AuthInterceptor {
|
5
|
-
constructor(
|
6
|
-
this.
|
7
|
+
constructor(_authenticationService) {
|
8
|
+
this._authenticationService = _authenticationService;
|
7
9
|
}
|
8
10
|
intercept(request, next) {
|
9
|
-
const token = this.
|
10
|
-
if (token && token.accessToken && !request.headers.get('skip')) {
|
11
|
+
const token = this._authenticationService.token;
|
12
|
+
if (!ObjectUtil.isNull(token) && !StringUtil.isEmpty(token.accessToken) && !request.headers.get('skip')) {
|
11
13
|
request = request.clone({
|
12
14
|
setHeaders: {
|
13
15
|
Authorization: `Bearer ${token.accessToken}`
|
@@ -25,4 +27,4 @@ AuthInterceptor = __decorate([
|
|
25
27
|
__metadata("design:paramtypes", [AuthenticationService])
|
26
28
|
], AuthInterceptor);
|
27
29
|
export { AuthInterceptor };
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BnaXBpc2lzdGVtYXMvbmctY29yZS8iLCJzb3VyY2VzIjpbImNvcmUvaW50ZXJjZXB0b3JzL2F1dGguaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFLM0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDM0UsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUdsRCxJQUFhLGVBQWUsR0FBNUIsTUFBYSxlQUFlO0lBRXhCLFlBQW9CLHNCQUF1RDtRQUF2RCwyQkFBc0IsR0FBdEIsc0JBQXNCLENBQWlDO0lBQUksQ0FBQztJQUVoRixTQUFTLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNsRCxNQUFNLEtBQUssR0FBdUIsSUFBSSxDQUFDLHNCQUFzQixDQUFDLEtBQUssQ0FBQztRQUNwRSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDckcsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7Z0JBQ3BCLFVBQVUsRUFBRTtvQkFDUixhQUFhLEVBQUUsVUFBVSxLQUFLLENBQUMsV0FBVyxFQUFFO2lCQUMvQzthQUNKLENBQUMsQ0FBQztTQUNOO1FBRUQsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDSixDQUFBOztZQWQrQyxxQkFBcUI7O0FBRnhELGVBQWU7SUFEM0IsVUFBVSxFQUFFO3FDQUdtQyxxQkFBcUI7R0FGeEQsZUFBZSxDQWdCM0I7U0FoQlksZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBFdmVudCwgSHR0cEhhbmRsZXIsIEh0dHBJbnRlcmNlcHRvciwgSHR0cFJlcXVlc3QgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IEJhc2VVc2VyIH0gZnJvbSAnLi4vbW9kZWxzL2Jhc2UtdXNlci5tb2RlbCc7XG5pbXBvcnQgeyBUb2tlbkRUTyB9IGZyb20gJy4uL21vZGVscy9kdG8vdG9rZW4uZHRvJztcbmltcG9ydCB7IEF1dGhlbnRpY2F0aW9uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2F1dGhlbnRpY2F0aW9uLnNlcnZpY2UnO1xuaW1wb3J0IHsgT2JqZWN0VXRpbCB9IGZyb20gJy4uL3V0aWxzL29iamVjdC51dGlsJztcbmltcG9ydCB7IFN0cmluZ1V0aWwgfSBmcm9tICcuLi91dGlscy9zdHJpbmcudXRpbCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBBdXRoSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBfYXV0aGVudGljYXRpb25TZXJ2aWNlOiBBdXRoZW50aWNhdGlvblNlcnZpY2U8QmFzZVVzZXI+KSB7IH1cblxuICAgIGludGVyY2VwdChyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcbiAgICAgICAgY29uc3QgdG9rZW46IFRva2VuRFRPPEJhc2VVc2VyPiA9IHRoaXMuX2F1dGhlbnRpY2F0aW9uU2VydmljZS50b2tlbjtcbiAgICAgICAgaWYgKCFPYmplY3RVdGlsLmlzTnVsbCh0b2tlbikgJiYgIVN0cmluZ1V0aWwuaXNFbXB0eSh0b2tlbi5hY2Nlc3NUb2tlbikgJiYgIXJlcXVlc3QuaGVhZGVycy5nZXQoJ3NraXAnKSkge1xuICAgICAgICAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xuICAgICAgICAgICAgICAgIHNldEhlYWRlcnM6IHtcbiAgICAgICAgICAgICAgICAgICAgQXV0aG9yaXphdGlvbjogYEJlYXJlciAke3Rva2VuLmFjY2Vzc1Rva2VufWBcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXF1ZXN0KTtcbiAgICB9XG59XG4iXX0=
|
@@ -1,9 +1,9 @@
|
|
1
|
-
import {
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
2
|
import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';
|
3
3
|
import { Injectable } from '@angular/core';
|
4
4
|
import { Router } from '@angular/router';
|
5
5
|
import { BehaviorSubject } from 'rxjs';
|
6
|
-
import { map } from 'rxjs/operators';
|
6
|
+
import { catchError, map, takeUntil } from 'rxjs/operators';
|
7
7
|
import * as moment_ from 'moment';
|
8
8
|
import * as i0 from "@angular/core";
|
9
9
|
import * as i1 from "@angular/router";
|
@@ -17,36 +17,37 @@ let AuthenticationService = class AuthenticationService extends AbstractService
|
|
17
17
|
super();
|
18
18
|
this.router = router;
|
19
19
|
this.http = http;
|
20
|
-
this.
|
21
|
-
this.token = this.
|
20
|
+
this._tokenSubject$ = new BehaviorSubject(JSON.parse(localStorage.getItem('token')));
|
21
|
+
this.token$ = this._tokenSubject$.asObservable();
|
22
22
|
}
|
23
|
-
login(
|
23
|
+
login(username, password) {
|
24
24
|
const body = new HttpParams()
|
25
25
|
.set('grant_type', 'password')
|
26
|
-
.set('username',
|
27
|
-
.set('password',
|
28
|
-
return this.http.post('api/authenticator/oauth/token', body, this.options()).pipe(map(
|
26
|
+
.set('username', username)
|
27
|
+
.set('password', password);
|
28
|
+
return this.http.post('api/authenticator/oauth/token', body, this.options(this.buildParams(), this.buildHeaders().append('skip', String(true)))).pipe(map((token) => {
|
29
|
+
if (this.isValidToken(token)) {
|
30
|
+
this.setSession(token);
|
31
|
+
}
|
32
|
+
return token;
|
33
|
+
}), takeUntil(this.onDestroy), catchError(this.handleError));
|
29
34
|
}
|
30
35
|
logout() {
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
+
this.revokeToken().subscribe(_ => {
|
37
|
+
this.removeSession();
|
38
|
+
this.router.navigate(['/oauth/login'], { queryParams: { returnUrl: this.router.routerState.snapshot.url } });
|
39
|
+
}, error => {
|
40
|
+
throw new Error(error);
|
36
41
|
});
|
37
42
|
}
|
38
|
-
removeToken() {
|
39
|
-
localStorage.removeItem('token');
|
40
|
-
this.tokenSubject.next(null);
|
41
|
-
}
|
42
43
|
refreshToken(additionalParams) {
|
43
44
|
let body = new HttpParams()
|
44
45
|
.set('grant_type', 'refresh_token')
|
45
|
-
.set('refresh_token', this.
|
46
|
+
.set('refresh_token', this.token.refreshToken);
|
46
47
|
if (!ObjectUtil.isNull(additionalParams)) {
|
47
48
|
additionalParams.forEach((value, key) => body = body.append(key, value));
|
48
49
|
}
|
49
|
-
return this.http.post('api/authenticator/oauth/token', body, this.options(this.buildParams(), this.buildHeaders().append('skip', 'true'))).pipe(map(accessToken => this.
|
50
|
+
return this.http.post('api/authenticator/oauth/token', body, this.options(this.buildParams(), this.buildHeaders().append('skip', 'true'))).pipe(map(accessToken => this.setSession(accessToken)), takeUntil(this.onDestroy), catchError(this.handleError));
|
50
51
|
}
|
51
52
|
revokeToken(token) {
|
52
53
|
let lHttpHeaders = null;
|
@@ -55,27 +56,32 @@ let AuthenticationService = class AuthenticationService extends AbstractService
|
|
55
56
|
.append('Authorization', token.accessToken)
|
56
57
|
.append('skip', 'true');
|
57
58
|
}
|
58
|
-
return this.http.post('api/authenticator/oauth/token/revoke', {}, this.options(null, lHttpHeaders));
|
59
|
-
}
|
60
|
-
isValidToken(token) {
|
61
|
-
if (!ObjectUtil.isNull(token) && !ObjectUtil.isNull(token.expiration)) {
|
62
|
-
return new Date(token.expiration).valueOf() > new Date().valueOf();
|
63
|
-
}
|
64
|
-
return false;
|
59
|
+
return this.http.post('api/authenticator/oauth/token/revoke', {}, this.options(null, lHttpHeaders)).pipe(takeUntil(this.onDestroy), catchError(this.handleError));
|
65
60
|
}
|
66
|
-
|
67
|
-
if (token
|
61
|
+
setSession(token) {
|
62
|
+
if (this.isValidToken(token)) {
|
68
63
|
localStorage.setItem('token', JSON.stringify(token));
|
69
|
-
this.
|
64
|
+
this._tokenSubject$.next(token);
|
70
65
|
}
|
71
66
|
return token;
|
72
67
|
}
|
73
|
-
|
74
|
-
|
68
|
+
removeSession() {
|
69
|
+
localStorage.removeItem('token');
|
70
|
+
sessionStorage.clear();
|
75
71
|
}
|
76
|
-
|
72
|
+
isValidToken(token) {
|
73
|
+
if (!ObjectUtil.isNull(token) && !ObjectUtil.isNull(token.expiration)) {
|
74
|
+
const tokenExpiration = moment(token.expiration);
|
75
|
+
return moment().isBefore(tokenExpiration);
|
76
|
+
}
|
77
|
+
return false;
|
78
|
+
}
|
79
|
+
get token() {
|
77
80
|
const token = localStorage.getItem('token');
|
78
|
-
|
81
|
+
if (StringUtil.isEmpty(token)) {
|
82
|
+
return null;
|
83
|
+
}
|
84
|
+
return JSON.parse(token);
|
79
85
|
}
|
80
86
|
buildHeaders() {
|
81
87
|
return new HttpHeaders()
|
@@ -96,4 +102,4 @@ AuthenticationService = __decorate([
|
|
96
102
|
HttpClient])
|
97
103
|
], AuthenticationService);
|
98
104
|
export { AuthenticationService };
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication.service.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["core/services/authentication.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport * as moment_ from 'moment';\nconst moment = moment_;\n\nimport { BaseUser } from '../models/base-user.model';\nimport { TokenDTO } from '../models/dto/token.dto';\nimport { ObjectUtil } from '../utils/object.util';\nimport { StringUtil } from '../utils/string.util';\nimport { AbstractService } from './abstract.service';\n\n@Injectable({ providedIn: 'root' })\nexport class AuthenticationService<U extends BaseUser> extends AbstractService {\n\n    protected tokenSubject: BehaviorSubject<TokenDTO<U>>;\n\n    token: Observable<TokenDTO<U>>;\n\n    constructor(\n        protected router: Router,\n        protected http: HttpClient,\n    ) {\n        super();\n        this.tokenSubject = new BehaviorSubject<TokenDTO<U>>(JSON.parse(localStorage.getItem('token')));\n        this.token = this.tokenSubject.asObservable();\n    }\n\n    login(user: U): Observable<TokenDTO<U>> {\n        const body: HttpParams = new HttpParams()\n            .set('grant_type', 'password')\n            .set('username', user.username)\n            .set('password', user.password);\n\n        return this.http.post<TokenDTO<U>>('api/authenticator/oauth/token', body, this.options()).pipe(\n            map(accessToken => this.setCurrentUser(accessToken))\n        );\n    }\n\n    async logout(): Promise<void> {\n        await this.revokeToken().toPromise().then(() => {\n            this.removeToken();\n            this.router.navigate(['/oauth/login'], { queryParams: { returnUrl: this.router.routerState.snapshot.url } });\n        });\n    }\n\n    removeToken(): void {\n        localStorage.removeItem('token');\n        this.tokenSubject.next(null);\n    }\n\n    refreshToken(additionalParams?: Map<any, any>): Observable<TokenDTO<U>> {\n        let body: HttpParams = new HttpParams()\n            .set('grant_type', 'refresh_token')\n            .set('refresh_token', this.tokenValue.refreshToken);\n\n        if (!ObjectUtil.isNull(additionalParams)) {\n            additionalParams.forEach((value, key) => body = body.append(key, value));\n        }\n\n        return this.http.post<TokenDTO<U>>('api/authenticator/oauth/token', body, this.options(this.buildParams(), this.buildHeaders().append('skip', 'true'))).pipe(\n            map(accessToken => this.setCurrentUser(accessToken))\n        );\n    }\n\n    revokeToken(token?: TokenDTO<U>): Observable<any> {\n        let lHttpHeaders: HttpHeaders = null;\n        if (!ObjectUtil.isNull(token)) {\n            lHttpHeaders = new HttpHeaders()\n                .append('Authorization', token.accessToken)\n                .append('skip', 'true');\n        }\n        return this.http.post('api/authenticator/oauth/token/revoke', {}, this.options(null, lHttpHeaders));\n    }\n\n    isValidToken(token: TokenDTO<U>): boolean {\n        if (!ObjectUtil.isNull(token) && !ObjectUtil.isNull(token.expiration)) {\n            return new Date(token.expiration).valueOf() > new Date().valueOf();\n        }\n        return false;\n    }\n\n    protected setCurrentUser(token: TokenDTO<U>): TokenDTO<U> {\n        if (token && token.accessToken) {\n            localStorage.setItem('token', JSON.stringify(token));\n            this.tokenSubject.next(token);\n        }\n        return token;\n    }\n\n    get tokenValue(): TokenDTO<U> {\n        return this.tokenSubject.value;\n    }\n\n    get tokenValueLocalStorage(): TokenDTO<U> {\n        const token: string = localStorage.getItem('token');\n        return !StringUtil.isEmpty(token) ? JSON.parse(token) : null;\n    }\n\n    protected buildHeaders(): HttpHeaders {\n        return new HttpHeaders()\n            .append('Authorization', 'Basic ' + btoa('CONVENANT_MANAGEMENT:123'))\n            .append('Content-Type', 'application/x-www-form-urlencoded')\n            .append('accessType', 'WEB')\n            .append('timeZone', moment(new Date()).format('ZZ'));\n    }\n\n}\n"]}
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication.service.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["core/services/authentication.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { catchError, map, takeUntil } from 'rxjs/operators';\n\nimport * as moment_ from 'moment';\nconst moment = moment_;\n\nimport { BaseUser } from '../models/base-user.model';\nimport { TokenDTO } from '../models/dto/token.dto';\nimport { ObjectUtil } from '../utils/object.util';\nimport { StringUtil } from '../utils/string.util';\nimport { AbstractService } from './abstract.service';\n\n@Injectable({ providedIn: 'root' })\nexport class AuthenticationService<U extends BaseUser> extends AbstractService {\n\n    private _tokenSubject$: BehaviorSubject<TokenDTO<U>>;\n    public token$: Observable<TokenDTO<U>>;\n\n    constructor(\n        protected router: Router,\n        protected http: HttpClient,\n    ) {\n        super();\n        this._tokenSubject$ = new BehaviorSubject(JSON.parse(localStorage.getItem('token')));\n        this.token$ = this._tokenSubject$.asObservable();\n    }\n\n    public login(username: string, password: string): Observable<TokenDTO<U>> {\n        const body: HttpParams = new HttpParams()\n            .set('grant_type', 'password')\n            .set('username', username)\n            .set('password', password);\n\n        return this.http.post<TokenDTO<U>>(\n            'api/authenticator/oauth/token',\n            body,\n            this.options(this.buildParams(), this.buildHeaders().append('skip', String(true)))\n        ).pipe(\n            map((token: TokenDTO<U>) => {\n                if (this.isValidToken(token)) {\n                    this.setSession(token);\n                }\n                return token;\n            }),\n            takeUntil(this.onDestroy),\n            catchError(this.handleError),\n        );\n    }\n\n    public logout(): void {\n        this.revokeToken().subscribe(_ => {\n            this.removeSession();\n            this.router.navigate(['/oauth/login'], { queryParams: { returnUrl: this.router.routerState.snapshot.url } });\n        }, error => {\n            throw new Error(error);\n        });\n    }\n\n    public refreshToken(additionalParams?: Map<any, any>): Observable<TokenDTO<U>> {\n        let body: HttpParams = new HttpParams()\n            .set('grant_type', 'refresh_token')\n            .set('refresh_token', this.token.refreshToken);\n\n        if (!ObjectUtil.isNull(additionalParams)) {\n            additionalParams.forEach((value, key) => body = body.append(key, value));\n        }\n\n        return this.http.post<TokenDTO<U>>('api/authenticator/oauth/token', body, this.options(this.buildParams(), this.buildHeaders().append('skip', 'true'))).pipe(\n            map(accessToken => this.setSession(accessToken)),\n            takeUntil(this.onDestroy),\n            catchError(this.handleError),\n        );\n    }\n\n    public revokeToken(token?: TokenDTO<U>): Observable<any> {\n        let lHttpHeaders: HttpHeaders = null;\n        if (!ObjectUtil.isNull(token)) {\n            lHttpHeaders = new HttpHeaders()\n                .append('Authorization', token.accessToken)\n                .append('skip', 'true');\n        }\n        return this.http.post('api/authenticator/oauth/token/revoke', {}, this.options(null, lHttpHeaders)).pipe(\n            takeUntil(this.onDestroy),\n            catchError(this.handleError),\n        );\n    }\n\n    protected setSession(token: TokenDTO<U>): TokenDTO<U> {\n        if (this.isValidToken(token)) {\n            localStorage.setItem('token', JSON.stringify(token));\n            this._tokenSubject$.next(token);\n        }\n        return token;\n    }\n\n    public removeSession(): void {\n        localStorage.removeItem('token');\n        sessionStorage.clear();\n    }\n\n    public isValidToken(token: TokenDTO<U>): boolean {\n        if (!ObjectUtil.isNull(token) && !ObjectUtil.isNull(token.expiration)) {\n            const tokenExpiration: moment.Moment = moment(token.expiration);\n            return moment().isBefore(tokenExpiration);\n        }\n        return false;\n    }\n\n    public get token(): TokenDTO<U> {\n        const token: string = localStorage.getItem('token');\n        if (StringUtil.isEmpty(token)) {\n            return null;\n        }\n        return JSON.parse(token);\n    }\n\n    protected buildHeaders(): HttpHeaders {\n        return new HttpHeaders()\n            .append('Authorization', 'Basic ' + btoa('CONVENANT_MANAGEMENT:123'))\n            .append('Content-Type', 'application/x-www-form-urlencoded')\n            .append('accessType', 'WEB')\n            .append('timeZone', moment(new Date()).format('ZZ'));\n    }\n\n}\n"]}
|
package/esm2015/core.js
CHANGED
@@ -8,7 +8,6 @@ export * from './core/core.module';
|
|
8
8
|
export * from './core/enums/local-time.enum';
|
9
9
|
export * from './core/guards/auth.guard';
|
10
10
|
export * from './core/guards/permission.guard';
|
11
|
-
export * from './core/guards/public.guard';
|
12
11
|
export * from './core/interceptors/auth.interceptor';
|
13
12
|
export * from './core/interceptors/error.interceptor';
|
14
13
|
export * from './core/models/abstract.model';
|
@@ -86,4 +85,4 @@ export * from './core/gipi-components/services/file.service';
|
|
86
85
|
export * from './core/gipi-components/services/session-storage.service';
|
87
86
|
export * from './core/gipi-components/types/generic.type';
|
88
87
|
export * from './core/gipi-components/types/uuid.type';
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.js","sourceRoot":"ng://@gipisistemas/ng-core/","sources":["core.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,2CAA2C,CAAC;AAC1D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,oBAAoB,CAAC;AACnC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,0BAA0B,CAAC;AACzC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sCAAsC,CAAC;AACrD,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oCAAoC,CAAC;AACnD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qCAAqC,CAAC;AACpD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,oCAAoC,CAAC;AACnD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,6CAA6C,CAAC;AAC5D,cAAc,kDAAkD,CAAC;AACjE,cAAc,oCAAoC,CAAC;AACnD,cAAc,uCAAuC,CAAC;AACtD,cAAc,yCAAyC,CAAC;AACxD,cAAc,iCAAiC,CAAC;AAChD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,0BAA0B,CAAC;AACzC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uCAAuC,CAAC;AACtD,cAAc,uCAAuC,CAAC;AACtD,cAAc,kCAAkC,CAAC;AACjD,cAAc,wCAAwC,CAAC;AACvD,cAAc,6CAA6C,CAAC;AAC5D,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,sCAAsC,CAAC;AACrD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,mCAAmC,CAAC;AAClD,cAAc,wBAAwB,CAAC;AACvC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AAEzC,cAAc,2BAA2B,CAAC;AAE1C,cAAc,2DAA2D,CAAC;AAC1E,cAAc,2DAA2D,CAAC;AAC1E,cAAc,sDAAsD,CAAC;AACrE,cAAc,uDAAuD,CAAC;AACtE,cAAc,kDAAkD,CAAC;AACjE,cAAc,0DAA0D,CAAC;AACzE,cAAc,0DAA0D,CAAC;AACzE,cAAc,qDAAqD,CAAC;AACpE,cAAc,qDAAqD,CAAC;AACpE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,oDAAoD,CAAC;AACnE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,0CAA0C,CAAC;AACzD,cAAc,0CAA0C,CAAC;AACzD,cAAc,uDAAuD,CAAC;AACtE,cAAc,kDAAkD,CAAC;AACjE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,yDAAyD,CAAC;AACxE,cAAc,2CAA2C,CAAC;AAC1D,cAAc,wCAAwC,CAAC","sourcesContent":["export * from './core/app-messages';\nexport * from './core/app.messages';\nexport * from './core/components/abstract-crud.component';\nexport * from './core/components/abstract-find.component';\nexport * from './core/components/abstract.component';\nexport * from './core/components/alert/alert.component';\nexport * from './core/core.module';\nexport * from './core/enums/local-time.enum';\nexport * from './core/guards/auth.guard';\nexport * from './core/guards/permission.guard';\nexport * from './core/interceptors/auth.interceptor';\nexport * from './core/interceptors/error.interceptor';\nexport * from './core/models/abstract.model';\nexport * from './core/models/archive.model';\nexport * from './core/models/base-user.model';\nexport * from './core/models/dto/abstract.dto';\nexport * from './core/models/dto/chart.dto';\nexport * from './core/models/dto/confirmation.dto';\nexport * from './core/models/dto/dialog.dto';\nexport * from './core/models/dto/filter.dto';\nexport * from './core/models/dto/input-listbox.dto';\nexport * from './core/models/dto/menu.dto';\nexport * from './core/models/dto/message.dto';\nexport * from './core/models/dto/page.dto';\nexport * from './core/models/dto/sort.dto';\nexport * from './core/models/dto/tab.dto';\nexport * from './core/models/dto/table-column.dto';\nexport * from './core/models/dto/token.dto';\nexport * from './core/models/enums/criteria-operation.enum';\nexport * from './core/models/enums/criteria-sort-direction.enum';\nexport * from './core/models/enums/menu-type.enum';\nexport * from './core/models/enums/radio-button.enum';\nexport * from './core/models/enums/sort-direction.enum';\nexport * from './core/models/multitenant.model';\nexport * from './core/models/permission.model';\nexport * from './core/models/role.model';\nexport * from './core/pipes/local-time.pipe';\nexport * from './core/services/abstract-crud.service';\nexport * from './core/services/abstract-find.service';\nexport * from './core/services/abstract.service';\nexport * from './core/services/authentication.service';\nexport * from './core/services/breakpoint-observer.service';\nexport * from './core/services/confirmation.service';\nexport * from './core/services/dialog.service';\nexport * from './core/services/message.service';\nexport * from './core/services/nav.service';\nexport * from './core/services/svg-register.service';\nexport * from './core/types/local-time.type';\nexport * from './core/utils/array.util';\nexport * from './core/utils/browser.util';\nexport * from './core/utils/currency.util';\nexport * from './core/utils/date.util';\nexport * from './core/utils/document.util';\nexport * from './core/utils/email.util';\nexport * from './core/utils/number.util';\nexport * from './core/utils/object.util';\nexport * from './core/utils/password.util';\nexport * from './core/utils/phone.util';\nexport * from './core/utils/string.util';\nexport * from './core/utils/table-column-builder';\nexport * from './core/utils/time.util';\nexport * from './core/utils/url-params.util';\nexport * from './core/utils/uuid.util';\nexport * from './core/utils/zindex.util';\n\nexport * from './core/custom-breakpoints';\n\nexport * from './core/gipi-components/components/abstract-crud.component';\nexport * from './core/gipi-components/components/abstract-find.component';\nexport * from './core/gipi-components/components/abstract.component';\nexport * from './core/gipi-components/decorators/autowired.decorator';\nexport * from './core/gipi-components/enums/sort-direction.enum';\nexport * from './core/gipi-components/interface/abstract-crud.interface';\nexport * from './core/gipi-components/interface/abstract-find.interface';\nexport * from './core/gipi-components/interface/abstract.interface';\nexport * from './core/gipi-components/models/abstract-filter.model';\nexport * from './core/gipi-components/models/abstract.model';\nexport * from './core/gipi-components/models/applied-filter.model';\nexport * from './core/gipi-components/models/dto/abstract.dto';\nexport * from './core/gipi-components/models/page-event.model';\nexport * from './core/gipi-components/models/page.model';\nexport * from './core/gipi-components/models/sort.model';\nexport * from './core/gipi-components/services/abstract-crud.service';\nexport * from './core/gipi-components/services/abstract.service';\nexport * from './core/gipi-components/services/base.service';\nexport * from './core/gipi-components/services/file.service';\nexport * from './core/gipi-components/services/session-storage.service';\nexport * from './core/gipi-components/types/generic.type';\nexport * from './core/gipi-components/types/uuid.type';\n\n"]}
|