create-pardx-scaffold 0.1.0

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 (555) hide show
  1. package/README.md +45 -0
  2. package/cli.js +104 -0
  3. package/package.json +15 -0
  4. package/template/.cursorrules +479 -0
  5. package/template/.prettierignore +29 -0
  6. package/template/.prettierrc +11 -0
  7. package/template/.vscode/extensions.json +8 -0
  8. package/template/.vscode/settings.json +122 -0
  9. package/template/CLAUDE.md +762 -0
  10. package/template/README.md +125 -0
  11. package/template/apps/api/.env.example +11 -0
  12. package/template/apps/api/.eslintrc.js +222 -0
  13. package/template/apps/api/config.local.yaml +397 -0
  14. package/template/apps/api/libs/domain/auth/package.json +11 -0
  15. package/template/apps/api/libs/domain/auth/src/README.md +189 -0
  16. package/template/apps/api/libs/domain/auth/src/auth-validation.service.ts +37 -0
  17. package/template/apps/api/libs/domain/auth/src/auth.guard.ts +173 -0
  18. package/template/apps/api/libs/domain/auth/src/auth.module.ts +23 -0
  19. package/template/apps/api/libs/domain/auth/src/auth.service.ts +198 -0
  20. package/template/apps/api/libs/domain/auth/src/auth.ts +66 -0
  21. package/template/apps/api/libs/domain/auth/src/decorators/presets.decorator.ts +50 -0
  22. package/template/apps/api/libs/domain/auth/src/decorators/rbac.decorator.ts +67 -0
  23. package/template/apps/api/libs/domain/auth/src/decorators/resource-owner.decorator.ts +67 -0
  24. package/template/apps/api/libs/domain/auth/src/dto/auth.dto.ts +10 -0
  25. package/template/apps/api/libs/domain/auth/src/guards/streaming-asr-session.guard.ts +179 -0
  26. package/template/apps/api/libs/domain/auth/src/index.ts +12 -0
  27. package/template/apps/api/libs/domain/auth/src/types/auth.interface.ts +52 -0
  28. package/template/apps/api/libs/domain/auth/tsconfig.lib.json +9 -0
  29. package/template/apps/api/libs/domain/db/package.json +11 -0
  30. package/template/apps/api/libs/domain/db/src/index.ts +14 -0
  31. package/template/apps/api/libs/domain/db/src/modules/country-code/country-code.module.ts +12 -0
  32. package/template/apps/api/libs/domain/db/src/modules/country-code/country-code.service.ts +140 -0
  33. package/template/apps/api/libs/domain/db/src/modules/country-code/index.ts +2 -0
  34. package/template/apps/api/libs/domain/db/src/modules/discord-auth/discord-auth.module.ts +12 -0
  35. package/template/apps/api/libs/domain/db/src/modules/discord-auth/discord-auth.service.ts +101 -0
  36. package/template/apps/api/libs/domain/db/src/modules/discord-auth/index.ts +2 -0
  37. package/template/apps/api/libs/domain/db/src/modules/email-auth/email-auth.module.ts +12 -0
  38. package/template/apps/api/libs/domain/db/src/modules/email-auth/email-auth.service.ts +101 -0
  39. package/template/apps/api/libs/domain/db/src/modules/email-auth/index.ts +2 -0
  40. package/template/apps/api/libs/domain/db/src/modules/file-source/file-source.module.ts +12 -0
  41. package/template/apps/api/libs/domain/db/src/modules/file-source/file-source.service.ts +109 -0
  42. package/template/apps/api/libs/domain/db/src/modules/file-source/index.ts +2 -0
  43. package/template/apps/api/libs/domain/db/src/modules/google-auth/google-auth.module.ts +12 -0
  44. package/template/apps/api/libs/domain/db/src/modules/google-auth/google-auth.service.ts +101 -0
  45. package/template/apps/api/libs/domain/db/src/modules/google-auth/index.ts +2 -0
  46. package/template/apps/api/libs/domain/db/src/modules/message/index.ts +2 -0
  47. package/template/apps/api/libs/domain/db/src/modules/message/message.module.ts +10 -0
  48. package/template/apps/api/libs/domain/db/src/modules/message/message.service.ts +314 -0
  49. package/template/apps/api/libs/domain/db/src/modules/mobile-auth/index.ts +2 -0
  50. package/template/apps/api/libs/domain/db/src/modules/mobile-auth/mobile-auth.module.ts +12 -0
  51. package/template/apps/api/libs/domain/db/src/modules/mobile-auth/mobile-auth.service.ts +101 -0
  52. package/template/apps/api/libs/domain/db/src/modules/risk-detection-record/index.ts +2 -0
  53. package/template/apps/api/libs/domain/db/src/modules/risk-detection-record/risk-detection-record.module.ts +12 -0
  54. package/template/apps/api/libs/domain/db/src/modules/risk-detection-record/risk-detection-record.service.ts +101 -0
  55. package/template/apps/api/libs/domain/db/src/modules/system-task-queue/index.ts +2 -0
  56. package/template/apps/api/libs/domain/db/src/modules/system-task-queue/system-task-queue.module.ts +12 -0
  57. package/template/apps/api/libs/domain/db/src/modules/system-task-queue/system-task-queue.service.ts +101 -0
  58. package/template/apps/api/libs/domain/db/src/modules/user-info/index.ts +2 -0
  59. package/template/apps/api/libs/domain/db/src/modules/user-info/user-info.module.ts +12 -0
  60. package/template/apps/api/libs/domain/db/src/modules/user-info/user-info.service.ts +139 -0
  61. package/template/apps/api/libs/domain/db/src/modules/wechat-auth/index.ts +2 -0
  62. package/template/apps/api/libs/domain/db/src/modules/wechat-auth/wechat-auth.module.ts +12 -0
  63. package/template/apps/api/libs/domain/db/src/modules/wechat-auth/wechat-auth.service.ts +101 -0
  64. package/template/apps/api/libs/domain/db/tsconfig.lib.json +9 -0
  65. package/template/apps/api/libs/infra/clients/internal/ai/index.ts +2 -0
  66. package/template/apps/api/libs/infra/clients/internal/ai/risk-detection.client.ts +301 -0
  67. package/template/apps/api/libs/infra/clients/internal/ai/risk-detection.module.ts +22 -0
  68. package/template/apps/api/libs/infra/clients/internal/crypt/crypt-client.service.spec.ts +18 -0
  69. package/template/apps/api/libs/infra/clients/internal/crypt/crypt.client.ts +37 -0
  70. package/template/apps/api/libs/infra/clients/internal/crypt/crypt.module.ts +10 -0
  71. package/template/apps/api/libs/infra/clients/internal/crypt/index.ts +2 -0
  72. package/template/apps/api/libs/infra/clients/internal/email/dto/email.dto.ts +75 -0
  73. package/template/apps/api/libs/infra/clients/internal/email/index.ts +11 -0
  74. package/template/apps/api/libs/infra/clients/internal/email/sendcloud.client.ts +400 -0
  75. package/template/apps/api/libs/infra/clients/internal/file-cdn/README.md +255 -0
  76. package/template/apps/api/libs/infra/clients/internal/file-cdn/dto/file-cdn.dto.ts +96 -0
  77. package/template/apps/api/libs/infra/clients/internal/file-cdn/file-cdn-client.service.spec.ts +18 -0
  78. package/template/apps/api/libs/infra/clients/internal/file-cdn/file-cdn.client.ts +620 -0
  79. package/template/apps/api/libs/infra/clients/internal/file-cdn/file-cdn.module.ts +19 -0
  80. package/template/apps/api/libs/infra/clients/internal/file-cdn/index.ts +40 -0
  81. package/template/apps/api/libs/infra/clients/internal/file-storage/config/file.config.ts +14 -0
  82. package/template/apps/api/libs/infra/clients/internal/file-storage/dto/file.dto.ts +127 -0
  83. package/template/apps/api/libs/infra/clients/internal/file-storage/file-gcs.client.ts +154 -0
  84. package/template/apps/api/libs/infra/clients/internal/file-storage/file-qiniu.client.ts +729 -0
  85. package/template/apps/api/libs/infra/clients/internal/file-storage/file-s3.client.ts +1097 -0
  86. package/template/apps/api/libs/infra/clients/internal/file-storage/file-storage.interface.ts +114 -0
  87. package/template/apps/api/libs/infra/clients/internal/file-storage/file-tos.client.ts +767 -0
  88. package/template/apps/api/libs/infra/clients/internal/file-storage/file-us3.client.ts +176 -0
  89. package/template/apps/api/libs/infra/clients/internal/file-storage/index.ts +16 -0
  90. package/template/apps/api/libs/infra/clients/internal/ocr/dto/ocr.dto.ts +61 -0
  91. package/template/apps/api/libs/infra/clients/internal/ocr/index.ts +3 -0
  92. package/template/apps/api/libs/infra/clients/internal/ocr/ocr.client.ts +123 -0
  93. package/template/apps/api/libs/infra/clients/internal/ocr/ocr.module.ts +15 -0
  94. package/template/apps/api/libs/infra/clients/internal/openai/index.ts +2 -0
  95. package/template/apps/api/libs/infra/clients/internal/openai/openai.client.ts +135 -0
  96. package/template/apps/api/libs/infra/clients/internal/openai/openai.module.ts +17 -0
  97. package/template/apps/api/libs/infra/clients/internal/openspeech/README.md +508 -0
  98. package/template/apps/api/libs/infra/clients/internal/openspeech/index.ts +44 -0
  99. package/template/apps/api/libs/infra/clients/internal/openspeech/openspeech.client.ts +441 -0
  100. package/template/apps/api/libs/infra/clients/internal/openspeech/openspeech.factory.ts +450 -0
  101. package/template/apps/api/libs/infra/clients/internal/openspeech/openspeech.module.ts +56 -0
  102. package/template/apps/api/libs/infra/clients/internal/openspeech/providers/aliyun.provider.ts +308 -0
  103. package/template/apps/api/libs/infra/clients/internal/openspeech/providers/base.provider.ts +114 -0
  104. package/template/apps/api/libs/infra/clients/internal/openspeech/providers/index.ts +10 -0
  105. package/template/apps/api/libs/infra/clients/internal/openspeech/providers/volcengine-streaming.provider.ts +1689 -0
  106. package/template/apps/api/libs/infra/clients/internal/openspeech/providers/volcengine.provider.ts +387 -0
  107. package/template/apps/api/libs/infra/clients/internal/openspeech/types.ts +467 -0
  108. package/template/apps/api/libs/infra/clients/internal/sms/dto/sms.dto.ts +97 -0
  109. package/template/apps/api/libs/infra/clients/internal/sms/index.ts +15 -0
  110. package/template/apps/api/libs/infra/clients/internal/sms/sms-aliyun.client.ts +52 -0
  111. package/template/apps/api/libs/infra/clients/internal/sms/sms-http.client.ts +111 -0
  112. package/template/apps/api/libs/infra/clients/internal/sms/sms-tencent.client.ts +54 -0
  113. package/template/apps/api/libs/infra/clients/internal/sms/sms-volcengine.client.ts +165 -0
  114. package/template/apps/api/libs/infra/clients/internal/sms/sms-zxjc.client.ts +47 -0
  115. package/template/apps/api/libs/infra/clients/internal/sse/index.ts +2 -0
  116. package/template/apps/api/libs/infra/clients/internal/sse/sse-client.service.spec.ts +18 -0
  117. package/template/apps/api/libs/infra/clients/internal/sse/sse.client.ts +360 -0
  118. package/template/apps/api/libs/infra/clients/internal/sse/sse.module.ts +17 -0
  119. package/template/apps/api/libs/infra/clients/internal/third-party-sse/index.ts +2 -0
  120. package/template/apps/api/libs/infra/clients/internal/third-party-sse/third-party-sse.client.ts +51 -0
  121. package/template/apps/api/libs/infra/clients/internal/third-party-sse/third-party-sse.module.ts +10 -0
  122. package/template/apps/api/libs/infra/clients/internal/third-party-sse/third-party-sse.service.spec.ts +18 -0
  123. package/template/apps/api/libs/infra/clients/internal/verify/index.ts +2 -0
  124. package/template/apps/api/libs/infra/clients/internal/verify/verify.client.ts +42 -0
  125. package/template/apps/api/libs/infra/clients/internal/verify/verify.module.ts +10 -0
  126. package/template/apps/api/libs/infra/clients/internal/volcengine-tts/dto/tts.dto.ts +64 -0
  127. package/template/apps/api/libs/infra/clients/internal/volcengine-tts/index.ts +3 -0
  128. package/template/apps/api/libs/infra/clients/internal/volcengine-tts/volcengine-tts.client.ts +846 -0
  129. package/template/apps/api/libs/infra/clients/internal/volcengine-tts/volcengine-tts.module.ts +21 -0
  130. package/template/apps/api/libs/infra/clients/internal/wechat/index.ts +2 -0
  131. package/template/apps/api/libs/infra/clients/internal/wechat/wechat-client.service.spec.ts +18 -0
  132. package/template/apps/api/libs/infra/clients/internal/wechat/wechat.client.ts +4 -0
  133. package/template/apps/api/libs/infra/clients/internal/wechat/wechat.module.ts +8 -0
  134. package/template/apps/api/libs/infra/clients/plugin/decorators/inject-client.decorator.ts +60 -0
  135. package/template/apps/api/libs/infra/clients/plugin/index.ts +21 -0
  136. package/template/apps/api/libs/infra/clients/plugin/interceptors/http-logging.interceptor.ts +130 -0
  137. package/template/apps/api/libs/infra/clients/plugin/interfaces/client.interface.ts +86 -0
  138. package/template/apps/api/libs/infra/clients/plugin/utils/retry.util.ts +157 -0
  139. package/template/apps/api/libs/infra/common/adapters/base.adapter.ts +94 -0
  140. package/template/apps/api/libs/infra/common/adapters/index.ts +38 -0
  141. package/template/apps/api/libs/infra/common/config/README.md +254 -0
  142. package/template/apps/api/libs/infra/common/config/agentx.config.ts +91 -0
  143. package/template/apps/api/libs/infra/common/config/configuration.ts +289 -0
  144. package/template/apps/api/libs/infra/common/config/constant/config.constants.ts +92 -0
  145. package/template/apps/api/libs/infra/common/config/dto/config.dto.ts +282 -0
  146. package/template/apps/api/libs/infra/common/config/package.json +11 -0
  147. package/template/apps/api/libs/infra/common/config/validation/env.validation.ts +161 -0
  148. package/template/apps/api/libs/infra/common/config/validation/index.ts +188 -0
  149. package/template/apps/api/libs/infra/common/config/validation/keys.validation.ts +564 -0
  150. package/template/apps/api/libs/infra/common/config/validation/yaml.validation.ts +582 -0
  151. package/template/apps/api/libs/infra/common/decorators/app-version/app-version.controller.ts +135 -0
  152. package/template/apps/api/libs/infra/common/decorators/app-version/app-version.interceptor.ts +36 -0
  153. package/template/apps/api/libs/infra/common/decorators/app-version/app-version.module.ts +27 -0
  154. package/template/apps/api/libs/infra/common/decorators/app-version/app-version.service.ts +252 -0
  155. package/template/apps/api/libs/infra/common/decorators/app-version/index.ts +13 -0
  156. package/template/apps/api/libs/infra/common/decorators/cache/cache.decorator.ts +437 -0
  157. package/template/apps/api/libs/infra/common/decorators/cache/cache.interceptor.ts +268 -0
  158. package/template/apps/api/libs/infra/common/decorators/cache/cache.module.ts +24 -0
  159. package/template/apps/api/libs/infra/common/decorators/cache/index.ts +33 -0
  160. package/template/apps/api/libs/infra/common/decorators/event/event.decorator.ts +229 -0
  161. package/template/apps/api/libs/infra/common/decorators/event/event.interceptor.ts +155 -0
  162. package/template/apps/api/libs/infra/common/decorators/event/event.module.ts +47 -0
  163. package/template/apps/api/libs/infra/common/decorators/event/handlers/cache-event.handler.ts +159 -0
  164. package/template/apps/api/libs/infra/common/decorators/event/index.ts +29 -0
  165. package/template/apps/api/libs/infra/common/decorators/feature-flag/feature-flag.decorator.ts +221 -0
  166. package/template/apps/api/libs/infra/common/decorators/feature-flag/feature-flag.interceptor.ts +150 -0
  167. package/template/apps/api/libs/infra/common/decorators/feature-flag/feature-flag.module.ts +27 -0
  168. package/template/apps/api/libs/infra/common/decorators/feature-flag/feature-flag.service.spec.ts +330 -0
  169. package/template/apps/api/libs/infra/common/decorators/feature-flag/feature-flag.service.ts +423 -0
  170. package/template/apps/api/libs/infra/common/decorators/feature-flag/index.ts +28 -0
  171. package/template/apps/api/libs/infra/common/decorators/rate-limit/dto/rate-limit.dto.ts +201 -0
  172. package/template/apps/api/libs/infra/common/decorators/rate-limit/index.ts +54 -0
  173. package/template/apps/api/libs/infra/common/decorators/rate-limit/rate-limit.decorator.ts +216 -0
  174. package/template/apps/api/libs/infra/common/decorators/rate-limit/rate-limit.exception.ts +74 -0
  175. package/template/apps/api/libs/infra/common/decorators/rate-limit/rate-limit.module.ts +37 -0
  176. package/template/apps/api/libs/infra/common/decorators/rate-limit/rate-limit.service.ts +430 -0
  177. package/template/apps/api/libs/infra/common/decorators/response.decorator.ts +67 -0
  178. package/template/apps/api/libs/infra/common/decorators/skip-version-check.decorator.ts +27 -0
  179. package/template/apps/api/libs/infra/common/decorators/transaction/index.ts +12 -0
  180. package/template/apps/api/libs/infra/common/decorators/transaction/transactional.decorator.ts +677 -0
  181. package/template/apps/api/libs/infra/common/decorators/ts-rest-controller.decorator.ts +63 -0
  182. package/template/apps/api/libs/infra/common/decorators/validation.decorator.ts +120 -0
  183. package/template/apps/api/libs/infra/common/decorators/version/index.ts +24 -0
  184. package/template/apps/api/libs/infra/common/decorators/version/version.decorator.ts +168 -0
  185. package/template/apps/api/libs/infra/common/decorators/version/version.interceptor.ts +97 -0
  186. package/template/apps/api/libs/infra/common/decorators/version/version.module.ts +21 -0
  187. package/template/apps/api/libs/infra/common/enums/action.enum.ts +7 -0
  188. package/template/apps/api/libs/infra/common/enums/error-codes.ts +71 -0
  189. package/template/apps/api/libs/infra/common/enums/role.enum.ts +4 -0
  190. package/template/apps/api/libs/infra/common/filter/exception/api.exception.ts +168 -0
  191. package/template/apps/api/libs/infra/common/filter/exception/exception.ts +47 -0
  192. package/template/apps/api/libs/infra/common/filter/exception/http.exception.ts +126 -0
  193. package/template/apps/api/libs/infra/common/guards/index.ts +1 -0
  194. package/template/apps/api/libs/infra/common/guards/version.guard.ts +312 -0
  195. package/template/apps/api/libs/infra/common/interceptor/mask/index.ts +1 -0
  196. package/template/apps/api/libs/infra/common/interceptor/mask/mask.interceptor.ts +242 -0
  197. package/template/apps/api/libs/infra/common/interceptor/rate-limit/no-rate-limit.interceptor.ts +14 -0
  198. package/template/apps/api/libs/infra/common/interceptor/rate-limit/rate-limit.interceptor.ts +230 -0
  199. package/template/apps/api/libs/infra/common/interceptor/transform/transform.interceptor.spec.ts +7 -0
  200. package/template/apps/api/libs/infra/common/interceptor/transform/transform.interceptor.ts +75 -0
  201. package/template/apps/api/libs/infra/common/interceptor/version/index.ts +1 -0
  202. package/template/apps/api/libs/infra/common/interceptor/version/version-header.interceptor.ts +62 -0
  203. package/template/apps/api/libs/infra/common/middleware/request.middleware.ts +109 -0
  204. package/template/apps/api/libs/infra/common/package.json +11 -0
  205. package/template/apps/api/libs/infra/common/pipes/transform-root.pipe.ts +12 -0
  206. package/template/apps/api/libs/infra/common/ts-rest/index.ts +26 -0
  207. package/template/apps/api/libs/infra/common/ts-rest/response.helper.ts +233 -0
  208. package/template/apps/api/libs/infra/i18n/en/errors.json +77 -0
  209. package/template/apps/api/libs/infra/i18n/en/events.json +1 -0
  210. package/template/apps/api/libs/infra/i18n/package.json +11 -0
  211. package/template/apps/api/libs/infra/i18n/zh-CN/errors.json +77 -0
  212. package/template/apps/api/libs/infra/i18n/zh-CN/events.json +1 -0
  213. package/template/apps/api/libs/infra/jwt/dto/jwt.dto.ts +1 -0
  214. package/template/apps/api/libs/infra/jwt/jwt.module.ts +26 -0
  215. package/template/apps/api/libs/infra/jwt/package.json +11 -0
  216. package/template/apps/api/libs/infra/prisma/db-metrics/package.json +11 -0
  217. package/template/apps/api/libs/infra/prisma/db-metrics/src/db-metrics.module.ts +141 -0
  218. package/template/apps/api/libs/infra/prisma/db-metrics/src/db-metrics.service.ts +456 -0
  219. package/template/apps/api/libs/infra/prisma/db-metrics/src/index.ts +2 -0
  220. package/template/apps/api/libs/infra/prisma/db-metrics/tsconfig.lib.json +9 -0
  221. package/template/apps/api/libs/infra/prisma/middleware/soft-delete.middleware.ts +179 -0
  222. package/template/apps/api/libs/infra/prisma/package.json +11 -0
  223. package/template/apps/api/libs/infra/prisma/prisma/index.ts +3 -0
  224. package/template/apps/api/libs/infra/prisma/prisma/prisma.module.ts +12 -0
  225. package/template/apps/api/libs/infra/prisma/prisma/prisma.service.ts +18 -0
  226. package/template/apps/api/libs/infra/prisma/prisma/types.ts +6 -0
  227. package/template/apps/api/libs/infra/prisma/prisma-read/prisma-read.module.ts +11 -0
  228. package/template/apps/api/libs/infra/prisma/prisma-read/prisma-read.service.ts +280 -0
  229. package/template/apps/api/libs/infra/prisma/prisma-write/prisma-write.module.ts +11 -0
  230. package/template/apps/api/libs/infra/prisma/prisma-write/prisma-write.service.ts +278 -0
  231. package/template/apps/api/libs/infra/prisma/prometheus/index.ts +1 -0
  232. package/template/apps/api/libs/infra/prisma/prometheus/prometheus.module.ts +231 -0
  233. package/template/apps/api/libs/infra/rabbitmq/package.json +11 -0
  234. package/template/apps/api/libs/infra/rabbitmq/src/dto/rabbitmq.dto.ts +13 -0
  235. package/template/apps/api/libs/infra/rabbitmq/src/index.ts +5 -0
  236. package/template/apps/api/libs/infra/rabbitmq/src/rabbitmq-events.module.ts +132 -0
  237. package/template/apps/api/libs/infra/rabbitmq/src/rabbitmq-events.service.ts +199 -0
  238. package/template/apps/api/libs/infra/rabbitmq/src/rabbitmq.module.ts +101 -0
  239. package/template/apps/api/libs/infra/rabbitmq/src/rabbitmq.service.spec.ts +18 -0
  240. package/template/apps/api/libs/infra/rabbitmq/src/rabbitmq.service.ts +543 -0
  241. package/template/apps/api/libs/infra/rabbitmq/tsconfig.lib.json +9 -0
  242. package/template/apps/api/libs/infra/redis/dto/redis.dto.ts +3 -0
  243. package/template/apps/api/libs/infra/redis/package.json +11 -0
  244. package/template/apps/api/libs/infra/redis/src/index.ts +2 -0
  245. package/template/apps/api/libs/infra/redis/src/redis.module.ts +63 -0
  246. package/template/apps/api/libs/infra/redis/src/redis.service.spec.ts +18 -0
  247. package/template/apps/api/libs/infra/redis/src/redis.service.ts +730 -0
  248. package/template/apps/api/libs/infra/redis/tsconfig.lib.json +9 -0
  249. package/template/apps/api/libs/infra/shared-db/index.ts +14 -0
  250. package/template/apps/api/libs/infra/shared-db/transaction-context.ts +51 -0
  251. package/template/apps/api/libs/infra/shared-db/transaction.module.ts +15 -0
  252. package/template/apps/api/libs/infra/shared-db/transaction.perf.spec.ts +226 -0
  253. package/template/apps/api/libs/infra/shared-db/transactional-service.base.ts +102 -0
  254. package/template/apps/api/libs/infra/shared-db/unit-of-work.service.ts +142 -0
  255. package/template/apps/api/libs/infra/shared-services/email/dto/email.dto.ts +87 -0
  256. package/template/apps/api/libs/infra/shared-services/email/email.module.ts +27 -0
  257. package/template/apps/api/libs/infra/shared-services/email/email.service.ts +258 -0
  258. package/template/apps/api/libs/infra/shared-services/email/index.ts +5 -0
  259. package/template/apps/api/libs/infra/shared-services/file-storage/README.md +376 -0
  260. package/template/apps/api/libs/infra/shared-services/file-storage/bucket-resolver.ts +306 -0
  261. package/template/apps/api/libs/infra/shared-services/file-storage/file-storage.factory.ts +347 -0
  262. package/template/apps/api/libs/infra/shared-services/file-storage/file-storage.module.ts +62 -0
  263. package/template/apps/api/libs/infra/shared-services/file-storage/file-storage.service.ts +849 -0
  264. package/template/apps/api/libs/infra/shared-services/file-storage/index.ts +57 -0
  265. package/template/apps/api/libs/infra/shared-services/file-storage/types.ts +210 -0
  266. package/template/apps/api/libs/infra/shared-services/ip-info/index.ts +2 -0
  267. package/template/apps/api/libs/infra/shared-services/ip-info/ip-info.module.ts +18 -0
  268. package/template/apps/api/libs/infra/shared-services/ip-info/ip-info.service.ts +118 -0
  269. package/template/apps/api/libs/infra/shared-services/sms/index.ts +11 -0
  270. package/template/apps/api/libs/infra/shared-services/sms/sms.factory.ts +367 -0
  271. package/template/apps/api/libs/infra/shared-services/sms/sms.module.ts +27 -0
  272. package/template/apps/api/libs/infra/shared-services/sms/sms.service.ts +315 -0
  273. package/template/apps/api/libs/infra/shared-services/sms/types.ts +297 -0
  274. package/template/apps/api/libs/infra/shared-services/streaming-asr/index.ts +50 -0
  275. package/template/apps/api/libs/infra/shared-services/streaming-asr/streaming-asr.module.ts +47 -0
  276. package/template/apps/api/libs/infra/shared-services/streaming-asr/streaming-asr.service.ts +1336 -0
  277. package/template/apps/api/libs/infra/shared-services/streaming-asr/types.ts +208 -0
  278. package/template/apps/api/libs/infra/shared-services/system-health/index.ts +3 -0
  279. package/template/apps/api/libs/infra/shared-services/system-health/system-health.controller.ts +61 -0
  280. package/template/apps/api/libs/infra/shared-services/system-health/system-health.module.ts +16 -0
  281. package/template/apps/api/libs/infra/shared-services/system-health/system-health.service.ts +69 -0
  282. package/template/apps/api/libs/infra/shared-services/uploader/index.ts +2 -0
  283. package/template/apps/api/libs/infra/shared-services/uploader/uploader.module.ts +11 -0
  284. package/template/apps/api/libs/infra/shared-services/uploader/uploader.service.ts +265 -0
  285. package/template/apps/api/libs/infra/utils/array-buffer.util.ts +8 -0
  286. package/template/apps/api/libs/infra/utils/array.util.ts +3 -0
  287. package/template/apps/api/libs/infra/utils/bcrypt.util.ts +3 -0
  288. package/template/apps/api/libs/infra/utils/bigint.util.ts +3 -0
  289. package/template/apps/api/libs/infra/utils/bytes.convert.util.ts +13 -0
  290. package/template/apps/api/libs/infra/utils/crypto.util.ts +206 -0
  291. package/template/apps/api/libs/infra/utils/download.ts +21 -0
  292. package/template/apps/api/libs/infra/utils/enviroment.util.ts +130 -0
  293. package/template/apps/api/libs/infra/utils/ffmpeg.util.ts +29 -0
  294. package/template/apps/api/libs/infra/utils/file.util.ts +448 -0
  295. package/template/apps/api/libs/infra/utils/folder.util.ts +11 -0
  296. package/template/apps/api/libs/infra/utils/frame.util.ts +24 -0
  297. package/template/apps/api/libs/infra/utils/http-client.ts +133 -0
  298. package/template/apps/api/libs/infra/utils/ip.util.ts +22 -0
  299. package/template/apps/api/libs/infra/utils/json.util.ts +3 -0
  300. package/template/apps/api/libs/infra/utils/load-env.util.ts +53 -0
  301. package/template/apps/api/libs/infra/utils/logger.util.ts +121 -0
  302. package/template/apps/api/libs/infra/utils/object.util.ts +3 -0
  303. package/template/apps/api/libs/infra/utils/package.json +11 -0
  304. package/template/apps/api/libs/infra/utils/prisma-error.util.ts +397 -0
  305. package/template/apps/api/libs/infra/utils/response.ts +23 -0
  306. package/template/apps/api/libs/infra/utils/serialize.util.ts +3 -0
  307. package/template/apps/api/libs/infra/utils/string.util.ts +3 -0
  308. package/template/apps/api/libs/infra/utils/timer.util.ts +3 -0
  309. package/template/apps/api/libs/infra/utils/urlencode.util.ts +3 -0
  310. package/template/apps/api/libs/infra/utils/validate.util.ts +3 -0
  311. package/template/apps/api/nest-cli.json +25 -0
  312. package/template/apps/api/package.json +174 -0
  313. package/template/apps/api/prisma/schema.prisma +352 -0
  314. package/template/apps/api/prisma/seed.ts +30 -0
  315. package/template/apps/api/scripts/generate-db-crud.js +344 -0
  316. package/template/apps/api/scripts/insert-country-codes.ts +325 -0
  317. package/template/apps/api/scripts/link-prisma.js +44 -0
  318. package/template/apps/api/scripts/validate-api-versions.ts +273 -0
  319. package/template/apps/api/src/app.module.ts +208 -0
  320. package/template/apps/api/src/main.ts +298 -0
  321. package/template/apps/api/src/modules/health/health.controller.ts +13 -0
  322. package/template/apps/api/src/modules/health/health.module.ts +7 -0
  323. package/template/apps/api/tsconfig.build.json +4 -0
  324. package/template/apps/api/tsconfig.json +123 -0
  325. package/template/apps/web/.env.example +5 -0
  326. package/template/apps/web/app/globals.css +27 -0
  327. package/template/apps/web/app/layout.tsx +19 -0
  328. package/template/apps/web/app/page.tsx +42 -0
  329. package/template/apps/web/hooks/useAspectRatioSize.ts +187 -0
  330. package/template/apps/web/hooks/useDebouncedValue.ts +25 -0
  331. package/template/apps/web/hooks/useErrorHandler.ts +113 -0
  332. package/template/apps/web/hooks/useHotkeys.ts +251 -0
  333. package/template/apps/web/hooks/useI18nToast.ts +240 -0
  334. package/template/apps/web/hooks/useI18nValidation.ts +262 -0
  335. package/template/apps/web/hooks/useNotificationSSE.ts +270 -0
  336. package/template/apps/web/hooks/useOperationFeedback.ts +108 -0
  337. package/template/apps/web/hooks/usePerformanceMonitor.ts +105 -0
  338. package/template/apps/web/hooks/usePermissions.ts +17 -0
  339. package/template/apps/web/hooks/useTask.ts +489 -0
  340. package/template/apps/web/hooks/useVersionCheck.ts +329 -0
  341. package/template/apps/web/i18n/config.ts +50 -0
  342. package/template/apps/web/i18n/index.ts +30 -0
  343. package/template/apps/web/i18n/navigation.ts +26 -0
  344. package/template/apps/web/i18n/request.ts +50 -0
  345. package/template/apps/web/i18n/routing.ts +21 -0
  346. package/template/apps/web/i18n/types.ts +57 -0
  347. package/template/apps/web/lib/actions/auth.ts +81 -0
  348. package/template/apps/web/lib/actions/chat.ts +129 -0
  349. package/template/apps/web/lib/actions/common.ts +13 -0
  350. package/template/apps/web/lib/actions/task.ts +20 -0
  351. package/template/apps/web/lib/agent/chat-client.ts +42 -0
  352. package/template/apps/web/lib/agent/prompts.ts +43 -0
  353. package/template/apps/web/lib/analytics/components/PageTracker.tsx +137 -0
  354. package/template/apps/web/lib/analytics/hooks/usePageTracking.ts +137 -0
  355. package/template/apps/web/lib/analytics/index.ts +180 -0
  356. package/template/apps/web/lib/api/agents.ts +7 -0
  357. package/template/apps/web/lib/api/agno-chat.ts +263 -0
  358. package/template/apps/web/lib/api/auth-server.ts +244 -0
  359. package/template/apps/web/lib/api/avatar-upload.ts +96 -0
  360. package/template/apps/web/lib/api/cache-config.ts +236 -0
  361. package/template/apps/web/lib/api/client.ts +649 -0
  362. package/template/apps/web/lib/api/contracts/client.ts +336 -0
  363. package/template/apps/web/lib/api/contracts/hooks/index.ts +25 -0
  364. package/template/apps/web/lib/api/contracts/hooks/notification.ts +180 -0
  365. package/template/apps/web/lib/api/contracts/hooks/setting.ts +33 -0
  366. package/template/apps/web/lib/api/contracts/index.ts +18 -0
  367. package/template/apps/web/lib/api/contracts/server-client.ts +145 -0
  368. package/template/apps/web/lib/api/hooks/use-python-task.ts +154 -0
  369. package/template/apps/web/lib/api/queries/analytics.ts +51 -0
  370. package/template/apps/web/lib/api/queries/message.ts +75 -0
  371. package/template/apps/web/lib/api.ts +179 -0
  372. package/template/apps/web/lib/aspect-ratio.ts +10 -0
  373. package/template/apps/web/lib/audio-buffer-queue.ts +273 -0
  374. package/template/apps/web/lib/config.ts +163 -0
  375. package/template/apps/web/lib/data/industry.json +369 -0
  376. package/template/apps/web/lib/data/region.json +501 -0
  377. package/template/apps/web/lib/errors/error-handler.ts +194 -0
  378. package/template/apps/web/lib/errors/index.ts +16 -0
  379. package/template/apps/web/lib/errors/streaming-asr-errors.ts +434 -0
  380. package/template/apps/web/lib/form/index.ts +23 -0
  381. package/template/apps/web/lib/form/use-form.ts +143 -0
  382. package/template/apps/web/lib/icons-usage.md +99 -0
  383. package/template/apps/web/lib/icons.tsx +395 -0
  384. package/template/apps/web/lib/performance/monitor.ts +225 -0
  385. package/template/apps/web/lib/requests.ts +177 -0
  386. package/template/apps/web/lib/storage/index.ts +158 -0
  387. package/template/apps/web/lib/upload/api.ts +260 -0
  388. package/template/apps/web/lib/upload/batch-uploader.ts +286 -0
  389. package/template/apps/web/lib/upload/errors.ts +44 -0
  390. package/template/apps/web/lib/upload/folder-utils.ts +295 -0
  391. package/template/apps/web/lib/upload/uploader.ts +439 -0
  392. package/template/apps/web/lib/utils/reconnect.ts +223 -0
  393. package/template/apps/web/lib/utils/transcript-export.ts +321 -0
  394. package/template/apps/web/lib/version-mismatch.ts +147 -0
  395. package/template/apps/web/lib/version.ts +60 -0
  396. package/template/apps/web/next-env.d.ts +6 -0
  397. package/template/apps/web/next.config.ts +97 -0
  398. package/template/apps/web/package.json +89 -0
  399. package/template/apps/web/providers/app-provider.tsx +45 -0
  400. package/template/apps/web/providers/index.tsx +45 -0
  401. package/template/apps/web/providers/query-provider.tsx +181 -0
  402. package/template/apps/web/providers/theme-provider.tsx +26 -0
  403. package/template/apps/web/tsconfig.json +30 -0
  404. package/template/package.json +91 -0
  405. package/template/packages/config/eslint/base.js +32 -0
  406. package/template/packages/config/eslint/next.js +134 -0
  407. package/template/packages/config/eslint/react-internal.js +41 -0
  408. package/template/packages/config/eslint.config.mjs +26 -0
  409. package/template/packages/config/eslint.nestjs.config.mjs +62 -0
  410. package/template/packages/config/index.ts +2 -0
  411. package/template/packages/config/package.json +44 -0
  412. package/template/packages/config/postcss.config.mjs +8 -0
  413. package/template/packages/config/prettier.config.mjs +14 -0
  414. package/template/packages/config/tsconfig.json +19 -0
  415. package/template/packages/config/typescript/base.json +20 -0
  416. package/template/packages/config/typescript/nextjs.json +12 -0
  417. package/template/packages/config/typescript/react-library.json +8 -0
  418. package/template/packages/constants/README.md +111 -0
  419. package/template/packages/constants/package.json +25 -0
  420. package/template/packages/constants/src/index.ts +243 -0
  421. package/template/packages/constants/tsconfig.build.json +13 -0
  422. package/template/packages/constants/tsconfig.json +12 -0
  423. package/template/packages/contracts/ERROR-MIGRATION.md +179 -0
  424. package/template/packages/contracts/README.md +203 -0
  425. package/template/packages/contracts/jest.config.js +11 -0
  426. package/template/packages/contracts/package.json +60 -0
  427. package/template/packages/contracts/src/api/analytics.contract.ts +45 -0
  428. package/template/packages/contracts/src/api/download.contract.ts +66 -0
  429. package/template/packages/contracts/src/api/index.ts +12 -0
  430. package/template/packages/contracts/src/api/message.contract.ts +70 -0
  431. package/template/packages/contracts/src/api/risk-words.contract.ts +44 -0
  432. package/template/packages/contracts/src/api/setting.contract.ts +127 -0
  433. package/template/packages/contracts/src/api/sign.contract.ts +269 -0
  434. package/template/packages/contracts/src/api/sms.contract.ts +95 -0
  435. package/template/packages/contracts/src/api/system.contract.ts +52 -0
  436. package/template/packages/contracts/src/api/task.contract.ts +58 -0
  437. package/template/packages/contracts/src/api/uploader.contract.ts +93 -0
  438. package/template/packages/contracts/src/api/user.contract.ts +60 -0
  439. package/template/packages/contracts/src/api/webhook.contract.ts +73 -0
  440. package/template/packages/contracts/src/base.ts +319 -0
  441. package/template/packages/contracts/src/errors/codes.ts +55 -0
  442. package/template/packages/contracts/src/errors/domains/common.errors.ts +212 -0
  443. package/template/packages/contracts/src/errors/domains/index.ts +7 -0
  444. package/template/packages/contracts/src/errors/domains/user.errors.ts +51 -0
  445. package/template/packages/contracts/src/errors/error-response.ts +145 -0
  446. package/template/packages/contracts/src/errors/index.ts +16 -0
  447. package/template/packages/contracts/src/errors/messages.ts +240 -0
  448. package/template/packages/contracts/src/index.ts +16 -0
  449. package/template/packages/contracts/src/schemas/analytics.schema.ts +81 -0
  450. package/template/packages/contracts/src/schemas/download.schema.ts +59 -0
  451. package/template/packages/contracts/src/schemas/index.ts +18 -0
  452. package/template/packages/contracts/src/schemas/message.schema.ts +83 -0
  453. package/template/packages/contracts/src/schemas/risk-words.schema.ts +25 -0
  454. package/template/packages/contracts/src/schemas/setting.schema.ts +84 -0
  455. package/template/packages/contracts/src/schemas/sign.schema.ts +171 -0
  456. package/template/packages/contracts/src/schemas/sms.schema.ts +53 -0
  457. package/template/packages/contracts/src/schemas/sse.schema.ts +30 -0
  458. package/template/packages/contracts/src/schemas/system.schema.ts +26 -0
  459. package/template/packages/contracts/src/schemas/tag.schema.ts +65 -0
  460. package/template/packages/contracts/src/schemas/task.schema.ts +47 -0
  461. package/template/packages/contracts/src/schemas/uploader.schema.ts +121 -0
  462. package/template/packages/contracts/src/schemas/user.schema.ts +75 -0
  463. package/template/packages/contracts/src/schemas/webhook.schema.ts +72 -0
  464. package/template/packages/contracts/tsconfig.build.json +20 -0
  465. package/template/packages/contracts/tsconfig.json +12 -0
  466. package/template/packages/types/README.md +143 -0
  467. package/template/packages/types/ai.ts +30 -0
  468. package/template/packages/types/auth.ts +99 -0
  469. package/template/packages/types/common.ts +13 -0
  470. package/template/packages/types/creative.ts +68 -0
  471. package/template/packages/types/image-factory.ts +122 -0
  472. package/template/packages/types/index.ts +8 -0
  473. package/template/packages/types/package.json +21 -0
  474. package/template/packages/types/task.ts +27 -0
  475. package/template/packages/types/tsconfig.json +11 -0
  476. package/template/packages/ui/README.md +30 -0
  477. package/template/packages/ui/components.json +22 -0
  478. package/template/packages/ui/eslint.config.js +4 -0
  479. package/template/packages/ui/package.json +58 -0
  480. package/template/packages/ui/postcss.config.mjs +6 -0
  481. package/template/packages/ui/src/components/accordion.tsx +66 -0
  482. package/template/packages/ui/src/components/alert.tsx +61 -0
  483. package/template/packages/ui/src/components/avatar.tsx +57 -0
  484. package/template/packages/ui/src/components/badge.tsx +38 -0
  485. package/template/packages/ui/src/components/button.tsx +60 -0
  486. package/template/packages/ui/src/components/calendar.tsx +71 -0
  487. package/template/packages/ui/src/components/card.tsx +92 -0
  488. package/template/packages/ui/src/components/carousel.tsx +241 -0
  489. package/template/packages/ui/src/components/checkbox.tsx +32 -0
  490. package/template/packages/ui/src/components/command.tsx +184 -0
  491. package/template/packages/ui/src/components/dialog.tsx +134 -0
  492. package/template/packages/ui/src/components/dropdown-menu.tsx +257 -0
  493. package/template/packages/ui/src/components/empty.tsx +104 -0
  494. package/template/packages/ui/src/components/field.tsx +248 -0
  495. package/template/packages/ui/src/components/form.tsx +172 -0
  496. package/template/packages/ui/src/components/input-group.tsx +170 -0
  497. package/template/packages/ui/src/components/input.tsx +21 -0
  498. package/template/packages/ui/src/components/item.tsx +193 -0
  499. package/template/packages/ui/src/components/label.tsx +24 -0
  500. package/template/packages/ui/src/components/password-strength.tsx +248 -0
  501. package/template/packages/ui/src/components/popover.tsx +48 -0
  502. package/template/packages/ui/src/components/progress.tsx +35 -0
  503. package/template/packages/ui/src/components/scroll-area.tsx +48 -0
  504. package/template/packages/ui/src/components/select.tsx +190 -0
  505. package/template/packages/ui/src/components/separator.tsx +28 -0
  506. package/template/packages/ui/src/components/sheet.tsx +139 -0
  507. package/template/packages/ui/src/components/sidebar.tsx +729 -0
  508. package/template/packages/ui/src/components/skeleton.tsx +13 -0
  509. package/template/packages/ui/src/components/slider.tsx +87 -0
  510. package/template/packages/ui/src/components/sonner.tsx +40 -0
  511. package/template/packages/ui/src/components/switch.tsx +31 -0
  512. package/template/packages/ui/src/components/tabs.tsx +66 -0
  513. package/template/packages/ui/src/components/textarea.tsx +18 -0
  514. package/template/packages/ui/src/components/tooltip.tsx +61 -0
  515. package/template/packages/ui/src/hooks/use-mobile.ts +21 -0
  516. package/template/packages/ui/src/index.ts +38 -0
  517. package/template/packages/ui/src/lib/utils.ts +6 -0
  518. package/template/packages/ui/src/styles/globals.css +134 -0
  519. package/template/packages/ui/tsconfig.json +11 -0
  520. package/template/packages/ui/tsconfig.lint.json +8 -0
  521. package/template/packages/utils/README.md +173 -0
  522. package/template/packages/utils/array.util.ts +335 -0
  523. package/template/packages/utils/bcrypt.util.ts +10 -0
  524. package/template/packages/utils/bigint.util.ts +111 -0
  525. package/template/packages/utils/cn.ts +6 -0
  526. package/template/packages/utils/encrypt.ts +104 -0
  527. package/template/packages/utils/fetch.ts +170 -0
  528. package/template/packages/utils/file.ts +275 -0
  529. package/template/packages/utils/headers.ts +116 -0
  530. package/template/packages/utils/index.ts +22 -0
  531. package/template/packages/utils/jest.config.js +28 -0
  532. package/template/packages/utils/json.util.ts +9 -0
  533. package/template/packages/utils/mask.util.ts +348 -0
  534. package/template/packages/utils/object.util.ts +149 -0
  535. package/template/packages/utils/package.json +112 -0
  536. package/template/packages/utils/serialize.util.ts +17 -0
  537. package/template/packages/utils/string.util.ts +159 -0
  538. package/template/packages/utils/timer.util.ts +210 -0
  539. package/template/packages/utils/tsconfig.build.json +17 -0
  540. package/template/packages/utils/tsconfig.json +13 -0
  541. package/template/packages/utils/urlencode.util.ts +18 -0
  542. package/template/packages/utils/validate.util.ts +25 -0
  543. package/template/packages/validators/README.md +149 -0
  544. package/template/packages/validators/jest.config.js +20 -0
  545. package/template/packages/validators/package.json +32 -0
  546. package/template/packages/validators/src/index.ts +178 -0
  547. package/template/packages/validators/tsconfig.build.json +19 -0
  548. package/template/packages/validators/tsconfig.json +12 -0
  549. package/template/pnpm-lock.yaml +21574 -0
  550. package/template/pnpm-workspace.yaml +4 -0
  551. package/template/scripts/generate-i18n-errors.ts +371 -0
  552. package/template/scripts/generate-prisma-enums.js +170 -0
  553. package/template/scripts/generate-prisma-enums.ts +172 -0
  554. package/template/scripts/init-project.js +232 -0
  555. package/template/turbo.json +55 -0
