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

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 (389) hide show
  1. package/README.md +187 -0
  2. package/dist/cli.d.ts +2 -0
  3. package/dist/cli.js +30 -0
  4. package/dist/commands/add-api.d.ts +5 -0
  5. package/dist/commands/add-api.js +34 -0
  6. package/dist/commands/add-app.d.ts +5 -0
  7. package/dist/commands/add-app.js +34 -0
  8. package/dist/commands/add-feature.d.ts +5 -0
  9. package/dist/commands/add-feature.js +32 -0
  10. package/dist/commands/init.d.ts +7 -0
  11. package/dist/commands/init.js +42 -0
  12. package/dist/commands/list.d.ts +6 -0
  13. package/dist/commands/list.js +36 -0
  14. package/dist/core/framework-version.d.ts +8 -0
  15. package/dist/core/framework-version.js +40 -0
  16. package/dist/core/logger.d.ts +6 -0
  17. package/dist/core/logger.js +16 -0
  18. package/dist/core/project-config.d.ts +21 -0
  19. package/dist/core/project-config.js +17 -0
  20. package/dist/core/prompts.d.ts +5 -0
  21. package/dist/core/prompts.js +43 -0
  22. package/dist/core/template-utils.d.ts +1 -0
  23. package/dist/core/template-utils.js +42 -0
  24. package/dist/core/workspace.d.ts +10 -0
  25. package/dist/core/workspace.js +141 -0
  26. package/dist/index.d.ts +2 -0
  27. package/dist/index.js +2 -0
  28. package/dist/scaffold.d.ts +7 -0
  29. package/dist/scaffold.js +272 -0
  30. package/dist/usecases/add-api.usecase.d.ts +16 -0
  31. package/dist/usecases/add-api.usecase.js +87 -0
  32. package/dist/usecases/add-app.usecase.d.ts +16 -0
  33. package/dist/usecases/add-app.usecase.js +101 -0
  34. package/dist/usecases/add-feature.usecase.d.ts +15 -0
  35. package/dist/usecases/add-feature.usecase.js +566 -0
  36. package/dist/usecases/init-scaffold.usecase.d.ts +19 -0
  37. package/dist/usecases/init-scaffold.usecase.js +131 -0
  38. package/package.json +43 -0
  39. package/templates/api-base/app.config.ts +155 -0
  40. package/templates/api-base/package.json +55 -0
  41. package/templates/api-base/scripts/codegen.cjs +30 -0
  42. package/templates/api-base/scripts/codegen.ts +10 -0
  43. package/templates/api-base/src/controller/auth.controller.ts +160 -0
  44. package/templates/api-base/src/controller/menu.controller.ts +56 -0
  45. package/templates/api-base/src/controller/role.controller.ts +62 -0
  46. package/templates/api-base/src/controller/user.controller.ts +75 -0
  47. package/templates/api-base/src/dto/auth.dto.ts +31 -0
  48. package/templates/api-base/src/dto/menu.dto.ts +38 -0
  49. package/templates/api-base/src/dto/role.dto.ts +18 -0
  50. package/templates/api-base/src/dto/user.dto.ts +36 -0
  51. package/templates/api-base/src/entity/menu.entity.ts +35 -0
  52. package/templates/api-base/src/entity/role-menu.entity.ts +14 -0
  53. package/templates/api-base/src/entity/role.entity.ts +23 -0
  54. package/templates/api-base/src/entity/user-role.entity.ts +14 -0
  55. package/templates/api-base/src/entity/user.entity.ts +32 -0
  56. package/templates/api-base/src/mapper/menu.mapper.ts +7 -0
  57. package/templates/api-base/src/mapper/role-menu.mapper.ts +7 -0
  58. package/templates/api-base/src/mapper/role.mapper.ts +7 -0
  59. package/templates/api-base/src/mapper/user-role.mapper.ts +7 -0
  60. package/templates/api-base/src/mapper/user.mapper.ts +12 -0
  61. package/templates/api-base/src/scripts/init-db.ts +204 -0
  62. package/templates/api-base/src/server.ts +69 -0
  63. package/templates/api-base/src/service/auth.service.ts +144 -0
  64. package/templates/api-base/src/service/log.request.service.ts +72 -0
  65. package/templates/api-base/src/service/menu.service.ts +94 -0
  66. package/templates/api-base/src/service/role.service.ts +88 -0
  67. package/templates/api-base/src/service/user.service.ts +175 -0
  68. package/templates/api-base/src/utils/jwt.util.ts +39 -0
  69. package/templates/api-base/tsconfig.json +18 -0
  70. package/templates/feature-file/api/upload.controller.ts +97 -0
  71. package/templates/feature-log/api/docs/log-integration-guide.md +54 -0
  72. package/templates/feature-log/api/src/service/log.request.service.ts +112 -0
  73. package/templates/feature-log/api/src/service/log.service.ts +124 -0
  74. package/templates/feature-mq/api/src/controller/mq.controller.ts +35 -0
  75. package/templates/feature-mq/api/src/dto/mq.dto.ts +16 -0
  76. package/templates/feature-mq/api/src/service/mq.consumer.service.ts +26 -0
  77. package/templates/feature-redis/api/src/controller/cache.controller.ts +107 -0
  78. package/templates/feature-redis/api/src/dto/cache.dto.ts +24 -0
  79. package/templates/feature-redis/api/src/service/cache.service.ts +80 -0
  80. package/templates/scaffold-default/README.md +114 -0
  81. package/templates/scaffold-default/package.json +26 -0
  82. package/templates/scaffold-default/packages/admin/.env.dev +1 -0
  83. package/templates/scaffold-default/packages/admin/.env.prod +4 -0
  84. package/templates/scaffold-default/packages/admin/.env.stage +4 -0
  85. package/templates/scaffold-default/packages/admin/Dockerfile +37 -0
  86. package/templates/scaffold-default/packages/admin/README.MD +27 -0
  87. package/templates/scaffold-default/packages/admin/components.json +21 -0
  88. package/templates/scaffold-default/packages/admin/eslint.config.js +28 -0
  89. package/templates/scaffold-default/packages/admin/index.html +50 -0
  90. package/templates/scaffold-default/packages/admin/package.json +100 -0
  91. package/templates/scaffold-default/packages/admin/public/vite.svg +1 -0
  92. package/templates/scaffold-default/packages/admin/src/App.css +82 -0
  93. package/templates/scaffold-default/packages/admin/src/App.tsx +128 -0
  94. package/templates/scaffold-default/packages/admin/src/app.config.ts +3 -0
  95. package/templates/scaffold-default/packages/admin/src/components/admin-ui/data-table/data-table-pagination.tsx +148 -0
  96. package/templates/scaffold-default/packages/admin/src/components/admin-ui/data-table/data-table-sorter.tsx +50 -0
  97. package/templates/scaffold-default/packages/admin/src/components/admin-ui/data-table/index.tsx +266 -0
  98. package/templates/scaffold-default/packages/admin/src/components/admin-ui/editable-table.tsx +292 -0
  99. package/templates/scaffold-default/packages/admin/src/components/admin-ui/form/input-password.tsx +38 -0
  100. package/templates/scaffold-default/packages/admin/src/components/admin-ui/form/sign-in-form.tsx +118 -0
  101. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/error-component.tsx +71 -0
  102. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/header.tsx +162 -0
  103. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/language-switcher.tsx +47 -0
  104. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/layout.tsx +42 -0
  105. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/loading-overlay.tsx +36 -0
  106. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/shell-bar.tsx +232 -0
  107. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/sidebar.tsx +193 -0
  108. package/templates/scaffold-default/packages/admin/src/components/admin-ui/layout/user-avatar.tsx +31 -0
  109. package/templates/scaffold-default/packages/admin/src/components/admin-ui/list-report.tsx +306 -0
  110. package/templates/scaffold-default/packages/admin/src/components/admin-ui/master-detail.tsx +382 -0
  111. package/templates/scaffold-default/packages/admin/src/components/admin-ui/notification/toaster.tsx +23 -0
  112. package/templates/scaffold-default/packages/admin/src/components/admin-ui/notification/undoable-notification.tsx +84 -0
  113. package/templates/scaffold-default/packages/admin/src/components/admin-ui/object-page.tsx +539 -0
  114. package/templates/scaffold-default/packages/admin/src/components/admin-ui/theme/theme-provider.tsx +160 -0
  115. package/templates/scaffold-default/packages/admin/src/components/admin-ui/theme/theme-select.tsx +129 -0
  116. package/templates/scaffold-default/packages/admin/src/components/admin-ui/theme/theme-toggle.tsx +90 -0
  117. package/templates/scaffold-default/packages/admin/src/components/ui/accordion.tsx +64 -0
  118. package/templates/scaffold-default/packages/admin/src/components/ui/alert-dialog.tsx +157 -0
  119. package/templates/scaffold-default/packages/admin/src/components/ui/alert.tsx +66 -0
  120. package/templates/scaffold-default/packages/admin/src/components/ui/aspect-ratio.tsx +9 -0
  121. package/templates/scaffold-default/packages/admin/src/components/ui/avatar.tsx +53 -0
  122. package/templates/scaffold-default/packages/admin/src/components/ui/badge.tsx +47 -0
  123. package/templates/scaffold-default/packages/admin/src/components/ui/breadcrumb.tsx +111 -0
  124. package/templates/scaffold-default/packages/admin/src/components/ui/button.tsx +59 -0
  125. package/templates/scaffold-default/packages/admin/src/components/ui/calendar.tsx +74 -0
  126. package/templates/scaffold-default/packages/admin/src/components/ui/card.tsx +92 -0
  127. package/templates/scaffold-default/packages/admin/src/components/ui/carousel.tsx +237 -0
  128. package/templates/scaffold-default/packages/admin/src/components/ui/chart.tsx +351 -0
  129. package/templates/scaffold-default/packages/admin/src/components/ui/checkbox.tsx +32 -0
  130. package/templates/scaffold-default/packages/admin/src/components/ui/collapsible.tsx +33 -0
  131. package/templates/scaffold-default/packages/admin/src/components/ui/command.tsx +182 -0
  132. package/templates/scaffold-default/packages/admin/src/components/ui/context-menu.tsx +252 -0
  133. package/templates/scaffold-default/packages/admin/src/components/ui/dialog.tsx +141 -0
  134. package/templates/scaffold-default/packages/admin/src/components/ui/drawer.tsx +130 -0
  135. package/templates/scaffold-default/packages/admin/src/components/ui/dropdown-menu.tsx +255 -0
  136. package/templates/scaffold-default/packages/admin/src/components/ui/form.tsx +166 -0
  137. package/templates/scaffold-default/packages/admin/src/components/ui/hover-card.tsx +42 -0
  138. package/templates/scaffold-default/packages/admin/src/components/ui/input-otp.tsx +77 -0
  139. package/templates/scaffold-default/packages/admin/src/components/ui/input.tsx +21 -0
  140. package/templates/scaffold-default/packages/admin/src/components/ui/label.tsx +22 -0
  141. package/templates/scaffold-default/packages/admin/src/components/ui/menubar.tsx +274 -0
  142. package/templates/scaffold-default/packages/admin/src/components/ui/navigation-menu.tsx +168 -0
  143. package/templates/scaffold-default/packages/admin/src/components/ui/pagination.tsx +127 -0
  144. package/templates/scaffold-default/packages/admin/src/components/ui/popover.tsx +48 -0
  145. package/templates/scaffold-default/packages/admin/src/components/ui/progress.tsx +29 -0
  146. package/templates/scaffold-default/packages/admin/src/components/ui/radio-group.tsx +45 -0
  147. package/templates/scaffold-default/packages/admin/src/components/ui/resizable.tsx +54 -0
  148. package/templates/scaffold-default/packages/admin/src/components/ui/scroll-area.tsx +58 -0
  149. package/templates/scaffold-default/packages/admin/src/components/ui/select.tsx +183 -0
  150. package/templates/scaffold-default/packages/admin/src/components/ui/separator.tsx +26 -0
  151. package/templates/scaffold-default/packages/admin/src/components/ui/sheet.tsx +139 -0
  152. package/templates/scaffold-default/packages/admin/src/components/ui/sidebar.tsx +740 -0
  153. package/templates/scaffold-default/packages/admin/src/components/ui/skeleton.tsx +13 -0
  154. package/templates/scaffold-default/packages/admin/src/components/ui/slider.tsx +63 -0
  155. package/templates/scaffold-default/packages/admin/src/components/ui/sonner.tsx +23 -0
  156. package/templates/scaffold-default/packages/admin/src/components/ui/switch.tsx +31 -0
  157. package/templates/scaffold-default/packages/admin/src/components/ui/table.tsx +114 -0
  158. package/templates/scaffold-default/packages/admin/src/components/ui/tabs.tsx +66 -0
  159. package/templates/scaffold-default/packages/admin/src/components/ui/textarea.tsx +18 -0
  160. package/templates/scaffold-default/packages/admin/src/components/ui/toggle-group.tsx +73 -0
  161. package/templates/scaffold-default/packages/admin/src/components/ui/toggle.tsx +45 -0
  162. package/templates/scaffold-default/packages/admin/src/components/ui/tooltip.tsx +59 -0
  163. package/templates/scaffold-default/packages/admin/src/hooks/use-mobile.ts +21 -0
  164. package/templates/scaffold-default/packages/admin/src/i18n.ts +20 -0
  165. package/templates/scaffold-default/packages/admin/src/index.tsx +19 -0
  166. package/templates/scaffold-default/packages/admin/src/layouts/menu-layout.tsx +211 -0
  167. package/templates/scaffold-default/packages/admin/src/layouts/tile-layout.tsx +355 -0
  168. package/templates/scaffold-default/packages/admin/src/lib/utils.ts +6 -0
  169. package/templates/scaffold-default/packages/admin/src/locales/en.json +68 -0
  170. package/templates/scaffold-default/packages/admin/src/locales/zh.json +68 -0
  171. package/templates/scaffold-default/packages/admin/src/pages/dashboard.tsx +12 -0
  172. package/templates/scaffold-default/packages/admin/src/pages/goods-receipt/CreatePage.tsx +302 -0
  173. package/templates/scaffold-default/packages/admin/src/pages/goods-receipt/EditPage.tsx +221 -0
  174. package/templates/scaffold-default/packages/admin/src/pages/goods-receipt/ListPage.tsx +283 -0
  175. package/templates/scaffold-default/packages/admin/src/pages/goods-receipt/ViewPage.tsx +280 -0
  176. package/templates/scaffold-default/packages/admin/src/pages/goods-receipt/index.ts +4 -0
  177. package/templates/scaffold-default/packages/admin/src/pages/home-page.tsx +244 -0
  178. package/templates/scaffold-default/packages/admin/src/pages/master-data/cost-centers/index.tsx +461 -0
  179. package/templates/scaffold-default/packages/admin/src/pages/master-data/currencies/index.tsx +255 -0
  180. package/templates/scaffold-default/packages/admin/src/pages/master-data/materials/ListPage.tsx +271 -0
  181. package/templates/scaffold-default/packages/admin/src/pages/master-data/materials/ViewPage.tsx +240 -0
  182. package/templates/scaffold-default/packages/admin/src/pages/master-data/materials/index.ts +2 -0
  183. package/templates/scaffold-default/packages/admin/src/pages/master-data/plants/ListPage.tsx +279 -0
  184. package/templates/scaffold-default/packages/admin/src/pages/master-data/plants/ViewPage.tsx +380 -0
  185. package/templates/scaffold-default/packages/admin/src/pages/master-data/plants/index.ts +2 -0
  186. package/templates/scaffold-default/packages/admin/src/pages/master-data/purchase-organizations/index.tsx +341 -0
  187. package/templates/scaffold-default/packages/admin/src/pages/master-data/units-of-measure/index.tsx +295 -0
  188. package/templates/scaffold-default/packages/admin/src/pages/master-data/vendors/ListPage.tsx +266 -0
  189. package/templates/scaffold-default/packages/admin/src/pages/master-data/vendors/ViewPage.tsx +274 -0
  190. package/templates/scaffold-default/packages/admin/src/pages/master-data/vendors/index.ts +2 -0
  191. package/templates/scaffold-default/packages/admin/src/pages/placeholder-page.tsx +13 -0
  192. package/templates/scaffold-default/packages/admin/src/pages/purchase-orders/ListPage.tsx +289 -0
  193. package/templates/scaffold-default/packages/admin/src/pages/purchase-orders/ViewPage.tsx +343 -0
  194. package/templates/scaffold-default/packages/admin/src/pages/purchase-orders/index.ts +2 -0
  195. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/CreatePage.tsx +398 -0
  196. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/EditPage.tsx +473 -0
  197. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/ListPage.tsx +307 -0
  198. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/ViewPage.tsx +304 -0
  199. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/constants.ts +51 -0
  200. package/templates/scaffold-default/packages/admin/src/pages/purchase-requisitions/index.ts +4 -0
  201. package/templates/scaffold-default/packages/admin/src/pages/reports/PurchaseOrderReport.tsx +312 -0
  202. package/templates/scaffold-default/packages/admin/src/pages/reports/PurchaseRequisitionReport.tsx +303 -0
  203. package/templates/scaffold-default/packages/admin/src/pages/reports/index.ts +2 -0
  204. package/templates/scaffold-default/packages/admin/src/pages/settings-page.tsx +335 -0
  205. package/templates/scaffold-default/packages/admin/src/providers/app-config.tsx +50 -0
  206. package/templates/scaffold-default/packages/admin/src/providers/auth-provider.ts +2 -0
  207. package/templates/scaffold-default/packages/admin/src/routes/auth.ts +9 -0
  208. package/templates/scaffold-default/packages/admin/src/routes/index.ts +85 -0
  209. package/templates/scaffold-default/packages/admin/src/routes/menu.ts +176 -0
  210. package/templates/scaffold-default/packages/admin/src/routes/modules/goods-receipt.ts +31 -0
  211. package/templates/scaffold-default/packages/admin/src/routes/modules/master-data.ts +41 -0
  212. package/templates/scaffold-default/packages/admin/src/routes/modules/purchase-orders.ts +27 -0
  213. package/templates/scaffold-default/packages/admin/src/routes/modules/purchase-requisitions.ts +39 -0
  214. package/templates/scaffold-default/packages/admin/src/routes/modules/reports.ts +33 -0
  215. package/templates/scaffold-default/packages/admin/src/routes/modules/settings.ts +19 -0
  216. package/templates/scaffold-default/packages/admin/src/routes/withSuspense.tsx +21 -0
  217. package/templates/scaffold-default/packages/admin/src/theme/amber.css +27 -0
  218. package/templates/scaffold-default/packages/admin/src/theme/blue.css +27 -0
  219. package/templates/scaffold-default/packages/admin/src/theme/default.css +75 -0
  220. package/templates/scaffold-default/packages/admin/src/theme/fiori.css +180 -0
  221. package/templates/scaffold-default/packages/admin/src/theme/green.css +27 -0
  222. package/templates/scaffold-default/packages/admin/src/theme/index.css +12 -0
  223. package/templates/scaffold-default/packages/admin/src/theme/rose.css +27 -0
  224. package/templates/scaffold-default/packages/admin/src/theme/violet.css +27 -0
  225. package/templates/scaffold-default/packages/admin/src/vite-env.d.ts +1 -0
  226. package/templates/scaffold-default/packages/admin/tsconfig.json +28 -0
  227. package/templates/scaffold-default/packages/admin/tsconfig.node.json +21 -0
  228. package/templates/scaffold-default/packages/admin/vite.config.ts +26 -0
  229. package/templates/scaffold-default/packages/api/.eslintrc.json +6 -0
  230. package/templates/scaffold-default/packages/api/.swcrc +17 -0
  231. package/templates/scaffold-default/packages/api/app.config.ts +163 -0
  232. package/templates/scaffold-default/packages/api/docs/api-document.md +497 -0
  233. package/templates/scaffold-default/packages/api/docs/final-completion-report.md +565 -0
  234. package/templates/scaffold-default/packages/api/docs/permission-integration-summary.md +432 -0
  235. package/templates/scaffold-default/packages/api/examples/security/README.md +664 -0
  236. package/templates/scaffold-default/packages/api/examples/security/complete/.env.example +26 -0
  237. package/templates/scaffold-default/packages/api/examples/security/complete/PROJECT_STRUCTURE.md +220 -0
  238. package/templates/scaffold-default/packages/api/examples/security/complete/README.md +847 -0
  239. package/templates/scaffold-default/packages/api/examples/security/complete/app.config.ts +69 -0
  240. package/templates/scaffold-default/packages/api/examples/security/complete/app.ts +63 -0
  241. package/templates/scaffold-default/packages/api/examples/security/complete/controller/auth.controller.ts +131 -0
  242. package/templates/scaffold-default/packages/api/examples/security/complete/controller/index.ts +4 -0
  243. package/templates/scaffold-default/packages/api/examples/security/complete/controller/permission.controller.ts +41 -0
  244. package/templates/scaffold-default/packages/api/examples/security/complete/controller/role.controller.ts +53 -0
  245. package/templates/scaffold-default/packages/api/examples/security/complete/controller/user.controller.ts +53 -0
  246. package/templates/scaffold-default/packages/api/examples/security/complete/dto/change-password.dto.ts +10 -0
  247. package/templates/scaffold-default/packages/api/examples/security/complete/dto/create-permission.dto.ts +14 -0
  248. package/templates/scaffold-default/packages/api/examples/security/complete/dto/create-role.dto.ts +11 -0
  249. package/templates/scaffold-default/packages/api/examples/security/complete/dto/create-user.dto.ts +15 -0
  250. package/templates/scaffold-default/packages/api/examples/security/complete/dto/index.ts +7 -0
  251. package/templates/scaffold-default/packages/api/examples/security/complete/dto/login.dto.ts +10 -0
  252. package/templates/scaffold-default/packages/api/examples/security/complete/dto/oauth-profile.dto.ts +7 -0
  253. package/templates/scaffold-default/packages/api/examples/security/complete/dto/register.dto.ts +17 -0
  254. package/templates/scaffold-default/packages/api/examples/security/complete/entity/index.ts +6 -0
  255. package/templates/scaffold-default/packages/api/examples/security/complete/entity/oauth-account.entity.ts +39 -0
  256. package/templates/scaffold-default/packages/api/examples/security/complete/entity/permission.entity.ts +31 -0
  257. package/templates/scaffold-default/packages/api/examples/security/complete/entity/role-permission.entity.ts +19 -0
  258. package/templates/scaffold-default/packages/api/examples/security/complete/entity/role.entity.ts +25 -0
  259. package/templates/scaffold-default/packages/api/examples/security/complete/entity/user-role.entity.ts +19 -0
  260. package/templates/scaffold-default/packages/api/examples/security/complete/entity/user.entity.ts +46 -0
  261. package/templates/scaffold-default/packages/api/examples/security/complete/init.sql +81 -0
  262. package/templates/scaffold-default/packages/api/examples/security/complete/middleware/auth.interceptor.ts +39 -0
  263. package/templates/scaffold-default/packages/api/examples/security/complete/middleware/index.ts +2 -0
  264. package/templates/scaffold-default/packages/api/examples/security/complete/middleware/permission.interceptor.ts +61 -0
  265. package/templates/scaffold-default/packages/api/examples/security/complete/package.json +54 -0
  266. package/templates/scaffold-default/packages/api/examples/security/complete/seed.sql +42 -0
  267. package/templates/scaffold-default/packages/api/examples/security/complete/service/auth.service.ts +41 -0
  268. package/templates/scaffold-default/packages/api/examples/security/complete/service/index.ts +5 -0
  269. package/templates/scaffold-default/packages/api/examples/security/complete/service/oauth.service.ts +82 -0
  270. package/templates/scaffold-default/packages/api/examples/security/complete/service/permission.service.ts +113 -0
  271. package/templates/scaffold-default/packages/api/examples/security/complete/service/role.service.ts +85 -0
  272. package/templates/scaffold-default/packages/api/examples/security/complete/service/user.service.ts +132 -0
  273. package/templates/scaffold-default/packages/api/examples/security/complete/tests/TEST_REPORT.md +318 -0
  274. package/templates/scaffold-default/packages/api/examples/security/complete/tests/generate-report.js +335 -0
  275. package/templates/scaffold-default/packages/api/examples/security/complete/tests/helpers/api-helpers.ts +116 -0
  276. package/templates/scaffold-default/packages/api/examples/security/complete/tests/helpers/index.ts +2 -0
  277. package/templates/scaffold-default/packages/api/examples/security/complete/tests/helpers/test-helpers.ts +129 -0
  278. package/templates/scaffold-default/packages/api/examples/security/complete/tests/integration/auth.api.test.ts +429 -0
  279. package/templates/scaffold-default/packages/api/examples/security/complete/tests/integration/role.api.test.ts +400 -0
  280. package/templates/scaffold-default/packages/api/examples/security/complete/tests/integration/user.api.test.ts +459 -0
  281. package/templates/scaffold-default/packages/api/examples/security/complete/tests/jest.config.js +40 -0
  282. package/templates/scaffold-default/packages/api/examples/security/complete/tests/run-all-tests.js +135 -0
  283. package/templates/scaffold-default/packages/api/examples/security/complete/tests/run-tests.js +109 -0
  284. package/templates/scaffold-default/packages/api/examples/security/complete/tests/setup.ts +19 -0
  285. package/templates/scaffold-default/packages/api/examples/security/complete/tests/unit/auth.service.test.ts +199 -0
  286. package/templates/scaffold-default/packages/api/examples/security/complete/tests/unit/permission.service.test.ts +377 -0
  287. package/templates/scaffold-default/packages/api/examples/security/complete/tests/unit/user.service.test.ts +288 -0
  288. package/templates/scaffold-default/packages/api/examples/security/complete/tsconfig.json +35 -0
  289. package/templates/scaffold-default/packages/api/examples/security/jwt/README.md +424 -0
  290. package/templates/scaffold-default/packages/api/examples/security/local/README.md +499 -0
  291. package/templates/scaffold-default/packages/api/examples/security/oauth2/README.md +637 -0
  292. package/templates/scaffold-default/packages/api/examples/security/permission/README.md +943 -0
  293. package/templates/scaffold-default/packages/api/examples/security/session/README.md +753 -0
  294. package/templates/scaffold-default/packages/api/package.json +63 -0
  295. package/templates/scaffold-default/packages/api/scripts/codegen.cjs +29 -0
  296. package/templates/scaffold-default/packages/api/scripts/codegen.ts +9 -0
  297. package/templates/scaffold-default/packages/api/src/config/security-auto-configuration.ts +75 -0
  298. package/templates/scaffold-default/packages/api/src/controller/auth.controller.ts +109 -0
  299. package/templates/scaffold-default/packages/api/src/controller/cache.controller.ts +106 -0
  300. package/templates/scaffold-default/packages/api/src/controller/menu.controller.ts +86 -0
  301. package/templates/scaffold-default/packages/api/src/controller/mq.controller.ts +35 -0
  302. package/templates/scaffold-default/packages/api/src/controller/role.controller.ts +100 -0
  303. package/templates/scaffold-default/packages/api/src/controller/upload.controller.ts +83 -0
  304. package/templates/scaffold-default/packages/api/src/controller/user.controller.ts +102 -0
  305. package/templates/scaffold-default/packages/api/src/dto/auth.dto.ts +30 -0
  306. package/templates/scaffold-default/packages/api/src/dto/cache.dto.ts +24 -0
  307. package/templates/scaffold-default/packages/api/src/dto/menu.dto.ts +37 -0
  308. package/templates/scaffold-default/packages/api/src/dto/mq.dto.ts +16 -0
  309. package/templates/scaffold-default/packages/api/src/dto/role.dto.ts +16 -0
  310. package/templates/scaffold-default/packages/api/src/dto/user.dto.ts +35 -0
  311. package/templates/scaffold-default/packages/api/src/entity/menu.entity.ts +34 -0
  312. package/templates/scaffold-default/packages/api/src/entity/role-menu.entity.ts +13 -0
  313. package/templates/scaffold-default/packages/api/src/entity/role.entity.ts +22 -0
  314. package/templates/scaffold-default/packages/api/src/entity/user-role.entity.ts +13 -0
  315. package/templates/scaffold-default/packages/api/src/entity/user.entity.ts +31 -0
  316. package/templates/scaffold-default/packages/api/src/mapper/menu.mapper.ts +6 -0
  317. package/templates/scaffold-default/packages/api/src/mapper/role-menu.mapper.ts +6 -0
  318. package/templates/scaffold-default/packages/api/src/mapper/role.mapper.ts +6 -0
  319. package/templates/scaffold-default/packages/api/src/mapper/user-role.mapper.ts +6 -0
  320. package/templates/scaffold-default/packages/api/src/mapper/user.mapper.ts +11 -0
  321. package/templates/scaffold-default/packages/api/src/scripts/assign-role.ts +41 -0
  322. package/templates/scaffold-default/packages/api/src/scripts/check-user-role.ts +28 -0
  323. package/templates/scaffold-default/packages/api/src/scripts/check-users.mjs +44 -0
  324. package/templates/scaffold-default/packages/api/src/scripts/demo-permissions.mjs +418 -0
  325. package/templates/scaffold-default/packages/api/src/scripts/init-db.ts +166 -0
  326. package/templates/scaffold-default/packages/api/src/scripts/reset-admin-password.mjs +70 -0
  327. package/templates/scaffold-default/packages/api/src/scripts/reset-password.ts +31 -0
  328. package/templates/scaffold-default/packages/api/src/scripts/simple-reset-admin.mjs +39 -0
  329. package/templates/scaffold-default/packages/api/src/scripts/test-db.ts +36 -0
  330. package/templates/scaffold-default/packages/api/src/scripts/test-di.ts +45 -0
  331. package/templates/scaffold-default/packages/api/src/scripts/test-permissions.mjs +551 -0
  332. package/templates/scaffold-default/packages/api/src/scripts/update-admin-password.mjs +56 -0
  333. package/templates/scaffold-default/packages/api/src/scripts/user-roles.ts +28 -0
  334. package/templates/scaffold-default/packages/api/src/server.ts +38 -0
  335. package/templates/scaffold-default/packages/api/src/service/auth.service.ts +165 -0
  336. package/templates/scaffold-default/packages/api/src/service/cache.service.ts +80 -0
  337. package/templates/scaffold-default/packages/api/src/service/log.request.service.ts +158 -0
  338. package/templates/scaffold-default/packages/api/src/service/log.service.ts +123 -0
  339. package/templates/scaffold-default/packages/api/src/service/menu.service.ts +94 -0
  340. package/templates/scaffold-default/packages/api/src/service/mq.consumer.service.ts +26 -0
  341. package/templates/scaffold-default/packages/api/src/service/role.service.ts +88 -0
  342. package/templates/scaffold-default/packages/api/src/service/user.service.ts +195 -0
  343. package/templates/scaffold-default/packages/api/src/types/sqljs.d.ts +18 -0
  344. package/templates/scaffold-default/packages/api/src/utils/auth.utils.js +0 -0
  345. package/templates/scaffold-default/packages/api/src/utils/jwt.util.ts +29 -0
  346. package/templates/scaffold-default/packages/api/tsconfig.json +17 -0
  347. package/templates/scaffold-default/packages/api/tsup.config.ts +14 -0
  348. package/templates/scaffold-default/packages/api/uploads/.gitkeep +0 -0
  349. package/templates/scaffold-default/packages/core/package.json +28 -0
  350. package/templates/scaffold-default/packages/core/src/auth/auth-client-middleware.ts +22 -0
  351. package/templates/scaffold-default/packages/core/src/auth/auth-constants.ts +6 -0
  352. package/templates/scaffold-default/packages/core/src/auth/auth-service.ts +65 -0
  353. package/templates/scaffold-default/packages/core/src/auth/backend-auth-provider.ts +149 -0
  354. package/templates/scaffold-default/packages/core/src/auth/default-auth-provider.ts +38 -0
  355. package/templates/scaffold-default/packages/core/src/auth/index.ts +12 -0
  356. package/templates/scaffold-default/packages/core/src/auth/types.ts +38 -0
  357. package/templates/scaffold-default/packages/core/src/authorization/authorization-client-middleware.ts +38 -0
  358. package/templates/scaffold-default/packages/core/src/authorization/authorization-config.ts +13 -0
  359. package/templates/scaffold-default/packages/core/src/authorization/authorization-provider.tsx +116 -0
  360. package/templates/scaffold-default/packages/core/src/authorization/default-authorization-provider.ts +26 -0
  361. package/templates/scaffold-default/packages/core/src/authorization/index.ts +15 -0
  362. package/templates/scaffold-default/packages/core/src/authorization/types.ts +42 -0
  363. package/templates/scaffold-default/packages/core/src/index.ts +3 -0
  364. package/templates/scaffold-default/packages/core/src/utils/promise-result-cache.ts +18 -0
  365. package/templates/scaffold-default/packages/core/tsconfig.json +19 -0
  366. package/templates/scaffold-default/packages/mobile/README.md +56 -0
  367. package/templates/scaffold-default/packages/mobile/index.html +13 -0
  368. package/templates/scaffold-default/packages/mobile/package.json +28 -0
  369. package/templates/scaffold-default/packages/mobile/postcss.config.mjs +7 -0
  370. package/templates/scaffold-default/packages/mobile/src/App.tsx +5 -0
  371. package/templates/scaffold-default/packages/mobile/src/app/globals.css +1 -0
  372. package/templates/scaffold-default/packages/mobile/src/components/LoginForm.tsx +83 -0
  373. package/templates/scaffold-default/packages/mobile/src/hooks/index.ts +5 -0
  374. package/templates/scaffold-default/packages/mobile/src/lib/utils.ts +7 -0
  375. package/templates/scaffold-default/packages/mobile/src/main.tsx +19 -0
  376. package/templates/scaffold-default/packages/mobile/src/pages/HomePage.tsx +41 -0
  377. package/templates/scaffold-default/packages/mobile/src/pages/LoginPage.tsx +24 -0
  378. package/templates/scaffold-default/packages/mobile/src/pages/index.ts +2 -0
  379. package/templates/scaffold-default/packages/mobile/src/routes/ProtectedRoute.tsx +35 -0
  380. package/templates/scaffold-default/packages/mobile/src/routes/index.tsx +24 -0
  381. package/templates/scaffold-default/packages/mobile/src/routes/routes.ts +11 -0
  382. package/templates/scaffold-default/packages/mobile/src/types/index.ts +5 -0
  383. package/templates/scaffold-default/packages/mobile/src/vite-env.d.ts +1 -0
  384. package/templates/scaffold-default/packages/mobile/tsconfig.json +23 -0
  385. package/templates/scaffold-default/packages/mobile/tsconfig.node.json +11 -0
  386. package/templates/scaffold-default/packages/mobile/vite.config.ts +20 -0
  387. package/templates/scaffold-default/pnpm-workspace.yaml +2 -0
  388. package/templates/scaffold-default/scripts/postinstall.cjs +42 -0
  389. package/templates/scaffold-default/scripts/rebuild-sqlite.cjs +23 -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 官方文档](https://github.com/ai-partner-x/aiko-boot)
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 官方文档](https://github.com/ai-partner-x/aiko-boot)
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