@ruiapp/rapid-core 0.5.11 → 0.5.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -7
- package/dist/facilities/cache/CacheFacilityTypes.d.ts +4 -2
- package/dist/facilities/cache/MemoryCache.d.ts +3 -1
- package/dist/index.d.ts +4 -0
- package/dist/index.js +131 -72
- package/dist/utilities/entityUtility.d.ts +1 -0
- package/dist/utilities/passwordUtility.d.ts +14 -0
- package/package.json +2 -2
- package/rollup.config.js +16 -16
- package/src/bootstrapApplicationConfig.ts +638 -638
- package/src/core/actionHandler.ts +22 -22
- package/src/core/eventManager.ts +20 -20
- package/src/core/facility.ts +7 -7
- package/src/core/http/formDataParser.ts +89 -89
- package/src/core/http-types.ts +4 -4
- package/src/core/pluginManager.ts +175 -175
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +95 -95
- package/src/core/response.ts +79 -79
- package/src/core/routeContext.ts +100 -100
- package/src/core/routesBuilder.ts +88 -88
- package/src/core/server.ts +145 -145
- package/src/dataAccess/columnTypeMapper.ts +22 -22
- package/src/dataAccess/dataAccessTypes.ts +163 -163
- package/src/dataAccess/dataAccessor.ts +135 -135
- package/src/dataAccess/entityManager.ts +1910 -1910
- package/src/dataAccess/entityMapper.ts +100 -100
- package/src/dataAccess/propertyMapper.ts +28 -28
- package/src/deno-std/assert/assert.ts +9 -9
- package/src/deno-std/assert/assertion_error.ts +7 -7
- package/src/deno-std/datetime/to_imf.ts +32 -32
- package/src/deno-std/encoding/base64.ts +141 -141
- package/src/deno-std/http/cookie.ts +372 -372
- package/src/facilities/cache/CacheFacilityTypes.ts +29 -27
- package/src/facilities/cache/CacheFactory.ts +31 -31
- package/src/facilities/cache/MemoryCache.ts +58 -42
- package/src/facilities/cache/MemoryCacheProvider.ts +15 -15
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/helpers/filterHelper.ts +148 -148
- package/src/helpers/inputHelper.ts +11 -11
- package/src/helpers/metaHelper.ts +104 -104
- package/src/helpers/runCollectionEntityActionHandler.ts +57 -57
- package/src/index.ts +67 -63
- package/src/plugins/auth/AuthPlugin.ts +93 -93
- package/src/plugins/auth/actionHandlers/changePassword.ts +60 -61
- package/src/plugins/auth/actionHandlers/createSession.ts +68 -68
- package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
- package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
- package/src/plugins/auth/actionHandlers/index.ts +8 -8
- package/src/plugins/auth/actionHandlers/resetPassword.ts +44 -45
- package/src/plugins/auth/models/AccessToken.ts +56 -56
- package/src/plugins/auth/models/index.ts +3 -3
- package/src/plugins/auth/routes/changePassword.ts +15 -15
- package/src/plugins/auth/routes/getMyProfile.ts +15 -15
- package/src/plugins/auth/routes/index.ts +7 -7
- package/src/plugins/auth/routes/resetPassword.ts +15 -15
- package/src/plugins/auth/routes/signin.ts +15 -15
- package/src/plugins/auth/routes/signout.ts +15 -15
- package/src/plugins/auth/services/AuthService.ts +39 -39
- package/src/plugins/cronJob/CronJobPlugin.ts +112 -112
- package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
- package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
- package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
- package/src/plugins/cronJob/routes/index.ts +3 -3
- package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
- package/src/plugins/dataManage/DataManagePlugin.ts +163 -163
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +17 -17
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +81 -81
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +45 -45
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +27 -27
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +30 -30
- package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +38 -38
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
- package/src/plugins/fileManage/FileManagePlugin.ts +52 -52
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +65 -65
- package/src/plugins/fileManage/actionHandlers/downloadFile.ts +44 -44
- package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
- package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
- package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
- package/src/plugins/fileManage/routes/index.ts +5 -5
- package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
- package/src/plugins/license/LicensePlugin.ts +79 -79
- package/src/plugins/license/LicensePluginTypes.ts +95 -95
- package/src/plugins/license/LicenseService.ts +118 -118
- package/src/plugins/license/actionHandlers/getLicense.ts +18 -18
- package/src/plugins/license/actionHandlers/index.ts +4 -4
- package/src/plugins/license/helpers/certHelper.ts +21 -21
- package/src/plugins/license/helpers/cryptoHelper.ts +47 -47
- package/src/plugins/license/models/index.ts +1 -1
- package/src/plugins/license/routes/getLicense.ts +15 -15
- package/src/plugins/license/routes/index.ts +3 -3
- package/src/plugins/mail/MailPlugin.ts +74 -74
- package/src/plugins/mail/MailPluginTypes.ts +27 -27
- package/src/plugins/mail/MailService.ts +38 -38
- package/src/plugins/mail/actionHandlers/index.ts +3 -3
- package/src/plugins/mail/models/index.ts +1 -1
- package/src/plugins/mail/routes/index.ts +1 -1
- package/src/plugins/metaManage/MetaManagePlugin.ts +530 -530
- package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
- package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
- package/src/plugins/notification/NotificationPlugin.ts +68 -68
- package/src/plugins/notification/NotificationPluginTypes.ts +13 -13
- package/src/plugins/notification/NotificationService.ts +25 -25
- package/src/plugins/notification/actionHandlers/index.ts +3 -3
- package/src/plugins/notification/models/Notification.ts +60 -60
- package/src/plugins/notification/models/index.ts +3 -3
- package/src/plugins/notification/routes/index.ts +1 -1
- package/src/plugins/routeManage/RouteManagePlugin.ts +62 -62
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/sequence/SequencePlugin.ts +146 -146
- package/src/plugins/sequence/SequencePluginTypes.ts +69 -69
- package/src/plugins/sequence/SequenceService.ts +92 -92
- package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
- package/src/plugins/sequence/actionHandlers/index.ts +4 -4
- package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
- package/src/plugins/sequence/models/SequenceRule.ts +42 -42
- package/src/plugins/sequence/models/index.ts +4 -4
- package/src/plugins/sequence/routes/generateSn.ts +15 -15
- package/src/plugins/sequence/routes/index.ts +3 -3
- package/src/plugins/sequence/segment-utility.ts +11 -11
- package/src/plugins/sequence/segments/autoIncrement.ts +90 -90
- package/src/plugins/sequence/segments/dayOfMonth.ts +19 -19
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/sequence/segments/literal.ts +16 -16
- package/src/plugins/sequence/segments/month.ts +19 -19
- package/src/plugins/sequence/segments/parameter.ts +20 -20
- package/src/plugins/sequence/segments/year.ts +19 -19
- package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
- package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
- package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
- package/src/plugins/serverOperation/actionHandlers/runServerOperation.ts +15 -15
- package/src/plugins/setting/SettingPlugin.ts +68 -68
- package/src/plugins/setting/SettingPluginTypes.ts +37 -37
- package/src/plugins/setting/SettingService.ts +213 -213
- package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
- package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
- package/src/plugins/setting/actionHandlers/index.ts +6 -6
- package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
- package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/SystemSettingItem.ts +48 -48
- package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/UserSettingItem.ts +55 -55
- package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/index.ts +8 -8
- package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
- package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
- package/src/plugins/setting/routes/index.ts +5 -5
- package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
- package/src/plugins/stateMachine/StateMachinePlugin.ts +196 -196
- package/src/plugins/stateMachine/StateMachinePluginTypes.ts +48 -48
- package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +54 -54
- package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
- package/src/plugins/stateMachine/models/index.ts +3 -3
- package/src/plugins/stateMachine/routes/index.ts +3 -3
- package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
- package/src/plugins/stateMachine/stateMachineHelper.ts +36 -36
- package/src/plugins/webhooks/WebhooksPlugin.ts +148 -148
- package/src/plugins/webhooks/pluginConfig.ts +75 -75
- package/src/polyfill.ts +5 -5
- package/src/proxy/mod.ts +38 -38
- package/src/proxy/types.ts +21 -21
- package/src/queryBuilder/index.ts +1 -1
- package/src/queryBuilder/queryBuilder.ts +668 -668
- package/src/server.ts +480 -480
- package/src/types.ts +722 -722
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/entityUtility.ts +18 -0
- package/src/utilities/errorUtility.ts +15 -15
- package/src/utilities/fsUtility.ts +61 -61
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/passwordUtility.ts +26 -0
- package/src/utilities/pathUtility.ts +14 -14
- package/src/utilities/timeUtility.ts +9 -9
- package/src/utilities/typeUtility.ts +15 -15
- package/tsconfig.json +19 -19
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
import { IRpdServer } from "~/core/server";
|
|
2
|
-
import EntityManager from "~/dataAccess/entityManager";
|
|
3
|
-
import { LicenseSettings, RpdCert, RpdLicense } from "./LicensePluginTypes";
|
|
4
|
-
import { SystemSettingItem } from "../setting/SettingPluginTypes";
|
|
5
|
-
import SettingService from "../setting/SettingService";
|
|
6
|
-
import { extractCertLicense } from "./helpers/certHelper";
|
|
7
|
-
import dayjs from "dayjs";
|
|
8
|
-
import { get, isString } from "lodash";
|
|
9
|
-
import { isNullOrUndefinedOrEmpty } from "~/utilities/typeUtility";
|
|
10
|
-
|
|
11
|
-
export interface GetSystemSettingValuesInput {
|
|
12
|
-
groupCode: string;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export interface SetSystemSettingValuesInput {
|
|
16
|
-
groupCode: string;
|
|
17
|
-
values: Record<string, any>;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export interface GetUserSettingValuesInput {
|
|
21
|
-
groupCode: string;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export default class LicenseService {
|
|
25
|
-
#server: IRpdServer;
|
|
26
|
-
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
27
|
-
#encryptionKey: string;
|
|
28
|
-
#license: RpdLicense;
|
|
29
|
-
|
|
30
|
-
constructor(server: IRpdServer, encryptionKey: string) {
|
|
31
|
-
this.#server = server;
|
|
32
|
-
this.#encryptionKey = encryptionKey;
|
|
33
|
-
|
|
34
|
-
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
async loadLicense(): Promise<void> {
|
|
38
|
-
const settingService = this.#server.getService<SettingService>("settingService");
|
|
39
|
-
const licenseSettings = await settingService.getSystemSettingValues("license");
|
|
40
|
-
const { deployId } = licenseSettings as LicenseSettings;
|
|
41
|
-
const certText = licenseSettings.cert;
|
|
42
|
-
|
|
43
|
-
if (!deployId || !certText) {
|
|
44
|
-
this.#server.getLogger().warn("License was not loaded properly.");
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
const certJSON = Buffer.from(certText, "base64").toString();
|
|
49
|
-
const cert: RpdCert = JSON.parse(certJSON);
|
|
50
|
-
|
|
51
|
-
try {
|
|
52
|
-
const license = extractCertLicense(this.#encryptionKey, deployId, cert);
|
|
53
|
-
this.#license = license;
|
|
54
|
-
} catch (error) {
|
|
55
|
-
this.#server.getLogger().error("Loading license failed.", error);
|
|
56
|
-
throw new Error("Loading license failed.");
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
getLicense() {
|
|
61
|
-
return this.#license;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
isExpired() {
|
|
65
|
-
if (!this.#license) {
|
|
66
|
-
return true;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
const { neverExpire, expireDate } = this.#license.authority;
|
|
70
|
-
|
|
71
|
-
if (neverExpire) {
|
|
72
|
-
return false;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
if (!expireDate) {
|
|
76
|
-
return true;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
const today = dayjs(dayjs().format("YYYY-MM-DD"));
|
|
80
|
-
return today.isAfter(dayjs(expireDate));
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
getQuota(name: string) {
|
|
84
|
-
if (!this.#license) {
|
|
85
|
-
return null;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
return get(this.#license.authority, `quota.${name}`, null);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
isOutOfQuota(name: string, currentAmount: number) {
|
|
92
|
-
const quotaLimit = this.getQuota(name);
|
|
93
|
-
|
|
94
|
-
if (isNullOrUndefinedOrEmpty(quotaLimit)) {
|
|
95
|
-
return true;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
let quotaLimitAmount: string | number = quotaLimit;
|
|
99
|
-
if (isString(quotaLimitAmount)) {
|
|
100
|
-
quotaLimitAmount = parseInt(quotaLimit, 10);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
if (quotaLimitAmount === -1) {
|
|
104
|
-
return true;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
return currentAmount > quotaLimitAmount;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
isFunctionAllowed(name: string) {
|
|
111
|
-
if (!this.#license) {
|
|
112
|
-
return false;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
const functions = get(this.#license.authority, "functions", []);
|
|
116
|
-
return functions.includes(name);
|
|
117
|
-
}
|
|
118
|
-
}
|
|
1
|
+
import { IRpdServer } from "~/core/server";
|
|
2
|
+
import EntityManager from "~/dataAccess/entityManager";
|
|
3
|
+
import { LicenseSettings, RpdCert, RpdLicense } from "./LicensePluginTypes";
|
|
4
|
+
import { SystemSettingItem } from "../setting/SettingPluginTypes";
|
|
5
|
+
import SettingService from "../setting/SettingService";
|
|
6
|
+
import { extractCertLicense } from "./helpers/certHelper";
|
|
7
|
+
import dayjs from "dayjs";
|
|
8
|
+
import { get, isString } from "lodash";
|
|
9
|
+
import { isNullOrUndefinedOrEmpty } from "~/utilities/typeUtility";
|
|
10
|
+
|
|
11
|
+
export interface GetSystemSettingValuesInput {
|
|
12
|
+
groupCode: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export interface SetSystemSettingValuesInput {
|
|
16
|
+
groupCode: string;
|
|
17
|
+
values: Record<string, any>;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface GetUserSettingValuesInput {
|
|
21
|
+
groupCode: string;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export default class LicenseService {
|
|
25
|
+
#server: IRpdServer;
|
|
26
|
+
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
27
|
+
#encryptionKey: string;
|
|
28
|
+
#license: RpdLicense;
|
|
29
|
+
|
|
30
|
+
constructor(server: IRpdServer, encryptionKey: string) {
|
|
31
|
+
this.#server = server;
|
|
32
|
+
this.#encryptionKey = encryptionKey;
|
|
33
|
+
|
|
34
|
+
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
async loadLicense(): Promise<void> {
|
|
38
|
+
const settingService = this.#server.getService<SettingService>("settingService");
|
|
39
|
+
const licenseSettings = await settingService.getSystemSettingValues("license");
|
|
40
|
+
const { deployId } = licenseSettings as LicenseSettings;
|
|
41
|
+
const certText = licenseSettings.cert;
|
|
42
|
+
|
|
43
|
+
if (!deployId || !certText) {
|
|
44
|
+
this.#server.getLogger().warn("License was not loaded properly.");
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
const certJSON = Buffer.from(certText, "base64").toString();
|
|
49
|
+
const cert: RpdCert = JSON.parse(certJSON);
|
|
50
|
+
|
|
51
|
+
try {
|
|
52
|
+
const license = extractCertLicense(this.#encryptionKey, deployId, cert);
|
|
53
|
+
this.#license = license;
|
|
54
|
+
} catch (error) {
|
|
55
|
+
this.#server.getLogger().error("Loading license failed.", error);
|
|
56
|
+
throw new Error("Loading license failed.");
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
getLicense() {
|
|
61
|
+
return this.#license;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
isExpired() {
|
|
65
|
+
if (!this.#license) {
|
|
66
|
+
return true;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const { neverExpire, expireDate } = this.#license.authority;
|
|
70
|
+
|
|
71
|
+
if (neverExpire) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (!expireDate) {
|
|
76
|
+
return true;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const today = dayjs(dayjs().format("YYYY-MM-DD"));
|
|
80
|
+
return today.isAfter(dayjs(expireDate));
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
getQuota(name: string) {
|
|
84
|
+
if (!this.#license) {
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return get(this.#license.authority, `quota.${name}`, null);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
isOutOfQuota(name: string, currentAmount: number) {
|
|
92
|
+
const quotaLimit = this.getQuota(name);
|
|
93
|
+
|
|
94
|
+
if (isNullOrUndefinedOrEmpty(quotaLimit)) {
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
let quotaLimitAmount: string | number = quotaLimit;
|
|
99
|
+
if (isString(quotaLimitAmount)) {
|
|
100
|
+
quotaLimitAmount = parseInt(quotaLimit, 10);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
if (quotaLimitAmount === -1) {
|
|
104
|
+
return true;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
return currentAmount > quotaLimitAmount;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
isFunctionAllowed(name: string) {
|
|
111
|
+
if (!this.#license) {
|
|
112
|
+
return false;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
const functions = get(this.#license.authority, "functions", []);
|
|
116
|
+
return functions.includes(name);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import LicenseService from "../LicenseService";
|
|
4
|
-
|
|
5
|
-
export interface GetLicenseOptions {}
|
|
6
|
-
|
|
7
|
-
export const code = "getLicense";
|
|
8
|
-
|
|
9
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetLicenseOptions) {
|
|
10
|
-
const { server, routerContext } = ctx;
|
|
11
|
-
const { response } = routerContext;
|
|
12
|
-
|
|
13
|
-
const licenseService = server.getService<LicenseService>("licenseService");
|
|
14
|
-
|
|
15
|
-
const license = licenseService.getLicense();
|
|
16
|
-
|
|
17
|
-
ctx.output = license;
|
|
18
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import LicenseService from "../LicenseService";
|
|
4
|
+
|
|
5
|
+
export interface GetLicenseOptions {}
|
|
6
|
+
|
|
7
|
+
export const code = "getLicense";
|
|
8
|
+
|
|
9
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: GetLicenseOptions) {
|
|
10
|
+
const { server, routerContext } = ctx;
|
|
11
|
+
const { response } = routerContext;
|
|
12
|
+
|
|
13
|
+
const licenseService = server.getService<LicenseService>("licenseService");
|
|
14
|
+
|
|
15
|
+
const license = licenseService.getLicense();
|
|
16
|
+
|
|
17
|
+
ctx.output = license;
|
|
18
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
-
import * as getLicense from "./getLicense";
|
|
3
|
-
|
|
4
|
-
export default [getLicense] satisfies IPluginActionHandler[];
|
|
1
|
+
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
+
import * as getLicense from "./getLicense";
|
|
3
|
+
|
|
4
|
+
export default [getLicense] satisfies IPluginActionHandler[];
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { RpdCert } from "../LicensePluginTypes";
|
|
2
|
-
import { decryptData, getEncryptionIV, validateDigitalSignature, generatePubKeyFileContent } from "./cryptoHelper";
|
|
3
|
-
|
|
4
|
-
export function extractCertLicense(encryptionKey: string, deployId: string, cert: RpdCert) {
|
|
5
|
-
const iv = getEncryptionIV(deployId);
|
|
6
|
-
const signature = cert.sig;
|
|
7
|
-
const pub = generatePubKeyFileContent(cert.pub);
|
|
8
|
-
const valid = validateDigitalSignature(cert.lic, "base64", signature, "base64", pub);
|
|
9
|
-
if (!valid) {
|
|
10
|
-
throw new Error("Certification validate failed.");
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
try {
|
|
14
|
-
const licenseText = decryptData(cert.lic, "base64", "utf-8", encryptionKey, iv, cert.tag);
|
|
15
|
-
return JSON.parse(licenseText);
|
|
16
|
-
} catch (ex) {
|
|
17
|
-
throw new Error("Certification parse failed.", {
|
|
18
|
-
cause: ex,
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
}
|
|
1
|
+
import { RpdCert } from "../LicensePluginTypes";
|
|
2
|
+
import { decryptData, getEncryptionIV, validateDigitalSignature, generatePubKeyFileContent } from "./cryptoHelper";
|
|
3
|
+
|
|
4
|
+
export function extractCertLicense(encryptionKey: string, deployId: string, cert: RpdCert) {
|
|
5
|
+
const iv = getEncryptionIV(deployId);
|
|
6
|
+
const signature = cert.sig;
|
|
7
|
+
const pub = generatePubKeyFileContent(cert.pub);
|
|
8
|
+
const valid = validateDigitalSignature(cert.lic, "base64", signature, "base64", pub);
|
|
9
|
+
if (!valid) {
|
|
10
|
+
throw new Error("Certification validate failed.");
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
try {
|
|
14
|
+
const licenseText = decryptData(cert.lic, "base64", "utf-8", encryptionKey, iv, cert.tag);
|
|
15
|
+
return JSON.parse(licenseText);
|
|
16
|
+
} catch (ex) {
|
|
17
|
+
throw new Error("Certification parse failed.", {
|
|
18
|
+
cause: ex,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
import crypto, { BinaryToTextEncoding } from "crypto";
|
|
2
|
-
|
|
3
|
-
export function getEncryptionIV(input: string) {
|
|
4
|
-
const hash = crypto.createHash("sha512").update(input).digest("hex");
|
|
5
|
-
return hash.substring(0, 12);
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export function generatePubKeyFileContent(base64EncodedPubKey: string) {
|
|
9
|
-
return `-----BEGIN PUBLIC KEY-----\n${base64EncodedPubKey}\n-----END PUBLIC KEY-----`;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
const ENC_ALGORITHM: crypto.CipherGCMTypes = "aes-256-gcm";
|
|
13
|
-
|
|
14
|
-
// Decrypt data
|
|
15
|
-
export function decryptData(
|
|
16
|
-
encryptedData: string,
|
|
17
|
-
encryptedDataEncoding: BufferEncoding,
|
|
18
|
-
decryptedDataEncoding: BufferEncoding,
|
|
19
|
-
encryptionKey: string,
|
|
20
|
-
encryptionIV: string,
|
|
21
|
-
authTag: string,
|
|
22
|
-
) {
|
|
23
|
-
const decipher = crypto.createDecipheriv(ENC_ALGORITHM, Buffer.from(encryptionKey, "base64"), encryptionIV);
|
|
24
|
-
decipher.setAuthTag(Buffer.from(authTag, "base64"));
|
|
25
|
-
const buff = Buffer.from(encryptedData, encryptedDataEncoding);
|
|
26
|
-
return Buffer.concat([decipher.update(buff), decipher.final()]).toString(decryptedDataEncoding); // Decrypts data and converts to utf8
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function generateDigitalSignature(data: string, dataEncoding: BufferEncoding, privateKey: string): string {
|
|
30
|
-
const sign = crypto.createSign("RSA-SHA256");
|
|
31
|
-
const buffer = Buffer.from(data, dataEncoding);
|
|
32
|
-
sign.update(buffer);
|
|
33
|
-
return sign.sign(privateKey, "base64");
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export function validateDigitalSignature(
|
|
37
|
-
data: string,
|
|
38
|
-
dataEncoding: BufferEncoding,
|
|
39
|
-
signature: string,
|
|
40
|
-
signatureEncoding: BinaryToTextEncoding,
|
|
41
|
-
publicKey: string,
|
|
42
|
-
): boolean {
|
|
43
|
-
const verify = crypto.createVerify("RSA-SHA256");
|
|
44
|
-
const buffer = Buffer.from(data, dataEncoding);
|
|
45
|
-
verify.update(buffer);
|
|
46
|
-
return verify.verify(publicKey, signature, signatureEncoding);
|
|
47
|
-
}
|
|
1
|
+
import crypto, { BinaryToTextEncoding } from "crypto";
|
|
2
|
+
|
|
3
|
+
export function getEncryptionIV(input: string) {
|
|
4
|
+
const hash = crypto.createHash("sha512").update(input).digest("hex");
|
|
5
|
+
return hash.substring(0, 12);
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export function generatePubKeyFileContent(base64EncodedPubKey: string) {
|
|
9
|
+
return `-----BEGIN PUBLIC KEY-----\n${base64EncodedPubKey}\n-----END PUBLIC KEY-----`;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const ENC_ALGORITHM: crypto.CipherGCMTypes = "aes-256-gcm";
|
|
13
|
+
|
|
14
|
+
// Decrypt data
|
|
15
|
+
export function decryptData(
|
|
16
|
+
encryptedData: string,
|
|
17
|
+
encryptedDataEncoding: BufferEncoding,
|
|
18
|
+
decryptedDataEncoding: BufferEncoding,
|
|
19
|
+
encryptionKey: string,
|
|
20
|
+
encryptionIV: string,
|
|
21
|
+
authTag: string,
|
|
22
|
+
) {
|
|
23
|
+
const decipher = crypto.createDecipheriv(ENC_ALGORITHM, Buffer.from(encryptionKey, "base64"), encryptionIV);
|
|
24
|
+
decipher.setAuthTag(Buffer.from(authTag, "base64"));
|
|
25
|
+
const buff = Buffer.from(encryptedData, encryptedDataEncoding);
|
|
26
|
+
return Buffer.concat([decipher.update(buff), decipher.final()]).toString(decryptedDataEncoding); // Decrypts data and converts to utf8
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function generateDigitalSignature(data: string, dataEncoding: BufferEncoding, privateKey: string): string {
|
|
30
|
+
const sign = crypto.createSign("RSA-SHA256");
|
|
31
|
+
const buffer = Buffer.from(data, dataEncoding);
|
|
32
|
+
sign.update(buffer);
|
|
33
|
+
return sign.sign(privateKey, "base64");
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export function validateDigitalSignature(
|
|
37
|
+
data: string,
|
|
38
|
+
dataEncoding: BufferEncoding,
|
|
39
|
+
signature: string,
|
|
40
|
+
signatureEncoding: BinaryToTextEncoding,
|
|
41
|
+
publicKey: string,
|
|
42
|
+
): boolean {
|
|
43
|
+
const verify = crypto.createVerify("RSA-SHA256");
|
|
44
|
+
const buffer = Buffer.from(data, dataEncoding);
|
|
45
|
+
verify.update(buffer);
|
|
46
|
+
return verify.verify(publicKey, signature, signatureEncoding);
|
|
47
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export default [];
|
|
1
|
+
export default [];
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "svc",
|
|
5
|
-
name: "svc.getLicense",
|
|
6
|
-
code: "svc.getLicense",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "GET",
|
|
9
|
-
endpoint: "/svc/license",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "getLicense",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "svc",
|
|
5
|
+
name: "svc.getLicense",
|
|
6
|
+
code: "svc.getLicense",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "GET",
|
|
9
|
+
endpoint: "/svc/license",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "getLicense",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import getLicense from "./getLicense";
|
|
2
|
-
|
|
3
|
-
export default [getLicense];
|
|
1
|
+
import getLicense from "./getLicense";
|
|
2
|
+
|
|
3
|
+
export default [getLicense];
|
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mail plugin
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { RpdApplicationConfig } from "~/types";
|
|
6
|
-
import {
|
|
7
|
-
IRpdServer,
|
|
8
|
-
RapidPlugin,
|
|
9
|
-
RpdConfigurationItemOptions,
|
|
10
|
-
RpdServerPluginConfigurableTargetOptions,
|
|
11
|
-
RpdServerPluginExtendingAbilities,
|
|
12
|
-
} from "~/core/server";
|
|
13
|
-
|
|
14
|
-
import pluginActionHandlers from "./actionHandlers";
|
|
15
|
-
import pluginModels from "./models";
|
|
16
|
-
import pluginRoutes from "./routes";
|
|
17
|
-
import MailService from "./MailService";
|
|
18
|
-
import { MailPluginConfig } from "./MailPluginTypes";
|
|
19
|
-
|
|
20
|
-
class MailPlugin implements RapidPlugin {
|
|
21
|
-
#mailService!: MailService;
|
|
22
|
-
#config: MailPluginConfig;
|
|
23
|
-
|
|
24
|
-
constructor(config: MailPluginConfig) {
|
|
25
|
-
this.#config = config;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
get mailService() {
|
|
29
|
-
return this.#mailService;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
get code(): string {
|
|
33
|
-
return "mail";
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
get description(): string {
|
|
37
|
-
return null;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
41
|
-
return [];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
45
|
-
return [];
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
get configurations(): RpdConfigurationItemOptions[] {
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
53
|
-
for (const actionHandler of pluginActionHandlers) {
|
|
54
|
-
server.registerActionHandler(this, actionHandler);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
59
|
-
server.appendApplicationConfig({ models: pluginModels });
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
async configureServices(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
63
|
-
this.#mailService = new MailService(server, this.#config.smtpServer);
|
|
64
|
-
server.registerService("mailService", this.#mailService);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
68
|
-
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig) {}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
export default MailPlugin;
|
|
1
|
+
/**
|
|
2
|
+
* Mail plugin
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { RpdApplicationConfig } from "~/types";
|
|
6
|
+
import {
|
|
7
|
+
IRpdServer,
|
|
8
|
+
RapidPlugin,
|
|
9
|
+
RpdConfigurationItemOptions,
|
|
10
|
+
RpdServerPluginConfigurableTargetOptions,
|
|
11
|
+
RpdServerPluginExtendingAbilities,
|
|
12
|
+
} from "~/core/server";
|
|
13
|
+
|
|
14
|
+
import pluginActionHandlers from "./actionHandlers";
|
|
15
|
+
import pluginModels from "./models";
|
|
16
|
+
import pluginRoutes from "./routes";
|
|
17
|
+
import MailService from "./MailService";
|
|
18
|
+
import { MailPluginConfig } from "./MailPluginTypes";
|
|
19
|
+
|
|
20
|
+
class MailPlugin implements RapidPlugin {
|
|
21
|
+
#mailService!: MailService;
|
|
22
|
+
#config: MailPluginConfig;
|
|
23
|
+
|
|
24
|
+
constructor(config: MailPluginConfig) {
|
|
25
|
+
this.#config = config;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
get mailService() {
|
|
29
|
+
return this.#mailService;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
get code(): string {
|
|
33
|
+
return "mail";
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
get description(): string {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
41
|
+
return [];
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
45
|
+
return [];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
get configurations(): RpdConfigurationItemOptions[] {
|
|
49
|
+
return [];
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
53
|
+
for (const actionHandler of pluginActionHandlers) {
|
|
54
|
+
server.registerActionHandler(this, actionHandler);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
59
|
+
server.appendApplicationConfig({ models: pluginModels });
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
async configureServices(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
63
|
+
this.#mailService = new MailService(server, this.#config.smtpServer);
|
|
64
|
+
server.registerService("mailService", this.#mailService);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
68
|
+
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
async onApplicationLoaded(server: IRpdServer, applicationConfig: RpdApplicationConfig) {}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export default MailPlugin;
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
export type MailPluginConfig = {
|
|
2
|
-
smtpServer: RpdMailSmtpServer;
|
|
3
|
-
};
|
|
4
|
-
|
|
5
|
-
export type RpdMailSmtpServer = {
|
|
6
|
-
host: string;
|
|
7
|
-
port: number;
|
|
8
|
-
secure: boolean; // true for port 465, false for other ports (normally 587).
|
|
9
|
-
username: string;
|
|
10
|
-
password: string;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export type RpdMail = {
|
|
14
|
-
from?: string;
|
|
15
|
-
to?: string;
|
|
16
|
-
subject?: string;
|
|
17
|
-
text?: string;
|
|
18
|
-
html?: string;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export type SendMailOptions = {
|
|
22
|
-
from?: string;
|
|
23
|
-
to?: string;
|
|
24
|
-
subject?: string;
|
|
25
|
-
text?: string;
|
|
26
|
-
html?: string;
|
|
27
|
-
};
|
|
1
|
+
export type MailPluginConfig = {
|
|
2
|
+
smtpServer: RpdMailSmtpServer;
|
|
3
|
+
};
|
|
4
|
+
|
|
5
|
+
export type RpdMailSmtpServer = {
|
|
6
|
+
host: string;
|
|
7
|
+
port: number;
|
|
8
|
+
secure: boolean; // true for port 465, false for other ports (normally 587).
|
|
9
|
+
username: string;
|
|
10
|
+
password: string;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export type RpdMail = {
|
|
14
|
+
from?: string;
|
|
15
|
+
to?: string;
|
|
16
|
+
subject?: string;
|
|
17
|
+
text?: string;
|
|
18
|
+
html?: string;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export type SendMailOptions = {
|
|
22
|
+
from?: string;
|
|
23
|
+
to?: string;
|
|
24
|
+
subject?: string;
|
|
25
|
+
text?: string;
|
|
26
|
+
html?: string;
|
|
27
|
+
};
|