@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,163 +1,163 @@
|
|
|
1
|
-
export type DataAccessPgColumnTypes =
|
|
2
|
-
| "int4"
|
|
3
|
-
| "int8"
|
|
4
|
-
| "float4"
|
|
5
|
-
| "float8"
|
|
6
|
-
| "decimal"
|
|
7
|
-
| "text"
|
|
8
|
-
| "text[]"
|
|
9
|
-
| "bool"
|
|
10
|
-
| "date"
|
|
11
|
-
| "time"
|
|
12
|
-
| "timestamptz"
|
|
13
|
-
| "jsonb";
|
|
14
|
-
|
|
15
|
-
export type RowFilterRelationalOperators =
|
|
16
|
-
| "eq"
|
|
17
|
-
| "ne"
|
|
18
|
-
| "lt"
|
|
19
|
-
| "lte"
|
|
20
|
-
| "gt"
|
|
21
|
-
| "gte"
|
|
22
|
-
| "contains"
|
|
23
|
-
| "notContains"
|
|
24
|
-
| "containsCS"
|
|
25
|
-
| "notContainsCS"
|
|
26
|
-
| "startsWith"
|
|
27
|
-
| "notStartsWith"
|
|
28
|
-
| "endsWith"
|
|
29
|
-
| "notEndsWith";
|
|
30
|
-
|
|
31
|
-
export type RowFilterArrayOperators = "arrayContains" | "arrayOverlap";
|
|
32
|
-
|
|
33
|
-
export type RowFilterSetOperators = "in" | "notIn";
|
|
34
|
-
|
|
35
|
-
export type RowFilterRangeOperators = "between";
|
|
36
|
-
|
|
37
|
-
export type RowFilterLogicalOperators = "or" | "and";
|
|
38
|
-
|
|
39
|
-
export type RowFilterUnaryOperators = "null" | "notNull";
|
|
40
|
-
|
|
41
|
-
export type RowFilterExistenceOperators = "exists" | "notExists";
|
|
42
|
-
|
|
43
|
-
export type RowFilterOperators =
|
|
44
|
-
| RowFilterRelationalOperators
|
|
45
|
-
| RowFilterArrayOperators
|
|
46
|
-
| RowFilterSetOperators
|
|
47
|
-
| RowFilterRangeOperators
|
|
48
|
-
| RowFilterLogicalOperators
|
|
49
|
-
| RowFilterUnaryOperators
|
|
50
|
-
| RowFilterExistenceOperators;
|
|
51
|
-
|
|
52
|
-
export type RowFilterOptions =
|
|
53
|
-
| FindRowRelationalFilterOptions
|
|
54
|
-
| FindRowArrayFilterOptions
|
|
55
|
-
| FindRowSetFilterOptions
|
|
56
|
-
| FindRowRangeFilterOptions
|
|
57
|
-
| FindRowLogicalFilterOptions
|
|
58
|
-
| FindRowUnaryFilterOptions
|
|
59
|
-
| FindRowExistenceFilterOptions;
|
|
60
|
-
|
|
61
|
-
export type RowNonRelationPropertyFilterOptions =
|
|
62
|
-
| FindRowRelationalFilterOptions
|
|
63
|
-
| FindRowArrayFilterOptions
|
|
64
|
-
| FindRowSetFilterOptions
|
|
65
|
-
| FindRowRangeFilterOptions
|
|
66
|
-
| FindRowUnaryFilterOptions;
|
|
67
|
-
|
|
68
|
-
export type ColumnSelectOptions = string | ColumnNameWithTableName;
|
|
69
|
-
|
|
70
|
-
export type ColumnNameWithTableName = {
|
|
71
|
-
name: string;
|
|
72
|
-
tableName?: string;
|
|
73
|
-
schema?: string;
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
export interface FindRowOptions {
|
|
77
|
-
filters?: RowFilterOptions[];
|
|
78
|
-
orderBy?: FindRowOrderByOptions[];
|
|
79
|
-
pagination?: FindRowPaginationOptions;
|
|
80
|
-
// TODO: may be `columns` is a better name.
|
|
81
|
-
fields?: ColumnSelectOptions[];
|
|
82
|
-
keepNonPropertyFields?: boolean;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export interface FindRowRelationalFilterOptions {
|
|
86
|
-
// TODO: may be `column` is a better name.
|
|
87
|
-
field: ColumnSelectOptions;
|
|
88
|
-
operator: RowFilterRelationalOperators;
|
|
89
|
-
value: any;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
export interface FindRowArrayFilterOptions {
|
|
93
|
-
field: ColumnSelectOptions;
|
|
94
|
-
operator: RowFilterArrayOperators;
|
|
95
|
-
value: any[];
|
|
96
|
-
itemType?: string;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
export interface FindRowSetFilterOptions {
|
|
100
|
-
field: ColumnSelectOptions;
|
|
101
|
-
operator: RowFilterSetOperators;
|
|
102
|
-
value: any[];
|
|
103
|
-
itemType?: string;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
export interface FindRowRangeFilterOptions {
|
|
107
|
-
field: ColumnSelectOptions;
|
|
108
|
-
operator: RowFilterRangeOperators;
|
|
109
|
-
value: any[];
|
|
110
|
-
itemType?: string;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
export interface FindRowLogicalFilterOptions {
|
|
114
|
-
operator: RowFilterLogicalOperators;
|
|
115
|
-
filters: RowFilterOptions[];
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
export interface FindRowUnaryFilterOptions {
|
|
119
|
-
field: ColumnSelectOptions;
|
|
120
|
-
operator: RowFilterUnaryOperators;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
export interface FindRowExistenceFilterOptions {
|
|
124
|
-
field: ColumnSelectOptions;
|
|
125
|
-
operator: RowFilterExistenceOperators;
|
|
126
|
-
filters: RowFilterOptions[];
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
export interface FindRowPaginationOptions {
|
|
130
|
-
offset: number;
|
|
131
|
-
limit: number;
|
|
132
|
-
withoutTotal?: boolean;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
export interface FindRowOrderByOptions {
|
|
136
|
-
/**
|
|
137
|
-
* 排序字段
|
|
138
|
-
*/
|
|
139
|
-
field: ColumnSelectOptions;
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* 是否倒序
|
|
143
|
-
*/
|
|
144
|
-
desc?: boolean;
|
|
145
|
-
|
|
146
|
-
/**
|
|
147
|
-
* 关系字段
|
|
148
|
-
*/
|
|
149
|
-
relationField?: ColumnNameWithTableName;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
export interface CountRowOptions {
|
|
153
|
-
filters?: RowFilterOptions[];
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
export interface UpdateRowOptions {
|
|
157
|
-
filters?: RowFilterOptions[];
|
|
158
|
-
entity: any;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
export interface DeleteRowOptions {
|
|
162
|
-
filters?: RowFilterOptions[];
|
|
163
|
-
}
|
|
1
|
+
export type DataAccessPgColumnTypes =
|
|
2
|
+
| "int4"
|
|
3
|
+
| "int8"
|
|
4
|
+
| "float4"
|
|
5
|
+
| "float8"
|
|
6
|
+
| "decimal"
|
|
7
|
+
| "text"
|
|
8
|
+
| "text[]"
|
|
9
|
+
| "bool"
|
|
10
|
+
| "date"
|
|
11
|
+
| "time"
|
|
12
|
+
| "timestamptz"
|
|
13
|
+
| "jsonb";
|
|
14
|
+
|
|
15
|
+
export type RowFilterRelationalOperators =
|
|
16
|
+
| "eq"
|
|
17
|
+
| "ne"
|
|
18
|
+
| "lt"
|
|
19
|
+
| "lte"
|
|
20
|
+
| "gt"
|
|
21
|
+
| "gte"
|
|
22
|
+
| "contains"
|
|
23
|
+
| "notContains"
|
|
24
|
+
| "containsCS"
|
|
25
|
+
| "notContainsCS"
|
|
26
|
+
| "startsWith"
|
|
27
|
+
| "notStartsWith"
|
|
28
|
+
| "endsWith"
|
|
29
|
+
| "notEndsWith";
|
|
30
|
+
|
|
31
|
+
export type RowFilterArrayOperators = "arrayContains" | "arrayOverlap";
|
|
32
|
+
|
|
33
|
+
export type RowFilterSetOperators = "in" | "notIn";
|
|
34
|
+
|
|
35
|
+
export type RowFilterRangeOperators = "between";
|
|
36
|
+
|
|
37
|
+
export type RowFilterLogicalOperators = "or" | "and";
|
|
38
|
+
|
|
39
|
+
export type RowFilterUnaryOperators = "null" | "notNull";
|
|
40
|
+
|
|
41
|
+
export type RowFilterExistenceOperators = "exists" | "notExists";
|
|
42
|
+
|
|
43
|
+
export type RowFilterOperators =
|
|
44
|
+
| RowFilterRelationalOperators
|
|
45
|
+
| RowFilterArrayOperators
|
|
46
|
+
| RowFilterSetOperators
|
|
47
|
+
| RowFilterRangeOperators
|
|
48
|
+
| RowFilterLogicalOperators
|
|
49
|
+
| RowFilterUnaryOperators
|
|
50
|
+
| RowFilterExistenceOperators;
|
|
51
|
+
|
|
52
|
+
export type RowFilterOptions =
|
|
53
|
+
| FindRowRelationalFilterOptions
|
|
54
|
+
| FindRowArrayFilterOptions
|
|
55
|
+
| FindRowSetFilterOptions
|
|
56
|
+
| FindRowRangeFilterOptions
|
|
57
|
+
| FindRowLogicalFilterOptions
|
|
58
|
+
| FindRowUnaryFilterOptions
|
|
59
|
+
| FindRowExistenceFilterOptions;
|
|
60
|
+
|
|
61
|
+
export type RowNonRelationPropertyFilterOptions =
|
|
62
|
+
| FindRowRelationalFilterOptions
|
|
63
|
+
| FindRowArrayFilterOptions
|
|
64
|
+
| FindRowSetFilterOptions
|
|
65
|
+
| FindRowRangeFilterOptions
|
|
66
|
+
| FindRowUnaryFilterOptions;
|
|
67
|
+
|
|
68
|
+
export type ColumnSelectOptions = string | ColumnNameWithTableName;
|
|
69
|
+
|
|
70
|
+
export type ColumnNameWithTableName = {
|
|
71
|
+
name: string;
|
|
72
|
+
tableName?: string;
|
|
73
|
+
schema?: string;
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
export interface FindRowOptions {
|
|
77
|
+
filters?: RowFilterOptions[];
|
|
78
|
+
orderBy?: FindRowOrderByOptions[];
|
|
79
|
+
pagination?: FindRowPaginationOptions;
|
|
80
|
+
// TODO: may be `columns` is a better name.
|
|
81
|
+
fields?: ColumnSelectOptions[];
|
|
82
|
+
keepNonPropertyFields?: boolean;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export interface FindRowRelationalFilterOptions {
|
|
86
|
+
// TODO: may be `column` is a better name.
|
|
87
|
+
field: ColumnSelectOptions;
|
|
88
|
+
operator: RowFilterRelationalOperators;
|
|
89
|
+
value: any;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export interface FindRowArrayFilterOptions {
|
|
93
|
+
field: ColumnSelectOptions;
|
|
94
|
+
operator: RowFilterArrayOperators;
|
|
95
|
+
value: any[];
|
|
96
|
+
itemType?: string;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
export interface FindRowSetFilterOptions {
|
|
100
|
+
field: ColumnSelectOptions;
|
|
101
|
+
operator: RowFilterSetOperators;
|
|
102
|
+
value: any[];
|
|
103
|
+
itemType?: string;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export interface FindRowRangeFilterOptions {
|
|
107
|
+
field: ColumnSelectOptions;
|
|
108
|
+
operator: RowFilterRangeOperators;
|
|
109
|
+
value: any[];
|
|
110
|
+
itemType?: string;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
export interface FindRowLogicalFilterOptions {
|
|
114
|
+
operator: RowFilterLogicalOperators;
|
|
115
|
+
filters: RowFilterOptions[];
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export interface FindRowUnaryFilterOptions {
|
|
119
|
+
field: ColumnSelectOptions;
|
|
120
|
+
operator: RowFilterUnaryOperators;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
export interface FindRowExistenceFilterOptions {
|
|
124
|
+
field: ColumnSelectOptions;
|
|
125
|
+
operator: RowFilterExistenceOperators;
|
|
126
|
+
filters: RowFilterOptions[];
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export interface FindRowPaginationOptions {
|
|
130
|
+
offset: number;
|
|
131
|
+
limit: number;
|
|
132
|
+
withoutTotal?: boolean;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
export interface FindRowOrderByOptions {
|
|
136
|
+
/**
|
|
137
|
+
* 排序字段
|
|
138
|
+
*/
|
|
139
|
+
field: ColumnSelectOptions;
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* 是否倒序
|
|
143
|
+
*/
|
|
144
|
+
desc?: boolean;
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* 关系字段
|
|
148
|
+
*/
|
|
149
|
+
relationField?: ColumnNameWithTableName;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
export interface CountRowOptions {
|
|
153
|
+
filters?: RowFilterOptions[];
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
export interface UpdateRowOptions {
|
|
157
|
+
filters?: RowFilterOptions[];
|
|
158
|
+
entity: any;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
export interface DeleteRowOptions {
|
|
162
|
+
filters?: RowFilterOptions[];
|
|
163
|
+
}
|
|
@@ -1,135 +1,135 @@
|
|
|
1
|
-
import { CreateEntityOptions, IRpdDataAccessor, RpdDataModel, IDatabaseAccessor, DatabaseQuery, IDatabaseClient } from "~/types";
|
|
2
|
-
import QueryBuilder from "~/queryBuilder/queryBuilder";
|
|
3
|
-
import { first, set } from "lodash";
|
|
4
|
-
import { IRpdServer } from "~/core/server";
|
|
5
|
-
import { Logger } from "~/facilities/log/LogFacility";
|
|
6
|
-
import { newDatabaseError } from "~/utilities/errorUtility";
|
|
7
|
-
import { CountRowOptions, FindRowOptions, UpdateRowOptions } from "./dataAccessTypes";
|
|
8
|
-
|
|
9
|
-
export interface IDataAccessorOptions {
|
|
10
|
-
model: RpdDataModel;
|
|
11
|
-
queryBuilder: QueryBuilder;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export default class DataAccessor<T = any> implements IRpdDataAccessor<T> {
|
|
15
|
-
#logger: Logger;
|
|
16
|
-
#model: RpdDataModel;
|
|
17
|
-
#queryBuilder: QueryBuilder;
|
|
18
|
-
#server: IRpdServer;
|
|
19
|
-
#databaseAccessor: IDatabaseAccessor;
|
|
20
|
-
|
|
21
|
-
constructor(server: IRpdServer, databaseAccessor: IDatabaseAccessor, options: IDataAccessorOptions) {
|
|
22
|
-
this.#server = server;
|
|
23
|
-
this.#logger = server.getLogger();
|
|
24
|
-
this.#databaseAccessor = databaseAccessor;
|
|
25
|
-
this.#queryBuilder = options.queryBuilder;
|
|
26
|
-
this.#model = options.model;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
getModel() {
|
|
30
|
-
return this.#model;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
async create(entity: Partial<T>, databaseClient: IDatabaseClient | null): Promise<T> {
|
|
34
|
-
const options: CreateEntityOptions = {
|
|
35
|
-
entity,
|
|
36
|
-
};
|
|
37
|
-
const query = this.#queryBuilder.insert(this.#model, options);
|
|
38
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
39
|
-
return first(result);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
async updateById(id: any, entity: Partial<T>, databaseClient: IDatabaseClient | null): Promise<{ count: number }> {
|
|
43
|
-
const options: UpdateRowOptions = {
|
|
44
|
-
entity,
|
|
45
|
-
filters: [
|
|
46
|
-
{
|
|
47
|
-
field: {
|
|
48
|
-
name: "id",
|
|
49
|
-
},
|
|
50
|
-
operator: "eq",
|
|
51
|
-
value: id,
|
|
52
|
-
},
|
|
53
|
-
],
|
|
54
|
-
};
|
|
55
|
-
const query = this.#queryBuilder.update(this.#model, options);
|
|
56
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
57
|
-
return first(result);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
async find(options: FindRowOptions, databaseClient: IDatabaseClient | null): Promise<T[]> {
|
|
61
|
-
this.#logger.debug(`Finding '${this.#model.singularCode}' entity.`, { options });
|
|
62
|
-
let query: DatabaseQuery;
|
|
63
|
-
if (this.#model.base) {
|
|
64
|
-
const baseModel = this.#server.getModel({
|
|
65
|
-
singularCode: this.#model.base,
|
|
66
|
-
});
|
|
67
|
-
query = this.#queryBuilder.selectDerived(this.#model, baseModel, options);
|
|
68
|
-
} else {
|
|
69
|
-
query = this.#queryBuilder.select(this.#model, options);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
try {
|
|
73
|
-
return await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
74
|
-
} catch (err) {
|
|
75
|
-
throw newDatabaseError(`Failed to find entities. ${err.message}`, err);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
async findOne(options: FindRowOptions, databaseClient: IDatabaseClient | null): Promise<T> {
|
|
80
|
-
set(options, "pagination.limit", 1);
|
|
81
|
-
const list = await this.find(options, databaseClient);
|
|
82
|
-
return first(list);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
async findById(id: any, databaseClient: IDatabaseClient | null): Promise<T | null> {
|
|
86
|
-
const options: FindRowOptions = {
|
|
87
|
-
filters: [
|
|
88
|
-
{
|
|
89
|
-
field: {
|
|
90
|
-
name: "id",
|
|
91
|
-
},
|
|
92
|
-
operator: "eq",
|
|
93
|
-
value: id,
|
|
94
|
-
},
|
|
95
|
-
],
|
|
96
|
-
};
|
|
97
|
-
const result = await this.findOne(options, databaseClient);
|
|
98
|
-
return result;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
async count(options: CountRowOptions, databaseClient: IDatabaseClient | null): Promise<number> {
|
|
102
|
-
let query: DatabaseQuery;
|
|
103
|
-
if (this.#model.base) {
|
|
104
|
-
const baseModel = this.#server.getModel({
|
|
105
|
-
singularCode: this.#model.base,
|
|
106
|
-
});
|
|
107
|
-
query = this.#queryBuilder.countDerived(this.#model, baseModel, options);
|
|
108
|
-
} else {
|
|
109
|
-
query = this.#queryBuilder.count(this.#model, options);
|
|
110
|
-
}
|
|
111
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
112
|
-
|
|
113
|
-
const row = first(result);
|
|
114
|
-
if (row) {
|
|
115
|
-
return row.count;
|
|
116
|
-
}
|
|
117
|
-
return 0;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
async deleteById(id: any, databaseClient: IDatabaseClient | null) {
|
|
121
|
-
const options: FindRowOptions = {
|
|
122
|
-
filters: [
|
|
123
|
-
{
|
|
124
|
-
field: {
|
|
125
|
-
name: "id",
|
|
126
|
-
},
|
|
127
|
-
operator: "eq",
|
|
128
|
-
value: id,
|
|
129
|
-
},
|
|
130
|
-
],
|
|
131
|
-
};
|
|
132
|
-
const query = this.#queryBuilder.delete(this.#model, options);
|
|
133
|
-
await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
134
|
-
}
|
|
135
|
-
}
|
|
1
|
+
import { CreateEntityOptions, IRpdDataAccessor, RpdDataModel, IDatabaseAccessor, DatabaseQuery, IDatabaseClient } from "~/types";
|
|
2
|
+
import QueryBuilder from "~/queryBuilder/queryBuilder";
|
|
3
|
+
import { first, set } from "lodash";
|
|
4
|
+
import { IRpdServer } from "~/core/server";
|
|
5
|
+
import { Logger } from "~/facilities/log/LogFacility";
|
|
6
|
+
import { newDatabaseError } from "~/utilities/errorUtility";
|
|
7
|
+
import { CountRowOptions, FindRowOptions, UpdateRowOptions } from "./dataAccessTypes";
|
|
8
|
+
|
|
9
|
+
export interface IDataAccessorOptions {
|
|
10
|
+
model: RpdDataModel;
|
|
11
|
+
queryBuilder: QueryBuilder;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default class DataAccessor<T = any> implements IRpdDataAccessor<T> {
|
|
15
|
+
#logger: Logger;
|
|
16
|
+
#model: RpdDataModel;
|
|
17
|
+
#queryBuilder: QueryBuilder;
|
|
18
|
+
#server: IRpdServer;
|
|
19
|
+
#databaseAccessor: IDatabaseAccessor;
|
|
20
|
+
|
|
21
|
+
constructor(server: IRpdServer, databaseAccessor: IDatabaseAccessor, options: IDataAccessorOptions) {
|
|
22
|
+
this.#server = server;
|
|
23
|
+
this.#logger = server.getLogger();
|
|
24
|
+
this.#databaseAccessor = databaseAccessor;
|
|
25
|
+
this.#queryBuilder = options.queryBuilder;
|
|
26
|
+
this.#model = options.model;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
getModel() {
|
|
30
|
+
return this.#model;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
async create(entity: Partial<T>, databaseClient: IDatabaseClient | null): Promise<T> {
|
|
34
|
+
const options: CreateEntityOptions = {
|
|
35
|
+
entity,
|
|
36
|
+
};
|
|
37
|
+
const query = this.#queryBuilder.insert(this.#model, options);
|
|
38
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
39
|
+
return first(result);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
async updateById(id: any, entity: Partial<T>, databaseClient: IDatabaseClient | null): Promise<{ count: number }> {
|
|
43
|
+
const options: UpdateRowOptions = {
|
|
44
|
+
entity,
|
|
45
|
+
filters: [
|
|
46
|
+
{
|
|
47
|
+
field: {
|
|
48
|
+
name: "id",
|
|
49
|
+
},
|
|
50
|
+
operator: "eq",
|
|
51
|
+
value: id,
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
};
|
|
55
|
+
const query = this.#queryBuilder.update(this.#model, options);
|
|
56
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
57
|
+
return first(result);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
async find(options: FindRowOptions, databaseClient: IDatabaseClient | null): Promise<T[]> {
|
|
61
|
+
this.#logger.debug(`Finding '${this.#model.singularCode}' entity.`, { options });
|
|
62
|
+
let query: DatabaseQuery;
|
|
63
|
+
if (this.#model.base) {
|
|
64
|
+
const baseModel = this.#server.getModel({
|
|
65
|
+
singularCode: this.#model.base,
|
|
66
|
+
});
|
|
67
|
+
query = this.#queryBuilder.selectDerived(this.#model, baseModel, options);
|
|
68
|
+
} else {
|
|
69
|
+
query = this.#queryBuilder.select(this.#model, options);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
try {
|
|
73
|
+
return await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
74
|
+
} catch (err) {
|
|
75
|
+
throw newDatabaseError(`Failed to find entities. ${err.message}`, err);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
async findOne(options: FindRowOptions, databaseClient: IDatabaseClient | null): Promise<T> {
|
|
80
|
+
set(options, "pagination.limit", 1);
|
|
81
|
+
const list = await this.find(options, databaseClient);
|
|
82
|
+
return first(list);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
async findById(id: any, databaseClient: IDatabaseClient | null): Promise<T | null> {
|
|
86
|
+
const options: FindRowOptions = {
|
|
87
|
+
filters: [
|
|
88
|
+
{
|
|
89
|
+
field: {
|
|
90
|
+
name: "id",
|
|
91
|
+
},
|
|
92
|
+
operator: "eq",
|
|
93
|
+
value: id,
|
|
94
|
+
},
|
|
95
|
+
],
|
|
96
|
+
};
|
|
97
|
+
const result = await this.findOne(options, databaseClient);
|
|
98
|
+
return result;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
async count(options: CountRowOptions, databaseClient: IDatabaseClient | null): Promise<number> {
|
|
102
|
+
let query: DatabaseQuery;
|
|
103
|
+
if (this.#model.base) {
|
|
104
|
+
const baseModel = this.#server.getModel({
|
|
105
|
+
singularCode: this.#model.base,
|
|
106
|
+
});
|
|
107
|
+
query = this.#queryBuilder.countDerived(this.#model, baseModel, options);
|
|
108
|
+
} else {
|
|
109
|
+
query = this.#queryBuilder.count(this.#model, options);
|
|
110
|
+
}
|
|
111
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
112
|
+
|
|
113
|
+
const row = first(result);
|
|
114
|
+
if (row) {
|
|
115
|
+
return row.count;
|
|
116
|
+
}
|
|
117
|
+
return 0;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
async deleteById(id: any, databaseClient: IDatabaseClient | null) {
|
|
121
|
+
const options: FindRowOptions = {
|
|
122
|
+
filters: [
|
|
123
|
+
{
|
|
124
|
+
field: {
|
|
125
|
+
name: "id",
|
|
126
|
+
},
|
|
127
|
+
operator: "eq",
|
|
128
|
+
value: id,
|
|
129
|
+
},
|
|
130
|
+
],
|
|
131
|
+
};
|
|
132
|
+
const query = this.#queryBuilder.delete(this.#model, options);
|
|
133
|
+
await this.#databaseAccessor.queryDatabaseObject(query.command, query.params, databaseClient);
|
|
134
|
+
}
|
|
135
|
+
}
|