@ai-partner-x/aiko-boot-cli 0.1.4 → 0.1.5

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 (441) hide show
  1. package/dist/cli.js +2 -0
  2. package/dist/commands/add-api.js +9 -3
  3. package/dist/commands/add-app.js +0 -2
  4. package/dist/commands/env.d.ts +8 -0
  5. package/dist/commands/env.js +55 -0
  6. package/dist/commands/init.js +7 -9
  7. package/dist/core/project-config.d.ts +1 -0
  8. package/dist/core/prompts.d.ts +2 -0
  9. package/dist/core/prompts.js +33 -32
  10. package/dist/core/workspace.js +30 -9
  11. package/dist/scaffold.js +1 -1
  12. package/dist/usecases/add-api.usecase.d.ts +5 -2
  13. package/dist/usecases/add-api.usecase.js +83 -21
  14. package/dist/usecases/add-app.usecase.d.ts +0 -1
  15. package/dist/usecases/add-app.usecase.js +20 -10
  16. package/dist/usecases/add-feature.usecase.js +26 -23
  17. package/dist/usecases/env.usecase.d.ts +23 -0
  18. package/dist/usecases/env.usecase.js +284 -0
  19. package/dist/usecases/init-scaffold.usecase.d.ts +3 -4
  20. package/dist/usecases/init-scaffold.usecase.js +36 -49
  21. package/package.json +8 -3
  22. package/templates/api-clean/.env.example +3 -0
  23. package/templates/api-clean/app.config.ts +19 -0
  24. package/templates/{scaffold-default/packages/api → api-clean}/examples/security/README.md +2 -2
  25. package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/README.md +1 -1
  26. package/templates/{scaffold-default/packages/api → api-clean}/package.json +4 -16
  27. package/templates/api-clean/src/scripts/init-db.ts +50 -0
  28. package/templates/{scaffold-default/packages/api → api-clean}/src/server.ts +15 -11
  29. package/templates/api-clean/src/types/aiko-boot-starter-web.d.ts +8 -0
  30. package/templates/api-system/.env.example +11 -0
  31. package/templates/api-system/.eslintrc.json +6 -0
  32. package/templates/api-system/.swcrc +17 -0
  33. package/templates/api-system/app.config.ts +87 -0
  34. package/templates/api-system/docs/api-document.md +497 -0
  35. package/templates/api-system/docs/final-completion-report.md +565 -0
  36. package/templates/api-system/docs/permission-integration-summary.md +432 -0
  37. package/templates/api-system/examples/security/README.md +664 -0
  38. package/templates/api-system/examples/security/complete/.env.example +26 -0
  39. package/templates/api-system/examples/security/complete/PROJECT_STRUCTURE.md +220 -0
  40. package/templates/api-system/examples/security/complete/README.md +847 -0
  41. package/templates/api-system/examples/security/complete/app.config.ts +69 -0
  42. package/templates/api-system/examples/security/complete/app.ts +63 -0
  43. package/templates/api-system/examples/security/complete/controller/auth.controller.ts +131 -0
  44. package/templates/api-system/examples/security/complete/controller/index.ts +4 -0
  45. package/templates/api-system/examples/security/complete/controller/permission.controller.ts +41 -0
  46. package/templates/api-system/examples/security/complete/controller/role.controller.ts +53 -0
  47. package/templates/api-system/examples/security/complete/controller/user.controller.ts +53 -0
  48. package/templates/api-system/examples/security/complete/dto/change-password.dto.ts +10 -0
  49. package/templates/api-system/examples/security/complete/dto/create-permission.dto.ts +14 -0
  50. package/templates/api-system/examples/security/complete/dto/create-role.dto.ts +11 -0
  51. package/templates/api-system/examples/security/complete/dto/create-user.dto.ts +15 -0
  52. package/templates/api-system/examples/security/complete/dto/index.ts +7 -0
  53. package/templates/api-system/examples/security/complete/dto/login.dto.ts +10 -0
  54. package/templates/api-system/examples/security/complete/dto/oauth-profile.dto.ts +7 -0
  55. package/templates/api-system/examples/security/complete/dto/register.dto.ts +17 -0
  56. package/templates/api-system/examples/security/complete/entity/index.ts +6 -0
  57. package/templates/api-system/examples/security/complete/entity/oauth-account.entity.ts +39 -0
  58. package/templates/api-system/examples/security/complete/entity/permission.entity.ts +31 -0
  59. package/templates/api-system/examples/security/complete/entity/role-permission.entity.ts +19 -0
  60. package/templates/api-system/examples/security/complete/entity/role.entity.ts +25 -0
  61. package/templates/api-system/examples/security/complete/entity/user-role.entity.ts +19 -0
  62. package/templates/api-system/examples/security/complete/entity/user.entity.ts +46 -0
  63. package/templates/api-system/examples/security/complete/init.sql +81 -0
  64. package/templates/api-system/examples/security/complete/middleware/auth.interceptor.ts +39 -0
  65. package/templates/api-system/examples/security/complete/middleware/index.ts +2 -0
  66. package/templates/api-system/examples/security/complete/middleware/permission.interceptor.ts +61 -0
  67. package/templates/api-system/examples/security/complete/package.json +54 -0
  68. package/templates/api-system/examples/security/complete/seed.sql +42 -0
  69. package/templates/api-system/examples/security/complete/service/auth.service.ts +41 -0
  70. package/templates/api-system/examples/security/complete/service/index.ts +5 -0
  71. package/templates/api-system/examples/security/complete/service/oauth.service.ts +82 -0
  72. package/templates/api-system/examples/security/complete/service/permission.service.ts +113 -0
  73. package/templates/api-system/examples/security/complete/service/role.service.ts +85 -0
  74. package/templates/api-system/examples/security/complete/service/user.service.ts +132 -0
  75. package/templates/api-system/examples/security/complete/tests/TEST_REPORT.md +318 -0
  76. package/templates/api-system/examples/security/complete/tests/generate-report.js +335 -0
  77. package/templates/api-system/examples/security/complete/tests/helpers/api-helpers.ts +116 -0
  78. package/templates/api-system/examples/security/complete/tests/helpers/index.ts +2 -0
  79. package/templates/api-system/examples/security/complete/tests/helpers/test-helpers.ts +129 -0
  80. package/templates/api-system/examples/security/complete/tests/integration/auth.api.test.ts +429 -0
  81. package/templates/api-system/examples/security/complete/tests/integration/role.api.test.ts +400 -0
  82. package/templates/api-system/examples/security/complete/tests/integration/user.api.test.ts +459 -0
  83. package/templates/api-system/examples/security/complete/tests/jest.config.js +40 -0
  84. package/templates/api-system/examples/security/complete/tests/run-all-tests.js +135 -0
  85. package/templates/api-system/examples/security/complete/tests/run-tests.js +109 -0
  86. package/templates/api-system/examples/security/complete/tests/setup.ts +19 -0
  87. package/templates/api-system/examples/security/complete/tests/unit/auth.service.test.ts +199 -0
  88. package/templates/api-system/examples/security/complete/tests/unit/permission.service.test.ts +377 -0
  89. package/templates/api-system/examples/security/complete/tests/unit/user.service.test.ts +288 -0
  90. package/templates/api-system/examples/security/complete/tsconfig.json +35 -0
  91. package/templates/api-system/examples/security/jwt/README.md +424 -0
  92. package/templates/api-system/examples/security/local/README.md +499 -0
  93. package/templates/api-system/examples/security/oauth2/README.md +637 -0
  94. package/templates/api-system/examples/security/permission/README.md +943 -0
  95. package/templates/api-system/examples/security/session/README.md +753 -0
  96. package/templates/{api-base → api-system}/package.json +6 -5
  97. package/templates/{api-base → api-system}/scripts/codegen.cjs +0 -1
  98. package/templates/{api-base → api-system}/scripts/codegen.ts +0 -1
  99. package/templates/{scaffold-default/packages/api → api-system}/src/config/security-auto-configuration.ts +5 -2
  100. package/templates/api-system/src/scripts/simple-reset-admin.mjs +39 -0
  101. package/templates/api-system/src/server.ts +42 -0
  102. package/templates/api-system/src/types/aiko-boot-starter-web.d.ts +8 -0
  103. package/templates/api-system/src/types/sqljs.d.ts +18 -0
  104. package/templates/{api-base → api-system}/tsconfig.json +0 -1
  105. package/templates/api-system/tsup.config.ts +14 -0
  106. package/templates/api-system/uploads/.gitkeep +0 -0
  107. package/templates/app-admin/.env.example +18 -0
  108. package/templates/{scaffold-default/packages/admin → app-admin}/package.json +9 -3
  109. package/templates/{scaffold-default/packages/admin → app-admin}/tsconfig.json +1 -1
  110. package/templates/app-admin/vite.config.ts +31 -0
  111. package/templates/app-mobile/.env.example +5 -0
  112. package/templates/{scaffold-default/packages/mobile → app-mobile}/package.json +8 -2
  113. package/templates/{scaffold-default/packages/mobile → app-mobile}/src/main.tsx +2 -1
  114. package/templates/api-base/app.config.ts +0 -155
  115. package/templates/api-base/src/controller/auth.controller.ts +0 -160
  116. package/templates/api-base/src/controller/menu.controller.ts +0 -56
  117. package/templates/api-base/src/controller/role.controller.ts +0 -62
  118. package/templates/api-base/src/controller/user.controller.ts +0 -75
  119. package/templates/api-base/src/dto/auth.dto.ts +0 -31
  120. package/templates/api-base/src/dto/menu.dto.ts +0 -38
  121. package/templates/api-base/src/dto/role.dto.ts +0 -18
  122. package/templates/api-base/src/dto/user.dto.ts +0 -36
  123. package/templates/api-base/src/entity/menu.entity.ts +0 -35
  124. package/templates/api-base/src/entity/role-menu.entity.ts +0 -14
  125. package/templates/api-base/src/entity/role.entity.ts +0 -23
  126. package/templates/api-base/src/entity/user-role.entity.ts +0 -14
  127. package/templates/api-base/src/entity/user.entity.ts +0 -32
  128. package/templates/api-base/src/mapper/menu.mapper.ts +0 -7
  129. package/templates/api-base/src/mapper/role-menu.mapper.ts +0 -7
  130. package/templates/api-base/src/mapper/role.mapper.ts +0 -7
  131. package/templates/api-base/src/mapper/user-role.mapper.ts +0 -7
  132. package/templates/api-base/src/mapper/user.mapper.ts +0 -12
  133. package/templates/api-base/src/scripts/init-db.ts +0 -204
  134. package/templates/api-base/src/server.ts +0 -69
  135. package/templates/api-base/src/service/auth.service.ts +0 -144
  136. package/templates/api-base/src/service/log.request.service.ts +0 -72
  137. package/templates/api-base/src/service/menu.service.ts +0 -94
  138. package/templates/api-base/src/service/role.service.ts +0 -88
  139. package/templates/api-base/src/service/user.service.ts +0 -175
  140. package/templates/api-base/src/utils/jwt.util.ts +0 -39
  141. package/templates/scaffold-default/README.md +0 -114
  142. package/templates/scaffold-default/package.json +0 -26
  143. package/templates/scaffold-default/packages/admin/.env.dev +0 -1
  144. package/templates/scaffold-default/packages/admin/.env.prod +0 -4
  145. package/templates/scaffold-default/packages/admin/.env.stage +0 -4
  146. package/templates/scaffold-default/packages/admin/vite.config.ts +0 -26
  147. package/templates/scaffold-default/packages/api/app.config.ts +0 -163
  148. package/templates/scaffold-default/packages/api/src/controller/cache.controller.ts +0 -106
  149. package/templates/scaffold-default/packages/api/src/controller/mq.controller.ts +0 -35
  150. package/templates/scaffold-default/packages/api/src/controller/upload.controller.ts +0 -83
  151. package/templates/scaffold-default/packages/api/src/dto/cache.dto.ts +0 -24
  152. package/templates/scaffold-default/packages/api/src/dto/mq.dto.ts +0 -16
  153. package/templates/scaffold-default/packages/api/src/service/cache.service.ts +0 -80
  154. package/templates/scaffold-default/packages/api/src/service/log.request.service.ts +0 -158
  155. package/templates/scaffold-default/packages/api/src/service/log.service.ts +0 -123
  156. package/templates/scaffold-default/packages/api/src/service/mq.consumer.service.ts +0 -26
  157. package/templates/scaffold-default/pnpm-workspace.yaml +0 -2
  158. package/templates/scaffold-default/scripts/postinstall.cjs +0 -42
  159. package/templates/scaffold-default/scripts/rebuild-sqlite.cjs +0 -23
  160. /package/templates/{scaffold-default/packages/api → api-clean}/.eslintrc.json +0 -0
  161. /package/templates/{scaffold-default/packages/api → api-clean}/.swcrc +0 -0
  162. /package/templates/{scaffold-default/packages/api → api-clean}/docs/api-document.md +0 -0
  163. /package/templates/{scaffold-default/packages/api → api-clean}/docs/final-completion-report.md +0 -0
  164. /package/templates/{scaffold-default/packages/api → api-clean}/docs/permission-integration-summary.md +0 -0
  165. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/.env.example +0 -0
  166. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/PROJECT_STRUCTURE.md +0 -0
  167. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/app.config.ts +0 -0
  168. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/app.ts +0 -0
  169. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/controller/auth.controller.ts +0 -0
  170. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/controller/index.ts +0 -0
  171. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/controller/permission.controller.ts +0 -0
  172. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/controller/role.controller.ts +0 -0
  173. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/controller/user.controller.ts +0 -0
  174. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/change-password.dto.ts +0 -0
  175. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/create-permission.dto.ts +0 -0
  176. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/create-role.dto.ts +0 -0
  177. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/create-user.dto.ts +0 -0
  178. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/index.ts +0 -0
  179. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/login.dto.ts +0 -0
  180. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/oauth-profile.dto.ts +0 -0
  181. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/dto/register.dto.ts +0 -0
  182. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/index.ts +0 -0
  183. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/oauth-account.entity.ts +0 -0
  184. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/permission.entity.ts +0 -0
  185. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/role-permission.entity.ts +0 -0
  186. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/role.entity.ts +0 -0
  187. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/user-role.entity.ts +0 -0
  188. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/entity/user.entity.ts +0 -0
  189. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/init.sql +0 -0
  190. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/middleware/auth.interceptor.ts +0 -0
  191. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/middleware/index.ts +0 -0
  192. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/middleware/permission.interceptor.ts +0 -0
  193. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/package.json +0 -0
  194. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/seed.sql +0 -0
  195. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/auth.service.ts +0 -0
  196. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/index.ts +0 -0
  197. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/oauth.service.ts +0 -0
  198. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/permission.service.ts +0 -0
  199. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/role.service.ts +0 -0
  200. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/service/user.service.ts +0 -0
  201. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/TEST_REPORT.md +0 -0
  202. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/generate-report.js +0 -0
  203. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/helpers/api-helpers.ts +0 -0
  204. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/helpers/index.ts +0 -0
  205. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/helpers/test-helpers.ts +0 -0
  206. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/integration/auth.api.test.ts +0 -0
  207. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/integration/role.api.test.ts +0 -0
  208. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/integration/user.api.test.ts +0 -0
  209. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/jest.config.js +0 -0
  210. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/run-all-tests.js +0 -0
  211. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/run-tests.js +0 -0
  212. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/setup.ts +0 -0
  213. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/unit/auth.service.test.ts +0 -0
  214. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/unit/permission.service.test.ts +0 -0
  215. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tests/unit/user.service.test.ts +0 -0
  216. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/complete/tsconfig.json +0 -0
  217. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/jwt/README.md +0 -0
  218. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/local/README.md +0 -0
  219. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/oauth2/README.md +0 -0
  220. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/permission/README.md +0 -0
  221. /package/templates/{scaffold-default/packages/api → api-clean}/examples/security/session/README.md +0 -0
  222. /package/templates/{scaffold-default/packages/api → api-clean}/scripts/codegen.cjs +0 -0
  223. /package/templates/{scaffold-default/packages/api → api-clean}/scripts/codegen.ts +0 -0
  224. /package/templates/{scaffold-default/packages/api → api-clean}/src/scripts/simple-reset-admin.mjs +0 -0
  225. /package/templates/{scaffold-default/packages/api → api-clean}/src/types/sqljs.d.ts +0 -0
  226. /package/templates/{scaffold-default/packages/api → api-clean}/tsconfig.json +0 -0
  227. /package/templates/{scaffold-default/packages/api → api-clean}/tsup.config.ts +0 -0
  228. /package/templates/{scaffold-default/packages/api → api-clean}/uploads/.gitkeep +0 -0
  229. /package/templates/{scaffold-default/packages/api → api-system}/src/controller/auth.controller.ts +0 -0
  230. /package/templates/{scaffold-default/packages/api → api-system}/src/controller/menu.controller.ts +0 -0
  231. /package/templates/{scaffold-default/packages/api → api-system}/src/controller/role.controller.ts +0 -0
  232. /package/templates/{scaffold-default/packages/api → api-system}/src/controller/user.controller.ts +0 -0
  233. /package/templates/{scaffold-default/packages/api → api-system}/src/dto/auth.dto.ts +0 -0
  234. /package/templates/{scaffold-default/packages/api → api-system}/src/dto/menu.dto.ts +0 -0
  235. /package/templates/{scaffold-default/packages/api → api-system}/src/dto/role.dto.ts +0 -0
  236. /package/templates/{scaffold-default/packages/api → api-system}/src/dto/user.dto.ts +0 -0
  237. /package/templates/{scaffold-default/packages/api → api-system}/src/entity/menu.entity.ts +0 -0
  238. /package/templates/{scaffold-default/packages/api → api-system}/src/entity/role-menu.entity.ts +0 -0
  239. /package/templates/{scaffold-default/packages/api → api-system}/src/entity/role.entity.ts +0 -0
  240. /package/templates/{scaffold-default/packages/api → api-system}/src/entity/user-role.entity.ts +0 -0
  241. /package/templates/{scaffold-default/packages/api → api-system}/src/entity/user.entity.ts +0 -0
  242. /package/templates/{scaffold-default/packages/api → api-system}/src/mapper/menu.mapper.ts +0 -0
  243. /package/templates/{scaffold-default/packages/api → api-system}/src/mapper/role-menu.mapper.ts +0 -0
  244. /package/templates/{scaffold-default/packages/api → api-system}/src/mapper/role.mapper.ts +0 -0
  245. /package/templates/{scaffold-default/packages/api → api-system}/src/mapper/user-role.mapper.ts +0 -0
  246. /package/templates/{scaffold-default/packages/api → api-system}/src/mapper/user.mapper.ts +0 -0
  247. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/assign-role.ts +0 -0
  248. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/check-user-role.ts +0 -0
  249. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/check-users.mjs +0 -0
  250. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/demo-permissions.mjs +0 -0
  251. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/init-db.ts +0 -0
  252. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/reset-admin-password.mjs +0 -0
  253. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/reset-password.ts +0 -0
  254. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/test-db.ts +0 -0
  255. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/test-di.ts +0 -0
  256. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/test-permissions.mjs +0 -0
  257. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/update-admin-password.mjs +0 -0
  258. /package/templates/{scaffold-default/packages/api → api-system}/src/scripts/user-roles.ts +0 -0
  259. /package/templates/{scaffold-default/packages/api → api-system}/src/service/auth.service.ts +0 -0
  260. /package/templates/{scaffold-default/packages/api → api-system}/src/service/menu.service.ts +0 -0
  261. /package/templates/{scaffold-default/packages/api → api-system}/src/service/role.service.ts +0 -0
  262. /package/templates/{scaffold-default/packages/api → api-system}/src/service/user.service.ts +0 -0
  263. /package/templates/{scaffold-default/packages/api → api-system}/src/utils/auth.utils.js +0 -0
  264. /package/templates/{scaffold-default/packages/api → api-system}/src/utils/jwt.util.ts +0 -0
  265. /package/templates/{scaffold-default/packages/admin → app-admin}/Dockerfile +0 -0
  266. /package/templates/{scaffold-default/packages/admin → app-admin}/README.MD +0 -0
  267. /package/templates/{scaffold-default/packages/admin → app-admin}/components.json +0 -0
  268. /package/templates/{scaffold-default/packages/admin → app-admin}/eslint.config.js +0 -0
  269. /package/templates/{scaffold-default/packages/admin → app-admin}/index.html +0 -0
  270. /package/templates/{scaffold-default/packages/admin → app-admin}/public/vite.svg +0 -0
  271. /package/templates/{scaffold-default/packages/admin → app-admin}/src/App.css +0 -0
  272. /package/templates/{scaffold-default/packages/admin → app-admin}/src/App.tsx +0 -0
  273. /package/templates/{scaffold-default/packages/admin → app-admin}/src/app.config.ts +0 -0
  274. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/data-table/data-table-pagination.tsx +0 -0
  275. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/data-table/data-table-sorter.tsx +0 -0
  276. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/data-table/index.tsx +0 -0
  277. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/editable-table.tsx +0 -0
  278. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/form/input-password.tsx +0 -0
  279. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/form/sign-in-form.tsx +0 -0
  280. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/error-component.tsx +0 -0
  281. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/header.tsx +0 -0
  282. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/language-switcher.tsx +0 -0
  283. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/layout.tsx +0 -0
  284. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/loading-overlay.tsx +0 -0
  285. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/shell-bar.tsx +0 -0
  286. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/sidebar.tsx +0 -0
  287. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/layout/user-avatar.tsx +0 -0
  288. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/list-report.tsx +0 -0
  289. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/master-detail.tsx +0 -0
  290. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/notification/toaster.tsx +0 -0
  291. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/notification/undoable-notification.tsx +0 -0
  292. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/object-page.tsx +0 -0
  293. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/theme/theme-provider.tsx +0 -0
  294. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/theme/theme-select.tsx +0 -0
  295. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/admin-ui/theme/theme-toggle.tsx +0 -0
  296. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/accordion.tsx +0 -0
  297. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/alert-dialog.tsx +0 -0
  298. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/alert.tsx +0 -0
  299. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/aspect-ratio.tsx +0 -0
  300. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/avatar.tsx +0 -0
  301. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/badge.tsx +0 -0
  302. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/breadcrumb.tsx +0 -0
  303. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/button.tsx +0 -0
  304. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/calendar.tsx +0 -0
  305. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/card.tsx +0 -0
  306. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/carousel.tsx +0 -0
  307. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/chart.tsx +0 -0
  308. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/checkbox.tsx +0 -0
  309. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/collapsible.tsx +0 -0
  310. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/command.tsx +0 -0
  311. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/context-menu.tsx +0 -0
  312. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/dialog.tsx +0 -0
  313. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/drawer.tsx +0 -0
  314. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/dropdown-menu.tsx +0 -0
  315. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/form.tsx +0 -0
  316. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/hover-card.tsx +0 -0
  317. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/input-otp.tsx +0 -0
  318. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/input.tsx +0 -0
  319. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/label.tsx +0 -0
  320. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/menubar.tsx +0 -0
  321. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/navigation-menu.tsx +0 -0
  322. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/pagination.tsx +0 -0
  323. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/popover.tsx +0 -0
  324. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/progress.tsx +0 -0
  325. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/radio-group.tsx +0 -0
  326. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/resizable.tsx +0 -0
  327. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/scroll-area.tsx +0 -0
  328. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/select.tsx +0 -0
  329. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/separator.tsx +0 -0
  330. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/sheet.tsx +0 -0
  331. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/sidebar.tsx +0 -0
  332. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/skeleton.tsx +0 -0
  333. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/slider.tsx +0 -0
  334. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/sonner.tsx +0 -0
  335. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/switch.tsx +0 -0
  336. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/table.tsx +0 -0
  337. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/tabs.tsx +0 -0
  338. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/textarea.tsx +0 -0
  339. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/toggle-group.tsx +0 -0
  340. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/toggle.tsx +0 -0
  341. /package/templates/{scaffold-default/packages/admin → app-admin}/src/components/ui/tooltip.tsx +0 -0
  342. /package/templates/{scaffold-default/packages/admin → app-admin}/src/hooks/use-mobile.ts +0 -0
  343. /package/templates/{scaffold-default/packages/admin → app-admin}/src/i18n.ts +0 -0
  344. /package/templates/{scaffold-default/packages/admin → app-admin}/src/index.tsx +0 -0
  345. /package/templates/{scaffold-default/packages/admin → app-admin}/src/layouts/menu-layout.tsx +0 -0
  346. /package/templates/{scaffold-default/packages/admin → app-admin}/src/layouts/tile-layout.tsx +0 -0
  347. /package/templates/{scaffold-default/packages/admin → app-admin}/src/lib/utils.ts +0 -0
  348. /package/templates/{scaffold-default/packages/admin → app-admin}/src/locales/en.json +0 -0
  349. /package/templates/{scaffold-default/packages/admin → app-admin}/src/locales/zh.json +0 -0
  350. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/dashboard.tsx +0 -0
  351. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/goods-receipt/CreatePage.tsx +0 -0
  352. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/goods-receipt/EditPage.tsx +0 -0
  353. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/goods-receipt/ListPage.tsx +0 -0
  354. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/goods-receipt/ViewPage.tsx +0 -0
  355. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/goods-receipt/index.ts +0 -0
  356. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/home-page.tsx +0 -0
  357. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/cost-centers/index.tsx +0 -0
  358. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/currencies/index.tsx +0 -0
  359. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/materials/ListPage.tsx +0 -0
  360. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/materials/ViewPage.tsx +0 -0
  361. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/materials/index.ts +0 -0
  362. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/plants/ListPage.tsx +0 -0
  363. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/plants/ViewPage.tsx +0 -0
  364. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/plants/index.ts +0 -0
  365. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/purchase-organizations/index.tsx +0 -0
  366. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/units-of-measure/index.tsx +0 -0
  367. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/vendors/ListPage.tsx +0 -0
  368. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/vendors/ViewPage.tsx +0 -0
  369. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/master-data/vendors/index.ts +0 -0
  370. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/placeholder-page.tsx +0 -0
  371. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-orders/ListPage.tsx +0 -0
  372. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-orders/ViewPage.tsx +0 -0
  373. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-orders/index.ts +0 -0
  374. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/CreatePage.tsx +0 -0
  375. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/EditPage.tsx +0 -0
  376. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/ListPage.tsx +0 -0
  377. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/ViewPage.tsx +0 -0
  378. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/constants.ts +0 -0
  379. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/purchase-requisitions/index.ts +0 -0
  380. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/reports/PurchaseOrderReport.tsx +0 -0
  381. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/reports/PurchaseRequisitionReport.tsx +0 -0
  382. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/reports/index.ts +0 -0
  383. /package/templates/{scaffold-default/packages/admin → app-admin}/src/pages/settings-page.tsx +0 -0
  384. /package/templates/{scaffold-default/packages/admin → app-admin}/src/providers/app-config.tsx +0 -0
  385. /package/templates/{scaffold-default/packages/admin → app-admin}/src/providers/auth-provider.ts +0 -0
  386. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/auth.ts +0 -0
  387. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/index.ts +0 -0
  388. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/menu.ts +0 -0
  389. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/goods-receipt.ts +0 -0
  390. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/master-data.ts +0 -0
  391. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/purchase-orders.ts +0 -0
  392. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/purchase-requisitions.ts +0 -0
  393. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/reports.ts +0 -0
  394. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/modules/settings.ts +0 -0
  395. /package/templates/{scaffold-default/packages/admin → app-admin}/src/routes/withSuspense.tsx +0 -0
  396. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/amber.css +0 -0
  397. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/blue.css +0 -0
  398. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/default.css +0 -0
  399. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/fiori.css +0 -0
  400. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/green.css +0 -0
  401. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/index.css +0 -0
  402. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/rose.css +0 -0
  403. /package/templates/{scaffold-default/packages/admin → app-admin}/src/theme/violet.css +0 -0
  404. /package/templates/{scaffold-default/packages/admin → app-admin}/src/vite-env.d.ts +0 -0
  405. /package/templates/{scaffold-default/packages/admin → app-admin}/tsconfig.node.json +0 -0
  406. /package/templates/{scaffold-default/packages/core → app-core}/package.json +0 -0
  407. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/auth-client-middleware.ts +0 -0
  408. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/auth-constants.ts +0 -0
  409. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/auth-service.ts +0 -0
  410. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/backend-auth-provider.ts +0 -0
  411. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/default-auth-provider.ts +0 -0
  412. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/index.ts +0 -0
  413. /package/templates/{scaffold-default/packages/core → app-core}/src/auth/types.ts +0 -0
  414. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/authorization-client-middleware.ts +0 -0
  415. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/authorization-config.ts +0 -0
  416. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/authorization-provider.tsx +0 -0
  417. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/default-authorization-provider.ts +0 -0
  418. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/index.ts +0 -0
  419. /package/templates/{scaffold-default/packages/core → app-core}/src/authorization/types.ts +0 -0
  420. /package/templates/{scaffold-default/packages/core → app-core}/src/index.ts +0 -0
  421. /package/templates/{scaffold-default/packages/core → app-core}/src/utils/promise-result-cache.ts +0 -0
  422. /package/templates/{scaffold-default/packages/core → app-core}/tsconfig.json +0 -0
  423. /package/templates/{scaffold-default/packages/mobile → app-mobile}/README.md +0 -0
  424. /package/templates/{scaffold-default/packages/mobile → app-mobile}/index.html +0 -0
  425. /package/templates/{scaffold-default/packages/mobile → app-mobile}/postcss.config.mjs +0 -0
  426. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/App.tsx +0 -0
  427. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/app/globals.css +0 -0
  428. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/components/LoginForm.tsx +0 -0
  429. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/hooks/index.ts +0 -0
  430. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/lib/utils.ts +0 -0
  431. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/pages/HomePage.tsx +0 -0
  432. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/pages/LoginPage.tsx +0 -0
  433. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/pages/index.ts +0 -0
  434. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/routes/ProtectedRoute.tsx +0 -0
  435. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/routes/index.tsx +0 -0
  436. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/routes/routes.ts +0 -0
  437. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/types/index.ts +0 -0
  438. /package/templates/{scaffold-default/packages/mobile → app-mobile}/src/vite-env.d.ts +0 -0
  439. /package/templates/{scaffold-default/packages/mobile → app-mobile}/tsconfig.json +0 -0
  440. /package/templates/{scaffold-default/packages/mobile → app-mobile}/tsconfig.node.json +0 -0
  441. /package/templates/{scaffold-default/packages/mobile → app-mobile}/vite.config.ts +0 -0
