tnx-shared 5.1.310 → 5.1.313
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/tnx-shared.umd.js +143 -12
- package/bundles/tnx-shared.umd.js.map +1 -1
- package/bundles/tnx-shared.umd.min.js +1 -1
- package/bundles/tnx-shared.umd.min.js.map +1 -1
- package/classes/public-function.d.ts +1 -1
- package/components/common-app-component/common-app-component.d.ts +4 -3
- package/components/common-app-component/common-app-component.d.ts.map +1 -1
- package/components/crud/crud-form/crud-form.component.d.ts +2 -2
- package/esm2015/components/chat/chat-box/chat-box.component.js +1 -1
- package/esm2015/components/chat/chat-send-message-box/chat-send-message-box.component.js +1 -1
- package/esm2015/components/common-app-component/common-app-component.js +27 -5
- package/esm2015/services/permission.service.js +63 -18
- package/esm2015/services/role.service.js +29 -1
- package/esm2015/services/user.service.js +4 -1
- package/fesm2015/tnx-shared.js +117 -19
- package/fesm2015/tnx-shared.js.map +1 -1
- package/package.json +2 -2
- package/services/permission.service.d.ts +6 -4
- package/services/permission.service.d.ts.map +1 -1
- package/services/role.service.d.ts +7 -0
- package/services/role.service.d.ts.map +1 -1
- package/services/user.service.d.ts +1 -0
- package/services/user.service.d.ts.map +1 -1
- package/tnx-shared.metadata.json +1 -1
|
@@ -31,18 +31,19 @@ export class PermissionService extends BaseService {
|
|
|
31
31
|
this._oauthService = _oauthService;
|
|
32
32
|
this._appContext = _appContext;
|
|
33
33
|
this.storage = sessionStorage;
|
|
34
|
-
this.delayCheckPermissions = [];
|
|
35
34
|
this.ignoreAdmin = false;
|
|
35
|
+
this.delayCheckPermissions = [];
|
|
36
36
|
this.appCode = null;
|
|
37
|
-
this.
|
|
38
|
-
this.
|
|
39
|
-
this.
|
|
37
|
+
this._config = this._moduleConfigService.getConfig();
|
|
38
|
+
this.endPoint = this._config.environment.apiDomain.authorizationEndpoint;
|
|
39
|
+
this.ignoreAdmin = this._config.environment.isIgnoreAdmin;
|
|
40
|
+
this.appCode = this._config.appCode;
|
|
40
41
|
}
|
|
41
42
|
clearPermissionCacheAll() {
|
|
42
43
|
var _a, _b, _c;
|
|
43
|
-
const lstAppCodes = (_c = (_b = (_a = this.
|
|
44
|
+
const lstAppCodes = (_c = (_b = (_a = this._config.environment.appMetadata) === null || _a === void 0 ? void 0 : _a.appSwitcher) === null || _b === void 0 ? void 0 : _b.map(app => app.code)) !== null && _c !== void 0 ? _c : [];
|
|
44
45
|
const lstApiEndpoint = [];
|
|
45
|
-
const apiDomain = this.
|
|
46
|
+
const apiDomain = this._config.environment.apiDomain;
|
|
46
47
|
for (const domainName in apiDomain) {
|
|
47
48
|
if (domainName.startsWith('-') || domainName.startsWith('1') || domainName == 'gateway')
|
|
48
49
|
continue;
|
|
@@ -59,18 +60,22 @@ export class PermissionService extends BaseService {
|
|
|
59
60
|
const url = `${this.serviceUri}/GetCurrentUserPermission`;
|
|
60
61
|
return this.defaultGet(url);
|
|
61
62
|
}
|
|
62
|
-
getAllBasePermission() {
|
|
63
|
+
getAllBasePermission(userId) {
|
|
63
64
|
var _a, _b, _c, _d;
|
|
64
65
|
return __awaiter(this, void 0, void 0, function* () {
|
|
65
|
-
|
|
66
|
+
let url = `${this.serviceUri}/GetAllBasePermission`;
|
|
66
67
|
const user = this._userService.getCurrentUser();
|
|
67
68
|
if (user
|
|
68
69
|
&& (user.issuperuser && user.issuperuser.toLowerCase() == 'true')
|
|
69
70
|
|| (user.isadmin && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin)) {
|
|
70
71
|
return;
|
|
71
72
|
}
|
|
73
|
+
if (userId && userId != '' && userId != this._commonService.guidEmpty()) {
|
|
74
|
+
url += `?userId=${userId}`;
|
|
75
|
+
return this.defaultGet(url);
|
|
76
|
+
}
|
|
72
77
|
const res = yield this.defaultGet(url);
|
|
73
|
-
const lstAppCodes = (_c = (_b = (_a = this.
|
|
78
|
+
const lstAppCodes = (_c = (_b = (_a = this._config.environment.appMetadata) === null || _a === void 0 ? void 0 : _a.appSwitcher) === null || _b === void 0 ? void 0 : _b.map(app => app.code)) !== null && _c !== void 0 ? _c : [];
|
|
74
79
|
if (!res.success || res.data == null) {
|
|
75
80
|
const promiseArr = [];
|
|
76
81
|
for (const code in lstAppCodes) {
|
|
@@ -142,11 +147,9 @@ export class PermissionService extends BaseService {
|
|
|
142
147
|
yield this.checkPermission(service, permission, resolve, reject);
|
|
143
148
|
}));
|
|
144
149
|
}
|
|
145
|
-
checkPermission(service,
|
|
150
|
+
checkPermission(service, permissionToCheck, resolve, reject) {
|
|
146
151
|
return __awaiter(this, void 0, void 0, function* () {
|
|
147
152
|
const user = (yield this._userService.getCurrentUser());
|
|
148
|
-
resolve(true);
|
|
149
|
-
return;
|
|
150
153
|
if (user && user.issuperuser && user.issuperuser.toLowerCase() == 'true') {
|
|
151
154
|
resolve(true);
|
|
152
155
|
return;
|
|
@@ -155,20 +158,62 @@ export class PermissionService extends BaseService {
|
|
|
155
158
|
resolve(true);
|
|
156
159
|
return;
|
|
157
160
|
}
|
|
158
|
-
this.getPermissions(service).then(
|
|
159
|
-
if (
|
|
160
|
-
|
|
161
|
-
resolve(isAuthorized);
|
|
161
|
+
this.getPermissions(service).then(userPermissions => {
|
|
162
|
+
if (userPermissions && userPermissions.length) {
|
|
163
|
+
resolve(this._checkPermission(userPermissions, permissionToCheck));
|
|
162
164
|
}
|
|
163
165
|
else {
|
|
164
|
-
console.log(`
|
|
166
|
+
console.log(`Không có quyền với phân hệ [${service}]`);
|
|
165
167
|
resolve(false);
|
|
166
168
|
}
|
|
167
169
|
}, error => {
|
|
168
170
|
reject(false);
|
|
171
|
+
console.log(`Lỗi không lấy được permission cho module: ${service}`);
|
|
169
172
|
});
|
|
170
173
|
});
|
|
171
174
|
}
|
|
175
|
+
_checkPermission(userPermissions, permissionToCheck) {
|
|
176
|
+
let isAuthorized = false;
|
|
177
|
+
// check quyền theo cách cũ nếu trường họp là phân quyền module
|
|
178
|
+
if (permissionToCheck.includes('MODULE')) {
|
|
179
|
+
return userPermissions.includes(permissionToCheck);
|
|
180
|
+
}
|
|
181
|
+
for (const userPermission of userPermissions) {
|
|
182
|
+
// Cắt chuỗi permission thành mảng để xem mỗi fragement có khớp nhau không
|
|
183
|
+
const userPermissionFragments = userPermission.split('/');
|
|
184
|
+
const permissionFragements = permissionToCheck.split('/');
|
|
185
|
+
// Mảng khác độ dài thì thoát sớm
|
|
186
|
+
if (userPermissionFragments.length != permissionFragements.length) {
|
|
187
|
+
continue;
|
|
188
|
+
}
|
|
189
|
+
// biến flag ra hiệu người dùng authorized và out vòng
|
|
190
|
+
let breakLoop = false;
|
|
191
|
+
// nếu tất cả phần tử khớp nhau => permission này trùng và người dùng được authorized
|
|
192
|
+
for (let index = 0; index < permissionFragements.length; index++) {
|
|
193
|
+
const userFragement = userPermissionFragments[index];
|
|
194
|
+
const permissionFragment = permissionFragements[index];
|
|
195
|
+
// skip qua các phần tử có ký tự bắt đầu là '{'
|
|
196
|
+
if (userFragement[0] == '{') {
|
|
197
|
+
if (index == permissionFragements.length - 1) {
|
|
198
|
+
isAuthorized = true;
|
|
199
|
+
breakLoop = true;
|
|
200
|
+
}
|
|
201
|
+
continue;
|
|
202
|
+
}
|
|
203
|
+
if (userFragement.toLowerCase() != permissionFragment.toLowerCase()) {
|
|
204
|
+
break;
|
|
205
|
+
}
|
|
206
|
+
if (index == permissionFragements.length - 1) {
|
|
207
|
+
isAuthorized = true;
|
|
208
|
+
breakLoop = true;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
if (breakLoop) {
|
|
212
|
+
break;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return isAuthorized;
|
|
216
|
+
}
|
|
172
217
|
isAuthorizedByPermissions(permissions, operator = 'OR', ignoreAdmin = false) {
|
|
173
218
|
return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
|
|
174
219
|
const user = (yield this._userService.getCurrentUser());
|
|
@@ -247,4 +292,4 @@ PermissionService.ctorParameters = () => [
|
|
|
247
292
|
{ type: OAuthService },
|
|
248
293
|
{ type: ApplicationContextService }
|
|
249
294
|
];
|
|
250
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission.service.js","sourceRoot":"../../../../projects/tnx-shared/src/lib/","sources":["services/permission.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable, Injector } from '@angular/core';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\n\r\nimport { ApplicationContextService } from '../app-context/application-context.service';\r\nimport { ComponentContextService } from '../app-context/component-context.service';\r\nimport { Permission } from '../models/permission';\r\nimport { TnUser } from '../models/tn-user';\r\nimport { BaseService } from './base.service';\r\nimport { ModuleConfigService } from './module-config.service';\r\nimport { UserService } from './user.service';\r\nimport { ResponseResult } from '../models/response-result';\r\n\r\nexport class PhanQuyenModel {\r\n    subjectType: number;\r\n    idUserGroups?: string[];\r\n    idUsers?: string[];\r\n    addRoleIds?: string[] = [];\r\n    removeRoleIds?: string[] = [];\r\n    addPermissionIds?: string[] = [];\r\n    removePermissionIds?: string[] = [];\r\n    constructor(init: PhanQuyenModel) {\r\n        for (const key in init) {\r\n            this[key] = init[key];\r\n        }\r\n    }\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class PermissionService extends BaseService {\r\n\r\n    readonly storage = sessionStorage;\r\n    delayCheckPermissions = [];\r\n    root: ComponentContextService;\r\n    ignoreAdmin = false;\r\n    appCode: string = null;\r\n\r\n    constructor(\r\n        http: HttpClient,\r\n        injector: Injector,\r\n        private _moduleConfigService: ModuleConfigService,\r\n        private _userService: UserService,\r\n        private _oauthService: OAuthService,\r\n        private _appContext: ApplicationContextService\r\n    ) {\r\n        super(http, injector, `${_moduleConfigService.getConfig().environment.apiDomain.authorizationEndpoint}/${_moduleConfigService.getConfig().environment.apiVersion}/permission`);\r\n        this.endPoint = _moduleConfigService.getConfig().environment.apiDomain.authorizationEndpoint;\r\n        this.ignoreAdmin = this._moduleConfigService.getConfig().environment.isIgnoreAdmin;\r\n        this.appCode = this._moduleConfigService.getConfig().appCode;\r\n    }\r\n\r\n    clearPermissionCacheAll() {\r\n        const lstAppCodes = this._moduleConfigService.getConfig().environment.appMetadata?.appSwitcher?.map(app => app.code) ?? [];\r\n        const lstApiEndpoint = [];\r\n        const apiDomain = this._moduleConfigService.getConfig().environment.apiDomain;\r\n        for (const domainName in apiDomain) {\r\n            if (domainName.startsWith('-') || domainName.startsWith('1') || domainName == 'gateway') continue;\r\n            const realDomainName = domainName.split('Endpoint') ? domainName.split('Endpoint')[0] : domainName;\r\n            lstApiEndpoint.push(realDomainName.toUpperCase());\r\n        }\r\n        return this.clearPermissionCache([...lstAppCodes, ...lstApiEndpoint]);\r\n    }\r\n\r\n    clearPermissionCache(lstModule: string[]) {\r\n        const url = `${this.serviceUri}/ClearPermissionCache`;\r\n        return this.defaultPost(url, lstModule);\r\n    }\r\n\r\n    getCurrentUserPermission(): Promise<ResponseResult> {\r\n        const url = `${this.serviceUri}/GetCurrentUserPermission`;\r\n        return this.defaultGet(url);\r\n    }\r\n\r\n    async getAllBasePermission() {\r\n        const url = `${this.serviceUri}/GetAllBasePermission`;\r\n        const user = this._userService.getCurrentUser();\r\n        if (user\r\n            && (user.issuperuser && user.issuperuser.toLowerCase() == 'true')\r\n            || (user.isadmin && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin)) {\r\n            return;\r\n        }\r\n\r\n        const res = await this.defaultGet(url);\r\n        const lstAppCodes = this._moduleConfigService.getConfig().environment.appMetadata?.appSwitcher?.map(app => app.code) ?? [];\r\n        if (!res.success || res.data == null) {\r\n            const promiseArr: Promise<ResponseResult>[] = [];\r\n            for (const code in lstAppCodes) {\r\n                promiseArr.push(this.getPermissions(code));\r\n            }\r\n            await Promise.all(promiseArr);\r\n            return;\r\n        }\r\n\r\n        for (const service in lstAppCodes) {\r\n            const permissions = res.data[service] ?? [];\r\n            const key = `AUTHORIZATION.${service.toUpperCase()}`;\r\n            const storageItem = this.storage.getItem(key);\r\n            if (storageItem != null) {\r\n                this.storage.removeItem(key);\r\n            }\r\n            this.storage.setItem(key, JSON.stringify(permissions));\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Truyền vào danh sách permision cần check\r\n     * @param lstPermissionCode những perrmision code cần check => nên dùng trong trường hợp check các button trong code\r\n     * @returns trả ra các perrmisionCode có quyền\r\n     */\r\n    getPermissionAuthorized(lstPermissionCode: string[]): Promise<string[]> {\r\n        return new Promise(async (resolve, reject) => {\r\n            const user = (await this._userService.getCurrentUser()) as TnUser;\r\n            if (user && user.issuperuser.toLowerCase() == 'true') {\r\n                resolve(lstPermissionCode);\r\n                return;\r\n            }\r\n\r\n            if (user && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n                resolve(lstPermissionCode);\r\n                return;\r\n            }\r\n\r\n            const result = [];\r\n            for (const item of lstPermissionCode) {\r\n                if (await this.isAuthorizedPermission(item)) {\r\n                    result.push(item);\r\n                }\r\n            }\r\n\r\n            resolve(result);\r\n        });\r\n    }\r\n\r\n    isAuthorizedPermission(permission: string): Promise<boolean> {\r\n        return new Promise(async (resolve, reject) => {\r\n            let retryCount = 0;\r\n            while (!this._oauthService.hasValidAccessToken()) {\r\n                await this._commonService.delay(100);\r\n                retryCount++;\r\n                if (retryCount > 50) {\r\n                    break;\r\n                }\r\n            }\r\n            await this.checkPermission(this.appCode, permission, resolve, reject);\r\n        });\r\n    }\r\n\r\n    isAuthorized(service: string, permission: string, ignoreAdmin: boolean = false): Promise<boolean> {\r\n        this.root = this._appContext.getRootContext();\r\n        return new Promise(async (resolve, reject) => {\r\n            let retryCount = 0;\r\n            while (!this._oauthService.hasValidAccessToken()) {\r\n                await this._commonService.delay(100);\r\n                retryCount++;\r\n                if (retryCount > 50) {\r\n                    break;\r\n                }\r\n            }\r\n            await this.checkPermission(service, permission, resolve, reject);\r\n        });\r\n    }\r\n\r\n    async checkPermission(service, permission: string, resolve, reject) {\r\n        const user = (await this._userService.getCurrentUser()) as TnUser;\r\n        resolve(true);\r\n        return;\r\n        if (user && user.issuperuser && user.issuperuser.toLowerCase() == 'true') {\r\n            resolve(true);\r\n            return;\r\n        }\r\n\r\n        if (user && user.isadmin && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n            resolve(true);\r\n            return;\r\n        }\r\n\r\n        this.getPermissions(service).then(permissions => {\r\n            if (permissions && permissions.length) {\r\n                const isAuthorized = permissions.includes(permission);\r\n                resolve(isAuthorized);\r\n            }\r\n            else {\r\n                console.log(`Lỗi không lấy được permission cho module: ${service}`);\r\n                resolve(false);\r\n            }\r\n        }, error => {\r\n            reject(false);\r\n        });\r\n    }\r\n\r\n    isAuthorizedByPermissions(permissions: Array<Permission>, operator = 'OR', ignoreAdmin: boolean = false): Promise<boolean> {\r\n        return new Promise(async (resolve, reject) => {\r\n\r\n            const user = (await this._userService.getCurrentUser()) as TnUser;\r\n            if (user && user.issuperuser.toLowerCase() == 'true') {\r\n                resolve(true);\r\n                return;\r\n            }\r\n\r\n            if (user && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n                resolve(true);\r\n                return;\r\n            }\r\n\r\n            let isAuthorized = true;\r\n\r\n            if (operator.toUpperCase() == 'OR') {\r\n                isAuthorized = false;\r\n            }\r\n\r\n            await permissions.forEach(item => {\r\n                this.getPermissions(item.service).then(permissionResult => {\r\n                    if (operator.toUpperCase() == 'OR') {\r\n                        if (permissionResult.includes(item.permission)) {\r\n                            isAuthorized = true;\r\n                            return;\r\n                        }\r\n                    }\r\n                    else {\r\n                        if (!permissionResult.includes(item.permission)) {\r\n                            isAuthorized = false;\r\n                            return;\r\n                        }\r\n                    }\r\n                }, error => {\r\n                    reject(false);\r\n                });\r\n            });\r\n\r\n            resolve(isAuthorized);\r\n        });\r\n    }\r\n\r\n    getPermissions(service): Promise<any> {\r\n        return new Promise((resolve, reject) => {\r\n            const url = `${this.serviceUri}/GetPermissionsByService?service=${service}`;\r\n            const key = `AUTHORIZATION.${service.toUpperCase()}`;\r\n\r\n            const storageItem = this.storage.getItem(key);\r\n            if (storageItem && storageItem !== 'null' && storageItem !== 'undefined') {\r\n                const result = JSON.parse(storageItem);\r\n                resolve(result);\r\n            }\r\n            else {\r\n                this.defaultGet(url).then(response => {\r\n                    this.storage.setItem(key, JSON.stringify(response.data));\r\n                    resolve(response.data);\r\n                }, error => {\r\n                    reject();\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n    getPermissionIdsByModule(moduleCode: string) {\r\n        const url = `${this.serviceUri}/GetPermissionIdsByModule/${moduleCode}`;\r\n        return this.defaultGet(url);\r\n    }\r\n\r\n    phanQuyenNguoiDung(model: PhanQuyenModel) {\r\n        const url = `${this.serviceUri}/PhanQuyenNguoiDung`;\r\n        return this.defaultPost(url, model);\r\n    }\r\n}\r\n"]}
|
|
295
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission.service.js","sourceRoot":"../../../../projects/tnx-shared/src/lib/","sources":["services/permission.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable, Injector } from '@angular/core';\r\nimport { OAuthService } from 'angular-oauth2-oidc';\r\n\r\nimport { ApplicationContextService } from '../app-context/application-context.service';\r\nimport { ComponentContextService } from '../app-context/component-context.service';\r\nimport { Permission } from '../models/permission';\r\nimport { ResponseResult } from '../models/response-result';\r\nimport { TnUser } from '../models/tn-user';\r\nimport { BaseService } from './base.service';\r\nimport { ModuleConfigService } from './module-config.service';\r\nimport { UserService } from './user.service';\r\n\r\nexport class PhanQuyenModel {\r\n    subjectType: number;\r\n    idUserGroups?: string[];\r\n    idUsers?: string[];\r\n    addRoleIds?: string[] = [];\r\n    removeRoleIds?: string[] = [];\r\n    addPermissionIds?: string[] = [];\r\n    removePermissionIds?: string[] = [];\r\n\r\n    constructor(init: PhanQuyenModel) {\r\n        for (const key in init) {\r\n            this[key] = init[key];\r\n        }\r\n    }\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class PermissionService extends BaseService {\r\n\r\n    readonly storage = sessionStorage;\r\n    readonly _config: any;\r\n    readonly ignoreAdmin = false;\r\n    delayCheckPermissions = [];\r\n    root: ComponentContextService;\r\n    appCode: string = null;\r\n\r\n    constructor(\r\n        http: HttpClient,\r\n        injector: Injector,\r\n        private _moduleConfigService: ModuleConfigService,\r\n        private _userService: UserService,\r\n        private _oauthService: OAuthService,\r\n        private _appContext: ApplicationContextService\r\n    ) {\r\n        super(http, injector, `${_moduleConfigService.getConfig().environment.apiDomain.authorizationEndpoint}/${_moduleConfigService.getConfig().environment.apiVersion}/permission`);\r\n        this._config = this._moduleConfigService.getConfig();\r\n        this.endPoint = this._config.environment.apiDomain.authorizationEndpoint;\r\n        this.ignoreAdmin = this._config.environment.isIgnoreAdmin;\r\n        this.appCode = this._config.appCode;\r\n    }\r\n\r\n    clearPermissionCacheAll() {\r\n        const lstAppCodes = this._config.environment.appMetadata?.appSwitcher?.map(app => app.code) ?? [];\r\n        const lstApiEndpoint = [];\r\n        const apiDomain = this._config.environment.apiDomain;\r\n        for (const domainName in apiDomain) {\r\n            if (domainName.startsWith('-') || domainName.startsWith('1') || domainName == 'gateway') continue;\r\n            const realDomainName = domainName.split('Endpoint') ? domainName.split('Endpoint')[0] : domainName;\r\n            lstApiEndpoint.push(realDomainName.toUpperCase());\r\n        }\r\n        return this.clearPermissionCache([...lstAppCodes, ...lstApiEndpoint]);\r\n    }\r\n\r\n    clearPermissionCache(lstModule: string[]) {\r\n        const url = `${this.serviceUri}/ClearPermissionCache`;\r\n        return this.defaultPost(url, lstModule);\r\n    }\r\n\r\n    getCurrentUserPermission(): Promise<ResponseResult> {\r\n        const url = `${this.serviceUri}/GetCurrentUserPermission`;\r\n        return this.defaultGet(url);\r\n    }\r\n\r\n    async getAllBasePermission(userId?: string) {\r\n        let url = `${this.serviceUri}/GetAllBasePermission`;\r\n        const user = this._userService.getCurrentUser();\r\n        if (user\r\n            && (user.issuperuser && user.issuperuser.toLowerCase() == 'true')\r\n            || (user.isadmin && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin)) {\r\n            return;\r\n        }\r\n        if (userId && userId != '' && userId != this._commonService.guidEmpty()) {\r\n            url += `?userId=${userId}`;\r\n            return this.defaultGet(url);\r\n        }\r\n        const res = await this.defaultGet(url);\r\n        const lstAppCodes = this._config.environment.appMetadata?.appSwitcher?.map(app => app.code) ?? [];\r\n        if (!res.success || res.data == null) {\r\n            const promiseArr: Promise<ResponseResult>[] = [];\r\n            for (const code in lstAppCodes) {\r\n                promiseArr.push(this.getPermissions(code));\r\n\r\n            }\r\n            await Promise.all(promiseArr);\r\n            return;\r\n        }\r\n\r\n        for (const service in lstAppCodes) {\r\n            const permissions = res.data[service] ?? [];\r\n            const key = `AUTHORIZATION.${service.toUpperCase()}`;\r\n            const storageItem = this.storage.getItem(key);\r\n            if (storageItem != null) {\r\n                this.storage.removeItem(key);\r\n            }\r\n            this.storage.setItem(key, JSON.stringify(permissions));\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Truyền vào danh sách permision cần check\r\n     * @param lstPermissionCode những perrmision code cần check => nên dùng trong trường hợp check các button trong code\r\n     * @returns trả ra các perrmisionCode có quyền\r\n     */\r\n    getPermissionAuthorized(lstPermissionCode: string[]): Promise<string[]> {\r\n        return new Promise(async (resolve, reject) => {\r\n            const user = (await this._userService.getCurrentUser()) as TnUser;\r\n            if (user && user.issuperuser.toLowerCase() == 'true') {\r\n                resolve(lstPermissionCode);\r\n                return;\r\n            }\r\n\r\n            if (user && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n                resolve(lstPermissionCode);\r\n                return;\r\n            }\r\n\r\n            const result = [];\r\n            for (const item of lstPermissionCode) {\r\n                if (await this.isAuthorizedPermission(item)) {\r\n                    result.push(item);\r\n                }\r\n            }\r\n\r\n            resolve(result);\r\n        });\r\n    }\r\n\r\n    isAuthorizedPermission(permission: string): Promise<boolean> {\r\n        return new Promise(async (resolve, reject) => {\r\n            let retryCount = 0;\r\n            while (!this._oauthService.hasValidAccessToken()) {\r\n                await this._commonService.delay(100);\r\n                retryCount++;\r\n                if (retryCount > 50) {\r\n                    break;\r\n                }\r\n            }\r\n            await this.checkPermission(this.appCode, permission, resolve, reject);\r\n        });\r\n    }\r\n\r\n    isAuthorized(service: string, permission: string, ignoreAdmin: boolean = false): Promise<boolean> {\r\n        this.root = this._appContext.getRootContext();\r\n        return new Promise(async (resolve, reject) => {\r\n            let retryCount = 0;\r\n            while (!this._oauthService.hasValidAccessToken()) {\r\n                await this._commonService.delay(100);\r\n                retryCount++;\r\n                if (retryCount > 50) {\r\n                    break;\r\n                }\r\n            }\r\n            await this.checkPermission(service, permission, resolve, reject);\r\n        });\r\n    }\r\n\r\n    async checkPermission(service, permissionToCheck: string, resolve, reject) {\r\n        const user = (await this._userService.getCurrentUser()) as TnUser;\r\n\r\n        if (user && user.issuperuser && user.issuperuser.toLowerCase() == 'true') {\r\n            resolve(true);\r\n            return;\r\n        }\r\n\r\n        if (user && user.isadmin && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n            resolve(true);\r\n            return;\r\n        }\r\n\r\n        this.getPermissions(service).then(userPermissions => {\r\n            if (userPermissions && userPermissions.length) {\r\n                resolve(this._checkPermission(userPermissions, permissionToCheck));\r\n            }\r\n            else {\r\n                console.log(`Không có quyền với phân hệ [${service}]`);\r\n                resolve(false);\r\n            }\r\n        }, error => {\r\n            reject(false);\r\n            console.log(`Lỗi không lấy được permission cho module: ${service}`);\r\n        });\r\n    }\r\n\r\n    _checkPermission(userPermissions: string[], permissionToCheck: string) {\r\n        let isAuthorized = false;\r\n        // check quyền theo cách cũ nếu trường họp là phân quyền module\r\n        if (permissionToCheck.includes('MODULE')) {\r\n            return userPermissions.includes(permissionToCheck);\r\n        }\r\n        for (const userPermission of userPermissions) {\r\n            // Cắt chuỗi permission thành mảng để xem mỗi fragement có khớp nhau không\r\n            const userPermissionFragments = (userPermission as string).split('/');\r\n            const permissionFragements = permissionToCheck.split('/');\r\n\r\n            // Mảng khác độ dài thì thoát sớm\r\n            if (userPermissionFragments.length != permissionFragements.length) {\r\n                continue;\r\n            }\r\n\r\n            // biến flag ra hiệu người dùng authorized và out vòng\r\n            let breakLoop = false;\r\n            // nếu tất cả phần tử khớp nhau => permission này trùng và người dùng được authorized\r\n            for (let index = 0; index < permissionFragements.length; index++) {\r\n                const userFragement = userPermissionFragments[index];\r\n                const permissionFragment = permissionFragements[index];\r\n                // skip qua các phần tử có ký tự bắt đầu là '{'\r\n                if (userFragement[0] == '{') {\r\n                    if (index == permissionFragements.length - 1) {\r\n                        isAuthorized = true;\r\n                        breakLoop = true;\r\n                    }\r\n                    continue;\r\n                }\r\n                if (userFragement.toLowerCase() != permissionFragment.toLowerCase()) {\r\n                    break;\r\n                }\r\n                if (index == permissionFragements.length - 1) {\r\n                    isAuthorized = true;\r\n                    breakLoop = true;\r\n                }\r\n            }\r\n            if (breakLoop) {\r\n                break;\r\n            }\r\n        }\r\n        return isAuthorized;\r\n    }\r\n\r\n    isAuthorizedByPermissions(permissions: Array<Permission>, operator = 'OR', ignoreAdmin: boolean = false): Promise<boolean> {\r\n        return new Promise(async (resolve, reject) => {\r\n\r\n            const user = (await this._userService.getCurrentUser()) as TnUser;\r\n            if (user && user.issuperuser.toLowerCase() == 'true') {\r\n                resolve(true);\r\n                return;\r\n            }\r\n\r\n            if (user && user.isadmin.toLowerCase() == 'true' && !this.ignoreAdmin) {\r\n                resolve(true);\r\n                return;\r\n            }\r\n\r\n            let isAuthorized = true;\r\n\r\n            if (operator.toUpperCase() == 'OR') {\r\n                isAuthorized = false;\r\n            }\r\n\r\n            await permissions.forEach(item => {\r\n                this.getPermissions(item.service).then(permissionResult => {\r\n                    if (operator.toUpperCase() == 'OR') {\r\n                        if (permissionResult.includes(item.permission)) {\r\n                            isAuthorized = true;\r\n                            return;\r\n                        }\r\n                    }\r\n                    else {\r\n                        if (!permissionResult.includes(item.permission)) {\r\n                            isAuthorized = false;\r\n                            return;\r\n                        }\r\n                    }\r\n                }, error => {\r\n                    reject(false);\r\n                });\r\n            });\r\n\r\n            resolve(isAuthorized);\r\n        });\r\n    }\r\n\r\n    getPermissions(service): Promise<any> {\r\n        return new Promise((resolve, reject) => {\r\n            const url = `${this.serviceUri}/GetPermissionsByService?service=${service}`;\r\n            const key = `AUTHORIZATION.${service.toUpperCase()}`;\r\n\r\n            const storageItem = this.storage.getItem(key);\r\n            if (storageItem && storageItem !== 'null' && storageItem !== 'undefined') {\r\n                const result = JSON.parse(storageItem);\r\n                resolve(result);\r\n            }\r\n            else {\r\n                this.defaultGet(url).then(response => {\r\n                    this.storage.setItem(key, JSON.stringify(response.data));\r\n                    resolve(response.data);\r\n                }, error => {\r\n                    reject();\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n    getPermissionIdsByModule(moduleCode: string) {\r\n        const url = `${this.serviceUri}/GetPermissionIdsByModule/${moduleCode}`;\r\n        return this.defaultGet(url);\r\n    }\r\n\r\n    phanQuyenNguoiDung(model: PhanQuyenModel) {\r\n        const url = `${this.serviceUri}/PhanQuyenNguoiDung`;\r\n        return this.defaultPost(url, model);\r\n    }\r\n}\r\n"]}
|
|
@@ -11,6 +11,34 @@ export class RoleService extends BaseService {
|
|
|
11
11
|
this.endPoint = _moduleConfigService.getConfig().environment.apiDomain.authorizationEndpoint;
|
|
12
12
|
this._moduleConfig = _moduleConfigService.getConfig();
|
|
13
13
|
}
|
|
14
|
+
getDetailCustom(id, pid) {
|
|
15
|
+
const url = `${this.serviceUri}/GetDetailCustom/${id}?pid=${pid}`;
|
|
16
|
+
return this.defaultGet(url);
|
|
17
|
+
}
|
|
18
|
+
GetIdByUsers(model) {
|
|
19
|
+
const url = `${this.serviceUri}/GetIdByUsers`;
|
|
20
|
+
return this.defaultPost(url, model);
|
|
21
|
+
}
|
|
22
|
+
GetIdByGroupUsers(model) {
|
|
23
|
+
const url = `${this.serviceUri}/GetIdByGroupUsers`;
|
|
24
|
+
return this.defaultPost(url, model);
|
|
25
|
+
}
|
|
26
|
+
GetIntersectIdByGroupUsers(userIds) {
|
|
27
|
+
const url = `${this.serviceUri}/GetIntersectIdByGroupUsers`;
|
|
28
|
+
return this.defaultPost(url, userIds);
|
|
29
|
+
}
|
|
30
|
+
GetIntersectDirectIdByGroupUsers(userIds) {
|
|
31
|
+
const url = `${this.serviceUri}/GetIntersectDirectIdByGroupUsers`;
|
|
32
|
+
return this.defaultPost(url, userIds);
|
|
33
|
+
}
|
|
34
|
+
GetIntersectIdByUsers(userIds) {
|
|
35
|
+
const url = `${this.serviceUri}/GetIntersectIdByUsers`;
|
|
36
|
+
return this.defaultPost(url, userIds);
|
|
37
|
+
}
|
|
38
|
+
GetIntersectDirectIdByUsers(userIds) {
|
|
39
|
+
const url = `${this.serviceUri}/GetIntersectDirectIdByUsers`;
|
|
40
|
+
return this.defaultPost(url, userIds);
|
|
41
|
+
}
|
|
14
42
|
}
|
|
15
43
|
RoleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RoleService_Factory() { return new RoleService(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i2.ModuleConfigService)); }, token: RoleService, providedIn: "root" });
|
|
16
44
|
RoleService.decorators = [
|
|
@@ -23,4 +51,4 @@ RoleService.ctorParameters = () => [
|
|
|
23
51
|
{ type: Injector },
|
|
24
52
|
{ type: ModuleConfigService }
|
|
25
53
|
];
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uL3Byb2plY3RzL3RueC1zaGFyZWQvc3JjL2xpYi8iLCJzb3VyY2VzIjpbInNlcnZpY2VzL3JvbGUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7O0FBSzlELE1BQU0sT0FBTyxXQUFZLFNBQVEsV0FBVztJQUd4QyxZQUNJLElBQWdCLEVBQ2hCLFFBQWtCLEVBQ2xCLG9CQUF5QztRQUV6QyxLQUFLLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRSxHQUFHLG9CQUFvQixDQUFDLFNBQVMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMscUJBQXFCLElBQUksb0JBQW9CLENBQUMsU0FBUyxFQUFFLENBQUMsV0FBVyxDQUFDLFVBQVUsT0FBTyxDQUFDLENBQUM7UUFDekssSUFBSSxDQUFDLFFBQVEsR0FBRyxvQkFBb0IsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLHFCQUFxQixDQUFDO1FBQzdGLElBQUksQ0FBQyxhQUFhLEdBQUcsb0JBQW9CLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDMUQsQ0FBQztJQUdELGVBQWUsQ0FBQyxFQUFVLEVBQUUsR0FBVztRQUNuQyxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxVQUFVLG9CQUFvQixFQUFFLFFBQVEsR0FBRyxFQUFFLENBQUM7UUFDbEUsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxZQUFZLENBQUMsS0FBSztRQUNkLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsZUFBZSxDQUFDO1FBQzlDLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQUs7UUFDbkIsTUFBTSxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSxvQkFBb0IsQ0FBQztRQUNuRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCwwQkFBMEIsQ0FBQyxPQUFPO1FBQzlCLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsNkJBQTZCLENBQUM7UUFDNUQsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsZ0NBQWdDLENBQUMsT0FBTztRQUNwQyxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxVQUFVLG1DQUFtQyxDQUFDO1FBQ2xFLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELHFCQUFxQixDQUFDLE9BQU87UUFDekIsTUFBTSxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSx3QkFBd0IsQ0FBQztRQUN2RCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCwyQkFBMkIsQ0FBQyxPQUFPO1FBQy9CLE1BQU0sR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsOEJBQThCLENBQUM7UUFDN0QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMxQyxDQUFDOzs7O1lBbERKLFVBQVUsU0FBQztnQkFDUixVQUFVLEVBQUUsTUFBTTthQUNyQjs7O1lBUlEsVUFBVTtZQUNFLFFBQVE7WUFHcEIsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTW9kdWxlQ29uZmlnIH0gZnJvbSAnLi4vY29uZmlncy9tb2R1bGUtY29uZmlnJztcclxuaW1wb3J0IHsgQmFzZVNlcnZpY2UgfSBmcm9tICcuL2Jhc2Uuc2VydmljZSc7XHJcbmltcG9ydCB7IE1vZHVsZUNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuL21vZHVsZS1jb25maWcuc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJvbGVTZXJ2aWNlIGV4dGVuZHMgQmFzZVNlcnZpY2Uge1xyXG4gICAgcmVhZG9ubHkgX21vZHVsZUNvbmZpZzogTW9kdWxlQ29uZmlnO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIGh0dHA6IEh0dHBDbGllbnQsXHJcbiAgICAgICAgaW5qZWN0b3I6IEluamVjdG9yLFxyXG4gICAgICAgIF9tb2R1bGVDb25maWdTZXJ2aWNlOiBNb2R1bGVDb25maWdTZXJ2aWNlXHJcbiAgICApIHtcclxuICAgICAgICBzdXBlcihodHRwLCBpbmplY3RvciwgYCR7X21vZHVsZUNvbmZpZ1NlcnZpY2UuZ2V0Q29uZmlnKCkuZW52aXJvbm1lbnQuYXBpRG9tYWluLmF1dGhvcml6YXRpb25FbmRwb2ludH0vJHtfbW9kdWxlQ29uZmlnU2VydmljZS5nZXRDb25maWcoKS5lbnZpcm9ubWVudC5hcGlWZXJzaW9ufS9yb2xlYCk7XHJcbiAgICAgICAgdGhpcy5lbmRQb2ludCA9IF9tb2R1bGVDb25maWdTZXJ2aWNlLmdldENvbmZpZygpLmVudmlyb25tZW50LmFwaURvbWFpbi5hdXRob3JpemF0aW9uRW5kcG9pbnQ7XHJcbiAgICAgICAgdGhpcy5fbW9kdWxlQ29uZmlnID0gX21vZHVsZUNvbmZpZ1NlcnZpY2UuZ2V0Q29uZmlnKCk7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGdldERldGFpbEN1c3RvbShpZDogc3RyaW5nLCBwaWQ6IHN0cmluZykge1xyXG4gICAgICAgIGNvbnN0IHVybCA9IGAke3RoaXMuc2VydmljZVVyaX0vR2V0RGV0YWlsQ3VzdG9tLyR7aWR9P3BpZD0ke3BpZH1gO1xyXG4gICAgICAgIHJldHVybiB0aGlzLmRlZmF1bHRHZXQodXJsKTtcclxuICAgIH1cclxuXHJcbiAgICBHZXRJZEJ5VXNlcnMobW9kZWwpIHtcclxuICAgICAgICBjb25zdCB1cmwgPSBgJHt0aGlzLnNlcnZpY2VVcml9L0dldElkQnlVc2Vyc2A7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuZGVmYXVsdFBvc3QodXJsLCBtb2RlbCk7XHJcbiAgICB9XHJcblxyXG4gICAgR2V0SWRCeUdyb3VwVXNlcnMobW9kZWwpIHtcclxuICAgICAgICBjb25zdCB1cmwgPSBgJHt0aGlzLnNlcnZpY2VVcml9L0dldElkQnlHcm91cFVzZXJzYDtcclxuICAgICAgICByZXR1cm4gdGhpcy5kZWZhdWx0UG9zdCh1cmwsIG1vZGVsKTtcclxuICAgIH1cclxuXHJcbiAgICBHZXRJbnRlcnNlY3RJZEJ5R3JvdXBVc2Vycyh1c2VySWRzKSB7XHJcbiAgICAgICAgY29uc3QgdXJsID0gYCR7dGhpcy5zZXJ2aWNlVXJpfS9HZXRJbnRlcnNlY3RJZEJ5R3JvdXBVc2Vyc2A7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuZGVmYXVsdFBvc3QodXJsLCB1c2VySWRzKTtcclxuICAgIH1cclxuXHJcbiAgICBHZXRJbnRlcnNlY3REaXJlY3RJZEJ5R3JvdXBVc2Vycyh1c2VySWRzKSB7XHJcbiAgICAgICAgY29uc3QgdXJsID0gYCR7dGhpcy5zZXJ2aWNlVXJpfS9HZXRJbnRlcnNlY3REaXJlY3RJZEJ5R3JvdXBVc2Vyc2A7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuZGVmYXVsdFBvc3QodXJsLCB1c2VySWRzKTtcclxuICAgIH1cclxuXHJcbiAgICBHZXRJbnRlcnNlY3RJZEJ5VXNlcnModXNlcklkcykge1xyXG4gICAgICAgIGNvbnN0IHVybCA9IGAke3RoaXMuc2VydmljZVVyaX0vR2V0SW50ZXJzZWN0SWRCeVVzZXJzYDtcclxuICAgICAgICByZXR1cm4gdGhpcy5kZWZhdWx0UG9zdCh1cmwsIHVzZXJJZHMpO1xyXG4gICAgfVxyXG5cclxuICAgIEdldEludGVyc2VjdERpcmVjdElkQnlVc2Vycyh1c2VySWRzKSB7XHJcbiAgICAgICAgY29uc3QgdXJsID0gYCR7dGhpcy5zZXJ2aWNlVXJpfS9HZXRJbnRlcnNlY3REaXJlY3RJZEJ5VXNlcnNgO1xyXG4gICAgICAgIHJldHVybiB0aGlzLmRlZmF1bHRQb3N0KHVybCwgdXNlcklkcyk7XHJcbiAgICB9XHJcbn1cclxuIl19
|