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,508 @@
1
+ # OpenSpeech 语音识别服务
2
+
3
+ 多云服务商语音识别能力的统一封装模块,支持阿里云和火山引擎。
4
+
5
+ ## 功能特性
6
+
7
+ - **录音文件识别(AUC)**:异步提交音频文件,轮询或回调获取结果
8
+ - **流式语音识别(SAUC)**:实时音频流转写,WebSocket 双向通信
9
+ - **多云服务商支持**:阿里云 NLS、火山引擎大模型
10
+ - **统一 API 接口**:Facade 模式封装,简化调用
11
+
12
+ ## 目录结构
13
+
14
+ ```text
15
+ openspeech/
16
+ ├── index.ts # 模块导出入口
17
+ ├── types.ts # 类型定义
18
+ ├── openspeech.module.ts # NestJS 模块配置
19
+ ├── openspeech.client.ts # 统一客户端(Facade)
20
+ ├── openspeech.factory.ts # 提供商工厂
21
+ ├── providers/ # 云服务商实现
22
+ │ ├── index.ts # 提供商导出
23
+ │ ├── base.provider.ts # 抽象基类
24
+ │ ├── aliyun.provider.ts # 阿里云录音识别
25
+ │ ├── volcengine.provider.ts # 火山引擎录音识别
26
+ │ └── volcengine-streaming.provider.ts # 火山引擎流式识别
27
+ └── README.md # 本文档
28
+ ```
29
+
30
+ ## 架构设计
31
+
32
+ 采用 **Facade + Factory + Strategy** 模式:
33
+
34
+ ```text
35
+ ┌─────────────────────────────────────────────────────────────────────────┐
36
+ │ OpenspeechClient │
37
+ │ (Facade 门面) │
38
+ │ - 提供统一的 API 接口(录音识别 + 流式识别) │
39
+ │ - 处理 FileKey 到音频 URL 的转换 │
40
+ │ - 选择云服务商 │
41
+ └───────────────────────────────┬─────────────────────────────────────────┘
42
+
43
+
44
+ ┌─────────────────────────────────────────────────────────────────────────┐
45
+ │ OpenspeechProviderFactory │
46
+ │ (Factory 工厂) │
47
+ │ - 根据 vendor 创建对应提供商 │
48
+ │ - 单例模式缓存实例 │
49
+ │ - 管理提供商生命周期 │
50
+ │ - 支持录音识别(AUC)和流式识别(SAUC)两种模式 │
51
+ └───────────┬───────────────────────────────────────────┬─────────────────┘
52
+ │ │
53
+ ▼ ▼
54
+ ┌───────────────────────────────────────┐ ┌─────────────────────────────┐
55
+ │ 录音文件识别提供商 │ │ 流式识别提供商 │
56
+ │ IOpenspeechProvider │ │ IStreamingAsrProvider │
57
+ ├───────────────────────────────────────┤ ├─────────────────────────────┤
58
+ │ AliyunOpenspeechProvider (oss) │ │ VolcengineStreamingAsr- │
59
+ │ VolcengineOpenspeechProvider (tos) │ │ Provider (tos) │
60
+ └───────────────────────────────────────┘ └─────────────────────────────┘
61
+ ```
62
+
63
+ ## 快速开始
64
+
65
+ ### 1. 导入模块
66
+
67
+ ```typescript
68
+ import { Module } from '@nestjs/common';
69
+ import { OpenspeechModule } from '@app/clients/internal/openspeech';
70
+
71
+ @Module({
72
+ imports: [OpenspeechModule],
73
+ })
74
+ export class VideoModule {}
75
+ ```
76
+
77
+ ### 2. 注入使用
78
+
79
+ ```typescript
80
+ import { Injectable } from '@nestjs/common';
81
+ import { OpenspeechClient } from '@app/clients/internal/openspeech';
82
+ import { FileKey, FileBucketVendor } from '@prisma/client';
83
+
84
+ @Injectable()
85
+ export class VideoService {
86
+ constructor(private readonly openspeech: OpenspeechClient) {}
87
+
88
+ // ... 使用示例见下文
89
+ }
90
+ ```
91
+
92
+ ## API 参考
93
+
94
+ ### 录音文件识别
95
+
96
+ #### `submitTranscribeTask(fileKey): Promise<SubmitTaskResult>`
97
+
98
+ 提交语音识别任务。
99
+
100
+ **参数:**
101
+
102
+ - `fileKey.vendor` - 存储服务商(`oss` | `tos`)
103
+ - `fileKey.bucket` - 存储桶名称
104
+ - `fileKey.key` - 文件路径(视频文件,会自动推导音频路径)
105
+ - `fileKey.preferVendor` - 可选,优先使用的云服务商
106
+
107
+ **返回:**
108
+
109
+ ```typescript
110
+ {
111
+ vendor: 'oss' | 'tos'; // 实际使用的云服务商
112
+ vendorTaskId: string; // 云服务商任务 ID
113
+ audioUrl: string; // 音频文件 URL
114
+ }
115
+ ```
116
+
117
+ **示例:**
118
+
119
+ ```typescript
120
+ const { vendor, vendorTaskId, audioUrl } =
121
+ await this.openspeech.submitTranscribeTask(fileKey);
122
+
123
+ // 保存 vendorTaskId 到数据库,等待回调通知或定时轮询
124
+ ```
125
+
126
+ #### `queryTranscribeTaskStatus(vendor, vendorTaskId): Promise<TaskStatusResult>`
127
+
128
+ 查询任务状态。
129
+
130
+ **返回:**
131
+
132
+ ```typescript
133
+ {
134
+ status: 'processing' | 'success' | 'error';
135
+ text?: string; // 成功时的识别文本
136
+ error?: string; // 失败时的错误信息
137
+ }
138
+ ```
139
+
140
+ **示例:**
141
+
142
+ ```typescript
143
+ const result = await this.openspeech.queryTranscribeTaskStatus(vendor, taskId);
144
+
145
+ if (result.status === 'success') {
146
+ console.log('识别结果:', result.text);
147
+ } else if (result.status === 'error') {
148
+ throw new Error(result.error);
149
+ }
150
+ ```
151
+
152
+ #### `transcribeFromFileKey(fileKey): Promise<string>`
153
+
154
+ 同步识别(会阻塞直到完成)。
155
+
156
+ > 不推荐在生产环境使用,建议使用异步模式。
157
+
158
+ ### 流式语音识别
159
+
160
+ #### `connectStreaming(vendor, params, callbacks): Promise<string>`
161
+
162
+ 建立流式识别 WebSocket 连接。
163
+
164
+ **参数:**
165
+
166
+ - `vendor` - 云服务商类型(目前仅支持 `'tos'`)
167
+ - `params.sessionId` - 会话 ID
168
+ - `params.audioFormat` - 音频格式(默认 `'pcm'`)
169
+ - `params.sampleRate` - 采样率(默认 `16000`)
170
+ - `params.channels` - 声道数(默认 `1`)
171
+ - `params.enableSpeakerInfo` - 是否启用说话人分离(默认 `true`)
172
+ - `callbacks.onResult` - 收到识别结果回调
173
+ - `callbacks.onConnected` - 连接建立回调
174
+ - `callbacks.onDisconnected` - 连接关闭回调
175
+ - `callbacks.onError` - 错误回调
176
+
177
+ **返回:** 连接 ID
178
+
179
+ **示例:**
180
+
181
+ ```typescript
182
+ const connectionId = await this.openspeech.connectStreaming(
183
+ 'tos',
184
+ {
185
+ sessionId: 'session-123',
186
+ audioFormat: 'pcm',
187
+ sampleRate: 16000,
188
+ enableSpeakerInfo: true,
189
+ },
190
+ {
191
+ onResult: (result) => {
192
+ console.log('识别结果:', result.text);
193
+ if (result.isFinal) {
194
+ console.log('最终结果');
195
+ }
196
+ if (result.utterances) {
197
+ // 说话人分离数据
198
+ result.utterances.forEach(u => {
199
+ console.log(`${u.speakerId}: ${u.text}`);
200
+ });
201
+ }
202
+ },
203
+ onConnected: () => console.log('WebSocket 已连接'),
204
+ onDisconnected: () => console.log('WebSocket 已断开'),
205
+ onError: (error) => console.error('错误:', error),
206
+ }
207
+ );
208
+ ```
209
+
210
+ #### `sendStreamingAudio(vendor, connectionId, audioData, isLast?): Promise<void>`
211
+
212
+ 发送音频数据到流式识别连接。
213
+
214
+ **参数:**
215
+
216
+ - `vendor` - 云服务商类型
217
+ - `connectionId` - 连接 ID
218
+ - `audioData` - 音频数据(Buffer)
219
+ - `isLast` - 是否为最后一帧(默认 `false`)
220
+
221
+ **示例:**
222
+
223
+ ```typescript
224
+ // 持续发送音频数据
225
+ await this.openspeech.sendStreamingAudio('tos', connectionId, audioChunk);
226
+
227
+ // 发送最后一帧
228
+ await this.openspeech.sendStreamingAudio('tos', connectionId, lastChunk, true);
229
+ ```
230
+
231
+ #### `disconnectStreaming(vendor, connectionId): Promise<void>`
232
+
233
+ 关闭流式识别连接。
234
+
235
+ ```typescript
236
+ await this.openspeech.disconnectStreaming('tos', connectionId);
237
+ ```
238
+
239
+ #### `getStreamingStatus(vendor, connectionId): StreamingAsrStatus`
240
+
241
+ 获取流式识别连接状态。
242
+
243
+ **返回值:**
244
+
245
+ - `'connecting'` - 正在连接
246
+ - `'connected'` - 已连接
247
+ - `'streaming'` - 正在识别
248
+ - `'completed'` - 识别完成
249
+ - `'error'` - 发生错误
250
+ - `'disconnected'` - 已断开
251
+
252
+ #### `isStreamingAvailable(vendor): boolean`
253
+
254
+ 检查指定云服务商是否支持流式识别。
255
+
256
+ #### `getStreamingAvailableVendors(): FileBucketVendor[]`
257
+
258
+ 获取所有支持流式识别的云服务商列表。
259
+
260
+ ### 高级用法
261
+
262
+ 直接操作提供商实例:
263
+
264
+ ```typescript
265
+ import { OpenspeechProviderFactory } from '@app/clients/internal/openspeech';
266
+
267
+ // 获取录音识别提供商
268
+ const provider = factory.getProvider('oss');
269
+
270
+ // 获取流式识别提供商
271
+ const streamingProvider = factory.getStreamingProvider('tos');
272
+
273
+ // 检查可用性
274
+ const isAvailable = factory.isVendorAvailable('tos');
275
+ const isStreamingAvailable = factory.isStreamingAvailable('tos');
276
+
277
+ // 获取所有可用云服务商
278
+ const vendors = factory.getAvailableVendors();
279
+ const streamingVendors = factory.getStreamingAvailableVendors();
280
+
281
+ // 流式提供商高级方法
282
+ const transcript = streamingProvider.getTranscript(connectionId);
283
+ const activeCount = streamingProvider.getActiveConnectionCount();
284
+ await streamingProvider.cleanupAllConnections();
285
+ ```
286
+
287
+ ## 完整使用示例
288
+
289
+ ### 录音文件识别(异步模式)
290
+
291
+ ```typescript
292
+ @Injectable()
293
+ export class TranscriptionService {
294
+ constructor(private readonly openspeech: OpenspeechClient) {}
295
+
296
+ async startTranscription(fileKey: FileKey) {
297
+ const { vendor, vendorTaskId, audioUrl } =
298
+ await this.openspeech.submitTranscribeTask(fileKey);
299
+
300
+ // 保存任务信息到数据库
301
+ await this.saveTask({ vendor, vendorTaskId, audioUrl });
302
+
303
+ return { vendor, vendorTaskId };
304
+ }
305
+
306
+ async checkStatus(vendor: FileBucketVendor, taskId: string) {
307
+ const result = await this.openspeech.queryTranscribeTaskStatus(vendor, taskId);
308
+
309
+ if (result.status === 'success') {
310
+ return { completed: true, text: result.text };
311
+ } else if (result.status === 'error') {
312
+ throw new Error(result.error);
313
+ }
314
+
315
+ return { completed: false };
316
+ }
317
+ }
318
+ ```
319
+
320
+ ### 流式语音识别示例
321
+
322
+ ```typescript
323
+ @Injectable()
324
+ export class RealtimeTranscriptionService {
325
+ private connectionId?: string;
326
+
327
+ constructor(private readonly openspeech: OpenspeechClient) {}
328
+
329
+ async startStreaming(sessionId: string, onText: (text: string) => void) {
330
+ // 检查流式识别是否可用
331
+ if (!this.openspeech.isStreamingAvailable('tos')) {
332
+ throw new Error('Streaming ASR not available');
333
+ }
334
+
335
+ this.connectionId = await this.openspeech.connectStreaming(
336
+ 'tos',
337
+ { sessionId, audioFormat: 'pcm', enableSpeakerInfo: true },
338
+ {
339
+ onResult: (result) => {
340
+ onText(result.text);
341
+ if (result.isFinal) {
342
+ console.log('识别完成');
343
+ }
344
+ },
345
+ onError: (error) => {
346
+ console.error('流式识别错误:', error);
347
+ },
348
+ }
349
+ );
350
+
351
+ return this.connectionId;
352
+ }
353
+
354
+ async sendAudio(audioData: Buffer, isLast = false) {
355
+ if (!this.connectionId) {
356
+ throw new Error('No active connection');
357
+ }
358
+ await this.openspeech.sendStreamingAudio('tos', this.connectionId, audioData, isLast);
359
+ }
360
+
361
+ async stopStreaming() {
362
+ if (this.connectionId) {
363
+ await this.openspeech.disconnectStreaming('tos', this.connectionId);
364
+ this.connectionId = undefined;
365
+ }
366
+ }
367
+ }
368
+ ```
369
+
370
+ ## 云服务商配置
371
+
372
+ ### 阿里云 (oss)
373
+
374
+ 配置路径:`config.openspeech.oss`
375
+
376
+ ```typescript
377
+ {
378
+ accessKeyId: string; // AccessKey ID
379
+ accessKeySecret: string; // AccessKey Secret
380
+ endpoint: string; // API 端点
381
+ nslAppKey: string; // NLS 应用 AppKey
382
+ }
383
+ ```
384
+
385
+ 参考文档:[阿里云录音文件识别](https://help.aliyun.com/document_detail/90727.html)
386
+
387
+ ### 火山引擎 (tos)
388
+
389
+ 配置路径:`config.openspeech.tos`
390
+
391
+ ```typescript
392
+ {
393
+ appId: string; // 应用 ID
394
+ appAccessToken: string; // 应用访问令牌
395
+ uid: string; // 用户 ID
396
+ appAccessSecret?: string; // 应用访问密钥(可选)
397
+ accessKey?: string; // Access Key(用于签名,可选)
398
+ secretKey?: string; // Secret Key(用于签名,可选)
399
+
400
+ // 录音文件识别配置
401
+ auc: {
402
+ endpoint: string; // API 端点
403
+ resourceId: string; // 资源 ID
404
+ };
405
+
406
+ // 流式语音识别配置
407
+ sauc: {
408
+ endpoint: string; // WebSocket 端点
409
+ resourceId: string; // 资源 ID
410
+ };
411
+ }
412
+ ```
413
+
414
+ 参考文档:
415
+
416
+ - [火山引擎大模型录音文件识别](https://www.volcengine.com/docs/6561/1354868)
417
+ - [火山引擎大模型流式语音识别](https://www.volcengine.com/docs/6561/1354869)
418
+
419
+ ## 回调处理
420
+
421
+ 两个云服务商都支持回调通知,回调 URL 格式:
422
+
423
+ - 阿里云:`{API_BASE_URL}/webhook/audio-transcribe/oss`
424
+ - 火山引擎:`{API_BASE_URL}/webhook/audio-transcribe/tos`
425
+
426
+ ## 流式识别特性
427
+
428
+ 火山引擎流式识别 Provider 提供以下高级特性:
429
+
430
+ - **心跳机制**:自动发送心跳包保持连接活跃
431
+ - **自动重连**:连接异常断开时自动尝试重连(指数退避策略)
432
+ - **音频缓冲**:重连期间自动缓冲音频数据,重连成功后发送
433
+ - **说话人分离**:支持多说话人场景,返回每个说话人的识别结果
434
+ - **连接池管理**:支持多个并发连接,统一管理
435
+
436
+ ## 扩展新的云服务商
437
+
438
+ ### 添加录音识别提供商
439
+
440
+ 1. 创建新的提供商类,继承 `BaseOpenspeechProvider`
441
+ 2. 实现 `submitTask` 和 `queryTaskStatus` 方法
442
+ 3. 在 `OpenspeechProviderFactory` 中添加创建逻辑
443
+
444
+ ```typescript
445
+ // providers/new-vendor.provider.ts
446
+ export class NewVendorProvider extends BaseOpenspeechProvider {
447
+ readonly vendor: FileBucketVendor = 'new-vendor';
448
+
449
+ async submitTask(params: SubmitTaskParams): Promise<string> {
450
+ // 实现提交逻辑
451
+ }
452
+
453
+ async queryTaskStatus(vendorTaskId: string): Promise<TaskStatusResult> {
454
+ // 实现查询逻辑
455
+ }
456
+ }
457
+ ```
458
+
459
+ ### 添加流式识别提供商
460
+
461
+ 1. 创建新的提供商类,实现 `IStreamingAsrProvider` 接口
462
+ 2. 实现 `connect`、`sendAudio`、`disconnect`、`getConnectionStatus` 方法
463
+ 3. 在 `OpenspeechProviderFactory.createStreamingProvider` 中添加创建逻辑
464
+
465
+ ```typescript
466
+ // providers/new-vendor-streaming.provider.ts
467
+ export class NewVendorStreamingProvider implements IStreamingAsrProvider {
468
+ readonly vendor = 'new-vendor-streaming';
469
+
470
+ async connect(params: StreamingConnectParams, callbacks: StreamingAsrCallbacks): Promise<string> {
471
+ // 实现连接逻辑
472
+ }
473
+
474
+ async sendAudio(connectionId: string, audioData: Buffer, isLast?: boolean): Promise<void> {
475
+ // 实现发送逻辑
476
+ }
477
+
478
+ async disconnect(connectionId: string): Promise<void> {
479
+ // 实现断开逻辑
480
+ }
481
+
482
+ getConnectionStatus(connectionId: string): StreamingAsrStatus {
483
+ // 实现状态查询
484
+ }
485
+ }
486
+ ```
487
+
488
+ ## 更新日志
489
+
490
+ ### v2.1.0
491
+
492
+ - 添加流式语音识别支持(火山引擎 SAUC)
493
+ - `OpenspeechClient` 新增流式识别方法
494
+ - `OpenspeechProviderFactory` 支持流式提供商管理
495
+ - 新增 `VolcengineStreamingAsrProvider`,支持:
496
+ - WebSocket 双向流式通信
497
+ - 心跳机制和自动重连
498
+ - 说话人分离
499
+ - 音频缓冲
500
+
501
+ ### v2.0.0
502
+
503
+ - 采用 Facade + Factory + Strategy 模式重构
504
+ - 分离阿里云和火山引擎实现到独立文件
505
+ - 添加完整的 TypeScript 类型定义
506
+ - 添加详细的 JSDoc 文档注释
507
+ - 支持提供商工厂的单例缓存
508
+ - 向后兼容原有 API 接口
@@ -0,0 +1,44 @@
1
+ /**
2
+ * @fileoverview OpenSpeech 语音识别服务导出
3
+ *
4
+ * 本模块提供多云服务商语音识别能力的统一封装。
5
+ *
6
+ * 支持的云服务商:
7
+ * - 阿里云 NLS 录音文件识别
8
+ * - 火山引擎大模型录音文件识别
9
+ *
10
+ * @module openspeech
11
+ *
12
+ * @example
13
+ * ```typescript
14
+ * // 导入模块
15
+ * import { OpenspeechModule, OpenspeechClient } from '@app/clients/internal/openspeech';
16
+ *
17
+ * // 在 NestJS 模块中使用
18
+ * @Module({
19
+ * imports: [OpenspeechModule],
20
+ * })
21
+ * export class MyModule {}
22
+ *
23
+ * // 在服务中注入使用
24
+ * @Injectable()
25
+ * class MyService {
26
+ * constructor(private readonly openspeech: OpenspeechClient) {}
27
+ * }
28
+ * ```
29
+ */
30
+
31
+ // 模块导出
32
+ export * from './openspeech.module';
33
+
34
+ // 客户端导出
35
+ export * from './openspeech.client';
36
+
37
+ // 工厂导出
38
+ export * from './openspeech.factory';
39
+
40
+ // 类型导出
41
+ export * from './types';
42
+
43
+ // 提供商导出(用于高级场景)
44
+ export * from './providers';