@ruiapp/rapid-core 0.3.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -7
- package/dist/index.d.ts +2 -0
- package/dist/index.js +359 -134
- package/dist/plugins/license/LicensePlugin.d.ts +23 -0
- package/dist/plugins/license/LicensePluginTypes.d.ts +78 -0
- package/dist/plugins/license/LicenseService.d.ts +22 -0
- package/dist/plugins/license/actionHandlers/getLicense.d.ts +6 -0
- package/dist/plugins/license/actionHandlers/index.d.ts +3 -0
- package/dist/plugins/license/helpers/certHelper.d.ts +2 -0
- package/dist/plugins/license/helpers/cryptoHelper.d.ts +8 -0
- package/dist/plugins/license/models/index.d.ts +2 -0
- package/dist/plugins/license/routes/getLicense.d.ts +12 -0
- package/dist/plugins/license/routes/index.d.ts +12 -0
- package/dist/utilities/typeUtility.d.ts +1 -0
- package/package.json +1 -1
- package/src/bootstrapApplicationConfig.ts +631 -631
- package/src/core/response.ts +76 -76
- package/src/core/routeContext.ts +47 -47
- package/src/core/server.ts +142 -142
- package/src/dataAccess/columnTypeMapper.ts +22 -22
- package/src/dataAccess/dataAccessTypes.ts +163 -163
- package/src/dataAccess/dataAccessor.ts +135 -135
- package/src/dataAccess/entityManager.ts +1718 -1718
- package/src/dataAccess/entityMapper.ts +100 -100
- package/src/dataAccess/propertyMapper.ts +28 -28
- package/src/deno-std/http/cookie.ts +372 -372
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/helpers/filterHelper.ts +148 -148
- package/src/helpers/metaHelper.ts +89 -89
- package/src/helpers/runCollectionEntityActionHandler.ts +27 -27
- package/src/index.ts +57 -54
- package/src/plugins/auth/AuthPlugin.ts +85 -85
- package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
- package/src/plugins/auth/actionHandlers/createSession.ts +75 -63
- package/src/plugins/auth/actionHandlers/resetPassword.ts +38 -38
- package/src/plugins/cronJob/CronJobPlugin.ts +112 -112
- package/src/plugins/dataManage/DataManagePlugin.ts +163 -163
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +16 -16
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +38 -38
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +26 -26
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +21 -21
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +41 -41
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
- package/src/plugins/fileManage/FileManagePlugin.ts +52 -52
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +65 -65
- package/src/plugins/fileManage/actionHandlers/downloadFile.ts +44 -44
- package/src/plugins/license/LicensePlugin.ts +79 -0
- package/src/plugins/license/LicensePluginTypes.ts +95 -0
- package/src/plugins/license/LicenseService.ts +112 -0
- package/src/plugins/license/actionHandlers/getLicense.ts +18 -0
- package/src/plugins/license/actionHandlers/index.ts +4 -0
- package/src/plugins/license/helpers/certHelper.ts +21 -0
- package/src/plugins/license/helpers/cryptoHelper.ts +47 -0
- package/src/plugins/license/models/index.ts +1 -0
- package/src/plugins/license/routes/getLicense.ts +15 -0
- package/src/plugins/license/routes/index.ts +3 -0
- package/src/plugins/mail/MailPlugin.ts +74 -74
- package/src/plugins/mail/MailPluginTypes.ts +27 -27
- package/src/plugins/mail/MailService.ts +38 -38
- package/src/plugins/mail/actionHandlers/index.ts +3 -3
- package/src/plugins/mail/models/index.ts +1 -1
- package/src/plugins/mail/routes/index.ts +1 -1
- package/src/plugins/metaManage/MetaManagePlugin.ts +504 -504
- package/src/plugins/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 -57
- 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/sequence/SequencePlugin.ts +136 -136
- package/src/plugins/sequence/SequencePluginTypes.ts +69 -69
- package/src/plugins/sequence/SequenceService.ts +81 -81
- package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
- package/src/plugins/sequence/segments/autoIncrement.ts +78 -78
- package/src/plugins/sequence/segments/dayOfMonth.ts +17 -17
- package/src/plugins/sequence/segments/literal.ts +14 -14
- package/src/plugins/sequence/segments/month.ts +17 -17
- package/src/plugins/sequence/segments/parameter.ts +18 -18
- package/src/plugins/sequence/segments/year.ts +17 -17
- package/src/plugins/setting/SettingPlugin.ts +68 -68
- package/src/plugins/setting/SettingPluginTypes.ts +37 -37
- package/src/plugins/setting/models/SystemSettingItem.ts +48 -42
- package/src/plugins/setting/models/UserSettingItem.ts +55 -49
- package/src/plugins/stateMachine/StateMachinePlugin.ts +186 -186
- package/src/plugins/stateMachine/StateMachinePluginTypes.ts +48 -48
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +51 -51
- package/src/plugins/webhooks/WebhooksPlugin.ts +148 -148
- package/src/plugins/webhooks/pluginConfig.ts +75 -75
- package/src/queryBuilder/queryBuilder.ts +665 -665
- package/src/server.ts +463 -463
- package/src/types.ts +701 -701
- package/src/utilities/errorUtility.ts +15 -15
- package/src/utilities/pathUtility.ts +14 -14
- package/src/utilities/typeUtility.ts +15 -11
|
@@ -1,112 +1,112 @@
|
|
|
1
|
-
import * as cron from "cron";
|
|
2
|
-
import type { RpdApplicationConfig } from "~/types";
|
|
3
|
-
import pluginActionHandlers from "./actionHandlers";
|
|
4
|
-
import pluginRoutes from "./routes";
|
|
5
|
-
import { CronJobConfiguration, CronJobPluginInitOptions } from "./CronJobPluginTypes";
|
|
6
|
-
import {
|
|
7
|
-
IRpdServer,
|
|
8
|
-
RapidPlugin,
|
|
9
|
-
RpdConfigurationItemOptions,
|
|
10
|
-
RpdServerPluginConfigurableTargetOptions,
|
|
11
|
-
RpdServerPluginExtendingAbilities,
|
|
12
|
-
} from "~/core/server";
|
|
13
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
14
|
-
import { find } from "lodash";
|
|
15
|
-
|
|
16
|
-
class CronJobPlugin implements RapidPlugin {
|
|
17
|
-
#jobs: CronJobConfiguration[];
|
|
18
|
-
|
|
19
|
-
constructor(options: CronJobPluginInitOptions) {
|
|
20
|
-
this.#jobs = options.jobs || [];
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
get code(): string {
|
|
24
|
-
return "cronJob";
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
get description(): string {
|
|
28
|
-
return "";
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
32
|
-
return [];
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
36
|
-
return [];
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
get configurations(): RpdConfigurationItemOptions[] {
|
|
40
|
-
return [];
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
async initPlugin(server: IRpdServer): Promise<any> {}
|
|
44
|
-
|
|
45
|
-
async registerMiddlewares(server: IRpdServer): Promise<any> {}
|
|
46
|
-
|
|
47
|
-
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
48
|
-
for (const actionHandler of pluginActionHandlers) {
|
|
49
|
-
server.registerActionHandler(this, actionHandler);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
async registerEventHandlers(server: IRpdServer): Promise<any> {}
|
|
54
|
-
|
|
55
|
-
async registerMessageHandlers(server: IRpdServer): Promise<any> {}
|
|
56
|
-
|
|
57
|
-
async registerTaskProcessors(server: IRpdServer): Promise<any> {}
|
|
58
|
-
|
|
59
|
-
async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
60
|
-
|
|
61
|
-
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
62
|
-
|
|
63
|
-
async configureModelProperties(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
64
|
-
|
|
65
|
-
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
66
|
-
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
70
|
-
|
|
71
|
-
async onApplicationReady(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
72
|
-
for (const job of this.#jobs) {
|
|
73
|
-
const jobInstance = cron.CronJob.from({
|
|
74
|
-
cronTime: job.cronTime,
|
|
75
|
-
onTick: async () => {
|
|
76
|
-
server.getLogger().info(`Executing cron job '${job.code}'...`);
|
|
77
|
-
await this.executeJob(server, job);
|
|
78
|
-
},
|
|
79
|
-
});
|
|
80
|
-
jobInstance.start();
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
getJobConfigurationByCode(code: string) {
|
|
85
|
-
return find(this.#jobs, (job) => job.code === code);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
async executeJob(server: IRpdServer, job: CronJobConfiguration) {
|
|
89
|
-
const logger = server.getLogger();
|
|
90
|
-
try {
|
|
91
|
-
let handlerContext: ActionHandlerContext = {
|
|
92
|
-
logger,
|
|
93
|
-
routerContext: null,
|
|
94
|
-
next: null,
|
|
95
|
-
server,
|
|
96
|
-
applicationConfig: null,
|
|
97
|
-
input: null,
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
if (job.actionHandlerCode) {
|
|
101
|
-
const actionHandler = server.getActionHandlerByCode(job.code);
|
|
102
|
-
await actionHandler(handlerContext, job.handleOptions);
|
|
103
|
-
} else {
|
|
104
|
-
await job.handler(handlerContext, job.handleOptions);
|
|
105
|
-
}
|
|
106
|
-
} catch (ex) {
|
|
107
|
-
logger.error("Cron job execution error: " + ex.message);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
export default CronJobPlugin;
|
|
1
|
+
import * as cron from "cron";
|
|
2
|
+
import type { RpdApplicationConfig } from "~/types";
|
|
3
|
+
import pluginActionHandlers from "./actionHandlers";
|
|
4
|
+
import pluginRoutes from "./routes";
|
|
5
|
+
import { CronJobConfiguration, CronJobPluginInitOptions } from "./CronJobPluginTypes";
|
|
6
|
+
import {
|
|
7
|
+
IRpdServer,
|
|
8
|
+
RapidPlugin,
|
|
9
|
+
RpdConfigurationItemOptions,
|
|
10
|
+
RpdServerPluginConfigurableTargetOptions,
|
|
11
|
+
RpdServerPluginExtendingAbilities,
|
|
12
|
+
} from "~/core/server";
|
|
13
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
14
|
+
import { find } from "lodash";
|
|
15
|
+
|
|
16
|
+
class CronJobPlugin implements RapidPlugin {
|
|
17
|
+
#jobs: CronJobConfiguration[];
|
|
18
|
+
|
|
19
|
+
constructor(options: CronJobPluginInitOptions) {
|
|
20
|
+
this.#jobs = options.jobs || [];
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
get code(): string {
|
|
24
|
+
return "cronJob";
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
get description(): string {
|
|
28
|
+
return "";
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
32
|
+
return [];
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
36
|
+
return [];
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
get configurations(): RpdConfigurationItemOptions[] {
|
|
40
|
+
return [];
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async initPlugin(server: IRpdServer): Promise<any> {}
|
|
44
|
+
|
|
45
|
+
async registerMiddlewares(server: IRpdServer): Promise<any> {}
|
|
46
|
+
|
|
47
|
+
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
48
|
+
for (const actionHandler of pluginActionHandlers) {
|
|
49
|
+
server.registerActionHandler(this, actionHandler);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
async registerEventHandlers(server: IRpdServer): Promise<any> {}
|
|
54
|
+
|
|
55
|
+
async registerMessageHandlers(server: IRpdServer): Promise<any> {}
|
|
56
|
+
|
|
57
|
+
async registerTaskProcessors(server: IRpdServer): Promise<any> {}
|
|
58
|
+
|
|
59
|
+
async onLoadingApplication(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
60
|
+
|
|
61
|
+
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
62
|
+
|
|
63
|
+
async configureModelProperties(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
64
|
+
|
|
65
|
+
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
66
|
+
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {}
|
|
70
|
+
|
|
71
|
+
async onApplicationReady(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
72
|
+
for (const job of this.#jobs) {
|
|
73
|
+
const jobInstance = cron.CronJob.from({
|
|
74
|
+
cronTime: job.cronTime,
|
|
75
|
+
onTick: async () => {
|
|
76
|
+
server.getLogger().info(`Executing cron job '${job.code}'...`);
|
|
77
|
+
await this.executeJob(server, job);
|
|
78
|
+
},
|
|
79
|
+
});
|
|
80
|
+
jobInstance.start();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
getJobConfigurationByCode(code: string) {
|
|
85
|
+
return find(this.#jobs, (job) => job.code === code);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
async executeJob(server: IRpdServer, job: CronJobConfiguration) {
|
|
89
|
+
const logger = server.getLogger();
|
|
90
|
+
try {
|
|
91
|
+
let handlerContext: ActionHandlerContext = {
|
|
92
|
+
logger,
|
|
93
|
+
routerContext: null,
|
|
94
|
+
next: null,
|
|
95
|
+
server,
|
|
96
|
+
applicationConfig: null,
|
|
97
|
+
input: null,
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
if (job.actionHandlerCode) {
|
|
101
|
+
const actionHandler = server.getActionHandlerByCode(job.code);
|
|
102
|
+
await actionHandler(handlerContext, job.handleOptions);
|
|
103
|
+
} else {
|
|
104
|
+
await job.handler(handlerContext, job.handleOptions);
|
|
105
|
+
}
|
|
106
|
+
} catch (ex) {
|
|
107
|
+
logger.error("Cron job execution error: " + ex.message);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
export default CronJobPlugin;
|
|
@@ -1,163 +1,163 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Support manage data in database.
|
|
3
|
-
* This plugin provide:
|
|
4
|
-
* - routes for manage data in database.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { RpdApplicationConfig, RpdHttpMethod, RpdRoute, RunEntityActionHandlerOptions } from "~/types";
|
|
8
|
-
|
|
9
|
-
import * as findCollectionEntities from "./actionHandlers/findCollectionEntities";
|
|
10
|
-
import * as findCollectionEntityById from "./actionHandlers/findCollectionEntityById";
|
|
11
|
-
import * as countCollectionEntities from "./actionHandlers/countCollectionEntities";
|
|
12
|
-
import * as createCollectionEntity from "./actionHandlers/createCollectionEntity";
|
|
13
|
-
import * as createCollectionEntitiesBatch from "./actionHandlers/createCollectionEntitiesBatch";
|
|
14
|
-
import * as updateCollectionEntityById from "./actionHandlers/updateCollectionEntityById";
|
|
15
|
-
import * as deleteCollectionEntities from "./actionHandlers/deleteCollectionEntities";
|
|
16
|
-
import * as deleteCollectionEntityById from "./actionHandlers/deleteCollectionEntityById";
|
|
17
|
-
import * as addEntityRelations from "./actionHandlers/addEntityRelations";
|
|
18
|
-
import * as removeEntityRelations from "./actionHandlers/removeEntityRelations";
|
|
19
|
-
import * as queryDatabase from "./actionHandlers/queryDatabase";
|
|
20
|
-
import {
|
|
21
|
-
RpdServerPluginExtendingAbilities,
|
|
22
|
-
RpdServerPluginConfigurableTargetOptions,
|
|
23
|
-
RpdConfigurationItemOptions,
|
|
24
|
-
IRpdServer,
|
|
25
|
-
RapidPlugin,
|
|
26
|
-
} from "~/core/server";
|
|
27
|
-
|
|
28
|
-
const routeConfigs: {
|
|
29
|
-
code: string;
|
|
30
|
-
method: RpdHttpMethod;
|
|
31
|
-
endpoint: string;
|
|
32
|
-
handlerCode: string;
|
|
33
|
-
}[] = [
|
|
34
|
-
{
|
|
35
|
-
code: "createBatch",
|
|
36
|
-
method: "POST",
|
|
37
|
-
endpoint: "/operations/create_batch",
|
|
38
|
-
handlerCode: "createCollectionEntitiesBatch",
|
|
39
|
-
},
|
|
40
|
-
{
|
|
41
|
-
code: "find",
|
|
42
|
-
method: "POST",
|
|
43
|
-
endpoint: "/operations/find",
|
|
44
|
-
handlerCode: "findCollectionEntities",
|
|
45
|
-
},
|
|
46
|
-
{
|
|
47
|
-
code: "count",
|
|
48
|
-
method: "POST",
|
|
49
|
-
endpoint: "/operations/count",
|
|
50
|
-
handlerCode: "countCollectionEntities",
|
|
51
|
-
},
|
|
52
|
-
{
|
|
53
|
-
code: "delete",
|
|
54
|
-
method: "POST",
|
|
55
|
-
endpoint: "/operations/delete",
|
|
56
|
-
handlerCode: "deleteCollectionEntities",
|
|
57
|
-
},
|
|
58
|
-
{
|
|
59
|
-
code: "addRelations",
|
|
60
|
-
method: "POST",
|
|
61
|
-
endpoint: "/operations/add_relations",
|
|
62
|
-
handlerCode: "addEntityRelations",
|
|
63
|
-
},
|
|
64
|
-
{
|
|
65
|
-
code: "removeRelations",
|
|
66
|
-
method: "POST",
|
|
67
|
-
endpoint: "/operations/remove_relations",
|
|
68
|
-
handlerCode: "removeEntityRelations",
|
|
69
|
-
},
|
|
70
|
-
{
|
|
71
|
-
code: "getById",
|
|
72
|
-
method: "GET",
|
|
73
|
-
endpoint: "/:id",
|
|
74
|
-
handlerCode: "findCollectionEntityById",
|
|
75
|
-
},
|
|
76
|
-
{
|
|
77
|
-
code: "create",
|
|
78
|
-
method: "POST",
|
|
79
|
-
endpoint: "",
|
|
80
|
-
handlerCode: "createCollectionEntity",
|
|
81
|
-
},
|
|
82
|
-
{
|
|
83
|
-
code: "updateById",
|
|
84
|
-
method: "PATCH",
|
|
85
|
-
endpoint: "/:id",
|
|
86
|
-
handlerCode: "updateCollectionEntityById",
|
|
87
|
-
},
|
|
88
|
-
{
|
|
89
|
-
code: "deleteById",
|
|
90
|
-
method: "DELETE",
|
|
91
|
-
endpoint: "/:id",
|
|
92
|
-
handlerCode: "deleteCollectionEntityById",
|
|
93
|
-
},
|
|
94
|
-
];
|
|
95
|
-
|
|
96
|
-
class DataManager implements RapidPlugin {
|
|
97
|
-
get code(): string {
|
|
98
|
-
return "dataManager";
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
get description(): string {
|
|
102
|
-
return "对数据进行管理,提供增删改查等接口。";
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
106
|
-
return [];
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
110
|
-
return [];
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
get configurations(): RpdConfigurationItemOptions[] {
|
|
114
|
-
return [];
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
118
|
-
server.registerActionHandler(this, findCollectionEntities);
|
|
119
|
-
server.registerActionHandler(this, findCollectionEntityById);
|
|
120
|
-
server.registerActionHandler(this, countCollectionEntities);
|
|
121
|
-
server.registerActionHandler(this, createCollectionEntity);
|
|
122
|
-
server.registerActionHandler(this, createCollectionEntitiesBatch);
|
|
123
|
-
server.registerActionHandler(this, updateCollectionEntityById);
|
|
124
|
-
server.registerActionHandler(this, addEntityRelations);
|
|
125
|
-
server.registerActionHandler(this, removeEntityRelations);
|
|
126
|
-
server.registerActionHandler(this, deleteCollectionEntities);
|
|
127
|
-
server.registerActionHandler(this, deleteCollectionEntityById);
|
|
128
|
-
server.registerActionHandler(this, queryDatabase);
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
132
|
-
const { models } = applicationConfig;
|
|
133
|
-
const routes: RpdRoute[] = [];
|
|
134
|
-
|
|
135
|
-
models.forEach((model) => {
|
|
136
|
-
const { namespace, singularCode, pluralCode } = model;
|
|
137
|
-
|
|
138
|
-
routeConfigs.forEach((routeConfig) => {
|
|
139
|
-
routes.push({
|
|
140
|
-
namespace,
|
|
141
|
-
name: `${namespace}.${singularCode}.${routeConfig.code}`,
|
|
142
|
-
code: `${namespace}.${singularCode}.${routeConfig.code}`,
|
|
143
|
-
type: "RESTful",
|
|
144
|
-
method: routeConfig.method,
|
|
145
|
-
endpoint: `/${namespace}/${pluralCode}${routeConfig.endpoint}`,
|
|
146
|
-
actions: [
|
|
147
|
-
{
|
|
148
|
-
code: routeConfig.handlerCode,
|
|
149
|
-
config: {
|
|
150
|
-
namespace,
|
|
151
|
-
singularCode,
|
|
152
|
-
} as RunEntityActionHandlerOptions,
|
|
153
|
-
},
|
|
154
|
-
],
|
|
155
|
-
});
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
server.appendApplicationConfig({ routes });
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
export default DataManager;
|
|
1
|
+
/**
|
|
2
|
+
* Support manage data in database.
|
|
3
|
+
* This plugin provide:
|
|
4
|
+
* - routes for manage data in database.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { RpdApplicationConfig, RpdHttpMethod, RpdRoute, RunEntityActionHandlerOptions } from "~/types";
|
|
8
|
+
|
|
9
|
+
import * as findCollectionEntities from "./actionHandlers/findCollectionEntities";
|
|
10
|
+
import * as findCollectionEntityById from "./actionHandlers/findCollectionEntityById";
|
|
11
|
+
import * as countCollectionEntities from "./actionHandlers/countCollectionEntities";
|
|
12
|
+
import * as createCollectionEntity from "./actionHandlers/createCollectionEntity";
|
|
13
|
+
import * as createCollectionEntitiesBatch from "./actionHandlers/createCollectionEntitiesBatch";
|
|
14
|
+
import * as updateCollectionEntityById from "./actionHandlers/updateCollectionEntityById";
|
|
15
|
+
import * as deleteCollectionEntities from "./actionHandlers/deleteCollectionEntities";
|
|
16
|
+
import * as deleteCollectionEntityById from "./actionHandlers/deleteCollectionEntityById";
|
|
17
|
+
import * as addEntityRelations from "./actionHandlers/addEntityRelations";
|
|
18
|
+
import * as removeEntityRelations from "./actionHandlers/removeEntityRelations";
|
|
19
|
+
import * as queryDatabase from "./actionHandlers/queryDatabase";
|
|
20
|
+
import {
|
|
21
|
+
RpdServerPluginExtendingAbilities,
|
|
22
|
+
RpdServerPluginConfigurableTargetOptions,
|
|
23
|
+
RpdConfigurationItemOptions,
|
|
24
|
+
IRpdServer,
|
|
25
|
+
RapidPlugin,
|
|
26
|
+
} from "~/core/server";
|
|
27
|
+
|
|
28
|
+
const routeConfigs: {
|
|
29
|
+
code: string;
|
|
30
|
+
method: RpdHttpMethod;
|
|
31
|
+
endpoint: string;
|
|
32
|
+
handlerCode: string;
|
|
33
|
+
}[] = [
|
|
34
|
+
{
|
|
35
|
+
code: "createBatch",
|
|
36
|
+
method: "POST",
|
|
37
|
+
endpoint: "/operations/create_batch",
|
|
38
|
+
handlerCode: "createCollectionEntitiesBatch",
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
code: "find",
|
|
42
|
+
method: "POST",
|
|
43
|
+
endpoint: "/operations/find",
|
|
44
|
+
handlerCode: "findCollectionEntities",
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
code: "count",
|
|
48
|
+
method: "POST",
|
|
49
|
+
endpoint: "/operations/count",
|
|
50
|
+
handlerCode: "countCollectionEntities",
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
code: "delete",
|
|
54
|
+
method: "POST",
|
|
55
|
+
endpoint: "/operations/delete",
|
|
56
|
+
handlerCode: "deleteCollectionEntities",
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
code: "addRelations",
|
|
60
|
+
method: "POST",
|
|
61
|
+
endpoint: "/operations/add_relations",
|
|
62
|
+
handlerCode: "addEntityRelations",
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
code: "removeRelations",
|
|
66
|
+
method: "POST",
|
|
67
|
+
endpoint: "/operations/remove_relations",
|
|
68
|
+
handlerCode: "removeEntityRelations",
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
code: "getById",
|
|
72
|
+
method: "GET",
|
|
73
|
+
endpoint: "/:id",
|
|
74
|
+
handlerCode: "findCollectionEntityById",
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
code: "create",
|
|
78
|
+
method: "POST",
|
|
79
|
+
endpoint: "",
|
|
80
|
+
handlerCode: "createCollectionEntity",
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
code: "updateById",
|
|
84
|
+
method: "PATCH",
|
|
85
|
+
endpoint: "/:id",
|
|
86
|
+
handlerCode: "updateCollectionEntityById",
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
code: "deleteById",
|
|
90
|
+
method: "DELETE",
|
|
91
|
+
endpoint: "/:id",
|
|
92
|
+
handlerCode: "deleteCollectionEntityById",
|
|
93
|
+
},
|
|
94
|
+
];
|
|
95
|
+
|
|
96
|
+
class DataManager implements RapidPlugin {
|
|
97
|
+
get code(): string {
|
|
98
|
+
return "dataManager";
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
get description(): string {
|
|
102
|
+
return "对数据进行管理,提供增删改查等接口。";
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
106
|
+
return [];
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
110
|
+
return [];
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
get configurations(): RpdConfigurationItemOptions[] {
|
|
114
|
+
return [];
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
118
|
+
server.registerActionHandler(this, findCollectionEntities);
|
|
119
|
+
server.registerActionHandler(this, findCollectionEntityById);
|
|
120
|
+
server.registerActionHandler(this, countCollectionEntities);
|
|
121
|
+
server.registerActionHandler(this, createCollectionEntity);
|
|
122
|
+
server.registerActionHandler(this, createCollectionEntitiesBatch);
|
|
123
|
+
server.registerActionHandler(this, updateCollectionEntityById);
|
|
124
|
+
server.registerActionHandler(this, addEntityRelations);
|
|
125
|
+
server.registerActionHandler(this, removeEntityRelations);
|
|
126
|
+
server.registerActionHandler(this, deleteCollectionEntities);
|
|
127
|
+
server.registerActionHandler(this, deleteCollectionEntityById);
|
|
128
|
+
server.registerActionHandler(this, queryDatabase);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
132
|
+
const { models } = applicationConfig;
|
|
133
|
+
const routes: RpdRoute[] = [];
|
|
134
|
+
|
|
135
|
+
models.forEach((model) => {
|
|
136
|
+
const { namespace, singularCode, pluralCode } = model;
|
|
137
|
+
|
|
138
|
+
routeConfigs.forEach((routeConfig) => {
|
|
139
|
+
routes.push({
|
|
140
|
+
namespace,
|
|
141
|
+
name: `${namespace}.${singularCode}.${routeConfig.code}`,
|
|
142
|
+
code: `${namespace}.${singularCode}.${routeConfig.code}`,
|
|
143
|
+
type: "RESTful",
|
|
144
|
+
method: routeConfig.method,
|
|
145
|
+
endpoint: `/${namespace}/${pluralCode}${routeConfig.endpoint}`,
|
|
146
|
+
actions: [
|
|
147
|
+
{
|
|
148
|
+
code: routeConfig.handlerCode,
|
|
149
|
+
config: {
|
|
150
|
+
namespace,
|
|
151
|
+
singularCode,
|
|
152
|
+
} as RunEntityActionHandlerOptions,
|
|
153
|
+
},
|
|
154
|
+
],
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
server.appendApplicationConfig({ routes });
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
export default DataManager;
|
|
@@ -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,16 +1,16 @@
|
|
|
1
|
-
import { CountEntityOptions, CountEntityResult, 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, async (entityManager, input: CountEntityOptions): Promise<CountEntityResult> => {
|
|
11
|
-
input.filters = removeFiltersWithNullValue(input.filters);
|
|
12
|
-
input.routeContext = ctx.routerContext;
|
|
13
|
-
const count = await entityManager.count(input);
|
|
14
|
-
return { count };
|
|
15
|
-
});
|
|
16
|
-
}
|
|
1
|
+
import { CountEntityOptions, CountEntityResult, 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, async (entityManager, input: CountEntityOptions): Promise<CountEntityResult> => {
|
|
11
|
+
input.filters = removeFiltersWithNullValue(input.filters);
|
|
12
|
+
input.routeContext = ctx.routerContext;
|
|
13
|
+
const count = await entityManager.count(input);
|
|
14
|
+
return { count };
|
|
15
|
+
});
|
|
16
|
+
}
|