create-hq 5.1.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 (299) 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 +1 -1
  6. package/dist/scaffold.d.ts.map +1 -1
  7. package/dist/scaffold.js +16 -26
  8. package/dist/scaffold.js.map +1 -1
  9. package/dist/ui.js +1 -1
  10. package/package.json +3 -6
  11. package/template/.claude/CLAUDE.md +0 -202
  12. package/template/.claude/commands/checkpoint.md +0 -127
  13. package/template/.claude/commands/cleanup.md +0 -307
  14. package/template/.claude/commands/execute-task.md +0 -440
  15. package/template/.claude/commands/exit-plan.md +0 -41
  16. package/template/.claude/commands/handoff.md +0 -97
  17. package/template/.claude/commands/learn.md +0 -218
  18. package/template/.claude/commands/metrics.md +0 -118
  19. package/template/.claude/commands/newworker.md +0 -162
  20. package/template/.claude/commands/nexttask.md +0 -67
  21. package/template/.claude/commands/prd.md +0 -238
  22. package/template/.claude/commands/reanchor.md +0 -51
  23. package/template/.claude/commands/remember.md +0 -126
  24. package/template/.claude/commands/run-project.md +0 -348
  25. package/template/.claude/commands/run.md +0 -110
  26. package/template/.claude/commands/search-reindex.md +0 -62
  27. package/template/.claude/commands/search.md +0 -100
  28. package/template/.claude/commands/setup.md +0 -381
  29. package/template/.claude/scripts/pure-ralph-loop.ps1 +0 -312
  30. package/template/.claude/scripts/pure-ralph-loop.sh +0 -859
  31. package/template/CHANGELOG.md +0 -220
  32. package/template/LICENSE +0 -21
  33. package/template/MIGRATION.md +0 -259
  34. package/template/README.md +0 -368
  35. package/template/data/journal/.gitkeep +0 -0
  36. package/template/docs/images/ascii-banner-options.md +0 -122
  37. package/template/docs/images/hq-banner.svg +0 -105
  38. package/template/knowledge/Ralph/01-overview.md +0 -71
  39. package/template/knowledge/Ralph/02-core-concepts.md +0 -114
  40. package/template/knowledge/Ralph/03-how-ralph-works.md +0 -184
  41. package/template/knowledge/Ralph/04-back-pressure.md +0 -222
  42. package/template/knowledge/Ralph/05-specifications.md +0 -210
  43. package/template/knowledge/Ralph/06-agents-md.md +0 -222
  44. package/template/knowledge/Ralph/07-implementation.md +0 -316
  45. package/template/knowledge/Ralph/08-economics.md +0 -182
  46. package/template/knowledge/Ralph/09-resources.md +0 -145
  47. package/template/knowledge/Ralph/10-claude-code-workflow.md +0 -212
  48. package/template/knowledge/Ralph/11-team-training-guide.md +0 -383
  49. package/template/knowledge/Ralph/README.md +0 -40
  50. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +0 -139
  51. package/template/knowledge/ai-security-framework/GLOSSARY.md +0 -176
  52. package/template/knowledge/ai-security-framework/LICENSE +0 -21
  53. package/template/knowledge/ai-security-framework/QUICK-START.md +0 -172
  54. package/template/knowledge/ai-security-framework/README.md +0 -232
  55. package/template/knowledge/ai-security-framework/checklists/browser-security.md +0 -301
  56. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +0 -322
  57. package/template/knowledge/ai-security-framework/checklists/incident-response.md +0 -288
  58. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +0 -249
  59. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +0 -159
  60. package/template/knowledge/ai-security-framework/configs/audit-logging.md +0 -372
  61. package/template/knowledge/ai-security-framework/configs/kill-switches.md +0 -354
  62. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +0 -256
  63. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +0 -326
  64. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +0 -250
  65. package/template/knowledge/ai-security-framework/templates/agents-security.md +0 -233
  66. package/template/knowledge/design-styles/README.md +0 -42
  67. package/template/knowledge/design-styles/american-industrial.md +0 -136
  68. package/template/knowledge/design-styles/ethereal-abstract.md +0 -133
  69. package/template/knowledge/design-styles/liminal-portal.md +0 -111
  70. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  71. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  72. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  73. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  74. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  75. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  76. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  77. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  78. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  79. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  80. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  81. package/template/knowledge/design-styles/swipes/american-industrial/README.md +0 -31
  82. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  83. package/template/knowledge/dev-team/README.md +0 -35
  84. package/template/knowledge/dev-team/patterns/README.md +0 -34
  85. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +0 -178
  86. package/template/knowledge/dev-team/troubleshooting/README.md +0 -31
  87. package/template/knowledge/dev-team/workflows/README.md +0 -49
  88. package/template/knowledge/hq/checkpoint-schema.json +0 -51
  89. package/template/knowledge/hq/index-md-spec.md +0 -74
  90. package/template/knowledge/hq/thread-schema.md +0 -153
  91. package/template/knowledge/hq-core/checkpoint-schema.json +0 -51
  92. package/template/knowledge/hq-core/index-md-spec.md +0 -74
  93. package/template/knowledge/hq-core/thread-schema.md +0 -153
  94. package/template/knowledge/loom/README.md +0 -51
  95. package/template/knowledge/loom/architecture.md +0 -125
  96. package/template/knowledge/loom/code-style.md +0 -169
  97. package/template/knowledge/loom/llm-proxy.md +0 -132
  98. package/template/knowledge/loom/state-machine.md +0 -131
  99. package/template/knowledge/loom/thread-system.md +0 -117
  100. package/template/knowledge/loom/tools.md +0 -94
  101. package/template/knowledge/loom/weaver.md +0 -96
  102. package/template/knowledge/loom/web-frontend.md +0 -131
  103. package/template/knowledge/projects/README.md +0 -72
  104. package/template/knowledge/projects/templates/README.template.md +0 -28
  105. package/template/knowledge/workers/README.md +0 -195
  106. package/template/knowledge/workers/ralph-loop-pattern.md +0 -157
  107. package/template/knowledge/workers/skill-schema.md +0 -182
  108. package/template/knowledge/workers/state-machine.md +0 -102
  109. package/template/knowledge/workers/templates/base-worker.yaml +0 -73
  110. package/template/knowledge/workers/templates/code-worker.yaml +0 -85
  111. package/template/knowledge/workers/templates/skill.yaml +0 -49
  112. package/template/knowledge/workers/templates/social-worker.yaml +0 -70
  113. package/template/modules/examples/full-manifest.yaml +0 -92
  114. package/template/modules/examples/minimal.yaml +0 -14
  115. package/template/modules/modules.yaml +0 -59
  116. package/template/projects/.gitkeep +0 -0
  117. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +0 -88
  118. package/template/projects/pure-ralph-branch-isolation/README.md +0 -114
  119. package/template/projects/pure-ralph-branch-isolation/prd.json +0 -123
  120. package/template/projects/purist-ralph-loop/README.md +0 -148
  121. package/template/projects/purist-ralph-loop/prd.json +0 -135
  122. package/template/projects/ralph-test/prd.json +0 -50
  123. package/template/prompts/pure-ralph-base.md +0 -551
  124. package/template/settings/.gitkeep +0 -0
  125. package/template/settings/pure-ralph.json +0 -42
  126. package/template/social-content/drafts/INDEX.md +0 -21
  127. package/template/social-content/drafts/linkedin/.gitkeep +0 -1
  128. package/template/social-content/drafts/x/.gitkeep +0 -1
  129. package/template/social-content/images/.gitkeep +0 -1
  130. package/template/starter-projects/code-worker/README.md +0 -97
  131. package/template/starter-projects/code-worker/prd.json +0 -45
  132. package/template/starter-projects/personal-assistant/README.md +0 -42
  133. package/template/starter-projects/personal-assistant/prd.json +0 -43
  134. package/template/starter-projects/social-media/README.md +0 -60
  135. package/template/starter-projects/social-media/prd.json +0 -43
  136. package/template/workers/content-brand/README.md +0 -59
  137. package/template/workers/content-brand/skills/messaging-alignment.md +0 -91
  138. package/template/workers/content-brand/skills/tone-check.md +0 -76
  139. package/template/workers/content-brand/skills/voice-analysis.md +0 -68
  140. package/template/workers/content-brand/worker.yaml +0 -81
  141. package/template/workers/content-legal/README.md +0 -80
  142. package/template/workers/content-legal/skills/claim-substantiation.md +0 -150
  143. package/template/workers/content-legal/skills/compliance-scan.md +0 -123
  144. package/template/workers/content-legal/skills/disclaimer-check.md +0 -146
  145. package/template/workers/content-legal/worker.yaml +0 -118
  146. package/template/workers/content-product/README.md +0 -77
  147. package/template/workers/content-product/skills/claim-verification.md +0 -96
  148. package/template/workers/content-product/skills/feature-accuracy.md +0 -117
  149. package/template/workers/content-product/skills/stats-check.md +0 -128
  150. package/template/workers/content-product/worker.yaml +0 -97
  151. package/template/workers/content-sales/README.md +0 -70
  152. package/template/workers/content-sales/skills/conversion-analysis.md +0 -96
  153. package/template/workers/content-sales/skills/cta-audit.md +0 -107
  154. package/template/workers/content-sales/skills/value-prop-check.md +0 -114
  155. package/template/workers/content-sales/worker.yaml +0 -93
  156. package/template/workers/content-shared/cli.ts +0 -242
  157. package/template/workers/content-shared/index.ts +0 -234
  158. package/template/workers/content-shared/lib/accuracy-analyzer.ts +0 -661
  159. package/template/workers/content-shared/lib/analyze.ts +0 -370
  160. package/template/workers/content-shared/lib/brand-analyzer.ts +0 -526
  161. package/template/workers/content-shared/lib/cms-integration.ts +0 -446
  162. package/template/workers/content-shared/lib/compliance-analyzer.ts +0 -655
  163. package/template/workers/content-shared/lib/conversion-analyzer.ts +0 -555
  164. package/template/workers/content-shared/lib/github-integration.ts +0 -582
  165. package/template/workers/content-shared/lib/output.ts +0 -373
  166. package/template/workers/content-shared/lib/parser.ts +0 -771
  167. package/template/workers/content-shared/lib/priority.ts +0 -439
  168. package/template/workers/content-shared/lib/recommendations.ts +0 -512
  169. package/template/workers/content-shared/lib/reporter.ts +0 -749
  170. package/template/workers/content-shared/lib/restructure.ts +0 -664
  171. package/template/workers/content-shared/lib/scorer.ts +0 -140
  172. package/template/workers/content-shared/lib/types.ts +0 -227
  173. package/template/workers/content-shared/lib/variants.ts +0 -595
  174. package/template/workers/content-shared/package.json +0 -51
  175. package/template/workers/content-shared/pnpm-lock.yaml +0 -39
  176. package/template/workers/content-shared/test/sample-page.json +0 -115
  177. package/template/workers/content-shared/tsconfig.json +0 -20
  178. package/template/workers/dev-team/README.md +0 -166
  179. package/template/workers/dev-team/_template.yaml +0 -70
  180. package/template/workers/dev-team/architect/package.json +0 -27
  181. package/template/workers/dev-team/architect/skills/api-design.md +0 -89
  182. package/template/workers/dev-team/architect/skills/refactor-plan.md +0 -96
  183. package/template/workers/dev-team/architect/skills/system-design.md +0 -100
  184. package/template/workers/dev-team/architect/src/index.ts +0 -49
  185. package/template/workers/dev-team/architect/src/mcp-server.ts +0 -122
  186. package/template/workers/dev-team/architect/src/skills/api-design.ts +0 -316
  187. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +0 -264
  188. package/template/workers/dev-team/architect/src/skills/system-design.ts +0 -212
  189. package/template/workers/dev-team/architect/tsconfig.json +0 -19
  190. package/template/workers/dev-team/architect/worker.yaml +0 -128
  191. package/template/workers/dev-team/backend-dev/package-lock.json +0 -1252
  192. package/template/workers/dev-team/backend-dev/package.json +0 -27
  193. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +0 -70
  194. package/template/workers/dev-team/backend-dev/skills/implement-service.md +0 -62
  195. package/template/workers/dev-team/backend-dev/src/index.ts +0 -51
  196. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +0 -109
  197. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +0 -122
  198. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +0 -126
  199. package/template/workers/dev-team/backend-dev/tsconfig.json +0 -19
  200. package/template/workers/dev-team/backend-dev/worker.yaml +0 -128
  201. package/template/workers/dev-team/code-reviewer/package-lock.json +0 -1080
  202. package/template/workers/dev-team/code-reviewer/package.json +0 -24
  203. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +0 -61
  204. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +0 -54
  205. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +0 -63
  206. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +0 -77
  207. package/template/workers/dev-team/code-reviewer/src/index.ts +0 -56
  208. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +0 -101
  209. package/template/workers/dev-team/code-reviewer/tsconfig.json +0 -19
  210. package/template/workers/dev-team/code-reviewer/worker.yaml +0 -90
  211. package/template/workers/dev-team/database-dev/package.json +0 -22
  212. package/template/workers/dev-team/database-dev/skills/create-schema.md +0 -48
  213. package/template/workers/dev-team/database-dev/src/index.ts +0 -50
  214. package/template/workers/dev-team/database-dev/src/mcp-server.ts +0 -76
  215. package/template/workers/dev-team/database-dev/tsconfig.json +0 -18
  216. package/template/workers/dev-team/database-dev/worker.yaml +0 -90
  217. package/template/workers/dev-team/frontend-dev/package.json +0 -22
  218. package/template/workers/dev-team/frontend-dev/skills/create-component.md +0 -26
  219. package/template/workers/dev-team/frontend-dev/src/index.ts +0 -50
  220. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +0 -77
  221. package/template/workers/dev-team/frontend-dev/tsconfig.json +0 -18
  222. package/template/workers/dev-team/frontend-dev/worker.yaml +0 -132
  223. package/template/workers/dev-team/infra-dev/package.json +0 -24
  224. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +0 -73
  225. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +0 -80
  226. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +0 -62
  227. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +0 -63
  228. package/template/workers/dev-team/infra-dev/src/index.ts +0 -55
  229. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +0 -82
  230. package/template/workers/dev-team/infra-dev/tsconfig.json +0 -19
  231. package/template/workers/dev-team/infra-dev/worker.yaml +0 -92
  232. package/template/workers/dev-team/knowledge-curator/package.json +0 -24
  233. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +0 -63
  234. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +0 -61
  235. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +0 -76
  236. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +0 -63
  237. package/template/workers/dev-team/knowledge-curator/src/index.ts +0 -53
  238. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +0 -92
  239. package/template/workers/dev-team/knowledge-curator/tsconfig.json +0 -19
  240. package/template/workers/dev-team/knowledge-curator/worker.yaml +0 -80
  241. package/template/workers/dev-team/motion-designer/package.json +0 -22
  242. package/template/workers/dev-team/motion-designer/skills/add-animation.md +0 -25
  243. package/template/workers/dev-team/motion-designer/skills/generate-image.md +0 -36
  244. package/template/workers/dev-team/motion-designer/src/index.ts +0 -63
  245. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +0 -79
  246. package/template/workers/dev-team/motion-designer/tsconfig.json +0 -18
  247. package/template/workers/dev-team/motion-designer/worker.yaml +0 -84
  248. package/template/workers/dev-team/product-planner/queue.json +0 -4
  249. package/template/workers/dev-team/product-planner/worker.yaml +0 -220
  250. package/template/workers/dev-team/project-manager/package-lock.json +0 -1252
  251. package/template/workers/dev-team/project-manager/package.json +0 -27
  252. package/template/workers/dev-team/project-manager/skills/create-prd.md +0 -66
  253. package/template/workers/dev-team/project-manager/skills/next-issue.md +0 -51
  254. package/template/workers/dev-team/project-manager/skills/project-status.md +0 -59
  255. package/template/workers/dev-team/project-manager/skills/update-learnings.md +0 -65
  256. package/template/workers/dev-team/project-manager/src/index.ts +0 -54
  257. package/template/workers/dev-team/project-manager/src/mcp-server.ts +0 -207
  258. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +0 -86
  259. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +0 -137
  260. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +0 -131
  261. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +0 -94
  262. package/template/workers/dev-team/project-manager/tsconfig.json +0 -19
  263. package/template/workers/dev-team/project-manager/worker.yaml +0 -96
  264. package/template/workers/dev-team/qa-tester/package.json +0 -24
  265. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +0 -36
  266. package/template/workers/dev-team/qa-tester/skills/run-tests.md +0 -36
  267. package/template/workers/dev-team/qa-tester/skills/write-test.md +0 -27
  268. package/template/workers/dev-team/qa-tester/src/index.ts +0 -61
  269. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +0 -88
  270. package/template/workers/dev-team/qa-tester/tsconfig.json +0 -18
  271. package/template/workers/dev-team/qa-tester/worker.yaml +0 -116
  272. package/template/workers/dev-team/task-executor/package-lock.json +0 -1252
  273. package/template/workers/dev-team/task-executor/package.json +0 -27
  274. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +0 -101
  275. package/template/workers/dev-team/task-executor/skills/execute.md +0 -133
  276. package/template/workers/dev-team/task-executor/skills/report-learnings.md +0 -106
  277. package/template/workers/dev-team/task-executor/skills/validate-completion.md +0 -121
  278. package/template/workers/dev-team/task-executor/src/index.ts +0 -54
  279. package/template/workers/dev-team/task-executor/src/mcp-server.ts +0 -139
  280. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +0 -219
  281. package/template/workers/dev-team/task-executor/src/skills/execute.ts +0 -132
  282. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +0 -119
  283. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +0 -142
  284. package/template/workers/dev-team/task-executor/tsconfig.json +0 -19
  285. package/template/workers/dev-team/task-executor/worker.yaml +0 -110
  286. package/template/workers/registry.yaml +0 -171
  287. package/template/workers/security-scanner/README.md +0 -73
  288. package/template/workers/security-scanner/skills/pre-deploy-check.md +0 -205
  289. package/template/workers/security-scanner/worker.yaml +0 -26
  290. package/template/workspace/checkpoints/.gitkeep +0 -0
  291. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  292. package/template/workspace/drafts/.gitkeep +0 -0
  293. package/template/workspace/learnings/.gitkeep +0 -3
  294. package/template/workspace/orchestrator/.gitkeep +0 -0
  295. package/template/workspace/ralph-test/COMPLETE.md +0 -18
  296. package/template/workspace/ralph-test/hello.txt +0 -2
  297. package/template/workspace/reports/.gitkeep +0 -0
  298. package/template/workspace/scratch/.gitkeep +0 -0
  299. 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