@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.
Files changed (185) hide show
  1. package/CHANGELOG.md +7 -7
  2. package/dist/facilities/cache/CacheFacilityTypes.d.ts +4 -2
  3. package/dist/facilities/cache/MemoryCache.d.ts +3 -1
  4. package/dist/index.d.ts +4 -0
  5. package/dist/index.js +131 -72
  6. package/dist/utilities/entityUtility.d.ts +1 -0
  7. package/dist/utilities/passwordUtility.d.ts +14 -0
  8. package/package.json +2 -2
  9. package/rollup.config.js +16 -16
  10. package/src/bootstrapApplicationConfig.ts +638 -638
  11. package/src/core/actionHandler.ts +22 -22
  12. package/src/core/eventManager.ts +20 -20
  13. package/src/core/facility.ts +7 -7
  14. package/src/core/http/formDataParser.ts +89 -89
  15. package/src/core/http-types.ts +4 -4
  16. package/src/core/pluginManager.ts +175 -175
  17. package/src/core/providers/runtimeProvider.ts +5 -5
  18. package/src/core/request.ts +95 -95
  19. package/src/core/response.ts +79 -79
  20. package/src/core/routeContext.ts +100 -100
  21. package/src/core/routesBuilder.ts +88 -88
  22. package/src/core/server.ts +145 -145
  23. package/src/dataAccess/columnTypeMapper.ts +22 -22
  24. package/src/dataAccess/dataAccessTypes.ts +163 -163
  25. package/src/dataAccess/dataAccessor.ts +135 -135
  26. package/src/dataAccess/entityManager.ts +1910 -1910
  27. package/src/dataAccess/entityMapper.ts +100 -100
  28. package/src/dataAccess/propertyMapper.ts +28 -28
  29. package/src/deno-std/assert/assert.ts +9 -9
  30. package/src/deno-std/assert/assertion_error.ts +7 -7
  31. package/src/deno-std/datetime/to_imf.ts +32 -32
  32. package/src/deno-std/encoding/base64.ts +141 -141
  33. package/src/deno-std/http/cookie.ts +372 -372
  34. package/src/facilities/cache/CacheFacilityTypes.ts +29 -27
  35. package/src/facilities/cache/CacheFactory.ts +31 -31
  36. package/src/facilities/cache/MemoryCache.ts +58 -42
  37. package/src/facilities/cache/MemoryCacheProvider.ts +15 -15
  38. package/src/facilities/log/LogFacility.ts +35 -35
  39. package/src/helpers/entityHelpers.ts +76 -76
  40. package/src/helpers/filterHelper.ts +148 -148
  41. package/src/helpers/inputHelper.ts +11 -11
  42. package/src/helpers/metaHelper.ts +104 -104
  43. package/src/helpers/runCollectionEntityActionHandler.ts +57 -57
  44. package/src/index.ts +67 -63
  45. package/src/plugins/auth/AuthPlugin.ts +93 -93
  46. package/src/plugins/auth/actionHandlers/changePassword.ts +60 -61
  47. package/src/plugins/auth/actionHandlers/createSession.ts +68 -68
  48. package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
  49. package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
  50. package/src/plugins/auth/actionHandlers/index.ts +8 -8
  51. package/src/plugins/auth/actionHandlers/resetPassword.ts +44 -45
  52. package/src/plugins/auth/models/AccessToken.ts +56 -56
  53. package/src/plugins/auth/models/index.ts +3 -3
  54. package/src/plugins/auth/routes/changePassword.ts +15 -15
  55. package/src/plugins/auth/routes/getMyProfile.ts +15 -15
  56. package/src/plugins/auth/routes/index.ts +7 -7
  57. package/src/plugins/auth/routes/resetPassword.ts +15 -15
  58. package/src/plugins/auth/routes/signin.ts +15 -15
  59. package/src/plugins/auth/routes/signout.ts +15 -15
  60. package/src/plugins/auth/services/AuthService.ts +39 -39
  61. package/src/plugins/cronJob/CronJobPlugin.ts +112 -112
  62. package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
  63. package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
  64. package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
  65. package/src/plugins/cronJob/routes/index.ts +3 -3
  66. package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
  67. package/src/plugins/dataManage/DataManagePlugin.ts +163 -163
  68. package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +15 -15
  69. package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +17 -17
  70. package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +81 -81
  71. package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +20 -20
  72. package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +45 -45
  73. package/src/plugins/dataManage/actionHandlers/deleteCollectionEntityById.ts +20 -20
  74. package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +27 -27
  75. package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +30 -30
  76. package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
  77. package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +15 -15
  78. package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +38 -38
  79. package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +146 -146
  80. package/src/plugins/fileManage/FileManagePlugin.ts +52 -52
  81. package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +65 -65
  82. package/src/plugins/fileManage/actionHandlers/downloadFile.ts +44 -44
  83. package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
  84. package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
  85. package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
  86. package/src/plugins/fileManage/routes/index.ts +5 -5
  87. package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
  88. package/src/plugins/license/LicensePlugin.ts +79 -79
  89. package/src/plugins/license/LicensePluginTypes.ts +95 -95
  90. package/src/plugins/license/LicenseService.ts +118 -118
  91. package/src/plugins/license/actionHandlers/getLicense.ts +18 -18
  92. package/src/plugins/license/actionHandlers/index.ts +4 -4
  93. package/src/plugins/license/helpers/certHelper.ts +21 -21
  94. package/src/plugins/license/helpers/cryptoHelper.ts +47 -47
  95. package/src/plugins/license/models/index.ts +1 -1
  96. package/src/plugins/license/routes/getLicense.ts +15 -15
  97. package/src/plugins/license/routes/index.ts +3 -3
  98. package/src/plugins/mail/MailPlugin.ts +74 -74
  99. package/src/plugins/mail/MailPluginTypes.ts +27 -27
  100. package/src/plugins/mail/MailService.ts +38 -38
  101. package/src/plugins/mail/actionHandlers/index.ts +3 -3
  102. package/src/plugins/mail/models/index.ts +1 -1
  103. package/src/plugins/mail/routes/index.ts +1 -1
  104. package/src/plugins/metaManage/MetaManagePlugin.ts +530 -530
  105. package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
  106. package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
  107. package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
  108. package/src/plugins/notification/NotificationPlugin.ts +68 -68
  109. package/src/plugins/notification/NotificationPluginTypes.ts +13 -13
  110. package/src/plugins/notification/NotificationService.ts +25 -25
  111. package/src/plugins/notification/actionHandlers/index.ts +3 -3
  112. package/src/plugins/notification/models/Notification.ts +60 -60
  113. package/src/plugins/notification/models/index.ts +3 -3
  114. package/src/plugins/notification/routes/index.ts +1 -1
  115. package/src/plugins/routeManage/RouteManagePlugin.ts +62 -62
  116. package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
  117. package/src/plugins/sequence/SequencePlugin.ts +146 -146
  118. package/src/plugins/sequence/SequencePluginTypes.ts +69 -69
  119. package/src/plugins/sequence/SequenceService.ts +92 -92
  120. package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
  121. package/src/plugins/sequence/actionHandlers/index.ts +4 -4
  122. package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
  123. package/src/plugins/sequence/models/SequenceRule.ts +42 -42
  124. package/src/plugins/sequence/models/index.ts +4 -4
  125. package/src/plugins/sequence/routes/generateSn.ts +15 -15
  126. package/src/plugins/sequence/routes/index.ts +3 -3
  127. package/src/plugins/sequence/segment-utility.ts +11 -11
  128. package/src/plugins/sequence/segments/autoIncrement.ts +90 -90
  129. package/src/plugins/sequence/segments/dayOfMonth.ts +19 -19
  130. package/src/plugins/sequence/segments/index.ts +9 -9
  131. package/src/plugins/sequence/segments/literal.ts +16 -16
  132. package/src/plugins/sequence/segments/month.ts +19 -19
  133. package/src/plugins/sequence/segments/parameter.ts +20 -20
  134. package/src/plugins/sequence/segments/year.ts +19 -19
  135. package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
  136. package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
  137. package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
  138. package/src/plugins/serverOperation/actionHandlers/runServerOperation.ts +15 -15
  139. package/src/plugins/setting/SettingPlugin.ts +68 -68
  140. package/src/plugins/setting/SettingPluginTypes.ts +37 -37
  141. package/src/plugins/setting/SettingService.ts +213 -213
  142. package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
  143. package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
  144. package/src/plugins/setting/actionHandlers/index.ts +6 -6
  145. package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
  146. package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
  147. package/src/plugins/setting/models/SystemSettingItem.ts +48 -48
  148. package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
  149. package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
  150. package/src/plugins/setting/models/UserSettingItem.ts +55 -55
  151. package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
  152. package/src/plugins/setting/models/index.ts +8 -8
  153. package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
  154. package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
  155. package/src/plugins/setting/routes/index.ts +5 -5
  156. package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
  157. package/src/plugins/stateMachine/StateMachinePlugin.ts +196 -196
  158. package/src/plugins/stateMachine/StateMachinePluginTypes.ts +48 -48
  159. package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
  160. package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +54 -54
  161. package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
  162. package/src/plugins/stateMachine/models/index.ts +3 -3
  163. package/src/plugins/stateMachine/routes/index.ts +3 -3
  164. package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
  165. package/src/plugins/stateMachine/stateMachineHelper.ts +36 -36
  166. package/src/plugins/webhooks/WebhooksPlugin.ts +148 -148
  167. package/src/plugins/webhooks/pluginConfig.ts +75 -75
  168. package/src/polyfill.ts +5 -5
  169. package/src/proxy/mod.ts +38 -38
  170. package/src/proxy/types.ts +21 -21
  171. package/src/queryBuilder/index.ts +1 -1
  172. package/src/queryBuilder/queryBuilder.ts +668 -668
  173. package/src/server.ts +480 -480
  174. package/src/types.ts +722 -722
  175. package/src/utilities/accessControlUtility.ts +33 -33
  176. package/src/utilities/entityUtility.ts +18 -0
  177. package/src/utilities/errorUtility.ts +15 -15
  178. package/src/utilities/fsUtility.ts +61 -61
  179. package/src/utilities/httpUtility.ts +19 -19
  180. package/src/utilities/jwtUtility.ts +26 -26
  181. package/src/utilities/passwordUtility.ts +26 -0
  182. package/src/utilities/pathUtility.ts +14 -14
  183. package/src/utilities/timeUtility.ts +9 -9
  184. package/src/utilities/typeUtility.ts +15 -15
  185. 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/jwtUtility";
