llm-content-creator 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 (438) hide show
  1. package/README.md +309 -0
  2. package/dist/application/workflow/SyncExecutor.d.ts +75 -0
  3. package/dist/application/workflow/SyncExecutor.d.ts.map +1 -0
  4. package/dist/application/workflow/SyncExecutor.js +370 -0
  5. package/dist/application/workflow/SyncExecutor.js.map +1 -0
  6. package/dist/application/workflow/types.d.ts +46 -0
  7. package/dist/application/workflow/types.d.ts.map +1 -0
  8. package/dist/application/workflow/types.js +7 -0
  9. package/dist/application/workflow/types.js.map +1 -0
  10. package/dist/config/index.d.ts +173 -0
  11. package/dist/config/index.d.ts.map +1 -0
  12. package/dist/config/index.js +288 -0
  13. package/dist/config/index.js.map +1 -0
  14. package/dist/domain/entities/QualityCheck.d.ts +181 -0
  15. package/dist/domain/entities/QualityCheck.d.ts.map +1 -0
  16. package/dist/domain/entities/QualityCheck.js +39 -0
  17. package/dist/domain/entities/QualityCheck.js.map +1 -0
  18. package/dist/domain/entities/Result.d.ts +103 -0
  19. package/dist/domain/entities/Result.d.ts.map +1 -0
  20. package/dist/domain/entities/Result.js +15 -0
  21. package/dist/domain/entities/Result.js.map +1 -0
  22. package/dist/domain/entities/Task.d.ts +130 -0
  23. package/dist/domain/entities/Task.d.ts.map +1 -0
  24. package/dist/domain/entities/Task.js +64 -0
  25. package/dist/domain/entities/Task.js.map +1 -0
  26. package/dist/domain/entities/TaskStep.d.ts +160 -0
  27. package/dist/domain/entities/TaskStep.d.ts.map +1 -0
  28. package/dist/domain/entities/TaskStep.js +30 -0
  29. package/dist/domain/entities/TaskStep.js.map +1 -0
  30. package/dist/domain/entities/TokenUsage.d.ts +70 -0
  31. package/dist/domain/entities/TokenUsage.d.ts.map +1 -0
  32. package/dist/domain/entities/TokenUsage.js +42 -0
  33. package/dist/domain/entities/TokenUsage.js.map +1 -0
  34. package/dist/domain/entities/index.d.ts +11 -0
  35. package/dist/domain/entities/index.d.ts.map +1 -0
  36. package/dist/domain/entities/index.js +16 -0
  37. package/dist/domain/entities/index.js.map +1 -0
  38. package/dist/domain/repositories/QualityCheckRepository.d.ts +49 -0
  39. package/dist/domain/repositories/QualityCheckRepository.d.ts.map +1 -0
  40. package/dist/domain/repositories/QualityCheckRepository.js +5 -0
  41. package/dist/domain/repositories/QualityCheckRepository.js.map +1 -0
  42. package/dist/domain/repositories/ResultRepository.d.ts +43 -0
  43. package/dist/domain/repositories/ResultRepository.d.ts.map +1 -0
  44. package/dist/domain/repositories/ResultRepository.js +5 -0
  45. package/dist/domain/repositories/ResultRepository.js.map +1 -0
  46. package/dist/domain/repositories/TaskRepository.d.ts +240 -0
  47. package/dist/domain/repositories/TaskRepository.d.ts.map +1 -0
  48. package/dist/domain/repositories/TaskRepository.js +7 -0
  49. package/dist/domain/repositories/TaskRepository.js.map +1 -0
  50. package/dist/domain/workflow/CheckpointManager.d.ts +94 -0
  51. package/dist/domain/workflow/CheckpointManager.d.ts.map +1 -0
  52. package/dist/domain/workflow/CheckpointManager.js +224 -0
  53. package/dist/domain/workflow/CheckpointManager.js.map +1 -0
  54. package/dist/domain/workflow/ContentCreatorGraph.d.ts +17 -0
  55. package/dist/domain/workflow/ContentCreatorGraph.d.ts.map +1 -0
  56. package/dist/domain/workflow/ContentCreatorGraph.js +381 -0
  57. package/dist/domain/workflow/ContentCreatorGraph.js.map +1 -0
  58. package/dist/domain/workflow/State.d.ts +172 -0
  59. package/dist/domain/workflow/State.d.ts.map +1 -0
  60. package/dist/domain/workflow/State.js +184 -0
  61. package/dist/domain/workflow/State.js.map +1 -0
  62. package/dist/domain/workflow/index.d.ts +11 -0
  63. package/dist/domain/workflow/index.d.ts.map +1 -0
  64. package/dist/domain/workflow/index.js +15 -0
  65. package/dist/domain/workflow/index.js.map +1 -0
  66. package/dist/domain/workflow/nodes/BaseNode.d.ts +134 -0
  67. package/dist/domain/workflow/nodes/BaseNode.d.ts.map +1 -0
  68. package/dist/domain/workflow/nodes/BaseNode.js +253 -0
  69. package/dist/domain/workflow/nodes/BaseNode.js.map +1 -0
  70. package/dist/domain/workflow/nodes/CheckImageNode.d.ts +43 -0
  71. package/dist/domain/workflow/nodes/CheckImageNode.d.ts.map +1 -0
  72. package/dist/domain/workflow/nodes/CheckImageNode.js +254 -0
  73. package/dist/domain/workflow/nodes/CheckImageNode.js.map +1 -0
  74. package/dist/domain/workflow/nodes/CheckTextNode.d.ts +66 -0
  75. package/dist/domain/workflow/nodes/CheckTextNode.d.ts.map +1 -0
  76. package/dist/domain/workflow/nodes/CheckTextNode.js +530 -0
  77. package/dist/domain/workflow/nodes/CheckTextNode.js.map +1 -0
  78. package/dist/domain/workflow/nodes/GenerateImageNode.d.ts +44 -0
  79. package/dist/domain/workflow/nodes/GenerateImageNode.d.ts.map +1 -0
  80. package/dist/domain/workflow/nodes/GenerateImageNode.js +272 -0
  81. package/dist/domain/workflow/nodes/GenerateImageNode.js.map +1 -0
  82. package/dist/domain/workflow/nodes/OrganizeNode.d.ts +49 -0
  83. package/dist/domain/workflow/nodes/OrganizeNode.d.ts.map +1 -0
  84. package/dist/domain/workflow/nodes/OrganizeNode.js +241 -0
  85. package/dist/domain/workflow/nodes/OrganizeNode.js.map +1 -0
  86. package/dist/domain/workflow/nodes/SearchNode.d.ts +48 -0
  87. package/dist/domain/workflow/nodes/SearchNode.d.ts.map +1 -0
  88. package/dist/domain/workflow/nodes/SearchNode.js +151 -0
  89. package/dist/domain/workflow/nodes/SearchNode.js.map +1 -0
  90. package/dist/domain/workflow/nodes/WriteNode.d.ts +68 -0
  91. package/dist/domain/workflow/nodes/WriteNode.d.ts.map +1 -0
  92. package/dist/domain/workflow/nodes/WriteNode.js +431 -0
  93. package/dist/domain/workflow/nodes/WriteNode.js.map +1 -0
  94. package/dist/domain/workflow/nodes/config/index.js +287 -0
  95. package/dist/domain/workflow/nodes/domain/entities/Task.js +68 -0
  96. package/dist/domain/workflow/nodes/domain/workflow/State.js +200 -0
  97. package/dist/domain/workflow/nodes/domain/workflow/nodes/BaseNode.js +328 -0
  98. package/dist/domain/workflow/nodes/domain/workflow/nodes/CheckTextNode.js +500 -0
  99. package/dist/domain/workflow/nodes/index.d.ts +13 -0
  100. package/dist/domain/workflow/nodes/index.d.ts.map +1 -0
  101. package/dist/domain/workflow/nodes/index.js +13 -0
  102. package/dist/domain/workflow/nodes/index.js.map +1 -0
  103. package/dist/domain/workflow/nodes/infrastructure/logging/logger.js +275 -0
  104. package/dist/domain/workflow/nodes/services/llm/EnhancedLLMService.js +559 -0
  105. package/dist/index.d.ts +24 -0
  106. package/dist/index.d.ts.map +1 -0
  107. package/dist/index.js +34 -0
  108. package/dist/index.js.map +1 -0
  109. package/dist/infrastructure/cache/CacheService.d.ts +139 -0
  110. package/dist/infrastructure/cache/CacheService.d.ts.map +1 -0
  111. package/dist/infrastructure/cache/CacheService.js +419 -0
  112. package/dist/infrastructure/cache/CacheService.js.map +1 -0
  113. package/dist/infrastructure/cache/index.d.ts +5 -0
  114. package/dist/infrastructure/cache/index.d.ts.map +1 -0
  115. package/dist/infrastructure/cache/index.js +6 -0
  116. package/dist/infrastructure/cache/index.js.map +1 -0
  117. package/dist/infrastructure/database/BaseRepository.d.ts +98 -0
  118. package/dist/infrastructure/database/BaseRepository.d.ts.map +1 -0
  119. package/dist/infrastructure/database/BaseRepository.js +178 -0
  120. package/dist/infrastructure/database/BaseRepository.js.map +1 -0
  121. package/dist/infrastructure/database/MemoryTaskRepository.d.ts +77 -0
  122. package/dist/infrastructure/database/MemoryTaskRepository.d.ts.map +1 -0
  123. package/dist/infrastructure/database/MemoryTaskRepository.js +309 -0
  124. package/dist/infrastructure/database/MemoryTaskRepository.js.map +1 -0
  125. package/dist/infrastructure/database/PostgresQualityCheckRepository.d.ts +36 -0
  126. package/dist/infrastructure/database/PostgresQualityCheckRepository.d.ts.map +1 -0
  127. package/dist/infrastructure/database/PostgresQualityCheckRepository.js +89 -0
  128. package/dist/infrastructure/database/PostgresQualityCheckRepository.js.map +1 -0
  129. package/dist/infrastructure/database/PostgresTaskRepository.d.ts +94 -0
  130. package/dist/infrastructure/database/PostgresTaskRepository.d.ts.map +1 -0
  131. package/dist/infrastructure/database/PostgresTaskRepository.js +364 -0
  132. package/dist/infrastructure/database/PostgresTaskRepository.js.map +1 -0
  133. package/dist/infrastructure/database/ResultRepository.d.ts +41 -0
  134. package/dist/infrastructure/database/ResultRepository.d.ts.map +1 -0
  135. package/dist/infrastructure/database/ResultRepository.js +86 -0
  136. package/dist/infrastructure/database/ResultRepository.js.map +1 -0
  137. package/dist/infrastructure/database/SQLiteTaskRepository.d.ts +101 -0
  138. package/dist/infrastructure/database/SQLiteTaskRepository.d.ts.map +1 -0
  139. package/dist/infrastructure/database/SQLiteTaskRepository.js +548 -0
  140. package/dist/infrastructure/database/SQLiteTaskRepository.js.map +1 -0
  141. package/dist/infrastructure/database/index.d.ts +32 -0
  142. package/dist/infrastructure/database/index.d.ts.map +1 -0
  143. package/dist/infrastructure/database/index.js +72 -0
  144. package/dist/infrastructure/database/index.js.map +1 -0
  145. package/dist/infrastructure/logging/logger.d.ts +69 -0
  146. package/dist/infrastructure/logging/logger.d.ts.map +1 -0
  147. package/dist/infrastructure/logging/logger.js +169 -0
  148. package/dist/infrastructure/logging/logger.js.map +1 -0
  149. package/dist/infrastructure/monitoring/LoggingService.d.ts +109 -0
  150. package/dist/infrastructure/monitoring/LoggingService.d.ts.map +1 -0
  151. package/dist/infrastructure/monitoring/LoggingService.js +198 -0
  152. package/dist/infrastructure/monitoring/LoggingService.js.map +1 -0
  153. package/dist/infrastructure/monitoring/MetricsService.d.ts +112 -0
  154. package/dist/infrastructure/monitoring/MetricsService.d.ts.map +1 -0
  155. package/dist/infrastructure/monitoring/MetricsService.js +362 -0
  156. package/dist/infrastructure/monitoring/MetricsService.js.map +1 -0
  157. package/dist/infrastructure/monitoring/SentryService.d.ts +108 -0
  158. package/dist/infrastructure/monitoring/SentryService.d.ts.map +1 -0
  159. package/dist/infrastructure/monitoring/SentryService.js +282 -0
  160. package/dist/infrastructure/monitoring/SentryService.js.map +1 -0
  161. package/dist/infrastructure/monitoring/index.d.ts +7 -0
  162. package/dist/infrastructure/monitoring/index.d.ts.map +1 -0
  163. package/dist/infrastructure/monitoring/index.js +10 -0
  164. package/dist/infrastructure/monitoring/index.js.map +1 -0
  165. package/dist/infrastructure/queue/TaskQueue.d.ts +110 -0
  166. package/dist/infrastructure/queue/TaskQueue.d.ts.map +1 -0
  167. package/dist/infrastructure/queue/TaskQueue.js +363 -0
  168. package/dist/infrastructure/queue/TaskQueue.js.map +1 -0
  169. package/dist/infrastructure/queue/index.d.ts +5 -0
  170. package/dist/infrastructure/queue/index.d.ts.map +1 -0
  171. package/dist/infrastructure/queue/index.js +5 -0
  172. package/dist/infrastructure/queue/index.js.map +1 -0
  173. package/dist/infrastructure/redis/connection.d.ts +61 -0
  174. package/dist/infrastructure/redis/connection.d.ts.map +1 -0
  175. package/dist/infrastructure/redis/connection.js +184 -0
  176. package/dist/infrastructure/redis/connection.js.map +1 -0
  177. package/dist/infrastructure/redis/index.d.ts +5 -0
  178. package/dist/infrastructure/redis/index.d.ts.map +1 -0
  179. package/dist/infrastructure/redis/index.js +5 -0
  180. package/dist/infrastructure/redis/index.js.map +1 -0
  181. package/dist/infrastructure/security/ApiKeyService.d.ts +103 -0
  182. package/dist/infrastructure/security/ApiKeyService.d.ts.map +1 -0
  183. package/dist/infrastructure/security/ApiKeyService.js +250 -0
  184. package/dist/infrastructure/security/ApiKeyService.js.map +1 -0
  185. package/dist/infrastructure/security/QuotaService.d.ts +87 -0
  186. package/dist/infrastructure/security/QuotaService.d.ts.map +1 -0
  187. package/dist/infrastructure/security/QuotaService.js +303 -0
  188. package/dist/infrastructure/security/QuotaService.js.map +1 -0
  189. package/dist/infrastructure/security/RateLimiter.d.ts +104 -0
  190. package/dist/infrastructure/security/RateLimiter.d.ts.map +1 -0
  191. package/dist/infrastructure/security/RateLimiter.js +331 -0
  192. package/dist/infrastructure/security/RateLimiter.js.map +1 -0
  193. package/dist/infrastructure/security/index.d.ts +7 -0
  194. package/dist/infrastructure/security/index.d.ts.map +1 -0
  195. package/dist/infrastructure/security/index.js +10 -0
  196. package/dist/infrastructure/security/index.js.map +1 -0
  197. package/dist/monitoring/index.d.ts +5 -0
  198. package/dist/monitoring/index.d.ts.map +1 -0
  199. package/dist/monitoring/index.js +5 -0
  200. package/dist/monitoring/index.js.map +1 -0
  201. package/dist/monitoring/server.d.ts +14 -0
  202. package/dist/monitoring/server.d.ts.map +1 -0
  203. package/dist/monitoring/server.js +99 -0
  204. package/dist/monitoring/server.js.map +1 -0
  205. package/dist/presentation/cli/commands/cancel.d.ts +8 -0
  206. package/dist/presentation/cli/commands/cancel.d.ts.map +1 -0
  207. package/dist/presentation/cli/commands/cancel.js +57 -0
  208. package/dist/presentation/cli/commands/cancel.js.map +1 -0
  209. package/dist/presentation/cli/commands/create.d.ts +8 -0
  210. package/dist/presentation/cli/commands/create.d.ts.map +1 -0
  211. package/dist/presentation/cli/commands/create.js +368 -0
  212. package/dist/presentation/cli/commands/create.js.map +1 -0
  213. package/dist/presentation/cli/commands/result.d.ts +8 -0
  214. package/dist/presentation/cli/commands/result.d.ts.map +1 -0
  215. package/dist/presentation/cli/commands/result.js +121 -0
  216. package/dist/presentation/cli/commands/result.js.map +1 -0
  217. package/dist/presentation/cli/commands/status.d.ts +8 -0
  218. package/dist/presentation/cli/commands/status.d.ts.map +1 -0
  219. package/dist/presentation/cli/commands/status.js +92 -0
  220. package/dist/presentation/cli/commands/status.js.map +1 -0
  221. package/dist/presentation/cli/index.d.ts +8 -0
  222. package/dist/presentation/cli/index.d.ts.map +1 -0
  223. package/dist/presentation/cli/index.js +32 -0
  224. package/dist/presentation/cli/index.js.map +1 -0
  225. package/dist/presentation/cli/utils/cleanup.d.ts +14 -0
  226. package/dist/presentation/cli/utils/cleanup.d.ts.map +1 -0
  227. package/dist/presentation/cli/utils/cleanup.js +62 -0
  228. package/dist/presentation/cli/utils/cleanup.js.map +1 -0
  229. package/dist/presentation/cli/utils/formatter.d.ts +28 -0
  230. package/dist/presentation/cli/utils/formatter.d.ts.map +1 -0
  231. package/dist/presentation/cli/utils/formatter.js +68 -0
  232. package/dist/presentation/cli/utils/formatter.js.map +1 -0
  233. package/dist/presentation/cli.d.ts +7 -0
  234. package/dist/presentation/cli.d.ts.map +1 -0
  235. package/dist/presentation/cli.js +8 -0
  236. package/dist/presentation/cli.js.map +1 -0
  237. package/dist/presentation/monitor-cli.d.ts +8 -0
  238. package/dist/presentation/monitor-cli.d.ts.map +1 -0
  239. package/dist/presentation/monitor-cli.js +44 -0
  240. package/dist/presentation/monitor-cli.js.map +1 -0
  241. package/dist/presentation/worker-cli.d.ts +8 -0
  242. package/dist/presentation/worker-cli.d.ts.map +1 -0
  243. package/dist/presentation/worker-cli.js +51 -0
  244. package/dist/presentation/worker-cli.js.map +1 -0
  245. package/dist/schedulers/TaskScheduler.d.ts +99 -0
  246. package/dist/schedulers/TaskScheduler.d.ts.map +1 -0
  247. package/dist/schedulers/TaskScheduler.js +233 -0
  248. package/dist/schedulers/TaskScheduler.js.map +1 -0
  249. package/dist/schedulers/index.d.ts +5 -0
  250. package/dist/schedulers/index.d.ts.map +1 -0
  251. package/dist/schedulers/index.js +5 -0
  252. package/dist/schedulers/index.js.map +1 -0
  253. package/dist/services/image/ImageService.d.ts +68 -0
  254. package/dist/services/image/ImageService.d.ts.map +1 -0
  255. package/dist/services/image/ImageService.js +166 -0
  256. package/dist/services/image/ImageService.js.map +1 -0
  257. package/dist/services/index.d.ts +8 -0
  258. package/dist/services/index.d.ts.map +1 -0
  259. package/dist/services/index.js +12 -0
  260. package/dist/services/index.js.map +1 -0
  261. package/dist/services/llm/EnhancedLLMService.d.ts +148 -0
  262. package/dist/services/llm/EnhancedLLMService.d.ts.map +1 -0
  263. package/dist/services/llm/EnhancedLLMService.js +425 -0
  264. package/dist/services/llm/EnhancedLLMService.js.map +1 -0
  265. package/dist/services/llm/LLMService.d.ts +103 -0
  266. package/dist/services/llm/LLMService.d.ts.map +1 -0
  267. package/dist/services/llm/LLMService.js +212 -0
  268. package/dist/services/llm/LLMService.js.map +1 -0
  269. package/dist/services/quality/HardRuleChecker.d.ts +143 -0
  270. package/dist/services/quality/HardRuleChecker.d.ts.map +1 -0
  271. package/dist/services/quality/HardRuleChecker.js +353 -0
  272. package/dist/services/quality/HardRuleChecker.js.map +1 -0
  273. package/dist/services/quality/LLMEvaluator.d.ts +105 -0
  274. package/dist/services/quality/LLMEvaluator.d.ts.map +1 -0
  275. package/dist/services/quality/LLMEvaluator.js +312 -0
  276. package/dist/services/quality/LLMEvaluator.js.map +1 -0
  277. package/dist/services/quality/QualityCheckService.d.ts +112 -0
  278. package/dist/services/quality/QualityCheckService.d.ts.map +1 -0
  279. package/dist/services/quality/QualityCheckService.js +342 -0
  280. package/dist/services/quality/QualityCheckService.js.map +1 -0
  281. package/dist/services/quality/QualityService.d.ts +75 -0
  282. package/dist/services/quality/QualityService.d.ts.map +1 -0
  283. package/dist/services/quality/QualityService.js +360 -0
  284. package/dist/services/quality/QualityService.js.map +1 -0
  285. package/dist/services/quality/index.d.ts +7 -0
  286. package/dist/services/quality/index.d.ts.map +1 -0
  287. package/dist/services/quality/index.js +10 -0
  288. package/dist/services/quality/index.js.map +1 -0
  289. package/dist/services/search/SearchService.d.ts +79 -0
  290. package/dist/services/search/SearchService.d.ts.map +1 -0
  291. package/dist/services/search/SearchService.js +193 -0
  292. package/dist/services/search/SearchService.js.map +1 -0
  293. package/dist/workers/TaskWorker.d.ts +61 -0
  294. package/dist/workers/TaskWorker.d.ts.map +1 -0
  295. package/dist/workers/TaskWorker.js +256 -0
  296. package/dist/workers/TaskWorker.js.map +1 -0
  297. package/dist/workers/index.d.ts +5 -0
  298. package/dist/workers/index.d.ts.map +1 -0
  299. package/dist/workers/index.js +5 -0
  300. package/dist/workers/index.js.map +1 -0
  301. package/docs/DOCUMENTATION-ANALYSIS.md +190 -0
  302. package/docs/README.md +145 -0
  303. package/docs/SOURCE-CODE-ANALYSIS.md +1107 -0
  304. package/docs/architecture-complete.md +5524 -0
  305. package/docs/archive/implementation/implementation-analysis/README.md +244 -0
  306. package/docs/archive/implementation/implementation-analysis/implementation-analysis-context.md +483 -0
  307. package/docs/archive/implementation/implementation-analysis/implementation-analysis-plan.md +1242 -0
  308. package/docs/archive/implementation/implementation-analysis/implementation-analysis-tasks.md +777 -0
  309. package/docs/archive/phases/phase-1/phase-1-completion-summary.md +284 -0
  310. package/docs/archive/phases/phase-1/phase-1-implementation-guide.md +1380 -0
  311. package/docs/archive/phases/phase-2/phase-2a/phase-2a-completion-summary.md +443 -0
  312. package/docs/archive/phases/phase-2/phase-2b/phase-2b-completion-report.md +430 -0
  313. package/docs/archive/phases/phase-2/phase-2b/phase-2b-completion-summary.md +592 -0
  314. package/docs/archive/phases/phase-2/phase-2b/phase-2b-final-summary.md +371 -0
  315. package/docs/archive/phases/phase-2/phase-2b/phase-2b-preparation-complete.md +343 -0
  316. package/docs/archive/phases/phase-2/phase-2b/phase-2b-preparation.md +945 -0
  317. package/docs/archive/phases/phase-2/phase-2b/phase-2b-progress-update.md +366 -0
  318. package/docs/archive/phases/phase-3/phase-3-completion-summary.md +354 -0
  319. package/docs/archive/phases/phase-3/phase-3-development-plan.md +878 -0
  320. package/docs/archive/phases/phase-3/phase-3-quick-start.md +324 -0
  321. package/docs/archive/phases/phase-4/phase-4-completion-summary.md +708 -0
  322. package/docs/archive/phases/phase-4/phase-4-development-plan.md +740 -0
  323. package/docs/archive/phases/phase-4/phase-4-quick-start.md +632 -0
  324. package/docs/archive/phases/phase-4/phase-4-session-3-security-testing.md +484 -0
  325. package/docs/archive/phases/phase-4/phase-4-session-4-unit-tests.md +550 -0
  326. package/docs/archive/phases/phase-4/phase-4-session-5-security-tests.md +564 -0
  327. package/docs/archive/phases/phase-4/phase-4-session-6-cache-integration.md +456 -0
  328. package/docs/archive/phases/phase-4/phase-4-session-7-test-fixes.md +348 -0
  329. package/docs/archive/phases/phase-4/phase-4-session-8-taskqueue-fixes.md +323 -0
  330. package/docs/archive/phases/phase-4/phase-4-session-summary-continued.md +373 -0
  331. package/docs/archive/phases/phase-4/phase-4-session-summary.md +595 -0
  332. package/docs/archive/reports/progress-reports/PHASE_0_PROGRESS.md +242 -0
  333. package/docs/archive/reports/progress-reports/PHASE_0_SUMMARY.md +262 -0
  334. package/docs/archive/reports/progress-reports/PHASE_1_2_ISSUES.md +399 -0
  335. package/docs/archive/reports/progress-reports/PHASE_1_PROGRESS.md +388 -0
  336. package/docs/archive/reports/progress-reports/PHASE_3_PREPARATION.md +574 -0
  337. package/docs/archive/reports/progress-reports/current-progress-update.md +294 -0
  338. package/docs/archive/reports/progress-reports/final-summary.md +215 -0
  339. package/docs/archive/reports/progress-reports/implementation-summary.md +287 -0
  340. package/docs/archive/reports/progress-reports/project-progress-report.md +440 -0
  341. package/docs/archive/reports/progress-reports/project-progress.md +386 -0
  342. package/docs/archive/reports/test-reports/TEST-COVERAGE-REPORT.md +441 -0
  343. package/docs/archive/reports/test-reports/e2e-test-report.md +293 -0
  344. package/docs/archive/reports/test-reports/final-test-report.md +367 -0
  345. package/docs/archive/reports/test-reports/real-env-test-report.md +391 -0
  346. package/docs/archive/reports/test-reports/test-completion-summary.md +356 -0
  347. package/docs/archive/reports/test-reports/test-report.md +371 -0
  348. package/docs/archive/sessions/session-2-summary.md +429 -0
  349. package/docs/archive/sessions/session-3-summary.md +395 -0
  350. package/docs/archive/sessions/session-summary.md +370 -0
  351. package/docs/config-system-update.md +239 -0
  352. package/docs/database-refactoring-PLAN.md +199 -0
  353. package/docs/database-refactoring-SUMMARY.md +384 -0
  354. package/docs/quality-check-architecture.md +1030 -0
  355. package/docs/quick-start.md +388 -0
  356. package/docs/references/bullmq-quick-reference.md +525 -0
  357. package/docs/references/monitoring-optimization-guide.md +871 -0
  358. package/docs/references/performance-optimization-guide.md +933 -0
  359. package/docs/storage-guide.md +612 -0
  360. package/docs/test-implementation-PLAN.md +223 -0
  361. package/docs/test-implementation-SUMMARY.md +194 -0
  362. package/docs/user-guide.md +719 -0
  363. package/docs/workflow-architecture.md +549 -0
  364. package/package.json +126 -0
  365. package/src/application/workflow/SyncExecutor.ts +444 -0
  366. package/src/application/workflow/types.ts +57 -0
  367. package/src/config/index.ts +352 -0
  368. package/src/domain/entities/QualityCheck.ts +202 -0
  369. package/src/domain/entities/Result.ts +130 -0
  370. package/src/domain/entities/Task.ts +178 -0
  371. package/src/domain/entities/TaskStep.ts +188 -0
  372. package/src/domain/entities/TokenUsage.ts +119 -0
  373. package/src/domain/entities/index.ts +20 -0
  374. package/src/domain/repositories/QualityCheckRepository.ts +52 -0
  375. package/src/domain/repositories/ResultRepository.ts +47 -0
  376. package/src/domain/repositories/TaskRepository.ts +271 -0
  377. package/src/domain/workflow/CheckpointManager.ts +283 -0
  378. package/src/domain/workflow/ContentCreatorGraph.ts +446 -0
  379. package/src/domain/workflow/State.ts +321 -0
  380. package/src/domain/workflow/index.ts +18 -0
  381. package/src/domain/workflow/nodes/BaseNode.ts +325 -0
  382. package/src/domain/workflow/nodes/CheckImageNode.ts +325 -0
  383. package/src/domain/workflow/nodes/CheckTextNode.ts +709 -0
  384. package/src/domain/workflow/nodes/GenerateImageNode.ts +342 -0
  385. package/src/domain/workflow/nodes/OrganizeNode.ts +304 -0
  386. package/src/domain/workflow/nodes/SearchNode.ts +192 -0
  387. package/src/domain/workflow/nodes/WriteNode.ts +505 -0
  388. package/src/domain/workflow/nodes/index.ts +13 -0
  389. package/src/index.ts +43 -0
  390. package/src/infrastructure/cache/CacheService.ts +483 -0
  391. package/src/infrastructure/cache/index.ts +6 -0
  392. package/src/infrastructure/database/BaseRepository.ts +214 -0
  393. package/src/infrastructure/database/MemoryTaskRepository.ts +377 -0
  394. package/src/infrastructure/database/PostgresQualityCheckRepository.ts +115 -0
  395. package/src/infrastructure/database/PostgresTaskRepository.ts +424 -0
  396. package/src/infrastructure/database/ResultRepository.ts +113 -0
  397. package/src/infrastructure/database/SQLiteTaskRepository.ts +651 -0
  398. package/src/infrastructure/database/index.ts +83 -0
  399. package/src/infrastructure/logging/logger.ts +231 -0
  400. package/src/infrastructure/monitoring/LoggingService.ts +292 -0
  401. package/src/infrastructure/monitoring/MetricsService.ts +468 -0
  402. package/src/infrastructure/monitoring/SentryService.ts +345 -0
  403. package/src/infrastructure/monitoring/index.ts +12 -0
  404. package/src/infrastructure/queue/TaskQueue.ts +429 -0
  405. package/src/infrastructure/queue/index.ts +5 -0
  406. package/src/infrastructure/redis/connection.ts +215 -0
  407. package/src/infrastructure/redis/index.ts +5 -0
  408. package/src/infrastructure/security/ApiKeyService.ts +340 -0
  409. package/src/infrastructure/security/QuotaService.ts +411 -0
  410. package/src/infrastructure/security/RateLimiter.ts +417 -0
  411. package/src/infrastructure/security/index.ts +12 -0
  412. package/src/monitoring/index.ts +5 -0
  413. package/src/monitoring/server.ts +109 -0
  414. package/src/presentation/cli/commands/cancel.ts +64 -0
  415. package/src/presentation/cli/commands/create.ts +400 -0
  416. package/src/presentation/cli/commands/result.ts +136 -0
  417. package/src/presentation/cli/commands/status.ts +102 -0
  418. package/src/presentation/cli/index.ts +39 -0
  419. package/src/presentation/cli/utils/cleanup.ts +65 -0
  420. package/src/presentation/cli/utils/formatter.ts +74 -0
  421. package/src/presentation/cli.ts +8 -0
  422. package/src/presentation/monitor-cli.ts +52 -0
  423. package/src/presentation/worker-cli.ts +62 -0
  424. package/src/schedulers/TaskScheduler.ts +314 -0
  425. package/src/schedulers/index.ts +11 -0
  426. package/src/services/image/ImageService.ts +221 -0
  427. package/src/services/index.ts +15 -0
  428. package/src/services/llm/EnhancedLLMService.ts +596 -0
  429. package/src/services/llm/LLMService.ts +310 -0
  430. package/src/services/quality/HardRuleChecker.ts +509 -0
  431. package/src/services/quality/LLMEvaluator.ts +400 -0
  432. package/src/services/quality/QualityCheckService.ts +473 -0
  433. package/src/services/quality/QualityService.ts +445 -0
  434. package/src/services/quality/index.ts +12 -0
  435. package/src/services/search/SearchService.ts +266 -0
  436. package/src/types/global.d.ts +17 -0
  437. package/src/workers/TaskWorker.ts +320 -0
  438. package/src/workers/index.ts +5 -0