@@ -0,0 +1,173 @@
1
+ import {
2
+ CanActivate,
3
+ ExecutionContext,
4
+ Inject,
5
+ Injectable,
6
+ } from '@nestjs/common';
7
+ import { AuthService } from './auth.service';
8
+ import { JwtService } from '@nestjs/jwt';
9
+ import { CommonErrorCode } from '@repo/contracts/errors';
10
+ import { apiError } from '@/filter/exception/api.exception';
11
+ import { ConfigService } from '@nestjs/config';
12
+ import { JwtConfig } from '@/config/validation';
13
+ import stringUtil from '@/utils/string.util';
14
+ import { UserInfoService } from '@app/db';
15
+ import { RedisService } from '@app/redis';
16
+ import { FastifyRequest, FastifyReply } from 'fastify';
17
+ import enviromentUtil from '@/utils/enviroment.util';
18
+ import { Reflector } from '@nestjs/core';
19
+ import { WINSTON_MODULE_PROVIDER } from 'nest-winston';
20
+ import { Logger } from 'winston';
21
+ import { MPTRAIL_HEADER } from '@repo/constants';
22
+
23
+ @Injectable()
24
+ export class AuthGuard implements CanActivate {
25
+ private readonly outOfAnonymityPathConfig;
26
+ private readonly outOfUserPathConfig;
27
+
28
+ constructor(
29
+ private readonly auth: AuthService,
30
+ private readonly jwt: JwtService,
31
+ private readonly config: ConfigService,
32
+ private readonly reflector: Reflector,
33
+ private readonly redis: RedisService,
34
+ private readonly user: UserInfoService,
35
+ @Inject(WINSTON_MODULE_PROVIDER) private readonly logger: Logger,
36
+ ) {
37
+ this.outOfAnonymityPathConfig =
38
+ this.config.getOrThrow<string[]>('outOfAnonymityPath');
39
+ this.outOfUserPathConfig =
40
+ this.config.getOrThrow<string[]>('outOfUserPath');
41
+ }
42
+
43
+ async canActivate(context: ExecutionContext): Promise<boolean> {
44
+ const request = context.switchToHttp().getRequest<FastifyRequest>();
45
+ const response = context.switchToHttp().getResponse<FastifyReply>();
46
+ const requestMethod = request.method.toLowerCase();
47
+ const requestPath = stringUtil.trimSlashes(
48
+ stringUtil.splitString(request.url, '?')[0],
49
+ );
50
+
51
+ // 检查是否在白名单路径中
52
+ if (
53
+ this.outOfUserPathConfig[requestMethod]?.some((path) =>
54
+ new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(
55
+ requestPath.replace('api/', ''),
56
+ ),
57
+ )
58
+ ) {
59
+ return true;
60
+ }
61
+
62
+ // 从方法处理器获取元数据
63
+ let authTypes = this.reflector.get<string[]>('auths', context.getHandler());
64
+ if (!authTypes) {
65
+ authTypes = this.reflector.get<string[]>('auths', context.getClass());
66
+ }
67
+
68
+ const [authType = 'api', guardType = 'api'] = authTypes || ['api', 'api'];
69
+ const isMpTest = request.headers[MPTRAIL_HEADER] === 'true';
70
+ let userId,
71
+ isAdmin = false,
72
+ isAnonymity = false;
73
+
74
+ if (!process.env.MODE_USER_ID) {
75
+ let access;
76
+ if (guardType === 'sse') {
77
+ access = decodeURIComponent(request.query['access_token'] as string);
78
+ } else {
79
+ access = this.auth.extractTokenFromHeader(request);
80
+ if (!access) {
81
+ throw apiError(CommonErrorCode.UnAuthorized);
82
+ }
83
+ }
84
+ if (!access) {
85
+ throw apiError(CommonErrorCode.UnAuthorized);
86
+ }
87
+
88
+ let payload;
89
+ try {
90
+ const jwtConfig = this.config.getOrThrow<JwtConfig>('jwt');
91
+ payload = await this.jwt.verifyAsync(access, {
92
+ secret: jwtConfig.secret,
93
+ });
94
+ } catch (error) {
95
+ throw apiError(CommonErrorCode.UnAuthorized);
96
+ }
97
+
98
+ userId = payload?.sub;
99
+ isAnonymity = payload?.isAnonymity;
100
+ isAdmin = payload?.isAdmin;
101
+
102
+ if (isAnonymity) {
103
+ throw apiError(CommonErrorCode.UnAuthorized);
104
+ }
105
+
106
+ // 将 JWT payload 中的用户信息设置到 request 中
107
+ (request as any).userInfo = {
108
+ id: userId,
109
+ nickname: payload?.nickname,
110
+ code: payload?.code,
111
+ headerImg: payload?.headerImg,
112
+ sex: payload?.sex,
113
+ isAdmin: isAdmin,
114
+ isAnonymity: isAnonymity,
115
+ };
116
+ } else {
117
+ if (process.env.NODE_ENV === 'prod') {
118
+ console.error(
119
+ '!!! CRITICAL SECURITY ERROR: MODE_USER_ID is set in prod environment! !!!',
120
+ );
121
+ throw apiError(CommonErrorCode.UnAuthorized);
122
+ }
123
+
124
+ console.warn(
125
+ '!!! WARNING: Auth Guard is running in insecure bypass mode. DO NOT USE IN PROD. !!!',
126
+ );
127
+ console.warn(
128
+ `!!! Bypass mode activated with userId: ${process.env.MODE_USER_ID} !!!`,
129
+ );
130
+
131
+ userId = process.env.MODE_USER_ID;
132
+ isAdmin = true;
133
+ isAnonymity = false;
134
+ }
135
+
136
+ if (!userId) {
137
+ throw apiError(CommonErrorCode.UnAuthorized);
138
+ }
139
+
140
+ if (
141
+ request.method.toLowerCase() === 'post' &&
142
+ process.env?.PREVIEW_MODE === 'true' &&
143
+ enviromentUtil.isWeChatMiniProgram(request) &&
144
+ isMpTest &&
145
+ process.env?.PREVIEW_USER_ID
146
+ ) {
147
+ throw apiError(CommonErrorCode.UnAuthorized);
148
+ }
149
+
150
+ if (authType === 'admin' && !isAdmin) {
151
+ throw apiError(CommonErrorCode.UnAuthorized);
152
+ }
153
+
154
+ // 检查匿名用户访问限制
155
+ if (
156
+ this.outOfAnonymityPathConfig[requestMethod]?.some((path) =>
157
+ new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(
158
+ requestPath.replace('api/', ''),
159
+ ),
160
+ ) &&
161
+ (request as any).isAnonymity
162
+ ) {
163
+ throw apiError(CommonErrorCode.UnAuthorized);
164
+ }
165
+
166
+ // 将用户信息设置到request对象中
167
+ (request as any).userId = userId;
168
+ (request as any).isAnonymity = isAnonymity;
169
+ (request as any).isAdmin = isAdmin;
170
+
171
+ return true;
172
+ }
173
+ }
@@ -0,0 +1,23 @@
1
+ import { Module } from '@nestjs/common';
2
+ import { AuthGuard } from './auth.guard';
3
+ import { AuthService } from './auth.service';
4
+ import { AuthValidationService } from './auth-validation.service';
5
+ import { ConfigModule } from '@nestjs/config';
6
+ import { RedisModule } from '@app/redis';
7
+ import { JwtModule } from '@app/jwt/jwt.module';
8
+ import { UserInfoModule, FileSourceModule } from '@app/db';
9
+ import { FileCdnModule } from '@app/clients/internal/file-cdn';
10
+
11
+ @Module({
12
+ imports: [
13
+ ConfigModule,
14
+ RedisModule,
15
+ JwtModule,
16
+ UserInfoModule,
17
+ FileSourceModule,
18
+ FileCdnModule,
19
+ ],
20
+ providers: [AuthGuard, AuthService, AuthValidationService],
21
+ exports: [AuthGuard, AuthService, AuthValidationService],
22
+ })
23
+ export class AuthModule {}
@@ -0,0 +1,198 @@
1
+ import { Inject, Injectable } from '@nestjs/common';
2
+ import { WINSTON_MODULE_PROVIDER } from 'nest-winston';
3
+ import { Logger } from 'winston';
4
+ import { AuthClient } from '@app/auth';
5
+ import stringUtil from '@/utils/string.util';
6
+ import { JwtService } from '@nestjs/jwt';
7
+ import { RedisService } from '@app/redis';
8
+ import { UserInfo } from '@prisma/client';
9
+ import { UserInfoService, FileSourceService } from '@app/db';
10
+ import { FastifyRequest } from 'fastify';
11
+ import { PardxApp } from '@/config/dto/config.dto';
12
+ import { UserErrorCode, CommonErrorCode } from '@repo/contracts/errors';
13
+ import { LoginSuccess } from '@repo/contracts';
14
+ import { apiError } from '@/filter/exception/api.exception';
15
+ import { FileCdnClient } from '@app/clients/internal/file-cdn';
16
+
17
+ @Injectable()
18
+ export class AuthService {
19
+ constructor(
20
+ private readonly redis: RedisService,
21
+ private readonly jwt: JwtService,
22
+ private readonly user: UserInfoService,
23
+ private readonly fileSource: FileSourceService,
24
+ private readonly fileCdn: FileCdnClient,
25
+ @Inject(WINSTON_MODULE_PROVIDER) private readonly logger: Logger,
26
+ ) {}
27
+
28
+ /**
29
+ * 登录成功后的处理函数
30
+ *
31
+ * @param user 用户信息
32
+ * @returns 登录成功后的结果信息
33
+ */
34
+ async loginSuccess(
35
+ user: Partial<UserInfo>,
36
+ deviceInfo: PardxApp.HeaderData,
37
+ ): Promise<LoginSuccess> {
38
+ return await this.refreshTokenByUser(user, deviceInfo);
39
+ }
40
+
41
+ extractTokenFromHeader(request: FastifyRequest): string | undefined {
42
+ const authorizationHeader = request.headers['authorization'] as
43
+ | string
44
+ | undefined;
45
+ if (!authorizationHeader) return undefined;
46
+ const [type, token] = authorizationHeader.split(' ');
47
+ return type === 'Bearer' ? token : undefined;
48
+ }
49
+
50
+ async getUserId(access: string): Promise<string | null> {
51
+ const userId = await this.redis.getData('access', access);
52
+ if (!userId) return null;
53
+ return userId;
54
+ }
55
+
56
+ async getUserSession(userId: string): Promise<AuthClient.Session> {
57
+ const session: AuthClient.Session = await this.redis.getData(
58
+ 'session',
59
+ userId,
60
+ );
61
+ if (!session) return null;
62
+ return session;
63
+ }
64
+
65
+ async getUserSessionByRefresh(refresh: string): Promise<AuthClient.Session> {
66
+ const userId = await this.redis.getData('refresh', refresh);
67
+ if (!userId) return null;
68
+ return (await this.redis.getData('session', userId)) as AuthClient.Session;
69
+ }
70
+
71
+ async getUserSessionByAccess(access: string): Promise<AuthClient.Session> {
72
+ const userId = await this.redis.getData('access', access);
73
+ if (!userId) return null;
74
+ return (await this.redis.getData('session', userId)) as AuthClient.Session;
75
+ }
76
+
77
+ /**
78
+ * 移除原先的会话
79
+ *
80
+ * @param userId 用户ID
81
+ * @returns 返回新生成的AuthClient.Session对象
82
+ */
83
+ async removeSessions(userId: string): Promise<void> {
84
+ const prev = await this.redis.getData('session', userId);
85
+ if (prev) {
86
+ await this.redis.deleteData('refresh', prev.refresh);
87
+ }
88
+ }
89
+
90
+ async refreshTokenByUser(
91
+ user: Partial<UserInfo>,
92
+ deviceInfo: PardxApp.HeaderData,
93
+ ): Promise<LoginSuccess> {
94
+ const tokens: AuthClient.Session = await this.generateTokens(user);
95
+
96
+ await this.redis.saveData('session', tokens.userId, tokens);
97
+ await this.redis.saveData('refresh', tokens.refresh, tokens.userId);
98
+ await this.redis.saveData('access', tokens.access, tokens.userId);
99
+
100
+ return {
101
+ refresh: tokens.refresh,
102
+ expire: tokens.expire,
103
+ access: tokens.access,
104
+ accessExpire: tokens.accessExpire,
105
+ isAnonymity: tokens.isAnonymity,
106
+ user,
107
+ };
108
+ }
109
+
110
+ /**
111
+ * 创建匿名用户
112
+ * 根据设备信息创建匿名用户
113
+ *
114
+ * @param deviceInfo 设备信息
115
+ * @returns 创建的匿名用户
116
+ */
117
+ async createAnonyminyUser(
118
+ _deviceInfo: PardxApp.HeaderData,
119
+ ): Promise<Partial<UserInfo> | null> {
120
+ // TODO: Implement anonymous user creation with new schema
121
+ throw apiError(CommonErrorCode.InternalServerError, {
122
+ message: 'Anonymous user creation not implemented',
123
+ });
124
+ }
125
+
126
+ /**
127
+ * 刷新会话
128
+ * 根据 refresh token 刷新用户会话并返回 LoginSuccess 格式的数据
129
+ *
130
+ * @param refresh refresh token
131
+ * @param deviceInfo 设备信息
132
+ * @returns LoginSuccess 格式的登录数据
133
+ */
134
+ async refreshSession(
135
+ refresh: string,
136
+ deviceInfo: PardxApp.HeaderData,
137
+ ): Promise<LoginSuccess> {
138
+ const session = await this.getUserSessionByRefresh(refresh);
139
+ if (!session || session.isAnonymity) {
140
+ throw apiError(CommonErrorCode.UnAuthorized);
141
+ }
142
+
143
+ const user = await this.user.get({ id: session.userId });
144
+ if (!user) {
145
+ throw apiError(UserErrorCode.UserNotFound);
146
+ }
147
+
148
+ return await this.refreshTokenByUser(user, deviceInfo);
149
+ }
150
+
151
+ async generateTokens(user: Partial<UserInfo>): Promise<AuthClient.Session> {
152
+ const refresh = stringUtil.stringGen(64);
153
+ const accessTtl = this.redis.getExpireIn('access'); // 10分钟
154
+ const ttl = this.redis.getExpireIn('refresh'); // 30天
155
+ const isAnonymity = user?.isAnonymity;
156
+
157
+ // Convert avatarFileId to headerImg URL
158
+ let headerImg: string | undefined;
159
+ if (user.avatarFileId) {
160
+ const avatarFile = await this.fileSource.get({
161
+ id: user.avatarFileId,
162
+ });
163
+ if (avatarFile) {
164
+ headerImg = await this.fileCdn.getImageVolcengineCdn(
165
+ avatarFile.vendor,
166
+ avatarFile.bucket,
167
+ avatarFile.key,
168
+ '360:360:360:360',
169
+ );
170
+ }
171
+ }
172
+
173
+ // 为了与 JWT 标准保持一致,我们选择了 sub 作为属性名来保存 userId
174
+ // 将用户基本信息放入 JWT payload,避免每次都需要查询数据库
175
+ const access = await this.jwt.signAsync({
176
+ sub: user.id,
177
+ isAnonymity: isAnonymity,
178
+ isAdmin: user.isAdmin,
179
+ // 添加常用用户信息字段,避免每次都需要 getUserInfo
180
+ nickname: user.nickname,
181
+ code: user.code,
182
+ headerImg,
183
+ sex: user.sex,
184
+ });
185
+ const now = Date.now();
186
+ const expire = now + ttl * 1000;
187
+ const accessExpire = now + accessTtl * 1000;
188
+
189
+ return {
190
+ userId: user.id,
191
+ refresh,
192
+ access,
193
+ expire,
194
+ accessExpire,
195
+ isAnonymity,
196
+ };
197
+ }
198
+ }
@@ -0,0 +1,66 @@
1
+ import { applyDecorators, SetMetadata, UseGuards } from '@nestjs/common';
2
+ import { AuthGuard } from './auth.guard';
3
+ import { ApiBearerAuth } from '@nestjs/swagger';
4
+
5
+ /**
6
+ * Auth 装饰器选项
7
+ */
8
+ export interface AuthOptions {
9
+ /**
10
+ * 是否启用 RBAC 权限检查
11
+ * @default true
12
+ */
13
+ enableRbac?: boolean;
14
+
15
+ /**
16
+ * 是否启用模块权限检查
17
+ * 启用后会自动检查 @RequireModulePermission 等装饰器配置的权限
18
+ * @default true
19
+ */
20
+ enableModulePermission?: boolean;
21
+ }
22
+
23
+ /**
24
+ * 基础认证装饰器
25
+ * 现在已集成 RBAC 权限检查和模块权限检查功能
26
+ *
27
+ * @deprecated 该装饰器已废弃,请使用新的统一装饰器:
28
+ * - 简单认证: @SimpleAuth()
29
+ * - 只读操作: @ReadOnlyAuth(module, resource)
30
+ * - 管理员权限: @AdminAuth(isSuperAdmin?)
31
+ *
32
+ * 详见文档: apps/api/docs/Controller装饰器优化记录.md
33
+ *
34
+ * @param authType 认证类型:'api' | 'admin'
35
+ * @param guardType Guard类型:'sse' | 'api'
36
+ * @param options 选项对象或布尔值(向后兼容 enableRbac)
37
+ * @returns 装饰器组合
38
+ *
39
+ * @example
40
+ * // ❌ 旧写法(已废弃)
41
+ * @Auth()
42
+ * @RequireModulePermission('recruitment', 'job', 'create')
43
+ *
44
+ * // ✅ 新写法(推荐)
45
+ * @ReadOnlyAuth('recruitment', 'job')
46
+ */
47
+ export function Auth(
48
+ authType: 'api' | 'admin' = 'api',
49
+ guardType: 'sse' | 'api' = 'api',
50
+ options: AuthOptions | boolean = {},
51
+ ) {
52
+ // 向后兼容:如果 options 是布尔值,转换为对象
53
+ const normalizedOptions: AuthOptions =
54
+ typeof options === 'boolean' ? { enableRbac: options } : options;
55
+
56
+ const { enableRbac = true, enableModulePermission = true } =
57
+ normalizedOptions;
58
+
59
+ return applyDecorators(
60
+ SetMetadata('auths', [authType, guardType]),
61
+ SetMetadata('enableRbac', enableRbac),
62
+ SetMetadata('enableModulePermission', enableModulePermission),
63
+ UseGuards(AuthGuard),
64
+ ApiBearerAuth,
65
+ );
66
+ }
@@ -0,0 +1,50 @@
1
+ import { applyDecorators } from '@nestjs/common';
2
+ import { Auth } from '../auth';
3
+ import { RequireSuperAdmin } from './rbac.decorator';
4
+ /**
5
+ * 管理员权限预设
6
+ *
7
+ * @param requireSuper 是否要求系统超级管理员(默认 false,只要求团队管理员)
8
+ *
9
+ * @example
10
+ * @AdminAuth() // 团队管理员
11
+ *
12
+ * @AdminAuth(true) // 系统超级管理员
13
+ * async systemSettings() {}
14
+ */
15
+ export function AdminAuth() {
16
+ return applyDecorators(Auth('api', 'api'), RequireSuperAdmin());
17
+ }
18
+ /**
19
+ * 纯认证装饰器(无团队上下文,无权限检查)
20
+ * 适用于用户个人信息相关接口
21
+ *
22
+ * @example
23
+ * @SimpleAuth()
24
+ * async getUserProfile() {}
25
+ */
26
+ export function SimpleAuth() {
27
+ return Auth('api', 'api', {
28
+ enableModulePermission: false,
29
+ enableRbac: false,
30
+ });
31
+ }
32
+
33
+ /**
34
+ * SSE 认证装饰器(无团队上下文,无权限检查)
35
+ * 适用于 Server-Sent Events 端点
36
+ *
37
+ * 注意:SSE 端点因为 EventSource 不支持自定义 headers,
38
+ * 所以需要从 query 参数获取 access_token
39
+ *
40
+ * @example
41
+ * @SseAuth()
42
+ * @Sse('message/unread')
43
+ * async getUnreadMessageCountStream() {}
44
+ */
45
+ export function SseAuth() {
46
+ return Auth('api', 'sse', {
47
+ enableModulePermission: false,
48
+ enableRbac: false,
49
+ });
50
+ }
@@ -0,0 +1,67 @@
1
+ import { SetMetadata } from '@nestjs/common';
2
+
3
+ // 超级管理员检查装饰器
4
+ export const RequireSuperAdmin = () => SetMetadata('superAdmin', true);
5
+
6
+ /**
7
+ * 细粒度模块权限装饰器
8
+ */
9
+ export interface ModulePermissionMeta {
10
+ module: string;
11
+ resource: string;
12
+ action: string;
13
+ }
14
+
15
+ // 模块权限检查装饰器的元数据 key
16
+ export const MODULE_PERMISSION_KEY = 'modulePermission';
17
+
18
+ /**
19
+ * 模块权限检查装饰器
20
+ * 用于细粒度的模块级权限控制
21
+ *
22
+ * @example
23
+ * @RequireModulePermission('recruitment', 'job', 'create')
24
+ * async createJob() { ... }
25
+ */
26
+ export const RequireModulePermission = (
27
+ module: string,
28
+ resource: string,
29
+ action: string,
30
+ ) =>
31
+ SetMetadata(MODULE_PERMISSION_KEY, {
32
+ module,
33
+ resource,
34
+ action,
35
+ } as ModulePermissionMeta);
36
+
37
+ /**
38
+ * 多个模块权限检查装饰器(满足任一条件即可)
39
+ *
40
+ * @example
41
+ * ```typescript
42
+ * @RequireAnyModulePermission([
43
+ * { module: 'recruitment', resource: 'job', action: 'read' },
44
+ * { module: 'recruitment', resource: 'candidate', action: 'read' },
45
+ * ])
46
+ * async viewRecruitmentData() { ... }
47
+ * ```
48
+ */
49
+ export const RequireAnyModulePermission = (
50
+ permissions: ModulePermissionMeta[],
51
+ ) => SetMetadata('anyModulePermission', permissions);
52
+
53
+ /**
54
+ * 多个模块权限检查装饰器(必须满足所有条件)
55
+ *
56
+ * @example
57
+ * ```typescript
58
+ * @RequireAllModulePermissions([
59
+ * { module: 'recruitment', resource: 'job', action: 'read' },
60
+ * { module: 'recruitment', resource: 'candidate', action: 'create' },
61
+ * ])
62
+ * async createCandidateForJob() { ... }
63
+ * ```
64
+ */
65
+ export const RequireAllModulePermissions = (
66
+ permissions: ModulePermissionMeta[],
67
+ ) => SetMetadata('allModulePermissions', permissions);
@@ -0,0 +1,67 @@
1
+ import { SetMetadata, UseGuards, applyDecorators } from '@nestjs/common';
2
+
3
+ export const RESOURCE_OWNER_KEY = 'resource_owner_check';
4
+
5
+ /**
6
+ * 资源所有者检查配置
7
+ */
8
+ export interface ResourceOwnerCheck {
9
+ resourceType: 'fileSystem';
10
+ paramSource: 'params' | 'query' | 'body';
11
+ resourceIdField: string; // 资源 ID 在请求参数中的字段名
12
+ allowSystemAdmin?: boolean; // 是否允许系统管理员访问(默认 true)
13
+ }
14
+
15
+ /**
16
+ * 要求请求者是资源所有者
17
+ *
18
+ * @example
19
+ * // 基础用法 - 会议记录
20
+ * @RequireResourceOwner({
21
+ * resourceType: 'meetingRecord',
22
+ * paramSource: 'params',
23
+ * resourceIdField: 'id',
24
+ * })
25
+ * async deleteMeeting() {}
26
+ *
27
+ * @example
28
+ * // 文件系统(文件/文件夹)
29
+ * @RequireResourceOwner({
30
+ * resourceType: 'fileSystem',
31
+ * paramSource: 'params',
32
+ * resourceIdField: 'fileId',
33
+ * })
34
+ * async deleteFile() {}
35
+ *
36
+ * @example
37
+ * // 只允许所有者
38
+ * @RequireResourceOwner({
39
+ * resourceType: 'candidate',
40
+ * paramSource: 'params',
41
+ * resourceIdField: 'id',
42
+ * })
43
+ * async deleteCandidate() {}
44
+ *
45
+ * @example
46
+ * // 候选人 - 检查上传者
47
+ * @RequireResourceOwner({
48
+ * resourceType: 'candidate',
49
+ * paramSource: 'params',
50
+ * resourceIdField: 'candidateId',
51
+ * })
52
+ * async updateCandidate() {}
53
+ */
54
+ export const RequireResourceOwner = (
55
+ check: ResourceOwnerCheck,
56
+ ): MethodDecorator => {
57
+ // 导入 Guard(延迟导入避免循环依赖)
58
+ const { ResourceOwnerGuard } = require('../guards/resource-owner.guard');
59
+
60
+ return applyDecorators(
61
+ SetMetadata(RESOURCE_OWNER_KEY, {
62
+ ...check,
63
+ allowSystemAdmin: check.allowSystemAdmin ?? true,
64
+ }),
65
+ UseGuards(ResourceOwnerGuard),
66
+ );
67
+ };
@@ -0,0 +1,10 @@
1
+ export namespace AuthClient {
2
+ export interface Session {
3
+ userId: string;
4
+ access: string;
5
+ accessExpire: number;
6
+ refresh: string;
7
+ expire: number;
8
+ isAnonymity: boolean;
9
+ }
10
+ }