@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
package/src/index.ts
CHANGED
|
@@ -1,63 +1,67 @@
|
|
|
1
|
-
import { fixBigIntJSONSerialize } from "./polyfill";
|
|
2
|
-
fixBigIntJSONSerialize();
|
|
3
|
-
|
|
4
|
-
export * from "./types";
|
|
5
|
-
export * from "./server";
|
|
6
|
-
|
|
7
|
-
export * from "./core/facility";
|
|
8
|
-
export * from "./core/request";
|
|
9
|
-
export * from "./core/routeContext";
|
|
10
|
-
export * from "./core/server";
|
|
11
|
-
export * from "./core/http-types";
|
|
12
|
-
export * from "./core/actionHandler";
|
|
13
|
-
|
|
14
|
-
export * from "./utilities/
|
|
15
|
-
|
|
16
|
-
export * from "./
|
|
17
|
-
|
|
18
|
-
export
|
|
19
|
-
|
|
20
|
-
export *
|
|
21
|
-
|
|
22
|
-
export {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
export
|
|
28
|
-
|
|
29
|
-
export { default as
|
|
30
|
-
|
|
31
|
-
export { default as
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
export
|
|
37
|
-
|
|
38
|
-
export { default as
|
|
39
|
-
|
|
40
|
-
export { default as
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
export
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
export
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
export
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
export
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
export
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
export
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
export * from "./
|
|
1
|
+
import { fixBigIntJSONSerialize } from "./polyfill";
|
|
2
|
+
fixBigIntJSONSerialize();
|
|
3
|
+
|
|
4
|
+
export * from "./types";
|
|
5
|
+
export * from "./server";
|
|
6
|
+
|
|
7
|
+
export * from "./core/facility";
|
|
8
|
+
export * from "./core/request";
|
|
9
|
+
export * from "./core/routeContext";
|
|
10
|
+
export * from "./core/server";
|
|
11
|
+
export * from "./core/http-types";
|
|
12
|
+
export * from "./core/actionHandler";
|
|
13
|
+
|
|
14
|
+
export * from "./utilities/accessControlUtility";
|
|
15
|
+
export * from "./utilities/entityUtility";
|
|
16
|
+
export * from "./utilities/jwtUtility";
|
|
17
|
+
export * from "./utilities/timeUtility";
|
|
18
|
+
export * from "./utilities/passwordUtility";
|
|
19
|
+
|
|
20
|
+
export * from "./deno-std/http/cookie";
|
|
21
|
+
|
|
22
|
+
export { mapDbRowToEntity } from "./dataAccess/entityMapper";
|
|
23
|
+
|
|
24
|
+
export * as bootstrapApplicationConfig from "./bootstrapApplicationConfig";
|
|
25
|
+
|
|
26
|
+
export { default as CacheFactory } from "./facilities/cache/CacheFactory";
|
|
27
|
+
export * from "./facilities/cache/CacheFacilityTypes";
|
|
28
|
+
|
|
29
|
+
export { default as MetaManagePlugin } from "./plugins/metaManage/MetaManagePlugin";
|
|
30
|
+
|
|
31
|
+
export { default as DataManagePlugin } from "./plugins/dataManage/DataManagePlugin";
|
|
32
|
+
|
|
33
|
+
export { default as RouteManagePlugin } from "./plugins/routeManage/RouteManagePlugin";
|
|
34
|
+
|
|
35
|
+
export { default as SequencePlugin } from "./plugins/sequence/SequencePlugin";
|
|
36
|
+
export * from "./plugins/sequence/SequencePluginTypes";
|
|
37
|
+
|
|
38
|
+
export { default as WebhooksPlugin } from "./plugins/webhooks/WebhooksPlugin";
|
|
39
|
+
|
|
40
|
+
export { default as AuthPlugin } from "./plugins/auth/AuthPlugin";
|
|
41
|
+
|
|
42
|
+
export { default as FileManagePlugin } from "./plugins/fileManage/FileManagePlugin";
|
|
43
|
+
|
|
44
|
+
export { default as LicensePlugin } from "./plugins/license/LicensePlugin";
|
|
45
|
+
export * from "./plugins/license/LicensePluginTypes";
|
|
46
|
+
|
|
47
|
+
export { default as MailPlugin } from "./plugins/mail/MailPlugin";
|
|
48
|
+
export * from "./plugins/mail/MailPluginTypes";
|
|
49
|
+
|
|
50
|
+
export { default as NotificationPlugin } from "./plugins/notification/NotificationPlugin";
|
|
51
|
+
export * from "./plugins/notification/NotificationPluginTypes";
|
|
52
|
+
|
|
53
|
+
export { default as ServerOperationPlugin } from "./plugins/serverOperation/ServerOperationPlugin";
|
|
54
|
+
export * from "./plugins/serverOperation/ServerOperationPluginTypes";
|
|
55
|
+
|
|
56
|
+
export { default as SettingPlugin } from "./plugins/setting/SettingPlugin";
|
|
57
|
+
export * from "./plugins/setting/SettingPluginTypes";
|
|
58
|
+
|
|
59
|
+
export { default as CronJobPlugin } from "./plugins/cronJob/CronJobPlugin";
|
|
60
|
+
export * from "./plugins/cronJob/CronJobPluginTypes";
|
|
61
|
+
|
|
62
|
+
export { default as StateMachinePlugin } from "./plugins/stateMachine/StateMachinePlugin";
|
|
63
|
+
export * from "./plugins/stateMachine/StateMachinePluginTypes";
|
|
64
|
+
|
|
65
|
+
export { default as EntityAccessControlPlugin } from "./plugins/entityAccessControl/EntityAccessControlPlugin";
|
|
66
|
+
|
|
67
|
+
export * from "./facilities/log/LogFacility";
|
|
@@ -1,93 +1,93 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Auth manager 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 { RouteContext } from "~/core/routeContext";
|
|
18
|
-
import { verifyJwt } from "~/utilities/jwtUtility";
|
|
19
|
-
import AuthService from "./services/AuthService";
|
|
20
|
-
|
|
21
|
-
class AuthPlugin implements RapidPlugin {
|
|
22
|
-
#authService!: AuthService;
|
|
23
|
-
|
|
24
|
-
get code(): string {
|
|
25
|
-
return "authManager";
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
get description(): string {
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
33
|
-
return [];
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
37
|
-
return [];
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
get configurations(): RpdConfigurationItemOptions[] {
|
|
41
|
-
return [];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
45
|
-
for (const actionHandler of pluginActionHandlers) {
|
|
46
|
-
server.registerActionHandler(this, actionHandler);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
51
|
-
server.appendApplicationConfig({ models: pluginModels });
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
async configureServices(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
55
|
-
this.#authService = new AuthService(server, server.config.jwtKey);
|
|
56
|
-
server.registerService("authService", this.#authService);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
60
|
-
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async onPrepareRouteContext(server: IRpdServer, routeContext: RouteContext) {
|
|
64
|
-
const request = routeContext.request;
|
|
65
|
-
let token: string;
|
|
66
|
-
|
|
67
|
-
const headers = request.headers;
|
|
68
|
-
// No Authorization header
|
|
69
|
-
if (headers.has("Authorization")) {
|
|
70
|
-
// Authorization header has no Bearer or no token
|
|
71
|
-
const authHeader = headers.get("Authorization")!;
|
|
72
|
-
if (!authHeader.startsWith("Bearer ") || authHeader.length <= 7) {
|
|
73
|
-
throw new Error("AUTHORIZATION_HEADER_INVALID");
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
token = authHeader.slice(7);
|
|
77
|
-
} else {
|
|
78
|
-
token = request.cookies[server.config.sessionCookieName];
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
try {
|
|
82
|
-
const secretKey = Buffer.from(server.config.jwtKey, "base64");
|
|
83
|
-
const tokenPayload = verifyJwt(token, secretKey);
|
|
84
|
-
routeContext.state.userId = tokenPayload.aud as string;
|
|
85
|
-
routeContext.state.userLogin = tokenPayload.act as string;
|
|
86
|
-
} catch (error) {
|
|
87
|
-
const logger = server.getLogger();
|
|
88
|
-
logger.debug("Verify JWT failed.", { error });
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
export default AuthPlugin;
|
|
1
|
+
/**
|
|
2
|
+
* Auth manager 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 { RouteContext } from "~/core/routeContext";
|
|
18
|
+
import { verifyJwt } from "~/utilities/jwtUtility";
|
|
19
|
+
import AuthService from "./services/AuthService";
|
|
20
|
+
|
|
21
|
+
class AuthPlugin implements RapidPlugin {
|
|
22
|
+
#authService!: AuthService;
|
|
23
|
+
|
|
24
|
+
get code(): string {
|
|
25
|
+
return "authManager";
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
get description(): string {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
get extendingAbilities(): RpdServerPluginExtendingAbilities[] {
|
|
33
|
+
return [];
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
get configurableTargets(): RpdServerPluginConfigurableTargetOptions[] {
|
|
37
|
+
return [];
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
get configurations(): RpdConfigurationItemOptions[] {
|
|
41
|
+
return [];
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
async registerActionHandlers(server: IRpdServer): Promise<any> {
|
|
45
|
+
for (const actionHandler of pluginActionHandlers) {
|
|
46
|
+
server.registerActionHandler(this, actionHandler);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async configureModels(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
51
|
+
server.appendApplicationConfig({ models: pluginModels });
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
async configureServices(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
55
|
+
this.#authService = new AuthService(server, server.config.jwtKey);
|
|
56
|
+
server.registerService("authService", this.#authService);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
async configureRoutes(server: IRpdServer, applicationConfig: RpdApplicationConfig): Promise<any> {
|
|
60
|
+
server.appendApplicationConfig({ routes: pluginRoutes });
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
async onPrepareRouteContext(server: IRpdServer, routeContext: RouteContext) {
|
|
64
|
+
const request = routeContext.request;
|
|
65
|
+
let token: string;
|
|
66
|
+
|
|
67
|
+
const headers = request.headers;
|
|
68
|
+
// No Authorization header
|
|
69
|
+
if (headers.has("Authorization")) {
|
|
70
|
+
// Authorization header has no Bearer or no token
|
|
71
|
+
const authHeader = headers.get("Authorization")!;
|
|
72
|
+
if (!authHeader.startsWith("Bearer ") || authHeader.length <= 7) {
|
|
73
|
+
throw new Error("AUTHORIZATION_HEADER_INVALID");
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
token = authHeader.slice(7);
|
|
77
|
+
} else {
|
|
78
|
+
token = request.cookies[server.config.sessionCookieName];
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
try {
|
|
82
|
+
const secretKey = Buffer.from(server.config.jwtKey, "base64");
|
|
83
|
+
const tokenPayload = verifyJwt(token, secretKey);
|
|
84
|
+
routeContext.state.userId = tokenPayload.aud as string;
|
|
85
|
+
routeContext.state.userLogin = tokenPayload.act as string;
|
|
86
|
+
} catch (error) {
|
|
87
|
+
const logger = server.getLogger();
|
|
88
|
+
logger.debug("Verify JWT failed.", { error });
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
export default AuthPlugin;
|
|
@@ -1,61 +1,60 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
export const code = "changePassword";
|
|
6
|
-
|
|
7
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
8
|
-
const { server, input, routerContext: routeContext } = ctx;
|
|
9
|
-
const { response } = routeContext;
|
|
10
|
-
const { id, oldPassword, newPassword } = input;
|
|
11
|
-
|
|
12
|
-
const userId = routeContext.state.userId;
|
|
13
|
-
if (!userId) {
|
|
14
|
-
ctx.status = 401;
|
|
15
|
-
ctx.output = {
|
|
16
|
-
error: {
|
|
17
|
-
message: "You are not signed in.",
|
|
18
|
-
},
|
|
19
|
-
};
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const userDataAccessor = server.getDataAccessor({
|
|
24
|
-
singularCode: "oc_user",
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
const user = await userDataAccessor.findOne(
|
|
28
|
-
{
|
|
29
|
-
filters: [
|
|
30
|
-
{
|
|
31
|
-
operator: "eq",
|
|
32
|
-
field: "id",
|
|
33
|
-
value: userId,
|
|
34
|
-
},
|
|
35
|
-
],
|
|
36
|
-
},
|
|
37
|
-
routeContext?.getDbTransactionClient(),
|
|
38
|
-
);
|
|
39
|
-
|
|
40
|
-
if (!user) {
|
|
41
|
-
throw new Error("User not found.");
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const isMatch = await
|
|
45
|
-
if (!isMatch) {
|
|
46
|
-
throw new Error("旧密码错误。");
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
const
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import { generatePasswordHash, validatePassword } from "~/utilities/passwordUtility";
|
|
4
|
+
|
|
5
|
+
export const code = "changePassword";
|
|
6
|
+
|
|
7
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
8
|
+
const { server, input, routerContext: routeContext } = ctx;
|
|
9
|
+
const { response } = routeContext;
|
|
10
|
+
const { id, oldPassword, newPassword } = input;
|
|
11
|
+
|
|
12
|
+
const userId = routeContext.state.userId;
|
|
13
|
+
if (!userId) {
|
|
14
|
+
ctx.status = 401;
|
|
15
|
+
ctx.output = {
|
|
16
|
+
error: {
|
|
17
|
+
message: "You are not signed in.",
|
|
18
|
+
},
|
|
19
|
+
};
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const userDataAccessor = server.getDataAccessor({
|
|
24
|
+
singularCode: "oc_user",
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
const user = await userDataAccessor.findOne(
|
|
28
|
+
{
|
|
29
|
+
filters: [
|
|
30
|
+
{
|
|
31
|
+
operator: "eq",
|
|
32
|
+
field: "id",
|
|
33
|
+
value: userId,
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
},
|
|
37
|
+
routeContext?.getDbTransactionClient(),
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
if (!user) {
|
|
41
|
+
throw new Error("User not found.");
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const isMatch = await validatePassword(oldPassword, user.password);
|
|
45
|
+
if (!isMatch) {
|
|
46
|
+
throw new Error("旧密码错误。");
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
const passwordHash = await generatePasswordHash(newPassword);
|
|
50
|
+
|
|
51
|
+
await userDataAccessor.updateById(
|
|
52
|
+
user.id,
|
|
53
|
+
{
|
|
54
|
+
password: passwordHash,
|
|
55
|
+
},
|
|
56
|
+
routeContext?.getDbTransactionClient(),
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
ctx.output = {};
|
|
60
|
+
}
|
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
|
|
9
|
-
export const code = "createSession";
|
|
10
|
-
|
|
11
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
12
|
-
const { server, input, routerContext: routeContext } = ctx;
|
|
13
|
-
const { response } = routeContext;
|
|
14
|
-
const { account, password } = input;
|
|
15
|
-
|
|
16
|
-
const licenseService = server.getService<LicenseService>("licenseService");
|
|
17
|
-
const license = licenseService.getLicense();
|
|
18
|
-
if (!license) {
|
|
19
|
-
throw new Error(`登录失败,无法获取系统授权信息。`);
|
|
20
|
-
}
|
|
21
|
-
if (licenseService.isExpired()) {
|
|
22
|
-
const expireDate = get(license.authority, "expireDate");
|
|
23
|
-
throw new Error(`登录失败,系统授权已于${expireDate}过期。`);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const userDataAccessor = server.getDataAccessor({
|
|
27
|
-
singularCode: "oc_user",
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
const user = await userDataAccessor.findOne(
|
|
31
|
-
{
|
|
32
|
-
filters: [
|
|
33
|
-
{
|
|
34
|
-
operator: "eq",
|
|
35
|
-
field: "login",
|
|
36
|
-
value: account,
|
|
37
|
-
},
|
|
38
|
-
],
|
|
39
|
-
},
|
|
40
|
-
routeContext?.getDbTransactionClient(),
|
|
41
|
-
);
|
|
42
|
-
|
|
43
|
-
if (!user) {
|
|
44
|
-
throw new Error("用户名或密码错误。");
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
const isMatch = await
|
|
48
|
-
if (!isMatch) {
|
|
49
|
-
throw new Error("用户名或密码错误。");
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const authService = server.getService<AuthService>("authService");
|
|
53
|
-
const token = authService.createUserAccessToken({
|
|
54
|
-
issuer: "authManager",
|
|
55
|
-
userId: user.id,
|
|
56
|
-
userLogin: user.login,
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
setCookie(response.headers, {
|
|
60
|
-
name: ctx.server.config.sessionCookieName,
|
|
61
|
-
value: token,
|
|
62
|
-
path: "/",
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
ctx.output = {
|
|
66
|
-
token,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
1
|
+
import { setCookie } from "~/deno-std/http/cookie";
|
|
2
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
3
|
+
import { RapidPlugin } from "~/core/server";
|
|
4
|
+
import LicenseService from "~/plugins/license/LicenseService";
|
|
5
|
+
import { get } from "lodash";
|
|
6
|
+
import AuthService from "../services/AuthService";
|
|
7
|
+
import { validatePassword } from "~/utilities/passwordUtility";
|
|
8
|
+
|
|
9
|
+
export const code = "createSession";
|
|
10
|
+
|
|
11
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
12
|
+
const { server, input, routerContext: routeContext } = ctx;
|
|
13
|
+
const { response } = routeContext;
|
|
14
|
+
const { account, password } = input;
|
|
15
|
+
|
|
16
|
+
const licenseService = server.getService<LicenseService>("licenseService");
|
|
17
|
+
const license = licenseService.getLicense();
|
|
18
|
+
if (!license) {
|
|
19
|
+
throw new Error(`登录失败,无法获取系统授权信息。`);
|
|
20
|
+
}
|
|
21
|
+
if (licenseService.isExpired()) {
|
|
22
|
+
const expireDate = get(license.authority, "expireDate");
|
|
23
|
+
throw new Error(`登录失败,系统授权已于${expireDate}过期。`);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const userDataAccessor = server.getDataAccessor({
|
|
27
|
+
singularCode: "oc_user",
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const user = await userDataAccessor.findOne(
|
|
31
|
+
{
|
|
32
|
+
filters: [
|
|
33
|
+
{
|
|
34
|
+
operator: "eq",
|
|
35
|
+
field: "login",
|
|
36
|
+
value: account,
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
},
|
|
40
|
+
routeContext?.getDbTransactionClient(),
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
if (!user) {
|
|
44
|
+
throw new Error("用户名或密码错误。");
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const isMatch = await validatePassword(password, user.password);
|
|
48
|
+
if (!isMatch) {
|
|
49
|
+
throw new Error("用户名或密码错误。");
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const authService = server.getService<AuthService>("authService");
|
|
53
|
+
const token = authService.createUserAccessToken({
|
|
54
|
+
issuer: "authManager",
|
|
55
|
+
userId: user.id,
|
|
56
|
+
userLogin: user.login,
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
setCookie(response.headers, {
|
|
60
|
+
name: ctx.server.config.sessionCookieName,
|
|
61
|
+
value: token,
|
|
62
|
+
path: "/",
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
ctx.output = {
|
|
66
|
+
token,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
-
import { RapidPlugin } from "~/core/server";
|
|
3
|
-
import { setCookie } from "~/deno-std/http/cookie";
|
|
4
|
-
|
|
5
|
-
export const code = "deleteSession";
|
|
6
|
-
|
|
7
|
-
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
8
|
-
const { server, input, routerContext } = ctx;
|
|
9
|
-
const { response } = routerContext;
|
|
10
|
-
|
|
11
|
-
setCookie(response.headers, {
|
|
12
|
-
name: ctx.server.config.sessionCookieName,
|
|
13
|
-
value: "",
|
|
14
|
-
path: "/",
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
routerContext.redirect("/signin");
|
|
18
|
-
}
|
|
1
|
+
import { ActionHandlerContext } from "~/core/actionHandler";
|
|
2
|
+
import { RapidPlugin } from "~/core/server";
|
|
3
|
+
import { setCookie } from "~/deno-std/http/cookie";
|
|
4
|
+
|
|
5
|
+
export const code = "deleteSession";
|
|
6
|
+
|
|
7
|
+
export async function handler(plugin: RapidPlugin, ctx: ActionHandlerContext, options: any) {
|
|
8
|
+
const { server, input, routerContext } = ctx;
|
|
9
|
+
const { response } = routerContext;
|
|
10
|
+
|
|
11
|
+
setCookie(response.headers, {
|
|
12
|
+
name: ctx.server.config.sessionCookieName,
|
|
13
|
+
value: "",
|
|
14
|
+
path: "/",
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
routerContext.redirect("/signin");
|
|
18
|
+
}
|