@contractspec/bundle.workspace 1.44.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 (425) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +79 -0
  3. package/dist/_virtual/rolldown_runtime.js +36 -0
  4. package/dist/adapters/ai.d.ts +12 -0
  5. package/dist/adapters/ai.d.ts.map +1 -0
  6. package/dist/adapters/ai.js +83 -0
  7. package/dist/adapters/ai.js.map +1 -0
  8. package/dist/adapters/factory.d.ts +29 -0
  9. package/dist/adapters/factory.d.ts.map +1 -0
  10. package/dist/adapters/factory.js +37 -0
  11. package/dist/adapters/factory.js.map +1 -0
  12. package/dist/adapters/fs.d.ts +11 -0
  13. package/dist/adapters/fs.d.ts.map +1 -0
  14. package/dist/adapters/fs.js +131 -0
  15. package/dist/adapters/fs.js.map +1 -0
  16. package/dist/adapters/git.d.ts +11 -0
  17. package/dist/adapters/git.d.ts.map +1 -0
  18. package/dist/adapters/git.js +55 -0
  19. package/dist/adapters/git.js.map +1 -0
  20. package/dist/adapters/index.d.ts +7 -0
  21. package/dist/adapters/index.js +7 -0
  22. package/dist/adapters/logger.d.ts +18 -0
  23. package/dist/adapters/logger.d.ts.map +1 -0
  24. package/dist/adapters/logger.js +81 -0
  25. package/dist/adapters/logger.js.map +1 -0
  26. package/dist/adapters/watcher.d.ts +11 -0
  27. package/dist/adapters/watcher.d.ts.map +1 -0
  28. package/dist/adapters/watcher.js +74 -0
  29. package/dist/adapters/watcher.js.map +1 -0
  30. package/dist/adapters/workspace.d.ts +148 -0
  31. package/dist/adapters/workspace.d.ts.map +1 -0
  32. package/dist/adapters/workspace.js +275 -0
  33. package/dist/adapters/workspace.js.map +1 -0
  34. package/dist/ai/agents/claude-code-agent.d.ts +22 -0
  35. package/dist/ai/agents/claude-code-agent.d.ts.map +1 -0
  36. package/dist/ai/agents/claude-code-agent.js +182 -0
  37. package/dist/ai/agents/claude-code-agent.js.map +1 -0
  38. package/dist/ai/agents/cursor-agent.d.ts +68 -0
  39. package/dist/ai/agents/cursor-agent.d.ts.map +1 -0
  40. package/dist/ai/agents/cursor-agent.js +436 -0
  41. package/dist/ai/agents/cursor-agent.js.map +1 -0
  42. package/dist/ai/agents/index.js +5 -0
  43. package/dist/ai/agents/openai-codex-agent.d.ts +22 -0
  44. package/dist/ai/agents/openai-codex-agent.d.ts.map +1 -0
  45. package/dist/ai/agents/openai-codex-agent.js +167 -0
  46. package/dist/ai/agents/openai-codex-agent.js.map +1 -0
  47. package/dist/ai/agents/orchestrator.d.ts +50 -0
  48. package/dist/ai/agents/orchestrator.d.ts.map +1 -0
  49. package/dist/ai/agents/orchestrator.js +143 -0
  50. package/dist/ai/agents/orchestrator.js.map +1 -0
  51. package/dist/ai/agents/simple-agent.d.ts +17 -0
  52. package/dist/ai/agents/simple-agent.d.ts.map +1 -0
  53. package/dist/ai/agents/simple-agent.js +92 -0
  54. package/dist/ai/agents/simple-agent.js.map +1 -0
  55. package/dist/ai/agents/types.d.ts +36 -0
  56. package/dist/ai/agents/types.d.ts.map +1 -0
  57. package/dist/ai/client.d.ts +83 -0
  58. package/dist/ai/client.d.ts.map +1 -0
  59. package/dist/ai/client.js +163 -0
  60. package/dist/ai/client.js.map +1 -0
  61. package/dist/ai/index.d.ts +17 -0
  62. package/dist/ai/index.d.ts.map +1 -0
  63. package/dist/ai/index.js +28 -0
  64. package/dist/ai/index.js.map +1 -0
  65. package/dist/ai/prompts/code-generation.d.ts +26 -0
  66. package/dist/ai/prompts/code-generation.d.ts.map +1 -0
  67. package/dist/ai/prompts/code-generation.js +143 -0
  68. package/dist/ai/prompts/code-generation.js.map +1 -0
  69. package/dist/ai/prompts/index.d.ts +10 -0
  70. package/dist/ai/prompts/index.d.ts.map +1 -0
  71. package/dist/ai/prompts/index.js +13 -0
  72. package/dist/ai/prompts/index.js.map +1 -0
  73. package/dist/ai/prompts/spec-creation.d.ts +29 -0
  74. package/dist/ai/prompts/spec-creation.d.ts.map +1 -0
  75. package/dist/ai/prompts/spec-creation.js +111 -0
  76. package/dist/ai/prompts/spec-creation.js.map +1 -0
  77. package/dist/ai/providers.d.ts +29 -0
  78. package/dist/ai/providers.d.ts.map +1 -0
  79. package/dist/ai/providers.js +39 -0
  80. package/dist/ai/providers.js.map +1 -0
  81. package/dist/formatters/index.d.ts +11 -0
  82. package/dist/formatters/index.d.ts.map +1 -0
  83. package/dist/formatters/index.js +19 -0
  84. package/dist/formatters/index.js.map +1 -0
  85. package/dist/formatters/json.d.ts +89 -0
  86. package/dist/formatters/json.d.ts.map +1 -0
  87. package/dist/formatters/json.js +72 -0
  88. package/dist/formatters/json.js.map +1 -0
  89. package/dist/formatters/sarif.d.ts +101 -0
  90. package/dist/formatters/sarif.d.ts.map +1 -0
  91. package/dist/formatters/sarif.js +163 -0
  92. package/dist/formatters/sarif.js.map +1 -0
  93. package/dist/formatters/text.d.ts +35 -0
  94. package/dist/formatters/text.d.ts.map +1 -0
  95. package/dist/formatters/text.js +209 -0
  96. package/dist/formatters/text.js.map +1 -0
  97. package/dist/index.d.ts +82 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +204 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/ports/ai.d.ts +59 -0
  102. package/dist/ports/ai.d.ts.map +1 -0
  103. package/dist/ports/fs.d.ts +81 -0
  104. package/dist/ports/fs.d.ts.map +1 -0
  105. package/dist/ports/git.d.ts +33 -0
  106. package/dist/ports/git.d.ts.map +1 -0
  107. package/dist/ports/index.d.ts +5 -0
  108. package/dist/ports/logger.d.ts +88 -0
  109. package/dist/ports/logger.d.ts.map +1 -0
  110. package/dist/ports/watcher.d.ts +52 -0
  111. package/dist/ports/watcher.d.ts.map +1 -0
  112. package/dist/services/agent-guide/adapters/claude-code.d.ts +35 -0
  113. package/dist/services/agent-guide/adapters/claude-code.d.ts.map +1 -0
  114. package/dist/services/agent-guide/adapters/claude-code.js +144 -0
  115. package/dist/services/agent-guide/adapters/claude-code.js.map +1 -0
  116. package/dist/services/agent-guide/adapters/cursor-cli.d.ts +39 -0
  117. package/dist/services/agent-guide/adapters/cursor-cli.d.ts.map +1 -0
  118. package/dist/services/agent-guide/adapters/cursor-cli.js +135 -0
  119. package/dist/services/agent-guide/adapters/cursor-cli.js.map +1 -0
  120. package/dist/services/agent-guide/adapters/generic-mcp.d.ts +53 -0
  121. package/dist/services/agent-guide/adapters/generic-mcp.d.ts.map +1 -0
  122. package/dist/services/agent-guide/adapters/generic-mcp.js +159 -0
  123. package/dist/services/agent-guide/adapters/generic-mcp.js.map +1 -0
  124. package/dist/services/agent-guide/adapters/index.d.ts +23 -0
  125. package/dist/services/agent-guide/adapters/index.d.ts.map +1 -0
  126. package/dist/services/agent-guide/adapters/index.js +31 -0
  127. package/dist/services/agent-guide/adapters/index.js.map +1 -0
  128. package/dist/services/agent-guide/agent-guide-service.d.ts +56 -0
  129. package/dist/services/agent-guide/agent-guide-service.d.ts.map +1 -0
  130. package/dist/services/agent-guide/agent-guide-service.js +147 -0
  131. package/dist/services/agent-guide/agent-guide-service.js.map +1 -0
  132. package/dist/services/agent-guide/index.d.ts +6 -0
  133. package/dist/services/agent-guide/index.js +5 -0
  134. package/dist/services/agent-guide/types.d.ts +58 -0
  135. package/dist/services/agent-guide/types.d.ts.map +1 -0
  136. package/dist/services/build.d.ts +59 -0
  137. package/dist/services/build.d.ts.map +1 -0
  138. package/dist/services/build.js +140 -0
  139. package/dist/services/build.js.map +1 -0
  140. package/dist/services/ci-check/ci-check-service.d.ts +16 -0
  141. package/dist/services/ci-check/ci-check-service.d.ts.map +1 -0
  142. package/dist/services/ci-check/ci-check-service.js +392 -0
  143. package/dist/services/ci-check/ci-check-service.js.map +1 -0
  144. package/dist/services/ci-check/index.d.ts +2 -0
  145. package/dist/services/ci-check/index.js +2 -0
  146. package/dist/services/ci-check/types.d.ts +143 -0
  147. package/dist/services/ci-check/types.d.ts.map +1 -0
  148. package/dist/services/ci-check/types.js +29 -0
  149. package/dist/services/ci-check/types.js.map +1 -0
  150. package/dist/services/clean.d.ts +41 -0
  151. package/dist/services/clean.d.ts.map +1 -0
  152. package/dist/services/clean.js +72 -0
  153. package/dist/services/clean.js.map +1 -0
  154. package/dist/services/config.d.ts +26 -0
  155. package/dist/services/config.d.ts.map +1 -0
  156. package/dist/services/config.js +77 -0
  157. package/dist/services/config.js.map +1 -0
  158. package/dist/services/deps.d.ts +53 -0
  159. package/dist/services/deps.d.ts.map +1 -0
  160. package/dist/services/deps.js +62 -0
  161. package/dist/services/deps.js.map +1 -0
  162. package/dist/services/diff.d.ts +34 -0
  163. package/dist/services/diff.d.ts.map +1 -0
  164. package/dist/services/diff.js +34 -0
  165. package/dist/services/diff.js.map +1 -0
  166. package/dist/services/doctor/checks/ai.js +119 -0
  167. package/dist/services/doctor/checks/ai.js.map +1 -0
  168. package/dist/services/doctor/checks/cli.js +147 -0
  169. package/dist/services/doctor/checks/cli.js.map +1 -0
  170. package/dist/services/doctor/checks/config.js +171 -0
  171. package/dist/services/doctor/checks/config.js.map +1 -0
  172. package/dist/services/doctor/checks/deps.js +247 -0
  173. package/dist/services/doctor/checks/deps.js.map +1 -0
  174. package/dist/services/doctor/checks/index.js +6 -0
  175. package/dist/services/doctor/checks/mcp.js +145 -0
  176. package/dist/services/doctor/checks/mcp.js.map +1 -0
  177. package/dist/services/doctor/checks/workspace.js +244 -0
  178. package/dist/services/doctor/checks/workspace.js.map +1 -0
  179. package/dist/services/doctor/doctor-service.d.ts +24 -0
  180. package/dist/services/doctor/doctor-service.d.ts.map +1 -0
  181. package/dist/services/doctor/doctor-service.js +116 -0
  182. package/dist/services/doctor/doctor-service.js.map +1 -0
  183. package/dist/services/doctor/index.d.ts +2 -0
  184. package/dist/services/doctor/index.js +2 -0
  185. package/dist/services/doctor/types.d.ts +118 -0
  186. package/dist/services/doctor/types.d.ts.map +1 -0
  187. package/dist/services/doctor/types.js +27 -0
  188. package/dist/services/doctor/types.js.map +1 -0
  189. package/dist/services/impact/formatters.d.ts +27 -0
  190. package/dist/services/impact/formatters.d.ts.map +1 -0
  191. package/dist/services/impact/formatters.js +111 -0
  192. package/dist/services/impact/formatters.js.map +1 -0
  193. package/dist/services/impact/impact-detection-service.d.ts +22 -0
  194. package/dist/services/impact/impact-detection-service.d.ts.map +1 -0
  195. package/dist/services/impact/impact-detection-service.js +96 -0
  196. package/dist/services/impact/impact-detection-service.js.map +1 -0
  197. package/dist/services/impact/index.d.ts +11 -0
  198. package/dist/services/impact/index.d.ts.map +1 -0
  199. package/dist/services/impact/index.js +16 -0
  200. package/dist/services/impact/index.js.map +1 -0
  201. package/dist/services/impact/types.d.ts +58 -0
  202. package/dist/services/impact/types.d.ts.map +1 -0
  203. package/dist/services/implementation/discovery.d.ts +30 -0
  204. package/dist/services/implementation/discovery.d.ts.map +1 -0
  205. package/dist/services/implementation/discovery.js +144 -0
  206. package/dist/services/implementation/discovery.js.map +1 -0
  207. package/dist/services/implementation/index.d.ts +3 -0
  208. package/dist/services/implementation/index.js +2 -0
  209. package/dist/services/implementation/resolver.d.ts +44 -0
  210. package/dist/services/implementation/resolver.d.ts.map +1 -0
  211. package/dist/services/implementation/resolver.js +224 -0
  212. package/dist/services/implementation/resolver.js.map +1 -0
  213. package/dist/services/implementation/types.d.ts +79 -0
  214. package/dist/services/implementation/types.d.ts.map +1 -0
  215. package/dist/services/index.d.ts +60 -0
  216. package/dist/services/index.js +57 -0
  217. package/dist/services/integrity-diagram.d.ts +36 -0
  218. package/dist/services/integrity-diagram.d.ts.map +1 -0
  219. package/dist/services/integrity-diagram.js +275 -0
  220. package/dist/services/integrity-diagram.js.map +1 -0
  221. package/dist/services/integrity.d.ts +134 -0
  222. package/dist/services/integrity.d.ts.map +1 -0
  223. package/dist/services/integrity.js +272 -0
  224. package/dist/services/integrity.js.map +1 -0
  225. package/dist/services/list.d.ts +31 -0
  226. package/dist/services/list.d.ts.map +1 -0
  227. package/dist/services/list.js +36 -0
  228. package/dist/services/list.js.map +1 -0
  229. package/dist/services/openapi/export-service.d.ts +53 -0
  230. package/dist/services/openapi/export-service.d.ts.map +1 -0
  231. package/dist/services/openapi/export-service.js +50 -0
  232. package/dist/services/openapi/export-service.js.map +1 -0
  233. package/dist/services/openapi/import-service.d.ts +17 -0
  234. package/dist/services/openapi/import-service.d.ts.map +1 -0
  235. package/dist/services/openapi/import-service.js +74 -0
  236. package/dist/services/openapi/import-service.js.map +1 -0
  237. package/dist/services/openapi/index.d.ts +5 -0
  238. package/dist/services/openapi/index.js +4 -0
  239. package/dist/services/openapi/sync-service.d.ts +17 -0
  240. package/dist/services/openapi/sync-service.d.ts.map +1 -0
  241. package/dist/services/openapi/sync-service.js +120 -0
  242. package/dist/services/openapi/sync-service.js.map +1 -0
  243. package/dist/services/openapi/types.d.ts +162 -0
  244. package/dist/services/openapi/types.d.ts.map +1 -0
  245. package/dist/services/openapi/validate-service.d.ts +16 -0
  246. package/dist/services/openapi/validate-service.d.ts.map +1 -0
  247. package/dist/services/openapi/validate-service.js +130 -0
  248. package/dist/services/openapi/validate-service.js.map +1 -0
  249. package/dist/services/quickstart/dependencies.d.ts +31 -0
  250. package/dist/services/quickstart/dependencies.d.ts.map +1 -0
  251. package/dist/services/quickstart/dependencies.js +57 -0
  252. package/dist/services/quickstart/dependencies.js.map +1 -0
  253. package/dist/services/quickstart/index.js +2 -0
  254. package/dist/services/quickstart/quickstart-service.d.ts +20 -0
  255. package/dist/services/quickstart/quickstart-service.d.ts.map +1 -0
  256. package/dist/services/quickstart/quickstart-service.js +196 -0
  257. package/dist/services/quickstart/quickstart-service.js.map +1 -0
  258. package/dist/services/quickstart/types.d.ts +81 -0
  259. package/dist/services/quickstart/types.d.ts.map +1 -0
  260. package/dist/services/regenerator.d.ts +18 -0
  261. package/dist/services/regenerator.d.ts.map +1 -0
  262. package/dist/services/regenerator.js +23 -0
  263. package/dist/services/regenerator.js.map +1 -0
  264. package/dist/services/registry.d.ts +53 -0
  265. package/dist/services/registry.d.ts.map +1 -0
  266. package/dist/services/registry.js +74 -0
  267. package/dist/services/registry.js.map +1 -0
  268. package/dist/services/setup/config-generators.d.ts +42 -0
  269. package/dist/services/setup/config-generators.d.ts.map +1 -0
  270. package/dist/services/setup/config-generators.js +238 -0
  271. package/dist/services/setup/config-generators.js.map +1 -0
  272. package/dist/services/setup/file-merger.d.ts +27 -0
  273. package/dist/services/setup/file-merger.d.ts.map +1 -0
  274. package/dist/services/setup/file-merger.js +61 -0
  275. package/dist/services/setup/file-merger.js.map +1 -0
  276. package/dist/services/setup/index.js +4 -0
  277. package/dist/services/setup/setup-service.d.ts +12 -0
  278. package/dist/services/setup/setup-service.d.ts.map +1 -0
  279. package/dist/services/setup/setup-service.js +96 -0
  280. package/dist/services/setup/setup-service.js.map +1 -0
  281. package/dist/services/setup/targets/agents-md.js +47 -0
  282. package/dist/services/setup/targets/agents-md.js.map +1 -0
  283. package/dist/services/setup/targets/cli-config.js +60 -0
  284. package/dist/services/setup/targets/cli-config.js.map +1 -0
  285. package/dist/services/setup/targets/cursor-rules.js +48 -0
  286. package/dist/services/setup/targets/cursor-rules.js.map +1 -0
  287. package/dist/services/setup/targets/mcp-claude.js +60 -0
  288. package/dist/services/setup/targets/mcp-claude.js.map +1 -0
  289. package/dist/services/setup/targets/mcp-cursor.js +59 -0
  290. package/dist/services/setup/targets/mcp-cursor.js.map +1 -0
  291. package/dist/services/setup/targets/vscode-settings.js +63 -0
  292. package/dist/services/setup/targets/vscode-settings.js.map +1 -0
  293. package/dist/services/setup/types.d.ts +85 -0
  294. package/dist/services/setup/types.d.ts.map +1 -0
  295. package/dist/services/setup/types.js +27 -0
  296. package/dist/services/setup/types.js.map +1 -0
  297. package/dist/services/sync.d.ts +41 -0
  298. package/dist/services/sync.d.ts.map +1 -0
  299. package/dist/services/sync.js +63 -0
  300. package/dist/services/sync.js.map +1 -0
  301. package/dist/services/test.d.ts +15 -0
  302. package/dist/services/test.d.ts.map +1 -0
  303. package/dist/services/test.js +30 -0
  304. package/dist/services/test.js.map +1 -0
  305. package/dist/services/validate-implementation.d.ts +32 -0
  306. package/dist/services/validate-implementation.d.ts.map +1 -0
  307. package/dist/services/validate-implementation.js +64 -0
  308. package/dist/services/validate-implementation.js.map +1 -0
  309. package/dist/services/validate.d.ts +41 -0
  310. package/dist/services/validate.d.ts.map +1 -0
  311. package/dist/services/validate.js +48 -0
  312. package/dist/services/validate.js.map +1 -0
  313. package/dist/services/verification-cache/adapters/filesystem.d.ts +46 -0
  314. package/dist/services/verification-cache/adapters/filesystem.d.ts.map +1 -0
  315. package/dist/services/verification-cache/adapters/filesystem.js +120 -0
  316. package/dist/services/verification-cache/adapters/filesystem.js.map +1 -0
  317. package/dist/services/verification-cache/adapters/in-memory.d.ts +27 -0
  318. package/dist/services/verification-cache/adapters/in-memory.d.ts.map +1 -0
  319. package/dist/services/verification-cache/adapters/in-memory.js +46 -0
  320. package/dist/services/verification-cache/adapters/in-memory.js.map +1 -0
  321. package/dist/services/verification-cache/adapters/index.d.ts +3 -0
  322. package/dist/services/verification-cache/adapters/index.js +3 -0
  323. package/dist/services/verification-cache/adapters/workspace-state.d.ts +49 -0
  324. package/dist/services/verification-cache/adapters/workspace-state.d.ts.map +1 -0
  325. package/dist/services/verification-cache/adapters/workspace-state.js +91 -0
  326. package/dist/services/verification-cache/adapters/workspace-state.js.map +1 -0
  327. package/dist/services/verification-cache/cache-service.d.ts +70 -0
  328. package/dist/services/verification-cache/cache-service.d.ts.map +1 -0
  329. package/dist/services/verification-cache/cache-service.js +256 -0
  330. package/dist/services/verification-cache/cache-service.js.map +1 -0
  331. package/dist/services/verification-cache/index.d.ts +6 -0
  332. package/dist/services/verification-cache/index.js +6 -0
  333. package/dist/services/verification-cache/types.d.ts +124 -0
  334. package/dist/services/verification-cache/types.d.ts.map +1 -0
  335. package/dist/services/verification-cache/types.js +16 -0
  336. package/dist/services/verification-cache/types.js.map +1 -0
  337. package/dist/services/verify/ai-verifier.d.ts +25 -0
  338. package/dist/services/verify/ai-verifier.d.ts.map +1 -0
  339. package/dist/services/verify/ai-verifier.js +403 -0
  340. package/dist/services/verify/ai-verifier.js.map +1 -0
  341. package/dist/services/verify/behavior-verifier.d.ts +12 -0
  342. package/dist/services/verify/behavior-verifier.d.ts.map +1 -0
  343. package/dist/services/verify/behavior-verifier.js +186 -0
  344. package/dist/services/verify/behavior-verifier.js.map +1 -0
  345. package/dist/services/verify/index.d.ts +5 -0
  346. package/dist/services/verify/index.js +4 -0
  347. package/dist/services/verify/structure-verifier.d.ts +12 -0
  348. package/dist/services/verify/structure-verifier.d.ts.map +1 -0
  349. package/dist/services/verify/structure-verifier.js +196 -0
  350. package/dist/services/verify/structure-verifier.js.map +1 -0
  351. package/dist/services/verify/types.d.ts +137 -0
  352. package/dist/services/verify/types.d.ts.map +1 -0
  353. package/dist/services/verify/verify-service.d.ts +60 -0
  354. package/dist/services/verify/verify-service.d.ts.map +1 -0
  355. package/dist/services/verify/verify-service.js +204 -0
  356. package/dist/services/verify/verify-service.js.map +1 -0
  357. package/dist/services/watch.d.ts +25 -0
  358. package/dist/services/watch.d.ts.map +1 -0
  359. package/dist/services/watch.js +32 -0
  360. package/dist/services/watch.js.map +1 -0
  361. package/dist/services/workspace-info.d.ts +62 -0
  362. package/dist/services/workspace-info.d.ts.map +1 -0
  363. package/dist/services/workspace-info.js +103 -0
  364. package/dist/services/workspace-info.js.map +1 -0
  365. package/dist/templates/app-config.template.d.ts +7 -0
  366. package/dist/templates/app-config.template.d.ts.map +1 -0
  367. package/dist/templates/app-config.template.js +107 -0
  368. package/dist/templates/app-config.template.js.map +1 -0
  369. package/dist/templates/data-view.template.d.ts +7 -0
  370. package/dist/templates/data-view.template.d.ts.map +1 -0
  371. package/dist/templates/data-view.template.js +70 -0
  372. package/dist/templates/data-view.template.js.map +1 -0
  373. package/dist/templates/event.template.d.ts +11 -0
  374. package/dist/templates/event.template.d.ts.map +1 -0
  375. package/dist/templates/event.template.js +40 -0
  376. package/dist/templates/event.template.js.map +1 -0
  377. package/dist/templates/experiment.template.d.ts +7 -0
  378. package/dist/templates/experiment.template.d.ts.map +1 -0
  379. package/dist/templates/experiment.template.js +89 -0
  380. package/dist/templates/experiment.template.js.map +1 -0
  381. package/dist/templates/handler.template.d.ts +16 -0
  382. package/dist/templates/handler.template.d.ts.map +1 -0
  383. package/dist/templates/handler.template.js +100 -0
  384. package/dist/templates/handler.template.js.map +1 -0
  385. package/dist/templates/index.d.ts +21 -0
  386. package/dist/templates/index.d.ts.map +1 -0
  387. package/dist/templates/index.js +37 -0
  388. package/dist/templates/index.js.map +1 -0
  389. package/dist/templates/integration.template.d.ts +7 -0
  390. package/dist/templates/integration.template.d.ts.map +1 -0
  391. package/dist/templates/integration.template.js +160 -0
  392. package/dist/templates/integration.template.js.map +1 -0
  393. package/dist/templates/knowledge.template.d.ts +7 -0
  394. package/dist/templates/knowledge.template.d.ts.map +1 -0
  395. package/dist/templates/knowledge.template.js +75 -0
  396. package/dist/templates/knowledge.template.js.map +1 -0
  397. package/dist/templates/migration.template.d.ts +7 -0
  398. package/dist/templates/migration.template.d.ts.map +1 -0
  399. package/dist/templates/migration.template.js +62 -0
  400. package/dist/templates/migration.template.js.map +1 -0
  401. package/dist/templates/operation.template.d.ts +11 -0
  402. package/dist/templates/operation.template.d.ts.map +1 -0
  403. package/dist/templates/operation.template.js +105 -0
  404. package/dist/templates/operation.template.js.map +1 -0
  405. package/dist/templates/presentation.template.d.ts +11 -0
  406. package/dist/templates/presentation.template.d.ts.map +1 -0
  407. package/dist/templates/presentation.template.js +80 -0
  408. package/dist/templates/presentation.template.js.map +1 -0
  409. package/dist/templates/telemetry.template.d.ts +7 -0
  410. package/dist/templates/telemetry.template.d.ts.map +1 -0
  411. package/dist/templates/telemetry.template.js +91 -0
  412. package/dist/templates/telemetry.template.js.map +1 -0
  413. package/dist/templates/workflow-runner.template.d.ts +16 -0
  414. package/dist/templates/workflow-runner.template.d.ts.map +1 -0
  415. package/dist/templates/workflow-runner.template.js +50 -0
  416. package/dist/templates/workflow-runner.template.js.map +1 -0
  417. package/dist/templates/workflow.template.d.ts +7 -0
  418. package/dist/templates/workflow.template.d.ts.map +1 -0
  419. package/dist/templates/workflow.template.js +69 -0
  420. package/dist/templates/workflow.template.js.map +1 -0
  421. package/dist/types/config.d.ts +34 -0
  422. package/dist/types/config.d.ts.map +1 -0
  423. package/dist/types.d.ts +324 -0
  424. package/dist/types.d.ts.map +1 -0
  425. package/package.json +68 -0
