@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,27 +1,29 @@
|
|
|
1
|
-
import { IRpdServer } from "~/core/server";
|
|
2
|
-
|
|
3
|
-
export interface CacheFactoryConfig {
|
|
4
|
-
providers?: CacheProvider[];
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export interface CacheProvider {
|
|
8
|
-
providerName: string;
|
|
9
|
-
createCache: (server: IRpdServer) => Promise<Cache>;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export interface Cache {
|
|
13
|
-
set: (key: string, value:
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
1
|
+
import { IRpdServer } from "~/core/server";
|
|
2
|
+
|
|
3
|
+
export interface CacheFactoryConfig {
|
|
4
|
+
providers?: CacheProvider[];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export interface CacheProvider {
|
|
8
|
+
providerName: string;
|
|
9
|
+
createCache: (server: IRpdServer) => Promise<Cache>;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export interface Cache {
|
|
13
|
+
set: (key: string, value: string, options?: SetValueOptions) => Promise<void>;
|
|
14
|
+
setObject: (key: string, value: Record<string, any>, options?: SetValueOptions) => Promise<void>;
|
|
15
|
+
get: (key: string) => Promise<string | null>;
|
|
16
|
+
getObject: (key: string) => Promise<Record<string, any> | null>;
|
|
17
|
+
del: (key: string) => Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface SetValueOptions {
|
|
21
|
+
/**
|
|
22
|
+
* Time-to-live, in milliseconds
|
|
23
|
+
*/
|
|
24
|
+
ttl?: number;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export interface CreateCacheFacilityOptions {
|
|
28
|
+
providerName: string;
|
|
29
|
+
}
|
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
import { FacilityFactory } from "~/core/facility";
|
|
2
|
-
import { IRpdServer } from "~/core/server";
|
|
3
|
-
import { Cache, CacheProvider, CacheFactoryConfig, CreateCacheFacilityOptions } from "./CacheFacilityTypes";
|
|
4
|
-
import MemoryCacheProvider from "./MemoryCacheProvider";
|
|
5
|
-
|
|
6
|
-
export default class CacheFactory implements FacilityFactory<Cache, CreateCacheFacilityOptions> {
|
|
7
|
-
readonly name: string;
|
|
8
|
-
#providers: Map<string, CacheProvider>;
|
|
9
|
-
|
|
10
|
-
constructor(config: CacheFactoryConfig) {
|
|
11
|
-
this.name = "cache";
|
|
12
|
-
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
this.#providers = new Map();
|
|
16
|
-
this.#providers.set(
|
|
17
|
-
|
|
18
|
-
for (const provider of config.providers) {
|
|
19
|
-
this.#providers.set(provider.providerName, provider);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
async createFacility(server: IRpdServer, options?: CreateCacheFacilityOptions) {
|
|
24
|
-
const providerName = options?.providerName || "memory";
|
|
25
|
-
const creator = this.#providers.get(providerName);
|
|
26
|
-
if (!creator) {
|
|
27
|
-
throw new Error(`Unkown cache provider name: ${providerName}`);
|
|
28
|
-
}
|
|
29
|
-
return creator.createCache(server);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
1
|
+
import { FacilityFactory } from "~/core/facility";
|
|
2
|
+
import { IRpdServer } from "~/core/server";
|
|
3
|
+
import { Cache, CacheProvider, CacheFactoryConfig, CreateCacheFacilityOptions } from "./CacheFacilityTypes";
|
|
4
|
+
import MemoryCacheProvider from "./MemoryCacheProvider";
|
|
5
|
+
|
|
6
|
+
export default class CacheFactory implements FacilityFactory<Cache, CreateCacheFacilityOptions> {
|
|
7
|
+
readonly name: string;
|
|
8
|
+
#providers: Map<string, CacheProvider>;
|
|
9
|
+
|
|
10
|
+
constructor(config: CacheFactoryConfig) {
|
|
11
|
+
this.name = "cache";
|
|
12
|
+
|
|
13
|
+
const memoryCacheProvider = new MemoryCacheProvider();
|
|
14
|
+
|
|
15
|
+
this.#providers = new Map();
|
|
16
|
+
this.#providers.set(memoryCacheProvider.providerName, memoryCacheProvider);
|
|
17
|
+
|
|
18
|
+
for (const provider of config.providers) {
|
|
19
|
+
this.#providers.set(provider.providerName, provider);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
async createFacility(server: IRpdServer, options?: CreateCacheFacilityOptions) {
|
|
24
|
+
const providerName = options?.providerName || "memory";
|
|
25
|
+
const creator = this.#providers.get(providerName);
|
|
26
|
+
if (!creator) {
|
|
27
|
+
throw new Error(`Unkown cache provider name: ${providerName}`);
|
|
28
|
+
}
|
|
29
|
+
return creator.createCache(server);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -1,42 +1,58 @@
|
|
|
1
|
-
import { Cache, SetValueOptions } from "./CacheFacilityTypes";
|
|
2
|
-
|
|
3
|
-
export type MemoryCacheItem<TValue = any> = {
|
|
4
|
-
value: TValue;
|
|
5
|
-
expireAt: number;
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
const values: Map<string, MemoryCacheItem> = new Map();
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
if (cacheItem) {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
async
|
|
40
|
-
|
|
41
|
-
}
|
|
42
|
-
|
|
1
|
+
import { Cache, SetValueOptions } from "./CacheFacilityTypes";
|
|
2
|
+
|
|
3
|
+
export type MemoryCacheItem<TValue = any> = {
|
|
4
|
+
value: TValue;
|
|
5
|
+
expireAt: number;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
const values: Map<string, MemoryCacheItem> = new Map();
|
|
9
|
+
|
|
10
|
+
async function set(key: string, value: any, options?: SetValueOptions) {
|
|
11
|
+
let expireAt = -1;
|
|
12
|
+
if (options && options.ttl > 0) {
|
|
13
|
+
expireAt = new Date().valueOf() + options.ttl;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const cacheItem = {
|
|
17
|
+
value,
|
|
18
|
+
expireAt,
|
|
19
|
+
};
|
|
20
|
+
values.set(key, cacheItem);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
async function get(key: string) {
|
|
24
|
+
const cacheItem = values.get(key);
|
|
25
|
+
if (cacheItem) {
|
|
26
|
+
if (cacheItem.expireAt === -1) {
|
|
27
|
+
return cacheItem.value;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
if (cacheItem.expireAt >= new Date().valueOf()) {
|
|
31
|
+
return cacheItem.value;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return undefined;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export default class MemoryCache implements Cache {
|
|
39
|
+
async set(key: string, value: string, options?: SetValueOptions) {
|
|
40
|
+
await set(key, value, options);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async setObject(key: string, value: Record<string, any>, options?: SetValueOptions) {
|
|
44
|
+
await set(key, value, options);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
async get(key: string) {
|
|
48
|
+
return get(key);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
async getObject(key: string) {
|
|
52
|
+
return get(key);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
async del(key: string) {
|
|
56
|
+
values.delete(key);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import MemoryCache from "./MemoryCache";
|
|
2
|
-
import { CacheProvider } from "./CacheFacilityTypes";
|
|
3
|
-
import { IRpdServer } from "~/core/server";
|
|
4
|
-
|
|
5
|
-
export default class MemoryCacheProvider implements CacheProvider {
|
|
6
|
-
readonly providerName: string;
|
|
7
|
-
|
|
8
|
-
constructor() {
|
|
9
|
-
this.providerName = "memory";
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
async createCache(server: IRpdServer) {
|
|
13
|
-
return new MemoryCache();
|
|
14
|
-
}
|
|
15
|
-
}
|
|
1
|
+
import MemoryCache from "./MemoryCache";
|
|
2
|
+
import { CacheProvider } from "./CacheFacilityTypes";
|
|
3
|
+
import { IRpdServer } from "~/core/server";
|
|
4
|
+
|
|
5
|
+
export default class MemoryCacheProvider implements CacheProvider {
|
|
6
|
+
readonly providerName: string;
|
|
7
|
+
|
|
8
|
+
constructor() {
|
|
9
|
+
this.providerName = "memory";
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
async createCache(server: IRpdServer) {
|
|
13
|
+
return new MemoryCache();
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
import winston from "winston";
|
|
2
|
-
|
|
3
|
-
export interface Logger {
|
|
4
|
-
log: winston.LogMethod;
|
|
5
|
-
/**
|
|
6
|
-
* The service/app is going to stop or become unusable now. An operator should definitely look into this immediately.
|
|
7
|
-
*/
|
|
8
|
-
emerg: winston.LeveledLogMethod;
|
|
9
|
-
/**
|
|
10
|
-
* Fatal for a particular service, but the app continues servicing other requests. An operator should look at this immediately.
|
|
11
|
-
*/
|
|
12
|
-
crit: winston.LeveledLogMethod;
|
|
13
|
-
/**
|
|
14
|
-
* Fatal for a particular request, but the service/app continues servicing other requests. An operator should look at this soon(ish).
|
|
15
|
-
*/
|
|
16
|
-
error: winston.LeveledLogMethod;
|
|
17
|
-
/**
|
|
18
|
-
* A note on something that should probably be looked at by an operator eventually.
|
|
19
|
-
*/
|
|
20
|
-
warn: winston.LeveledLogMethod;
|
|
21
|
-
/**
|
|
22
|
-
* Detail on regular operation.
|
|
23
|
-
*/
|
|
24
|
-
info: winston.LeveledLogMethod;
|
|
25
|
-
/**
|
|
26
|
-
* Anything else, i.e. too verbose to be included in "info" level.
|
|
27
|
-
*/
|
|
28
|
-
debug: winston.LeveledLogMethod;
|
|
29
|
-
/**
|
|
30
|
-
* Logging from external libraries used by your app or very detailed application logging.
|
|
31
|
-
*/
|
|
32
|
-
verbose: winston.LeveledLogMethod;
|
|
33
|
-
|
|
34
|
-
child(options: Object): Logger;
|
|
35
|
-
}
|
|
1
|
+
import winston from "winston";
|
|
2
|
+
|
|
3
|
+
export interface Logger {
|
|
4
|
+
log: winston.LogMethod;
|
|
5
|
+
/**
|
|
6
|
+
* The service/app is going to stop or become unusable now. An operator should definitely look into this immediately.
|
|
7
|
+
*/
|
|
8
|
+
emerg: winston.LeveledLogMethod;
|
|
9
|
+
/**
|
|
10
|
+
* Fatal for a particular service, but the app continues servicing other requests. An operator should look at this immediately.
|
|
11
|
+
*/
|
|
12
|
+
crit: winston.LeveledLogMethod;
|
|
13
|
+
/**
|
|
14
|
+
* Fatal for a particular request, but the service/app continues servicing other requests. An operator should look at this soon(ish).
|
|
15
|
+
*/
|
|
16
|
+
error: winston.LeveledLogMethod;
|
|
17
|
+
/**
|
|
18
|
+
* A note on something that should probably be looked at by an operator eventually.
|
|
19
|
+
*/
|
|
20
|
+
warn: winston.LeveledLogMethod;
|
|
21
|
+
/**
|
|
22
|
+
* Detail on regular operation.
|
|
23
|
+
*/
|
|
24
|
+
info: winston.LeveledLogMethod;
|
|
25
|
+
/**
|
|
26
|
+
* Anything else, i.e. too verbose to be included in "info" level.
|
|
27
|
+
*/
|
|
28
|
+
debug: winston.LeveledLogMethod;
|
|
29
|
+
/**
|
|
30
|
+
* Logging from external libraries used by your app or very detailed application logging.
|
|
31
|
+
*/
|
|
32
|
+
verbose: winston.LeveledLogMethod;
|
|
33
|
+
|
|
34
|
+
child(options: Object): Logger;
|
|
35
|
+
}
|
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
import { isNumber, isObject } from "lodash";
|
|
2
|
-
import { IRpdServer } from "~/core/server";
|
|
3
|
-
import { getEntityPropertyByCode, isOneRelationProperty } from "~/helpers/metaHelper";
|
|
4
|
-
import { RpdDataModel } from "~/types";
|
|
5
|
-
|
|
6
|
-
export function getEntityPartChanges(server: IRpdServer, model: RpdDataModel, before: any, after: any): Record<string, any> | null {
|
|
7
|
-
if (!before) {
|
|
8
|
-
throw new Error("Argument 'before' can not be null.");
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
if (!after) {
|
|
12
|
-
throw new Error("Argument 'after' can not be null.");
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
let changed = false;
|
|
16
|
-
let changes = {};
|
|
17
|
-
for (const key in after) {
|
|
18
|
-
const property = getEntityPropertyByCode(server, model, key);
|
|
19
|
-
if (property && isOneRelationProperty(property)) {
|
|
20
|
-
const afterValue: number | { id: number } | null = after[key];
|
|
21
|
-
const beforeValue: number | { id: number } | null = before[key] || before[property.targetIdColumnName];
|
|
22
|
-
if (afterValue) {
|
|
23
|
-
if (isNumber(afterValue)) {
|
|
24
|
-
if (beforeValue) {
|
|
25
|
-
if (isNumber(beforeValue)) {
|
|
26
|
-
if (afterValue != beforeValue) {
|
|
27
|
-
changed = true;
|
|
28
|
-
changes[key] = afterValue;
|
|
29
|
-
}
|
|
30
|
-
} else {
|
|
31
|
-
if (afterValue != beforeValue.id) {
|
|
32
|
-
changed = true;
|
|
33
|
-
changes[key] = afterValue;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
} else {
|
|
37
|
-
changed = true;
|
|
38
|
-
changes[key] = afterValue;
|
|
39
|
-
}
|
|
40
|
-
} else {
|
|
41
|
-
if (beforeValue) {
|
|
42
|
-
if (isNumber(beforeValue)) {
|
|
43
|
-
if (afterValue.id != beforeValue) {
|
|
44
|
-
changed = true;
|
|
45
|
-
changes[key] = afterValue;
|
|
46
|
-
}
|
|
47
|
-
} else {
|
|
48
|
-
if (afterValue.id != beforeValue.id) {
|
|
49
|
-
changed = true;
|
|
50
|
-
changes[key] = afterValue;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
} else {
|
|
54
|
-
changed = true;
|
|
55
|
-
changes[key] = afterValue;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
} else {
|
|
59
|
-
if (beforeValue) {
|
|
60
|
-
changed = true;
|
|
61
|
-
changes[key] = null;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
} else {
|
|
65
|
-
if (after[key] != before[key]) {
|
|
66
|
-
changed = true;
|
|
67
|
-
changes[key] = after[key];
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
if (changed) {
|
|
73
|
-
return changes;
|
|
74
|
-
}
|
|
75
|
-
return null;
|
|
76
|
-
}
|
|
1
|
+
import { isNumber, isObject } from "lodash";
|
|
2
|
+
import { IRpdServer } from "~/core/server";
|
|
3
|
+
import { getEntityPropertyByCode, isOneRelationProperty } from "~/helpers/metaHelper";
|
|
4
|
+
import { RpdDataModel } from "~/types";
|
|
5
|
+
|
|
6
|
+
export function getEntityPartChanges(server: IRpdServer, model: RpdDataModel, before: any, after: any): Record<string, any> | null {
|
|
7
|
+
if (!before) {
|
|
8
|
+
throw new Error("Argument 'before' can not be null.");
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
if (!after) {
|
|
12
|
+
throw new Error("Argument 'after' can not be null.");
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
let changed = false;
|
|
16
|
+
let changes = {};
|
|
17
|
+
for (const key in after) {
|
|
18
|
+
const property = getEntityPropertyByCode(server, model, key);
|
|
19
|
+
if (property && isOneRelationProperty(property)) {
|
|
20
|
+
const afterValue: number | { id: number } | null = after[key];
|
|
21
|
+
const beforeValue: number | { id: number } | null = before[key] || before[property.targetIdColumnName];
|
|
22
|
+
if (afterValue) {
|
|
23
|
+
if (isNumber(afterValue)) {
|
|
24
|
+
if (beforeValue) {
|
|
25
|
+
if (isNumber(beforeValue)) {
|
|
26
|
+
if (afterValue != beforeValue) {
|
|
27
|
+
changed = true;
|
|
28
|
+
changes[key] = afterValue;
|
|
29
|
+
}
|
|
30
|
+
} else {
|
|
31
|
+
if (afterValue != beforeValue.id) {
|
|
32
|
+
changed = true;
|
|
33
|
+
changes[key] = afterValue;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
} else {
|
|
37
|
+
changed = true;
|
|
38
|
+
changes[key] = afterValue;
|
|
39
|
+
}
|
|
40
|
+
} else {
|
|
41
|
+
if (beforeValue) {
|
|
42
|
+
if (isNumber(beforeValue)) {
|
|
43
|
+
if (afterValue.id != beforeValue) {
|
|
44
|
+
changed = true;
|
|
45
|
+
changes[key] = afterValue;
|
|
46
|
+
}
|
|
47
|
+
} else {
|
|
48
|
+
if (afterValue.id != beforeValue.id) {
|
|
49
|
+
changed = true;
|
|
50
|
+
changes[key] = afterValue;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
} else {
|
|
54
|
+
changed = true;
|
|
55
|
+
changes[key] = afterValue;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
} else {
|
|
59
|
+
if (beforeValue) {
|
|
60
|
+
changed = true;
|
|
61
|
+
changes[key] = null;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
} else {
|
|
65
|
+
if (after[key] != before[key]) {
|
|
66
|
+
changed = true;
|
|
67
|
+
changes[key] = after[key];
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
if (changed) {
|
|
73
|
+
return changes;
|
|
74
|
+
}
|
|
75
|
+
return null;
|
|
76
|
+
}
|