@ruiapp/rapid-core 0.3.2 → 0.3.4

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 (92) hide show
  1. package/dist/index.d.ts +3 -0
  2. package/dist/index.js +48 -24
  3. package/dist/plugins/cronJob/CronJobPluginTypes.d.ts +14 -0
  4. package/dist/utilities/entityUtility.d.ts +1 -0
  5. package/package.json +1 -1
  6. package/rollup.config.js +16 -16
  7. package/src/core/actionHandler.ts +22 -22
  8. package/src/core/eventManager.ts +20 -20
  9. package/src/core/facility.ts +7 -7
  10. package/src/core/http/formDataParser.ts +89 -89
  11. package/src/core/http-types.ts +4 -4
  12. package/src/core/pluginManager.ts +175 -175
  13. package/src/core/providers/runtimeProvider.ts +5 -5
  14. package/src/core/request.ts +86 -86
  15. package/src/core/routesBuilder.ts +88 -88
  16. package/src/deno-std/assert/assert.ts +9 -9
  17. package/src/deno-std/assert/assertion_error.ts +7 -7
  18. package/src/deno-std/datetime/to_imf.ts +32 -32
  19. package/src/deno-std/encoding/base64.ts +141 -141
  20. package/src/facilities/log/LogFacility.ts +35 -35
  21. package/src/helpers/inputHelper.ts +11 -11
  22. package/src/index.ts +3 -0
  23. package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
  24. package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
  25. package/src/plugins/auth/actionHandlers/index.ts +8 -8
  26. package/src/plugins/auth/models/AccessToken.ts +56 -56
  27. package/src/plugins/auth/models/index.ts +3 -3
  28. package/src/plugins/auth/routes/changePassword.ts +15 -15
  29. package/src/plugins/auth/routes/getMyProfile.ts +15 -15
  30. package/src/plugins/auth/routes/index.ts +7 -7
  31. package/src/plugins/auth/routes/resetPassword.ts +15 -15
  32. package/src/plugins/auth/routes/signin.ts +15 -15
  33. package/src/plugins/auth/routes/signout.ts +15 -15
  34. package/src/plugins/cronJob/CronJobPlugin.ts +1 -0
  35. package/src/plugins/cronJob/CronJobPluginTypes.ts +65 -49
  36. package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
  37. package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
  38. package/src/plugins/cronJob/routes/index.ts +3 -3
  39. package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
  40. package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
  41. package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
  42. package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
  43. package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
  44. package/src/plugins/fileManage/routes/index.ts +5 -5
  45. package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
  46. package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
  47. package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
  48. package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
  49. package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
  50. package/src/plugins/sequence/actionHandlers/index.ts +4 -4
  51. package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
  52. package/src/plugins/sequence/models/SequenceRule.ts +42 -42
  53. package/src/plugins/sequence/models/index.ts +4 -4
  54. package/src/plugins/sequence/routes/generateSn.ts +15 -15
  55. package/src/plugins/sequence/routes/index.ts +3 -3
  56. package/src/plugins/sequence/segment-utility.ts +11 -11
  57. package/src/plugins/sequence/segments/index.ts +9 -9
  58. package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
  59. package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
  60. package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
  61. package/src/plugins/serverOperation/actionHandlers/runServerOperation.ts +15 -15
  62. package/src/plugins/setting/SettingService.ts +213 -213
  63. package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
  64. package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
  65. package/src/plugins/setting/actionHandlers/index.ts +6 -6
  66. package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
  67. package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
  68. package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
  69. package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
  70. package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
  71. package/src/plugins/setting/models/index.ts +8 -8
  72. package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
  73. package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
  74. package/src/plugins/setting/routes/index.ts +5 -5
  75. package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
  76. package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
  77. package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
  78. package/src/plugins/stateMachine/models/index.ts +3 -3
  79. package/src/plugins/stateMachine/routes/index.ts +3 -3
  80. package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
  81. package/src/plugins/stateMachine/stateMachineHelper.ts +36 -36
  82. package/src/polyfill.ts +5 -5
  83. package/src/proxy/mod.ts +38 -38
  84. package/src/proxy/types.ts +21 -21
  85. package/src/queryBuilder/index.ts +1 -1
  86. package/src/utilities/accessControlUtility.ts +33 -33
  87. package/src/utilities/entityUtility.ts +18 -0
  88. package/src/utilities/fsUtility.ts +61 -61
  89. package/src/utilities/httpUtility.ts +19 -19
  90. package/src/utilities/jwtUtility.ts +26 -26
  91. package/src/utilities/timeUtility.ts +9 -9
  92. package/tsconfig.json +19 -19