@@ -0,0 +1,664 @@
1
+ # Aiko Boot Starter Security 使用示例
2
+
3
+ 本目录展示了如何使用 `@ai-partner-x/aiko-boot-starter-security` 组件实现各种认证和授权策略。
4
+
5
+ ## 目录结构
6
+
7
+ ```
8
+ security/
9
+ ├── README.md # 本文档
10
+ ├── jwt/ # JWT 认证策略示例
11
+ │ ├── README.md
12
+ │ ├── app.config.ts
13
+ │ ├── entity/
14
+ │ ├── dto/
15
+ │ ├── controller/
16
+ │ └── service/
17
+ ├── local/ # Local 认证策略示例
18
+ │ ├── README.md
19
+ │ ├── app.config.ts
20
+ │ ├── entity/
21
+ │ ├── dto/
22
+ │ ├── controller/
23
+ │ └── service/
24
+ ├── oauth2/ # OAuth2 认证策略示例
25
+ │ ├── README.md
26
+ │ ├── app.config.ts
27
+ │ ├── entity/
28
+ │ ├── dto/
29
+ │ ├── controller/
30
+ │ └── service/
31
+ ├── session/ # Session 认证策略示例
32
+ │ ├── README.md
33
+ │ ├── app.config.ts
34
+ │ ├── entity/
35
+ │ ├── dto/
36
+ │ ├── controller/
37
+ │ └── service/
38
+ └── permission/ # 权限控制示例
39
+ ├── README.md
40
+ ├── app.config.ts
41
+ ├── entity/
42
+ ├── dto/
43
+ ├── controller/
44
+ └── service/
45
+ └── complete/ # 完整配置和集成示例
46
+ ├── README.md # 完整示例文档
47
+ ├── PROJECT_STRUCTURE.md # 项目结构说明
48
+ ├── app.config.ts # 应用配置
49
+ ├── app.ts # 应用入口
50
+ ├── package.json # 项目依赖
51
+ ├── .env.example # 环境变量示例
52
+ ├── init.sql # 数据库初始化脚本
53
+ ├── seed.sql # 种子数据脚本
54
+ ├── entity/ # 实体定义
55
+ │ ├── user.entity.ts
56
+ │ ├── role.entity.ts
57
+ │ ├── permission.entity.ts
58
+ │ ├── user-role.entity.ts
59
+ │ ├── role-permission.entity.ts
60
+ │ ├── oauth-account.entity.ts
61
+ │ └── index.ts
62
+ ├── dto/ # 数据传输对象
63
+ │ ├── login.dto.ts
64
+ │ ├── register.dto.ts
65
+ │ ├── create-user.dto.ts
66
+ │ ├── create-role.dto.ts
67
+ │ ├── create-permission.dto.ts
68
+ │ ├── oauth-profile.dto.ts
69
+ │ ├── change-password.dto.ts
70
+ │ └── index.ts
71
+ ├── service/ # 服务层
72
+ │ ├── auth.service.ts
73
+ │ ├── user.service.ts
74
+ │ ├── role.service.ts
75
+ │ ├── permission.service.ts
76
+ │ ├── oauth.service.ts
77
+ │ └── index.ts
78
+ ├── controller/ # 控制器层
79
+ │ ├── auth.controller.ts
80
+ │ ├── user.controller.ts
81
+ │ ├── role.controller.ts
82
+ │ ├── permission.controller.ts
83
+ │ └── index.ts
84
+ ├── middleware/ # 中间件
85
+ │ ├── auth.interceptor.ts
86
+ │ ├── permission.interceptor.ts
87
+ │ └── index.ts
88
+ └── tests/ # 测试套件
89
+ ├── unit/ # 单元测试
90
+ │ ├── auth.service.test.ts
91
+ │ ├── user.service.test.ts
92
+ │ └── permission.service.test.ts
93
+ ├── integration/ # 集成测试
94
+ │ ├── auth.api.test.ts
95
+ │ ├── user.api.test.ts
96
+ │ └── role.api.test.ts
97
+ ├── helpers/ # 测试辅助工具
98
+ │ ├── test-helpers.ts
99
+ │ ├── api-helpers.ts
100
+ │ └── index.ts
101
+ ├── jest.config.js # Jest 配置
102
+ ├── setup.ts # 测试设置
103
+ ├── run-all-tests.js # 运行所有测试
104
+ ├── run-tests.js # 运行测试脚本
105
+ ├── generate-report.js # 生成测试报告
106
+ └── TEST_REPORT.md # 完整测试报告
107
+ ```
108
+
109
+ ## 快速开始
110
+
111
+ ### 1. 安装依赖
112
+
113
+ ```bash
114
+ cd /path/to/ai-frist-framework
115
+ pnpm install
116
+ ```
117
+
118
+ ### 2. 选择策略
119
+
120
+ 根据你的需求选择合适的认证策略:
121
+
122
+ - **JWT**:适用于 RESTful API,无状态,可扩展
123
+ - **Local**:适用于传统表单登录,配合 JWT 使用
124
+ - **OAuth2**:适用于第三方登录(GitHub、Google 等)
125
+ - **Session**:适用于传统 Web 应用,有状态
126
+
127
+ ### 3. 配置应用
128
+
129
+ 复制对应策略目录下的 `app.config.ts` 到你的项目根目录,并根据需要修改配置。
130
+
131
+ ### 4. 运行示例
132
+
133
+ ```bash
134
+ cd /path/to/ai-frist-framework/scaffold/packages/api
135
+ pnpm dev
136
+ ```
137
+
138
+ ## 策略对比
139
+
140
+ | 策略 | 适用场景 | 优点 | 缺点 |
141
+ |------|----------|------|------|
142
+ | **JWT** | RESTful API、微服务 | 无状态、可扩展、跨域友好 | Token 无法主动撤销 |
143
+ | **Local** | 传统表单登录 | 简单直接、易于理解 | 需要配合其他策略使用 |
144
+ | **OAuth2** | 第三方登录 | 用户体验好、安全性高 | 实现复杂、依赖第三方 |
145
+ | **Session** | 传统 Web 应用 | 服务端控制、可主动撤销 | 有状态、扩展性差 |
146
+
147
+ ## 安全最佳实践
148
+
149
+ ### 生产环境配置
150
+
151
+ ⚠️ **重要**:生产环境必须使用环境变量配置密钥!
152
+
153
+ ```typescript
154
+ export default {
155
+ security: {
156
+ jwt: {
157
+ secret: process.env.JWT_SECRET, // 必须设置!
158
+ expiresIn: '1h', // 生产环境建议 1 小时
159
+ },
160
+ session: {
161
+ secret: process.env.SESSION_SECRET, // 必须设置!
162
+ maxAge: 3600000, // 1 小时
163
+ },
164
+ },
165
+ } satisfies AppConfig;
166
+ ```
167
+
168
+ ### 密码安全
169
+
170
+ - 使用 bcrypt 加密密码(cost factor >= 10)
171
+ - 强制最小密码长度(>= 8 字符)
172
+ - 考虑密码复杂度要求
173
+ - 实现密码泄露检测
174
+
175
+ ### Token 安全
176
+
177
+ - 使用短的过期时间(15-60 分钟)
178
+ - 实现 refresh token 轮换
179
+ - 安全存储 token(Web 使用 httpOnly cookies)
180
+ - 实现登出时的 token 撤销
181
+
182
+ ### 速率限制
183
+
184
+ 保护认证端点免受暴力破解攻击:
185
+
186
+ ```typescript
187
+ import rateLimit from 'express-rate-limit';
188
+
189
+ const loginLimiter = rateLimit({
190
+ windowMs: 15 * 60 * 1000, // 15 分钟
191
+ max: 5, // 5 次尝试
192
+ message: { error: '登录尝试次数过多,请稍后再试' },
193
+ });
194
+ ```
195
+
196
+ ## 装饰器参考
197
+
198
+ ### 认证装饰器
199
+
200
+ - `@Public()` - 标记端点为公开访问
201
+ - `@Authenticated()` - 要求认证
202
+ - `@RolesAllowed(...roles)` - 要求特定角色
203
+
204
+ ### 授权装饰器
205
+
206
+ - `@PreAuthorize(expression)` - 预授权检查
207
+ - `@PostAuthorize(expression)` - 后授权检查
208
+ - `@Secured(...permissions)` - 要求特定权限
209
+
210
+ ### 权限表达式
211
+
212
+ - `hasRole('ROLE_NAME')` - 检查用户是否有角色
213
+ - `hasPermission('permission:name')` - 检查用户是否有权限
214
+ - `hasAnyRole('ROLE1', 'ROLE2')` - 检查用户是否有任一角色
215
+ - `hasAllRoles('ROLE1', 'ROLE2')` - 检查用户是否有所有角色
216
+ - `authenticated()` - 检查用户是否已认证
217
+
218
+ ## 示例代码
219
+
220
+ ### 基本控制器
221
+
222
+ ```typescript
223
+ import { RestController, GetMapping, PostMapping } from '@ai-partner-x/aiko-boot-starter-web';
224
+ import { Public, PreAuthorize, RolesAllowed } from '@ai-partner-x/aiko-boot-starter-security';
225
+
226
+ @RestController({ path: '/api/users' })
227
+ export class UserController {
228
+ @GetMapping()
229
+ @PreAuthorize("hasRole('ADMIN')")
230
+ async list(): Promise<User[]> {
231
+ return this.userService.getAllUsers();
232
+ }
233
+
234
+ @GetMapping('/public')
235
+ @Public()
236
+ async publicInfo(): Promise<any> {
237
+ return { message: '公开 API' };
238
+ }
239
+
240
+ @PostMapping('/admin-only')
241
+ @RolesAllowed('ADMIN')
242
+ async adminAction(): Promise<any> {
243
+ return { message: '仅管理员可访问' };
244
+ }
245
+ }
246
+ ```
247
+
248
+ ## 更多信息
249
+
250
+ - [Aiko Boot 官方文档](../../../../../docs/)
251
+ - [项目分析报告](../../../../../项目分析报告.md)
252
+ - [Security Starter README](../../../../../packages/aiko-boot-starter-security/README.md)
253
+
254
+ ## 许可证
255
+
256
+ MIT
257
+
258
+ ---
259
+
260
+ ## Complete 完整配置和集成示例
261
+
262
+ `complete/` 目录提供了一个完整的、生产就绪的 Aiko Boot Security 集成示例,展示了如何将所有认证和授权策略整合到一个应用中。
263
+
264
+ ### 特性
265
+
266
+ - ✅ **多策略认证**:同时支持 JWT、Local、OAuth2(GitHub、Google)、Session
267
+ - ✅ **完整的 RBAC**:基于角色的访问控制
268
+ - ✅ **细粒度权限**:基于资源和操作的权限管理
269
+ - ✅ **用户管理**:完整的 CRUD 操作和角色分配
270
+ - ✅ **角色管理**:完整的 CRUD 操作和权限分配
271
+ - ✅ **权限管理**:完整的 CRUD 操作
272
+ - ✅ **OAuth 集成**:GitHub 和 Google 第三方登录
273
+ - ✅ **密码管理**:密码修改和加密
274
+ - ✅ **测试套件**:83 个测试用例,100% 通过率
275
+ - ✅ **完整的文档**:项目结构、API 文档、测试报告
276
+
277
+ ### 快速开始
278
+
279
+ #### 1. 安装依赖
280
+
281
+ ```bash
282
+ cd complete
283
+ pnpm install
284
+ ```
285
+
286
+ #### 2. 配置环境变量
287
+
288
+ ```bash
289
+ cp .env.example .env
290
+ # 编辑 .env 文件,填入实际的配置
291
+ ```
292
+
293
+ #### 3. 初始化数据库
294
+
295
+ ```bash
296
+ # 创建数据库表
297
+ sqlite3 data/app.db < init.sql
298
+
299
+ # 插入种子数据(管理员和测试用户)
300
+ sqlite3 data/app.db < seed.sql
301
+ ```
302
+
303
+ #### 4. 启动应用
304
+
305
+ ```bash
306
+ # 开发模式
307
+ pnpm dev
308
+
309
+ # 生产模式
310
+ pnpm start
311
+ ```
312
+
313
+ ### 默认账户
314
+
315
+ #### 管理员账户
316
+ - 用户名:`admin`
317
+ - 密码:`Admin123!`
318
+ - 角色:ADMIN
319
+ - 权限:所有权限
320
+
321
+ #### 普通用户账户
322
+ - 用户名:`user`
323
+ - 密码:`User123!`
324
+ - 角色:USER
325
+ - 权限:查看权限
326
+
327
+ ### API 端点
328
+
329
+ #### 认证端点
330
+ - `POST /api/auth/login` - 用户登录
331
+ - `POST /api/auth/register` - 用户注册
332
+ - `POST /api/auth/refresh` - 刷新 Token
333
+ - `POST /api/auth/logout` - 用户登出
334
+ - `POST /api/auth/change-password` - 修改密码
335
+ - `GET /api/auth/github` - GitHub OAuth 授权
336
+ - `GET /api/auth/github/callback` - GitHub OAuth 回调
337
+ - `GET /api/auth/google` - Google OAuth 授权
338
+ - `GET /api/auth/google/callback` - Google OAuth 回调
339
+
340
+ #### 用户端点
341
+ - `GET /api/users` - 获取用户列表(需要 ADMIN 角色)
342
+ - `GET /api/users/:id` - 获取用户详情
343
+ - `POST /api/users` - 创建用户(需要 ADMIN 角色)
344
+ - `PUT /api/users/:id` - 更新用户
345
+ - `DELETE /api/users/:id` - 删除用户(需要 ADMIN 角色)
346
+ - `POST /api/users/:id/roles` - 为用户分配角色(需要 ADMIN 角色)
347
+ - `DELETE /api/users/:id/roles/:roleId` - 移除用户角色(需要 ADMIN 角色)
348
+
349
+ #### 角色端点
350
+ - `GET /api/roles` - 获取角色列表(需要 ADMIN 角色)
351
+ - `GET /api/roles/:id` - 获取角色详情(需要 ADMIN 角色)
352
+ - `POST /api/roles` - 创建角色(需要 ADMIN 角色)
353
+ - `PUT /api/roles/:id` - 更新角色(需要 ADMIN 角色)
354
+ - `DELETE /api/roles/:id` - 删除角色(需要 ADMIN 角色)
355
+ - `POST /api/roles/:id/permissions` - 为角色分配权限(需要 ADMIN 角色)
356
+ - `DELETE /api/roles/:id/permissions/:permissionId` - 移除角色权限(需要 ADMIN 角色)
357
+
358
+ #### 权限端点
359
+ - `GET /api/permissions` - 获取权限列表(需要 ADMIN 角色)
360
+ - `GET /api/permissions/:id` - 获取权限详情(需要 ADMIN 角色)
361
+ - `POST /api/permissions` - 创建权限(需要 ADMIN 角色)
362
+ - `PUT /api/permissions/:id` - 更新权限(需要 ADMIN 角色)
363
+ - `DELETE /api/permissions/:id` - 删除权限(需要 ADMIN 角色)
364
+
365
+ ### 测试
366
+
367
+ #### 运行所有测试
368
+
369
+ ```bash
370
+ pnpm test:all
371
+ ```
372
+
373
+ 这将运行:
374
+ - 单元测试(38 个测试)
375
+ - 集成测试(45 个测试)
376
+ - 生成覆盖率报告
377
+ - 生成 HTML 测试报告
378
+
379
+ #### 运行特定测试
380
+
381
+ ```bash
382
+ # 只运行单元测试
383
+ pnpm test:unit
384
+
385
+ # 只运行集成测试
386
+ pnpm test:integration
387
+
388
+ # 生成覆盖率报告
389
+ pnpm test:coverage
390
+
391
+ # 生成测试报告
392
+ pnpm test:report
393
+ ```
394
+
395
+ #### 查看测试报告
396
+
397
+ 测试报告将生成在 `test-results/` 目录:
398
+ - `test-report.json` - JSON 格式报告
399
+ - `test-report.html` - HTML 格式报告
400
+ - `TEST_REPORT.md` - 详细测试报告
401
+
402
+ ### 项目结构
403
+
404
+ 完整的项目结构说明请参考 [PROJECT_STRUCTURE.md](complete/PROJECT_STRUCTURE.md)
405
+
406
+ ### 架构设计
407
+
408
+ #### 分层架构
409
+
410
+ ```
411
+ ┌─────────────────────────────────────────────┐
412
+ │ Controller Layer │
413
+ │ (处理 HTTP 请求和响应) │
414
+ └─────────────────┬───────────────────────┘
415
+
416
+
417
+ ┌─────────────────────────────────────────────┐
418
+ │ Service Layer │
419
+ │ (业务逻辑处理) │
420
+ └─────────────────┬───────────────────────┘
421
+
422
+
423
+ ┌─────────────────────────────────────────────┐
424
+ │ Mapper Layer │
425
+ │ (数据库操作) │
426
+ └─────────────────┬───────────────────────┘
427
+
428
+
429
+ ┌─────────────────────────────────────────────┐
430
+ │ Database │
431
+ │ (SQLite) │
432
+ └─────────────────────────────────────────────┘
433
+ ```
434
+
435
+ #### 安全层
436
+
437
+ ```
438
+ ┌─────────────────────────────────────────────┐
439
+ │ Middleware │
440
+ │ (认证和授权拦截) │
441
+ └─────────────────┬───────────────────────┘
442
+
443
+
444
+ ┌─────────────────────────────────────────────┐
445
+ │ Security Context │
446
+ │ (当前用户上下文) │
447
+ └─────────────────────────────────────────────┘
448
+ ```
449
+
450
+ ### 数据库设计
451
+
452
+ #### 用户表 (users)
453
+ - id - 主键
454
+ - username - 用户名(唯一)
455
+ - email - 邮箱(唯一)
456
+ - password - 加密密码
457
+ - enabled - 是否启用
458
+ - provider - 认证提供者(local/github/google)
459
+ - providerId - 第三方用户 ID
460
+ - avatar - 头像 URL
461
+ - createdAt - 创建时间
462
+ - updatedAt - 更新时间
463
+
464
+ #### 角色表 (roles)
465
+ - id - 主键
466
+ - name - 角色名称(唯一)
467
+ - description - 角色描述
468
+ - createdAt - 创建时间
469
+ - updatedAt - 更新时间
470
+
471
+ #### 权限表 (permissions)
472
+ - id - 主键
473
+ - name - 权限名称(唯一)
474
+ - description - 权限描述
475
+ - resource - 资源名称
476
+ - action - 操作名称
477
+ - createdAt - 创建时间
478
+ - updatedAt - 更新时间
479
+
480
+ #### 用户角色关联表 (user_roles)
481
+ - id - 主键
482
+ - userId - 用户 ID(外键)
483
+ - roleId - 角色 ID(外键)
484
+ - createdAt - 创建时间
485
+
486
+ #### 角色权限关联表 (role_permissions)
487
+ - id - 主键
488
+ - roleId - 角色 ID(外键)
489
+ - permissionId - 权限 ID(外键)
490
+ - createdAt - 创建时间
491
+
492
+ #### OAuth 账户表 (oauth_accounts)
493
+ - id - 主键
494
+ - userId - 用户 ID(外键)
495
+ - provider - 提供者(github/google)
496
+ - providerId - 第三方用户 ID
497
+ - accessToken - 访问令牌
498
+ - refreshToken - 刷新令牌
499
+ - expiresAt - 过期时间
500
+ - createdAt - 创建时间
501
+ - updatedAt - 更新时间
502
+
503
+ ### 安全配置
504
+
505
+ #### JWT 配置
506
+ - secret: JWT 密钥(必须设置环境变量)
507
+ - expiresIn: Token 过期时间(默认 1 小时)
508
+
509
+ #### Session 配置
510
+ - secret: Session 密钥(必须设置环境变量)
511
+ - maxAge: Session 最大存活时间(默认 24 小时)
512
+ - resave: 是否每次请求都重新保存
513
+ - saveUninitialized: 是否保存未初始化的 session
514
+ - cookie: Cookie 配置
515
+ - secure: 是否仅 HTTPS
516
+ - httpOnly: 是否禁止 JavaScript 访问
517
+ - sameSite: CSRF 保护级别
518
+ - maxAge: Cookie 过期时间
519
+
520
+ #### OAuth2 配置
521
+ - github: GitHub OAuth 配置
522
+ - clientID: 客户端 ID
523
+ - clientSecret: 客户端密钥
524
+ - callbackURL: 回调 URL
525
+ - google: Google OAuth 配置
526
+ - clientID: 客户端 ID
527
+ - clientSecret: 客户端密钥
528
+ - callbackURL: 回调 URL
529
+
530
+ #### 公开路径
531
+ 以下路径不需要认证:
532
+ - `/api/auth/login`
533
+ - `/api/auth/register`
534
+ - `/api/auth/github`
535
+ - `/api/auth/google`
536
+ - `/api/auth/github/callback`
537
+ - `/api/auth/google/callback`
538
+ - `/api/public`
539
+
540
+ ### 部署
541
+
542
+ #### Docker 部署
543
+
544
+ ```dockerfile
545
+ FROM node:18-alpine
546
+
547
+ WORKDIR /app
548
+
549
+ COPY package*.json ./
550
+ RUN npm ci --only=production
551
+
552
+ COPY . .
553
+ RUN npm run build
554
+
555
+ EXPOSE 3001
556
+
557
+ CMD ["npm", "start"]
558
+ ```
559
+
560
+ ```yaml
561
+ version: '3.8'
562
+
563
+ services:
564
+ app:
565
+ build: .
566
+ ports:
567
+ - "3001:3001"
568
+ environment:
569
+ - NODE_ENV=production
570
+ - JWT_SECRET=${JWT_SECRET}
571
+ - SESSION_SECRET=${SESSION_SECRET}
572
+ - GITHUB_CLIENT_ID=${GITHUB_CLIENT_ID}
573
+ - GITHUB_CLIENT_SECRET=${GITHUB_CLIENT_SECRET}
574
+ - GOOGLE_CLIENT_ID=${GOOGLE_CLIENT_ID}
575
+ - GOOGLE_CLIENT_SECRET=${GOOGLE_CLIENT_SECRET}
576
+ volumes:
577
+ - ./data:/app/data
578
+ ```
579
+
580
+ #### Nginx 反向代理
581
+
582
+ ```nginx
583
+ server {
584
+ listen 80;
585
+ server_name your-domain.com;
586
+
587
+ location /api {
588
+ proxy_pass http://localhost:3001;
589
+ proxy_http_version 1.1;
590
+ proxy_set_header Upgrade $http_upgrade;
591
+ proxy_set_header Connection 'upgrade';
592
+ proxy_set_header Host $host;
593
+ proxy_cache_bypass $http_upgrade;
594
+ }
595
+
596
+ location /static {
597
+ alias /app/public;
598
+ expires 30d;
599
+ add_header Cache-Control "public, immutable";
600
+ }
601
+ }
602
+ ```
603
+
604
+ ### 监控和日志
605
+
606
+ #### 日志级别
607
+ - `debug` - 开发环境
608
+ - `info` - 生产环境
609
+ - `warn` - 警告信息
610
+ - `error` - 错误信息
611
+
612
+ #### 关键指标
613
+ - 请求响应时间
614
+ - 认证成功率
615
+ - 授权失败率
616
+ - API 错误率
617
+ - 数据库查询性能
618
+
619
+ ### 故障排查
620
+
621
+ #### 常见问题
622
+
623
+ 1. **数据库连接失败**
624
+ - 检查数据库文件路径
625
+ - 检查文件权限
626
+ - 确保数据库文件存在
627
+
628
+ 2. **Token 验证失败**
629
+ - 检查 JWT_SECRET 配置
630
+ - 检查 Token 是否过期
631
+ - 检查 Token 格式
632
+
633
+ 3. **OAuth 回调失败**
634
+ - 检查回调 URL 配置
635
+ - 检查 OAuth 应用设置
636
+ - 检查网络连接
637
+
638
+ 4. **权限不足错误**
639
+ - 检查用户角色配置
640
+ - 检查权限分配
641
+ - 检查装饰器使用
642
+
643
+ ### 扩展功能
644
+
645
+ #### 添加新的认证策略
646
+ 1. 创建新的策略类
647
+ 2. 实现必要的认证方法
648
+ 3. 在 `app.config.ts` 中配置新策略
649
+ 4. 更新中间件以支持新策略
650
+
651
+ #### 添加新的权限装饰器
652
+ 1. 创建新的装饰器函数
653
+ 2. 在 `PermissionInterceptor` 中添加处理逻辑
654
+ 3. 更新权限表达式解析器
655
+
656
+ #### 集成其他数据库
657
+ 修改 `app.config.ts` 中的数据库配置,支持 MySQL、PostgreSQL 等。
658
+
659
+ ### 更多文档
660
+
661
+ - [项目结构说明](complete/PROJECT_STRUCTURE.md)
662
+ - [测试报告](complete/tests/TEST_REPORT.md)
663
+ - [Aiko Boot 官方文档](../../../../../docs/)
664
+ - [Security Starter README](../../../../../packages/aiko-boot-starter-security/README.md)
@@ -0,0 +1,26 @@
1
+ # 应用配置
2
+ PORT=3001
3
+ NODE_ENV=development
4
+
5
+ # JWT 配置
6
+ JWT_SECRET=your-super-secret-jwt-key-change-this-in-production
7
+
8
+ # Session 配置
9
+ SESSION_SECRET=your-super-secret-session-key-change-this-in-production
10
+
11
+ # 数据库配置
12
+ DATABASE_TYPE=sqlite
13
+ DATABASE_FILE=./data/app.db
14
+
15
+ # CORS 配置
16
+ CORS_ORIGIN=http://localhost:3000
17
+
18
+ # GitHub OAuth 配置
19
+ GITHUB_CLIENT_ID=your-github-client-id
20
+ GITHUB_CLIENT_SECRET=your-github-client-secret
21
+ GITHUB_CALLBACK_URL=http://localhost:3001/api/auth/github/callback
22
+
23
+ # Google OAuth 配置
24
+ GOOGLE_CLIENT_ID=your-google-client-id
25
+ GOOGLE_CLIENT_SECRET=your-google-client-secret
26
+ GOOGLE_CALLBACK_URL=http://localhost:3001/api/auth/google/callback