15
-
16
- export * from "./deno-std/http/cookie";
17
-
18
- export { mapDbRowToEntity } from "./dataAccess/entityMapper";
19
-
20
- export * as bootstrapApplicationConfig from "./bootstrapApplicationConfig";
21
-
22
- export { default as CacheFactory } from "./facilities/cache/CacheFactory";
23
- export * from "./facilities/cache/CacheFacilityTypes";
24
-
25
- export { default as MetaManagePlugin } from "./plugins/metaManage/MetaManagePlugin";
26
-
27
- export { default as DataManagePlugin } from "./plugins/dataManage/DataManagePlugin";
28
-
29
- export { default as RouteManagePlugin } from "./plugins/routeManage/RouteManagePlugin";
30
-
31
- export { default as SequencePlugin } from "./plugins/sequence/SequencePlugin";
32
- export * from "./plugins/sequence/SequencePluginTypes";
33
-
34
- export { default as WebhooksPlugin } from "./plugins/webhooks/WebhooksPlugin";
35
-
36
- export { default as AuthPlugin } from "./plugins/auth/AuthPlugin";
37
-
38
- export { default as FileManagePlugin } from "./plugins/fileManage/FileManagePlugin";
39
-
40
- export { default as LicensePlugin } from "./plugins/license/LicensePlugin";
41
- export * from "./plugins/license/LicensePluginTypes";
42
-
43
- export { default as MailPlugin } from "./plugins/mail/MailPlugin";
44
- export * from "./plugins/mail/MailPluginTypes";
45
-
46
- export { default as NotificationPlugin } from "./plugins/notification/NotificationPlugin";
47
- export * from "./plugins/notification/NotificationPluginTypes";
48
-
49
- export { default as ServerOperationPlugin } from "./plugins/serverOperation/ServerOperationPlugin";
50
- export * from "./plugins/serverOperation/ServerOperationPluginTypes";
51
-
52
- export { default as SettingPlugin } from "./plugins/setting/SettingPlugin";
53
- export * from "./plugins/setting/SettingPluginTypes";
54
-
55
- export { default as CronJobPlugin } from "./plugins/cronJob/CronJobPlugin";
56
- export * from "./plugins/cronJob/CronJobPluginTypes";
57
-
58
- export { default as StateMachinePlugin } from "./plugins/stateMachine/StateMachinePlugin";
59
- export * from "./plugins/stateMachine/StateMachinePluginTypes";
60
-
61
- export { default as EntityAccessControlPlugin } from "./plugins/entityAccessControl/EntityAccessControlPlugin";
62
-
63
- export * from "./facilities/log/LogFacility";
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 bcrypt from "bcrypt";
2
- import { ActionHandlerContext } from "~/core/actionHandler";
3
- import { RapidPlugin } from "~/core/server";
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 bcrypt.compare(oldPassword, user.password);
45
- if (!isMatch) {
46
- throw new Error("旧密码错误。");
47
- }
48
-
49
- const saltRounds = 10;
50
- const passwordHash = await bcrypt.hash(newPassword, saltRounds);
51
-
52
- await userDataAccessor.updateById(
53
- user.id,
54
- {
55
- password: passwordHash,
56
- },
57
- routeContext?.getDbTransactionClient(),
58
- );
59
-
60
- ctx.output = {};
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 bcrypt from "bcrypt";
2
- import { setCookie } from "~/deno-std/http/cookie";
3
- import { ActionHandlerContext } from "~/core/actionHandler";
4
- import { RapidPlugin } from "~/core/server";
5
- import LicenseService from "~/plugins/license/LicenseService";
6
- import { get } from "lodash";
7
- import AuthService from "../services/AuthService";
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 bcrypt.compare(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
+ 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
+ }