@@ -0,0 +1,400 @@
1
+ /**
2
+ * CLI create命令
3
+ *
4
+ * 创建内容创作任务
5
+ */
6
+
7
+ import { Command } from 'commander';
8
+ import chalk from 'chalk';
9
+ import ora from 'ora';
10
+ import { v4 as uuidv4 } from 'uuid';
11
+ import { createSyncExecutor } from '../../../application/workflow/SyncExecutor.js';
12
+ import { MemoryTaskRepository } from '../../../infrastructure/database/MemoryTaskRepository.js';
13
+ import { PostgresTaskRepository } from '../../../infrastructure/database/PostgresTaskRepository.js';
14
+ import { PostgresResultRepository } from '../../../infrastructure/database/ResultRepository.js';
15
+ import { PostgresQualityCheckRepository } from '../../../infrastructure/database/PostgresQualityCheckRepository.js';
16
+ import { ExecutionMode, TaskPriority } from '../../../domain/entities/Task.js';
17
+ import { createLogger } from '../../../infrastructure/logging/logger.js';
18
+ import { closeLogger } from '../../../infrastructure/logging/logger.js';
19
+ import { printSeparator, formatDuration, formatTokens, formatCost } from '../utils/formatter.js';
20
+ import { config } from '../../../config/index.js';
21
+
22
+ const logger = createLogger('CLI:Create');
23
+
24
+ export const createCommand = new Command('create')
25
+ .description('创建内容创作任务')
26
+ .option('-t, --topic <topic>', '文章主题')
27
+ .option('-r, --requirements <requirements>', '创作要求')
28
+ .option('-a, --audience <audience>', '目标受众', '普通读者')
29
+ .option('--keywords <keywords>', '关键词(逗号分隔)', '')
30
+ .option('--tone <tone>', '语气风格', '专业')
31
+ .option('--min-words <number>', '最小字数', '500')
32
+ .option('--max-words <number>', '最大字数', '2000')
33
+ .option('--mode <mode>', '执行模式 (sync|async)', 'sync')
34
+ .option('--priority <priority>', '优先级 (low|normal|high|urgent)', 'normal')
35
+ .option('--sync', '同步执行(等待结果)', false)
36
+ .action(async (options) => {
37
+ // ==================== 第一阶段:参数验证(不需要任何服务) ====================
38
+ try {
39
+ // 验证输入
40
+ if (!options.topic) {
41
+ console.error(chalk.red('❌ 错误: 必须提供文章主题 (-t, --topic)'));
42
+ process.exit(1);
43
+ }
44
+
45
+ if (!options.requirements) {
46
+ console.error(chalk.red('❌ 错误: 必须提供创作要求 (-r, --requirements)'));
47
+ process.exit(1);
48
+ }
49
+
50
+ // 显示任务信息
51
+ console.log(chalk.blue.bold('\n🚀 创建内容创作任务'));
52
+ printSeparator();
53
+ console.log(chalk.white(`主题: ${options.topic}`));
54
+ console.log(chalk.white(`要求: ${options.requirements}`));
55
+ console.log(chalk.white(`受众: ${options.audience}`));
56
+ console.log(chalk.white(`语气: ${options.tone}`));
57
+ if (options.keywords) {
58
+ console.log(chalk.white(`关键词: ${options.keywords}`));
59
+ }
60
+ console.log(chalk.white(`执行模式: ${options.mode}`));
61
+ console.log(chalk.white(`优先级: ${options.priority}`));
62
+ printSeparator();
63
+ } catch (error) {
64
+ console.error(chalk.red(`\n❌ 参数验证失败: ${error instanceof Error ? error.message : String(error)}`));
65
+ process.exit(1);
66
+ }
67
+
68
+ // 解析关键词(在两个 try 块之外的共享作用域)
69
+ const keywords = options.keywords
70
+ ? options.keywords.split(',').map((k: string) => k.trim())
71
+ : undefined;
72
+
73
+ // ==================== 第二阶段:服务初始化(仅在验证通过后) ====================
74
+ // 延迟导入服务,避免参数验证失败时不必要的初始化
75
+ const { redisClient } = await import('../../../infrastructure/redis/connection.js');
76
+ const { metricsService } = await import('../../../infrastructure/monitoring/MetricsService.js');
77
+
78
+ // 资源管理变量
79
+ const resources = {
80
+ pool: null as any,
81
+ servicesInitialized: true,
82
+ };
83
+
84
+ try {
85
+ // 创建执行器
86
+ // 根据配置选择使用 PostgreSQL 或内存数据库
87
+ let taskRepo: any;
88
+ let resultRepo: any = null;
89
+ let qualityCheckRepo: any = null;
90
+
91
+ if (config.database.type === 'postgres') {
92
+ const { Pool } = await import('pg');
93
+ resources.pool = new Pool({
94
+ host: config.postgres.host,
95
+ port: config.postgres.port,
96
+ database: config.postgres.database,
97
+ user: config.postgres.user,
98
+ password: config.postgres.password,
99
+ });
100
+
101
+ // 使用 PostgreSQL Task Repository,确保任务持久化
102
+ taskRepo = new PostgresTaskRepository(resources.pool);
103
+ resultRepo = new PostgresResultRepository(resources.pool);
104
+ qualityCheckRepo = new PostgresQualityCheckRepository(resources.pool);
105
+
106
+ console.log('✅ 使用 PostgreSQL 持久化存储');
107
+ } else {
108
+ // 使用内存数据库(仅用于测试)
109
+ taskRepo = new MemoryTaskRepository();
110
+ console.log('⚠️ 使用内存存储(数据不会持久化)');
111
+ }
112
+
113
+ // ==================== 第三阶段:执行任务 ====================
114
+ const isAsyncMode = options.mode === 'async';
115
+
116
+ if (isAsyncMode) {
117
+ // ==================== 异步模式:使用 TaskScheduler ====================
118
+ const { TaskScheduler } = await import('../../../schedulers/TaskScheduler.js');
119
+ const scheduler = new TaskScheduler();
120
+
121
+ // 初始化调度器
122
+ await scheduler.initialize();
123
+
124
+ // 创建进度spinner
125
+ const spinner = ora('添加任务到队列...').start();
126
+
127
+ // 添加任务到队列
128
+ const taskId = await scheduler.scheduleTask({
129
+ mode: 'async',
130
+ topic: options.topic,
131
+ requirements: options.requirements,
132
+ hardConstraints: {
133
+ minWords: parseInt(options.minWords) || undefined,
134
+ maxWords: parseInt(options.maxWords) || undefined,
135
+ keywords,
136
+ },
137
+ priority: parsePriorityToNumber(options.priority),
138
+ });
139
+
140
+ spinner.succeed('任务已添加到队列!');
141
+
142
+ // 显示任务信息
143
+ console.log(chalk.green.bold('\n✅ 任务已成功创建'));
144
+ printSeparator();
145
+ console.log(chalk.white(`任务ID: ${taskId}`));
146
+ console.log(chalk.white(`模式: 异步(队列)`));
147
+ console.log(chalk.white(`状态: 等待 Worker 处理`));
148
+ printSeparator();
149
+
150
+ console.log(chalk.yellow.bold('\n💡 后续操作:'));
151
+ console.log(chalk.white('1. 查询任务状态:'));
152
+ console.log(chalk.gray(` pnpm cli result --task-id ${taskId}`));
153
+ console.log(chalk.white('\n2. 确保 Worker 正在运行:'));
154
+ console.log(chalk.gray(' pnpm run worker'));
155
+ console.log(chalk.white('\n3. 查看队列状态:'));
156
+ console.log(chalk.gray(' pnpm cli worker:status'));
157
+ printSeparator();
158
+
159
+ logger.info('Task created via async mode', {
160
+ taskId,
161
+ mode: 'async',
162
+ topic: options.topic,
163
+ });
164
+
165
+ } else {
166
+ // ==================== 同步模式:使用 SyncExecutor ====================
167
+ const executor = createSyncExecutor(taskRepo, {
168
+ databaseType: config.database.type,
169
+ enableLogging: true,
170
+ logLevel: 'info',
171
+ });
172
+
173
+ // 设置结果仓储(如果可用)
174
+ if (resultRepo) {
175
+ executor.setResultRepository(resultRepo);
176
+ }
177
+ if (qualityCheckRepo) {
178
+ executor.setQualityCheckRepository(qualityCheckRepo);
179
+ }
180
+
181
+ // 创建进度spinner
182
+ const spinner = ora('初始化中...').start();
183
+
184
+ // 添加进度回调
185
+ const taskId = uuidv4();
186
+ executor.onProgress(taskId, (progress) => {
187
+ spinner.text = `${progress.message} (${progress.percentage}%)`;
188
+ });
189
+
190
+ // 执行任务
191
+ spinner.text = '执行任务中...';
192
+ const result = await executor.execute({
193
+ mode: ExecutionMode.SYNC,
194
+ topic: options.topic,
195
+ requirements: options.requirements,
196
+ targetAudience: options.audience,
197
+ keywords,
198
+ tone: options.tone,
199
+ hardConstraints: {
200
+ minWords: parseInt(options.minWords) || undefined,
201
+ maxWords: parseInt(options.maxWords) || undefined,
202
+ },
203
+ priority: parsePriority(options.priority),
204
+ idempotencyKey: taskId,
205
+ });
206
+
207
+ spinner.succeed('任务执行完成!');
208
+
209
+ // 显示结果
210
+ console.log(chalk.green.bold('\n✅ 执行成功'));
211
+ printSeparator();
212
+ console.log(chalk.white(`任务ID: ${result.taskId}`));
213
+ console.log(chalk.white(`状态: ${getStatusDisplay(result.status)}`));
214
+ console.log(chalk.white(`耗时: ${formatDuration(result.duration)}`));
215
+ console.log(chalk.white(`步骤: ${result.metadata.stepsCompleted.join(' → ')}`));
216
+ console.log(chalk.white(`Token: ${formatTokens(result.metadata.tokensUsed)}`));
217
+ console.log(chalk.white(`成本: ${formatCost(result.metadata.cost)}`));
218
+ printSeparator();
219
+
220
+ // 显示生成的内容
221
+ if (result.finalState.articleContent) {
222
+ console.log(chalk.white.bold('\n📝 生成的内容:'));
223
+ printSeparator();
224
+ console.log(result.finalState.articleContent);
225
+ printSeparator();
226
+ }
227
+
228
+ // 显示生成的图片
229
+ if (result.finalState.images && result.finalState.images.length > 0) {
230
+ console.log(chalk.white.bold('\n🖼️ 生成的配图:'));
231
+ printSeparator();
232
+ result.finalState.images.forEach((img: any) => {
233
+ console.log(chalk.cyan(img.url));
234
+ });
235
+ printSeparator();
236
+ }
237
+
238
+ // 显示质检结果
239
+ if (result.finalState.textQualityReport) {
240
+ const qr = result.finalState.textQualityReport;
241
+ console.log(chalk.white.bold('\n🔍 文本质检:'));
242
+ printSeparator();
243
+ console.log(chalk.white(`状态: ${qr.passed ? chalk.green('通过') : chalk.red('未通过')}`));
244
+ if (qr.score !== undefined) {
245
+ console.log(chalk.white(`评分: ${qr.score}/100`));
246
+ }
247
+ if (qr.fixSuggestions && qr.fixSuggestions.length > 0) {
248
+ console.log(chalk.gray(`建议: ${qr.fixSuggestions.join(', ')}`));
249
+ }
250
+ printSeparator();
251
+
252
+ // 🔧 保存质检报告到数据库(变通方案)
253
+ if (qualityCheckRepo) {
254
+ try {
255
+ await qualityCheckRepo.create({
256
+ taskId: result.taskId,
257
+ checkType: 'text',
258
+ score: qr.score || 0,
259
+ passed: qr.passed,
260
+ hardConstraintsPassed: qr.hardConstraintsPassed || false,
261
+ details: qr.details || {},
262
+ fixSuggestions: qr.fixSuggestions || [],
263
+ rubricVersion: '1.0',
264
+ modelName: qr.modelName,
265
+ });
266
+ logger.info('Text quality check saved to database (workaround)', {
267
+ taskId: result.taskId,
268
+ score: qr.score,
269
+ passed: qr.passed,
270
+ });
271
+ } catch (error) {
272
+ logger.error('Failed to save text quality check (workaround)', {
273
+ taskId: result.taskId,
274
+ error: error instanceof Error ? error.message : String(error),
275
+ });
276
+ }
277
+ }
278
+ }
279
+
280
+ // 🔧 同样保存图片质检报告(变通方案)
281
+ if (result.finalState.imageQualityReport && qualityCheckRepo) {
282
+ try {
283
+ const qr = result.finalState.imageQualityReport;
284
+ await qualityCheckRepo.create({
285
+ taskId: result.taskId,
286
+ checkType: 'image',
287
+ score: qr.score || 0,
288
+ passed: qr.passed,
289
+ hardConstraintsPassed: qr.hardConstraintsPassed || false,
290
+ details: qr.details || {},
291
+ fixSuggestions: qr.fixSuggestions || [],
292
+ rubricVersion: '1.0',
293
+ modelName: qr.modelName,
294
+ });
295
+ logger.info('Image quality check saved to database (workaround)', {
296
+ taskId: result.taskId,
297
+ score: qr.score,
298
+ passed: qr.passed,
299
+ });
300
+ } catch (error) {
301
+ logger.error('Failed to save image quality check (workaround)', {
302
+ taskId: result.taskId,
303
+ error: error instanceof Error ? error.message : String(error),
304
+ });
305
+ }
306
+ }
307
+
308
+ logger.info('Task completed via CLI', {
309
+ taskId: result.taskId,
310
+ status: result.status,
311
+ duration: result.duration
312
+ });
313
+ } // 结束同步模式的 else 块
314
+ } catch (error) {
315
+ logger.error('Create command failed', error as Error);
316
+ console.error(chalk.red(`\n❌ 错误: ${error instanceof Error ? error.message : String(error)}`));
317
+
318
+ if (error instanceof Error && error.stack) {
319
+ console.error(chalk.gray('\n堆栈信息:'));
320
+ console.error(chalk.gray(error.stack));
321
+ }
322
+
323
+ process.exit(1);
324
+ } finally {
325
+ // ==================== 第四阶段:资源清理 ====================
326
+ // 仅在服务已初始化的情况下清理
327
+ if (resources.servicesInitialized) {
328
+ logger.debug('Starting resource cleanup...');
329
+
330
+ // 1. 关闭 Logger(必须在最后)
331
+ try {
332
+ await closeLogger();
333
+ logger.debug('Logger closed');
334
+ } catch (error) {
335
+ console.log('Error closing logger (ignored):', error);
336
+ }
337
+
338
+ // 2. 停止 Metrics 服务定时器
339
+ try {
340
+ metricsService.stop();
341
+ console.log('Metrics service stopped');
342
+ } catch (error) {
343
+ console.log('Error stopping metrics service (ignored):', error);
344
+ }
345
+
346
+ // 3. 关闭 Redis 客户端连接
347
+ try {
348
+ await redisClient.disconnect();
349
+ console.log('Redis client disconnected');
350
+ } catch (error) {
351
+ console.log('Error disconnecting Redis (ignored):', error);
352
+ }
353
+
354
+ // 4. 关闭 PostgreSQL 连接池
355
+ try {
356
+ if (resources.pool) {
357
+ await resources.pool.end();
358
+ console.log('PostgreSQL connection pool closed');
359
+ }
360
+ } catch (error) {
361
+ console.log('Error closing PostgreSQL pool (ignored):', error);
362
+ }
363
+
364
+ console.log('Resource cleanup completed');
365
+ }
366
+ }
367
+ });
368
+
369
+ function parsePriority(priority: string): TaskPriority {
370
+ const priorityMap: Record<string, TaskPriority> = {
371
+ 'low': TaskPriority.LOW,
372
+ 'normal': TaskPriority.NORMAL,
373
+ 'high': TaskPriority.HIGH,
374
+ 'urgent': TaskPriority.URGENT,
375
+ };
376
+ return priorityMap[priority] || TaskPriority.NORMAL;
377
+ }
378
+
379
+ /**
380
+ * 将优先级字符串转换为数字(用于 TaskScheduler)
381
+ * TaskScheduler 使用数字优先级(1-10,数字越小优先级越高)
382
+ */
383
+ function parsePriorityToNumber(priority: string): number {
384
+ const priorityMap: Record<string, number> = {
385
+ 'low': 5, // 低优先级
386
+ 'normal': 7, // 普通优先级(默认)
387
+ 'high': 3, // 高优先级
388
+ 'urgent': 1, // 紧急优先级
389
+ };
390
+ return priorityMap[priority] || 7; // 默认为 normal (7)
391
+ }
392
+
393
+ function getStatusDisplay(status: string): string {
394
+ const statusMap: Record<string, string> = {
395
+ 'completed': chalk.green('已完成'),
396
+ 'failed': chalk.red('失败'),
397
+ 'cancelled': chalk.gray('已取消'),
398
+ };
399
+ return statusMap[status] || status;
400
+ }
@@ -0,0 +1,136 @@
1
+ /**
2
+ * CLI result命令
3
+ *
4
+ * 获取任务结果
5
+ */
6
+
7
+ import { Command } from 'commander';
8
+ import chalk from 'chalk';
9
+ import { createTaskRepository } from '../../../infrastructure/database/index.js';
10
+ import { PostgresResultRepository } from '../../../infrastructure/database/ResultRepository.js';
11
+ import { getStatusText, printSeparator } from '../utils/formatter.js';
12
+ import { cleanupResources } from '../utils/cleanup.js';
13
+ import { config } from '../../../config/index.js';
14
+
15
+ export const resultCommand = new Command('result')
16
+ .description('获取任务结果')
17
+ .requiredOption('-t, --task-id <taskId>', '任务ID')
18
+ .option('--format <format>', '输出格式 (text|json)', 'text')
19
+ .action(async (options) => {
20
+ // 使用工厂函数创建 Repository(支持 memory 和 postgres)
21
+ const taskRepo = createTaskRepository();
22
+ let resultRepo: any = null;
23
+ let pool: any = null;
24
+
25
+ try {
26
+ const task = await taskRepo.findById(options.taskId);
27
+
28
+ if (!task) {
29
+ console.error(chalk.red(`❌ 错误: 未找到任务 ${options.taskId}`));
30
+
31
+ // 如果是内存模式,显示额外提示
32
+ if (config.database.type === 'memory') {
33
+ console.log(chalk.yellow('\n💡 提示: 当前使用内存模式'));
34
+ console.log(chalk.gray(' - 内存模式下的任务数据不会持久化'));
35
+ console.log(chalk.gray(' - 任务完成后结果会直接显示在终端'));
36
+ console.log(chalk.gray(' - 如果需要查询历史任务,请使用 PostgreSQL 模式'));
37
+ }
38
+
39
+ await cleanupResources(taskRepo, resultRepo);
40
+ process.exit(1);
41
+ }
42
+
43
+ // 如果任务未完成,显示状态
44
+ if (task.status !== 'completed') {
45
+ console.log(chalk.yellow(`⚠️ 任务尚未完成,当前状态: ${getStatusText(task.status)}`));
46
+ await cleanupResources(taskRepo, resultRepo);
47
+ return;
48
+ }
49
+
50
+ // JSON格式输出
51
+ if (options.format === 'json') {
52
+ console.log(JSON.stringify(task, null, 2));
53
+ await cleanupResources(taskRepo, resultRepo);
54
+ return;
55
+ }
56
+
57
+ // 文本格式输出
58
+ console.log(chalk.blue.bold('\n📄 任务结果'));
59
+ printSeparator();
60
+ console.log(chalk.white(`任务ID: ${task.taskId}`));
61
+ console.log(chalk.white(`状态: ${getStatusText(task.status)}`));
62
+ printSeparator();
63
+
64
+ // 从数据库查询结果(仅 PostgreSQL)
65
+ if (config.database.type === 'postgres') {
66
+ const { Pool } = await import('pg');
67
+ pool = new Pool({
68
+ host: config.postgres.host,
69
+ port: config.postgres.port,
70
+ database: config.postgres.database,
71
+ user: config.postgres.user,
72
+ password: config.postgres.password,
73
+ });
74
+
75
+ resultRepo = new PostgresResultRepository(pool);
76
+ const results = await resultRepo.findByTaskId(options.taskId);
77
+
78
+ if (results.length === 0) {
79
+ console.log(chalk.yellow('提示: 该任务未生成结果'));
80
+ } else {
81
+ console.log(chalk.blue.bold('\n📋 生成结果'));
82
+ printSeparator();
83
+
84
+ results.forEach((result: any, index: number) => {
85
+ console.log(chalk.white.bold(`${index + 1}. ${result.resultType.toUpperCase()}`));
86
+ printSeparator();
87
+
88
+ if (result.resultType === 'article') {
89
+ console.log(chalk.white('内容:'));
90
+ console.log(chalk.gray(result.content || '(无内容)'));
91
+ if (result.metadata?.wordCount) {
92
+ console.log(chalk.gray(`字数: ${result.metadata.wordCount}`));
93
+ }
94
+ } else if (result.resultType === 'image') {
95
+ console.log(chalk.white('图片 URL:'));
96
+ console.log(chalk.cyan(result.content || '(无 URL)'));
97
+ }
98
+ printSeparator();
99
+ });
100
+ }
101
+
102
+ // 关闭结果查询的连接池
103
+ await pool.end();
104
+ } else {
105
+ // Memory 模式:提示结果仅实时返回
106
+ console.log(chalk.yellow('\n💡 提示: 当前使用 Memory 模式'));
107
+ console.log(chalk.gray(' - 任务结果仅在执行时实时返回到终端'));
108
+ console.log(chalk.gray(' - 任务完成后数据不会保存到数据库'));
109
+ console.log(chalk.gray(' - 如需保存结果,请使用 PostgreSQL 模式或 sync 模式查看实时输出'));
110
+ }
111
+
112
+ // 清理所有资源
113
+ await cleanupResources(taskRepo, resultRepo);
114
+
115
+ } catch (error) {
116
+ console.error(chalk.red(`❌ 错误: ${error instanceof Error ? error.message : String(error)}`));
117
+
118
+ // 如果是内存模式,显示额外提示
119
+ if (config.database.type === 'memory') {
120
+ console.log(chalk.yellow('\n💡 提示: Memory 模式下任务数据不持久化'));
121
+ }
122
+
123
+ await cleanupResources(taskRepo, resultRepo);
124
+
125
+ // 清理 PostgreSQL 连接池
126
+ if (pool) {
127
+ try {
128
+ await pool.end();
129
+ } catch (e) {
130
+ // 忽略关闭错误
131
+ }
132
+ }
133
+
134
+ process.exit(1);
135
+ }
136
+ });
@@ -0,0 +1,102 @@
1
+ /**
2
+ * CLI status命令
3
+ *
4
+ * 查询任务状态
5
+ */
6
+
7
+ import { Command } from 'commander';
8
+ import chalk from 'chalk';
9
+ import { PostgresTaskRepository } from '../../../infrastructure/database/PostgresTaskRepository.js';
10
+ import { getStatusText, formatDate, formatDuration, printSeparator } from '../utils/formatter.js';
11
+ import { cleanupResources } from '../utils/cleanup.js';
12
+
13
+ export const statusCommand = new Command('status')
14
+ .description('查询任务状态')
15
+ .requiredOption('-t, --task-id <taskId>', '任务ID')
16
+ .action(async (options) => {
17
+ const taskRepo = new PostgresTaskRepository();
18
+
19
+ try {
20
+ const task = await taskRepo.findById(options.taskId);
21
+
22
+ if (!task) {
23
+ console.error(chalk.red(`❌ 错误: 未找到任务 ${options.taskId}`));
24
+ await cleanupResources(taskRepo);
25
+ process.exit(1);
26
+ }
27
+
28
+ console.log(chalk.blue.bold('\n📊 任务状态'));
29
+ printSeparator();
30
+ console.log(chalk.white(`任务ID: ${task.taskId}`));
31
+ console.log(chalk.white(`状态: ${getStatusText(task.status)}`));
32
+ console.log(chalk.white(`当前步骤: ${task.currentStep ? getStepDisplayName(task.currentStep) : '无'}`));
33
+ console.log(chalk.white(`执行模式: ${task.mode === 'sync' ? '同步' : '异步'}`));
34
+ console.log(chalk.white(`优先级: ${getPriorityText(task.priority)}`));
35
+ printSeparator();
36
+ console.log(chalk.white(`创建时间: ${formatDate(task.createdAt)}`));
37
+ if (task.startedAt) {
38
+ console.log(chalk.white(`开始时间: ${formatDate(task.startedAt)}`));
39
+ }
40
+ if (task.completedAt) {
41
+ const duration = task.completedAt.getTime() - task.createdAt.getTime();
42
+ console.log(chalk.white(`完成时间: ${formatDate(task.completedAt)}`));
43
+ console.log(chalk.white(`总耗时: ${formatDuration(duration)}`));
44
+ }
45
+ printSeparator();
46
+
47
+ // 显示重试信息
48
+ if (task.textRetryCount > 0 || task.imageRetryCount > 0) {
49
+ console.log(chalk.white.bold('重试统计:'));
50
+ if (task.textRetryCount > 0) {
51
+ console.log(chalk.white(` 文本质检: ${task.textRetryCount} 次`));
52
+ }
53
+ if (task.imageRetryCount > 0) {
54
+ console.log(chalk.white(` 配图质检: ${task.imageRetryCount} 次`));
55
+ }
56
+ printSeparator();
57
+ }
58
+
59
+ // 显示错误信息
60
+ if (task.errorMessage) {
61
+ console.log(chalk.red.bold('错误信息:'));
62
+ console.log(chalk.red(task.errorMessage));
63
+ printSeparator();
64
+ }
65
+
66
+ // 显示Worker信息
67
+ if (task.workerId) {
68
+ console.log(chalk.white(`Worker ID: ${task.workerId}`));
69
+ printSeparator();
70
+ }
71
+
72
+ // 清理资源并正常退出
73
+ await cleanupResources(taskRepo);
74
+
75
+ } catch (error) {
76
+ console.error(chalk.red(`❌ 错误: ${error instanceof Error ? error.message : String(error)}`));
77
+ await cleanupResources(taskRepo);
78
+ process.exit(1);
79
+ }
80
+ });
81
+
82
+ function getStepDisplayName(step: string): string {
83
+ const displayNames: Record<string, string> = {
84
+ 'search': '🔍 搜索资料',
85
+ 'organize': '📋 整理大纲',
86
+ 'write': '✍️ 撰写内容',
87
+ 'check_text': '🔍 文本质检',
88
+ 'generate_image': '🎨 生成配图',
89
+ 'check_image': '🔍 配图质检',
90
+ };
91
+ return displayNames[step] || step;
92
+ }
93
+
94
+ function getPriorityText(priority: number): string {
95
+ const priorityMap: Record<number, string> = {
96
+ 1: '低',
97
+ 2: '普通',
98
+ 3: '高',
99
+ 4: '紧急',
100
+ };
101
+ return priorityMap[priority] || '普通';
102
+ }
@@ -0,0 +1,39 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Content Creator CLI
5
+ *
6
+ * AI驱动的内容创作工具
7
+ */
8
+
9
+ import { Command } from 'commander';
10
+ import { createCommand } from './commands/create.js';
11
+ import { statusCommand } from './commands/status.js';
12
+ import { resultCommand } from './commands/result.js';
13
+ import { cancelCommand } from './commands/cancel.js';
14
+ import { createLogger } from '../../infrastructure/logging/logger.js';
15
+
16
+ const logger = createLogger('CLI');
17
+
18
+ // 创建主程序
19
+ const program = new Command();
20
+
21
+ program
22
+ .name('content-creator')
23
+ .description('AI 驱动的内容创作工具')
24
+ .version('0.1.0')
25
+ .option('-v, --verbose', '显示详细日志');
26
+
27
+ // 添加命令
28
+ program.addCommand(createCommand);
29
+ program.addCommand(statusCommand);
30
+ program.addCommand(resultCommand);
31
+ program.addCommand(cancelCommand);
32
+
33
+ // 解析参数
34
+ program.parse();
35
+
36
+ // 记录命令执行
37
+ logger.debug('CLI command executed', {
38
+ args: process.argv.slice(2)
39
+ });