@ruiapp/rapid-core 0.1.63 → 0.1.66

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.
Files changed (166) hide show
  1. package/dist/helpers/entityHelpers.d.ts +3 -1
  2. package/dist/{dataAccess → helpers}/metaHelper.d.ts +3 -0
  3. package/dist/index.d.ts +2 -0
  4. package/dist/index.js +879 -154
  5. package/dist/plugins/setting/SettingPlugin.d.ts +21 -0
  6. package/dist/plugins/setting/SettingPluginTypes.d.ts +33 -0
  7. package/dist/plugins/setting/SettingService.d.ts +22 -0
  8. package/dist/plugins/setting/actionHandlers/getSystemSettingValues.d.ts +7 -0
  9. package/dist/plugins/setting/actionHandlers/getUserSettingValues.d.ts +7 -0
  10. package/dist/plugins/setting/actionHandlers/index.d.ts +4 -0
  11. package/dist/plugins/setting/models/SystemSettingGroupSetting.d.ts +3 -0
  12. package/dist/plugins/setting/models/SystemSettingItem.d.ts +3 -0
  13. package/dist/plugins/setting/models/SystemSettingItemSetting.d.ts +3 -0
  14. package/dist/plugins/setting/models/UserSettingGroupSetting.d.ts +3 -0
  15. package/dist/plugins/setting/models/UserSettingItem.d.ts +3 -0
  16. package/dist/plugins/setting/models/UserSettingItemSetting.d.ts +3 -0
  17. package/dist/plugins/setting/models/index.d.ts +2 -0
  18. package/dist/plugins/setting/routes/getSystemSettingValues.d.ts +12 -0
  19. package/dist/plugins/setting/routes/getUserSettingValues.d.ts +12 -0
  20. package/dist/plugins/setting/routes/index.d.ts +12 -0
  21. package/dist/types.d.ts +4 -0
  22. package/package.json +1 -1
  23. package/rollup.config.js +16 -16
  24. package/src/bootstrapApplicationConfig.ts +552 -545
  25. package/src/core/actionHandler.ts +22 -22
  26. package/src/core/eventManager.ts +20 -20
  27. package/src/core/facility.ts +7 -7
  28. package/src/core/http/formDataParser.ts +89 -89
  29. package/src/core/http-types.ts +4 -4
  30. package/src/core/pluginManager.ts +175 -175
  31. package/src/core/providers/runtimeProvider.ts +5 -5
  32. package/src/core/request.ts +86 -86
  33. package/src/core/response.ts +76 -76
  34. package/src/core/routeContext.ts +43 -43
  35. package/src/core/routesBuilder.ts +88 -88
  36. package/src/core/server.ts +16 -1
  37. package/src/dataAccess/dataAccessTypes.ts +109 -109
  38. package/src/dataAccess/dataAccessor.ts +137 -137
  39. package/src/dataAccess/entityManager.ts +1298 -1292
  40. package/src/dataAccess/entityMapper.ts +4 -5
  41. package/src/dataAccess/propertyMapper.ts +27 -27
  42. package/src/deno-std/assert/assert.ts +9 -9
  43. package/src/deno-std/assert/assertion_error.ts +7 -7
  44. package/src/deno-std/datetime/to_imf.ts +32 -32
  45. package/src/deno-std/encoding/base64.ts +141 -141
  46. package/src/deno-std/http/cookie.ts +8 -1
  47. package/src/facilities/log/LogFacility.ts +35 -35
  48. package/src/helpers/entityHelpers.ts +76 -21
  49. package/src/{dataAccess → helpers}/filterHelper.ts +3 -1
  50. package/src/helpers/inputHelper.ts +11 -11
  51. package/src/{dataAccess → helpers}/metaHelper.ts +15 -6
  52. package/src/helpers/runCollectionEntityActionHandler.ts +6 -1
  53. package/src/index.ts +44 -41
  54. package/src/plugins/auth/AuthPlugin.ts +7 -1
  55. package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
  56. package/src/plugins/auth/actionHandlers/createSession.ts +63 -63
  57. package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
  58. package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
  59. package/src/plugins/auth/actionHandlers/index.ts +8 -8
  60. package/src/plugins/auth/actionHandlers/resetPassword.ts +38 -38
  61. package/src/plugins/auth/models/AccessToken.ts +56 -56
  62. package/src/plugins/auth/models/index.ts +3 -3
  63. package/src/plugins/auth/routes/changePassword.ts +15 -15
  64. package/src/plugins/auth/routes/getMyProfile.ts +15 -15
  65. package/src/plugins/auth/routes/index.ts +7 -7
  66. package/src/plugins/auth/routes/resetPassword.ts +15 -15
  67. package/src/plugins/auth/routes/signin.ts +15 -15
  68. package/src/plugins/auth/routes/signout.ts +15 -15
  69. package/src/plugins/cronJob/CronJobPlugin.ts +7 -1
  70. package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
  71. package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
  72. package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
  73. package/src/plugins/cronJob/routes/index.ts +3 -3
  74. package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
  75. package/src/plugins/dataManage/DataManagePlugin.ts +7 -1
  76. package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +20 -20
  77. package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +15 -15
  78. package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
  79. package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
  80. package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +7 -4
  81. package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +26 -26
  82. package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +21 -21
  83. package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
  84. package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +20 -20
  85. package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +35 -35
  86. package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
  87. package/src/plugins/fileManage/FileManagePlugin.ts +7 -1
  88. package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +36 -36
  89. package/src/plugins/fileManage/actionHandlers/downloadFile.ts +28 -28
  90. package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
  91. package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
  92. package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
  93. package/src/plugins/fileManage/routes/index.ts +5 -5
  94. package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
  95. package/src/plugins/metaManage/MetaManagePlugin.ts +37 -9
  96. package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
  97. package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
  98. package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
  99. package/src/plugins/routeManage/RouteManagePlugin.ts +7 -1
  100. package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
  101. package/src/plugins/sequence/SequencePlugin.ts +8 -2
  102. package/src/plugins/sequence/SequencePluginTypes.ts +9 -1
  103. package/src/plugins/sequence/SequenceService.ts +81 -81
  104. package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
  105. package/src/plugins/sequence/actionHandlers/index.ts +4 -4
  106. package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
  107. package/src/plugins/sequence/models/SequenceRule.ts +42 -42
  108. package/src/plugins/sequence/models/index.ts +4 -4
  109. package/src/plugins/sequence/routes/generateSn.ts +15 -15
  110. package/src/plugins/sequence/routes/index.ts +3 -3
  111. package/src/plugins/sequence/segment-utility.ts +11 -11
  112. package/src/plugins/sequence/segments/autoIncrement.ts +6 -1
  113. package/src/plugins/sequence/segments/dayOfMonth.ts +6 -1
  114. package/src/plugins/sequence/segments/index.ts +9 -9
  115. package/src/plugins/sequence/segments/literal.ts +6 -1
  116. package/src/plugins/sequence/segments/month.ts +6 -1
  117. package/src/plugins/sequence/segments/parameter.ts +6 -1
  118. package/src/plugins/sequence/segments/year.ts +6 -1
  119. package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
  120. package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
  121. package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
  122. package/src/plugins/serverOperation/actionHandlers/runServerOperation.ts +15 -15
  123. package/src/plugins/setting/SettingPlugin.ts +68 -0
  124. package/src/plugins/setting/SettingPluginTypes.ts +37 -0
  125. package/src/plugins/setting/SettingService.ts +206 -0
  126. package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -0
  127. package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -0
  128. package/src/plugins/setting/actionHandlers/index.ts +5 -0
  129. package/src/plugins/setting/models/SystemSettingGroupSetting.ts +56 -0
  130. package/src/plugins/setting/models/SystemSettingItem.ts +42 -0
  131. package/src/plugins/setting/models/SystemSettingItemSetting.ts +72 -0
  132. package/src/plugins/setting/models/UserSettingGroupSetting.ts +56 -0
  133. package/src/plugins/setting/models/UserSettingItem.ts +49 -0
  134. package/src/plugins/setting/models/UserSettingItemSetting.ts +72 -0
  135. package/src/plugins/setting/models/index.ts +8 -0
  136. package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -0
  137. package/src/plugins/setting/routes/getUserSettingValues.ts +15 -0
  138. package/src/plugins/setting/routes/index.ts +4 -0
  139. package/src/plugins/stateMachine/StateMachinePlugin.ts +8 -2
  140. package/src/plugins/stateMachine/StateMachinePluginTypes.ts +9 -1
  141. package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
  142. package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +51 -51
  143. package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
  144. package/src/plugins/stateMachine/models/index.ts +3 -3
  145. package/src/plugins/stateMachine/routes/index.ts +3 -3
  146. package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
  147. package/src/plugins/stateMachine/stateMachineHelper.ts +36 -36
  148. package/src/plugins/webhooks/WebhooksPlugin.ts +13 -2
  149. package/src/plugins/webhooks/pluginConfig.ts +74 -74
  150. package/src/polyfill.ts +5 -5
  151. package/src/proxy/mod.ts +38 -38
  152. package/src/proxy/types.ts +21 -21
  153. package/src/queryBuilder/index.ts +1 -1
  154. package/src/queryBuilder/queryBuilder.ts +473 -473
  155. package/src/server.ts +23 -3
  156. package/src/types.ts +593 -589
  157. package/src/utilities/accessControlUtility.ts +33 -33
  158. package/src/utilities/errorUtility.ts +4 -6
  159. package/src/utilities/fsUtility.ts +61 -61
  160. package/src/utilities/httpUtility.ts +19 -19
  161. package/src/utilities/jwtUtility.ts +26 -26
  162. package/src/utilities/typeUtility.ts +11 -11
  163. package/tsconfig.json +19 -19
  164. package/dist/utilities/rapidUtility.d.ts +0 -2
  165. package/src/utilities/rapidUtility.ts +0 -5
  166. /package/dist/{dataAccess → helpers}/filterHelper.d.ts +0 -0
