@ruiapp/rapid-core 0.5.11 → 0.5.13
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/CHANGELOG.md +7 -7
- package/dist/facilities/cache/CacheFacilityTypes.d.ts +4 -2
- package/dist/facilities/cache/MemoryCache.d.ts +3 -1
- package/dist/index.d.ts +4 -0
- package/dist/index.js +131 -72
- package/dist/utilities/entityUtility.d.ts +1 -0
- package/dist/utilities/passwordUtility.d.ts +14 -0
- package/package.json +2 -2
- package/rollup.config.js +16 -16
- package/src/bootstrapApplicationConfig.ts +638 -638
- 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/http-types.ts +4 -4
- package/src/core/pluginManager.ts +175 -175
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +95 -95
- package/src/core/response.ts +79 -79
- package/src/core/routeContext.ts +100 -100
- package/src/core/routesBuilder.ts +88 -88
- package/src/core/server.ts +145 -145
- package/src/dataAccess/columnTypeMapper.ts +22 -22
- package/src/dataAccess/dataAccessTypes.ts +163 -163
- package/src/dataAccess/dataAccessor.ts +135 -135
- package/src/dataAccess/entityManager.ts +1910 -1910
- package/src/dataAccess/entityMapper.ts +100 -100
- package/src/dataAccess/propertyMapper.ts +28 -28
- package/src/deno-std/assert/assert.ts +9 -9
- package/src/deno-std/assert/assertion_error.ts +7 -7
- package/src/deno-std/datetime/to_imf.ts +32 -32
- package/src/deno-std/encoding/base64.ts +141 -141
- package/src/deno-std/http/cookie.ts +372 -372
- package/src/facilities/cache/CacheFacilityTypes.ts +29 -27
- package/src/facilities/cache/CacheFactory.ts +31 -31
- package/src/facilities/cache/MemoryCache.ts +58 -42
- package/src/facilities/cache/MemoryCacheProvider.ts +15 -15
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/helpers/filterHelper.ts +148 -148
- package/src/helpers/inputHelper.ts +11 -11
- package/src/helpers/metaHelper.ts +104 -104
- package/src/helpers/runCollectionEntityActionHandler.ts +57 -57
- package/src/index.ts +67 -63
- package/src/plugins/auth/AuthPlugin.ts +93 -93
- package/src/plugins/auth/actionHandlers/changePassword.ts +60 -61
- package/src/plugins/auth/actionHandlers/createSession.ts +68 -68
- 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 +44 -45
- 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/auth/services/AuthService.ts +39 -39
- package/src/plugins/cronJob/CronJobPlugin.ts +112 -112
- 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/DataManagePlugin.ts +163 -163
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +17 -17
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +81 -81
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +45 -45
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +27 -27
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +30 -30
- package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +38 -38
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
- package/src/plugins/fileManage/FileManagePlugin.ts +52 -52
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +65 -65
- package/src/plugins/fileManage/actionHandlers/downloadFile.ts +44 -44
- 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/license/LicensePlugin.ts +79 -79
- package/src/plugins/license/LicensePluginTypes.ts +95 -95
- package/src/plugins/license/LicenseService.ts +118 -118
- package/src/plugins/license/actionHandlers/getLicense.ts +18 -18
- package/src/plugins/license/actionHandlers/index.ts +4 -4
- package/src/plugins/license/helpers/certHelper.ts +21 -21
- package/src/plugins/license/helpers/cryptoHelper.ts +47 -47
- package/src/plugins/license/models/index.ts +1 -1
- package/src/plugins/license/routes/getLicense.ts +15 -15
- package/src/plugins/license/routes/index.ts +3 -3
- package/src/plugins/mail/MailPlugin.ts +74 -74
- package/src/plugins/mail/MailPluginTypes.ts +27 -27
- package/src/plugins/mail/MailService.ts +38 -38
- package/src/plugins/mail/actionHandlers/index.ts +3 -3
- package/src/plugins/mail/models/index.ts +1 -1
- package/src/plugins/mail/routes/index.ts +1 -1
- package/src/plugins/metaManage/MetaManagePlugin.ts +530 -530
- 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/notification/NotificationPlugin.ts +68 -68
- package/src/plugins/notification/NotificationPluginTypes.ts +13 -13
- package/src/plugins/notification/NotificationService.ts +25 -25
- package/src/plugins/notification/actionHandlers/index.ts +3 -3
- package/src/plugins/notification/models/Notification.ts +60 -60
- package/src/plugins/notification/models/index.ts +3 -3
- package/src/plugins/notification/routes/index.ts +1 -1
- package/src/plugins/routeManage/RouteManagePlugin.ts +62 -62
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/sequence/SequencePlugin.ts +146 -146
- package/src/plugins/sequence/SequencePluginTypes.ts +69 -69
- package/src/plugins/sequence/SequenceService.ts +92 -92
- 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/autoIncrement.ts +90 -90
- package/src/plugins/sequence/segments/dayOfMonth.ts +19 -19
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/sequence/segments/literal.ts +16 -16
- package/src/plugins/sequence/segments/month.ts +19 -19
- package/src/plugins/sequence/segments/parameter.ts +20 -20
- package/src/plugins/sequence/segments/year.ts +19 -19
- 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/serverOperation/actionHandlers/runServerOperation.ts +15 -15
- package/src/plugins/setting/SettingPlugin.ts +68 -68
- package/src/plugins/setting/SettingPluginTypes.ts +37 -37
- 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 +48 -48
- 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 +55 -55
- 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/StateMachinePlugin.ts +196 -196
- package/src/plugins/stateMachine/StateMachinePluginTypes.ts +48 -48
- package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +54 -54
- 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/plugins/stateMachine/stateMachineHelper.ts +36 -36
- package/src/plugins/webhooks/WebhooksPlugin.ts +148 -148
- package/src/plugins/webhooks/pluginConfig.ts +75 -75
- package/src/polyfill.ts +5 -5
- package/src/proxy/mod.ts +38 -38
- package/src/proxy/types.ts +21 -21
- package/src/queryBuilder/index.ts +1 -1
- package/src/queryBuilder/queryBuilder.ts +668 -668
- package/src/server.ts +480 -480
- package/src/types.ts +722 -722
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/entityUtility.ts +18 -0
- package/src/utilities/errorUtility.ts +15 -15
- package/src/utilities/fsUtility.ts +61 -61
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/passwordUtility.ts +26 -0
- package/src/utilities/pathUtility.ts +14 -14
- package/src/utilities/timeUtility.ts +9 -9
- package/src/utilities/typeUtility.ts +15 -15
- package/tsconfig.json +19 -19
|
@@ -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
|
+
}
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import SettingService, { GetSystemSettingValuesInput } from "../SettingService";
|
|
4
|
-
|
|
5
|
-
export interface GetSystemSettingValuesOptions {
|
|
6
|
-
groupCode: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export const code = "getSystemSettingValues";
|
|
10
|
-
|
|
11
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetSystemSettingValuesOptions) {
|
|
12
|
-
const { server, routerContext } = ctx;
|
|
13
|
-
const { response } = routerContext;
|
|
14
|
-
|
|
15
|
-
const input: GetSystemSettingValuesInput = ctx.input;
|
|
16
|
-
|
|
17
|
-
if (options?.groupCode) {
|
|
18
|
-
input.groupCode = options.groupCode;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (!input.groupCode) {
|
|
22
|
-
throw new Error(`Group code is required when getting system setting values.`);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const settingService = server.getService<SettingService>("settingService");
|
|
26
|
-
|
|
27
|
-
const settingValues = await settingService.getSystemSettingValues(input.groupCode);
|
|
28
|
-
|
|
29
|
-
ctx.output = settingValues;
|
|
30
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import SettingService, { GetSystemSettingValuesInput } from "../SettingService";
|
|
4
|
+
|
|
5
|
+
export interface GetSystemSettingValuesOptions {
|
|
6
|
+
groupCode: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const code = "getSystemSettingValues";
|
|
10
|
+
|
|
11
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetSystemSettingValuesOptions) {
|
|
12
|
+
const { server, routerContext } = ctx;
|
|
13
|
+
const { response } = routerContext;
|
|
14
|
+
|
|
15
|
+
const input: GetSystemSettingValuesInput = ctx.input;
|
|
16
|
+
|
|
17
|
+
if (options?.groupCode) {
|
|
18
|
+
input.groupCode = options.groupCode;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
if (!input.groupCode) {
|
|
22
|
+
throw new Error(`Group code is required when getting system setting values.`);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const settingService = server.getService<SettingService>("settingService");
|
|
26
|
+
|
|
27
|
+
const settingValues = await settingService.getSystemSettingValues(input.groupCode);
|
|
28
|
+
|
|
29
|
+
ctx.output = settingValues;
|
|
30
|
+
}
|
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import SettingService, { GetUserSettingValuesInput } from "../SettingService";
|
|
4
|
-
|
|
5
|
-
export interface GetUserSettingValuesOptions {
|
|
6
|
-
groupCode: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export const code = "getUserSettingValues";
|
|
10
|
-
|
|
11
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetUserSettingValuesOptions) {
|
|
12
|
-
const { server, routerContext } = ctx;
|
|
13
|
-
const userId = routerContext.state.userId;
|
|
14
|
-
if (!userId) {
|
|
15
|
-
ctx.status = 401;
|
|
16
|
-
ctx.output = {
|
|
17
|
-
error: {
|
|
18
|
-
message: "You are not signed in.",
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
return;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const input: GetUserSettingValuesInput = ctx.input;
|
|
25
|
-
|
|
26
|
-
if (options?.groupCode) {
|
|
27
|
-
input.groupCode = options.groupCode;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (!input.groupCode) {
|
|
31
|
-
throw new Error(`Group code is required when getting system setting values.`);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
const settingService = server.getService<SettingService>("settingService");
|
|
35
|
-
const settingValues = await settingService.getUserSettingValues(userId, input.groupCode);
|
|
36
|
-
|
|
37
|
-
ctx.output = settingValues;
|
|
38
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import SettingService, { GetUserSettingValuesInput } from "../SettingService";
|
|
4
|
+
|
|
5
|
+
export interface GetUserSettingValuesOptions {
|
|
6
|
+
groupCode: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const code = "getUserSettingValues";
|
|
10
|
+
|
|
11
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetUserSettingValuesOptions) {
|
|
12
|
+
const { server, routerContext } = ctx;
|
|
13
|
+
const userId = routerContext.state.userId;
|
|
14
|
+
if (!userId) {
|
|
15
|
+
ctx.status = 401;
|
|
16
|
+
ctx.output = {
|
|
17
|
+
error: {
|
|
18
|
+
message: "You are not signed in.",
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const input: GetUserSettingValuesInput = ctx.input;
|
|
25
|
+
|
|
26
|
+
if (options?.groupCode) {
|
|
27
|
+
input.groupCode = options.groupCode;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
if (!input.groupCode) {
|
|
31
|
+
throw new Error(`Group code is required when getting system setting values.`);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const settingService = server.getService<SettingService>("settingService");
|
|
35
|
+
const settingValues = await settingService.getUserSettingValues(userId, input.groupCode);
|
|
36
|
+
|
|
37
|
+
ctx.output = settingValues;
|
|
38
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
-
import * as getUserSettingValues from "./getUserSettingValues";
|
|
3
|
-
import * as getSystemSettingValues from "./getSystemSettingValues";
|
|
4
|
-
import * as setSystemSettingValues from "./setSystemSettingValues";
|
|
5
|
-
|
|
6
|
-
export default [getUserSettingValues, getSystemSettingValues, setSystemSettingValues] satisfies IPluginActionHandler[];
|
|
1
|
+
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
+
import * as getUserSettingValues from "./getUserSettingValues";
|
|
3
|
+
import * as getSystemSettingValues from "./getSystemSettingValues";
|
|
4
|
+
import * as setSystemSettingValues from "./setSystemSettingValues";
|
|
5
|
+
|
|
6
|
+
export default [getUserSettingValues, getSystemSettingValues, setSystemSettingValues] satisfies IPluginActionHandler[];
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import SettingService, { SetSystemSettingValuesInput } from "../SettingService";
|
|
4
|
-
|
|
5
|
-
export interface SetSystemSettingValuesOptions {
|
|
6
|
-
groupCode: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export const code = "setSystemSettingValues";
|
|
10
|
-
|
|
11
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: SetSystemSettingValuesOptions) {
|
|
12
|
-
const { server, routerContext } = ctx;
|
|
13
|
-
const { response } = routerContext;
|
|
14
|
-
|
|
15
|
-
const input: SetSystemSettingValuesInput = ctx.input;
|
|
16
|
-
|
|
17
|
-
if (options?.groupCode) {
|
|
18
|
-
input.groupCode = options.groupCode;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (!input.groupCode) {
|
|
22
|
-
throw new Error(`Group code is required when setting system setting values.`);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const settingService = server.getService<SettingService>("settingService");
|
|
26
|
-
|
|
27
|
-
await settingService.setSystemSettingValues(input.groupCode, input.values);
|
|
28
|
-
|
|
29
|
-
ctx.output = {};
|
|
30
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import SettingService, { SetSystemSettingValuesInput } from "../SettingService";
|
|
4
|
+
|
|
5
|
+
export interface SetSystemSettingValuesOptions {
|
|
6
|
+
groupCode: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const code = "setSystemSettingValues";
|
|
10
|
+
|
|
11
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: SetSystemSettingValuesOptions) {
|
|
12
|
+
const { server, routerContext } = ctx;
|
|
13
|
+
const { response } = routerContext;
|
|
14
|
+
|
|
15
|
+
const input: SetSystemSettingValuesInput = ctx.input;
|
|
16
|
+
|
|
17
|
+
if (options?.groupCode) {
|
|
18
|
+
input.groupCode = options.groupCode;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
if (!input.groupCode) {
|
|
22
|
+
throw new Error(`Group code is required when setting system setting values.`);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const settingService = server.getService<SettingService>("settingService");
|
|
26
|
+
|
|
27
|
+
await settingService.setSystemSettingValues(input.groupCode, input.values);
|
|
28
|
+
|
|
29
|
+
ctx.output = {};
|
|
30
|
+
}
|