@ruiapp/rapid-core 0.1.79 → 0.1.81
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +83 -42
- package/dist/plugins/dataManage/actionHandlers/deleteCollectionEntities.d.ts +8 -0
- package/package.json +1 -1
- package/rollup.config.js +16 -16
- package/src/core/actionHandler.ts +22 -22
- package/src/core/eventManager.ts +20 -20
- package/src/core/facility.ts +7 -7
- package/src/core/http/formDataParser.ts +89 -89
- package/src/core/pluginManager.ts +175 -175
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +86 -86
- package/src/core/response.ts +76 -76
- package/src/core/routeContext.ts +43 -43
- package/src/core/routesBuilder.ts +88 -88
- package/src/dataAccess/dataAccessor.ts +137 -137
- package/src/deno-std/datetime/to_imf.ts +32 -32
- package/src/deno-std/encoding/base64.ts +141 -141
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
- package/src/plugins/auth/actionHandlers/createSession.ts +63 -63
- package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
- package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
- package/src/plugins/auth/actionHandlers/index.ts +8 -8
- package/src/plugins/auth/actionHandlers/resetPassword.ts +38 -38
- package/src/plugins/auth/models/AccessToken.ts +56 -56
- package/src/plugins/auth/models/index.ts +3 -3
- package/src/plugins/auth/routes/changePassword.ts +15 -15
- package/src/plugins/auth/routes/getMyProfile.ts +15 -15
- package/src/plugins/auth/routes/index.ts +7 -7
- package/src/plugins/auth/routes/resetPassword.ts +15 -15
- package/src/plugins/auth/routes/signin.ts +15 -15
- package/src/plugins/auth/routes/signout.ts +15 -15
- package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
- package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
- package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
- package/src/plugins/cronJob/routes/index.ts +3 -3
- package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
- package/src/plugins/dataManage/DataManagePlugin.ts +8 -0
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +38 -0
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +26 -26
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +21 -21
- package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +35 -35
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +1 -1
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +36 -36
- package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
- package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
- package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
- package/src/plugins/fileManage/routes/index.ts +5 -5
- package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
- package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
- package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/sequence/SequenceService.ts +81 -81
- package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
- package/src/plugins/sequence/actionHandlers/index.ts +4 -4
- package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
- package/src/plugins/sequence/models/SequenceRule.ts +42 -42
- package/src/plugins/sequence/models/index.ts +4 -4
- package/src/plugins/sequence/routes/generateSn.ts +15 -15
- package/src/plugins/sequence/routes/index.ts +3 -3
- package/src/plugins/sequence/segment-utility.ts +11 -11
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
- package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
- package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
- package/src/plugins/setting/SettingService.ts +213 -213
- package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
- package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
- package/src/plugins/setting/actionHandlers/index.ts +6 -6
- package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
- package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/SystemSettingItem.ts +42 -42
- package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/UserSettingItem.ts +49 -49
- package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/index.ts +8 -8
- package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
- package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
- package/src/plugins/setting/routes/index.ts +5 -5
- package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
- package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +51 -51
- package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
- package/src/plugins/stateMachine/models/index.ts +3 -3
- package/src/plugins/stateMachine/routes/index.ts +3 -3
- package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
- package/src/polyfill.ts +5 -5
- package/src/proxy/mod.ts +38 -38
- package/src/queryBuilder/queryBuilder.ts +5 -1
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/fsUtility.ts +61 -61
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/timeUtility.ts +9 -9
- package/tsconfig.json +19 -19
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
import { RpdDataModel } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
maintainedBy: "authManager",
|
|
5
|
-
namespace: "auth",
|
|
6
|
-
name: "access_token",
|
|
7
|
-
singularCode: "access_token",
|
|
8
|
-
pluralCode: "access_tokens",
|
|
9
|
-
schema: "public",
|
|
10
|
-
tableName: "access_tokens",
|
|
11
|
-
properties: [
|
|
12
|
-
{
|
|
13
|
-
name: "id",
|
|
14
|
-
code: "id",
|
|
15
|
-
columnName: "id",
|
|
16
|
-
type: "integer",
|
|
17
|
-
required: true,
|
|
18
|
-
autoIncrement: true,
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
name: "token",
|
|
22
|
-
code: "token",
|
|
23
|
-
columnName: "token",
|
|
24
|
-
type: "text",
|
|
25
|
-
required: true,
|
|
26
|
-
},
|
|
27
|
-
{
|
|
28
|
-
name: "description",
|
|
29
|
-
code: "description",
|
|
30
|
-
columnName: "description",
|
|
31
|
-
type: "text",
|
|
32
|
-
required: false,
|
|
33
|
-
},
|
|
34
|
-
{
|
|
35
|
-
name: "ownerType",
|
|
36
|
-
code: "ownerType",
|
|
37
|
-
columnName: "owner_type",
|
|
38
|
-
type: "text",
|
|
39
|
-
required: true,
|
|
40
|
-
},
|
|
41
|
-
{
|
|
42
|
-
name: "ownerId",
|
|
43
|
-
code: "ownerId",
|
|
44
|
-
columnName: "owner_id",
|
|
45
|
-
type: "integer",
|
|
46
|
-
required: true,
|
|
47
|
-
},
|
|
48
|
-
{
|
|
49
|
-
name: "expirationTime",
|
|
50
|
-
code: "expirationTime",
|
|
51
|
-
columnName: "expiration_time",
|
|
52
|
-
type: "datetime",
|
|
53
|
-
required: true,
|
|
54
|
-
},
|
|
55
|
-
],
|
|
56
|
-
} as RpdDataModel;
|
|
1
|
+
import { RpdDataModel } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
maintainedBy: "authManager",
|
|
5
|
+
namespace: "auth",
|
|
6
|
+
name: "access_token",
|
|
7
|
+
singularCode: "access_token",
|
|
8
|
+
pluralCode: "access_tokens",
|
|
9
|
+
schema: "public",
|
|
10
|
+
tableName: "access_tokens",
|
|
11
|
+
properties: [
|
|
12
|
+
{
|
|
13
|
+
name: "id",
|
|
14
|
+
code: "id",
|
|
15
|
+
columnName: "id",
|
|
16
|
+
type: "integer",
|
|
17
|
+
required: true,
|
|
18
|
+
autoIncrement: true,
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
name: "token",
|
|
22
|
+
code: "token",
|
|
23
|
+
columnName: "token",
|
|
24
|
+
type: "text",
|
|
25
|
+
required: true,
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
name: "description",
|
|
29
|
+
code: "description",
|
|
30
|
+
columnName: "description",
|
|
31
|
+
type: "text",
|
|
32
|
+
required: false,
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
name: "ownerType",
|
|
36
|
+
code: "ownerType",
|
|
37
|
+
columnName: "owner_type",
|
|
38
|
+
type: "text",
|
|
39
|
+
required: true,
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
name: "ownerId",
|
|
43
|
+
code: "ownerId",
|
|
44
|
+
columnName: "owner_id",
|
|
45
|
+
type: "integer",
|
|
46
|
+
required: true,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
name: "expirationTime",
|
|
50
|
+
code: "expirationTime",
|
|
51
|
+
columnName: "expiration_time",
|
|
52
|
+
type: "datetime",
|
|
53
|
+
required: true,
|
|
54
|
+
},
|
|
55
|
+
],
|
|
56
|
+
} as RpdDataModel;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import AccessToken from "./AccessToken";
|
|
2
|
-
|
|
3
|
-
export default [AccessToken];
|
|
1
|
+
import AccessToken from "./AccessToken";
|
|
2
|
+
|
|
3
|
+
export default [AccessToken];
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "auth",
|
|
5
|
-
name: "auth.changePassword",
|
|
6
|
-
code: "auth.changePassword",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "POST",
|
|
9
|
-
endpoint: "/changePassword",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "changePassword",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "auth",
|
|
5
|
+
name: "auth.changePassword",
|
|
6
|
+
code: "auth.changePassword",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "POST",
|
|
9
|
+
endpoint: "/changePassword",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "changePassword",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "auth",
|
|
5
|
-
name: "auth.getMyProfile",
|
|
6
|
-
code: "auth.getMyProfile",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "GET",
|
|
9
|
-
endpoint: "/me",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "getMyProfile",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "auth",
|
|
5
|
+
name: "auth.getMyProfile",
|
|
6
|
+
code: "auth.getMyProfile",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "GET",
|
|
9
|
+
endpoint: "/me",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "getMyProfile",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import changePassword from "./changePassword";
|
|
2
|
-
import getMyProfile from "./getMyProfile";
|
|
3
|
-
import resetPassword from "./resetPassword";
|
|
4
|
-
import signin from "./signin";
|
|
5
|
-
import signout from "./signout";
|
|
6
|
-
|
|
7
|
-
export default [changePassword, getMyProfile, resetPassword, signin, signout];
|
|
1
|
+
import changePassword from "./changePassword";
|
|
2
|
+
import getMyProfile from "./getMyProfile";
|
|
3
|
+
import resetPassword from "./resetPassword";
|
|
4
|
+
import signin from "./signin";
|
|
5
|
+
import signout from "./signout";
|
|
6
|
+
|
|
7
|
+
export default [changePassword, getMyProfile, resetPassword, signin, signout];
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "auth",
|
|
5
|
-
name: "auth.resetPassword",
|
|
6
|
-
code: "auth.resetPassword",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "POST",
|
|
9
|
-
endpoint: "/resetPassword",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "resetPassword",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "auth",
|
|
5
|
+
name: "auth.resetPassword",
|
|
6
|
+
code: "auth.resetPassword",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "POST",
|
|
9
|
+
endpoint: "/resetPassword",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "resetPassword",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "auth",
|
|
5
|
-
name: "auth.signin",
|
|
6
|
-
code: "auth.signin",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "POST",
|
|
9
|
-
endpoint: "/signin",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "createSession",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "auth",
|
|
5
|
+
name: "auth.signin",
|
|
6
|
+
code: "auth.signin",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "POST",
|
|
9
|
+
endpoint: "/signin",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "createSession",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "auth",
|
|
5
|
-
name: "auth.signout",
|
|
6
|
-
code: "auth.signout",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "GET",
|
|
9
|
-
endpoint: "/signout",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "deleteSession",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "auth",
|
|
5
|
+
name: "auth.signout",
|
|
6
|
+
code: "auth.signout",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "GET",
|
|
9
|
+
endpoint: "/signout",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "deleteSession",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RpdHttpMethod } from "~/types";
|
|
3
|
-
|
|
4
|
-
export interface CronJobConfiguration {
|
|
5
|
-
/**
|
|
6
|
-
* 定时任务编号
|
|
7
|
-
*/
|
|
8
|
-
code: string;
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* 定时任务描述
|
|
12
|
-
*/
|
|
13
|
-
description?: string;
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* crontab 表达式
|
|
17
|
-
*/
|
|
18
|
-
cronTime: string;
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* 任务处理程序编号。当指定处理程序编号时,忽略 handler 配置。
|
|
22
|
-
*/
|
|
23
|
-
actionHandlerCode?: string;
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* 定时任务处理程序
|
|
27
|
-
* @param ctx
|
|
28
|
-
* @param options
|
|
29
|
-
* @returns
|
|
30
|
-
*/
|
|
31
|
-
handler?: (ctx: ActionHandlerContext, options: any) => Promise<void>;
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* 处理定时任务时的设置选项
|
|
35
|
-
*/
|
|
36
|
-
handleOptions?: any;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export interface CronJobPluginInitOptions {
|
|
40
|
-
jobs: CronJobConfiguration[];
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export type RunCronJobActionHandlerOptions = {
|
|
44
|
-
code?: string;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
export type RunCronJobInput = {
|
|
48
|
-
code?: string;
|
|
49
|
-
};
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RpdHttpMethod } from "~/types";
|
|
3
|
+
|
|
4
|
+
export interface CronJobConfiguration {
|
|
5
|
+
/**
|
|
6
|
+
* 定时任务编号
|
|
7
|
+
*/
|
|
8
|
+
code: string;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* 定时任务描述
|
|
12
|
+
*/
|
|
13
|
+
description?: string;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* crontab 表达式
|
|
17
|
+
*/
|
|
18
|
+
cronTime: string;
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* 任务处理程序编号。当指定处理程序编号时,忽略 handler 配置。
|
|
22
|
+
*/
|
|
23
|
+
actionHandlerCode?: string;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* 定时任务处理程序
|
|
27
|
+
* @param ctx
|
|
28
|
+
* @param options
|
|
29
|
+
* @returns
|
|
30
|
+
*/
|
|
31
|
+
handler?: (ctx: ActionHandlerContext, options: any) => Promise<void>;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* 处理定时任务时的设置选项
|
|
35
|
+
*/
|
|
36
|
+
handleOptions?: any;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export interface CronJobPluginInitOptions {
|
|
40
|
+
jobs: CronJobConfiguration[];
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export type RunCronJobActionHandlerOptions = {
|
|
44
|
+
code?: string;
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export type RunCronJobInput = {
|
|
48
|
+
code?: string;
|
|
49
|
+
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
-
import * as runCronJob from "./runCronJob";
|
|
3
|
-
|
|
4
|
-
export default [runCronJob] satisfies IPluginActionHandler[];
|
|
1
|
+
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
+
import * as runCronJob from "./runCronJob";
|
|
3
|
+
|
|
4
|
+
export default [runCronJob] satisfies IPluginActionHandler[];
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RunCronJobActionHandlerOptions, RunCronJobInput } from "../CronJobPluginTypes";
|
|
3
|
-
import type CronJobPlugin from "../CronJobPlugin";
|
|
4
|
-
|
|
5
|
-
export const code = "runCronJob";
|
|
6
|
-
|
|
7
|
-
export async function handler(plugin: CronJobPlugin, ctx: ActionHandlerContext, options: RunCronJobActionHandlerOptions) {
|
|
8
|
-
const { server, routerContext } = ctx;
|
|
9
|
-
const { response } = routerContext;
|
|
10
|
-
|
|
11
|
-
const input: RunCronJobInput = ctx.input;
|
|
12
|
-
|
|
13
|
-
if (options.code) {
|
|
14
|
-
input.code = options.code;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
if (!input.code) {
|
|
18
|
-
throw new Error(`Cron job code is required.`);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
const job = plugin.getJobConfigurationByCode(input.code);
|
|
22
|
-
if (!job) {
|
|
23
|
-
throw new Error(`Cron job with code '${input.code}' was not found.`);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
await plugin.executeJob(server, job);
|
|
27
|
-
|
|
28
|
-
response.json({});
|
|
29
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RunCronJobActionHandlerOptions, RunCronJobInput } from "../CronJobPluginTypes";
|
|
3
|
+
import type CronJobPlugin from "../CronJobPlugin";
|
|
4
|
+
|
|
5
|
+
export const code = "runCronJob";
|
|
6
|
+
|
|
7
|
+
export async function handler(plugin: CronJobPlugin, ctx: ActionHandlerContext, options: RunCronJobActionHandlerOptions) {
|
|
8
|
+
const { server, routerContext } = ctx;
|
|
9
|
+
const { response } = routerContext;
|
|
10
|
+
|
|
11
|
+
const input: RunCronJobInput = ctx.input;
|
|
12
|
+
|
|
13
|
+
if (options.code) {
|
|
14
|
+
input.code = options.code;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
if (!input.code) {
|
|
18
|
+
throw new Error(`Cron job code is required.`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const job = plugin.getJobConfigurationByCode(input.code);
|
|
22
|
+
if (!job) {
|
|
23
|
+
throw new Error(`Cron job with code '${input.code}' was not found.`);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
await plugin.executeJob(server, job);
|
|
27
|
+
|
|
28
|
+
response.json({});
|
|
29
|
+
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import runCronJob from "./runCronJob";
|
|
2
|
-
|
|
3
|
-
export default [runCronJob];
|
|
1
|
+
import runCronJob from "./runCronJob";
|
|
2
|
+
|
|
3
|
+
export default [runCronJob];
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "svc",
|
|
5
|
-
name: "svc.runCronJob",
|
|
6
|
-
code: "svc.runCronJob",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "POST",
|
|
9
|
-
endpoint: "/svc/runCronJob",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "runCronJob",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "svc",
|
|
5
|
+
name: "svc.runCronJob",
|
|
6
|
+
code: "svc.runCronJob",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "POST",
|
|
9
|
+
endpoint: "/svc/runCronJob",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "runCronJob",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -12,6 +12,7 @@ import * as countCollectionEntities from "./actionHandlers/countCollectionEntiti
|
|
|
12
12
|
import * as createCollectionEntity from "./actionHandlers/createCollectionEntity";
|
|
13
13
|
import * as createCollectionEntitiesBatch from "./actionHandlers/createCollectionEntitiesBatch";
|
|
14
14
|
import * as updateCollectionEntityById from "./actionHandlers/updateCollectionEntityById";
|
|
15
|
+
import * as deleteCollectionEntities from "./actionHandlers/deleteCollectionEntities";
|
|
15
16
|
import * as deleteCollectionEntityById from "./actionHandlers/deleteCollectionEntityById";
|
|
16
17
|
import * as addEntityRelations from "./actionHandlers/addEntityRelations";
|
|
17
18
|
import * as removeEntityRelations from "./actionHandlers/removeEntityRelations";
|
|
@@ -48,6 +49,12 @@ const routeConfigs: {
|
|
|
48
49
|
endpoint: "/operations/count",
|
|
49
50
|
handlerCode: "countCollectionEntities",
|
|
50
51
|
},
|
|
52
|
+
{
|
|
53
|
+
code: "delete",
|
|
54
|
+
method: "POST",
|
|
55
|
+
endpoint: "/operations/delete",
|
|
56
|
+
handlerCode: "deleteCollectionEntities",
|
|
57
|
+
},
|
|
51
58
|
{
|
|
52
59
|
code: "addRelations",
|
|
53
60
|
method: "POST",
|
|
@@ -116,6 +123,7 @@ class DataManager implements RapidPlugin {
|
|
|
116
123
|
server.registerActionHandler(this, updateCollectionEntityById);
|
|
117
124
|
server.registerActionHandler(this, addEntityRelations);
|
|
118
125
|
server.registerActionHandler(this, removeEntityRelations);
|
|
126
|
+
server.registerActionHandler(this, deleteCollectionEntities);
|
|
119
127
|
server.registerActionHandler(this, deleteCollectionEntityById);
|
|
120
128
|
server.registerActionHandler(this, queryDatabase);
|
|
121
129
|
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import { AddEntityRelationsOptions, RunEntityActionHandlerOptions } from "~/types";
|
|
2
|
-
import { mergeInput } from "~/helpers/inputHelper";
|
|
3
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
4
|
-
import { RapidPlugin } from "~/core/server";
|
|
5
|
-
|
|
6
|
-
export const code = "addEntityRelations";
|
|
7
|
-
|
|
8
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: RunEntityActionHandlerOptions) {
|
|
9
|
-
const { logger, server, input } = ctx;
|
|
10
|
-
|
|
11
|
-
const { defaultInput, fixedInput } = options;
|
|
12
|
-
const mergedInput: AddEntityRelationsOptions = mergeInput(defaultInput, input, fixedInput);
|
|
13
|
-
logger.debug(`Running ${code} handler...`, { defaultInput, fixedInput, mergedInput });
|
|
14
|
-
|
|
15
|
-
const entityManager = server.getEntityManager(options.singularCode);
|
|
16
|
-
mergedInput.routeContext = ctx.routerContext;
|
|
17
|
-
await entityManager.addRelations(mergedInput, plugin);
|
|
18
|
-
|
|
19
|
-
ctx.output = {};
|
|
20
|
-
}
|
|
1
|
+
import { AddEntityRelationsOptions, RunEntityActionHandlerOptions } from "~/types";
|
|
2
|
+
import { mergeInput } from "~/helpers/inputHelper";
|
|
3
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
4
|
+
import { RapidPlugin } from "~/core/server";
|
|
5
|
+
|
|
6
|
+
export const code = "addEntityRelations";
|
|
7
|
+
|
|
8
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: RunEntityActionHandlerOptions) {
|
|
9
|
+
const { logger, server, input } = ctx;
|
|
10
|
+
|
|
11
|
+
const { defaultInput, fixedInput } = options;
|
|
12
|
+
const mergedInput: AddEntityRelationsOptions = mergeInput(defaultInput, input, fixedInput);
|
|
13
|
+
logger.debug(`Running ${code} handler...`, { defaultInput, fixedInput, mergedInput });
|
|
14
|
+
|
|
15
|
+
const entityManager = server.getEntityManager(options.singularCode);
|
|
16
|
+
mergedInput.routeContext = ctx.routerContext;
|
|
17
|
+
await entityManager.addRelations(mergedInput, plugin);
|
|
18
|
+
|
|
19
|
+
ctx.output = {};
|
|
20
|
+
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { CountEntityOptions, RunEntityActionHandlerOptions } from "~/types";
|
|
2
|
-
import runCollectionEntityActionHandler from "~/helpers/runCollectionEntityActionHandler";
|
|
3
|
-
import { removeFiltersWithNullValue } from "~/helpers/filterHelper";
|
|
4
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
5
|
-
import { RapidPlugin } from "~/core/server";
|
|
6
|
-
|
|
7
|
-
export const code = "countCollectionEntities";
|
|
8
|
-
|
|
9
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: RunEntityActionHandlerOptions) {
|
|
10
|
-
await runCollectionEntityActionHandler(ctx, options, code, (entityManager, input: CountEntityOptions) => {
|
|
11
|
-
input.filters = removeFiltersWithNullValue(input.filters);
|
|
12
|
-
input.routeContext = ctx.routerContext;
|
|
13
|
-
return entityManager.count(input);
|
|
14
|
-
});
|
|
15
|
-
}
|
|
1
|
+
import { CountEntityOptions, RunEntityActionHandlerOptions } from "~/types";
|
|
2
|
+
import runCollectionEntityActionHandler from "~/helpers/runCollectionEntityActionHandler";
|
|
3
|
+
import { removeFiltersWithNullValue } from "~/helpers/filterHelper";
|
|
4
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
5
|
+
import { RapidPlugin } from "~/core/server";
|
|
6
|
+
|
|
7
|
+
export const code = "countCollectionEntities";
|
|
8
|
+
|
|
9
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: RunEntityActionHandlerOptions) {
|
|
10
|
+
await runCollectionEntityActionHandler(ctx, options, code, (entityManager, input: CountEntityOptions) => {
|
|
11
|
+
input.filters = removeFiltersWithNullValue(input.filters);
|
|
12
|
+
input.routeContext = ctx.routerContext;
|
|
13
|
+
return entityManager.count(input);
|
|
14
|
+
});
|
|
15
|
+
}
|