create-hq 5.0.0 → 5.2.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 (301) hide show
  1. package/dist/deps.d.ts +2 -2
  2. package/dist/deps.d.ts.map +1 -1
  3. package/dist/deps.js +138 -29
  4. package/dist/deps.js.map +1 -1
  5. package/dist/index.js +3 -3
  6. package/dist/index.js.map +1 -1
  7. package/dist/scaffold.d.ts +1 -1
  8. package/dist/scaffold.d.ts.map +1 -1
  9. package/dist/scaffold.js +125 -26
  10. package/dist/scaffold.js.map +1 -1
  11. package/dist/ui.js +1 -1
  12. package/package.json +4 -8
  13. package/template/.claude/CLAUDE.md +0 -202
  14. package/template/.claude/commands/checkpoint.md +0 -127
  15. package/template/.claude/commands/cleanup.md +0 -307
  16. package/template/.claude/commands/execute-task.md +0 -440
  17. package/template/.claude/commands/exit-plan.md +0 -41
  18. package/template/.claude/commands/handoff.md +0 -97
  19. package/template/.claude/commands/learn.md +0 -218
  20. package/template/.claude/commands/metrics.md +0 -118
  21. package/template/.claude/commands/newworker.md +0 -162
  22. package/template/.claude/commands/nexttask.md +0 -67
  23. package/template/.claude/commands/prd.md +0 -238
  24. package/template/.claude/commands/reanchor.md +0 -51
  25. package/template/.claude/commands/remember.md +0 -126
  26. package/template/.claude/commands/run-project.md +0 -348
  27. package/template/.claude/commands/run.md +0 -110
  28. package/template/.claude/commands/search-reindex.md +0 -62
  29. package/template/.claude/commands/search.md +0 -100
  30. package/template/.claude/commands/setup.md +0 -381
  31. package/template/.claude/scripts/pure-ralph-loop.ps1 +0 -312
  32. package/template/.claude/scripts/pure-ralph-loop.sh +0 -859
  33. package/template/CHANGELOG.md +0 -220
  34. package/template/LICENSE +0 -21
  35. package/template/MIGRATION.md +0 -259
  36. package/template/README.md +0 -368
  37. package/template/data/journal/.gitkeep +0 -0
  38. package/template/docs/images/ascii-banner-options.md +0 -122
  39. package/template/docs/images/hq-banner.svg +0 -105
  40. package/template/knowledge/Ralph/01-overview.md +0 -71
  41. package/template/knowledge/Ralph/02-core-concepts.md +0 -114
  42. package/template/knowledge/Ralph/03-how-ralph-works.md +0 -184
  43. package/template/knowledge/Ralph/04-back-pressure.md +0 -222
  44. package/template/knowledge/Ralph/05-specifications.md +0 -210
  45. package/template/knowledge/Ralph/06-agents-md.md +0 -222
  46. package/template/knowledge/Ralph/07-implementation.md +0 -316
  47. package/template/knowledge/Ralph/08-economics.md +0 -182
  48. package/template/knowledge/Ralph/09-resources.md +0 -145
  49. package/template/knowledge/Ralph/10-claude-code-workflow.md +0 -212
  50. package/template/knowledge/Ralph/11-team-training-guide.md +0 -383
  51. package/template/knowledge/Ralph/README.md +0 -40
  52. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +0 -139
  53. package/template/knowledge/ai-security-framework/GLOSSARY.md +0 -176
  54. package/template/knowledge/ai-security-framework/LICENSE +0 -21
  55. package/template/knowledge/ai-security-framework/QUICK-START.md +0 -172
  56. package/template/knowledge/ai-security-framework/README.md +0 -232
  57. package/template/knowledge/ai-security-framework/checklists/browser-security.md +0 -301
  58. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +0 -322
  59. package/template/knowledge/ai-security-framework/checklists/incident-response.md +0 -288
  60. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +0 -249
  61. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +0 -159
  62. package/template/knowledge/ai-security-framework/configs/audit-logging.md +0 -372
  63. package/template/knowledge/ai-security-framework/configs/kill-switches.md +0 -354
  64. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +0 -256
  65. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +0 -326
  66. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +0 -250
  67. package/template/knowledge/ai-security-framework/templates/agents-security.md +0 -233
  68. package/template/knowledge/design-styles/README.md +0 -42
  69. package/template/knowledge/design-styles/american-industrial.md +0 -136
  70. package/template/knowledge/design-styles/ethereal-abstract.md +0 -133
  71. package/template/knowledge/design-styles/liminal-portal.md +0 -111
  72. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  73. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  74. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  75. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  76. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  77. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  78. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  79. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  80. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  81. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  82. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  83. package/template/knowledge/design-styles/swipes/american-industrial/README.md +0 -31
  84. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  85. package/template/knowledge/dev-team/README.md +0 -35
  86. package/template/knowledge/dev-team/patterns/README.md +0 -34
  87. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +0 -178
  88. package/template/knowledge/dev-team/troubleshooting/README.md +0 -31
  89. package/template/knowledge/dev-team/workflows/README.md +0 -49
  90. package/template/knowledge/hq/checkpoint-schema.json +0 -51
  91. package/template/knowledge/hq/index-md-spec.md +0 -74
  92. package/template/knowledge/hq/thread-schema.md +0 -153
  93. package/template/knowledge/hq-core/checkpoint-schema.json +0 -51
  94. package/template/knowledge/hq-core/index-md-spec.md +0 -74
  95. package/template/knowledge/hq-core/thread-schema.md +0 -153
  96. package/template/knowledge/loom/README.md +0 -51
  97. package/template/knowledge/loom/architecture.md +0 -125
  98. package/template/knowledge/loom/code-style.md +0 -169
  99. package/template/knowledge/loom/llm-proxy.md +0 -132
  100. package/template/knowledge/loom/state-machine.md +0 -131
  101. package/template/knowledge/loom/thread-system.md +0 -117
  102. package/template/knowledge/loom/tools.md +0 -94
  103. package/template/knowledge/loom/weaver.md +0 -96
  104. package/template/knowledge/loom/web-frontend.md +0 -131
  105. package/template/knowledge/projects/README.md +0 -72
  106. package/template/knowledge/projects/templates/README.template.md +0 -28
  107. package/template/knowledge/workers/README.md +0 -195
  108. package/template/knowledge/workers/ralph-loop-pattern.md +0 -157
  109. package/template/knowledge/workers/skill-schema.md +0 -182
  110. package/template/knowledge/workers/state-machine.md +0 -102
  111. package/template/knowledge/workers/templates/base-worker.yaml +0 -73
  112. package/template/knowledge/workers/templates/code-worker.yaml +0 -85
  113. package/template/knowledge/workers/templates/skill.yaml +0 -49
  114. package/template/knowledge/workers/templates/social-worker.yaml +0 -70
  115. package/template/modules/examples/full-manifest.yaml +0 -92
  116. package/template/modules/examples/minimal.yaml +0 -14
  117. package/template/modules/modules.yaml +0 -59
  118. package/template/projects/.gitkeep +0 -0
  119. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +0 -88
  120. package/template/projects/pure-ralph-branch-isolation/README.md +0 -114
  121. package/template/projects/pure-ralph-branch-isolation/prd.json +0 -123
  122. package/template/projects/purist-ralph-loop/README.md +0 -148
  123. package/template/projects/purist-ralph-loop/prd.json +0 -135
  124. package/template/projects/ralph-test/prd.json +0 -50
  125. package/template/prompts/pure-ralph-base.md +0 -551
  126. package/template/settings/.gitkeep +0 -0
  127. package/template/settings/pure-ralph.json +0 -42
  128. package/template/social-content/drafts/INDEX.md +0 -21
  129. package/template/social-content/drafts/linkedin/.gitkeep +0 -1
  130. package/template/social-content/drafts/x/.gitkeep +0 -1
  131. package/template/social-content/images/.gitkeep +0 -1
  132. package/template/starter-projects/code-worker/README.md +0 -97
  133. package/template/starter-projects/code-worker/prd.json +0 -45
  134. package/template/starter-projects/personal-assistant/README.md +0 -42
  135. package/template/starter-projects/personal-assistant/prd.json +0 -43
  136. package/template/starter-projects/social-media/README.md +0 -60
  137. package/template/starter-projects/social-media/prd.json +0 -43
  138. package/template/workers/content-brand/README.md +0 -59
  139. package/template/workers/content-brand/skills/messaging-alignment.md +0 -91
  140. package/template/workers/content-brand/skills/tone-check.md +0 -76
  141. package/template/workers/content-brand/skills/voice-analysis.md +0 -68
  142. package/template/workers/content-brand/worker.yaml +0 -81
  143. package/template/workers/content-legal/README.md +0 -80
  144. package/template/workers/content-legal/skills/claim-substantiation.md +0 -150
  145. package/template/workers/content-legal/skills/compliance-scan.md +0 -123
  146. package/template/workers/content-legal/skills/disclaimer-check.md +0 -146
  147. package/template/workers/content-legal/worker.yaml +0 -118
  148. package/template/workers/content-product/README.md +0 -77
  149. package/template/workers/content-product/skills/claim-verification.md +0 -96
  150. package/template/workers/content-product/skills/feature-accuracy.md +0 -117
  151. package/template/workers/content-product/skills/stats-check.md +0 -128
  152. package/template/workers/content-product/worker.yaml +0 -97
  153. package/template/workers/content-sales/README.md +0 -70
  154. package/template/workers/content-sales/skills/conversion-analysis.md +0 -96
  155. package/template/workers/content-sales/skills/cta-audit.md +0 -107
  156. package/template/workers/content-sales/skills/value-prop-check.md +0 -114
  157. package/template/workers/content-sales/worker.yaml +0 -93
  158. package/template/workers/content-shared/cli.ts +0 -242
  159. package/template/workers/content-shared/index.ts +0 -234
  160. package/template/workers/content-shared/lib/accuracy-analyzer.ts +0 -661
  161. package/template/workers/content-shared/lib/analyze.ts +0 -370
  162. package/template/workers/content-shared/lib/brand-analyzer.ts +0 -526
  163. package/template/workers/content-shared/lib/cms-integration.ts +0 -446
  164. package/template/workers/content-shared/lib/compliance-analyzer.ts +0 -655
  165. package/template/workers/content-shared/lib/conversion-analyzer.ts +0 -555
  166. package/template/workers/content-shared/lib/github-integration.ts +0 -582
  167. package/template/workers/content-shared/lib/output.ts +0 -373
  168. package/template/workers/content-shared/lib/parser.ts +0 -771
  169. package/template/workers/content-shared/lib/priority.ts +0 -439
  170. package/template/workers/content-shared/lib/recommendations.ts +0 -512
  171. package/template/workers/content-shared/lib/reporter.ts +0 -749
  172. package/template/workers/content-shared/lib/restructure.ts +0 -664
  173. package/template/workers/content-shared/lib/scorer.ts +0 -140
  174. package/template/workers/content-shared/lib/types.ts +0 -227
  175. package/template/workers/content-shared/lib/variants.ts +0 -595
  176. package/template/workers/content-shared/package.json +0 -51
  177. package/template/workers/content-shared/pnpm-lock.yaml +0 -39
  178. package/template/workers/content-shared/test/sample-page.json +0 -115
  179. package/template/workers/content-shared/tsconfig.json +0 -20
  180. package/template/workers/dev-team/README.md +0 -166
  181. package/template/workers/dev-team/_template.yaml +0 -70
  182. package/template/workers/dev-team/architect/package.json +0 -27
  183. package/template/workers/dev-team/architect/skills/api-design.md +0 -89
  184. package/template/workers/dev-team/architect/skills/refactor-plan.md +0 -96
  185. package/template/workers/dev-team/architect/skills/system-design.md +0 -100
  186. package/template/workers/dev-team/architect/src/index.ts +0 -49
  187. package/template/workers/dev-team/architect/src/mcp-server.ts +0 -122
  188. package/template/workers/dev-team/architect/src/skills/api-design.ts +0 -316
  189. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +0 -264
  190. package/template/workers/dev-team/architect/src/skills/system-design.ts +0 -212
  191. package/template/workers/dev-team/architect/tsconfig.json +0 -19
  192. package/template/workers/dev-team/architect/worker.yaml +0 -128
  193. package/template/workers/dev-team/backend-dev/package-lock.json +0 -1252
  194. package/template/workers/dev-team/backend-dev/package.json +0 -27
  195. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +0 -70
  196. package/template/workers/dev-team/backend-dev/skills/implement-service.md +0 -62
  197. package/template/workers/dev-team/backend-dev/src/index.ts +0 -51
  198. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +0 -109
  199. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +0 -122
  200. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +0 -126
  201. package/template/workers/dev-team/backend-dev/tsconfig.json +0 -19
  202. package/template/workers/dev-team/backend-dev/worker.yaml +0 -128
  203. package/template/workers/dev-team/code-reviewer/package-lock.json +0 -1080
  204. package/template/workers/dev-team/code-reviewer/package.json +0 -24
  205. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +0 -61
  206. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +0 -54
  207. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +0 -63
  208. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +0 -77
  209. package/template/workers/dev-team/code-reviewer/src/index.ts +0 -56
  210. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +0 -101
  211. package/template/workers/dev-team/code-reviewer/tsconfig.json +0 -19
  212. package/template/workers/dev-team/code-reviewer/worker.yaml +0 -90
  213. package/template/workers/dev-team/database-dev/package.json +0 -22
  214. package/template/workers/dev-team/database-dev/skills/create-schema.md +0 -48
  215. package/template/workers/dev-team/database-dev/src/index.ts +0 -50
  216. package/template/workers/dev-team/database-dev/src/mcp-server.ts +0 -76
  217. package/template/workers/dev-team/database-dev/tsconfig.json +0 -18
  218. package/template/workers/dev-team/database-dev/worker.yaml +0 -90
  219. package/template/workers/dev-team/frontend-dev/package.json +0 -22
  220. package/template/workers/dev-team/frontend-dev/skills/create-component.md +0 -26
  221. package/template/workers/dev-team/frontend-dev/src/index.ts +0 -50
  222. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +0 -77
  223. package/template/workers/dev-team/frontend-dev/tsconfig.json +0 -18
  224. package/template/workers/dev-team/frontend-dev/worker.yaml +0 -132
  225. package/template/workers/dev-team/infra-dev/package.json +0 -24
  226. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +0 -73
  227. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +0 -80
  228. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +0 -62
  229. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +0 -63
  230. package/template/workers/dev-team/infra-dev/src/index.ts +0 -55
  231. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +0 -82
  232. package/template/workers/dev-team/infra-dev/tsconfig.json +0 -19
  233. package/template/workers/dev-team/infra-dev/worker.yaml +0 -92
  234. package/template/workers/dev-team/knowledge-curator/package.json +0 -24
  235. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +0 -63
  236. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +0 -61
  237. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +0 -76
  238. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +0 -63
  239. package/template/workers/dev-team/knowledge-curator/src/index.ts +0 -53
  240. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +0 -92
  241. package/template/workers/dev-team/knowledge-curator/tsconfig.json +0 -19
  242. package/template/workers/dev-team/knowledge-curator/worker.yaml +0 -80
  243. package/template/workers/dev-team/motion-designer/package.json +0 -22
  244. package/template/workers/dev-team/motion-designer/skills/add-animation.md +0 -25
  245. package/template/workers/dev-team/motion-designer/skills/generate-image.md +0 -36
  246. package/template/workers/dev-team/motion-designer/src/index.ts +0 -63
  247. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +0 -79
  248. package/template/workers/dev-team/motion-designer/tsconfig.json +0 -18
  249. package/template/workers/dev-team/motion-designer/worker.yaml +0 -84
  250. package/template/workers/dev-team/product-planner/queue.json +0 -4
  251. package/template/workers/dev-team/product-planner/worker.yaml +0 -220
  252. package/template/workers/dev-team/project-manager/package-lock.json +0 -1252
  253. package/template/workers/dev-team/project-manager/package.json +0 -27
  254. package/template/workers/dev-team/project-manager/skills/create-prd.md +0 -66
  255. package/template/workers/dev-team/project-manager/skills/next-issue.md +0 -51
  256. package/template/workers/dev-team/project-manager/skills/project-status.md +0 -59
  257. package/template/workers/dev-team/project-manager/skills/update-learnings.md +0 -65
  258. package/template/workers/dev-team/project-manager/src/index.ts +0 -54
  259. package/template/workers/dev-team/project-manager/src/mcp-server.ts +0 -207
  260. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +0 -86
  261. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +0 -137
  262. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +0 -131
  263. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +0 -94
  264. package/template/workers/dev-team/project-manager/tsconfig.json +0 -19
  265. package/template/workers/dev-team/project-manager/worker.yaml +0 -96
  266. package/template/workers/dev-team/qa-tester/package.json +0 -24
  267. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +0 -36
  268. package/template/workers/dev-team/qa-tester/skills/run-tests.md +0 -36
  269. package/template/workers/dev-team/qa-tester/skills/write-test.md +0 -27
  270. package/template/workers/dev-team/qa-tester/src/index.ts +0 -61
  271. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +0 -88
  272. package/template/workers/dev-team/qa-tester/tsconfig.json +0 -18
  273. package/template/workers/dev-team/qa-tester/worker.yaml +0 -116
  274. package/template/workers/dev-team/task-executor/package-lock.json +0 -1252
  275. package/template/workers/dev-team/task-executor/package.json +0 -27
  276. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +0 -101
  277. package/template/workers/dev-team/task-executor/skills/execute.md +0 -133
  278. package/template/workers/dev-team/task-executor/skills/report-learnings.md +0 -106
  279. package/template/workers/dev-team/task-executor/skills/validate-completion.md +0 -121
  280. package/template/workers/dev-team/task-executor/src/index.ts +0 -54
  281. package/template/workers/dev-team/task-executor/src/mcp-server.ts +0 -139
  282. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +0 -219
  283. package/template/workers/dev-team/task-executor/src/skills/execute.ts +0 -132
  284. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +0 -119
  285. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +0 -142
  286. package/template/workers/dev-team/task-executor/tsconfig.json +0 -19
  287. package/template/workers/dev-team/task-executor/worker.yaml +0 -110
  288. package/template/workers/registry.yaml +0 -171
  289. package/template/workers/security-scanner/README.md +0 -73
  290. package/template/workers/security-scanner/skills/pre-deploy-check.md +0 -205
  291. package/template/workers/security-scanner/worker.yaml +0 -26
  292. package/template/workspace/checkpoints/.gitkeep +0 -0
  293. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  294. package/template/workspace/drafts/.gitkeep +0 -0
  295. package/template/workspace/learnings/.gitkeep +0 -3
  296. package/template/workspace/orchestrator/.gitkeep +0 -0
  297. package/template/workspace/ralph-test/COMPLETE.md +0 -18
  298. package/template/workspace/ralph-test/hello.txt +0 -2
  299. package/template/workspace/reports/.gitkeep +0 -0
  300. package/template/workspace/scratch/.gitkeep +0 -0
  301. package/template/workspace/threads/.gitkeep +0 -3
