@ruiapp/rapid-core 0.3.1 → 0.3.3
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/index.d.ts +5 -0
- package/dist/index.js +403 -158
- package/dist/plugins/license/LicensePlugin.d.ts +23 -0
- package/dist/plugins/license/LicensePluginTypes.d.ts +78 -0
- package/dist/plugins/license/LicenseService.d.ts +22 -0
- package/dist/plugins/license/actionHandlers/getLicense.d.ts +6 -0
- package/dist/plugins/license/actionHandlers/index.d.ts +3 -0
- package/dist/plugins/license/helpers/certHelper.d.ts +2 -0
- package/dist/plugins/license/helpers/cryptoHelper.d.ts +8 -0
- package/dist/plugins/license/models/index.d.ts +2 -0
- package/dist/plugins/license/routes/getLicense.d.ts +12 -0
- package/dist/plugins/license/routes/index.d.ts +12 -0
- package/dist/utilities/entityUtility.d.ts +1 -0
- package/dist/utilities/typeUtility.d.ts +1 -0
- package/package.json +1 -1
- package/rollup.config.js +16 -16
- package/src/bootstrapApplicationConfig.ts +631 -631
- 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 +86 -86
- package/src/core/response.ts +76 -76
- package/src/core/routeContext.ts +47 -47
- package/src/core/routesBuilder.ts +88 -88
- package/src/core/server.ts +142 -142
- 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 +1718 -1718
- 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/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 +89 -89
- package/src/helpers/runCollectionEntityActionHandler.ts +27 -27
- package/src/index.ts +60 -54
- package/src/plugins/auth/AuthPlugin.ts +85 -85
- package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
- package/src/plugins/auth/actionHandlers/createSession.ts +75 -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/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 +20 -20
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +16 -16
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +38 -38
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +22 -22
- 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 +41 -41
- 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 -0
- package/src/plugins/license/LicensePluginTypes.ts +95 -0
- package/src/plugins/license/LicenseService.ts +112 -0
- package/src/plugins/license/actionHandlers/getLicense.ts +18 -0
- package/src/plugins/license/actionHandlers/index.ts +4 -0
- package/src/plugins/license/helpers/certHelper.ts +21 -0
- package/src/plugins/license/helpers/cryptoHelper.ts +47 -0
- package/src/plugins/license/models/index.ts +1 -0
- package/src/plugins/license/routes/getLicense.ts +15 -0
- package/src/plugins/license/routes/index.ts +3 -0
- 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 +504 -504
- 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 +136 -136
- package/src/plugins/sequence/SequencePluginTypes.ts +69 -69
- 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/autoIncrement.ts +78 -78
- package/src/plugins/sequence/segments/dayOfMonth.ts +17 -17
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/sequence/segments/literal.ts +14 -14
- package/src/plugins/sequence/segments/month.ts +17 -17
- package/src/plugins/sequence/segments/parameter.ts +18 -18
- package/src/plugins/sequence/segments/year.ts +17 -17
- 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 -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 +55 -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/StateMachinePlugin.ts +186 -186
- package/src/plugins/stateMachine/StateMachinePluginTypes.ts +48 -48
- 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/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 +665 -665
- package/src/server.ts +463 -463
- package/src/types.ts +701 -701
- 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/pathUtility.ts +14 -14
- package/src/utilities/timeUtility.ts +9 -9
- package/src/utilities/typeUtility.ts +15 -11
- package/tsconfig.json +19 -19
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
import winston from "winston";
|
|
2
|
-
|
|
3
|
-
export interface Logger {
|
|
4
|
-
log: winston.LogMethod;
|
|
5
|
-
/**
|
|
6
|
-
* The service/app is going to stop or become unusable now. An operator should definitely look into this immediately.
|
|
7
|
-
*/
|
|
8
|
-
emerg: winston.LeveledLogMethod;
|
|
9
|
-
/**
|
|
10
|
-
* Fatal for a particular service, but the app continues servicing other requests. An operator should look at this immediately.
|
|
11
|
-
*/
|
|
12
|
-
crit: winston.LeveledLogMethod;
|
|
13
|
-
/**
|
|
14
|
-
* Fatal for a particular request, but the service/app continues servicing other requests. An operator should look at this soon(ish).
|
|
15
|
-
*/
|
|
16
|
-
error: winston.LeveledLogMethod;
|
|
17
|
-
/**
|
|
18
|
-
* A note on something that should probably be looked at by an operator eventually.
|
|
19
|
-
*/
|
|
20
|
-
warn: winston.LeveledLogMethod;
|
|
21
|
-
/**
|
|
22
|
-
* Detail on regular operation.
|
|
23
|
-
*/
|
|
24
|
-
info: winston.LeveledLogMethod;
|
|
25
|
-
/**
|
|
26
|
-
* Anything else, i.e. too verbose to be included in "info" level.
|
|
27
|
-
*/
|
|
28
|
-
debug: winston.LeveledLogMethod;
|
|
29
|
-
/**
|
|
30
|
-
* Logging from external libraries used by your app or very detailed application logging.
|
|
31
|
-
*/
|
|
32
|
-
verbose: winston.LeveledLogMethod;
|
|
33
|
-
|
|
34
|
-
child(options: Object): Logger;
|
|
35
|
-
}
|
|
1
|
+
import winston from "winston";
|
|
2
|
+
|
|
3
|
+
export interface Logger {
|
|
4
|
+
log: winston.LogMethod;
|
|
5
|
+
/**
|
|
6
|
+
* The service/app is going to stop or become unusable now. An operator should definitely look into this immediately.
|
|
7
|
+
*/
|
|
8
|
+
emerg: winston.LeveledLogMethod;
|
|
9
|
+
/**
|
|
10
|
+
* Fatal for a particular service, but the app continues servicing other requests. An operator should look at this immediately.
|
|
11
|
+
*/
|
|
12
|
+
crit: winston.LeveledLogMethod;
|
|
13
|
+
/**
|
|
14
|
+
* Fatal for a particular request, but the service/app continues servicing other requests. An operator should look at this soon(ish).
|
|
15
|
+
*/
|
|
16
|
+
error: winston.LeveledLogMethod;
|
|
17
|
+
/**
|
|
18
|
+
* A note on something that should probably be looked at by an operator eventually.
|
|
19
|
+
*/
|
|
20
|
+
warn: winston.LeveledLogMethod;
|
|
21
|
+
/**
|
|
22
|
+
* Detail on regular operation.
|
|
23
|
+
*/
|
|
24
|
+
info: winston.LeveledLogMethod;
|
|
25
|
+
/**
|
|
26
|
+
* Anything else, i.e. too verbose to be included in "info" level.
|
|
27
|
+
*/
|
|
28
|
+
debug: winston.LeveledLogMethod;
|
|
29
|
+
/**
|
|
30
|
+
* Logging from external libraries used by your app or very detailed application logging.
|
|
31
|
+
*/
|
|
32
|
+
verbose: winston.LeveledLogMethod;
|
|
33
|
+
|
|
34
|
+
child(options: Object): Logger;
|
|
35
|
+
}
|
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
import { isNumber, isObject } from "lodash";
|
|
2
|
-
import { IRpdServer } from "~/core/server";
|
|
3
|
-
import { getEntityPropertyByCode, isOneRelationProperty } from "~/helpers/metaHelper";
|
|
4
|
-
import { RpdDataModel } from "~/types";
|
|
5
|
-
|
|
6
|
-
export function getEntityPartChanges(server: IRpdServer, model: RpdDataModel, before: any, after: any): Record<string, any> | null {
|
|
7
|
-
if (!before) {
|
|
8
|
-
throw new Error("Argument 'before' can not be null.");
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
if (!after) {
|
|
12
|
-
throw new Error("Argument 'after' can not be null.");
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
let changed = false;
|
|
16
|
-
let changes = {};
|
|
17
|
-
for (const key in after) {
|
|
18
|
-
const property = getEntityPropertyByCode(server, model, key);
|
|
19
|
-
if (property && isOneRelationProperty(property)) {
|
|
20
|
-
const afterValue: number | { id: number } | null = after[key];
|
|
21
|
-
const beforeValue: number | { id: number } | null = before[key] || before[property.targetIdColumnName];
|
|
22
|
-
if (afterValue) {
|
|
23
|
-
if (isNumber(afterValue)) {
|
|
24
|
-
if (beforeValue) {
|
|
25
|
-
if (isNumber(beforeValue)) {
|
|
26
|
-
if (afterValue != beforeValue) {
|
|
27
|
-
changed = true;
|
|
28
|
-
changes[key] = afterValue;
|
|
29
|
-
}
|
|
30
|
-
} else {
|
|
31
|
-
if (afterValue != beforeValue.id) {
|
|
32
|
-
changed = true;
|
|
33
|
-
changes[key] = afterValue;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
} else {
|
|
37
|
-
changed = true;
|
|
38
|
-
changes[key] = afterValue;
|
|
39
|
-
}
|
|
40
|
-
} else {
|
|
41
|
-
if (beforeValue) {
|
|
42
|
-
if (isNumber(beforeValue)) {
|
|
43
|
-
if (afterValue.id != beforeValue) {
|
|
44
|
-
changed = true;
|
|
45
|
-
changes[key] = afterValue;
|
|
46
|
-
}
|
|
47
|
-
} else {
|
|
48
|
-
if (afterValue.id != beforeValue.id) {
|
|
49
|
-
changed = true;
|
|
50
|
-
changes[key] = afterValue;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
} else {
|
|
54
|
-
changed = true;
|
|
55
|
-
changes[key] = afterValue;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
} else {
|
|
59
|
-
if (beforeValue) {
|
|
60
|
-
changed = true;
|
|
61
|
-
changes[key] = null;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
} else {
|
|
65
|
-
if (after[key] != before[key]) {
|
|
66
|
-
changed = true;
|
|
67
|
-
changes[key] = after[key];
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
if (changed) {
|
|
73
|
-
return changes;
|
|
74
|
-
}
|
|
75
|
-
return null;
|
|
76
|
-
}
|
|
1
|
+
import { isNumber, isObject } from "lodash";
|
|
2
|
+
import { IRpdServer } from "~/core/server";
|
|
3
|
+
import { getEntityPropertyByCode, isOneRelationProperty } from "~/helpers/metaHelper";
|
|
4
|
+
import { RpdDataModel } from "~/types";
|
|
5
|
+
|
|
6
|
+
export function getEntityPartChanges(server: IRpdServer, model: RpdDataModel, before: any, after: any): Record<string, any> | null {
|
|
7
|
+
if (!before) {
|
|
8
|
+
throw new Error("Argument 'before' can not be null.");
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
if (!after) {
|
|
12
|
+
throw new Error("Argument 'after' can not be null.");
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
let changed = false;
|
|
16
|
+
let changes = {};
|
|
17
|
+
for (const key in after) {
|
|
18
|
+
const property = getEntityPropertyByCode(server, model, key);
|
|
19
|
+
if (property && isOneRelationProperty(property)) {
|
|
20
|
+
const afterValue: number | { id: number } | null = after[key];
|
|
21
|
+
const beforeValue: number | { id: number } | null = before[key] || before[property.targetIdColumnName];
|
|
22
|
+
if (afterValue) {
|
|
23
|
+
if (isNumber(afterValue)) {
|
|
24
|
+
if (beforeValue) {
|
|
25
|
+
if (isNumber(beforeValue)) {
|
|
26
|
+
if (afterValue != beforeValue) {
|
|
27
|
+
changed = true;
|
|
28
|
+
changes[key] = afterValue;
|
|
29
|
+
}
|
|
30
|
+
} else {
|
|
31
|
+
if (afterValue != beforeValue.id) {
|
|
32
|
+
changed = true;
|
|
33
|
+
changes[key] = afterValue;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
} else {
|
|
37
|
+
changed = true;
|
|
38
|
+
changes[key] = afterValue;
|
|
39
|
+
}
|
|
40
|
+
} else {
|
|
41
|
+
if (beforeValue) {
|
|
42
|
+
if (isNumber(beforeValue)) {
|
|
43
|
+
if (afterValue.id != beforeValue) {
|
|
44
|
+
changed = true;
|
|
45
|
+
changes[key] = afterValue;
|
|
46
|
+
}
|
|
47
|
+
} else {
|
|
48
|
+
if (afterValue.id != beforeValue.id) {
|
|
49
|
+
changed = true;
|
|
50
|
+
changes[key] = afterValue;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
} else {
|
|
54
|
+
changed = true;
|
|
55
|
+
changes[key] = afterValue;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
} else {
|
|
59
|
+
if (beforeValue) {
|
|
60
|
+
changed = true;
|
|
61
|
+
changes[key] = null;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
} else {
|
|
65
|
+
if (after[key] != before[key]) {
|
|
66
|
+
changed = true;
|
|
67
|
+
changes[key] = after[key];
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
if (changed) {
|
|
73
|
+
return changes;
|
|
74
|
+
}
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
@@ -1,148 +1,148 @@
|
|
|
1
|
-
import {
|
|
2
|
-
EntityFilterOptions,
|
|
3
|
-
EntityNonRelationPropertyFilterOptions,
|
|
4
|
-
FindEntityExistenceFilterOptions,
|
|
5
|
-
FindEntityLogicalFilterOptions,
|
|
6
|
-
RpdDataModel,
|
|
7
|
-
RpdDataModelIndexOptions,
|
|
8
|
-
RpdDataModelProperty,
|
|
9
|
-
} from "~/types";
|
|
10
|
-
import { isNullOrUndefined } from "~/utilities/typeUtility";
|
|
11
|
-
import { getEntityOwnProperty, getEntityOwnPropertyByCode, isManyRelationProperty, isOneRelationProperty } from "./metaHelper";
|
|
12
|
-
import { IRpdServer } from "~/core/server";
|
|
13
|
-
import { isPlainObject } from "lodash";
|
|
14
|
-
import { RowFilterOptions } from "~/dataAccess/dataAccessTypes";
|
|
15
|
-
import { Logger } from "~/facilities/log/LogFacility";
|
|
16
|
-
|
|
17
|
-
export function removeFiltersWithNullValue(filters?: EntityFilterOptions[]) {
|
|
18
|
-
const result: EntityFilterOptions[] = [];
|
|
19
|
-
if (!filters) {
|
|
20
|
-
return result;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
for (const filter of filters) {
|
|
24
|
-
const { operator } = filter;
|
|
25
|
-
|
|
26
|
-
switch (operator) {
|
|
27
|
-
case "null":
|
|
28
|
-
case "notNull":
|
|
29
|
-
result.push(filter);
|
|
30
|
-
break;
|
|
31
|
-
case "exists":
|
|
32
|
-
case "notExists":
|
|
33
|
-
case "and":
|
|
34
|
-
case "or":
|
|
35
|
-
const transformedFilter = transformFilterWithSubFilters(filter);
|
|
36
|
-
if (transformedFilter !== null) {
|
|
37
|
-
result.push(transformedFilter);
|
|
38
|
-
}
|
|
39
|
-
break;
|
|
40
|
-
default:
|
|
41
|
-
if (!isNullOrUndefined(filter.value)) {
|
|
42
|
-
result.push(filter);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
return result;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
function transformFilterWithSubFilters(
|
|
51
|
-
filter: FindEntityExistenceFilterOptions | FindEntityLogicalFilterOptions,
|
|
52
|
-
): FindEntityExistenceFilterOptions | FindEntityLogicalFilterOptions | null {
|
|
53
|
-
const subFilters = removeFiltersWithNullValue(filter.filters);
|
|
54
|
-
if (!subFilters.length) {
|
|
55
|
-
return null;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
filter.filters = subFilters;
|
|
59
|
-
return filter;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
export function convertModelIndexConditionsToRowFilterOptions(logger: Logger, model: RpdDataModel, filters: RpdDataModelIndexOptions[]) {
|
|
63
|
-
if (!filters || !filters.length) {
|
|
64
|
-
return [];
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
const replacedFilters: RowFilterOptions[] = [];
|
|
68
|
-
for (const filter of filters) {
|
|
69
|
-
const { operator } = filter;
|
|
70
|
-
if (operator === "and" || operator === "or") {
|
|
71
|
-
replacedFilters.push({
|
|
72
|
-
operator: operator,
|
|
73
|
-
filters: convertModelIndexConditionsToRowFilterOptions(logger, model, filter.filters),
|
|
74
|
-
});
|
|
75
|
-
} else {
|
|
76
|
-
const replacedFilter = replaceModelIndexConditionEntityPropertyWithTableColumn(logger, model, filter);
|
|
77
|
-
if (replacedFilter) {
|
|
78
|
-
replacedFilters.push(replacedFilter);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return replacedFilters;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export function replaceModelIndexConditionEntityPropertyWithTableColumn(
|
|
86
|
-
logger: Logger,
|
|
87
|
-
model: RpdDataModel,
|
|
88
|
-
filter: RpdDataModelIndexOptions,
|
|
89
|
-
): RowFilterOptions {
|
|
90
|
-
const { operator } = filter;
|
|
91
|
-
const filterField = (filter as EntityNonRelationPropertyFilterOptions).field;
|
|
92
|
-
let property: RpdDataModelProperty = getEntityOwnPropertyByCode(model, filterField);
|
|
93
|
-
|
|
94
|
-
let filterValue = (filter as any).value;
|
|
95
|
-
|
|
96
|
-
let columnName = "";
|
|
97
|
-
if (property) {
|
|
98
|
-
if (isOneRelationProperty(property)) {
|
|
99
|
-
columnName = property.targetIdColumnName;
|
|
100
|
-
if (isPlainObject(filterValue)) {
|
|
101
|
-
filterValue = filterValue.id;
|
|
102
|
-
}
|
|
103
|
-
} else if (isManyRelationProperty(property)) {
|
|
104
|
-
logger.warn(`Index condition on many-relation property "${property.code}" is not supported.`);
|
|
105
|
-
return null;
|
|
106
|
-
} else {
|
|
107
|
-
columnName = property.columnName || property.code;
|
|
108
|
-
}
|
|
109
|
-
} else if ((operator as any) === "exists" || (operator as any) === "notExists") {
|
|
110
|
-
logger.warn(`"exists" and "notExists" operators are not supported in index conditions.`);
|
|
111
|
-
return null;
|
|
112
|
-
} else {
|
|
113
|
-
property = getEntityOwnProperty(model, (property) => {
|
|
114
|
-
return property.columnName === filterField;
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
if (property) {
|
|
118
|
-
columnName = property.columnName;
|
|
119
|
-
} else {
|
|
120
|
-
// may be relation property.
|
|
121
|
-
property = getEntityOwnProperty(model, (property) => {
|
|
122
|
-
return property.targetIdColumnName === filterField;
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
if (property) {
|
|
126
|
-
if (isManyRelationProperty(property)) {
|
|
127
|
-
logger.warn(`Index condition on many-relation property "${property.code}" is not supported.`);
|
|
128
|
-
return null;
|
|
129
|
-
}
|
|
130
|
-
columnName = property.targetIdColumnName;
|
|
131
|
-
if (isPlainObject(filterValue)) {
|
|
132
|
-
filterValue = filterValue.id;
|
|
133
|
-
}
|
|
134
|
-
} else {
|
|
135
|
-
logger.warn(`Unknown field "${filterField}" in index conditions.`);
|
|
136
|
-
return null;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// TODO: do not use `any` here
|
|
142
|
-
return {
|
|
143
|
-
operator: filter.operator,
|
|
144
|
-
field: columnName,
|
|
145
|
-
value: filterValue,
|
|
146
|
-
itemType: (filter as any).itemType,
|
|
147
|
-
} as RowFilterOptions;
|
|
148
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
EntityFilterOptions,
|
|
3
|
+
EntityNonRelationPropertyFilterOptions,
|
|
4
|
+
FindEntityExistenceFilterOptions,
|
|
5
|
+
FindEntityLogicalFilterOptions,
|
|
6
|
+
RpdDataModel,
|
|
7
|
+
RpdDataModelIndexOptions,
|
|
8
|
+
RpdDataModelProperty,
|
|
9
|
+
} from "~/types";
|
|
10
|
+
import { isNullOrUndefined } from "~/utilities/typeUtility";
|
|
11
|
+
import { getEntityOwnProperty, getEntityOwnPropertyByCode, isManyRelationProperty, isOneRelationProperty } from "./metaHelper";
|
|
12
|
+
import { IRpdServer } from "~/core/server";
|
|
13
|
+
import { isPlainObject } from "lodash";
|
|
14
|
+
import { RowFilterOptions } from "~/dataAccess/dataAccessTypes";
|
|
15
|
+
import { Logger } from "~/facilities/log/LogFacility";
|
|
16
|
+
|
|
17
|
+
export function removeFiltersWithNullValue(filters?: EntityFilterOptions[]) {
|
|
18
|
+
const result: EntityFilterOptions[] = [];
|
|
19
|
+
if (!filters) {
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
for (const filter of filters) {
|
|
24
|
+
const { operator } = filter;
|
|
25
|
+
|
|
26
|
+
switch (operator) {
|
|
27
|
+
case "null":
|
|
28
|
+
case "notNull":
|
|
29
|
+
result.push(filter);
|
|
30
|
+
break;
|
|
31
|
+
case "exists":
|
|
32
|
+
case "notExists":
|
|
33
|
+
case "and":
|
|
34
|
+
case "or":
|
|
35
|
+
const transformedFilter = transformFilterWithSubFilters(filter);
|
|
36
|
+
if (transformedFilter !== null) {
|
|
37
|
+
result.push(transformedFilter);
|
|
38
|
+
}
|
|
39
|
+
break;
|
|
40
|
+
default:
|
|
41
|
+
if (!isNullOrUndefined(filter.value)) {
|
|
42
|
+
result.push(filter);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return result;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function transformFilterWithSubFilters(
|
|
51
|
+
filter: FindEntityExistenceFilterOptions | FindEntityLogicalFilterOptions,
|
|
52
|
+
): FindEntityExistenceFilterOptions | FindEntityLogicalFilterOptions | null {
|
|
53
|
+
const subFilters = removeFiltersWithNullValue(filter.filters);
|
|
54
|
+
if (!subFilters.length) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
filter.filters = subFilters;
|
|
59
|
+
return filter;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export function convertModelIndexConditionsToRowFilterOptions(logger: Logger, model: RpdDataModel, filters: RpdDataModelIndexOptions[]) {
|
|
63
|
+
if (!filters || !filters.length) {
|
|
64
|
+
return [];
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const replacedFilters: RowFilterOptions[] = [];
|
|
68
|
+
for (const filter of filters) {
|
|
69
|
+
const { operator } = filter;
|
|
70
|
+
if (operator === "and" || operator === "or") {
|
|
71
|
+
replacedFilters.push({
|
|
72
|
+
operator: operator,
|
|
73
|
+
filters: convertModelIndexConditionsToRowFilterOptions(logger, model, filter.filters),
|
|
74
|
+
});
|
|
75
|
+
} else {
|
|
76
|
+
const replacedFilter = replaceModelIndexConditionEntityPropertyWithTableColumn(logger, model, filter);
|
|
77
|
+
if (replacedFilter) {
|
|
78
|
+
replacedFilters.push(replacedFilter);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return replacedFilters;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export function replaceModelIndexConditionEntityPropertyWithTableColumn(
|
|
86
|
+
logger: Logger,
|
|
87
|
+
model: RpdDataModel,
|
|
88
|
+
filter: RpdDataModelIndexOptions,
|
|
89
|
+
): RowFilterOptions {
|
|
90
|
+
const { operator } = filter;
|
|
91
|
+
const filterField = (filter as EntityNonRelationPropertyFilterOptions).field;
|
|
92
|
+
let property: RpdDataModelProperty = getEntityOwnPropertyByCode(model, filterField);
|
|
93
|
+
|
|
94
|
+
let filterValue = (filter as any).value;
|
|
95
|
+
|
|
96
|
+
let columnName = "";
|
|
97
|
+
if (property) {
|
|
98
|
+
if (isOneRelationProperty(property)) {
|
|
99
|
+
columnName = property.targetIdColumnName;
|
|
100
|
+
if (isPlainObject(filterValue)) {
|
|
101
|
+
filterValue = filterValue.id;
|
|
102
|
+
}
|
|
103
|
+
} else if (isManyRelationProperty(property)) {
|
|
104
|
+
logger.warn(`Index condition on many-relation property "${property.code}" is not supported.`);
|
|
105
|
+
return null;
|
|
106
|
+
} else {
|
|
107
|
+
columnName = property.columnName || property.code;
|
|
108
|
+
}
|
|
109
|
+
} else if ((operator as any) === "exists" || (operator as any) === "notExists") {
|
|
110
|
+
logger.warn(`"exists" and "notExists" operators are not supported in index conditions.`);
|
|
111
|
+
return null;
|
|
112
|
+
} else {
|
|
113
|
+
property = getEntityOwnProperty(model, (property) => {
|
|
114
|
+
return property.columnName === filterField;
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
if (property) {
|
|
118
|
+
columnName = property.columnName;
|
|
119
|
+
} else {
|
|
120
|
+
// may be relation property.
|
|
121
|
+
property = getEntityOwnProperty(model, (property) => {
|
|
122
|
+
return property.targetIdColumnName === filterField;
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
if (property) {
|
|
126
|
+
if (isManyRelationProperty(property)) {
|
|
127
|
+
logger.warn(`Index condition on many-relation property "${property.code}" is not supported.`);
|
|
128
|
+
return null;
|
|
129
|
+
}
|
|
130
|
+
columnName = property.targetIdColumnName;
|
|
131
|
+
if (isPlainObject(filterValue)) {
|
|
132
|
+
filterValue = filterValue.id;
|
|
133
|
+
}
|
|
134
|
+
} else {
|
|
135
|
+
logger.warn(`Unknown field "${filterField}" in index conditions.`);
|
|
136
|
+
return null;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
// TODO: do not use `any` here
|
|
142
|
+
return {
|
|
143
|
+
operator: filter.operator,
|
|
144
|
+
field: columnName,
|
|
145
|
+
value: filterValue,
|
|
146
|
+
itemType: (filter as any).itemType,
|
|
147
|
+
} as RowFilterOptions;
|
|
148
|
+
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { isArray, mergeWith } from "lodash";
|
|
2
|
-
|
|
3
|
-
export function mergeInput(defaultInput: any, input: any, fixedInput: any) {
|
|
4
|
-
return mergeWith({}, defaultInput, input, fixedInput, doNotMergeArray);
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
function doNotMergeArray(objValue: any, srcValue: any) {
|
|
8
|
-
if (isArray(srcValue)) {
|
|
9
|
-
return srcValue;
|
|
10
|
-
}
|
|
11
|
-
}
|
|
1
|
+
import { isArray, mergeWith } from "lodash";
|
|
2
|
+
|
|
3
|
+
export function mergeInput(defaultInput: any, input: any, fixedInput: any) {
|
|
4
|
+
return mergeWith({}, defaultInput, input, fixedInput, doNotMergeArray);
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
function doNotMergeArray(objValue: any, srcValue: any) {
|
|
8
|
+
if (isArray(srcValue)) {
|
|
9
|
+
return srcValue;
|
|
10
|
+
}
|
|
11
|
+
}
|