create-hq 5.0.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 (310) hide show
  1. package/dist/deps.d.ts +4 -0
  2. package/dist/deps.d.ts.map +1 -0
  3. package/dist/deps.js +65 -0
  4. package/dist/deps.js.map +1 -0
  5. package/dist/git.d.ts +3 -0
  6. package/dist/git.d.ts.map +1 -0
  7. package/dist/git.js +19 -0
  8. package/dist/git.js.map +1 -0
  9. package/dist/index.d.ts +3 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js +23 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/scaffold.d.ts +8 -0
  14. package/dist/scaffold.d.ts.map +1 -0
  15. package/dist/scaffold.js +130 -0
  16. package/dist/scaffold.js.map +1 -0
  17. package/dist/ui.d.ts +7 -0
  18. package/dist/ui.d.ts.map +1 -0
  19. package/dist/ui.js +36 -0
  20. package/dist/ui.js.map +1 -0
  21. package/package.json +41 -0
  22. package/template/.claude/CLAUDE.md +202 -0
  23. package/template/.claude/commands/checkpoint.md +127 -0
  24. package/template/.claude/commands/cleanup.md +307 -0
  25. package/template/.claude/commands/execute-task.md +440 -0
  26. package/template/.claude/commands/exit-plan.md +41 -0
  27. package/template/.claude/commands/handoff.md +97 -0
  28. package/template/.claude/commands/learn.md +218 -0
  29. package/template/.claude/commands/metrics.md +118 -0
  30. package/template/.claude/commands/newworker.md +162 -0
  31. package/template/.claude/commands/nexttask.md +67 -0
  32. package/template/.claude/commands/prd.md +238 -0
  33. package/template/.claude/commands/reanchor.md +51 -0
  34. package/template/.claude/commands/remember.md +126 -0
  35. package/template/.claude/commands/run-project.md +348 -0
  36. package/template/.claude/commands/run.md +110 -0
  37. package/template/.claude/commands/search-reindex.md +62 -0
  38. package/template/.claude/commands/search.md +100 -0
  39. package/template/.claude/commands/setup.md +381 -0
  40. package/template/.claude/scripts/pure-ralph-loop.ps1 +312 -0
  41. package/template/.claude/scripts/pure-ralph-loop.sh +859 -0
  42. package/template/CHANGELOG.md +220 -0
  43. package/template/LICENSE +21 -0
  44. package/template/MIGRATION.md +259 -0
  45. package/template/README.md +368 -0
  46. package/template/data/journal/.gitkeep +0 -0
  47. package/template/docs/images/ascii-banner-options.md +122 -0
  48. package/template/docs/images/hq-banner.svg +105 -0
  49. package/template/knowledge/Ralph/01-overview.md +71 -0
  50. package/template/knowledge/Ralph/02-core-concepts.md +114 -0
  51. package/template/knowledge/Ralph/03-how-ralph-works.md +184 -0
  52. package/template/knowledge/Ralph/04-back-pressure.md +222 -0
  53. package/template/knowledge/Ralph/05-specifications.md +210 -0
  54. package/template/knowledge/Ralph/06-agents-md.md +222 -0
  55. package/template/knowledge/Ralph/07-implementation.md +316 -0
  56. package/template/knowledge/Ralph/08-economics.md +182 -0
  57. package/template/knowledge/Ralph/09-resources.md +145 -0
  58. package/template/knowledge/Ralph/10-claude-code-workflow.md +212 -0
  59. package/template/knowledge/Ralph/11-team-training-guide.md +383 -0
  60. package/template/knowledge/Ralph/README.md +40 -0
  61. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +139 -0
  62. package/template/knowledge/ai-security-framework/GLOSSARY.md +176 -0
  63. package/template/knowledge/ai-security-framework/LICENSE +21 -0
  64. package/template/knowledge/ai-security-framework/QUICK-START.md +172 -0
  65. package/template/knowledge/ai-security-framework/README.md +232 -0
  66. package/template/knowledge/ai-security-framework/checklists/browser-security.md +301 -0
  67. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +322 -0
  68. package/template/knowledge/ai-security-framework/checklists/incident-response.md +288 -0
  69. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +249 -0
  70. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +159 -0
  71. package/template/knowledge/ai-security-framework/configs/audit-logging.md +372 -0
  72. package/template/knowledge/ai-security-framework/configs/kill-switches.md +354 -0
  73. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +256 -0
  74. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +326 -0
  75. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +250 -0
  76. package/template/knowledge/ai-security-framework/templates/agents-security.md +233 -0
  77. package/template/knowledge/design-styles/README.md +42 -0
  78. package/template/knowledge/design-styles/american-industrial.md +136 -0
  79. package/template/knowledge/design-styles/ethereal-abstract.md +133 -0
  80. package/template/knowledge/design-styles/liminal-portal.md +111 -0
  81. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  82. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  83. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  84. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  85. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  86. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  87. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  88. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  89. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  90. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  91. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  92. package/template/knowledge/design-styles/swipes/american-industrial/README.md +31 -0
  93. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  94. package/template/knowledge/dev-team/README.md +35 -0
  95. package/template/knowledge/dev-team/patterns/README.md +34 -0
  96. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +178 -0
  97. package/template/knowledge/dev-team/troubleshooting/README.md +31 -0
  98. package/template/knowledge/dev-team/workflows/README.md +49 -0
  99. package/template/knowledge/hq/checkpoint-schema.json +51 -0
  100. package/template/knowledge/hq/index-md-spec.md +74 -0
  101. package/template/knowledge/hq/thread-schema.md +153 -0
  102. package/template/knowledge/hq-core/checkpoint-schema.json +51 -0
  103. package/template/knowledge/hq-core/index-md-spec.md +74 -0
  104. package/template/knowledge/hq-core/thread-schema.md +153 -0
  105. package/template/knowledge/loom/README.md +51 -0
  106. package/template/knowledge/loom/architecture.md +125 -0
  107. package/template/knowledge/loom/code-style.md +169 -0
  108. package/template/knowledge/loom/llm-proxy.md +132 -0
  109. package/template/knowledge/loom/state-machine.md +131 -0
  110. package/template/knowledge/loom/thread-system.md +117 -0
  111. package/template/knowledge/loom/tools.md +94 -0
  112. package/template/knowledge/loom/weaver.md +96 -0
  113. package/template/knowledge/loom/web-frontend.md +131 -0
  114. package/template/knowledge/projects/README.md +72 -0
  115. package/template/knowledge/projects/templates/README.template.md +28 -0
  116. package/template/knowledge/workers/README.md +195 -0
  117. package/template/knowledge/workers/ralph-loop-pattern.md +157 -0
  118. package/template/knowledge/workers/skill-schema.md +182 -0
  119. package/template/knowledge/workers/state-machine.md +102 -0
  120. package/template/knowledge/workers/templates/base-worker.yaml +73 -0
  121. package/template/knowledge/workers/templates/code-worker.yaml +85 -0
  122. package/template/knowledge/workers/templates/skill.yaml +49 -0
  123. package/template/knowledge/workers/templates/social-worker.yaml +70 -0
  124. package/template/modules/examples/full-manifest.yaml +92 -0
  125. package/template/modules/examples/minimal.yaml +14 -0
  126. package/template/modules/modules.yaml +59 -0
  127. package/template/projects/.gitkeep +0 -0
  128. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +88 -0
  129. package/template/projects/pure-ralph-branch-isolation/README.md +114 -0
  130. package/template/projects/pure-ralph-branch-isolation/prd.json +123 -0
  131. package/template/projects/purist-ralph-loop/README.md +148 -0
  132. package/template/projects/purist-ralph-loop/prd.json +135 -0
  133. package/template/projects/ralph-test/prd.json +50 -0
  134. package/template/prompts/pure-ralph-base.md +551 -0
  135. package/template/settings/.gitkeep +0 -0
  136. package/template/settings/pure-ralph.json +42 -0
  137. package/template/social-content/drafts/INDEX.md +21 -0
  138. package/template/social-content/drafts/linkedin/.gitkeep +1 -0
  139. package/template/social-content/drafts/x/.gitkeep +1 -0
  140. package/template/social-content/images/.gitkeep +1 -0
  141. package/template/starter-projects/code-worker/README.md +97 -0
  142. package/template/starter-projects/code-worker/prd.json +45 -0
  143. package/template/starter-projects/personal-assistant/README.md +42 -0
  144. package/template/starter-projects/personal-assistant/prd.json +43 -0
  145. package/template/starter-projects/social-media/README.md +60 -0
  146. package/template/starter-projects/social-media/prd.json +43 -0
  147. package/template/workers/content-brand/README.md +59 -0
  148. package/template/workers/content-brand/skills/messaging-alignment.md +91 -0
  149. package/template/workers/content-brand/skills/tone-check.md +76 -0
  150. package/template/workers/content-brand/skills/voice-analysis.md +68 -0
  151. package/template/workers/content-brand/worker.yaml +81 -0
  152. package/template/workers/content-legal/README.md +80 -0
  153. package/template/workers/content-legal/skills/claim-substantiation.md +150 -0
  154. package/template/workers/content-legal/skills/compliance-scan.md +123 -0
  155. package/template/workers/content-legal/skills/disclaimer-check.md +146 -0
  156. package/template/workers/content-legal/worker.yaml +118 -0
  157. package/template/workers/content-product/README.md +77 -0
  158. package/template/workers/content-product/skills/claim-verification.md +96 -0
  159. package/template/workers/content-product/skills/feature-accuracy.md +117 -0
  160. package/template/workers/content-product/skills/stats-check.md +128 -0
  161. package/template/workers/content-product/worker.yaml +97 -0
  162. package/template/workers/content-sales/README.md +70 -0
  163. package/template/workers/content-sales/skills/conversion-analysis.md +96 -0
  164. package/template/workers/content-sales/skills/cta-audit.md +107 -0
  165. package/template/workers/content-sales/skills/value-prop-check.md +114 -0
  166. package/template/workers/content-sales/worker.yaml +93 -0
  167. package/template/workers/content-shared/cli.ts +242 -0
  168. package/template/workers/content-shared/index.ts +234 -0
  169. package/template/workers/content-shared/lib/accuracy-analyzer.ts +661 -0
  170. package/template/workers/content-shared/lib/analyze.ts +370 -0
  171. package/template/workers/content-shared/lib/brand-analyzer.ts +526 -0
  172. package/template/workers/content-shared/lib/cms-integration.ts +446 -0
  173. package/template/workers/content-shared/lib/compliance-analyzer.ts +655 -0
  174. package/template/workers/content-shared/lib/conversion-analyzer.ts +555 -0
  175. package/template/workers/content-shared/lib/github-integration.ts +582 -0
  176. package/template/workers/content-shared/lib/output.ts +373 -0
  177. package/template/workers/content-shared/lib/parser.ts +771 -0
  178. package/template/workers/content-shared/lib/priority.ts +439 -0
  179. package/template/workers/content-shared/lib/recommendations.ts +512 -0
  180. package/template/workers/content-shared/lib/reporter.ts +749 -0
  181. package/template/workers/content-shared/lib/restructure.ts +664 -0
  182. package/template/workers/content-shared/lib/scorer.ts +140 -0
  183. package/template/workers/content-shared/lib/types.ts +227 -0
  184. package/template/workers/content-shared/lib/variants.ts +595 -0
  185. package/template/workers/content-shared/package.json +51 -0
  186. package/template/workers/content-shared/pnpm-lock.yaml +39 -0
  187. package/template/workers/content-shared/test/sample-page.json +115 -0
  188. package/template/workers/content-shared/tsconfig.json +20 -0
  189. package/template/workers/dev-team/README.md +166 -0
  190. package/template/workers/dev-team/_template.yaml +70 -0
  191. package/template/workers/dev-team/architect/package.json +27 -0
  192. package/template/workers/dev-team/architect/skills/api-design.md +89 -0
  193. package/template/workers/dev-team/architect/skills/refactor-plan.md +96 -0
  194. package/template/workers/dev-team/architect/skills/system-design.md +100 -0
  195. package/template/workers/dev-team/architect/src/index.ts +49 -0
  196. package/template/workers/dev-team/architect/src/mcp-server.ts +122 -0
  197. package/template/workers/dev-team/architect/src/skills/api-design.ts +316 -0
  198. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +264 -0
  199. package/template/workers/dev-team/architect/src/skills/system-design.ts +212 -0
  200. package/template/workers/dev-team/architect/tsconfig.json +19 -0
  201. package/template/workers/dev-team/architect/worker.yaml +128 -0
  202. package/template/workers/dev-team/backend-dev/package-lock.json +1252 -0
  203. package/template/workers/dev-team/backend-dev/package.json +27 -0
  204. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +70 -0
  205. package/template/workers/dev-team/backend-dev/skills/implement-service.md +62 -0
  206. package/template/workers/dev-team/backend-dev/src/index.ts +51 -0
  207. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +109 -0
  208. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +122 -0
  209. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +126 -0
  210. package/template/workers/dev-team/backend-dev/tsconfig.json +19 -0
  211. package/template/workers/dev-team/backend-dev/worker.yaml +128 -0
  212. package/template/workers/dev-team/code-reviewer/package-lock.json +1080 -0
  213. package/template/workers/dev-team/code-reviewer/package.json +24 -0
  214. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +61 -0
  215. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +54 -0
  216. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +63 -0
  217. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +77 -0
  218. package/template/workers/dev-team/code-reviewer/src/index.ts +56 -0
  219. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +101 -0
  220. package/template/workers/dev-team/code-reviewer/tsconfig.json +19 -0
  221. package/template/workers/dev-team/code-reviewer/worker.yaml +90 -0
  222. package/template/workers/dev-team/database-dev/package.json +22 -0
  223. package/template/workers/dev-team/database-dev/skills/create-schema.md +48 -0
  224. package/template/workers/dev-team/database-dev/src/index.ts +50 -0
  225. package/template/workers/dev-team/database-dev/src/mcp-server.ts +76 -0
  226. package/template/workers/dev-team/database-dev/tsconfig.json +18 -0
  227. package/template/workers/dev-team/database-dev/worker.yaml +90 -0
  228. package/template/workers/dev-team/frontend-dev/package.json +22 -0
  229. package/template/workers/dev-team/frontend-dev/skills/create-component.md +26 -0
  230. package/template/workers/dev-team/frontend-dev/src/index.ts +50 -0
  231. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +77 -0
  232. package/template/workers/dev-team/frontend-dev/tsconfig.json +18 -0
  233. package/template/workers/dev-team/frontend-dev/worker.yaml +132 -0
  234. package/template/workers/dev-team/infra-dev/package.json +24 -0
  235. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +73 -0
  236. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +80 -0
  237. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +62 -0
  238. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +63 -0
  239. package/template/workers/dev-team/infra-dev/src/index.ts +55 -0
  240. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +82 -0
  241. package/template/workers/dev-team/infra-dev/tsconfig.json +19 -0
  242. package/template/workers/dev-team/infra-dev/worker.yaml +92 -0
  243. package/template/workers/dev-team/knowledge-curator/package.json +24 -0
  244. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +63 -0
  245. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +61 -0
  246. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +76 -0
  247. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +63 -0
  248. package/template/workers/dev-team/knowledge-curator/src/index.ts +53 -0
  249. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +92 -0
  250. package/template/workers/dev-team/knowledge-curator/tsconfig.json +19 -0
  251. package/template/workers/dev-team/knowledge-curator/worker.yaml +80 -0
  252. package/template/workers/dev-team/motion-designer/package.json +22 -0
  253. package/template/workers/dev-team/motion-designer/skills/add-animation.md +25 -0
  254. package/template/workers/dev-team/motion-designer/skills/generate-image.md +36 -0
  255. package/template/workers/dev-team/motion-designer/src/index.ts +63 -0
  256. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +79 -0
  257. package/template/workers/dev-team/motion-designer/tsconfig.json +18 -0
  258. package/template/workers/dev-team/motion-designer/worker.yaml +84 -0
  259. package/template/workers/dev-team/product-planner/queue.json +4 -0
  260. package/template/workers/dev-team/product-planner/worker.yaml +220 -0
  261. package/template/workers/dev-team/project-manager/package-lock.json +1252 -0
  262. package/template/workers/dev-team/project-manager/package.json +27 -0
  263. package/template/workers/dev-team/project-manager/skills/create-prd.md +66 -0
  264. package/template/workers/dev-team/project-manager/skills/next-issue.md +51 -0
  265. package/template/workers/dev-team/project-manager/skills/project-status.md +59 -0
  266. package/template/workers/dev-team/project-manager/skills/update-learnings.md +65 -0
  267. package/template/workers/dev-team/project-manager/src/index.ts +54 -0
  268. package/template/workers/dev-team/project-manager/src/mcp-server.ts +207 -0
  269. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +86 -0
  270. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +137 -0
  271. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +131 -0
  272. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +94 -0
  273. package/template/workers/dev-team/project-manager/tsconfig.json +19 -0
  274. package/template/workers/dev-team/project-manager/worker.yaml +96 -0
  275. package/template/workers/dev-team/qa-tester/package.json +24 -0
  276. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +36 -0
  277. package/template/workers/dev-team/qa-tester/skills/run-tests.md +36 -0
  278. package/template/workers/dev-team/qa-tester/skills/write-test.md +27 -0
  279. package/template/workers/dev-team/qa-tester/src/index.ts +61 -0
  280. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +88 -0
  281. package/template/workers/dev-team/qa-tester/tsconfig.json +18 -0
  282. package/template/workers/dev-team/qa-tester/worker.yaml +116 -0
  283. package/template/workers/dev-team/task-executor/package-lock.json +1252 -0
  284. package/template/workers/dev-team/task-executor/package.json +27 -0
  285. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +101 -0
  286. package/template/workers/dev-team/task-executor/skills/execute.md +133 -0
  287. package/template/workers/dev-team/task-executor/skills/report-learnings.md +106 -0
  288. package/template/workers/dev-team/task-executor/skills/validate-completion.md +121 -0
  289. package/template/workers/dev-team/task-executor/src/index.ts +54 -0
  290. package/template/workers/dev-team/task-executor/src/mcp-server.ts +139 -0
  291. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +219 -0
  292. package/template/workers/dev-team/task-executor/src/skills/execute.ts +132 -0
  293. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +119 -0
  294. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +142 -0
  295. package/template/workers/dev-team/task-executor/tsconfig.json +19 -0
  296. package/template/workers/dev-team/task-executor/worker.yaml +110 -0
  297. package/template/workers/registry.yaml +171 -0
  298. package/template/workers/security-scanner/README.md +73 -0
  299. package/template/workers/security-scanner/skills/pre-deploy-check.md +205 -0
  300. package/template/workers/security-scanner/worker.yaml +26 -0
  301. package/template/workspace/checkpoints/.gitkeep +0 -0
  302. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  303. package/template/workspace/drafts/.gitkeep +0 -0
  304. package/template/workspace/learnings/.gitkeep +3 -0
  305. package/template/workspace/orchestrator/.gitkeep +0 -0
  306. package/template/workspace/ralph-test/COMPLETE.md +18 -0
  307. package/template/workspace/ralph-test/hello.txt +2 -0
  308. package/template/workspace/reports/.gitkeep +0 -0
  309. package/template/workspace/scratch/.gitkeep +0 -0
  310. package/template/workspace/threads/.gitkeep +3 -0