@@ -1,146 +1,146 @@
1
- import type { RpdApplicationConfig, RpdDataModelProperty } from "~/types";
2
-
3
- import {
4
- IRpdServer,
5
- RapidPlugin,
6
- RpdConfigurationItemOptions,
7
- RpdServerPluginConfigurableTargetOptions,
8
- RpdServerPluginExtendingAbilities,
9
- } from "~/core/server";
10
- import { find, set } from "lodash";
11
- import { ActionHandlerContext } from "~/core/actionHandler";
12
- import { isAccessAllowed } from "~/utilities/accessControlUtility";
13
- import { RouteContext } from "~/core/routeContext";
14
-
15
- class EntityAccessControlPlugin implements RapidPlugin {
16
- constructor() {}
17
-
18
- get code(): string {
19
- return "entityAccessControl";
20
- }
21
-
22
- get description(): string {
23
- return "";
24
- }
25
-
26
- get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
27
- return [];
28
- }
29
-
30
- get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
31
- return [];
32
- }
33
-
34
- get configurations(): RpdConfigurationItemOptions[] {
35
- return [];
36
- }
37
-
38
- async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
39
- const properties: RpdDataModelProperty[] = [
40
- {
41
- name: "permissionPolicies",
42
- code: "permissionPolicies",
43
- columnName: "permission_policies",
44
- type: "json",
45
- },
46
- ];
47
- server.appendModelProperties("model", properties);
48
- }
49
-
50
- async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
51
- const logger = server.getLogger();
52
- logger.info("Configuring entity access checking policies...");
53
-
54
- const routes = applicationConfig.routes;
55
- for (const route of routes) {
56
- const { actions } = route;
57
- if (!actions) {
58
- continue;
59
- }
60
-
61
- for (const action of route.actions) {
62
- if (action.code === "findCollectionEntityById" || action.code === "findCollectionEntities" || action.code === "countCollectionEntities") {
63
- const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
64
- if (!model) {
65
- continue;
66
- }
67
- const { permissionPolicies } = model;
68
- if (!permissionPolicies) {
69
- continue;
70
- }
71
- if (permissionPolicies.find) {
72
- set(action, "config.permissionCheck", permissionPolicies.find);
73
- }
74
- } else if (action.code === "createCollectionEntity" || action.code === "createCollectionEntitiesBatch") {
75
- const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
76
- if (!model) {
77
- continue;
78
- }
79
- const { permissionPolicies } = model;
80
- if (!permissionPolicies) {
81
- continue;
82
- }
83
- if (permissionPolicies.create) {
84
- set(action, "config.permissionCheck", permissionPolicies.create);
85
- }
86
- } else if (action.code === "updateCollectionEntityById" || action.code === "addEntityRelations" || action.code === "removeEntityRelations") {
87
- const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
88
- if (!model) {
89
- continue;
90
- }
91
- const { permissionPolicies } = model;
92
- if (!permissionPolicies) {
93
- continue;
94
- }
95
- if (permissionPolicies.update) {
96
- set(action, "config.permissionCheck", permissionPolicies.update);
97
- }
98
- } else if (action.code === "deleteCollectionEntityById") {
99
- const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
100
- if (!model) {
101
- continue;
102
- }
103
- const { permissionPolicies } = model;
104
- if (!permissionPolicies) {
105
- continue;
106
- }
107
- if (permissionPolicies.delete) {
108
- set(action, "config.permissionCheck", permissionPolicies.delete);
109
- }
110
- }
111
- }
112
- }
113
- }
114
-
115
- async onPrepareRouteContext(server: IRpdServer, routeContext: RouteContext) {
116
- const userId = routeContext.state.userId;
117
- if (!userId) {
118
- return;
119
- }
120
-
121
- const actions = await server.queryDatabaseObject(
122
- `select distinct a.* from sys_actions a
123
- inner join oc_role_sys_action_links ra on a.id = ra.action_id
124
- inner join oc_role_user_links ru on ru.role_id = ra.role_id
125
- where ru.user_id = $1;`,
126
- [userId],
127
- );
128
- routeContext.state.allowedActions = actions.map((item) => item.code);
129
- }
130
-
131
- async beforeRunRouteActions(server: IRpdServer, handlerContext: ActionHandlerContext): Promise<any> {
132
- // Check permission
133
- const { routerContext } = handlerContext;
134
- const { routeConfig } = routerContext;
135
- for (const actionConfig of routeConfig.actions) {
136
- const permissionCheck = actionConfig.config?.permissionCheck;
137
- if (permissionCheck) {
138
- if (!isAccessAllowed(permissionCheck, routerContext.state.allowedActions || [])) {
139
- throw new Error(`Your action of '${actionConfig.code}' is not permitted.`);
140
- }
141
- }
142
- }
143
- }
144
- }
145
-
146
- export default EntityAccessControlPlugin;
1
+ import type { RpdApplicationConfig, RpdDataModelProperty } from "~/types";
2
+
3
+ import {
4
+ IRpdServer,
5
+ RapidPlugin,
6
+ RpdConfigurationItemOptions,
7
+ RpdServerPluginConfigurableTargetOptions,
8
+ RpdServerPluginExtendingAbilities,
9
+ } from "~/core/server";
10
+ import { find, set } from "lodash";
11
+ import { ActionHandlerContext } from "~/core/actionHandler";
12
+ import { isAccessAllowed } from "~/utilities/accessControlUtility";
13
+ import { RouteContext } from "~/core/routeContext";
14
+
15
+ class EntityAccessControlPlugin implements RapidPlugin {
16
+ constructor() {}
17
+
18
+ get code(): string {
19
+ return "entityAccessControl";
20
+ }
21
+
22
+ get description(): string {
23
+ return "";
24
+ }
25
+
26
+ get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
27
+ return [];
28
+ }
29
+
30
+ get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
31
+ return [];
32
+ }
33
+
34
+ get configurations(): RpdConfigurationItemOptions[] {
35
+ return [];
36
+ }
37
+
38
+ async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
39
+ const properties: RpdDataModelProperty[] = [
40
+ {
41
+ name: "permissionPolicies",
42
+ code: "permissionPolicies",
43
+ columnName: "permission_policies",
44
+ type: "json",
45
+ },
46
+ ];
47
+ server.appendModelProperties("model", properties);
48
+ }
49
+
50
+ async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
51
+ const logger = server.getLogger();
52
+ logger.info("Configuring entity access checking policies...");
53
+
54
+ const routes = applicationConfig.routes;
55
+ for (const route of routes) {
56
+ const { actions } = route;
57
+ if (!actions) {
58
+ continue;
59
+ }
60
+
61
+ for (const action of route.actions) {
62
+ if (action.code === "findCollectionEntityById" || action.code === "findCollectionEntities" || action.code === "countCollectionEntities") {
63
+ const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
64
+ if (!model) {
65
+ continue;
66
+ }
67
+ const { permissionPolicies } = model;
68
+ if (!permissionPolicies) {
69
+ continue;
70
+ }
71
+ if (permissionPolicies.find) {
72
+ set(action, "config.permissionCheck", permissionPolicies.find);
73
+ }
74
+ } else if (action.code === "createCollectionEntity" || action.code === "createCollectionEntitiesBatch") {
75
+ const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
76
+ if (!model) {
77
+ continue;
78
+ }
79
+ const { permissionPolicies } = model;
80
+ if (!permissionPolicies) {
81
+ continue;
82
+ }
83
+ if (permissionPolicies.create) {
84
+ set(action, "config.permissionCheck", permissionPolicies.create);
85
+ }
86
+ } else if (action.code === "updateCollectionEntityById" || action.code === "addEntityRelations" || action.code === "removeEntityRelations") {
87
+ const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
88
+ if (!model) {
89
+ continue;
90
+ }
91
+ const { permissionPolicies } = model;
92
+ if (!permissionPolicies) {
93
+ continue;
94
+ }
95
+ if (permissionPolicies.update) {
96
+ set(action, "config.permissionCheck", permissionPolicies.update);
97
+ }
98
+ } else if (action.code === "deleteCollectionEntityById") {
99
+ const model = find(applicationConfig.models, (item) => item.singularCode === action.config.singularCode);
100
+ if (!model) {
101
+ continue;
102
+ }
103
+ const { permissionPolicies } = model;
104
+ if (!permissionPolicies) {
105
+ continue;
106
+ }
107
+ if (permissionPolicies.delete) {
108
+ set(action, "config.permissionCheck", permissionPolicies.delete);
109
+ }
110
+ }
111
+ }
112
+ }
113
+ }
114
+
115
+ async onPrepareRouteContext(server: IRpdServer, routeContext: RouteContext) {
116
+ const userId = routeContext.state.userId;
117
+ if (!userId) {
118
+ return;
119
+ }
120
+
121
+ const actions = await server.queryDatabaseObject(
122
+ `select distinct a.* from sys_actions a
123
+ inner join oc_role_sys_action_links ra on a.id = ra.action_id
124
+ inner join oc_role_user_links ru on ru.role_id = ra.role_id
125
+ where ru.user_id = $1;`,
126
+ [userId],
127
+ );
128
+ routeContext.state.allowedActions = actions.map((item) => item.code);
129
+ }
130
+
131
+ async beforeRunRouteActions(server: IRpdServer, handlerContext: ActionHandlerContext): Promise<any> {
132
+ // Check permission
133
+ const { routerContext } = handlerContext;
134
+ const { routeConfig } = routerContext;
135
+ for (const actionConfig of routeConfig.actions) {
136
+ const permissionCheck = actionConfig.config?.permissionCheck;
137
+ if (permissionCheck) {
138
+ if (!isAccessAllowed(permissionCheck, routerContext.state.allowedActions || [])) {
139
+ throw new Error(`Your action of '${actionConfig.code}' is not permitted.`);
140
+ }
141
+ }
142
+ }
143
+ }
144
+ }
145
+
146
+ export default EntityAccessControlPlugin;
@@ -7,7 +7,13 @@ import { RpdApplicationConfig } from "~/types";
7
7
  import * as downloadDocumentActionHandler from "./actionHandlers/downloadDocument";