@@ -0,0 +1,247 @@
1
+ import { exec } from "node:child_process";
2
+ import { promisify } from "node:util";
3
+
4
+ //#region src/services/doctor/checks/deps.ts
5
+ /**
6
+ * Dependencies health checks.
7
+ */
8
+ const execAsync = promisify(exec);
9
+ /**
10
+ * Run dependency-related health checks.
11
+ */
12
+ async function runDepsChecks(fs, ctx) {
13
+ const results = [];
14
+ results.push(await checkNodeJs(ctx));
15
+ results.push(await checkBun(ctx));
16
+ results.push(await checkPackageManager(fs, ctx));
17
+ results.push(await checkNodeModules(fs, ctx));
18
+ results.push(await checkContractsLibrary(fs, ctx));
19
+ return results;
20
+ }
21
+ /**
22
+ * Check if Node.js is available.
23
+ */
24
+ async function checkNodeJs(ctx) {
25
+ try {
26
+ const { stdout } = await execAsync("node --version", {
27
+ cwd: ctx.workspaceRoot,
28
+ timeout: 5e3
29
+ });
30
+ return {
31
+ category: "deps",
32
+ name: "Node.js",
33
+ status: "pass",
34
+ message: `Node.js ${stdout.trim()} available`
35
+ };
36
+ } catch {
37
+ return {
38
+ category: "deps",
39
+ name: "Node.js",
40
+ status: "fail",
41
+ message: "Node.js not found",
42
+ details: "Install Node.js from https://nodejs.org"
43
+ };
44
+ }
45
+ }
46
+ /**
47
+ * Check if Bun is available.
48
+ */
49
+ async function checkBun(ctx) {
50
+ try {
51
+ const { stdout } = await execAsync("bun --version", {
52
+ cwd: ctx.workspaceRoot,
53
+ timeout: 5e3
54
+ });
55
+ return {
56
+ category: "deps",
57
+ name: "Bun Runtime",
58
+ status: "pass",
59
+ message: `Bun ${stdout.trim()} available`
60
+ };
61
+ } catch {
62
+ return {
63
+ category: "deps",
64
+ name: "Bun Runtime",
65
+ status: "warn",
66
+ message: "Bun not found (optional but recommended)",
67
+ details: "Install Bun from https://bun.sh for faster execution"
68
+ };
69
+ }
70
+ }
71
+ /**
72
+ * Detect and check the package manager.
73
+ */
74
+ async function checkPackageManager(fs, ctx) {
75
+ const lockFiles = [
76
+ {
77
+ file: "bun.lockb",
78
+ name: "bun"
79
+ },
80
+ {
81
+ file: "pnpm-lock.yaml",
82
+ name: "pnpm"
83
+ },
84
+ {
85
+ file: "yarn.lock",
86
+ name: "yarn"
87
+ },
88
+ {
89
+ file: "package-lock.json",
90
+ name: "npm"
91
+ }
92
+ ];
93
+ let detectedManager = null;
94
+ for (const { file, name } of lockFiles) {
95
+ const lockPath = fs.join(ctx.workspaceRoot, file);
96
+ if (await fs.exists(lockPath)) {
97
+ detectedManager = name;
98
+ break;
99
+ }
100
+ }
101
+ if (!detectedManager) return {
102
+ category: "deps",
103
+ name: "Package Manager",
104
+ status: "warn",
105
+ message: "No lock file found",
106
+ details: "Run npm install, yarn, pnpm install, or bun install"
107
+ };
108
+ try {
109
+ await execAsync(`${detectedManager} --version`, {
110
+ cwd: ctx.workspaceRoot,
111
+ timeout: 5e3
112
+ });
113
+ return {
114
+ category: "deps",
115
+ name: "Package Manager",
116
+ status: "pass",
117
+ message: `Using ${detectedManager}`
118
+ };
119
+ } catch {
120
+ return {
121
+ category: "deps",
122
+ name: "Package Manager",
123
+ status: "fail",
124
+ message: `${detectedManager} detected but not available`,
125
+ details: `Install ${detectedManager} or use a different package manager`
126
+ };
127
+ }
128
+ }
129
+ /**
130
+ * Check if node_modules exists.
131
+ */
132
+ async function checkNodeModules(fs, ctx) {
133
+ const nodeModulesPath = fs.join(ctx.workspaceRoot, "node_modules");
134
+ if (await fs.exists(nodeModulesPath)) return {
135
+ category: "deps",
136
+ name: "Dependencies Installed",
137
+ status: "pass",
138
+ message: "node_modules directory exists"
139
+ };
140
+ return {
141
+ category: "deps",
142
+ name: "Dependencies Installed",
143
+ status: "fail",
144
+ message: "node_modules not found",
145
+ details: "Run your package manager install command",
146
+ fix: {
147
+ description: "Install dependencies",
148
+ apply: async () => {
149
+ try {
150
+ try {
151
+ await execAsync("bun install", {
152
+ cwd: ctx.workspaceRoot,
153
+ timeout: 12e4
154
+ });
155
+ return {
156
+ success: true,
157
+ message: "Installed with bun"
158
+ };
159
+ } catch {
160
+ await execAsync("npm install", {
161
+ cwd: ctx.workspaceRoot,
162
+ timeout: 12e4
163
+ });
164
+ return {
165
+ success: true,
166
+ message: "Installed with npm"
167
+ };
168
+ }
169
+ } catch (error) {
170
+ return {
171
+ success: false,
172
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
173
+ };
174
+ }
175
+ }
176
+ }
177
+ };
178
+ }
179
+ /**
180
+ * Check if @contractspec/lib.contracts is installed.
181
+ */
182
+ async function checkContractsLibrary(fs, ctx) {
183
+ const packageJsonPath = fs.join(ctx.workspaceRoot, "package.json");
184
+ try {
185
+ const content = await fs.readFile(packageJsonPath);
186
+ const packageJson = JSON.parse(content);
187
+ const allDeps = {
188
+ ...packageJson.dependencies,
189
+ ...packageJson.devDependencies
190
+ };
191
+ if ("@contractspec/lib.contracts" in allDeps) return {
192
+ category: "deps",
193
+ name: "ContractSpec Library",
194
+ status: "pass",
195
+ message: `@contractspec/lib.contracts installed (${allDeps["@contractspec/lib.contracts"]})`
196
+ };
197
+ return {
198
+ category: "deps",
199
+ name: "ContractSpec Library",
200
+ status: "fail",
201
+ message: "@contractspec/lib.contracts not installed",
202
+ details: "Run \"contractspec quickstart\" to install required packages",
203
+ fix: {
204
+ description: "Install @contractspec/lib.contracts and dependencies",
205
+ apply: async () => {
206
+ try {
207
+ try {
208
+ await execAsync("bun add @contractspec/lib.contracts zod", {
209
+ cwd: ctx.workspaceRoot,
210
+ timeout: 12e4
211
+ });
212
+ return {
213
+ success: true,
214
+ message: "Installed with bun"
215
+ };
216
+ } catch {
217
+ await execAsync("npm install @contractspec/lib.contracts zod", {
218
+ cwd: ctx.workspaceRoot,
219
+ timeout: 12e4
220
+ });
221
+ return {
222
+ success: true,
223
+ message: "Installed with npm"
224
+ };
225
+ }
226
+ } catch (error) {
227
+ return {
228
+ success: false,
229
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
230
+ };
231
+ }
232
+ }
233
+ }
234
+ };
235
+ } catch {
236
+ return {
237
+ category: "deps",
238
+ name: "ContractSpec Library",
239
+ status: "skip",
240
+ message: "Could not read package.json"
241
+ };
242
+ }
243
+ }
244
+
245
+ //#endregion
246
+ export { runDepsChecks };
247
+ //# sourceMappingURL=deps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deps.js","names":["results: CheckResult[]","detectedManager: string | null"],"sources":["../../../../src/services/doctor/checks/deps.ts"],"sourcesContent":["/**\n * Dependencies health checks.\n */\n\nimport { exec } from 'node:child_process';\nimport { promisify } from 'node:util';\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { CheckResult, CheckContext } from '../types';\n\nconst execAsync = promisify(exec);\n\n/**\n * Run dependency-related health checks.\n */\nexport async function runDepsChecks(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult[]> {\n const results: CheckResult[] = [];\n\n // Check Node.js availability\n results.push(await checkNodeJs(ctx));\n\n // Check Bun availability\n results.push(await checkBun(ctx));\n\n // Check package manager\n results.push(await checkPackageManager(fs, ctx));\n\n // Check if node_modules exists\n results.push(await checkNodeModules(fs, ctx));\n\n // Check if @contractspec/lib.contracts is installed\n results.push(await checkContractsLibrary(fs, ctx));\n\n return results;\n}\n\n/**\n * Check if Node.js is available.\n */\nasync function checkNodeJs(ctx: CheckContext): Promise<CheckResult> {\n try {\n const { stdout } = await execAsync('node --version', {\n cwd: ctx.workspaceRoot,\n timeout: 5000,\n });\n\n const version = stdout.trim();\n\n return {\n category: 'deps',\n name: 'Node.js',\n status: 'pass',\n message: `Node.js ${version} available`,\n };\n } catch {\n return {\n category: 'deps',\n name: 'Node.js',\n status: 'fail',\n message: 'Node.js not found',\n details: 'Install Node.js from https://nodejs.org',\n };\n }\n}\n\n/**\n * Check if Bun is available.\n */\nasync function checkBun(ctx: CheckContext): Promise<CheckResult> {\n try {\n const { stdout } = await execAsync('bun --version', {\n cwd: ctx.workspaceRoot,\n timeout: 5000,\n });\n\n const version = stdout.trim();\n\n return {\n category: 'deps',\n name: 'Bun Runtime',\n status: 'pass',\n message: `Bun ${version} available`,\n };\n } catch {\n return {\n category: 'deps',\n name: 'Bun Runtime',\n status: 'warn',\n message: 'Bun not found (optional but recommended)',\n details: 'Install Bun from https://bun.sh for faster execution',\n };\n }\n}\n\n/**\n * Detect and check the package manager.\n */\nasync function checkPackageManager(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult> {\n // Check for lock files to determine package manager\n const lockFiles = [\n { file: 'bun.lockb', name: 'bun' },\n { file: 'pnpm-lock.yaml', name: 'pnpm' },\n { file: 'yarn.lock', name: 'yarn' },\n { file: 'package-lock.json', name: 'npm' },\n ];\n\n let detectedManager: string | null = null;\n\n for (const { file, name } of lockFiles) {\n const lockPath = fs.join(ctx.workspaceRoot, file);\n if (await fs.exists(lockPath)) {\n detectedManager = name;\n break;\n }\n }\n\n if (!detectedManager) {\n return {\n category: 'deps',\n name: 'Package Manager',\n status: 'warn',\n message: 'No lock file found',\n details: 'Run npm install, yarn, pnpm install, or bun install',\n };\n }\n\n // Verify the package manager is available\n try {\n await execAsync(`${detectedManager} --version`, {\n cwd: ctx.workspaceRoot,\n timeout: 5000,\n });\n\n return {\n category: 'deps',\n name: 'Package Manager',\n status: 'pass',\n message: `Using ${detectedManager}`,\n };\n } catch {\n return {\n category: 'deps',\n name: 'Package Manager',\n status: 'fail',\n message: `${detectedManager} detected but not available`,\n details: `Install ${detectedManager} or use a different package manager`,\n };\n }\n}\n\n/**\n * Check if node_modules exists.\n */\nasync function checkNodeModules(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult> {\n const nodeModulesPath = fs.join(ctx.workspaceRoot, 'node_modules');\n\n const exists = await fs.exists(nodeModulesPath);\n if (exists) {\n return {\n category: 'deps',\n name: 'Dependencies Installed',\n status: 'pass',\n message: 'node_modules directory exists',\n };\n }\n\n return {\n category: 'deps',\n name: 'Dependencies Installed',\n status: 'fail',\n message: 'node_modules not found',\n details: 'Run your package manager install command',\n fix: {\n description: 'Install dependencies',\n apply: async () => {\n try {\n // Try bun first, then npm\n try {\n await execAsync('bun install', {\n cwd: ctx.workspaceRoot,\n timeout: 120000,\n });\n return { success: true, message: 'Installed with bun' };\n } catch {\n await execAsync('npm install', {\n cwd: ctx.workspaceRoot,\n timeout: 120000,\n });\n return { success: true, message: 'Installed with npm' };\n }\n } catch (error) {\n const msg = error instanceof Error ? error.message : String(error);\n return { success: false, message: `Failed: ${msg}` };\n }\n },\n },\n };\n}\n\n/**\n * Check if @contractspec/lib.contracts is installed.\n */\nasync function checkContractsLibrary(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult> {\n const packageJsonPath = fs.join(ctx.workspaceRoot, 'package.json');\n\n try {\n const content = await fs.readFile(packageJsonPath);\n const packageJson = JSON.parse(content) as {\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n };\n\n const allDeps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if ('@contractspec/lib.contracts' in allDeps) {\n return {\n category: 'deps',\n name: 'ContractSpec Library',\n status: 'pass',\n message: `@contractspec/lib.contracts installed (${allDeps['@contractspec/lib.contracts']})`,\n };\n }\n\n return {\n category: 'deps',\n name: 'ContractSpec Library',\n status: 'fail',\n message: '@contractspec/lib.contracts not installed',\n details: 'Run \"contractspec quickstart\" to install required packages',\n fix: {\n description: 'Install @contractspec/lib.contracts and dependencies',\n apply: async () => {\n try {\n // Try bun first, then npm\n try {\n await execAsync('bun add @contractspec/lib.contracts zod', {\n cwd: ctx.workspaceRoot,\n timeout: 120000,\n });\n return { success: true, message: 'Installed with bun' };\n } catch {\n await execAsync('npm install @contractspec/lib.contracts zod', {\n cwd: ctx.workspaceRoot,\n timeout: 120000,\n });\n return { success: true, message: 'Installed with npm' };\n }\n } catch (error) {\n const msg = error instanceof Error ? error.message : String(error);\n return { success: false, message: `Failed: ${msg}` };\n }\n },\n },\n };\n } catch {\n return {\n category: 'deps',\n name: 'ContractSpec Library',\n status: 'skip',\n message: 'Could not read package.json',\n };\n }\n}\n"],"mappings":";;;;;;;AASA,MAAM,YAAY,UAAU,KAAK;;;;AAKjC,eAAsB,cACpB,IACA,KACwB;CACxB,MAAMA,UAAyB,EAAE;AAGjC,SAAQ,KAAK,MAAM,YAAY,IAAI,CAAC;AAGpC,SAAQ,KAAK,MAAM,SAAS,IAAI,CAAC;AAGjC,SAAQ,KAAK,MAAM,oBAAoB,IAAI,IAAI,CAAC;AAGhD,SAAQ,KAAK,MAAM,iBAAiB,IAAI,IAAI,CAAC;AAG7C,SAAQ,KAAK,MAAM,sBAAsB,IAAI,IAAI,CAAC;AAElD,QAAO;;;;;AAMT,eAAe,YAAY,KAAyC;AAClE,KAAI;EACF,MAAM,EAAE,WAAW,MAAM,UAAU,kBAAkB;GACnD,KAAK,IAAI;GACT,SAAS;GACV,CAAC;AAIF,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS,WANK,OAAO,MAAM,CAMC;GAC7B;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACT,SAAS;GACV;;;;;;AAOL,eAAe,SAAS,KAAyC;AAC/D,KAAI;EACF,MAAM,EAAE,WAAW,MAAM,UAAU,iBAAiB;GAClD,KAAK,IAAI;GACT,SAAS;GACV,CAAC;AAIF,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS,OANK,OAAO,MAAM,CAMH;GACzB;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACT,SAAS;GACV;;;;;;AAOL,eAAe,oBACb,IACA,KACsB;CAEtB,MAAM,YAAY;EAChB;GAAE,MAAM;GAAa,MAAM;GAAO;EAClC;GAAE,MAAM;GAAkB,MAAM;GAAQ;EACxC;GAAE,MAAM;GAAa,MAAM;GAAQ;EACnC;GAAE,MAAM;GAAqB,MAAM;GAAO;EAC3C;CAED,IAAIC,kBAAiC;AAErC,MAAK,MAAM,EAAE,MAAM,UAAU,WAAW;EACtC,MAAM,WAAW,GAAG,KAAK,IAAI,eAAe,KAAK;AACjD,MAAI,MAAM,GAAG,OAAO,SAAS,EAAE;AAC7B,qBAAkB;AAClB;;;AAIJ,KAAI,CAAC,gBACH,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACT,SAAS;EACV;AAIH,KAAI;AACF,QAAM,UAAU,GAAG,gBAAgB,aAAa;GAC9C,KAAK,IAAI;GACT,SAAS;GACV,CAAC;AAEF,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS,SAAS;GACnB;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS,GAAG,gBAAgB;GAC5B,SAAS,WAAW,gBAAgB;GACrC;;;;;;AAOL,eAAe,iBACb,IACA,KACsB;CACtB,MAAM,kBAAkB,GAAG,KAAK,IAAI,eAAe,eAAe;AAGlE,KADe,MAAM,GAAG,OAAO,gBAAgB,CAE7C,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACV;AAGH,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACT,SAAS;EACT,KAAK;GACH,aAAa;GACb,OAAO,YAAY;AACjB,QAAI;AAEF,SAAI;AACF,YAAM,UAAU,eAAe;OAC7B,KAAK,IAAI;OACT,SAAS;OACV,CAAC;AACF,aAAO;OAAE,SAAS;OAAM,SAAS;OAAsB;aACjD;AACN,YAAM,UAAU,eAAe;OAC7B,KAAK,IAAI;OACT,SAAS;OACV,CAAC;AACF,aAAO;OAAE,SAAS;OAAM,SAAS;OAAsB;;aAElD,OAAO;AAEd,YAAO;MAAE,SAAS;MAAO,SAAS,WADtB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;MACd;;;GAGzD;EACF;;;;;AAMH,eAAe,sBACb,IACA,KACsB;CACtB,MAAM,kBAAkB,GAAG,KAAK,IAAI,eAAe,eAAe;AAElE,KAAI;EACF,MAAM,UAAU,MAAM,GAAG,SAAS,gBAAgB;EAClD,MAAM,cAAc,KAAK,MAAM,QAAQ;EAKvC,MAAM,UAAU;GACd,GAAG,YAAY;GACf,GAAG,YAAY;GAChB;AAED,MAAI,iCAAiC,QACnC,QAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS,0CAA0C,QAAQ,+BAA+B;GAC3F;AAGH,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACT,SAAS;GACT,KAAK;IACH,aAAa;IACb,OAAO,YAAY;AACjB,SAAI;AAEF,UAAI;AACF,aAAM,UAAU,2CAA2C;QACzD,KAAK,IAAI;QACT,SAAS;QACV,CAAC;AACF,cAAO;QAAE,SAAS;QAAM,SAAS;QAAsB;cACjD;AACN,aAAM,UAAU,+CAA+C;QAC7D,KAAK,IAAI;QACT,SAAS;QACV,CAAC;AACF,cAAO;QAAE,SAAS;QAAM,SAAS;QAAsB;;cAElD,OAAO;AAEd,aAAO;OAAE,SAAS;OAAO,SAAS,WADtB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;OACd;;;IAGzD;GACF;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV"}
@@ -0,0 +1,6 @@
1
+ import { runCliChecks } from "./cli.js";
2
+ import { runConfigChecks } from "./config.js";
3
+ import { runMcpChecks } from "./mcp.js";
4
+ import { runDepsChecks } from "./deps.js";
5
+ import { runWorkspaceChecks } from "./workspace.js";
6
+ import { runAiChecks } from "./ai.js";
@@ -0,0 +1,145 @@
1
+ import { generateCursorMcpConfig, getClaudeDesktopConfigPath } from "../../setup/config-generators.js";
2
+ import { deepMergePreserve, formatJson } from "../../setup/file-merger.js";
3
+
4
+ //#region src/services/doctor/checks/mcp.ts
5
+ /**
6
+ * Run MCP-related health checks.
7
+ */
8
+ async function runMcpChecks(fs, ctx) {
9
+ const results = [];
10
+ results.push(await checkCursorMcpConfig(fs, ctx));
11
+ results.push(await checkCursorMcpServer(fs, ctx));
12
+ results.push(await checkClaudeMcpConfig(fs, ctx));
13
+ return results;
14
+ }
15
+ /**
16
+ * Check if .cursor/mcp.json exists.
17
+ */
18
+ async function checkCursorMcpConfig(fs, ctx) {
19
+ const configPath = fs.join(ctx.workspaceRoot, ".cursor", "mcp.json");
20
+ if (await fs.exists(configPath)) return {
21
+ category: "mcp",
22
+ name: "Cursor MCP Config",
23
+ status: "pass",
24
+ message: ".cursor/mcp.json found"
25
+ };
26
+ return {
27
+ category: "mcp",
28
+ name: "Cursor MCP Config",
29
+ status: "warn",
30
+ message: ".cursor/mcp.json not found",
31
+ details: "MCP integration with Cursor will not work",
32
+ fix: {
33
+ description: "Create .cursor/mcp.json",
34
+ apply: async () => {
35
+ try {
36
+ const cursorDir = fs.join(ctx.workspaceRoot, ".cursor");
37
+ if (!await fs.exists(cursorDir)) await fs.mkdir(cursorDir);
38
+ const defaults = generateCursorMcpConfig();
39
+ await fs.writeFile(configPath, formatJson(defaults));
40
+ return {
41
+ success: true,
42
+ message: "Created .cursor/mcp.json"
43
+ };
44
+ } catch (error) {
45
+ return {
46
+ success: false,
47
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
48
+ };
49
+ }
50
+ }
51
+ }
52
+ };
53
+ }
54
+ /**
55
+ * Check if ContractSpec MCP server is registered in Cursor config.
56
+ */
57
+ async function checkCursorMcpServer(fs, ctx) {
58
+ const configPath = fs.join(ctx.workspaceRoot, ".cursor", "mcp.json");
59
+ if (!await fs.exists(configPath)) return {
60
+ category: "mcp",
61
+ name: "MCP Server Registered",
62
+ status: "skip",
63
+ message: "Cursor MCP config does not exist"
64
+ };
65
+ try {
66
+ const content = await fs.readFile(configPath);
67
+ const config = JSON.parse(content);
68
+ if (config.mcpServers?.["contractspec-local"] !== void 0) return {
69
+ category: "mcp",
70
+ name: "MCP Server Registered",
71
+ status: "pass",
72
+ message: "ContractSpec MCP server is registered"
73
+ };
74
+ return {
75
+ category: "mcp",
76
+ name: "MCP Server Registered",
77
+ status: "fail",
78
+ message: "ContractSpec MCP server not registered",
79
+ fix: {
80
+ description: "Register ContractSpec MCP server",
81
+ apply: async () => {
82
+ try {
83
+ const merged = deepMergePreserve(config, generateCursorMcpConfig());
84
+ await fs.writeFile(configPath, formatJson(merged));
85
+ return {
86
+ success: true,
87
+ message: "Registered MCP server"
88
+ };
89
+ } catch (error) {
90
+ return {
91
+ success: false,
92
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
93
+ };
94
+ }
95
+ }
96
+ }
97
+ };
98
+ } catch {
99
+ return {
100
+ category: "mcp",
101
+ name: "MCP Server Registered",
102
+ status: "skip",
103
+ message: "Could not parse Cursor MCP config"
104
+ };
105
+ }
106
+ }
107
+ /**
108
+ * Check Claude Desktop MCP config (optional).
109
+ */
110
+ async function checkClaudeMcpConfig(fs, _ctx) {
111
+ const configPath = getClaudeDesktopConfigPath();
112
+ try {
113
+ if (!await fs.exists(configPath)) return {
114
+ category: "mcp",
115
+ name: "Claude Desktop MCP",
116
+ status: "skip",
117
+ message: "Claude Desktop config not found (optional)"
118
+ };
119
+ const content = await fs.readFile(configPath);
120
+ if (JSON.parse(content).mcpServers?.["contractspec-local"] !== void 0) return {
121
+ category: "mcp",
122
+ name: "Claude Desktop MCP",
123
+ status: "pass",
124
+ message: "ContractSpec registered in Claude Desktop"
125
+ };
126
+ return {
127
+ category: "mcp",
128
+ name: "Claude Desktop MCP",
129
+ status: "warn",
130
+ message: "ContractSpec not registered in Claude Desktop",
131
+ details: "Optional: Run setup to configure Claude Desktop"
132
+ };
133
+ } catch {
134
+ return {
135
+ category: "mcp",
136
+ name: "Claude Desktop MCP",
137
+ status: "skip",
138
+ message: "Could not check Claude Desktop config"
139
+ };
140
+ }
141
+ }
142
+
143
+ //#endregion
144
+ export { runMcpChecks };
145
+ //# sourceMappingURL=mcp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.js","names":["results: CheckResult[]"],"sources":["../../../../src/services/doctor/checks/mcp.ts"],"sourcesContent":["/**\n * MCP server health checks.\n */\n\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { CheckResult, CheckContext, FixResult } from '../types';\nimport {\n generateCursorMcpConfig,\n getClaudeDesktopConfigPath,\n} from '../../setup/config-generators';\nimport { deepMergePreserve, formatJson } from '../../setup/file-merger';\n\n/**\n * Run MCP-related health checks.\n */\nexport async function runMcpChecks(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult[]> {\n const results: CheckResult[] = [];\n\n // Check Cursor MCP config\n results.push(await checkCursorMcpConfig(fs, ctx));\n\n // Check Cursor MCP server registration\n results.push(await checkCursorMcpServer(fs, ctx));\n\n // Check Claude Desktop config (optional)\n results.push(await checkClaudeMcpConfig(fs, ctx));\n\n return results;\n}\n\n/**\n * Check if .cursor/mcp.json exists.\n */\nasync function checkCursorMcpConfig(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult> {\n const configPath = fs.join(ctx.workspaceRoot, '.cursor', 'mcp.json');\n\n const exists = await fs.exists(configPath);\n if (exists) {\n return {\n category: 'mcp',\n name: 'Cursor MCP Config',\n status: 'pass',\n message: '.cursor/mcp.json found',\n };\n }\n\n return {\n category: 'mcp',\n name: 'Cursor MCP Config',\n status: 'warn',\n message: '.cursor/mcp.json not found',\n details: 'MCP integration with Cursor will not work',\n fix: {\n description: 'Create .cursor/mcp.json',\n apply: async (): Promise<FixResult> => {\n try {\n const cursorDir = fs.join(ctx.workspaceRoot, '.cursor');\n if (!(await fs.exists(cursorDir))) {\n await fs.mkdir(cursorDir);\n }\n\n const defaults = generateCursorMcpConfig();\n await fs.writeFile(configPath, formatJson(defaults));\n return { success: true, message: 'Created .cursor/mcp.json' };\n } catch (error) {\n const msg = error instanceof Error ? error.message : String(error);\n return { success: false, message: `Failed: ${msg}` };\n }\n },\n },\n };\n}\n\n/**\n * Check if ContractSpec MCP server is registered in Cursor config.\n */\nasync function checkCursorMcpServer(\n fs: FsAdapter,\n ctx: CheckContext\n): Promise<CheckResult> {\n const configPath = fs.join(ctx.workspaceRoot, '.cursor', 'mcp.json');\n\n const exists = await fs.exists(configPath);\n if (!exists) {\n return {\n category: 'mcp',\n name: 'MCP Server Registered',\n status: 'skip',\n message: 'Cursor MCP config does not exist',\n };\n }\n\n try {\n const content = await fs.readFile(configPath);\n const config = JSON.parse(content) as {\n mcpServers?: Record<string, unknown>;\n };\n\n const hasServer = config.mcpServers?.['contractspec-local'] !== undefined;\n\n if (hasServer) {\n return {\n category: 'mcp',\n name: 'MCP Server Registered',\n status: 'pass',\n message: 'ContractSpec MCP server is registered',\n };\n }\n\n return {\n category: 'mcp',\n name: 'MCP Server Registered',\n status: 'fail',\n message: 'ContractSpec MCP server not registered',\n fix: {\n description: 'Register ContractSpec MCP server',\n apply: async (): Promise<FixResult> => {\n try {\n const defaults = generateCursorMcpConfig() as Record<\n string,\n unknown\n >;\n const merged = deepMergePreserve(\n config as Record<string, unknown>,\n defaults\n );\n await fs.writeFile(configPath, formatJson(merged));\n return { success: true, message: 'Registered MCP server' };\n } catch (error) {\n const msg = error instanceof Error ? error.message : String(error);\n return { success: false, message: `Failed: ${msg}` };\n }\n },\n },\n };\n } catch {\n return {\n category: 'mcp',\n name: 'MCP Server Registered',\n status: 'skip',\n message: 'Could not parse Cursor MCP config',\n };\n }\n}\n\n/**\n * Check Claude Desktop MCP config (optional).\n */\nasync function checkClaudeMcpConfig(\n fs: FsAdapter,\n _ctx: CheckContext\n): Promise<CheckResult> {\n const configPath = getClaudeDesktopConfigPath();\n\n try {\n const exists = await fs.exists(configPath);\n if (!exists) {\n return {\n category: 'mcp',\n name: 'Claude Desktop MCP',\n status: 'skip',\n message: 'Claude Desktop config not found (optional)',\n };\n }\n\n const content = await fs.readFile(configPath);\n const config = JSON.parse(content) as {\n mcpServers?: Record<string, unknown>;\n };\n\n const hasServer = config.mcpServers?.['contractspec-local'] !== undefined;\n\n if (hasServer) {\n return {\n category: 'mcp',\n name: 'Claude Desktop MCP',\n status: 'pass',\n message: 'ContractSpec registered in Claude Desktop',\n };\n }\n\n return {\n category: 'mcp',\n name: 'Claude Desktop MCP',\n status: 'warn',\n message: 'ContractSpec not registered in Claude Desktop',\n details: 'Optional: Run setup to configure Claude Desktop',\n };\n } catch {\n return {\n category: 'mcp',\n name: 'Claude Desktop MCP',\n status: 'skip',\n message: 'Could not check Claude Desktop config',\n };\n }\n}\n"],"mappings":";;;;;;;AAeA,eAAsB,aACpB,IACA,KACwB;CACxB,MAAMA,UAAyB,EAAE;AAGjC,SAAQ,KAAK,MAAM,qBAAqB,IAAI,IAAI,CAAC;AAGjD,SAAQ,KAAK,MAAM,qBAAqB,IAAI,IAAI,CAAC;AAGjD,SAAQ,KAAK,MAAM,qBAAqB,IAAI,IAAI,CAAC;AAEjD,QAAO;;;;;AAMT,eAAe,qBACb,IACA,KACsB;CACtB,MAAM,aAAa,GAAG,KAAK,IAAI,eAAe,WAAW,WAAW;AAGpE,KADe,MAAM,GAAG,OAAO,WAAW,CAExC,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACV;AAGH,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACT,SAAS;EACT,KAAK;GACH,aAAa;GACb,OAAO,YAAgC;AACrC,QAAI;KACF,MAAM,YAAY,GAAG,KAAK,IAAI,eAAe,UAAU;AACvD,SAAI,CAAE,MAAM,GAAG,OAAO,UAAU,CAC9B,OAAM,GAAG,MAAM,UAAU;KAG3B,MAAM,WAAW,yBAAyB;AAC1C,WAAM,GAAG,UAAU,YAAY,WAAW,SAAS,CAAC;AACpD,YAAO;MAAE,SAAS;MAAM,SAAS;MAA4B;aACtD,OAAO;AAEd,YAAO;MAAE,SAAS;MAAO,SAAS,WADtB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;MACd;;;GAGzD;EACF;;;;;AAMH,eAAe,qBACb,IACA,KACsB;CACtB,MAAM,aAAa,GAAG,KAAK,IAAI,eAAe,WAAW,WAAW;AAGpE,KAAI,CADW,MAAM,GAAG,OAAO,WAAW,CAExC,QAAO;EACL,UAAU;EACV,MAAM;EACN,QAAQ;EACR,SAAS;EACV;AAGH,KAAI;EACF,MAAM,UAAU,MAAM,GAAG,SAAS,WAAW;EAC7C,MAAM,SAAS,KAAK,MAAM,QAAQ;AAMlC,MAFkB,OAAO,aAAa,0BAA0B,OAG9D,QAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV;AAGH,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACT,KAAK;IACH,aAAa;IACb,OAAO,YAAgC;AACrC,SAAI;MAKF,MAAM,SAAS,kBACb,QALe,yBAAyB,CAOzC;AACD,YAAM,GAAG,UAAU,YAAY,WAAW,OAAO,CAAC;AAClD,aAAO;OAAE,SAAS;OAAM,SAAS;OAAyB;cACnD,OAAO;AAEd,aAAO;OAAE,SAAS;OAAO,SAAS,WADtB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;OACd;;;IAGzD;GACF;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV;;;;;;AAOL,eAAe,qBACb,IACA,MACsB;CACtB,MAAM,aAAa,4BAA4B;AAE/C,KAAI;AAEF,MAAI,CADW,MAAM,GAAG,OAAO,WAAW,CAExC,QAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV;EAGH,MAAM,UAAU,MAAM,GAAG,SAAS,WAAW;AAO7C,MANe,KAAK,MAAM,QAAQ,CAIT,aAAa,0BAA0B,OAG9D,QAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV;AAGH,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACT,SAAS;GACV;SACK;AACN,SAAO;GACL,UAAU;GACV,MAAM;GACN,QAAQ;GACR,SAAS;GACV"}
@@ -0,0 +1,244 @@
1
+ //#region src/services/doctor/checks/workspace.ts
2
+ /**
3
+ * Common contract directory paths to check.
4
+ */
5
+ const CONTRACT_PATHS = [
6
+ "src/contracts",
7
+ "contracts",
8
+ "src/specs",
9
+ "specs"
10
+ ];
11
+ /**
12
+ * Run workspace-related health checks.
13
+ */
14
+ async function runWorkspaceChecks(fs, ctx) {
15
+ const results = [];
16
+ results.push(checkMonorepoStatus(ctx));
17
+ results.push(await checkValidWorkspace(fs, ctx));
18
+ results.push(await checkContractsDirectory(fs, ctx));
19
+ results.push(await checkContractFiles(fs, ctx));
20
+ results.push(await checkOutputDirectory(fs, ctx));
21
+ return results;
22
+ }
23
+ /**
24
+ * Report monorepo detection status.
25
+ */
26
+ function checkMonorepoStatus(ctx) {
27
+ if (ctx.isMonorepo) {
28
+ const pkgInfo = ctx.packageName ? ` in package "${ctx.packageName}"` : "";
29
+ const locationInfo = ctx.packageRoot !== ctx.workspaceRoot ? ` (package root: ${ctx.packageRoot})` : "";
30
+ return {
31
+ category: "workspace",
32
+ name: "Monorepo Detection",
33
+ status: "pass",
34
+ message: `Monorepo detected${pkgInfo}`,
35
+ details: ctx.verbose ? `Workspace root: ${ctx.workspaceRoot}${locationInfo}` : void 0
36
+ };
37
+ }
38
+ return {
39
+ category: "workspace",
40
+ name: "Monorepo Detection",
41
+ status: "pass",
42
+ message: "Single project (not a monorepo)"
43
+ };
44
+ }
45
+ /**
46
+ * Check if this is a valid workspace.
47
+ */
48
+ async function checkValidWorkspace(fs, ctx) {
49
+ const pathsToCheck = ctx.isMonorepo ? [ctx.packageRoot, ctx.workspaceRoot] : [ctx.workspaceRoot];
50
+ for (const root of pathsToCheck) {
51
+ const packageJsonPath = fs.join(root, "package.json");
52
+ if (await fs.exists(packageJsonPath)) return {
53
+ category: "workspace",
54
+ name: "Valid Workspace",
55
+ status: "pass",
56
+ message: "package.json found",
57
+ details: ctx.verbose && ctx.isMonorepo ? `Found at: ${root}` : void 0
58
+ };
59
+ }
60
+ return {
61
+ category: "workspace",
62
+ name: "Valid Workspace",
63
+ status: "fail",
64
+ message: "No package.json found",
65
+ details: "This does not appear to be a Node.js/TypeScript project"
66
+ };
67
+ }
68
+ /**
69
+ * Check if contracts directory exists.
70
+ *
71
+ * In monorepo: checks current package first, then workspace root.
72
+ */
73
+ async function checkContractsDirectory(fs, ctx) {
74
+ const searchRoots = ctx.isMonorepo ? [ctx.packageRoot, ctx.workspaceRoot] : [ctx.workspaceRoot];
75
+ const targetRoot = ctx.isMonorepo ? ctx.packageRoot : ctx.workspaceRoot;
76
+ for (const root of searchRoots) for (const path of CONTRACT_PATHS) {
77
+ const fullPath = fs.join(root, path);
78
+ if (await fs.exists(fullPath)) {
79
+ const relativeTo = root === ctx.packageRoot ? "package" : "workspace";
80
+ return {
81
+ category: "workspace",
82
+ name: "Contracts Directory",
83
+ status: "pass",
84
+ message: `Contracts directory found: ${path}`,
85
+ details: ctx.isMonorepo ? `Found at ${relativeTo} level` : void 0
86
+ };
87
+ }
88
+ }
89
+ const createPath = ctx.isMonorepo ? "src/contracts" : "src/contracts";
90
+ const locationHint = ctx.isMonorepo ? ` in package "${ctx.packageName ?? ctx.packageRoot}"` : "";
91
+ return {
92
+ category: "workspace",
93
+ name: "Contracts Directory",
94
+ status: "warn",
95
+ message: "No contracts directory found",
96
+ details: `Create ${createPath}/${locationHint} to organize your specs`,
97
+ fix: {
98
+ description: `Create ${createPath}/ directory${locationHint}`,
99
+ apply: async () => {
100
+ try {
101
+ const contractsDir = fs.join(targetRoot, "src", "contracts");
102
+ await fs.mkdir(contractsDir);
103
+ return {
104
+ success: true,
105
+ message: `Created ${createPath}/`
106
+ };
107
+ } catch (error) {
108
+ return {
109
+ success: false,
110
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
111
+ };
112
+ }
113
+ }
114
+ }
115
+ };
116
+ }
117
+ /**
118
+ * Check if any contract files exist.
119
+ *
120
+ * In monorepo: searches from current package root.
121
+ */
122
+ async function checkContractFiles(fs, ctx) {
123
+ try {
124
+ const patterns = [
125
+ "**/*.operation.ts",
126
+ "**/*.event.ts",
127
+ "**/*.presentation.ts",
128
+ "**/*.feature.ts"
129
+ ];
130
+ const searchRoot = ctx.isMonorepo ? ctx.packageRoot : ctx.workspaceRoot;
131
+ const files = await fs.glob({
132
+ patterns,
133
+ ignore: ["node_modules/**", "dist/**"],
134
+ cwd: searchRoot
135
+ });
136
+ if (files.length > 0) {
137
+ const locationInfo = ctx.isMonorepo ? " (in current package)" : "";
138
+ return {
139
+ category: "workspace",
140
+ name: "Contract Files",
141
+ status: "pass",
142
+ message: `Found ${files.length} contract file(s)${locationInfo}`,
143
+ details: ctx.verbose ? files.slice(0, 5).join(", ") : void 0
144
+ };
145
+ }
146
+ return {
147
+ category: "workspace",
148
+ name: "Contract Files",
149
+ status: "warn",
150
+ message: ctx.isMonorepo ? `No contract files found in package "${ctx.packageName ?? "current"}"` : "No contract files found",
151
+ details: "Create specs using \"contractspec create\" or VS Code command"
152
+ };
153
+ } catch {
154
+ return {
155
+ category: "workspace",
156
+ name: "Contract Files",
157
+ status: "skip",
158
+ message: "Could not search for contract files"
159
+ };
160
+ }
161
+ }
162
+ /**
163
+ * Find the config file, checking package level first in monorepos.
164
+ */
165
+ async function findConfigFile(fs, ctx) {
166
+ if (ctx.isMonorepo && ctx.packageRoot !== ctx.workspaceRoot) {
167
+ const pkgConfigPath = fs.join(ctx.packageRoot, ".contractsrc.json");
168
+ if (await fs.exists(pkgConfigPath)) return {
169
+ path: pkgConfigPath,
170
+ root: ctx.packageRoot,
171
+ level: "package"
172
+ };
173
+ }
174
+ const wsConfigPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
175
+ if (await fs.exists(wsConfigPath)) return {
176
+ path: wsConfigPath,
177
+ root: ctx.workspaceRoot,
178
+ level: "workspace"
179
+ };
180
+ return null;
181
+ }
182
+ /**
183
+ * Check if output directory is configured and exists.
184
+ *
185
+ * In monorepo: checks package-level config first, then workspace-level.
186
+ * Resolves outputDir relative to the config file location.
187
+ */
188
+ async function checkOutputDirectory(fs, ctx) {
189
+ try {
190
+ const configInfo = await findConfigFile(fs, ctx);
191
+ if (!configInfo) return {
192
+ category: "workspace",
193
+ name: "Output Directory",
194
+ status: "skip",
195
+ message: ctx.isMonorepo ? "No config file found at package or workspace level" : "No config file to check output directory"
196
+ };
197
+ const content = await fs.readFile(configInfo.path);
198
+ const outputDir = JSON.parse(content).outputDir ?? "./src";
199
+ const outputPath = fs.join(configInfo.root, outputDir);
200
+ const levelInfo = ctx.isMonorepo ? ` (${configInfo.level} level)` : "";
201
+ if (await fs.exists(outputPath)) return {
202
+ category: "workspace",
203
+ name: "Output Directory",
204
+ status: "pass",
205
+ message: `Output directory exists: ${outputDir}${levelInfo}`,
206
+ details: ctx.verbose ? `Resolved to: ${outputPath}` : void 0
207
+ };
208
+ return {
209
+ category: "workspace",
210
+ name: "Output Directory",
211
+ status: "warn",
212
+ message: `Output directory not found: ${outputDir}${levelInfo}`,
213
+ details: ctx.verbose ? `Expected at: ${outputPath}` : void 0,
214
+ fix: {
215
+ description: `Create ${outputDir} directory`,
216
+ apply: async () => {
217
+ try {
218
+ await fs.mkdir(outputPath);
219
+ return {
220
+ success: true,
221
+ message: `Created ${outputDir}`
222
+ };
223
+ } catch (error) {
224
+ return {
225
+ success: false,
226
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
227
+ };
228
+ }
229
+ }
230
+ }
231
+ };
232
+ } catch {
233
+ return {
234
+ category: "workspace",
235
+ name: "Output Directory",
236
+ status: "skip",
237
+ message: "Could not check output directory"
238
+ };
239
+ }
240
+ }
241
+
242
+ //#endregion
243
+ export { runWorkspaceChecks };
244
+ //# sourceMappingURL=workspace.js.map