@ruiapp/rapid-core 0.1.77 → 0.1.78
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/dist/index.js +7 -3
- package/package.json +1 -1
- package/rollup.config.js +16 -16
- package/src/core/actionHandler.ts +22 -22
- package/src/core/eventManager.ts +20 -20
- package/src/core/facility.ts +7 -7
- package/src/core/http/formDataParser.ts +89 -89
- package/src/core/pluginManager.ts +175 -175
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +86 -86
- package/src/core/response.ts +76 -76
- package/src/core/routeContext.ts +43 -43
- package/src/core/routesBuilder.ts +88 -88
- package/src/dataAccess/dataAccessor.ts +137 -137
- package/src/dataAccess/entityManager.ts +4 -0
- package/src/deno-std/datetime/to_imf.ts +32 -32
- package/src/deno-std/encoding/base64.ts +141 -141
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/index.ts +44 -44
- package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
- package/src/plugins/auth/actionHandlers/createSession.ts +63 -63
- package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
- package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
- package/src/plugins/auth/actionHandlers/index.ts +8 -8
- package/src/plugins/auth/actionHandlers/resetPassword.ts +38 -38
- package/src/plugins/auth/models/AccessToken.ts +56 -56
- package/src/plugins/auth/models/index.ts +3 -3
- package/src/plugins/auth/routes/changePassword.ts +15 -15
- package/src/plugins/auth/routes/getMyProfile.ts +15 -15
- package/src/plugins/auth/routes/index.ts +7 -7
- package/src/plugins/auth/routes/resetPassword.ts +15 -15
- package/src/plugins/auth/routes/signin.ts +15 -15
- package/src/plugins/auth/routes/signout.ts +15 -15
- package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
- package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
- package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
- package/src/plugins/cronJob/routes/index.ts +3 -3
- package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +26 -26
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +21 -21
- package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +35 -35
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +36 -36
- package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
- package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
- package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
- package/src/plugins/fileManage/routes/index.ts +5 -5
- package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
- package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
- package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/sequence/SequenceService.ts +81 -81
- package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
- package/src/plugins/sequence/actionHandlers/index.ts +4 -4
- package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
- package/src/plugins/sequence/models/SequenceRule.ts +42 -42
- package/src/plugins/sequence/models/index.ts +4 -4
- package/src/plugins/sequence/routes/generateSn.ts +15 -15
- package/src/plugins/sequence/routes/index.ts +3 -3
- package/src/plugins/sequence/segment-utility.ts +11 -11
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
- package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
- package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
- package/src/plugins/setting/SettingService.ts +213 -213
- package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
- package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
- package/src/plugins/setting/actionHandlers/index.ts +6 -6
- package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
- package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/SystemSettingItem.ts +42 -42
- package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/UserSettingItem.ts +49 -49
- package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/index.ts +8 -8
- package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
- package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
- package/src/plugins/setting/routes/index.ts +5 -5
- package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
- package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +51 -51
- package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
- package/src/plugins/stateMachine/models/index.ts +3 -3
- package/src/plugins/stateMachine/routes/index.ts +3 -3
- package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
- package/src/polyfill.ts +5 -5
- package/src/proxy/mod.ts +38 -38
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/fsUtility.ts +61 -61
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/timeUtility.ts +9 -9
- package/tsconfig.json +19 -19
|
@@ -1,91 +1,91 @@
|
|
|
1
|
-
import type { RpdApplicationConfig, RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
import pluginActionHandlers from "./actionHandlers";
|
|
4
|
-
import { ServerOperation, ServerOperationPluginInitOptions } from "./ServerOperationPluginTypes";
|
|
5
|
-
import {
|
|
6
|
-
IRpdServer,
|
|
7
|
-
RapidPlugin,
|
|
8
|
-
RpdConfigurationItemOptions,
|
|
9
|
-
RpdServerPluginConfigurableTargetOptions,
|
|
10
|
-
RpdServerPluginExtendingAbilities,
|
|
11
|
-
} from "~/core/server";
|
|
12
|
-
|
|
13
|
-
class ServerOperationPlugin implements RapidPlugin {
|
|
14
|
-
#operations: ServerOperation[];
|
|
15
|
-
|
|
16
|
-
constructor(options: ServerOperationPluginInitOptions) {
|
|
17
|
-
this.#operations = options.operations || [];
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
get code(): string {
|
|
21
|
-
return "serverOperation";
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
get description(): string {
|
|
25
|
-
return "";
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
29
|
-
return [];
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
33
|
-
return [];
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
get configurations(): RpdConfigurationItemOptions[] {
|
|
37
|
-
return [];
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
async initPlugin(server: IRpdServer): Promise<any> {}
|
|
41
|
-
|
|
42
|
-
async registerMiddlewares(server: IRpdServer): Promise<any> {}
|
|
43
|
-
|
|
44
|
-
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
45
|
-
for (const actionHandler of pluginActionHandlers) {
|
|
46
|
-
server.registerActionHandler(this, actionHandler);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
async registerEventHandlers(server: IRpdServer): Promise<any> {}
|
|
51
|
-
|
|
52
|
-
async registerMessageHandlers(server: IRpdServer): Promise<any> {}
|
|
53
|
-
|
|
54
|
-
async registerTaskProcessors(server: IRpdServer): Promise<any> {}
|
|
55
|
-
|
|
56
|
-
async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
57
|
-
|
|
58
|
-
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
59
|
-
|
|
60
|
-
async configureModelProperties(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
61
|
-
|
|
62
|
-
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
63
|
-
const routes: RpdRoute[] = [];
|
|
64
|
-
for (const operation of this.#operations) {
|
|
65
|
-
routes.push({
|
|
66
|
-
namespace: "app",
|
|
67
|
-
name: `app.operations.${operation.code}`,
|
|
68
|
-
code: `app.operations.${operation.code}`,
|
|
69
|
-
type: "RESTful",
|
|
70
|
-
method: operation.method,
|
|
71
|
-
endpoint: `/app/${operation.code}`,
|
|
72
|
-
actions: [
|
|
73
|
-
{
|
|
74
|
-
code: "runServerOperation",
|
|
75
|
-
config: {
|
|
76
|
-
operation: operation.handler,
|
|
77
|
-
permissionCheck: operation.permissionCheck,
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
],
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
server.appendApplicationConfig({ routes });
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
87
|
-
|
|
88
|
-
async onApplicationReady(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
export default ServerOperationPlugin;
|
|
1
|
+
import type { RpdApplicationConfig, RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
import pluginActionHandlers from "./actionHandlers";
|
|
4
|
+
import { ServerOperation, ServerOperationPluginInitOptions } from "./ServerOperationPluginTypes";
|
|
5
|
+
import {
|
|
6
|
+
IRpdServer,
|
|
7
|
+
RapidPlugin,
|
|
8
|
+
RpdConfigurationItemOptions,
|
|
9
|
+
RpdServerPluginConfigurableTargetOptions,
|
|
10
|
+
RpdServerPluginExtendingAbilities,
|
|
11
|
+
} from "~/core/server";
|
|
12
|
+
|
|
13
|
+
class ServerOperationPlugin implements RapidPlugin {
|
|
14
|
+
#operations: ServerOperation[];
|
|
15
|
+
|
|
16
|
+
constructor(options: ServerOperationPluginInitOptions) {
|
|
17
|
+
this.#operations = options.operations || [];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
get code(): string {
|
|
21
|
+
return "serverOperation";
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
get description(): string {
|
|
25
|
+
return "";
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
29
|
+
return [];
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
33
|
+
return [];
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
get configurations(): RpdConfigurationItemOptions[] {
|
|
37
|
+
return [];
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async initPlugin(server: IRpdServer): Promise<any> {}
|
|
41
|
+
|
|
42
|
+
async registerMiddlewares(server: IRpdServer): Promise<any> {}
|
|
43
|
+
|
|
44
|
+
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
45
|
+
for (const actionHandler of pluginActionHandlers) {
|
|
46
|
+
server.registerActionHandler(this, actionHandler);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async registerEventHandlers(server: IRpdServer): Promise<any> {}
|
|
51
|
+
|
|
52
|
+
async registerMessageHandlers(server: IRpdServer): Promise<any> {}
|
|
53
|
+
|
|
54
|
+
async registerTaskProcessors(server: IRpdServer): Promise<any> {}
|
|
55
|
+
|
|
56
|
+
async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
57
|
+
|
|
58
|
+
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
59
|
+
|
|
60
|
+
async configureModelProperties(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
61
|
+
|
|
62
|
+
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
63
|
+
const routes: RpdRoute[] = [];
|
|
64
|
+
for (const operation of this.#operations) {
|
|
65
|
+
routes.push({
|
|
66
|
+
namespace: "app",
|
|
67
|
+
name: `app.operations.${operation.code}`,
|
|
68
|
+
code: `app.operations.${operation.code}`,
|
|
69
|
+
type: "RESTful",
|
|
70
|
+
method: operation.method,
|
|
71
|
+
endpoint: `/app/${operation.code}`,
|
|
72
|
+
actions: [
|
|
73
|
+
{
|
|
74
|
+
code: "runServerOperation",
|
|
75
|
+
config: {
|
|
76
|
+
operation: operation.handler,
|
|
77
|
+
permissionCheck: operation.permissionCheck,
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
],
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
server.appendApplicationConfig({ routes });
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
87
|
+
|
|
88
|
+
async onApplicationReady(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
export default ServerOperationPlugin;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RpdHttpMethod } from "~/types";
|
|
3
|
-
import { PermissionCheckPolicy } from "~/utilities/accessControlUtility";
|
|
4
|
-
|
|
5
|
-
export interface ServerOperation {
|
|
6
|
-
code: string;
|
|
7
|
-
description?: string;
|
|
8
|
-
method: RpdHttpMethod;
|
|
9
|
-
permissionCheck?: PermissionCheckPolicy;
|
|
10
|
-
handler: (ctx: ActionHandlerContext) => Promise<void>;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export interface ServerOperationPluginInitOptions {
|
|
14
|
-
operations: ServerOperation[];
|
|
15
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RpdHttpMethod } from "~/types";
|
|
3
|
+
import { PermissionCheckPolicy } from "~/utilities/accessControlUtility";
|
|
4
|
+
|
|
5
|
+
export interface ServerOperation {
|
|
6
|
+
code: string;
|
|
7
|
+
description?: string;
|
|
8
|
+
method: RpdHttpMethod;
|
|
9
|
+
permissionCheck?: PermissionCheckPolicy;
|
|
10
|
+
handler: (ctx: ActionHandlerContext) => Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export interface ServerOperationPluginInitOptions {
|
|
14
|
+
operations: ServerOperation[];
|
|
15
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
-
import * as runServerOperation from "./runServerOperation";
|
|
3
|
-
|
|
4
|
-
export default [runServerOperation] satisfies IPluginActionHandler[];
|
|
1
|
+
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
+
import * as runServerOperation from "./runServerOperation";
|
|
3
|
+
|
|
4
|
+
export default [runServerOperation] satisfies IPluginActionHandler[];
|
|
@@ -1,213 +1,213 @@
|
|
|
1
|
-
import { IRpdServer } from "~/core/server";
|
|
2
|
-
import EntityManager from "~/dataAccess/entityManager";
|
|
3
|
-
import { SystemSettingItem, UserSettingItem } from "./SettingPluginTypes";
|
|
4
|
-
|
|
5
|
-
export interface GetSystemSettingValuesInput {
|
|
6
|
-
groupCode: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export interface SetSystemSettingValuesInput {
|
|
10
|
-
groupCode: string;
|
|
11
|
-
values: Record<string, any>;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export interface GetUserSettingValuesInput {
|
|
15
|
-
groupCode: string;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export default class SettingService {
|
|
19
|
-
#server: IRpdServer;
|
|
20
|
-
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
21
|
-
#userSettingItemManager: EntityManager<UserSettingItem>;
|
|
22
|
-
|
|
23
|
-
constructor(server: IRpdServer) {
|
|
24
|
-
this.#server = server;
|
|
25
|
-
|
|
26
|
-
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
27
|
-
this.#userSettingItemManager = server.getEntityManager("user_setting_item");
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
//#region System Setting
|
|
31
|
-
async getSystemSettingItems(groupCode: string): Promise<SystemSettingItem[]> {
|
|
32
|
-
return await this.#systemSettingItemManager.findEntities({
|
|
33
|
-
filters: [
|
|
34
|
-
{
|
|
35
|
-
operator: "eq",
|
|
36
|
-
field: "groupCode",
|
|
37
|
-
value: groupCode,
|
|
38
|
-
},
|
|
39
|
-
],
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
async getSystemSettingValues(groupCode: string): Promise<Record<string, any>> {
|
|
44
|
-
const settingItems = await this.getSystemSettingItems(groupCode);
|
|
45
|
-
|
|
46
|
-
return settingItems.reduce<Record<string, any>>((settingValues, settingItem) => {
|
|
47
|
-
settingValues[settingItem.itemCode] = settingItem.value;
|
|
48
|
-
return settingValues;
|
|
49
|
-
}, {});
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
async getSystemSettingValue(groupCode: string, itemCode: string): Promise<any> {
|
|
53
|
-
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
54
|
-
filters: [
|
|
55
|
-
{
|
|
56
|
-
operator: "eq",
|
|
57
|
-
field: "groupCode",
|
|
58
|
-
value: groupCode,
|
|
59
|
-
},
|
|
60
|
-
{
|
|
61
|
-
operator: "eq",
|
|
62
|
-
field: "itemCode",
|
|
63
|
-
value: itemCode,
|
|
64
|
-
},
|
|
65
|
-
],
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
return settingItem ? settingItem.value : null;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
async setSystemSettingValue(groupCode: string, itemCode: string, value: any) {
|
|
72
|
-
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
73
|
-
filters: [
|
|
74
|
-
{
|
|
75
|
-
operator: "eq",
|
|
76
|
-
field: "groupCode",
|
|
77
|
-
value: groupCode,
|
|
78
|
-
},
|
|
79
|
-
{
|
|
80
|
-
operator: "eq",
|
|
81
|
-
field: "itemCode",
|
|
82
|
-
value: itemCode,
|
|
83
|
-
},
|
|
84
|
-
],
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
if (settingItem) {
|
|
88
|
-
if (settingItem.value !== value) {
|
|
89
|
-
await this.#systemSettingItemManager.updateEntityById({
|
|
90
|
-
id: settingItem.id,
|
|
91
|
-
entityToSave: {
|
|
92
|
-
value,
|
|
93
|
-
},
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
} else {
|
|
97
|
-
await this.#systemSettingItemManager.createEntity({
|
|
98
|
-
entity: {
|
|
99
|
-
groupCode,
|
|
100
|
-
itemCode,
|
|
101
|
-
value,
|
|
102
|
-
} as Partial<SystemSettingItem>,
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
async setSystemSettingValues(groupCode: string, settingValues: Record<string, any>) {
|
|
108
|
-
for (const itemCode in settingValues) {
|
|
109
|
-
const value = settingValues[itemCode];
|
|
110
|
-
await this.setSystemSettingValue(groupCode, itemCode, value);
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
//#endregion
|
|
114
|
-
|
|
115
|
-
//#region User Setting
|
|
116
|
-
async getUserSettingItems(ownerId: number, groupCode: string): Promise<UserSettingItem[]> {
|
|
117
|
-
return await this.#userSettingItemManager.findEntities({
|
|
118
|
-
filters: [
|
|
119
|
-
{
|
|
120
|
-
operator: "eq",
|
|
121
|
-
field: "ownerId",
|
|
122
|
-
value: ownerId,
|
|
123
|
-
},
|
|
124
|
-
{
|
|
125
|
-
operator: "eq",
|
|
126
|
-
field: "groupCode",
|
|
127
|
-
value: groupCode,
|
|
128
|
-
},
|
|
129
|
-
],
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
async getUserSettingValues(ownerId: number, groupCode: string): Promise<Record<string, any>> {
|
|
134
|
-
const settingItems = await this.getUserSettingItems(ownerId, groupCode);
|
|
135
|
-
|
|
136
|
-
return settingItems.reduce<Record<string, any>>((settingValues, settingItem) => {
|
|
137
|
-
settingValues[settingItem.itemCode] = settingItem.value;
|
|
138
|
-
return settingValues;
|
|
139
|
-
}, {});
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
async getUserSettingValue(ownerId: number, groupCode: string, itemCode: string): Promise<any> {
|
|
143
|
-
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
144
|
-
filters: [
|
|
145
|
-
{
|
|
146
|
-
operator: "eq",
|
|
147
|
-
field: "ownerId",
|
|
148
|
-
value: ownerId,
|
|
149
|
-
},
|
|
150
|
-
{
|
|
151
|
-
operator: "eq",
|
|
152
|
-
field: "groupCode",
|
|
153
|
-
value: groupCode,
|
|
154
|
-
},
|
|
155
|
-
{
|
|
156
|
-
operator: "eq",
|
|
157
|
-
field: "itemCode",
|
|
158
|
-
value: itemCode,
|
|
159
|
-
},
|
|
160
|
-
],
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
return settingItem ? settingItem.value : null;
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
async setUserSettingValue(ownerId: number, groupCode: string, itemCode: string, value: any) {
|
|
167
|
-
const settingItem = await this.#userSettingItemManager.findEntity({
|
|
168
|
-
filters: [
|
|
169
|
-
{
|
|
170
|
-
operator: "eq",
|
|
171
|
-
field: "ownerId",
|
|
172
|
-
value: ownerId,
|
|
173
|
-
},
|
|
174
|
-
{
|
|
175
|
-
operator: "eq",
|
|
176
|
-
field: "groupCode",
|
|
177
|
-
value: groupCode,
|
|
178
|
-
},
|
|
179
|
-
{
|
|
180
|
-
operator: "eq",
|
|
181
|
-
field: "itemCode",
|
|
182
|
-
value: itemCode,
|
|
183
|
-
},
|
|
184
|
-
],
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
if (settingItem) {
|
|
188
|
-
await this.#userSettingItemManager.updateEntityById({
|
|
189
|
-
id: settingItem.id,
|
|
190
|
-
entityToSave: {
|
|
191
|
-
value,
|
|
192
|
-
},
|
|
193
|
-
});
|
|
194
|
-
} else {
|
|
195
|
-
await this.#systemSettingItemManager.createEntity({
|
|
196
|
-
entity: {
|
|
197
|
-
ownerId: ownerId,
|
|
198
|
-
groupCode,
|
|
199
|
-
itemCode,
|
|
200
|
-
value,
|
|
201
|
-
} as Partial<UserSettingItem>,
|
|
202
|
-
});
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
async setUserSettingValues(ownerId: number, groupCode: string, settingValues: Record<string, any>) {
|
|
207
|
-
for (const itemCode in settingValues) {
|
|
208
|
-
const value = settingValues[itemCode];
|
|
209
|
-
await this.setUserSettingValue(ownerId, groupCode, itemCode, value);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
//#endregion
|
|
213
|
-
}
|
|
1
|
+
import { IRpdServer } from "~/core/server";
|
|
2
|
+
import EntityManager from "~/dataAccess/entityManager";
|
|
3
|
+
import { SystemSettingItem, UserSettingItem } from "./SettingPluginTypes";
|
|
4
|
+
|
|
5
|
+
export interface GetSystemSettingValuesInput {
|
|
6
|
+
groupCode: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface SetSystemSettingValuesInput {
|
|
10
|
+
groupCode: string;
|
|
11
|
+
values: Record<string, any>;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export interface GetUserSettingValuesInput {
|
|
15
|
+
groupCode: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export default class SettingService {
|
|
19
|
+
#server: IRpdServer;
|
|
20
|
+
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
21
|
+
#userSettingItemManager: EntityManager<UserSettingItem>;
|
|
22
|
+
|
|
23
|
+
constructor(server: IRpdServer) {
|
|
24
|
+
this.#server = server;
|
|
25
|
+
|
|
26
|
+
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
27
|
+
this.#userSettingItemManager = server.getEntityManager("user_setting_item");
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
//#region System Setting
|
|
31
|
+
async getSystemSettingItems(groupCode: string): Promise<SystemSettingItem[]> {
|
|
32
|
+
return await this.#systemSettingItemManager.findEntities({
|
|
33
|
+
filters: [
|
|
34
|
+
{
|
|
35
|
+
operator: "eq",
|
|
36
|
+
field: "groupCode",
|
|
37
|
+
value: groupCode,
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async getSystemSettingValues(groupCode: string): Promise<Record<string, any>> {
|
|
44
|
+
const settingItems = await this.getSystemSettingItems(groupCode);
|
|
45
|
+
|
|
46
|
+
return settingItems.reduce<Record<string, any>>((settingValues, settingItem) => {
|
|
47
|
+
settingValues[settingItem.itemCode] = settingItem.value;
|
|
48
|
+
return settingValues;
|
|
49
|
+
}, {});
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
async getSystemSettingValue(groupCode: string, itemCode: string): Promise<any> {
|
|
53
|
+
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
54
|
+
filters: [
|
|
55
|
+
{
|
|
56
|
+
operator: "eq",
|
|
57
|
+
field: "groupCode",
|
|
58
|
+
value: groupCode,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
operator: "eq",
|
|
62
|
+
field: "itemCode",
|
|
63
|
+
value: itemCode,
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
return settingItem ? settingItem.value : null;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
async setSystemSettingValue(groupCode: string, itemCode: string, value: any) {
|
|
72
|
+
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
73
|
+
filters: [
|
|
74
|
+
{
|
|
75
|
+
operator: "eq",
|
|
76
|
+
field: "groupCode",
|
|
77
|
+
value: groupCode,
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
operator: "eq",
|
|
81
|
+
field: "itemCode",
|
|
82
|
+
value: itemCode,
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
if (settingItem) {
|
|
88
|
+
if (settingItem.value !== value) {
|
|
89
|
+
await this.#systemSettingItemManager.updateEntityById({
|
|
90
|
+
id: settingItem.id,
|
|
91
|
+
entityToSave: {
|
|
92
|
+
value,
|
|
93
|
+
},
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
await this.#systemSettingItemManager.createEntity({
|
|
98
|
+
entity: {
|
|
99
|
+
groupCode,
|
|
100
|
+
itemCode,
|
|
101
|
+
value,
|
|
102
|
+
} as Partial<SystemSettingItem>,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
async setSystemSettingValues(groupCode: string, settingValues: Record<string, any>) {
|
|
108
|
+
for (const itemCode in settingValues) {
|
|
109
|
+
const value = settingValues[itemCode];
|
|
110
|
+
await this.setSystemSettingValue(groupCode, itemCode, value);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//#endregion
|
|
114
|
+
|
|
115
|
+
//#region User Setting
|
|
116
|
+
async getUserSettingItems(ownerId: number, groupCode: string): Promise<UserSettingItem[]> {
|
|
117
|
+
return await this.#userSettingItemManager.findEntities({
|
|
118
|
+
filters: [
|
|
119
|
+
{
|
|
120
|
+
operator: "eq",
|
|
121
|
+
field: "ownerId",
|
|
122
|
+
value: ownerId,
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
operator: "eq",
|
|
126
|
+
field: "groupCode",
|
|
127
|
+
value: groupCode,
|
|
128
|
+
},
|
|
129
|
+
],
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
async getUserSettingValues(ownerId: number, groupCode: string): Promise<Record<string, any>> {
|
|
134
|
+
const settingItems = await this.getUserSettingItems(ownerId, groupCode);
|
|
135
|
+
|
|
136
|
+
return settingItems.reduce<Record<string, any>>((settingValues, settingItem) => {
|
|
137
|
+
settingValues[settingItem.itemCode] = settingItem.value;
|
|
138
|
+
return settingValues;
|
|
139
|
+
}, {});
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
async getUserSettingValue(ownerId: number, groupCode: string, itemCode: string): Promise<any> {
|
|
143
|
+
const settingItem = await this.#systemSettingItemManager.findEntity({
|
|
144
|
+
filters: [
|
|
145
|
+
{
|
|
146
|
+
operator: "eq",
|
|
147
|
+
field: "ownerId",
|
|
148
|
+
value: ownerId,
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
operator: "eq",
|
|
152
|
+
field: "groupCode",
|
|
153
|
+
value: groupCode,
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
operator: "eq",
|
|
157
|
+
field: "itemCode",
|
|
158
|
+
value: itemCode,
|
|
159
|
+
},
|
|
160
|
+
],
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
return settingItem ? settingItem.value : null;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
async setUserSettingValue(ownerId: number, groupCode: string, itemCode: string, value: any) {
|
|
167
|
+
const settingItem = await this.#userSettingItemManager.findEntity({
|
|
168
|
+
filters: [
|
|
169
|
+
{
|
|
170
|
+
operator: "eq",
|
|
171
|
+
field: "ownerId",
|
|
172
|
+
value: ownerId,
|
|
173
|
+
},
|
|
174
|
+
{
|
|
175
|
+
operator: "eq",
|
|
176
|
+
field: "groupCode",
|
|
177
|
+
value: groupCode,
|
|
178
|
+
},
|
|
179
|
+
{
|
|
180
|
+
operator: "eq",
|
|
181
|
+
field: "itemCode",
|
|
182
|
+
value: itemCode,
|
|
183
|
+
},
|
|
184
|
+
],
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
if (settingItem) {
|
|
188
|
+
await this.#userSettingItemManager.updateEntityById({
|
|
189
|
+
id: settingItem.id,
|
|
190
|
+
entityToSave: {
|
|
191
|
+
value,
|
|
192
|
+
},
|
|
193
|
+
});
|
|
194
|
+
} else {
|
|
195
|
+
await this.#systemSettingItemManager.createEntity({
|
|
196
|
+
entity: {
|
|
197
|
+
ownerId: ownerId,
|
|
198
|
+
groupCode,
|
|
199
|
+
itemCode,
|
|
200
|
+
value,
|
|
201
|
+
} as Partial<UserSettingItem>,
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
async setUserSettingValues(ownerId: number, groupCode: string, settingValues: Record<string, any>) {
|
|
207
|
+
for (const itemCode in settingValues) {
|
|
208
|
+
const value = settingValues[itemCode];
|
|
209
|
+
await this.setUserSettingValue(ownerId, groupCode, itemCode, value);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
//#endregion
|
|
213
|
+
}
|