@@ -1,264 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
- import { execSync } from 'child_process';
4
-
5
- interface RefactorPlanOptions {
6
- target: string;
7
- repo?: string;
8
- goal?: string;
9
- }
10
-
11
- interface RefactorStep {
12
- description: string;
13
- files: string[];
14
- risk: 'low' | 'medium' | 'high';
15
- tests: string[];
16
- }
17
-
18
- export async function refactorPlan(options: RefactorPlanOptions): Promise<void> {
19
- const { target, repo, goal } = options;
20
-
21
- console.log(`\n=== Refactor Plan: ${target} ===\n`);
22
-
23
- if (goal) {
24
- console.log(`Goal: ${goal}\n`);
25
- }
26
-
27
- // Analyze target
28
- let analysis: { issues: string[]; metrics: Record<string, number> } = {
29
- issues: [],
30
- metrics: {},
31
- };
32
-
33
- if (repo) {
34
- console.log('Analyzing target code...');
35
- analysis = analyzeTarget(repo, target);
36
-
37
- console.log('\nCurrent state:');
38
- for (const issue of analysis.issues) {
39
- console.log(` - ${issue}`);
40
- }
41
-
42
- if (Object.keys(analysis.metrics).length > 0) {
43
- console.log('\nMetrics:');
44
- for (const [key, value] of Object.entries(analysis.metrics)) {
45
- console.log(` - ${key}: ${value}`);
46
- }
47
- }
48
- }
49
-
50
- // Generate refactoring steps
51
- const steps = generateSteps(target, goal, analysis.issues);
52
-
53
- console.log('\n' + '-'.repeat(40));
54
- console.log('\nRefactoring Steps:\n');
55
-
56
- for (let i = 0; i < steps.length; i++) {
57
- const step = steps[i];
58
- const riskColor = step.risk === 'high' ? '⚠️' : step.risk === 'medium' ? '⚡' : '✓';
59
- console.log(`${i + 1}. [ ] ${step.description} ${riskColor}`);
60
- console.log(` Files: ${step.files.join(', ')}`);
61
- console.log(` Risk: ${step.risk}`);
62
- if (step.tests.length > 0) {
63
- console.log(` Tests: ${step.tests.join(', ')}`);
64
- }
65
- console.log();
66
- }
67
-
68
- // Test strategy
69
- console.log('-'.repeat(40));
70
- console.log('\nTest Strategy:');
71
- console.log(' - Run existing tests after each step');
72
- console.log(' - Verify no regressions');
73
- if (analysis.issues.some(i => i.includes('test'))) {
74
- console.log(' - Add missing tests before refactoring');
75
- }
76
-
77
- // Rollback plan
78
- console.log('\nRollback Plan:');
79
- console.log(' If issues arise at step N:');
80
- console.log(' 1. git revert to commit before step N');
81
- console.log(' 2. Analyze failure');
82
- console.log(' 3. Adjust approach and retry');
83
-
84
- // Effort estimate
85
- const complexity = steps.length <= 3 ? 'simple' :
86
- steps.length <= 6 ? 'medium' : 'complex';
87
- console.log(`\nEstimated effort: ${steps.length} phases, ${complexity} complexity`);
88
-
89
- console.log('\n[Human approval required]');
90
- console.log('Approve plan? [y/n/modify]');
91
- }
92
-
93
- function analyzeTarget(repoPath: string, target: string): { issues: string[]; metrics: Record<string, number> } {
94
- const issues: string[] = [];
95
- const metrics: Record<string, number> = {};
96
-
97
- const fullPath = path.join(repoPath, target);
98
-
99
- if (!fs.existsSync(fullPath)) {
100
- issues.push(`Target not found: ${target}`);
101
- return { issues, metrics };
102
- }
103
-
104
- // Check if it's a directory or file
105
- const stat = fs.statSync(fullPath);
106
-
107
- if (stat.isDirectory()) {
108
- // Count files
109
- try {
110
- const files = fs.readdirSync(fullPath, { recursive: true }) as string[];
111
- const tsFiles = files.filter(f => f.endsWith('.ts') || f.endsWith('.tsx'));
112
- metrics['files'] = tsFiles.length;
113
- } catch (e) {
114
- // Ignore
115
- }
116
- }
117
-
118
- // Look for common issues
119
- try {
120
- const content = stat.isFile()
121
- ? fs.readFileSync(fullPath, 'utf-8')
122
- : '';
123
-
124
- // Check for 'any' types
125
- const anyCount = (content.match(/: any/g) || []).length;
126
- if (anyCount > 0) {
127
- issues.push(`${anyCount} uses of 'any' type`);
128
- metrics['any_types'] = anyCount;
129
- }
130
-
131
- // Check for @ts-ignore
132
- const ignoreCount = (content.match(/@ts-ignore/g) || []).length;
133
- if (ignoreCount > 0) {
134
- issues.push(`${ignoreCount} @ts-ignore comments`);
135
- metrics['ts_ignore'] = ignoreCount;
136
- }
137
-
138
- // Check for TODO comments
139
- const todoCount = (content.match(/TODO/gi) || []).length;
140
- if (todoCount > 0) {
141
- issues.push(`${todoCount} TODO comments`);
142
- metrics['todos'] = todoCount;
143
- }
144
-
145
- } catch (e) {
146
- // Ignore read errors
147
- }
148
-
149
- if (issues.length === 0) {
150
- issues.push('No obvious issues detected (manual review recommended)');
151
- }
152
-
153
- return { issues, metrics };
154
- }
155
-
156
- function generateSteps(target: string, goal?: string, issues: string[] = []): RefactorStep[] {
157
- const goalLower = (goal || '').toLowerCase();
158
-
159
- // TypeScript strict mode refactoring
160
- if (goalLower.includes('strict') || goalLower.includes('typescript')) {
161
- return [
162
- {
163
- description: 'Add explicit types to function parameters',
164
- files: [target],
165
- risk: 'low',
166
- tests: ['npm run typecheck'],
167
- },
168
- {
169
- description: 'Add explicit return types to functions',
170
- files: [target],
171
- risk: 'low',
172
- tests: ['npm run typecheck'],
173
- },
174
- {
175
- description: 'Replace "any" with proper types',
176
- files: [target],
177
- risk: 'medium',
178
- tests: ['npm run typecheck', 'npm test'],
179
- },
180
- {
181
- description: 'Add null checks for optional values',
182
- files: [target],
183
- risk: 'medium',
184
- tests: ['npm run typecheck', 'npm test'],
185
- },
186
- {
187
- description: 'Remove @ts-ignore comments',
188
- files: [target],
189
- risk: 'low',
190
- tests: ['npm run typecheck'],
191
- },
192
- {
193
- description: 'Enable strict mode in tsconfig',
194
- files: ['tsconfig.json'],
195
- risk: 'low',
196
- tests: ['npm run typecheck', 'npm run build'],
197
- },
198
- ];
199
- }
200
-
201
- // Performance refactoring
202
- if (goalLower.includes('performance') || goalLower.includes('optimize')) {
203
- return [
204
- {
205
- description: 'Profile current performance',
206
- files: [target],
207
- risk: 'low',
208
- tests: ['manual performance measurement'],
209
- },
210
- {
211
- description: 'Identify bottlenecks',
212
- files: [target],
213
- risk: 'low',
214
- tests: [],
215
- },
216
- {
217
- description: 'Implement optimizations',
218
- files: [target],
219
- risk: 'medium',
220
- tests: ['npm test', 'performance benchmark'],
221
- },
222
- {
223
- description: 'Verify performance improvement',
224
- files: [],
225
- risk: 'low',
226
- tests: ['performance benchmark'],
227
- },
228
- ];
229
- }
230
-
231
- // Default: General refactoring steps
232
- return [
233
- {
234
- description: 'Identify code to refactor',
235
- files: [target],
236
- risk: 'low',
237
- tests: [],
238
- },
239
- {
240
- description: 'Add tests for existing behavior',
241
- files: [target],
242
- risk: 'low',
243
- tests: ['npm test'],
244
- },
245
- {
246
- description: 'Perform refactoring',
247
- files: [target],
248
- risk: 'medium',
249
- tests: ['npm run typecheck', 'npm test'],
250
- },
251
- {
252
- description: 'Update documentation',
253
- files: [target],
254
- risk: 'low',
255
- tests: [],
256
- },
257
- {
258
- description: 'Final verification',
259
- files: [],
260
- risk: 'low',
261
- tests: ['npm run typecheck', 'npm run lint', 'npm test'],
262
- },
263
- ];
264
- }
@@ -1,212 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
-
4
- interface SystemDesignOptions {
5
- feature: string;
6
- repo?: string;
7
- scope?: 'small' | 'medium' | 'large';
8
- }
9
-
10
- interface DesignOption {
11
- name: string;
12
- description: string;
13
- pros: string[];
14
- cons: string[];
15
- recommended?: boolean;
16
- }
17
-
18
- export async function systemDesign(options: SystemDesignOptions): Promise<void> {
19
- const { feature, repo, scope = 'medium' } = options;
20
-
21
- console.log(`\n=== System Design: ${feature} ===\n`);
22
-
23
- // Analyze existing architecture if repo provided
24
- if (repo) {
25
- console.log('Analyzing existing architecture...');
26
- const analysis = analyzeRepo(repo);
27
- console.log('\nExisting patterns:');
28
- for (const pattern of analysis.patterns) {
29
- console.log(` - ${pattern}`);
30
- }
31
- console.log('\nKey dependencies:');
32
- for (const dep of analysis.dependencies.slice(0, 5)) {
33
- console.log(` - ${dep}`);
34
- }
35
- }
36
-
37
- // Generate design options based on feature
38
- const designOptions = generateDesignOptions(feature, scope);
39
-
40
- console.log('\n' + '-'.repeat(40));
41
- console.log('\nDesign Options:\n');
42
-
43
- for (let i = 0; i < designOptions.length; i++) {
44
- const opt = designOptions[i];
45
- const rec = opt.recommended ? ' (Recommended)' : '';
46
- console.log(`${i + 1}. ${opt.name}${rec}`);
47
- console.log(` ${opt.description}`);
48
- console.log(' Pros:');
49
- for (const pro of opt.pros) {
50
- console.log(` + ${pro}`);
51
- }
52
- console.log(' Cons:');
53
- for (const con of opt.cons) {
54
- console.log(` - ${con}`);
55
- }
56
- console.log();
57
- }
58
-
59
- console.log('[Human approval required]');
60
- console.log(`Select approach: [1-${designOptions.length}]`);
61
-
62
- // Show what would be generated
63
- console.log('\n' + '-'.repeat(40));
64
- console.log('\nOn approval, will generate:');
65
- console.log(' - Architecture Decision Record (ADR)');
66
- console.log(' - Component diagram (Mermaid)');
67
- console.log(' - Implementation guide for workers');
68
-
69
- // Sample ADR output
70
- console.log('\n' + '-'.repeat(40));
71
- console.log('\nSample ADR Preview:');
72
- console.log(`
73
- # ADR: ${feature}
74
-
75
- ## Status
76
- Proposed
77
-
78
- ## Context
79
- Implementation of ${feature} requires architectural decisions
80
- regarding ${scope} scope changes.
81
-
82
- ## Decision
83
- [Selected option will be documented here]
84
-
85
- ## Consequences
86
- - Integration with existing patterns
87
- - Changes to: [affected components]
88
- - New dependencies: [if any]
89
-
90
- ## Implementation Guide
91
- 1. [Steps for architect/other workers]
92
- 2. ...
93
- `);
94
- }
95
-
96
- function analyzeRepo(repoPath: string): { patterns: string[]; dependencies: string[] } {
97
- const patterns: string[] = [];
98
- const dependencies: string[] = [];
99
-
100
- // Check for common patterns
101
- const checks = [
102
- { file: 'next.config.js', pattern: 'Next.js' },
103
- { file: 'next.config.mjs', pattern: 'Next.js' },
104
- { file: 'prisma/schema.prisma', pattern: 'Prisma ORM' },
105
- { file: 'drizzle.config.ts', pattern: 'Drizzle ORM' },
106
- { file: 'src/app', pattern: 'Next.js App Router' },
107
- { file: 'src/pages', pattern: 'Next.js Pages Router' },
108
- { file: 'tailwind.config.js', pattern: 'Tailwind CSS' },
109
- { file: 'tailwind.config.ts', pattern: 'Tailwind CSS' },
110
- ];
111
-
112
- for (const check of checks) {
113
- const fullPath = path.join(repoPath, check.file);
114
- if (fs.existsSync(fullPath)) {
115
- patterns.push(check.pattern);
116
- }
117
- }
118
-
119
- // Check package.json for dependencies
120
- const pkgPath = path.join(repoPath, 'package.json');
121
- if (fs.existsSync(pkgPath)) {
122
- try {
123
- const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));
124
- const deps = { ...pkg.dependencies, ...pkg.devDependencies };
125
- dependencies.push(...Object.keys(deps).slice(0, 10));
126
- } catch (e) {
127
- // Ignore parse errors
128
- }
129
- }
130
-
131
- if (patterns.length === 0) {
132
- patterns.push('(Unable to detect patterns - provide --repo)');
133
- }
134
-
135
- return { patterns, dependencies };
136
- }
137
-
138
- function generateDesignOptions(feature: string, scope: string): DesignOption[] {
139
- // Generate context-aware options based on feature keywords
140
- const featureLower = feature.toLowerCase();
141
-
142
- if (featureLower.includes('auth')) {
143
- return [
144
- {
145
- name: 'NextAuth.js',
146
- description: 'Use NextAuth.js for authentication with built-in providers',
147
- pros: ['Battle-tested', 'Many OAuth providers', 'Session management included'],
148
- cons: ['Opinionated structure', 'Some flexibility limits'],
149
- recommended: true,
150
- },
151
- {
152
- name: 'Custom OAuth',
153
- description: 'Build custom OAuth implementation',
154
- pros: ['Full control', 'No external dependencies'],
155
- cons: ['More work', 'Security risks', 'Maintenance burden'],
156
- },
157
- {
158
- name: 'Managed Service (Clerk/Auth0)',
159
- description: 'Use a managed authentication service',
160
- pros: ['Zero maintenance', 'Advanced features included'],
161
- cons: ['Vendor lock-in', 'Monthly cost', 'Less control'],
162
- },
163
- ];
164
- }
165
-
166
- if (featureLower.includes('api') || featureLower.includes('endpoint')) {
167
- return [
168
- {
169
- name: 'REST API',
170
- description: 'Traditional REST endpoints with JSON',
171
- pros: ['Simple', 'Well-understood', 'Good tooling'],
172
- cons: ['Over/under-fetching', 'Multiple requests needed'],
173
- recommended: true,
174
- },
175
- {
176
- name: 'GraphQL',
177
- description: 'GraphQL API with schema-first approach',
178
- pros: ['Flexible queries', 'Strong typing', 'Single endpoint'],
179
- cons: ['Complexity', 'Learning curve', 'Caching challenges'],
180
- },
181
- {
182
- name: 'tRPC',
183
- description: 'End-to-end typesafe APIs',
184
- pros: ['Full type safety', 'No codegen', 'Great DX'],
185
- cons: ['TypeScript only', 'Tighter coupling'],
186
- },
187
- ];
188
- }
189
-
190
- // Default options for general features
191
- return [
192
- {
193
- name: 'Incremental Addition',
194
- description: 'Add feature alongside existing code',
195
- pros: ['Low risk', 'Quick to implement', 'Easy rollback'],
196
- cons: ['May not optimize for feature', 'Technical debt possible'],
197
- recommended: true,
198
- },
199
- {
200
- name: 'Refactor First',
201
- description: 'Refactor existing code, then add feature',
202
- pros: ['Clean architecture', 'Better long-term'],
203
- cons: ['More time', 'Higher initial risk'],
204
- },
205
- {
206
- name: 'New Module',
207
- description: 'Create isolated module for feature',
208
- pros: ['Clean separation', 'Independent testing'],
209
- cons: ['Integration overhead', 'Duplication possible'],
210
- },
211
- ];
212
- }
@@ -1,19 +0,0 @@
1
- {
2
- "compilerOptions": {
3
- "target": "ES2022",
4
- "module": "commonjs",
5
- "lib": ["ES2022"],
6
- "outDir": "./dist",
7
- "rootDir": "./src",
8
- "strict": true,
9
- "esModuleInterop": true,
10
- "skipLibCheck": true,
11
- "forceConsistentCasingInFileNames": true,
12
- "resolveJsonModule": true,
13
- "declaration": true,
14
- "declarationMap": true,
15
- "sourceMap": true
16
- },
17
- "include": ["src/**/*"],
18
- "exclude": ["node_modules", "dist"]
19
- }
@@ -1,128 +0,0 @@
1
- worker:
2
- id: architect
3
- name: "Architect"
4
- type: CodeWorker
5
- version: "1.0"
6
-
7
- execution:
8
- mode: on_demand
9
- max_runtime: 15m
10
- retry_attempts: 1
11
-
12
- context:
13
- base:
14
- - workers/public/dev-team/architect/
15
- - workers/public/dev-team/architect/skills/
16
- - knowledge/public/dev-team/patterns/
17
- dynamic:
18
- - pattern: "{target_repo}/"
19
- when: always
20
- exclude:
21
- - node_modules/
22
- - dist/
23
- - "*.log"
24
- - ".git/"
25
-
26
- verification:
27
- post_execute:
28
- - check: typescript
29
- command: npm run typecheck
30
- approval_required: true
31
-
32
- external_skills:
33
- # Vercel React Best Practices - Architecture guidance
34
- - vercel/react-best-practices
35
- # Architecture-relevant patterns:
36
- # - Strategic Suspense boundaries
37
- # - Component composition for parallel fetching
38
- # - Bundle splitting strategies
39
- # - Server/client boundary decisions
40
-
41
- output:
42
- destination: workspace/reports/dev-team/
43
- format: both
44
- naming: "{date}-architect-{task}.{ext}"
45
-
46
- mcp:
47
- server:
48
- command: node
49
- args:
50
- - dist/mcp-server.js
51
- cwd: workers/public/dev-team/architect
52
- tools:
53
- - system_design
54
- - api_design
55
- - code_review_plan
56
- - refactor_plan
57
-
58
- # State Machine (Loom pattern)
59
- state_machine:
60
- enabled: true
61
- max_retries: 1
62
- hooks:
63
- post_execute:
64
- - auto_checkpoint
65
- - log_metrics
66
- on_error:
67
- - log_error
68
- - checkpoint_error_state
69
-
70
- instructions: |
71
- # Architect
72
-
73
- System design, planning, and technical decision-making.
74
-
75
- ## Skills
76
-
77
- | Skill | Description |
78
- |-------|-------------|
79
- | system-design | Design system architecture for feature |
80
- | api-design | Design API contracts and interfaces |
81
- | code-review-plan | Plan approach for code review |
82
- | refactor-plan | Plan refactoring approach |
83
-
84
- ## CLI Usage
85
-
86
- ```bash
87
- cd workers/public/dev-team/architect
88
- node dist/index.js system-design --feature "user auth" --repo path/to/repo
89
- node dist/index.js api-design --endpoint "/api/users" --repo path/to/repo
90
- ```
91
-
92
- ## Responsibilities
93
-
94
- 1. Analyze existing codebase architecture
95
- 2. Design new features to fit existing patterns
96
- 3. Define API contracts before implementation
97
- 4. Identify breaking changes and migration paths
98
- 5. Document architectural decisions
99
-
100
- ## React Architecture Patterns (Vercel)
101
-
102
- Data Loading:
103
- - Strategic Suspense boundary placement
104
- - Component composition for parallel data fetching
105
- - Server vs Client component decisions
106
-
107
- Performance:
108
- - Bundle splitting strategy (dynamic imports)
109
- - Avoid barrel file architectures
110
- - Preloading based on user intent patterns
111
-
112
- Server Components:
113
- - Minimize RSC serialization boundaries
114
- - Cross-request caching strategies
115
- - React.cache() placement
116
-
117
- ## Output
118
-
119
- - Architecture decision records (ADR)
120
- - API specifications (OpenAPI/TypeScript interfaces)
121
- - Component diagrams (Mermaid)
122
- - Implementation guides for other workers
123
-
124
- ## Human-in-the-loop
125
-
126
- - Present design options with trade-offs
127
- - Get approval before defining contracts
128
- - Surface breaking changes clearly