zek 14.2.59 → 14.2.60

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,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2RlbHMvbG9naW4ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhcHRjaGEgfSBmcm9tICcuL2NhcHRjaGEubW9kZWwnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBMb2dpblRva2VuIHtcclxuICAgIGlkPzogbnVtYmVyIHwgbnVsbDtcclxuICAgIHVzZXJOYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHJvbGVzPzogc3RyaW5nW10gfCBudWxsO1xyXG4gICAgcGVybWlzc2lvbnM/OiB7IFtpZDogbnVtYmVyXTogbnVtYmVyOyB9IHwgbnVsbDtcclxuICAgIHRva2VuPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGV4cGlyZWQ/OiBzdHJpbmcgfCBudWxsO1xyXG4gICAgZmlyc3ROYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGxhc3ROYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGZ1bGxOYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHBvc2l0aW9uPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGNvbXBhbnk/OiBzdHJpbmcgfCBudWxsO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIExvZ2luIGV4dGVuZHMgQ2FwdGNoYSB7XHJcbiAgICB1c2VyTmFtZT86IHN0cmluZztcclxuICAgIHJlbWVtYmVyTWU/OiBib29sZWFuO1xyXG4gICAgcGFzc3dvcmQ/OiBzdHJpbmc7XHJcbn0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2RlbHMvbG9naW4ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhcHRjaGEgfSBmcm9tICcuL2NhcHRjaGEubW9kZWwnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBMb2dpbkJhc2Uge1xyXG4gICAgaWQ/OiBudW1iZXIgfCBudWxsO1xyXG4gICAgdXNlck5hbWU/OiBzdHJpbmcgfCBudWxsO1xyXG4gICAgcm9sZXM/OiBzdHJpbmdbXSB8IG51bGw7XHJcbiAgICBwZXJtaXNzaW9ucz86IHsgW2lkOiBudW1iZXJdOiBudW1iZXI7IH0gfCBudWxsO1xyXG4gICAgdG9rZW4/OiBzdHJpbmcgfCBudWxsO1xyXG4gICAgZmlyc3ROYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGxhc3ROYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGZ1bGxOYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHBvc2l0aW9uPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGNvbXBhbnk/OiBzdHJpbmcgfCBudWxsO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgTG9naW5Ub2tlbiBleHRlbmRzIExvZ2luQmFzZSB7XHJcbiAgICBleHBpcmVkPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHJlZnJlc2hUb2tlblRpbWU/OiBzdHJpbmcgfCBudWxsO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgTG9naW5Vc2VyIGV4dGVuZHMgTG9naW5CYXNlIHtcclxuICAgIGV4cGlyZWQ6IERhdGUgfCBudWxsO1xyXG4gICAgcmVmcmVzaFRva2VuVGltZTogRGF0ZSB8IG51bGw7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTG9naW4gZXh0ZW5kcyBDYXB0Y2hhIHtcclxuICAgIHVzZXJOYW1lPzogc3RyaW5nO1xyXG4gICAgcmVtZW1iZXJNZT86IGJvb2xlYW47XHJcbiAgICBwYXNzd29yZD86IHN0cmluZztcclxufSJdfQ==
@@ -1,26 +1,38 @@
1
1
  import { Injectable, } from '@angular/core';
2
2
  import { BehaviorSubject } from 'rxjs';
3
- import { StorageHelper } from '../utils';
3
+ import { DateHelper, StorageHelper } from '../utils';
4
4
  import { BitwiseHelper } from '../utils/bitwise-helper';
5
5
  import * as i0 from "@angular/core";