8
8
  import * as downloadFileActionHandler from "./actionHandlers/downloadFile";
9
9
  import * as uploadFileActionHandler from "./actionHandlers/uploadFile";
10
- import { IRpdServer, RapidPlugin, RpdConfigurationItemOptions, RpdServerPluginConfigurableTargetOptions, RpdServerPluginExtendingAbilities } from "~/core/server";
10
+ import {
11
+ IRpdServer,
12
+ RapidPlugin,
13
+ RpdConfigurationItemOptions,
14
+ RpdServerPluginConfigurableTargetOptions,
15
+ RpdServerPluginExtendingAbilities,
16
+ } from "~/core/server";
11
17
 
12
18
  import pluginRoutes from "./routes";
13
19
 
@@ -1,36 +1,36 @@
1
- import path from "path";
2
- import { ActionHandlerContext } from "~/core/actionHandler";
3
- import { RapidPlugin } from "~/core/server";
4
- import { readFile } from "~/utilities/fsUtility";
5
-
6
- export const code = "downloadDocument";
7
-
8
- export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
9
- const { server, applicationConfig, routerContext, input } = ctx;
10
- const { request, response } = routerContext;
11
-
12
- const documentDataAccessor = ctx.server.getDataAccessor({
13
- singularCode: "ecm_document",
14
- });
15
- const storageDataAccessor = ctx.server.getDataAccessor({
16
- singularCode: "ecm_storage_object",
17
- });
18
-
19
- const document = await documentDataAccessor.findById(input.documentId);
20
- if (!document) {
21
- ctx.output = { error: new Error("Document not found.") };
22
- return;
23
- }
24
- const storageObject = await storageDataAccessor.findById(document.storage_object_id);
25
- if (!storageObject) {
26
- ctx.output = { error: new Error("Storage object not found.") };
27
- return;
28
- }
29
-
30
- const fileKey = storageObject.key;
31
- const filePathName = path.join(server.config.localFileStoragePath, fileKey);
32
- const attachmentFileName = document.name;
33
-
34
- response.body = await readFile(filePathName);
35
- response.headers.set("Content-Disposition", `attachment; filename="${encodeURIComponent(attachmentFileName)}"`);
36
- }
1
+ import path from "path";
2
+ import { ActionHandlerContext } from "~/core/actionHandler";
3
+ import { RapidPlugin } from "~/core/server";
4
+ import { readFile } from "~/utilities/fsUtility";
5
+
6
+ export const code = "downloadDocument";
7
+
8
+ export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
9
+ const { server, applicationConfig, routerContext, input } = ctx;
10
+ const { request, response } = routerContext;
11
+
12
+ const documentDataAccessor = ctx.server.getDataAccessor({
13
+ singularCode: "ecm_document",
14
+ });
15
+ const storageDataAccessor = ctx.server.getDataAccessor({
16
+ singularCode: "ecm_storage_object",
17
+ });
18
+
19
+ const document = await documentDataAccessor.findById(input.documentId);
20
+ if (!document) {
21
+ ctx.output = { error: new Error("Document not found.") };
22
+ return;
23
+ }
24
+ const storageObject = await storageDataAccessor.findById(document.storage_object_id);
25
+ if (!storageObject) {
26
+ ctx.output = { error: new Error("Storage object not found.") };
27
+ return;
28
+ }
29
+
30
+ const fileKey = storageObject.key;
31
+ const filePathName = path.join(server.config.localFileStoragePath, fileKey);
32
+ const attachmentFileName = document.name;
33
+
34
+ response.body = await readFile(filePathName);
35
+ response.headers.set("Content-Disposition", `attachment; filename="${encodeURIComponent(attachmentFileName)}"`);
36
+ }
@@ -1,28 +1,28 @@
1
- import path from "path";
2
- import { readFile } from "~/utilities/fsUtility";
3
- import { ActionHandlerContext } from "~/core/actionHandler";
4
- import { RapidPlugin } from "~/core/server";
5
-
6
- export const code = "downloadFile";
7
-
8
- export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
9
- const { server, applicationConfig, routerContext, input } = ctx;
10
- const { request, response } = routerContext;
11
-
12
- const dataAccessor = ctx.server.getDataAccessor({
13
- singularCode: "ecm_storage_object",
14
- });
15
-
16
- const storageObject = await dataAccessor.findById(input.fileId);
17
- if (!storageObject) {
18
- ctx.output = { error: new Error("Storage object not found.") };
19
- return;
20
- }
21
-
22
- const fileKey = storageObject.key;
23
- const filePathName = path.join(server.config.localFileStoragePath, fileKey);
24
- const attachmentFileName = input.fileName || path.basename(fileKey);
25
-
26
- response.body = await readFile(filePathName);
27
- response.headers.set("Content-Disposition", `attachment; filename="${encodeURIComponent(attachmentFileName)}"`);
28
- }
1
+ import path from "path";
2
+ import { readFile } from "~/utilities/fsUtility";
3
+ import { ActionHandlerContext } from "~/core/actionHandler";
4
+ import { RapidPlugin } from "~/core/server";
5
+
6
+ export const code = "downloadFile";
7
+
8
+ export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
9
+ const { server, applicationConfig, routerContext, input } = ctx;
10
+ const { request, response } = routerContext;
11
+
12
+ const dataAccessor = ctx.server.getDataAccessor({
13
+ singularCode: "ecm_storage_object",
14
+ });
15
+
16
+ const storageObject = await dataAccessor.findById(input.fileId);
17
+ if (!storageObject) {
18
+ ctx.output = { error: new Error("Storage object not found.") };
19
+ return;
20
+ }
21
+
22
+ const fileKey = storageObject.key;
23
+ const filePathName = path.join(server.config.localFileStoragePath, fileKey);
24
+ const attachmentFileName = input.fileName || path.basename(fileKey);
25
+
26
+ response.body = await readFile(filePathName);
27
+ response.headers.set("Content-Disposition", `attachment; filename="${encodeURIComponent(attachmentFileName)}"`);
28
+ }
@@ -1,33 +1,33 @@
1
- import { v1 as uuidv1 } from "uuid";
2
- import { appendFile } from "~/utilities/fsUtility";
3
- import { ActionHandlerContext } from "~/core/actionHandler";
4
- import path from "path";
5
- import { isArray } from "lodash";
6
- import { RapidPlugin } from "~/core/server";
7
-
8
- export const code = "uploadFile";
9
-
10
- export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
11
- const { server, applicationConfig, routerContext, input } = ctx;
12
- const { request, response } = routerContext;
13
-
14
- let file: File | File[] | null = input.file || input.files;
15
- if (isArray(file)) {
16
- file = file[0];
17
- }
18
-
19
- if (!file) {
20
- ctx.status = 400;
21
- ctx.output = { error: "File not found in request body." };
22
- return;
23
- }
24
-
25
- const extName = path.extname(file.name);
26
- const fileKey = `${uuidv1()}${extName}`;
27
- const filePathName = path.join(server.config.localFileStoragePath, fileKey);
28
-
29
- const fileBuffer = await file.arrayBuffer();
30
- await appendFile(filePathName, fileBuffer);
31
-
32
- ctx.output = { ok: true, fileKey };
33
- }
1
+ import { v1 as uuidv1 } from "uuid";
2
+ import { appendFile } from "~/utilities/fsUtility";
3
+ import { ActionHandlerContext } from "~/core/actionHandler";
4
+ import path from "path";
5
+ import { isArray } from "lodash";
6
+ import { RapidPlugin } from "~/core/server";
7
+
8
+ export const code = "uploadFile";
9
+
10
+ export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
11
+ const { server, applicationConfig, routerContext, input } = ctx;
12
+ const { request, response } = routerContext;
13
+
14
+ let file: File | File[] | null = input.file || input.files;
15
+ if (isArray(file)) {
16
+ file = file[0];
17
+ }
18
+
19
+ if (!file) {
20
+ ctx.status = 400;
21
+ ctx.output = { error: "File not found in request body." };
22
+ return;
23
+ }
24
+
25
+ const extName = path.extname(file.name);
26
+ const fileKey = `${uuidv1()}${extName}`;
27
+ const filePathName = path.join(server.config.localFileStoragePath, fileKey);
28
+
29
+ const fileBuffer = await file.arrayBuffer();
30
+ await appendFile(filePathName, fileBuffer);
31
+
32
+ ctx.output = { ok: true, fileKey };
33
+ }
@@ -1,15 +1,15 @@
1
- import { RpdRoute } from "~/types";
2
-
3
- export default {
4
- namespace: "ecm",
5
- name: "ecm.downloadDocument",
6
- code: "ecm.downloadDocument",
7
- type: "RESTful",
8
- method: "GET",
9
- endpoint: "/download/document",
10
- actions: [
11
- {
12
- code: "downloadDocument",
13
- },
14
- ],
15
- } satisfies RpdRoute;
1
+ import { RpdRoute } from "~/types";
2
+
3
+ export default {
4
+ namespace: "ecm",
5
+ name: "ecm.downloadDocument",
6
+ code: "ecm.downloadDocument",
7
+ type: "RESTful",
8
+ method: "GET",
9
+ endpoint: "/download/document",
10
+ actions: [
11
+ {
12
+ code: "downloadDocument",
13
+ },
14
+ ],
15
+ } satisfies RpdRoute;
@@ -1,15 +1,15 @@
1
- import { RpdRoute } from "~/types";
2
-
3
- export default {
4
- namespace: "ecm",
5
- name: "ecm.downloadFile",
6
- code: "ecm.downloadFile",
7
- type: "RESTful",
8
- method: "GET",
9
- endpoint: "/download/file",
10
- actions: [
11
- {
12
- code: "downloadFile",
13
- },
14
- ],
15
- } satisfies RpdRoute;
1
+ import { RpdRoute } from "~/types";
2
+
3
+ export default {
4
+ namespace: "ecm",
5
+ name: "ecm.downloadFile",
6
+ code: "ecm.downloadFile",
7
+ type: "RESTful",
8
+ method: "GET",
9
+ endpoint: "/download/file",
10
+ actions: [
11
+ {
12
+ code: "downloadFile",
13
+ },
14
+ ],
15
+ } satisfies RpdRoute;
@@ -1,5 +1,5 @@
1
- import getMyProfile from "./uploadFile";
2
- import signin from "./downloadFile";
3
- import signout from "./downloadDocument";
4
-
5
- export default [getMyProfile, signin, signout];
1
+ import getMyProfile from "./uploadFile";
2
+ import signin from "./downloadFile";
3
+ import signout from "./downloadDocument";
4
+
5
+ export default [getMyProfile, signin, signout];
@@ -1,15 +1,15 @@
1
- import { RpdRoute } from "~/types";
2
-
3
- export default {
4
- namespace: "ecm",
5
- name: "ecm.uploadFile",
6
- code: "ecm.uploadFile",
7
- type: "RESTful",
8
- method: "POST",
9
- endpoint: "/upload",
10
- actions: [
11
- {
12
- code: "uploadFile",
13
- },
14
- ],
15
- } satisfies RpdRoute;
1
+ import { RpdRoute } from "~/types";
2
+
3
+ export default {
4
+ namespace: "ecm",
5
+ name: "ecm.uploadFile",
6
+ code: "ecm.uploadFile",
7
+ type: "RESTful",
8
+ method: "POST",
9
+ endpoint: "/upload",
10
+ actions: [
11
+ {
12
+ code: "uploadFile",
13
+ },
14
+ ],
15
+ } satisfies RpdRoute;