@@ -0,0 +1,49 @@
1
+ #!/usr/bin/env node
2
+ import { Command } from 'commander';
3
+ import { systemDesign } from './skills/system-design';
4
+ import { apiDesign } from './skills/api-design';
5
+ import { refactorPlan } from './skills/refactor-plan';
6
+
7
+ const program = new Command();
8
+
9
+ program
10
+ .name('architect')
11
+ .description('System design, planning, and technical decision-making')
12
+ .version('1.0.0');
13
+
14
+ program
15
+ .command('system-design')
16
+ .description('Design system architecture for a feature')
17
+ .requiredOption('--feature <description>', 'Feature to design')
18
+ .option('--repo <path>', 'Target repository')
19
+ .option('--scope <level>', 'Scope: small|medium|large')
20
+ .action(async (options) => {
21
+ await systemDesign(options);
22
+ });
23
+
24
+ program
25
+ .command('api-design')
26
+ .description('Design API contracts and interfaces')
27
+ .option('--endpoint <path>', 'API endpoint path')
28
+ .option('--feature <name>', 'Feature name')
29
+ .option('--repo <path>', 'Target repository')
30
+ .option('--format <type>', 'Output format: openapi|typescript')
31
+ .action(async (options) => {
32
+ if (!options.endpoint && !options.feature) {
33
+ console.error('Either --endpoint or --feature is required');
34
+ process.exit(1);
35
+ }
36
+ await apiDesign(options);
37
+ });
38
+
39
+ program
40
+ .command('refactor-plan')
41
+ .description('Plan a refactoring approach')
42
+ .requiredOption('--target <path>', 'Target file, directory, or pattern')
43
+ .option('--repo <path>', 'Target repository')
44
+ .option('--goal <description>', 'Refactoring goal')
45
+ .action(async (options) => {
46
+ await refactorPlan(options);
47
+ });
48
+
49
+ program.parse();
@@ -0,0 +1,122 @@
1
+ #!/usr/bin/env node
2
+ import { Server } from '@modelcontextprotocol/sdk/server/index.js';
3
+ import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
4
+ import {
5
+ CallToolRequestSchema,
6
+ ListToolsRequestSchema,
7
+ } from '@modelcontextprotocol/sdk/types.js';
8
+
9
+ const server = new Server(
10
+ {
11
+ name: 'architect',
12
+ version: '1.0.0',
13
+ },
14
+ {
15
+ capabilities: {
16
+ tools: {},
17
+ },
18
+ }
19
+ );
20
+
21
+ server.setRequestHandler(ListToolsRequestSchema, async () => {
22
+ return {
23
+ tools: [
24
+ {
25
+ name: 'system_design',
26
+ description: 'Design system architecture for a feature',
27
+ inputSchema: {
28
+ type: 'object',
29
+ properties: {
30
+ feature: { type: 'string', description: 'Feature to design' },
31
+ repo: { type: 'string', description: 'Target repository path' },
32
+ scope: { type: 'string', enum: ['small', 'medium', 'large'], description: 'Scope of design' },
33
+ },
34
+ required: ['feature'],
35
+ },
36
+ },
37
+ {
38
+ name: 'api_design',
39
+ description: 'Design API contracts and interfaces',
40
+ inputSchema: {
41
+ type: 'object',
42
+ properties: {
43
+ endpoint: { type: 'string', description: 'API endpoint path' },
44
+ feature: { type: 'string', description: 'Feature name' },
45
+ repo: { type: 'string', description: 'Target repository' },
46
+ format: { type: 'string', enum: ['openapi', 'typescript'], description: 'Output format' },
47
+ },
48
+ },
49
+ },
50
+ {
51
+ name: 'refactor_plan',
52
+ description: 'Plan a refactoring approach',
53
+ inputSchema: {
54
+ type: 'object',
55
+ properties: {
56
+ target: { type: 'string', description: 'Target file, directory, or pattern' },
57
+ repo: { type: 'string', description: 'Target repository' },
58
+ goal: { type: 'string', description: 'Refactoring goal' },
59
+ },
60
+ required: ['target'],
61
+ },
62
+ },
63
+ ],
64
+ };
65
+ });
66
+
67
+ server.setRequestHandler(CallToolRequestSchema, async (request) => {
68
+ const { name, arguments: args } = request.params;
69
+
70
+ try {
71
+ switch (name) {
72
+ case 'system_design': {
73
+ const { systemDesign } = await import('./skills/system-design');
74
+ const result = await captureOutput(() => systemDesign(args as any));
75
+ return { content: [{ type: 'text', text: result }] };
76
+ }
77
+
78
+ case 'api_design': {
79
+ const { apiDesign } = await import('./skills/api-design');
80
+ const result = await captureOutput(() => apiDesign(args as any));
81
+ return { content: [{ type: 'text', text: result }] };
82
+ }
83
+
84
+ case 'refactor_plan': {
85
+ const { refactorPlan } = await import('./skills/refactor-plan');
86
+ const result = await captureOutput(() => refactorPlan(args as any));
87
+ return { content: [{ type: 'text', text: result }] };
88
+ }
89
+
90
+ default:
91
+ throw new Error(`Unknown tool: ${name}`);
92
+ }
93
+ } catch (error) {
94
+ const message = error instanceof Error ? error.message : String(error);
95
+ return { content: [{ type: 'text', text: `Error: ${message}` }], isError: true };
96
+ }
97
+ });
98
+
99
+ async function captureOutput(fn: () => Promise<any>): Promise<string> {
100
+ const logs: string[] = [];
101
+ const originalLog = console.log;
102
+ const originalError = console.error;
103
+
104
+ console.log = (...args) => logs.push(args.join(' '));
105
+ console.error = (...args) => logs.push(`ERROR: ${args.join(' ')}`);
106
+
107
+ try {
108
+ await fn();
109
+ } finally {
110
+ console.log = originalLog;
111
+ console.error = originalError;
112
+ }
113
+
114
+ return logs.join('\n');
115
+ }
116
+
117
+ async function main() {
118
+ const transport = new StdioServerTransport();
119
+ await server.connect(transport);
120
+ }
121
+
122
+ main().catch(console.error);
@@ -0,0 +1,316 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+
4
+ interface ApiDesignOptions {
5
+ endpoint?: string;
6
+ feature?: string;
7
+ repo?: string;
8
+ format?: 'openapi' | 'typescript';
9
+ }
10
+
11
+ interface EndpointSpec {
12
+ method: string;
13
+ path: string;
14
+ description: string;
15
+ request?: Record<string, string>;
16
+ response: Record<string, string>;
17
+ errors: string[];
18
+ auth: boolean;
19
+ }
20
+
21
+ export async function apiDesign(options: ApiDesignOptions): Promise<void> {
22
+ const { endpoint, feature, repo, format = 'typescript' } = options;
23
+
24
+ const target = endpoint || feature;
25
+ console.log(`\n=== API Design: ${target} ===\n`);
26
+
27
+ // Analyze existing API patterns if repo provided
28
+ if (repo) {
29
+ console.log('Analyzing existing API patterns...');
30
+ const patterns = analyzeApiPatterns(repo);
31
+ console.log('\nExisting conventions:');
32
+ for (const pattern of patterns) {
33
+ console.log(` - ${pattern}`);
34
+ }
35
+ }
36
+
37
+ // Generate endpoint specifications
38
+ const endpoints = generateEndpoints(target!);
39
+
40
+ console.log('\n' + '-'.repeat(40));
41
+ console.log('\nProposed endpoints:\n');
42
+
43
+ for (const ep of endpoints) {
44
+ console.log(`${ep.method} ${ep.path}`);
45
+ console.log(` ${ep.description}`);
46
+ if (ep.request) {
47
+ console.log(` Request: ${JSON.stringify(ep.request)}`);
48
+ }
49
+ console.log(` Response: ${JSON.stringify(ep.response)}`);
50
+ if (ep.errors.length > 0) {
51
+ console.log(` Errors: ${ep.errors.join(', ')}`);
52
+ }
53
+ console.log(` Auth: ${ep.auth ? 'Required' : 'None'}`);
54
+ console.log();
55
+ }
56
+
57
+ // Generate TypeScript interfaces
58
+ if (format === 'typescript') {
59
+ console.log('-'.repeat(40));
60
+ console.log('\nGenerated TypeScript interfaces:\n');
61
+ console.log(generateTypeScriptInterfaces(endpoints, target!));
62
+ }
63
+
64
+ console.log('\n[Human approval required]');
65
+ console.log('Approve contract? [y/n/modify]');
66
+
67
+ console.log('\nOn approval, will generate:');
68
+ console.log(' - Type definitions in src/types/');
69
+ console.log(' - API route stubs (if Next.js detected)');
70
+ console.log(' - Validation schemas');
71
+ }
72
+
73
+ function analyzeApiPatterns(repoPath: string): string[] {
74
+ const patterns: string[] = [];
75
+
76
+ // Check for API directory structure
77
+ const apiDirs = [
78
+ 'src/app/api',
79
+ 'src/pages/api',
80
+ 'pages/api',
81
+ 'api',
82
+ ];
83
+
84
+ for (const dir of apiDirs) {
85
+ const fullPath = path.join(repoPath, dir);
86
+ if (fs.existsSync(fullPath)) {
87
+ patterns.push(`API routes in ${dir}`);
88
+ break;
89
+ }
90
+ }
91
+
92
+ // Check for common API patterns
93
+ const pkgPath = path.join(repoPath, 'package.json');
94
+ if (fs.existsSync(pkgPath)) {
95
+ try {
96
+ const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));
97
+ const deps = { ...pkg.dependencies, ...pkg.devDependencies };
98
+
99
+ if (deps['zod']) patterns.push('Zod validation');
100
+ if (deps['@trpc/server']) patterns.push('tRPC');
101
+ if (deps['express']) patterns.push('Express.js');
102
+ if (deps['next']) patterns.push('Next.js API routes');
103
+ } catch (e) {
104
+ // Ignore
105
+ }
106
+ }
107
+
108
+ if (patterns.length === 0) {
109
+ patterns.push('(No existing patterns detected)');
110
+ }
111
+
112
+ return patterns;
113
+ }
114
+
115
+ function generateEndpoints(target: string): EndpointSpec[] {
116
+ const targetLower = target.toLowerCase();
117
+
118
+ // Auth-related endpoints
119
+ if (targetLower.includes('auth') || targetLower.includes('login')) {
120
+ return [
121
+ {
122
+ method: 'POST',
123
+ path: '/api/auth/login',
124
+ description: 'Authenticate user with credentials',
125
+ request: { email: 'string', password: 'string', rememberMe: 'boolean?' },
126
+ response: { user: 'User', token: 'string', expiresAt: 'string' },
127
+ errors: ['INVALID_CREDENTIALS', 'ACCOUNT_LOCKED', 'RATE_LIMITED'],
128
+ auth: false,
129
+ },
130
+ {
131
+ method: 'POST',
132
+ path: '/api/auth/logout',
133
+ description: 'End user session',
134
+ response: { success: 'boolean' },
135
+ errors: ['UNAUTHORIZED'],
136
+ auth: true,
137
+ },
138
+ {
139
+ method: 'GET',
140
+ path: '/api/auth/me',
141
+ description: 'Get current user profile',
142
+ response: { user: 'User' },
143
+ errors: ['UNAUTHORIZED'],
144
+ auth: true,
145
+ },
146
+ {
147
+ method: 'POST',
148
+ path: '/api/auth/refresh',
149
+ description: 'Refresh authentication token',
150
+ request: { refreshToken: 'string' },
151
+ response: { token: 'string', expiresAt: 'string' },
152
+ errors: ['INVALID_TOKEN', 'EXPIRED_TOKEN'],
153
+ auth: false,
154
+ },
155
+ ];
156
+ }
157
+
158
+ // User-related endpoints
159
+ if (targetLower.includes('user')) {
160
+ return [
161
+ {
162
+ method: 'GET',
163
+ path: '/api/users',
164
+ description: 'List users (paginated)',
165
+ request: { page: 'number?', limit: 'number?' },
166
+ response: { users: 'User[]', total: 'number', page: 'number' },
167
+ errors: ['UNAUTHORIZED', 'FORBIDDEN'],
168
+ auth: true,
169
+ },
170
+ {
171
+ method: 'GET',
172
+ path: '/api/users/:id',
173
+ description: 'Get user by ID',
174
+ response: { user: 'User' },
175
+ errors: ['UNAUTHORIZED', 'NOT_FOUND'],
176
+ auth: true,
177
+ },
178
+ {
179
+ method: 'PATCH',
180
+ path: '/api/users/:id',
181
+ description: 'Update user',
182
+ request: { name: 'string?', email: 'string?' },
183
+ response: { user: 'User' },
184
+ errors: ['UNAUTHORIZED', 'FORBIDDEN', 'VALIDATION_ERROR'],
185
+ auth: true,
186
+ },
187
+ {
188
+ method: 'DELETE',
189
+ path: '/api/users/:id',
190
+ description: 'Delete user',
191
+ response: { success: 'boolean' },
192
+ errors: ['UNAUTHORIZED', 'FORBIDDEN', 'NOT_FOUND'],
193
+ auth: true,
194
+ },
195
+ ];
196
+ }
197
+
198
+ // Generic CRUD endpoints
199
+ const resource = target.replace(/[^a-zA-Z]/g, '').toLowerCase();
200
+ const Resource = resource.charAt(0).toUpperCase() + resource.slice(1);
201
+
202
+ return [
203
+ {
204
+ method: 'GET',
205
+ path: `/api/${resource}`,
206
+ description: `List ${resource} (paginated)`,
207
+ request: { page: 'number?', limit: 'number?' },
208
+ response: { items: `${Resource}[]`, total: 'number' },
209
+ errors: ['UNAUTHORIZED'],
210
+ auth: true,
211
+ },
212
+ {
213
+ method: 'POST',
214
+ path: `/api/${resource}`,
215
+ description: `Create ${resource}`,
216
+ request: { '...fields': 'varies' },
217
+ response: { item: Resource },
218
+ errors: ['UNAUTHORIZED', 'VALIDATION_ERROR'],
219
+ auth: true,
220
+ },
221
+ {
222
+ method: 'GET',
223
+ path: `/api/${resource}/:id`,
224
+ description: `Get ${resource} by ID`,
225
+ response: { item: Resource },
226
+ errors: ['UNAUTHORIZED', 'NOT_FOUND'],
227
+ auth: true,
228
+ },
229
+ {
230
+ method: 'PATCH',
231
+ path: `/api/${resource}/:id`,
232
+ description: `Update ${resource}`,
233
+ request: { '...fields': 'varies' },
234
+ response: { item: Resource },
235
+ errors: ['UNAUTHORIZED', 'NOT_FOUND', 'VALIDATION_ERROR'],
236
+ auth: true,
237
+ },
238
+ {
239
+ method: 'DELETE',
240
+ path: `/api/${resource}/:id`,
241
+ description: `Delete ${resource}`,
242
+ response: { success: 'boolean' },
243
+ errors: ['UNAUTHORIZED', 'NOT_FOUND'],
244
+ auth: true,
245
+ },
246
+ ];
247
+ }
248
+
249
+ function generateTypeScriptInterfaces(endpoints: EndpointSpec[], target: string): string {
250
+ const lines: string[] = [];
251
+ const targetLower = target.toLowerCase();
252
+
253
+ // Determine main entity type
254
+ let entityName = 'Item';
255
+ if (targetLower.includes('user') || targetLower.includes('auth')) {
256
+ entityName = 'User';
257
+ }
258
+
259
+ lines.push(`// API Types for: ${target}`);
260
+ lines.push('');
261
+ lines.push(`export interface ${entityName} {`);
262
+ lines.push(' id: string;');
263
+ if (entityName === 'User') {
264
+ lines.push(' email: string;');
265
+ lines.push(' name: string;');
266
+ lines.push(' createdAt: string;');
267
+ } else {
268
+ lines.push(' // Add entity fields');
269
+ lines.push(' createdAt: string;');
270
+ lines.push(' updatedAt: string;');
271
+ }
272
+ lines.push('}');
273
+ lines.push('');
274
+
275
+ // Generate request/response types for each endpoint
276
+ for (const ep of endpoints) {
277
+ const typeName = ep.path
278
+ .replace('/api/', '')
279
+ .replace(/[/:]/g, '_')
280
+ .split('_')
281
+ .map(s => s.charAt(0).toUpperCase() + s.slice(1))
282
+ .join('');
283
+
284
+ if (ep.request) {
285
+ lines.push(`export interface ${typeName}${ep.method}Request {`);
286
+ for (const [key, type] of Object.entries(ep.request)) {
287
+ const optional = type.endsWith('?') ? '?' : '';
288
+ const cleanType = type.replace('?', '');
289
+ lines.push(` ${key}${optional}: ${cleanType};`);
290
+ }
291
+ lines.push('}');
292
+ lines.push('');
293
+ }
294
+
295
+ lines.push(`export interface ${typeName}${ep.method}Response {`);
296
+ for (const [key, type] of Object.entries(ep.response)) {
297
+ lines.push(` ${key}: ${type};`);
298
+ }
299
+ lines.push('}');
300
+ lines.push('');
301
+ }
302
+
303
+ // Generate error type
304
+ const allErrors = [...new Set(endpoints.flatMap(ep => ep.errors))];
305
+ if (allErrors.length > 0) {
306
+ lines.push('export type ApiErrorCode =');
307
+ lines.push(` | '${allErrors.join("'\n | '")}';`);
308
+ lines.push('');
309
+ lines.push('export interface ApiError {');
310
+ lines.push(' code: ApiErrorCode;');
311
+ lines.push(' message: string;');
312
+ lines.push('}');
313
+ }
314
+
315
+ return lines.join('\n');
316
+ }