6
6
  export class AuthService {
7
7
  constructor() {
8
- this.subject = new BehaviorSubject(false); //todo check if need BehaviorSubject
9
- this.model = null;
10
- this.expired = null;
11
- this.oldValueIsAuthenticated = false;
8
+ this._isInitialized = false;
9
+ this._subject = new BehaviorSubject(false); //todo check if need BehaviorSubject
10
+ this._oldValueIsAuthenticated = false;
11
+ this._user = null;
12
12
  }
13
+ get user() {
14
+ if (!this._isInitialized) {
15
+ let tmp = StorageHelper.get('login');
16
+ if (tmp) {
17
+ tmp.expired = DateHelper.parseDate(tmp.expired);
18
+ tmp.refreshTokenTime = DateHelper.parseDate(tmp.refreshTokenTime);
19
+ }
20
+ this._user = tmp;
21
+ this._isInitialized = true;
22
+ }
23
+ return this._user;
24
+ }
25
+ // private _expired: Date | null = null;
26
+ // private _refreshTokenExpired: Date | null = null;
13
27
  isAuthenticated() {
14
- let expired = this.getExpired();
15
- if (!expired)
16
- expired = new Date(0);
28
+ let expired = this.getExpired() || new Date(0);
17
29
  const newValue = new Date() < expired;
18
- if (this.oldValueIsAuthenticated != newValue) {
19
- this.oldValueIsAuthenticated = newValue;
30
+ if (this._oldValueIsAuthenticated != newValue) {
31
+ this._oldValueIsAuthenticated = newValue;
20
32
  if (this.onSignedInSubject) {
21
33
  this.onSignedInSubject.next(newValue);
22
34
  }
23
- this.subject.next(newValue);
35
+ this._subject.next(newValue);
24
36
  //if user is signed in and expired we need to logout (remove from localStorage)
25
37
  if (!newValue) {
26
38
  this.logout();
@@ -33,7 +45,7 @@ export class AuthService {
33
45
  * @deprecated The method should not be used. please use onSignedIn
34
46
  */
35
47
  isSignedIn() {
36
- return this.subject.asObservable();
48
+ return this._subject.asObservable();
37
49
  }
38
50
  get onSignedIn() {
39
51
  if (!this.onSignedInSubject) {
@@ -44,39 +56,39 @@ export class AuthService {
44
56
  throw new Error("onExecuteObservable is undefined");
45
57
  return this.onSignedInObservable;
46
58
  }
47
- login(tmp) {
48
- this.model = undefined;
49
- if (tmp) {
50
- //Globals.setServerDate(tmpModel.currentDateTime);
51
- //this.permissionsService.flushPermissions();
52
- if (tmp.roles) {
53
- tmp.roles = tmp.roles.map(function (e) { return e.toUpperCase(); });
54
- //this.permissionsService.loadPermissions(model.roles);
59
+ login(user) {
60
+ if (user) {
61
+ if (Array.isArray(user.roles)) {
62
+ user.roles = user.roles.map(function (e) { return e.toUpperCase(); });
55
63
  }
56
64
  }
57
- //delete tmpModel.currentDateTime;
58
- this.model = tmp;
59
- this.expired = null;
60
- StorageHelper.set('login', this.model);
65
+ StorageHelper.set('login', user);
66
+ this._user = null;
67
+ this._isInitialized = false;
61
68
  this.isAuthenticated(); //this method need to execute subject.next();
62
69
  }
63
70
  logout() {
64
71
  this.login(null);
65
72
  }
66
- getUser() {
67
- if (!this.model) {
68
- this.model = StorageHelper.get('login');
73
+ // getUser(): LoginToken | null {
74
+ // if (!this.model) {
75
+ // this.model = StorageHelper.get('login');
76
+ // }
77
+ // return this.model;
78
+ // }
79
+ getExpired() {
80
+ let user = this.user;
81
+ if (user) {
82
+ return user.expired;
69
83
  }
70
- return this.model;
84
+ return null;
71
85
  }
72
- getExpired() {
73
- if (!this.expired) {
74
- const tmp = this.getUser();
75
- if (tmp && tmp.expired) {
76
- this.expired = new Date(tmp.expired);
77
- }
86
+ getRefreshTokenExpired() {
87
+ let user = this.user;
88
+ if (user) {
89
+ return user.refreshTokenTime;
78
90
  }
79
- return this.expired;
91
+ return null;
80
92
  }
81
93
  // isInRole(allowedRoles: string[]): boolean {
82
94
  // if (!allowedRoles || allowedRoles.length === 0) {
@@ -112,8 +124,8 @@ export class AuthService {
112
124
  if (!permissions || permissions.length === 0) {
113
125
  return true;
114
126
  }
115
- const tmp = this.getUser();
116
- const userPermissions = tmp ? tmp.permissions : null;
127
+ const user = this.user;
128
+ const userPermissions = user ? user.permissions : null;
117
129
  if (!userPermissions) {
118
130
  return false;
119
131
  }
@@ -153,4 +165,4 @@ AuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
153
165
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AuthService, decorators: [{
154
166
  type: Injectable
155
167
  }] });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, } from '@angular/core';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { KeyPair, LoginToken } from '../models';\r\nimport { StorageHelper } from '../utils';\r\nimport { BitwiseHelper } from '../utils/bitwise-helper';\r\n\r\n@Injectable()\r\nexport class AuthService {\r\n    private subject = new BehaviorSubject<boolean>(false);//todo check if need BehaviorSubject\r\n    protected model?: LoginToken | null = null;\r\n    private expired: Date | null = null;\r\n\r\n    private oldValueIsAuthenticated: boolean = false;\r\n    isAuthenticated(): boolean {\r\n        let expired = this.getExpired();\r\n        if (!expired) expired = new Date(0);\r\n\r\n        const newValue = new Date() < expired;\r\n        if (this.oldValueIsAuthenticated != newValue) {\r\n            this.oldValueIsAuthenticated = newValue;\r\n\r\n            if (this.onSignedInSubject) {\r\n                this.onSignedInSubject.next(newValue);\r\n            }\r\n            this.subject.next(newValue);\r\n\r\n            //if user is signed in and expired we need to logout (remove from localStorage)\r\n            if (!newValue) {\r\n                this.logout();\r\n            }\r\n            return newValue;\r\n        }\r\n        return newValue;\r\n    }\r\n\r\n    /**\r\n    * @deprecated The method should not be used. please use onSignedIn\r\n    */\r\n    isSignedIn() {\r\n        return this.subject.asObservable();\r\n    }\r\n\r\n    private onSignedInSubject?: BehaviorSubject<boolean>;//BehaviorSubject is for initial firt value = false\r\n    private onSignedInObservable?: Observable<boolean>;\r\n    public get onSignedIn(): Observable<boolean> {\r\n        if (!this.onSignedInSubject) {\r\n            this.onSignedInSubject = new BehaviorSubject<boolean>(false);\r\n            this.onSignedInObservable = this.onSignedInSubject.asObservable();\r\n        }\r\n\r\n        if (!this.onSignedInObservable)\r\n            throw new Error(\"onExecuteObservable is undefined\");\r\n\r\n        return this.onSignedInObservable;\r\n    }\r\n\r\n\r\n    login(tmp?: LoginToken | null) {\r\n        this.model = undefined;\r\n        if (tmp) {\r\n            //Globals.setServerDate(tmpModel.currentDateTime);\r\n\r\n            //this.permissionsService.flushPermissions();\r\n            if (tmp.roles) {\r\n                tmp.roles = tmp.roles.map(function (e) { return e.toUpperCase(); });\r\n                //this.permissionsService.loadPermissions(model.roles);\r\n            }\r\n        }\r\n\r\n        //delete tmpModel.currentDateTime;\r\n        this.model = tmp;\r\n        this.expired = null;\r\n        StorageHelper.set('login', this.model);\r\n        this.isAuthenticated();//this method need to execute subject.next();\r\n    }\r\n    logout() {\r\n        this.login(null);\r\n    }\r\n\r\n    getUser(): LoginToken | undefined | null {\r\n        if (!this.model) {\r\n            this.model = StorageHelper.get('login');\r\n        }\r\n        return this.model;\r\n    }\r\n    protected getExpired(): Date | undefined | null {\r\n        if (!this.expired) {\r\n            const tmp = this.getUser();\r\n            if (tmp && tmp.expired) {\r\n                this.expired = new Date(tmp.expired);\r\n            }\r\n        }\r\n        return this.expired;\r\n    }\r\n\r\n\r\n    // isInRole(allowedRoles: string[]): boolean {\r\n    //     if (!allowedRoles || allowedRoles.length === 0) {\r\n    //         return true;\r\n    //     }\r\n\r\n    //     const tmp = this.getUser();\r\n    //     const roles = tmp ? tmp.roles : null;\r\n    //     if (!roles || roles.length === 0) {\r\n    //         return false;\r\n    //     }\r\n\r\n    //     let isInRole = allowedRoles.some(role => roles.indexOf(role) !== -1);\r\n    //     return isInRole;\r\n    // }\r\n\r\n\r\n    hasPermission(permission?: KeyPair<number, number> | number | null): boolean {\r\n        if (!permission) {\r\n            return true;\r\n        }\r\n\r\n        let key = 0;\r\n        let value: number | null | undefined;\r\n        if (typeof permission === 'number' || typeof permission === 'string') {\r\n            key = +permission;\r\n        }// else if (Array.isArray(permission)) {\r\n        // }\r\n        else if (typeof permission === 'object') {\r\n            if (!permission.key)\r\n                return true;\r\n\r\n            key = permission.key;\r\n            value = permission.value;\r\n        }\r\n\r\n        return this.hasPermissions([key], value);\r\n    }\r\n\r\n\r\n    hasPermissions(permissions?: Array<number>, value?: number | null): boolean {\r\n        if (!permissions || permissions.length === 0) {\r\n            return true;\r\n        }\r\n\r\n        const tmp = this.getUser();\r\n        const userPermissions = tmp ? tmp.permissions : null;\r\n        if (!userPermissions) {\r\n            return false;\r\n        }\r\n\r\n        if (value) {\r\n            for (let i = 0; i < permissions.length; i++) {\r\n                const p = permissions[i];\r\n                let found = userPermissions[p];\r\n                if (found) {\r\n                    let hasPermission = BitwiseHelper.hasFlag(found, value);\r\n                    if (hasPermission)\r\n                        return true;\r\n                }\r\n            }\r\n        } else {\r\n            for (let i = 0; i < permissions.length; i++) {\r\n                const p = permissions[i];\r\n                let found = userPermissions[p];\r\n                if (found)\r\n                    return true;\r\n            }\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n\r\n    hasDataPermission(data: any) {\r\n        //if (data === undefined || data === null) return true;\r\n        // const allowedRoles = data.roles;\r\n        // let isInRole = this.isInRole(allowedRoles);\r\n\r\n        const permission = data.permission;\r\n\r\n        let hasPermission = this.hasPermission(permission);\r\n\r\n        // return isInRole && hasPermission;\r\n        return hasPermission;\r\n    }\r\n}"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/auth.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,GAAG,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAuB,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;;AAGxD,MAAM,OAAO,WAAW;IADxB;QAEY,mBAAc,GAAY,KAAK,CAAC;QAChC,aAAQ,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC,CAAA,oCAAoC;QACnF,6BAAwB,GAAY,KAAK,CAAC;QAG1C,UAAK,GAAqB,IAAI,CAAC;KA6L1C;IA5LG,IAAW,IAAI;QACX,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACtB,IAAI,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YACrC,IAAI,GAAG,EAAE;gBACL,GAAG,CAAC,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;gBAChD,GAAG,CAAC,gBAAgB,GAAG,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;aACrE;YACD,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;YACjB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC9B;QACD,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAID,wCAAwC;IACxC,oDAAoD;IAEpD,eAAe;QACX,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;QAE/C,MAAM,QAAQ,GAAG,IAAI,IAAI,EAAE,GAAG,OAAO,CAAC;QACtC,IAAI,IAAI,CAAC,wBAAwB,IAAI,QAAQ,EAAE;YAC3C,IAAI,CAAC,wBAAwB,GAAG,QAAQ,CAAC;YAEzC,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACzC;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAE7B,+EAA+E;YAC/E,IAAI,CAAC,QAAQ,EAAE;gBACX,IAAI,CAAC,MAAM,EAAE,CAAC;aACjB;YACD,OAAO,QAAQ,CAAC;SACnB;QACD,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;MAEE;IACF,UAAU;QACN,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC;IACxC,CAAC;IAID,IAAW,UAAU;QACjB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;YAC7D,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;SACrE;QAED,IAAI,CAAC,IAAI,CAAC,oBAAoB;YAC1B,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QAExD,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACrC,CAAC;IAGD,KAAK,CAAC,IAAuB;QACzB,IAAI,IAAI,EAAE;YACN,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC3B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aACzE;SACJ;QAED,aAAa,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,eAAe,EAAE,CAAC,CAAA,6CAA6C;IACxE,CAAC;IACD,MAAM;QACF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAED,iCAAiC;IACjC,yBAAyB;IACzB,mDAAmD;IACnD,QAAQ;IACR,yBAAyB;IACzB,IAAI;IAEM,UAAU;QAChB,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACrB,IAAI,IAAI,EAAE;YACN,OAAO,IAAI,CAAC,OAAO,CAAC;SACvB;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,sBAAsB;QAC5B,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACrB,IAAI,IAAI,EAAE;YACN,OAAO,IAAI,CAAC,gBAAgB,CAAC;SAChC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,8CAA8C;IAC9C,wDAAwD;IACxD,uBAAuB;IACvB,QAAQ;IAER,kCAAkC;IAClC,4CAA4C;IAC5C,0CAA0C;IAC1C,wBAAwB;IACxB,QAAQ;IAER,4EAA4E;IAC5E,uBAAuB;IACvB,IAAI;IAGJ,aAAa,CAAC,UAAoD;QAC9D,IAAI,CAAC,UAAU,EAAE;YACb,OAAO,IAAI,CAAC;SACf;QAED,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,IAAI,KAAgC,CAAC;QACrC,IAAI,OAAO,UAAU,KAAK,QAAQ,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YAClE,GAAG,GAAG,CAAC,UAAU,CAAC;SACrB,CAAA,wCAAwC;QACzC,IAAI;aACC,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YACrC,IAAI,CAAC,UAAU,CAAC,GAAG;gBACf,OAAO,IAAI,CAAC;YAEhB,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC;YACrB,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;IAC7C,CAAC;IAGD,cAAc,CAAC,WAA2B,EAAE,KAAqB;QAC7D,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC1C,OAAO,IAAI,CAAC;SACf;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACvB,MAAM,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;QACvD,IAAI,CAAC,eAAe,EAAE;YAClB,OAAO,KAAK,CAAC;SAChB;QAED,IAAI,KAAK,EAAE;YACP,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACzC,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;gBACzB,IAAI,KAAK,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAI,KAAK,EAAE;oBACP,IAAI,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBACxD,IAAI,aAAa;wBACb,OAAO,IAAI,CAAC;iBACnB;aACJ;SACJ;aAAM;YACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACzC,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;gBACzB,IAAI,KAAK,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAI,KAAK;oBACL,OAAO,IAAI,CAAC;aACnB;SACJ;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAGD,iBAAiB,CAAC,IAAS;QACvB,uDAAuD;QACvD,mCAAmC;QACnC,8CAA8C;QAE9C,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAEnC,IAAI,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAEnD,oCAAoC;QACpC,OAAO,aAAa,CAAC;IACzB,CAAC;;wGAlMQ,WAAW;4GAAX,WAAW;2FAAX,WAAW;kBADvB,UAAU","sourcesContent":["import { Injectable, } from '@angular/core';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { KeyPair, LoginToken, LoginUser } from '../models';\r\nimport { DateHelper, StorageHelper } from '../utils';\r\nimport { BitwiseHelper } from '../utils/bitwise-helper';\r\n\r\n@Injectable()\r\nexport class AuthService {\r\n    private _isInitialized: boolean = false;\r\n    private _subject = new BehaviorSubject<boolean>(false);//todo check if need BehaviorSubject\r\n    private _oldValueIsAuthenticated: boolean = false;\r\n\r\n\r\n    private _user: LoginUser | null = null;\r\n    public get user(): LoginUser | null {\r\n        if (!this._isInitialized) {\r\n            let tmp = StorageHelper.get('login');\r\n            if (tmp) {\r\n                tmp.expired = DateHelper.parseDate(tmp.expired);\r\n                tmp.refreshTokenTime = DateHelper.parseDate(tmp.refreshTokenTime);\r\n            }\r\n            this._user = tmp;\r\n            this._isInitialized = true;\r\n        }\r\n        return this._user;\r\n    }\r\n    \r\n\r\n\r\n    // private _expired: Date | null = null;\r\n    // private _refreshTokenExpired: Date | null = null;\r\n\r\n    isAuthenticated(): boolean {\r\n        let expired = this.getExpired() || new Date(0);\r\n\r\n        const newValue = new Date() < expired;\r\n        if (this._oldValueIsAuthenticated != newValue) {\r\n            this._oldValueIsAuthenticated = newValue;\r\n\r\n            if (this.onSignedInSubject) {\r\n                this.onSignedInSubject.next(newValue);\r\n            }\r\n            this._subject.next(newValue);\r\n\r\n            //if user is signed in and expired we need to logout (remove from localStorage)\r\n            if (!newValue) {\r\n                this.logout();\r\n            }\r\n            return newValue;\r\n        }\r\n        return newValue;\r\n    }\r\n\r\n    /**\r\n    * @deprecated The method should not be used. please use onSignedIn\r\n    */\r\n    isSignedIn() {\r\n        return this._subject.asObservable();\r\n    }\r\n\r\n    private onSignedInSubject?: BehaviorSubject<boolean>;//BehaviorSubject is for initial firt value = false\r\n    private onSignedInObservable?: Observable<boolean>;\r\n    public get onSignedIn(): Observable<boolean> {\r\n        if (!this.onSignedInSubject) {\r\n            this.onSignedInSubject = new BehaviorSubject<boolean>(false);\r\n            this.onSignedInObservable = this.onSignedInSubject.asObservable();\r\n        }\r\n\r\n        if (!this.onSignedInObservable)\r\n            throw new Error(\"onExecuteObservable is undefined\");\r\n\r\n        return this.onSignedInObservable;\r\n    }\r\n\r\n\r\n    login(user: LoginToken | null) {\r\n        if (user) {\r\n            if (Array.isArray(user.roles)) {\r\n                user.roles = user.roles.map(function (e) { return e.toUpperCase(); });\r\n            }\r\n        }\r\n\r\n        StorageHelper.set('login', user);\r\n        this._user = null;\r\n        this._isInitialized = false;\r\n        this.isAuthenticated();//this method need to execute subject.next();\r\n    }\r\n    logout() {\r\n        this.login(null);\r\n    }\r\n\r\n    // getUser(): LoginToken | null {\r\n    //     if (!this.model) {\r\n    //         this.model = StorageHelper.get('login');\r\n    //     }\r\n    //     return this.model;\r\n    // }\r\n\r\n    protected getExpired(): Date | null {\r\n        let user = this.user;\r\n        if (user) {\r\n            return user.expired;\r\n        }\r\n\r\n        return null;\r\n    }\r\n\r\n    protected getRefreshTokenExpired(): Date | null {\r\n        let user = this.user;\r\n        if (user) {\r\n            return user.refreshTokenTime;\r\n        }\r\n\r\n        return null;\r\n    }\r\n\r\n\r\n    // isInRole(allowedRoles: string[]): boolean {\r\n    //     if (!allowedRoles || allowedRoles.length === 0) {\r\n    //         return true;\r\n    //     }\r\n\r\n    //     const tmp = this.getUser();\r\n    //     const roles = tmp ? tmp.roles : null;\r\n    //     if (!roles || roles.length === 0) {\r\n    //         return false;\r\n    //     }\r\n\r\n    //     let isInRole = allowedRoles.some(role => roles.indexOf(role) !== -1);\r\n    //     return isInRole;\r\n    // }\r\n\r\n\r\n    hasPermission(permission?: KeyPair<number, number> | number | null): boolean {\r\n        if (!permission) {\r\n            return true;\r\n        }\r\n\r\n        let key = 0;\r\n        let value: number | null | undefined;\r\n        if (typeof permission === 'number' || typeof permission === 'string') {\r\n            key = +permission;\r\n        }// else if (Array.isArray(permission)) {\r\n        // }\r\n        else if (typeof permission === 'object') {\r\n            if (!permission.key)\r\n                return true;\r\n\r\n            key = permission.key;\r\n            value = permission.value;\r\n        }\r\n\r\n        return this.hasPermissions([key], value);\r\n    }\r\n\r\n\r\n    hasPermissions(permissions?: Array<number>, value?: number | null): boolean {\r\n        if (!permissions || permissions.length === 0) {\r\n            return true;\r\n        }\r\n\r\n        const user = this.user;\r\n        const userPermissions = user ? user.permissions : null;\r\n        if (!userPermissions) {\r\n            return false;\r\n        }\r\n\r\n        if (value) {\r\n            for (let i = 0; i < permissions.length; i++) {\r\n                const p = permissions[i];\r\n                let found = userPermissions[p];\r\n                if (found) {\r\n                    let hasPermission = BitwiseHelper.hasFlag(found, value);\r\n                    if (hasPermission)\r\n                        return true;\r\n                }\r\n            }\r\n        } else {\r\n            for (let i = 0; i < permissions.length; i++) {\r\n                const p = permissions[i];\r\n                let found = userPermissions[p];\r\n                if (found)\r\n                    return true;\r\n            }\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n\r\n    hasDataPermission(data: any) {\r\n        //if (data === undefined || data === null) return true;\r\n        // const allowedRoles = data.roles;\r\n        // let isInRole = this.isInRole(allowedRoles);\r\n\r\n        const permission = data.permission;\r\n\r\n        let hasPermission = this.hasPermission(permission);\r\n\r\n        // return isInRole && hasPermission;\r\n        return hasPermission;\r\n    }\r\n}"]}
@@ -94,7 +94,7 @@ export class WebApiClient {
94
94
  getHeaders() {
95
95
  let httpHeaders = new HttpHeaders();
96
96
  httpHeaders = httpHeaders.set('Content-Type', 'application/json');
97
- const tmp = this.authService.getUser();
97
+ const tmp = this.authService.user;
98
98
  const token = tmp ? tmp.token : undefined;
99
99
  if (token)
100
100
  httpHeaders = httpHeaders.set('Authorization', token);
@@ -123,4 +123,4 @@ export class CustomHttpParamEncoder {
123
123
  return decodeURIComponent(value);
124
124
  }
125
125
  }
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web.api.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/web.api.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\r\nimport { HttpClient, HttpHeaders, HttpParams/*, HttpErrorResponse*/ } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\n//import { of } from 'rxjs/observable/of';\r\n//import { catchError } from 'rxjs/operators';\r\n\r\nimport { AuthService } from './auth.service';\r\n//import { deleteNullProperties } from '../utils';\r\n//import { HttpErrorHandler, HandleError } from './http-error-handler.service';\r\n\r\n\r\nexport interface WebApiConfig {\r\n    baseUrl: string;\r\n}\r\n\r\n@Injectable()\r\nexport class WebApiClient {\r\n    constructor(\r\n        protected readonly http: HttpClient,\r\n        protected readonly authService: AuthService,\r\n        @Inject(API_BASE_URL) private readonly baseUrl: string) {\r\n    }\r\n\r\n    get<T = any>(url: string, params?: any): Observable<T> {\r\n        return this.http.get<T>(this.baseUrl + url, { headers: this.getHeaders(), params: this.toHttpParams(params) });\r\n        /*.catch(catchError(this.handleError(url)))\r\n        .do((res: Response) => {\r\n            // Handle success, maybe display notification\r\n        }, (error: any) => {\r\n            // Handle errors\r\n        })\r\n        .finally(() => {\r\n            // Request completed\r\n        });\r\n    */\r\n    }\r\n\r\n    getString(url: string, params?: object): Observable<string | null> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'text', params: this.toHttpParams(params) });\r\n    }\r\n    getBytes(url: string, params?: any): Observable<ArrayBuffer> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'arraybuffer', params: this.toHttpParams(params) });\r\n    }\r\n    getBlob(url: string, params?: any): Observable<Blob> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'blob', params: this.toHttpParams(params) });\r\n    }\r\n\r\n\r\n\r\n    protected toHttpParams(obj: any) {\r\n        if (!obj)\r\n            return undefined;\r\n\r\n        let params = new HttpParams({ encoder: new CustomHttpParamEncoder() });\r\n        for (const key of Object.keys(obj)) {\r\n            const field = obj[key];\r\n\r\n            if (field === undefined || field === null || (typeof field === 'string' && field.length === 0))\r\n                continue;\r\n\r\n            let value = field;\r\n            // if (typeof field === 'string' && field.length > 0) {\r\n            //     value = field.replace(/\\+/gi, '%2B');\r\n            // }\r\n\r\n            params = params.append(key, value);\r\n            // if (field instanceof Array) {\r\n            //     field.forEach((item: any) => {\r\n            //         params = params.append(`${key}[]`, item);\r\n            //     });\r\n            // } else {\r\n            //     params = params.append(key, field);\r\n            // }\r\n        }\r\n        return params;\r\n\r\n\r\n        //deleteNullProperties(obj);\r\n        //comment because int[] not sending in c# it send \"1,2,3,4\"\r\n        // return obj\r\n        //     ? Object.getOwnPropertyNames(obj).reduce((p, key) => p.set(key, obj[key]), new HttpParams())\r\n        //     : undefined;\r\n    }\r\n\r\n    //toKeyPairs(obj: any): KeyPair[] | undefined {\r\n    //    if (obj instanceof Object) {\r\n    //        const properties = Object.getOwnPropertyNames(obj);\r\n    //        const result = new Array<KeyPair>();\r\n    //        for (let property of properties) {\r\n    //            const value = obj[property];\r\n    //            result.push({ key: property, value: value });\r\n    //        }\r\n    //        return result;\r\n    //    }\r\n    //    return undefined;\r\n    //}\r\n\r\n    post<T = any>(url: string, body?: any | null): Observable<T> {\r\n        return this.http.post<T>(this.baseUrl + url, body, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n    put<T = any>(url: string, body?: any | null): Observable<T> {\r\n        return this.http.put<T>(this.baseUrl + url, body, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n    delete(url: string, body?: any | null): Observable<any> {\r\n        return this.http.request('delete', this.baseUrl + url, { body, headers: this.getHeaders() });\r\n        //return this.http.delete(environment.url + url, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n\r\n\r\n\r\n    protected getHeaders(): HttpHeaders {\r\n        let httpHeaders = new HttpHeaders();\r\n        httpHeaders = httpHeaders.set('Content-Type', 'application/json');\r\n        const tmp = this.authService.getUser();\r\n        const token = tmp ? tmp.token : undefined;\r\n        if (token)\r\n            httpHeaders = httpHeaders.set('Authorization', token);\r\n        return httpHeaders;\r\n    }\r\n\r\n\r\n\r\n    //private getParams(params?: KeyPair[] | null) {\r\n    //    if (!params || params.length === 0) {\r\n    //        return undefined;\r\n    //    }\r\n    //    let httpParams = new HttpParams();\r\n    //    if (params) {\r\n    //        for (let param of params) {\r\n    //            httpParams = httpParams.set(param.key, param.value);\r\n    //        }\r\n    //    }\r\n    //    return httpParams;\r\n    //}\r\n}\r\n\r\n\r\nimport { HttpParameterCodec } from '@angular/common/http';\r\nimport { API_BASE_URL } from '../tokens';\r\nexport class CustomHttpParamEncoder implements HttpParameterCodec {\r\n    encodeKey(key: string): string {\r\n        return encodeURIComponent(key);\r\n    }\r\n    encodeValue(value: string): string {\r\n        return encodeURIComponent(value);\r\n    }\r\n    decodeKey(key: string): string {\r\n        return decodeURIComponent(key);\r\n    }\r\n    decodeValue(value: string): string {\r\n        return decodeURIComponent(value);\r\n    }\r\n}"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web.api.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/web.api.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\r\nimport { HttpClient, HttpHeaders, HttpParams/*, HttpErrorResponse*/ } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\n//import { of } from 'rxjs/observable/of';\r\n//import { catchError } from 'rxjs/operators';\r\n\r\nimport { AuthService } from './auth.service';\r\n//import { deleteNullProperties } from '../utils';\r\n//import { HttpErrorHandler, HandleError } from './http-error-handler.service';\r\n\r\n\r\nexport interface WebApiConfig {\r\n    baseUrl: string;\r\n}\r\n\r\n@Injectable()\r\nexport class WebApiClient {\r\n    constructor(\r\n        protected readonly http: HttpClient,\r\n        protected readonly authService: AuthService,\r\n        @Inject(API_BASE_URL) private readonly baseUrl: string) {\r\n    }\r\n\r\n    get<T = any>(url: string, params?: any): Observable<T> {\r\n        return this.http.get<T>(this.baseUrl + url, { headers: this.getHeaders(), params: this.toHttpParams(params) });\r\n        /*.catch(catchError(this.handleError(url)))\r\n        .do((res: Response) => {\r\n            // Handle success, maybe display notification\r\n        }, (error: any) => {\r\n            // Handle errors\r\n        })\r\n        .finally(() => {\r\n            // Request completed\r\n        });\r\n    */\r\n    }\r\n\r\n    getString(url: string, params?: object): Observable<string | null> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'text', params: this.toHttpParams(params) });\r\n    }\r\n    getBytes(url: string, params?: any): Observable<ArrayBuffer> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'arraybuffer', params: this.toHttpParams(params) });\r\n    }\r\n    getBlob(url: string, params?: any): Observable<Blob> {\r\n        return this.http.get(this.baseUrl + url, { headers: this.getHeaders(), responseType: 'blob', params: this.toHttpParams(params) });\r\n    }\r\n\r\n\r\n\r\n    protected toHttpParams(obj: any) {\r\n        if (!obj)\r\n            return undefined;\r\n\r\n        let params = new HttpParams({ encoder: new CustomHttpParamEncoder() });\r\n        for (const key of Object.keys(obj)) {\r\n            const field = obj[key];\r\n\r\n            if (field === undefined || field === null || (typeof field === 'string' && field.length === 0))\r\n                continue;\r\n\r\n            let value = field;\r\n            // if (typeof field === 'string' && field.length > 0) {\r\n            //     value = field.replace(/\\+/gi, '%2B');\r\n            // }\r\n\r\n            params = params.append(key, value);\r\n            // if (field instanceof Array) {\r\n            //     field.forEach((item: any) => {\r\n            //         params = params.append(`${key}[]`, item);\r\n            //     });\r\n            // } else {\r\n            //     params = params.append(key, field);\r\n            // }\r\n        }\r\n        return params;\r\n\r\n\r\n        //deleteNullProperties(obj);\r\n        //comment because int[] not sending in c# it send \"1,2,3,4\"\r\n        // return obj\r\n        //     ? Object.getOwnPropertyNames(obj).reduce((p, key) => p.set(key, obj[key]), new HttpParams())\r\n        //     : undefined;\r\n    }\r\n\r\n    //toKeyPairs(obj: any): KeyPair[] | undefined {\r\n    //    if (obj instanceof Object) {\r\n    //        const properties = Object.getOwnPropertyNames(obj);\r\n    //        const result = new Array<KeyPair>();\r\n    //        for (let property of properties) {\r\n    //            const value = obj[property];\r\n    //            result.push({ key: property, value: value });\r\n    //        }\r\n    //        return result;\r\n    //    }\r\n    //    return undefined;\r\n    //}\r\n\r\n    post<T = any>(url: string, body?: any | null): Observable<T> {\r\n        return this.http.post<T>(this.baseUrl + url, body, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n    put<T = any>(url: string, body?: any | null): Observable<T> {\r\n        return this.http.put<T>(this.baseUrl + url, body, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n    delete(url: string, body?: any | null): Observable<any> {\r\n        return this.http.request('delete', this.baseUrl + url, { body, headers: this.getHeaders() });\r\n        //return this.http.delete(environment.url + url, { headers: this.getHeaders() });\r\n        //.pipe(\r\n        //catchError(this.handleError(url))\r\n        //);\r\n    }\r\n\r\n\r\n\r\n    protected getHeaders(): HttpHeaders {\r\n        let httpHeaders = new HttpHeaders();\r\n        httpHeaders = httpHeaders.set('Content-Type', 'application/json');\r\n        const tmp = this.authService.user;\r\n        const token = tmp ? tmp.token : undefined;\r\n        if (token)\r\n            httpHeaders = httpHeaders.set('Authorization', token);\r\n        return httpHeaders;\r\n    }\r\n\r\n\r\n\r\n    //private getParams(params?: KeyPair[] | null) {\r\n    //    if (!params || params.length === 0) {\r\n    //        return undefined;\r\n    //    }\r\n    //    let httpParams = new HttpParams();\r\n    //    if (params) {\r\n    //        for (let param of params) {\r\n    //            httpParams = httpParams.set(param.key, param.value);\r\n    //        }\r\n    //    }\r\n    //    return httpParams;\r\n    //}\r\n}\r\n\r\n\r\nimport { HttpParameterCodec } from '@angular/common/http';\r\nimport { API_BASE_URL } from '../tokens';\r\nexport class CustomHttpParamEncoder implements HttpParameterCodec {\r\n    encodeKey(key: string): string {\r\n        return encodeURIComponent(key);\r\n    }\r\n    encodeValue(value: string): string {\r\n        return encodeURIComponent(value);\r\n    }\r\n    decodeKey(key: string): string {\r\n        return decodeURIComponent(key);\r\n    }\r\n    decodeValue(value: string): string {\r\n        return decodeURIComponent(value);\r\n    }\r\n}"]}
package/fesm2015/zek.mjs CHANGED
@@ -1110,22 +1110,34 @@ class UrlHelper {
1110
1110
 
1111
1111
  class AuthService {
1112
1112
  constructor() {
1113
- this.subject = new BehaviorSubject(false); //todo check if need BehaviorSubject
1114
- this.model = null;
1115
- this.expired = null;
1116
- this.oldValueIsAuthenticated = false;
1113
+ this._isInitialized = false;
1114
+ this._subject = new BehaviorSubject(false); //todo check if need BehaviorSubject
1115
+ this._oldValueIsAuthenticated = false;
1116
+ this._user = null;
1117
+ }
1118
+ get user() {
1119
+ if (!this._isInitialized) {
1120
+ let tmp = StorageHelper.get('login');
1121
+ if (tmp) {
1122
+ tmp.expired = DateHelper.parseDate(tmp.expired);
1123
+ tmp.refreshTokenTime = DateHelper.parseDate(tmp.refreshTokenTime);
1124
+ }
1125
+ this._user = tmp;
1126
+ this._isInitialized = true;
1127
+ }
1128
+ return this._user;
1117
1129
  }
1130
+ // private _expired: Date | null = null;
1131
+ // private _refreshTokenExpired: Date | null = null;
1118
1132
  isAuthenticated() {
1119
- let expired = this.getExpired();
1120
- if (!expired)
1121
- expired = new Date(0);
1133
+ let expired = this.getExpired() || new Date(0);
1122
1134
  const newValue = new Date() < expired;
1123
- if (this.oldValueIsAuthenticated != newValue) {
1124
- this.oldValueIsAuthenticated = newValue;
1135
+ if (this._oldValueIsAuthenticated != newValue) {
1136
+ this._oldValueIsAuthenticated = newValue;
1125
1137
  if (this.onSignedInSubject) {
1126
1138
  this.onSignedInSubject.next(newValue);
1127
1139
  }
1128
- this.subject.next(newValue);
1140
+ this._subject.next(newValue);
1129
1141
  //if user is signed in and expired we need to logout (remove from localStorage)
1130
1142
  if (!newValue) {
1131
1143
  this.logout();
@@ -1138,7 +1150,7 @@ class AuthService {
1138
1150
  * @deprecated The method should not be used. please use onSignedIn
1139
1151
  */
1140
1152
  isSignedIn() {
1141
- return this.subject.asObservable();
1153
+ return this._subject.asObservable();
1142
1154
  }
1143
1155
  get onSignedIn() {
1144
1156
  if (!this.onSignedInSubject) {
@@ -1149,39 +1161,39 @@ class AuthService {
1149
1161
  throw new Error("onExecuteObservable is undefined");
1150
1162
  return this.onSignedInObservable;
1151
1163
  }
1152
- login(tmp) {
1153
- this.model = undefined;
1154
- if (tmp) {
1155
- //Globals.setServerDate(tmpModel.currentDateTime);
1156
- //this.permissionsService.flushPermissions();
1157
- if (tmp.roles) {
1158
- tmp.roles = tmp.roles.map(function (e) { return e.toUpperCase(); });
1159
- //this.permissionsService.loadPermissions(model.roles);
1164
+ login(user) {
1165
+ if (user) {
1166
+ if (Array.isArray(user.roles)) {
1167
+ user.roles = user.roles.map(function (e) { return e.toUpperCase(); });
1160
1168
  }
1161
1169
  }
1162
- //delete tmpModel.currentDateTime;
1163
- this.model = tmp;
1164
- this.expired = null;
1165
- StorageHelper.set('login', this.model);
1170
+ StorageHelper.set('login', user);
1171
+ this._user = null;
1172
+ this._isInitialized = false;
1166
1173
  this.isAuthenticated(); //this method need to execute subject.next();
1167
1174
  }
1168
1175
  logout() {
1169
1176
  this.login(null);
1170
1177
  }
1171
- getUser() {
1172
- if (!this.model) {
1173
- this.model = StorageHelper.get('login');
1178
+ // getUser(): LoginToken | null {
1179
+ // if (!this.model) {
1180
+ // this.model = StorageHelper.get('login');
1181
+ // }
1182
+ // return this.model;
1183
+ // }
1184
+ getExpired() {
1185
+ let user = this.user;
1186
+ if (user) {
1187
+ return user.expired;
1174
1188
  }
1175
- return this.model;
1189
+ return null;
1176
1190
  }
1177
- getExpired() {
1178
- if (!this.expired) {
1179
- const tmp = this.getUser();
1180
- if (tmp && tmp.expired) {
1181
- this.expired = new Date(tmp.expired);
1182
- }
1191
+ getRefreshTokenExpired() {
1192
+ let user = this.user;
1193
+ if (user) {
1194
+ return user.refreshTokenTime;
1183
1195
  }
1184
- return this.expired;
1196
+ return null;
1185
1197
  }
1186
1198
  // isInRole(allowedRoles: string[]): boolean {
1187
1199
  // if (!allowedRoles || allowedRoles.length === 0) {
@@ -1217,8 +1229,8 @@ class AuthService {
1217
1229
  if (!permissions || permissions.length === 0) {
1218
1230
  return true;
1219
1231
  }
1220
- const tmp = this.getUser();
1221
- const userPermissions = tmp ? tmp.permissions : null;
1232
+ const user = this.user;
1233
+ const userPermissions = user ? user.permissions : null;
1222
1234
  if (!userPermissions) {
1223
1235
  return false;
1224
1236
  }
@@ -1729,7 +1741,7 @@ class WebApiClient {
1729
1741
  getHeaders() {
1730
1742
  let httpHeaders = new HttpHeaders();
1731
1743
  httpHeaders = httpHeaders.set('Content-Type', 'application/json');
1732
- const tmp = this.authService.getUser();
1744
+ const tmp = this.authService.user;
1733
1745
  const token = tmp ? tmp.token : undefined;
1734
1746
  if (token)
1735
1747
  httpHeaders = httpHeaders.set('Authorization', token);