@ruiapp/rapid-core 0.11.5 → 0.11.7
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 +11 -11
- package/dist/core/pluginManager.d.ts +2 -0
- package/dist/core/server.d.ts +3 -0
- package/dist/dataAccess/entityManager.d.ts +3 -3
- package/dist/index.js +118 -41
- package/dist/server.d.ts +1 -0
- package/dist/types.d.ts +2 -0
- package/package.json +1 -1
- package/rollup.config.js +16 -16
- package/src/bootstrapApplicationConfig.ts +904 -904
- package/src/core/ExpressionInterpreter.ts +45 -45
- package/src/core/actionHandler.ts +24 -24
- package/src/core/actionHandlers/ifActionHandler.ts +27 -27
- package/src/core/eventManager.ts +20 -20
- package/src/core/facility.ts +7 -7
- package/src/core/http/formDataParser.ts +87 -87
- package/src/core/http-types.ts +4 -4
- package/src/core/pluginManager.ts +202 -193
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +96 -96
- package/src/core/response.ts +84 -84
- package/src/core/routeContext.ts +127 -127
- package/src/core/routes/healthz.ts +20 -20
- package/src/core/routes/index.ts +3 -3
- package/src/core/routesBuilder.ts +129 -122
- package/src/core/server.ts +161 -158
- package/src/dataAccess/columnTypeMapper.ts +22 -22
- package/src/dataAccess/dataAccessTypes.ts +165 -165
- package/src/dataAccess/dataAccessor.ts +135 -135
- package/src/dataAccess/entityManager.ts +2031 -1986
- package/src/dataAccess/entityMapper.ts +111 -111
- package/src/dataAccess/entityValidator.ts +33 -33
- 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 -29
- package/src/facilities/cache/CacheFactory.ts +31 -31
- package/src/facilities/cache/MemoryCache.ts +58 -58
- package/src/facilities/cache/MemoryCacheProvider.ts +15 -15
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/dbTransactionHelper.ts +42 -42
- package/src/helpers/entityHelper.ts +89 -89
- package/src/helpers/filterHelper.ts +148 -148
- package/src/helpers/inputHelper.ts +11 -11
- package/src/helpers/licenseHelper.ts +29 -29
- package/src/helpers/metaHelper.ts +111 -111
- package/src/helpers/runCollectionEntityActionHandler.ts +58 -58
- package/src/index.ts +85 -85
- package/src/plugins/auth/AuthPlugin.ts +107 -107
- package/src/plugins/auth/AuthPluginTypes.ts +11 -11
- package/src/plugins/auth/actionHandlers/changePassword.ts +61 -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 +28 -28
- package/src/plugins/auth/actionHandlers/index.ts +8 -8
- package/src/plugins/auth/actionHandlers/resetPassword.ts +45 -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 +66 -66
- package/src/plugins/cronJob/CronJobPlugin.ts +104 -104
- package/src/plugins/cronJob/CronJobPluginTypes.ts +44 -44
- package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
- package/src/plugins/cronJob/actionHandlers/runCronJob.ts +32 -32
- package/src/plugins/cronJob/entityWatchers/cronJobEntityWatchers.ts +24 -24
- package/src/plugins/cronJob/entityWatchers/index.ts +4 -4
- package/src/plugins/cronJob/models/CronJob.ts +129 -129
- package/src/plugins/cronJob/models/index.ts +3 -3
- package/src/plugins/cronJob/routes/index.ts +3 -3
- package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
- package/src/plugins/cronJob/services/CronJobService.ts +255 -255
- package/src/plugins/dataManage/DataManagePlugin.ts +165 -165
- 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 +47 -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/saveEntity.ts +46 -46
- 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 +141 -141
- package/src/plugins/license/actionHandlers/getLicense.ts +18 -18
- package/src/plugins/license/actionHandlers/index.ts +5 -5
- package/src/plugins/license/actionHandlers/updateLicense.ts +24 -24
- 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 +4 -4
- package/src/plugins/license/routes/updateLicense.ts +15 -15
- 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 +198 -198
- package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +10 -10
- package/src/plugins/metaManage/services/MetaService.ts +376 -376
- 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 +64 -64
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/routeManage/actionHandlers/mock.ts +28 -28
- 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 +93 -93
- package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +25 -25
- package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
- package/src/plugins/serverOperation/actionHandlers/runServerOperation.ts +20 -20
- package/src/plugins/setting/SettingPlugin.ts +68 -68
- package/src/plugins/setting/SettingPluginTypes.ts +37 -37
- package/src/plugins/setting/SettingService.ts +222 -222
- 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 +755 -755
- package/src/server.ts +567 -556
- package/src/types/cron-job-types.ts +71 -71
- package/src/types.ts +884 -882
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/entityUtility.ts +18 -18
- package/src/utilities/errorUtility.ts +15 -15
- package/src/utilities/fsUtility.ts +137 -137
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/passwordUtility.ts +26 -26
- package/src/utilities/pathUtility.ts +14 -14
- package/src/utilities/timeUtility.ts +17 -17
- package/src/utilities/typeUtility.ts +15 -15
- package/tsconfig.json +19 -19
|
@@ -1,141 +1,141 @@
|
|
|
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
|
-
import { RouteContext } from "~/core/routeContext";
|
|
11
|
-
|
|
12
|
-
export interface GetSystemSettingValuesInput {
|
|
13
|
-
groupCode: string;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export interface SetSystemSettingValuesInput {
|
|
17
|
-
groupCode: string;
|
|
18
|
-
values: Record<string, any>;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export interface GetUserSettingValuesInput {
|
|
22
|
-
groupCode: string;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export default class LicenseService {
|
|
26
|
-
#server: IRpdServer;
|
|
27
|
-
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
28
|
-
#encryptionKey: string;
|
|
29
|
-
#license: RpdLicense;
|
|
30
|
-
|
|
31
|
-
constructor(server: IRpdServer, encryptionKey: string) {
|
|
32
|
-
this.#server = server;
|
|
33
|
-
this.#encryptionKey = encryptionKey;
|
|
34
|
-
|
|
35
|
-
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
async loadLicense(): Promise<void> {
|
|
39
|
-
const routeContext = new RouteContext(this.#server, null);
|
|
40
|
-
|
|
41
|
-
const settingService = this.#server.getService<SettingService>("settingService");
|
|
42
|
-
const licenseSettings = await settingService.getSystemSettingValues(routeContext, "license");
|
|
43
|
-
const { deployId, cert: certText } = licenseSettings as LicenseSettings;
|
|
44
|
-
|
|
45
|
-
if (!deployId || !certText) {
|
|
46
|
-
this.#server.getLogger().warn("License was not loaded properly.");
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
try {
|
|
51
|
-
const license = this.parseLicense(deployId, certText);
|
|
52
|
-
this.#license = license;
|
|
53
|
-
} catch (error) {
|
|
54
|
-
this.#server.getLogger().error("Loading license failed.", error);
|
|
55
|
-
throw new Error("Loading license failed.");
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
getLicense() {
|
|
60
|
-
return this.#license;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
parseLicense(deployId: string, certText: string): RpdLicense {
|
|
64
|
-
const certJSON = Buffer.from(certText, "base64").toString();
|
|
65
|
-
const cert: RpdCert = JSON.parse(certJSON);
|
|
66
|
-
return extractCertLicense(this.#encryptionKey, deployId, cert);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
async updateLicense(certText: string) {
|
|
70
|
-
const routeContext = new RouteContext(this.#server, null);
|
|
71
|
-
const settingService = this.#server.getService<SettingService>("settingService");
|
|
72
|
-
const deployId: string = await settingService.getSystemSettingValue(routeContext, "license", "deployId");
|
|
73
|
-
|
|
74
|
-
let license: RpdLicense;
|
|
75
|
-
try {
|
|
76
|
-
license = this.parseLicense(deployId, certText);
|
|
77
|
-
} catch (error) {
|
|
78
|
-
this.#server.getLogger().error("Parse license failed.", error);
|
|
79
|
-
throw new Error("Parse license failed.");
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
await settingService.setSystemSettingValue(routeContext, "license", "cert", certText);
|
|
83
|
-
this.#license = license;
|
|
84
|
-
return license;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
isExpired() {
|
|
88
|
-
if (!this.#license) {
|
|
89
|
-
return true;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
const { neverExpire, expireDate } = this.#license.authority;
|
|
93
|
-
|
|
94
|
-
if (neverExpire) {
|
|
95
|
-
return false;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
if (!expireDate) {
|
|
99
|
-
return true;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
const today = dayjs(dayjs().format("YYYY-MM-DD"));
|
|
103
|
-
return today.isAfter(dayjs(expireDate));
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
getQuota(name: string) {
|
|
107
|
-
if (!this.#license) {
|
|
108
|
-
return null;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
return get(this.#license.authority, `quota.${name}`, null);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
isOutOfQuota(name: string, currentAmount: number) {
|
|
115
|
-
const quotaLimit = this.getQuota(name);
|
|
116
|
-
|
|
117
|
-
if (isNullOrUndefinedOrEmpty(quotaLimit)) {
|
|
118
|
-
return true;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
let quotaLimitAmount: string | number = quotaLimit;
|
|
122
|
-
if (isString(quotaLimitAmount)) {
|
|
123
|
-
quotaLimitAmount = parseInt(quotaLimit, 10);
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
if (quotaLimitAmount === -1) {
|
|
127
|
-
return true;
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
return currentAmount > quotaLimitAmount;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
isFunctionAllowed(name: string) {
|
|
134
|
-
if (!this.#license) {
|
|
135
|
-
return false;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const functions = get(this.#license.authority, "functions", []);
|
|
139
|
-
return functions.includes(name);
|
|
140
|
-
}
|
|
141
|
-
}
|
|
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
|
+
import { RouteContext } from "~/core/routeContext";
|
|
11
|
+
|
|
12
|
+
export interface GetSystemSettingValuesInput {
|
|
13
|
+
groupCode: string;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export interface SetSystemSettingValuesInput {
|
|
17
|
+
groupCode: string;
|
|
18
|
+
values: Record<string, any>;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface GetUserSettingValuesInput {
|
|
22
|
+
groupCode: string;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export default class LicenseService {
|
|
26
|
+
#server: IRpdServer;
|
|
27
|
+
#systemSettingItemManager: EntityManager<SystemSettingItem>;
|
|
28
|
+
#encryptionKey: string;
|
|
29
|
+
#license: RpdLicense;
|
|
30
|
+
|
|
31
|
+
constructor(server: IRpdServer, encryptionKey: string) {
|
|
32
|
+
this.#server = server;
|
|
33
|
+
this.#encryptionKey = encryptionKey;
|
|
34
|
+
|
|
35
|
+
this.#systemSettingItemManager = server.getEntityManager("system_setting_item");
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
async loadLicense(): Promise<void> {
|
|
39
|
+
const routeContext = new RouteContext(this.#server, null);
|
|
40
|
+
|
|
41
|
+
const settingService = this.#server.getService<SettingService>("settingService");
|
|
42
|
+
const licenseSettings = await settingService.getSystemSettingValues(routeContext, "license");
|
|
43
|
+
const { deployId, cert: certText } = licenseSettings as LicenseSettings;
|
|
44
|
+
|
|
45
|
+
if (!deployId || !certText) {
|
|
46
|
+
this.#server.getLogger().warn("License was not loaded properly.");
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
try {
|
|
51
|
+
const license = this.parseLicense(deployId, certText);
|
|
52
|
+
this.#license = license;
|
|
53
|
+
} catch (error) {
|
|
54
|
+
this.#server.getLogger().error("Loading license failed.", error);
|
|
55
|
+
throw new Error("Loading license failed.");
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getLicense() {
|
|
60
|
+
return this.#license;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
parseLicense(deployId: string, certText: string): RpdLicense {
|
|
64
|
+
const certJSON = Buffer.from(certText, "base64").toString();
|
|
65
|
+
const cert: RpdCert = JSON.parse(certJSON);
|
|
66
|
+
return extractCertLicense(this.#encryptionKey, deployId, cert);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
async updateLicense(certText: string) {
|
|
70
|
+
const routeContext = new RouteContext(this.#server, null);
|
|
71
|
+
const settingService = this.#server.getService<SettingService>("settingService");
|
|
72
|
+
const deployId: string = await settingService.getSystemSettingValue(routeContext, "license", "deployId");
|
|
73
|
+
|
|
74
|
+
let license: RpdLicense;
|
|
75
|
+
try {
|
|
76
|
+
license = this.parseLicense(deployId, certText);
|
|
77
|
+
} catch (error) {
|
|
78
|
+
this.#server.getLogger().error("Parse license failed.", error);
|
|
79
|
+
throw new Error("Parse license failed.");
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
await settingService.setSystemSettingValue(routeContext, "license", "cert", certText);
|
|
83
|
+
this.#license = license;
|
|
84
|
+
return license;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
isExpired() {
|
|
88
|
+
if (!this.#license) {
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
const { neverExpire, expireDate } = this.#license.authority;
|
|
93
|
+
|
|
94
|
+
if (neverExpire) {
|
|
95
|
+
return false;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
if (!expireDate) {
|
|
99
|
+
return true;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
const today = dayjs(dayjs().format("YYYY-MM-DD"));
|
|
103
|
+
return today.isAfter(dayjs(expireDate));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
getQuota(name: string) {
|
|
107
|
+
if (!this.#license) {
|
|
108
|
+
return null;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return get(this.#license.authority, `quota.${name}`, null);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
isOutOfQuota(name: string, currentAmount: number) {
|
|
115
|
+
const quotaLimit = this.getQuota(name);
|
|
116
|
+
|
|
117
|
+
if (isNullOrUndefinedOrEmpty(quotaLimit)) {
|
|
118
|
+
return true;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
let quotaLimitAmount: string | number = quotaLimit;
|
|
122
|
+
if (isString(quotaLimitAmount)) {
|
|
123
|
+
quotaLimitAmount = parseInt(quotaLimit, 10);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
if (quotaLimitAmount === -1) {
|
|
127
|
+
return true;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
return currentAmount > quotaLimitAmount;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
isFunctionAllowed(name: string) {
|
|
134
|
+
if (!this.#license) {
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const functions = get(this.#license.authority, "functions", []);
|
|
139
|
+
return functions.includes(name);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
@@ -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,5 +1,5 @@
|
|
|
1
|
-
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
-
import * as getLicense from "./getLicense";
|
|
3
|
-
import * as updateLicense from "./updateLicense";
|
|
4
|
-
|
|
5
|
-
export default [getLicense, updateLicense] satisfies IPluginActionHandler[];
|
|
1
|
+
import { IPluginActionHandler } from "~/core/actionHandler";
|
|
2
|
+
import * as getLicense from "./getLicense";
|
|
3
|
+
import * as updateLicense from "./updateLicense";
|
|
4
|
+
|
|
5
|
+
export default [getLicense, updateLicense] satisfies IPluginActionHandler[];
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import LicenseService from "../LicenseService";
|
|
4
|
-
|
|
5
|
-
export interface UpdateLicenseOptions {}
|
|
6
|
-
|
|
7
|
-
export interface UpdateLicenseInput {
|
|
8
|
-
certText: string;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export const code = "updateLicense";
|
|
12
|
-
|
|
13
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: UpdateLicenseOptions) {
|
|
14
|
-
const { server, routerContext } = ctx;
|
|
15
|
-
const { response } = routerContext;
|
|
16
|
-
|
|
17
|
-
const input: UpdateLicenseInput = ctx.input;
|
|
18
|
-
|
|
19
|
-
const licenseService = server.getService<LicenseService>("licenseService");
|
|
20
|
-
|
|
21
|
-
const license = await licenseService.updateLicense(input.certText);
|
|
22
|
-
|
|
23
|
-
ctx.output = license;
|
|
24
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import LicenseService from "../LicenseService";
|
|
4
|
+
|
|
5
|
+
export interface UpdateLicenseOptions {}
|
|
6
|
+
|
|
7
|
+
export interface UpdateLicenseInput {
|
|
8
|
+
certText: string;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export const code = "updateLicense";
|
|
12
|
+
|
|
13
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: UpdateLicenseOptions) {
|
|
14
|
+
const { server, routerContext } = ctx;
|
|
15
|
+
const { response } = routerContext;
|
|
16
|
+
|
|
17
|
+
const input: UpdateLicenseInput = ctx.input;
|
|
18
|
+
|
|
19
|
+
const licenseService = server.getService<LicenseService>("licenseService");
|
|
20
|
+
|
|
21
|
+
const license = await licenseService.updateLicense(input.certText);
|
|
22
|
+
|
|
23
|
+
ctx.output = license;
|
|
24
|
+
}
|
|
@@ -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,4 +1,4 @@
|
|
|
1
|
-
import getLicense from "./getLicense";
|
|
2
|
-
import updateLicense from "./updateLicense";
|
|
3
|
-
|
|
4
|
-
export default [getLicense, updateLicense];
|
|
1
|
+
import getLicense from "./getLicense";
|
|
2
|
+
import updateLicense from "./updateLicense";
|
|
3
|
+
|
|
4
|
+
export default [getLicense, updateLicense];
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { RpdRoute } from "~/types";
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
namespace: "svc",
|
|
5
|
-
name: "svc.updateLicense",
|
|
6
|
-
code: "svc.updateLicense",
|
|
7
|
-
type: "RESTful",
|
|
8
|
-
method: "POST",
|
|
9
|
-
endpoint: "/svc/license",
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
code: "updateLicense",
|
|
13
|
-
},
|
|
14
|
-
],
|
|
15
|
-
} satisfies RpdRoute;
|
|
1
|
+
import { RpdRoute } from "~/types";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
namespace: "svc",
|
|
5
|
+
name: "svc.updateLicense",
|
|
6
|
+
code: "svc.updateLicense",
|
|
7
|
+
type: "RESTful",
|
|
8
|
+
method: "POST",
|
|
9
|
+
endpoint: "/svc/license",
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
code: "updateLicense",
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
} satisfies RpdRoute;
|