@@ -1,18 +1,18 @@
1
- import { ActionHandlerContext } from "~/core/actionHandler";
2
- import { RapidPlugin } from "~/core/server";
3
- import { setCookie } from "~/deno-std/http/cookie";
4
-
5
- export const code = "deleteSession";
6
-
7
- export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
8
- const { server, input, routerContext } = ctx;
9
- const { response } = routerContext;
10
-
11
- setCookie(response.headers, {
12
- name: ctx.server.config.sessionCookieName,
13
- value: "",
14
- path: "/",
15
- });
16
-
17
- routerContext.redirect("/signin");
18
- }
1
+ import { ActionHandlerContext } from "~/core/actionHandler";
2
+ import { RapidPlugin } from "~/core/server";
3
+ import { setCookie } from "~/deno-std/http/cookie";
4
+
5
+ export const code = "deleteSession";
6
+
7
+ export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
8
+ const { server, input, routerContext } = ctx;
9
+ const { response } = routerContext;
10
+
11
+ setCookie(response.headers, {
12
+ name: ctx.server.config.sessionCookieName,
13
+ value: "",
14
+ path: "/",
15
+ });
16
+
17
+ routerContext.redirect("/signin");
18
+ }
@@ -1,35 +1,35 @@
1
- import { ActionHandlerContext } from "~/core/actionHandler";
2
- import { RapidPlugin } from "~/core/server";
3
-
4
- export const code = "getMyProfile";
5
-
6
- export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
7
- const { server, input, routerContext } = ctx;
8
-
9
- const userId = routerContext.state.userId;
10
- if (!userId) {
11
- ctx.status = 401;
12
- ctx.output = {
13
- error: {
14
- message: "You are not signed in.",
15
- },
16
- };
17
- return;
18
- }
19
-
20
- const entityManager = server.getEntityManager("oc_user");
21
- const user = await entityManager.findEntity({
22
- filters: [
23
- {
24
- operator: "eq",
25
- field: "id",
26
- value: userId,
27
- },
28
- ],
29
- properties: ["id", "name", "login", "email", "department", "roles", "state", "createdAt"],
30
- });
31
-
32
- ctx.output = {
33
- user,
34
- };
35
- }
1
+ import { ActionHandlerContext } from "~/core/actionHandler";
2
+ import { RapidPlugin } from "~/core/server";
3
+
4
+ export const code = "getMyProfile";
5
+
6
+ export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
7
+ const { server, input, routerContext } = ctx;
8
+
9
+ const userId = routerContext.state.userId;
10
+ if (!userId) {
11
+ ctx.status = 401;
12
+ ctx.output = {
13
+ error: {
14
+ message: "You are not signed in.",
15
+ },
16
+ };
17
+ return;
18
+ }
19
+
20
+ const entityManager = server.getEntityManager("oc_user");
21
+ const user = await entityManager.findEntity({
22
+ filters: [
23
+ {
24
+ operator: "eq",
25
+ field: "id",
26
+ value: userId,
27
+ },
28
+ ],
29
+ properties: ["id", "name", "login", "email", "department", "roles", "state", "createdAt"],
30
+ });
31
+
32
+ ctx.output = {
33
+ user,
34
+ };
35
+ }
@@ -1,8 +1,8 @@
1
- import { IPluginActionHandler } from "~/core/actionHandler";
2
- import * as changePassword from "./changePassword";
3
- import * as createSession from "./createSession";
4
- import * as deleteSession from "./deleteSession";
5
- import * as getMyProfile from "./getMyProfile";
6
- import * as resetPassword from "./resetPassword";
7
-
8
- export default [changePassword, createSession, deleteSession, getMyProfile, resetPassword] satisfies IPluginActionHandler[];
1
+ import { IPluginActionHandler } from "~/core/actionHandler";
2
+ import * as changePassword from "./changePassword";
3
+ import * as createSession from "./createSession";
4
+ import * as deleteSession from "./deleteSession";
5
+ import * as getMyProfile from "./getMyProfile";
6
+ import * as resetPassword from "./resetPassword";
7
+
8
+ export default [changePassword, createSession, deleteSession, getMyProfile, resetPassword] satisfies IPluginActionHandler[];
@@ -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;
@@ -71,6 +71,7 @@ class CronJobPlugin implements RapidPlugin {
71
71
  async onApplicationReady(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
72
72
  for (const job of this.#jobs) {
73
73
  const jobInstance = cron.CronJob.from({
74
+ ...(job.jobOptions || {}),
74
75
  cronTime: job.cronTime,
75
76
  onTick: async () => {
76
77
  server.getLogger().info(`Executing cron job '${job.code}'...`);
@@ -1,49 +1,65 @@
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
+
3
+ export interface CronJobConfiguration {
4
+ /**
5
+ * 定时任务编号
6
+ */
7
+ code: string;
8
+
9
+ /**
10
+ * 定时任务描述
11
+ */
12
+ description?: string;
13
+
14
+ /**
15
+ * crontab 表达式
16
+ */
17
+ cronTime: string;
18
+
19
+ /**
20
+ * 任务设置
21
+ */
22
+ jobOptions?: CronJobOptions;
23
+
24
+ /**
25
+ * 任务处理程序编号。当指定处理程序编号时,忽略 handler 配置。
26
+ */
27
+ actionHandlerCode?: string;
28
+
29
+ /**
30
+ * 定时任务处理程序
31
+ * @param ctx
32
+ * @param options
33
+ * @returns
34
+ */
35
+ handler?: (ctx: ActionHandlerContext, options: any) => Promise<void>;
36
+
37
+ /**
38
+ * 处理定时任务时的设置选项
39
+ */
40
+ handleOptions?: any;
41
+ }
42
+
43
+ export interface CronJobOptions {
44
+ /**
45
+ * Instantly triggers the onTick function post initialization. Default is false.
46
+ */
47
+ runOnInit?: boolean;
48
+
49
+ /**
50
+ * If true, no additional instances of the onTick callback function will run until the current onTick callback has completed. Any new scheduled executions that occur while the current callback is running will be skipped entirely. Default is false.
51
+ */
52
+ waitForCompletion?: boolean;
53
+ }
54
+
55
+ export interface CronJobPluginInitOptions {
56
+ jobs: CronJobConfiguration[];
57
+ }
58
+
59
+ export type RunCronJobActionHandlerOptions = {
60
+ code?: string;
61
+ };
62
+
63
+ export type RunCronJobInput = {
64
+ code?: string;
65
+ };
@@ -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;