@lssm/bundle.contractspec-workspace 0.0.0-canary-20251217060834 → 0.0.0-canary-20251217072406

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 (269) hide show
  1. package/dist/_virtual/rolldown_runtime.js +22 -1
  2. package/dist/adapters/ai.js +82 -1
  3. package/dist/adapters/factory.js +36 -1
  4. package/dist/adapters/fs.js +118 -1
  5. package/dist/adapters/git.js +54 -1
  6. package/dist/adapters/index.js +7 -1
  7. package/dist/adapters/logger.js +80 -1
  8. package/dist/adapters/watcher.js +69 -1
  9. package/dist/adapters/workspace.js +190 -2
  10. package/dist/ai/agents/claude-code-agent.js +146 -9
  11. package/dist/ai/agents/cursor-agent.js +286 -17
  12. package/dist/ai/agents/index.js +5 -1
  13. package/dist/ai/agents/openai-codex-agent.js +140 -8
  14. package/dist/ai/agents/orchestrator.js +142 -1
  15. package/dist/ai/agents/simple-agent.js +80 -4
  16. package/dist/ai/client.js +162 -1
  17. package/dist/ai/index.js +27 -1
  18. package/dist/ai/prompts/code-generation.js +55 -13
  19. package/dist/ai/prompts/index.js +12 -1
  20. package/dist/ai/prompts/spec-creation.js +61 -20
  21. package/dist/ai/providers.js +40 -1
  22. package/dist/formatters/index.js +18 -1
  23. package/dist/formatters/json.js +71 -1
  24. package/dist/formatters/sarif.js +163 -1
  25. package/dist/formatters/text.js +208 -2
  26. package/dist/index.d.ts +0 -3
  27. package/dist/index.js +81 -1
  28. package/dist/libs/ai-providers/dist/factory.js +154 -0
  29. package/dist/libs/ai-providers/dist/index.js +4 -0
  30. package/dist/libs/ai-providers/dist/legacy.js +72 -0
  31. package/dist/libs/ai-providers/dist/models.js +287 -0
  32. package/dist/libs/ai-providers/dist/validation.js +1 -0
  33. package/dist/libs/contracts/dist/capabilities/openbanking.js +88 -0
  34. package/dist/libs/contracts/dist/client/index.js +5 -0
  35. package/dist/libs/contracts/dist/client/react/feature-render.js +2 -0
  36. package/dist/libs/contracts/dist/client/react/form-render.js +4 -0
  37. package/dist/libs/contracts/dist/client/react/index.js +4 -0
  38. package/dist/libs/contracts/dist/contract-registry/index.js +1 -0
  39. package/dist/libs/contracts/dist/contract-registry/schemas.js +60 -0
  40. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -0
  41. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -0
  42. package/dist/libs/contracts/dist/docs/index.js +29 -0
  43. package/dist/libs/contracts/dist/docs/presentations.js +71 -0
  44. package/dist/libs/contracts/dist/docs/registry.js +44 -0
  45. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -0
  46. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -0
  47. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -0
  48. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -0
  49. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -0
  50. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +80 -0
  51. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +57 -0
  52. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -0
  53. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +357 -0
  54. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -0
  55. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -0
  56. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -0
  57. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -0
  58. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +79 -0
  59. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +84 -0
  60. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +45 -0
  61. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -0
  62. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +40 -0
  63. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +69 -0
  64. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -0
  65. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +62 -0
  66. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +155 -0
  67. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -0
  68. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +101 -0
  69. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -0
  70. package/dist/libs/contracts/dist/events.js +8 -0
  71. package/dist/libs/contracts/dist/experiments/evaluator.js +1 -0
  72. package/dist/libs/contracts/dist/index.js +72 -0
  73. package/dist/libs/contracts/dist/install.js +2 -0
  74. package/dist/libs/contracts/dist/integrations/contracts.js +377 -0
  75. package/dist/libs/contracts/dist/integrations/index.js +18 -0
  76. package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +228 -0
  77. package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +159 -0
  78. package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +3 -0
  79. package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +210 -0
  80. package/dist/libs/contracts/dist/integrations/openbanking/models.js +242 -0
  81. package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +13 -0
  82. package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +52 -0
  83. package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +75 -0
  84. package/dist/libs/contracts/dist/integrations/providers/gmail.js +87 -0
  85. package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +66 -0
  86. package/dist/libs/contracts/dist/integrations/providers/index.js +11 -0
  87. package/dist/libs/contracts/dist/integrations/providers/mistral.js +68 -0
  88. package/dist/libs/contracts/dist/integrations/providers/postmark.js +68 -0
  89. package/dist/libs/contracts/dist/integrations/providers/powens.js +116 -0
  90. package/dist/libs/contracts/dist/integrations/providers/qdrant.js +73 -0
  91. package/dist/libs/contracts/dist/integrations/providers/registry.js +10 -0
  92. package/dist/libs/contracts/dist/integrations/providers/stripe.js +83 -0
  93. package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +61 -0
  94. package/dist/libs/contracts/dist/jsonschema.js +24 -0
  95. package/dist/libs/contracts/dist/knowledge/contracts.js +306 -0
  96. package/dist/libs/contracts/dist/knowledge/index.js +7 -0
  97. package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +34 -0
  98. package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +34 -0
  99. package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +38 -0
  100. package/dist/libs/contracts/dist/knowledge/spaces/index.js +6 -0
  101. package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +34 -0
  102. package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +37 -0
  103. package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +34 -0
  104. package/dist/libs/contracts/dist/llm/exporters.js +352 -0
  105. package/dist/libs/contracts/dist/llm/index.js +2 -0
  106. package/dist/libs/contracts/dist/llm/prompts.js +211 -0
  107. package/dist/libs/contracts/dist/onboarding-base.js +196 -0
  108. package/dist/libs/contracts/dist/openapi.js +75 -0
  109. package/dist/libs/contracts/dist/ownership.js +21 -0
  110. package/dist/libs/contracts/dist/presentations.js +1 -0
  111. package/dist/libs/contracts/dist/presentations.v2.js +11 -0
  112. package/dist/libs/contracts/dist/prompt.js +1 -0
  113. package/dist/libs/contracts/dist/promptRegistry.js +1 -0
  114. package/dist/libs/contracts/dist/regenerator/index.js +2 -0
  115. package/dist/libs/contracts/dist/regenerator/service.js +92 -0
  116. package/dist/libs/contracts/dist/regenerator/utils.js +51 -0
  117. package/dist/libs/contracts/dist/registry.js +208 -0
  118. package/dist/libs/contracts/dist/resources.js +1 -0
  119. package/dist/libs/contracts/dist/schema/dist/EnumType.js +2 -0
  120. package/dist/libs/contracts/dist/schema/dist/FieldType.js +49 -0
  121. package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +236 -0
  122. package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +34 -0
  123. package/dist/libs/contracts/dist/schema/dist/entity/defineEntity.js +1 -0
  124. package/dist/libs/contracts/dist/schema/dist/entity/index.js +2 -0
  125. package/dist/libs/contracts/dist/schema/dist/entity/types.js +1 -0
  126. package/dist/libs/contracts/dist/schema/dist/index.js +6 -0
  127. package/dist/libs/contracts/dist/server/graphql-pothos.js +6 -0
  128. package/dist/libs/contracts/dist/server/index.js +8 -0
  129. package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +4 -0
  130. package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +2 -0
  131. package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +1 -0
  132. package/dist/libs/contracts/dist/server/mcp/registerResources.js +2 -0
  133. package/dist/libs/contracts/dist/server/mcp/registerTools.js +1 -0
  134. package/dist/libs/contracts/dist/server/provider-mcp.js +1 -0
  135. package/dist/libs/contracts/dist/server/rest-elysia.js +1 -0
  136. package/dist/libs/contracts/dist/server/rest-express.js +1 -0
  137. package/dist/libs/contracts/dist/server/rest-generic.js +1 -0
  138. package/dist/libs/contracts/dist/server/rest-next-app.js +1 -0
  139. package/dist/libs/contracts/dist/server/rest-next-pages.js +1 -0
  140. package/dist/libs/contracts/dist/spec.js +35 -0
  141. package/dist/libs/contracts/dist/telemetry/index.js +1 -0
  142. package/dist/libs/contracts/dist/telemetry/tracker.js +1 -0
  143. package/dist/libs/contracts/dist/tests/index.js +1 -0
  144. package/dist/libs/contracts/dist/tests/runner.js +150 -0
  145. package/dist/libs/contracts/dist/workflow/index.js +1 -0
  146. package/dist/libs/contracts/dist/workflow/runner.js +1 -0
  147. package/dist/libs/contracts-transformers/dist/common/utils.js +47 -0
  148. package/dist/libs/contracts-transformers/dist/openapi/exporter.js +1 -0
  149. package/dist/libs/contracts-transformers/dist/openapi/importer.js +255 -0
  150. package/dist/libs/contracts-transformers/dist/openapi/index.js +4 -0
  151. package/dist/libs/contracts-transformers/dist/openapi/parser.js +231 -0
  152. package/dist/libs/contracts-transformers/dist/openapi/schema-converter.js +201 -0
  153. package/dist/modules/contractspec-workspace/dist/ai/code-generation.js +137 -0
  154. package/dist/modules/contractspec-workspace/dist/ai/spec-creation.js +101 -0
  155. package/dist/modules/contractspec-workspace/dist/analysis/deps/graph.js +84 -0
  156. package/dist/modules/contractspec-workspace/dist/analysis/deps/parse-imports.js +30 -0
  157. package/dist/modules/contractspec-workspace/dist/analysis/diff/semantic.js +96 -0
  158. package/dist/modules/contractspec-workspace/dist/analysis/feature-scan.js +151 -0
  159. package/dist/modules/contractspec-workspace/dist/analysis/spec-scan.js +344 -0
  160. package/dist/modules/contractspec-workspace/dist/analysis/validate/spec-structure.js +122 -0
  161. package/dist/modules/contractspec-workspace/dist/templates/app-config.js +105 -0
  162. package/dist/modules/contractspec-workspace/dist/templates/data-view.js +68 -0
  163. package/dist/modules/contractspec-workspace/dist/templates/event.js +38 -0
  164. package/dist/modules/contractspec-workspace/dist/templates/experiment.js +87 -0
  165. package/dist/modules/contractspec-workspace/dist/templates/handler.js +95 -0
  166. package/dist/modules/contractspec-workspace/dist/templates/integration-utils.js +104 -0
  167. package/dist/modules/contractspec-workspace/dist/templates/integration.js +62 -0
  168. package/dist/modules/contractspec-workspace/dist/templates/knowledge.js +68 -0
  169. package/dist/modules/contractspec-workspace/dist/templates/migration.js +60 -0
  170. package/dist/modules/contractspec-workspace/dist/templates/operation.js +100 -0
  171. package/dist/modules/contractspec-workspace/dist/templates/presentation.js +78 -0
  172. package/dist/modules/contractspec-workspace/dist/templates/telemetry.js +89 -0
  173. package/dist/modules/contractspec-workspace/dist/templates/utils.js +38 -0
  174. package/dist/modules/contractspec-workspace/dist/templates/workflow-runner.js +48 -0
  175. package/dist/modules/contractspec-workspace/dist/templates/workflow.js +67 -0
  176. package/dist/modules/contractspec-workspace/dist/types/generation-types.js +20 -0
  177. package/dist/services/agent-guide/adapters/claude-code.js +144 -3
  178. package/dist/services/agent-guide/adapters/cursor-cli.js +135 -3
  179. package/dist/services/agent-guide/adapters/generic-mcp.js +159 -3
  180. package/dist/services/agent-guide/adapters/index.js +30 -1
  181. package/dist/services/agent-guide/agent-guide-service.js +148 -1
  182. package/dist/services/agent-guide/index.js +5 -1
  183. package/dist/services/build.js +140 -1
  184. package/dist/services/ci-check/ci-check-service.js +393 -1
  185. package/dist/services/ci-check/index.js +2 -1
  186. package/dist/services/ci-check/types.js +28 -1
  187. package/dist/services/clean.js +71 -1
  188. package/dist/services/config.js +76 -1
  189. package/dist/services/deps.js +62 -1
  190. package/dist/services/diff.js +33 -1
  191. package/dist/services/doctor/checks/ai.js +118 -2
  192. package/dist/services/doctor/checks/cli.js +146 -1
  193. package/dist/services/doctor/checks/config.js +170 -1
  194. package/dist/services/doctor/checks/deps.js +180 -1
  195. package/dist/services/doctor/checks/index.js +6 -1
  196. package/dist/services/doctor/checks/mcp.js +144 -1
  197. package/dist/services/doctor/checks/workspace.js +243 -1
  198. package/dist/services/doctor/doctor-service.js +115 -2
  199. package/dist/services/doctor/index.js +2 -1
  200. package/dist/services/doctor/types.js +26 -1
  201. package/dist/services/implementation/discovery.js +143 -2
  202. package/dist/services/implementation/index.js +2 -1
  203. package/dist/services/implementation/resolver.js +223 -1
  204. package/dist/services/index.js +53 -1
  205. package/dist/services/integrity-diagram.js +274 -6
  206. package/dist/services/integrity.js +272 -1
  207. package/dist/services/list.js +35 -1
  208. package/dist/services/openapi/export-service.js +51 -2
  209. package/dist/services/openapi/import-service.js +75 -1
  210. package/dist/services/openapi/index.js +4 -1
  211. package/dist/services/openapi/sync-service.js +121 -1
  212. package/dist/services/openapi/validate-service.js +130 -1
  213. package/dist/services/regenerator.js +23 -1
  214. package/dist/services/registry.js +73 -1
  215. package/dist/services/setup/config-generators.js +113 -26
  216. package/dist/services/setup/file-merger.js +60 -2
  217. package/dist/services/setup/index.js +4 -1
  218. package/dist/services/setup/setup-service.js +95 -1
  219. package/dist/services/setup/targets/agents-md.js +46 -1
  220. package/dist/services/setup/targets/cli-config.js +59 -1
  221. package/dist/services/setup/targets/cursor-rules.js +47 -1
  222. package/dist/services/setup/targets/mcp-claude.js +59 -1
  223. package/dist/services/setup/targets/mcp-cursor.js +58 -1
  224. package/dist/services/setup/targets/vscode-settings.js +62 -1
  225. package/dist/services/setup/types.js +26 -1
  226. package/dist/services/sync.js +62 -1
  227. package/dist/services/test.js +30 -1
  228. package/dist/services/validate-implementation.js +69 -1
  229. package/dist/services/validate.js +47 -1
  230. package/dist/services/verification-cache/adapters/filesystem.js +121 -1
  231. package/dist/services/verification-cache/adapters/in-memory.js +45 -1
  232. package/dist/services/verification-cache/adapters/index.js +3 -1
  233. package/dist/services/verification-cache/adapters/workspace-state.js +90 -1
  234. package/dist/services/verification-cache/cache-service.js +255 -1
  235. package/dist/services/verification-cache/index.js +6 -1
  236. package/dist/services/verification-cache/types.js +15 -1
  237. package/dist/services/verify/ai-verifier.js +336 -9
  238. package/dist/services/verify/behavior-verifier.js +185 -1
  239. package/dist/services/verify/index.js +4 -1
  240. package/dist/services/verify/structure-verifier.js +195 -2
  241. package/dist/services/verify/verify-service.js +203 -3
  242. package/dist/services/watch.js +31 -1
  243. package/dist/services/workspace-info.js +102 -2
  244. package/dist/templates/app-config.template.js +101 -28
  245. package/dist/templates/data-view.template.js +42 -27
  246. package/dist/templates/event.template.js +29 -14
  247. package/dist/templates/experiment.template.js +77 -51
  248. package/dist/templates/handler.template.js +53 -17
  249. package/dist/templates/index.js +36 -1
  250. package/dist/templates/integration.template.js +134 -50
  251. package/dist/templates/knowledge.template.js +62 -21
  252. package/dist/templates/migration.template.js +50 -26
  253. package/dist/templates/operation.template.js +44 -28
  254. package/dist/templates/presentation.template.js +46 -20
  255. package/dist/templates/telemetry.template.js +74 -53
  256. package/dist/templates/workflow-runner.template.js +12 -6
  257. package/dist/templates/workflow.template.js +51 -24
  258. package/package.json +13 -9
  259. package/dist/adapters/index.d.ts +0 -7
  260. package/dist/ports/index.d.ts +0 -5
  261. package/dist/services/agent-guide/index.d.ts +0 -6
  262. package/dist/services/ci-check/index.d.ts +0 -2
  263. package/dist/services/doctor/index.d.ts +0 -2
  264. package/dist/services/implementation/index.d.ts +0 -3
  265. package/dist/services/index.d.ts +0 -56
  266. package/dist/services/openapi/index.d.ts +0 -5
  267. package/dist/services/verification-cache/adapters/index.d.ts +0 -3
  268. package/dist/services/verification-cache/index.d.ts +0 -6
  269. package/dist/services/verify/index.d.ts +0 -5
@@ -1 +1,33 @@
1
- import{computeSemanticDiff as e}from"@lssm/module.contractspec-workspace";async function t(t,n,r,i={}){let{fs:a,git:o}=r;if(!await a.exists(t))throw Error(`Spec file not found: ${t}`);let s=await a.readFile(t),c,l;if(i.baseline)c=await o.showFile(i.baseline,t),l=`${i.baseline}:${t}`;else{if(!await a.exists(n))throw Error(`Spec file not found: ${n}`);c=await a.readFile(n),l=n}let u=e(s,t,c,l,{breakingOnly:i.breakingOnly});return{spec1:t,spec2:l,differences:u}}export{t as compareSpecs};
1
+ import { computeSemanticDiff } from "../modules/contractspec-workspace/dist/analysis/diff/semantic.js";
2
+
3
+ //#region src/services/diff.ts
4
+ /**
5
+ * Diff service.
6
+ */
7
+ /**
8
+ * Compare two spec files semantically.
9
+ */
10
+ async function compareSpecs(spec1Path, spec2Path, adapters, options = {}) {
11
+ const { fs, git } = adapters;
12
+ if (!await fs.exists(spec1Path)) throw new Error(`Spec file not found: ${spec1Path}`);
13
+ const spec1Code = await fs.readFile(spec1Path);
14
+ let spec2Code;
15
+ let spec2Label;
16
+ if (options.baseline) {
17
+ spec2Code = await git.showFile(options.baseline, spec1Path);
18
+ spec2Label = `${options.baseline}:${spec1Path}`;
19
+ } else {
20
+ if (!await fs.exists(spec2Path)) throw new Error(`Spec file not found: ${spec2Path}`);
21
+ spec2Code = await fs.readFile(spec2Path);
22
+ spec2Label = spec2Path;
23
+ }
24
+ const differences = computeSemanticDiff(spec1Code, spec1Path, spec2Code, spec2Label, { breakingOnly: options.breakingOnly });
25
+ return {
26
+ spec1: spec1Path,
27
+ spec2: spec2Label,
28
+ differences
29
+ };
30
+ }
31
+
32
+ //#endregion
33
+ export { compareSpecs };
@@ -1,2 +1,118 @@
1
- async function e(e,r,i){let a=[],o=await t(e,r);return a.push(o),o.status===`pass`&&a.push(await n(e,r,i)),a}async function t(e,t){let n=e.join(t.workspaceRoot,`.contractsrc.json`);try{if(!await e.exists(n))return{category:`ai`,name:`AI Provider`,status:`skip`,message:`No config file found`};let t=await e.readFile(n),r=JSON.parse(t);return{category:`ai`,name:`AI Provider`,status:`pass`,message:`Provider: ${r.aiProvider??`claude`}, Model: ${r.aiModel??`default`}`}}catch{return{category:`ai`,name:`AI Provider`,status:`skip`,message:`Could not read AI config`}}}async function n(e,t,n){let r=e.join(t.workspaceRoot,`.contractsrc.json`);try{let i=await e.readFile(r),a=JSON.parse(i).aiProvider??`claude`,o={claude:`ANTHROPIC_API_KEY`,openai:`OPENAI_API_KEY`,ollama:``,custom:`CONTRACTSPEC_LLM_API_KEY`}[a];return o?process.env[o]?{category:`ai`,name:`API Key`,status:`pass`,message:`${o} is set`}:{category:`ai`,name:`API Key`,status:`warn`,message:`${o} not set`,details:`Set ${o} in your environment to use AI features`,fix:n?{description:`Set ${o} environment variable`,apply:async()=>{let r=await n.input(`Enter your ${a} API key:`,{password:!0});if(!r)return{success:!1,message:`No API key provided`};let i=e.join(t.workspaceRoot,`.env`);try{let t=``;if(await e.exists(i)){if(t=await e.readFile(i),t.includes(`${o}=`))return{success:!1,message:`${o} already in .env, update manually`};t+=`
2
- `}return t+=`${o}=${r}\n`,await e.writeFile(i,t),{success:!0,message:`Added ${o} to .env (restart required)`}}catch(e){return{success:!1,message:`Failed: ${e instanceof Error?e.message:String(e)}`}}}}:void 0}:{category:`ai`,name:`API Key`,status:`pass`,message:`${a} does not require an API key`}}catch{return{category:`ai`,name:`API Key`,status:`skip`,message:`Could not check API key`}}}export{e as runAiChecks};
1
+ //#region src/services/doctor/checks/ai.ts
2
+ /**
3
+ * Run AI provider-related health checks.
4
+ */
5
+ async function runAiChecks(fs, ctx, prompts) {
6
+ const results = [];
7
+ const providerResult = await checkAiProvider(fs, ctx);
8
+ results.push(providerResult);
9
+ if (providerResult.status === "pass") results.push(await checkApiKey(fs, ctx, prompts));
10
+ return results;
11
+ }
12
+ /**
13
+ * Check which AI provider is configured.
14
+ */
15
+ async function checkAiProvider(fs, ctx) {
16
+ const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
17
+ try {
18
+ if (!await fs.exists(configPath)) return {
19
+ category: "ai",
20
+ name: "AI Provider",
21
+ status: "skip",
22
+ message: "No config file found"
23
+ };
24
+ const content = await fs.readFile(configPath);
25
+ const config = JSON.parse(content);
26
+ return {
27
+ category: "ai",
28
+ name: "AI Provider",
29
+ status: "pass",
30
+ message: `Provider: ${config.aiProvider ?? "claude"}, Model: ${config.aiModel ?? "default"}`
31
+ };
32
+ } catch {
33
+ return {
34
+ category: "ai",
35
+ name: "AI Provider",
36
+ status: "skip",
37
+ message: "Could not read AI config"
38
+ };
39
+ }
40
+ }
41
+ /**
42
+ * Check if API key is set for the configured provider.
43
+ */
44
+ async function checkApiKey(fs, ctx, prompts) {
45
+ const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
46
+ try {
47
+ const content = await fs.readFile(configPath);
48
+ const provider = JSON.parse(content).aiProvider ?? "claude";
49
+ const envVar = {
50
+ claude: "ANTHROPIC_API_KEY",
51
+ openai: "OPENAI_API_KEY",
52
+ ollama: "",
53
+ custom: "CONTRACTSPEC_LLM_API_KEY"
54
+ }[provider];
55
+ if (!envVar) return {
56
+ category: "ai",
57
+ name: "API Key",
58
+ status: "pass",
59
+ message: `${provider} does not require an API key`
60
+ };
61
+ if (!!process.env[envVar]) return {
62
+ category: "ai",
63
+ name: "API Key",
64
+ status: "pass",
65
+ message: `${envVar} is set`
66
+ };
67
+ return {
68
+ category: "ai",
69
+ name: "API Key",
70
+ status: "warn",
71
+ message: `${envVar} not set`,
72
+ details: `Set ${envVar} in your environment to use AI features`,
73
+ fix: prompts ? {
74
+ description: `Set ${envVar} environment variable`,
75
+ apply: async () => {
76
+ const key = await prompts.input(`Enter your ${provider} API key:`, { password: true });
77
+ if (!key) return {
78
+ success: false,
79
+ message: "No API key provided"
80
+ };
81
+ const envPath = fs.join(ctx.workspaceRoot, ".env");
82
+ try {
83
+ let envContent = "";
84
+ if (await fs.exists(envPath)) {
85
+ envContent = await fs.readFile(envPath);
86
+ if (envContent.includes(`${envVar}=`)) return {
87
+ success: false,
88
+ message: `${envVar} already in .env, update manually`
89
+ };
90
+ envContent += "\n";
91
+ }
92
+ envContent += `${envVar}=${key}\n`;
93
+ await fs.writeFile(envPath, envContent);
94
+ return {
95
+ success: true,
96
+ message: `Added ${envVar} to .env (restart required)`
97
+ };
98
+ } catch (error) {
99
+ return {
100
+ success: false,
101
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
102
+ };
103
+ }
104
+ }
105
+ } : void 0
106
+ };
107
+ } catch {
108
+ return {
109
+ category: "ai",
110
+ name: "API Key",
111
+ status: "skip",
112
+ message: "Could not check API key"
113
+ };
114
+ }
115
+ }
116
+
117
+ //#endregion
118
+ export { runAiChecks };
@@ -1 +1,146 @@
1
- import{exec as e}from"node:child_process";import{promisify as t}from"node:util";const n=t(e);async function r(e,t){let n=[];return n.push(await i(t)),n.push(await a(t)),n.push(await o(e,t)),n}async function i(e){try{return await n(`npx contractspec --version`,{cwd:e.workspaceRoot,timeout:1e4}),{category:`cli`,name:`CLI Accessible`,status:`pass`,message:`ContractSpec CLI is accessible`}}catch{return{category:`cli`,name:`CLI Accessible`,status:`fail`,message:`ContractSpec CLI is not accessible`,details:`Could not run "npx contractspec --version"`,fix:{description:`Install ContractSpec CLI globally`,apply:async()=>{try{return await n(`npm install -g @lssm/app.cli-contracts`,{cwd:e.workspaceRoot,timeout:6e4}),{success:!0,message:`CLI installed globally`}}catch(e){return{success:!1,message:`Failed to install: ${e instanceof Error?e.message:String(e)}`}}}}}}}async function a(e){try{let{stdout:t}=await n(`npx contractspec --version`,{cwd:e.workspaceRoot,timeout:1e4});return{category:`cli`,name:`CLI Version`,status:`pass`,message:`CLI version: ${t.trim()}`}}catch{return{category:`cli`,name:`CLI Version`,status:`skip`,message:`Could not determine CLI version`}}}async function o(e,t){let r=e.join(t.workspaceRoot,`package.json`);try{if(!await e.exists(r))return{category:`cli`,name:`Local Installation`,status:`skip`,message:`No package.json found`};let i=await e.readFile(r),a=JSON.parse(i);return a.dependencies?.[`@lssm/app.cli-contracts`]!==void 0||a.devDependencies?.[`@lssm/app.cli-contracts`]!==void 0?{category:`cli`,name:`Local Installation`,status:`pass`,message:`CLI is installed as a project dependency`}:{category:`cli`,name:`Local Installation`,status:`warn`,message:`CLI is not installed as a project dependency`,details:`Consider adding @lssm/app.cli-contracts to devDependencies`,fix:{description:`Add CLI as a dev dependency`,apply:async()=>{try{return await n(`npm install -D @lssm/app.cli-contracts`,{cwd:t.workspaceRoot,timeout:6e4}),{success:!0,message:`CLI added as dev dependency`}}catch(e){return{success:!1,message:`Failed to install: ${e instanceof Error?e.message:String(e)}`}}}}}}catch{return{category:`cli`,name:`Local Installation`,status:`skip`,message:`Could not check local installation`}}}export{r as runCliChecks};
1
+ import { exec } from "node:child_process";
2
+ import { promisify } from "node:util";
3
+
4
+ //#region src/services/doctor/checks/cli.ts
5
+ /**
6
+ * CLI installation health checks.
7
+ */
8
+ const execAsync = promisify(exec);
9
+ /**
10
+ * Run CLI-related health checks.
11
+ */
12
+ async function runCliChecks(fs, ctx) {
13
+ const results = [];
14
+ results.push(await checkCliAccessible(ctx));
15
+ results.push(await checkCliVersion(ctx));
16
+ results.push(await checkCliInstallLocation(fs, ctx));
17
+ return results;
18
+ }
19
+ /**
20
+ * Check if the CLI is accessible.
21
+ */
22
+ async function checkCliAccessible(ctx) {
23
+ try {
24
+ await execAsync("npx contractspec --version", {
25
+ cwd: ctx.workspaceRoot,
26
+ timeout: 1e4
27
+ });
28
+ return {
29
+ category: "cli",
30
+ name: "CLI Accessible",
31
+ status: "pass",
32
+ message: "ContractSpec CLI is accessible"
33
+ };
34
+ } catch {
35
+ return {
36
+ category: "cli",
37
+ name: "CLI Accessible",
38
+ status: "fail",
39
+ message: "ContractSpec CLI is not accessible",
40
+ details: "Could not run \"npx contractspec --version\"",
41
+ fix: {
42
+ description: "Install ContractSpec CLI globally",
43
+ apply: async () => {
44
+ try {
45
+ await execAsync("npm install -g @lssm/app.cli-contracts", {
46
+ cwd: ctx.workspaceRoot,
47
+ timeout: 6e4
48
+ });
49
+ return {
50
+ success: true,
51
+ message: "CLI installed globally"
52
+ };
53
+ } catch (error) {
54
+ return {
55
+ success: false,
56
+ message: `Failed to install: ${error instanceof Error ? error.message : String(error)}`
57
+ };
58
+ }
59
+ }
60
+ }
61
+ };
62
+ }
63
+ }
64
+ /**
65
+ * Check CLI version.
66
+ */
67
+ async function checkCliVersion(ctx) {
68
+ try {
69
+ const { stdout } = await execAsync("npx contractspec --version", {
70
+ cwd: ctx.workspaceRoot,
71
+ timeout: 1e4
72
+ });
73
+ return {
74
+ category: "cli",
75
+ name: "CLI Version",
76
+ status: "pass",
77
+ message: `CLI version: ${stdout.trim()}`
78
+ };
79
+ } catch {
80
+ return {
81
+ category: "cli",
82
+ name: "CLI Version",
83
+ status: "skip",
84
+ message: "Could not determine CLI version"
85
+ };
86
+ }
87
+ }
88
+ /**
89
+ * Check if CLI is installed locally in the project.
90
+ */
91
+ async function checkCliInstallLocation(fs, ctx) {
92
+ const packageJsonPath = fs.join(ctx.workspaceRoot, "package.json");
93
+ try {
94
+ if (!await fs.exists(packageJsonPath)) return {
95
+ category: "cli",
96
+ name: "Local Installation",
97
+ status: "skip",
98
+ message: "No package.json found"
99
+ };
100
+ const content = await fs.readFile(packageJsonPath);
101
+ const pkg = JSON.parse(content);
102
+ if (pkg.dependencies?.["@lssm/app.cli-contracts"] !== void 0 || pkg.devDependencies?.["@lssm/app.cli-contracts"] !== void 0) return {
103
+ category: "cli",
104
+ name: "Local Installation",
105
+ status: "pass",
106
+ message: "CLI is installed as a project dependency"
107
+ };
108
+ return {
109
+ category: "cli",
110
+ name: "Local Installation",
111
+ status: "warn",
112
+ message: "CLI is not installed as a project dependency",
113
+ details: "Consider adding @lssm/app.cli-contracts to devDependencies",
114
+ fix: {
115
+ description: "Add CLI as a dev dependency",
116
+ apply: async () => {
117
+ try {
118
+ await execAsync("npm install -D @lssm/app.cli-contracts", {
119
+ cwd: ctx.workspaceRoot,
120
+ timeout: 6e4
121
+ });
122
+ return {
123
+ success: true,
124
+ message: "CLI added as dev dependency"
125
+ };
126
+ } catch (error) {
127
+ return {
128
+ success: false,
129
+ message: `Failed to install: ${error instanceof Error ? error.message : String(error)}`
130
+ };
131
+ }
132
+ }
133
+ }
134
+ };
135
+ } catch {
136
+ return {
137
+ category: "cli",
138
+ name: "Local Installation",
139
+ status: "skip",
140
+ message: "Could not check local installation"
141
+ };
142
+ }
143
+ }
144
+
145
+ //#endregion
146
+ export { runCliChecks };
@@ -1 +1,170 @@
1
- import{generateContractsrcConfig as e}from"../../setup/config-generators.js";import{formatJson as t}from"../../setup/file-merger.js";async function n(e,t){let n=[];return n.push(await r(e,t)),n.push(await i(e,t)),n.push(await a(e,t)),n}async function r(n,r){let i=n.join(r.workspaceRoot,`.contractsrc.json`);return await n.exists(i)?{category:`config`,name:`Config File Exists`,status:`pass`,message:`.contractsrc.json found`}:{category:`config`,name:`Config File Exists`,status:`fail`,message:`.contractsrc.json not found`,fix:{description:`Create .contractsrc.json with defaults`,apply:async()=>{try{let a=e({workspaceRoot:r.workspaceRoot,interactive:!1,targets:[]});return await n.writeFile(i,t(a)),{success:!0,message:`Created .contractsrc.json`}}catch(e){return{success:!1,message:`Failed to create: ${e instanceof Error?e.message:String(e)}`}}}}}}async function i(n,r){let i=n.join(r.workspaceRoot,`.contractsrc.json`);if(!await n.exists(i))return{category:`config`,name:`Config Valid JSON`,status:`skip`,message:`Config file does not exist`};try{let e=await n.readFile(i);return JSON.parse(e),{category:`config`,name:`Config Valid JSON`,status:`pass`,message:`.contractsrc.json is valid JSON`}}catch(a){return{category:`config`,name:`Config Valid JSON`,status:`fail`,message:`.contractsrc.json is not valid JSON`,details:a instanceof Error?a.message:String(a),fix:{description:`Replace with valid default config`,apply:async()=>{try{let a=e({workspaceRoot:r.workspaceRoot,interactive:!1,targets:[]});return await n.writeFile(i,t(a)),{success:!0,message:`Replaced with valid config`}}catch(e){return{success:!1,message:`Failed: ${e instanceof Error?e.message:String(e)}`}}}}}}}async function a(n,r){let i=n.join(r.workspaceRoot,`.contractsrc.json`);if(!await n.exists(i))return{category:`config`,name:`Config Fields`,status:`skip`,message:`Config file does not exist`};try{let a=await n.readFile(i),o=JSON.parse(a),s=[];return o.outputDir||s.push(`outputDir`),o.conventions||s.push(`conventions`),s.length===0?{category:`config`,name:`Config Fields`,status:`pass`,message:`All recommended fields present`}:{category:`config`,name:`Config Fields`,status:`warn`,message:`Missing recommended fields: ${s.join(`, `)}`,fix:{description:`Add missing fields with defaults`,apply:async()=>{try{let a=e({workspaceRoot:r.workspaceRoot,interactive:!1,targets:[]});for(let e of s)a[e]!==void 0&&(o[e]=a[e]);return await n.writeFile(i,t(o)),{success:!0,message:`Added missing fields`}}catch(e){return{success:!1,message:`Failed: ${e instanceof Error?e.message:String(e)}`}}}}}}catch{return{category:`config`,name:`Config Fields`,status:`skip`,message:`Could not parse config`}}}export{n as runConfigChecks};
1
+ import { generateContractsrcConfig } from "../../setup/config-generators.js";
2
+ import { formatJson } from "../../setup/file-merger.js";
3
+
4
+ //#region src/services/doctor/checks/config.ts
5
+ /**
6
+ * Run configuration-related health checks.
7
+ */
8
+ async function runConfigChecks(fs, ctx) {
9
+ const results = [];
10
+ results.push(await checkContractsrcExists(fs, ctx));
11
+ results.push(await checkContractsrcValid(fs, ctx));
12
+ results.push(await checkContractsrcFields(fs, ctx));
13
+ return results;
14
+ }
15
+ /**
16
+ * Check if .contractsrc.json exists.
17
+ */
18
+ async function checkContractsrcExists(fs, ctx) {
19
+ const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
20
+ if (await fs.exists(configPath)) return {
21
+ category: "config",
22
+ name: "Config File Exists",
23
+ status: "pass",
24
+ message: ".contractsrc.json found"
25
+ };
26
+ return {
27
+ category: "config",
28
+ name: "Config File Exists",
29
+ status: "fail",
30
+ message: ".contractsrc.json not found",
31
+ fix: {
32
+ description: "Create .contractsrc.json with defaults",
33
+ apply: async () => {
34
+ try {
35
+ const defaults = generateContractsrcConfig({
36
+ workspaceRoot: ctx.workspaceRoot,
37
+ interactive: false,
38
+ targets: []
39
+ });
40
+ await fs.writeFile(configPath, formatJson(defaults));
41
+ return {
42
+ success: true,
43
+ message: "Created .contractsrc.json"
44
+ };
45
+ } catch (error) {
46
+ return {
47
+ success: false,
48
+ message: `Failed to create: ${error instanceof Error ? error.message : String(error)}`
49
+ };
50
+ }
51
+ }
52
+ }
53
+ };
54
+ }
55
+ /**
56
+ * Check if .contractsrc.json is valid JSON.
57
+ */
58
+ async function checkContractsrcValid(fs, ctx) {
59
+ const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
60
+ if (!await fs.exists(configPath)) return {
61
+ category: "config",
62
+ name: "Config Valid JSON",
63
+ status: "skip",
64
+ message: "Config file does not exist"
65
+ };
66
+ try {
67
+ const content = await fs.readFile(configPath);
68
+ JSON.parse(content);
69
+ return {
70
+ category: "config",
71
+ name: "Config Valid JSON",
72
+ status: "pass",
73
+ message: ".contractsrc.json is valid JSON"
74
+ };
75
+ } catch (error) {
76
+ return {
77
+ category: "config",
78
+ name: "Config Valid JSON",
79
+ status: "fail",
80
+ message: ".contractsrc.json is not valid JSON",
81
+ details: error instanceof Error ? error.message : String(error),
82
+ fix: {
83
+ description: "Replace with valid default config",
84
+ apply: async () => {
85
+ try {
86
+ const defaults = generateContractsrcConfig({
87
+ workspaceRoot: ctx.workspaceRoot,
88
+ interactive: false,
89
+ targets: []
90
+ });
91
+ await fs.writeFile(configPath, formatJson(defaults));
92
+ return {
93
+ success: true,
94
+ message: "Replaced with valid config"
95
+ };
96
+ } catch (err) {
97
+ return {
98
+ success: false,
99
+ message: `Failed: ${err instanceof Error ? err.message : String(err)}`
100
+ };
101
+ }
102
+ }
103
+ }
104
+ };
105
+ }
106
+ }
107
+ /**
108
+ * Check required fields in .contractsrc.json.
109
+ */
110
+ async function checkContractsrcFields(fs, ctx) {
111
+ const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
112
+ if (!await fs.exists(configPath)) return {
113
+ category: "config",
114
+ name: "Config Fields",
115
+ status: "skip",
116
+ message: "Config file does not exist"
117
+ };
118
+ try {
119
+ const content = await fs.readFile(configPath);
120
+ const config = JSON.parse(content);
121
+ const missingFields = [];
122
+ if (!config["outputDir"]) missingFields.push("outputDir");
123
+ if (!config["conventions"]) missingFields.push("conventions");
124
+ if (missingFields.length === 0) return {
125
+ category: "config",
126
+ name: "Config Fields",
127
+ status: "pass",
128
+ message: "All recommended fields present"
129
+ };
130
+ return {
131
+ category: "config",
132
+ name: "Config Fields",
133
+ status: "warn",
134
+ message: `Missing recommended fields: ${missingFields.join(", ")}`,
135
+ fix: {
136
+ description: "Add missing fields with defaults",
137
+ apply: async () => {
138
+ try {
139
+ const defaults = generateContractsrcConfig({
140
+ workspaceRoot: ctx.workspaceRoot,
141
+ interactive: false,
142
+ targets: []
143
+ });
144
+ for (const field of missingFields) if (defaults[field] !== void 0) config[field] = defaults[field];
145
+ await fs.writeFile(configPath, formatJson(config));
146
+ return {
147
+ success: true,
148
+ message: "Added missing fields"
149
+ };
150
+ } catch (err) {
151
+ return {
152
+ success: false,
153
+ message: `Failed: ${err instanceof Error ? err.message : String(err)}`
154
+ };
155
+ }
156
+ }
157
+ }
158
+ };
159
+ } catch {
160
+ return {
161
+ category: "config",
162
+ name: "Config Fields",
163
+ status: "skip",
164
+ message: "Could not parse config"
165
+ };
166
+ }
167
+ }
168
+
169
+ //#endregion
170
+ export { runConfigChecks };
@@ -1 +1,180 @@
1
- import{exec as e}from"node:child_process";import{promisify as t}from"node:util";const n=t(e);async function r(e,t){let n=[];return n.push(await i(t)),n.push(await a(t)),n.push(await o(e,t)),n.push(await s(e,t)),n}async function i(e){try{let{stdout:t}=await n(`node --version`,{cwd:e.workspaceRoot,timeout:5e3});return{category:`deps`,name:`Node.js`,status:`pass`,message:`Node.js ${t.trim()} available`}}catch{return{category:`deps`,name:`Node.js`,status:`fail`,message:`Node.js not found`,details:`Install Node.js from https://nodejs.org`}}}async function a(e){try{let{stdout:t}=await n(`bun --version`,{cwd:e.workspaceRoot,timeout:5e3});return{category:`deps`,name:`Bun Runtime`,status:`pass`,message:`Bun ${t.trim()} available`}}catch{return{category:`deps`,name:`Bun Runtime`,status:`warn`,message:`Bun not found (optional but recommended)`,details:`Install Bun from https://bun.sh for faster execution`}}}async function o(e,t){let r=[{file:`bun.lockb`,name:`bun`},{file:`pnpm-lock.yaml`,name:`pnpm`},{file:`yarn.lock`,name:`yarn`},{file:`package-lock.json`,name:`npm`}],i=null;for(let{file:n,name:a}of r){let r=e.join(t.workspaceRoot,n);if(await e.exists(r)){i=a;break}}if(!i)return{category:`deps`,name:`Package Manager`,status:`warn`,message:`No lock file found`,details:`Run npm install, yarn, pnpm install, or bun install`};try{return await n(`${i} --version`,{cwd:t.workspaceRoot,timeout:5e3}),{category:`deps`,name:`Package Manager`,status:`pass`,message:`Using ${i}`}}catch{return{category:`deps`,name:`Package Manager`,status:`fail`,message:`${i} detected but not available`,details:`Install ${i} or use a different package manager`}}}async function s(e,t){let r=e.join(t.workspaceRoot,`node_modules`);return await e.exists(r)?{category:`deps`,name:`Dependencies Installed`,status:`pass`,message:`node_modules directory exists`}:{category:`deps`,name:`Dependencies Installed`,status:`fail`,message:`node_modules not found`,details:`Run your package manager install command`,fix:{description:`Install dependencies`,apply:async()=>{try{try{return await n(`bun install`,{cwd:t.workspaceRoot,timeout:12e4}),{success:!0,message:`Installed with bun`}}catch{return await n(`npm install`,{cwd:t.workspaceRoot,timeout:12e4}),{success:!0,message:`Installed with npm`}}}catch(e){return{success:!1,message:`Failed: ${e instanceof Error?e.message:String(e)}`}}}}}}export{r as runDepsChecks};
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
+ return results;
19
+ }
20
+ /**
21
+ * Check if Node.js is available.
22
+ */
23
+ async function checkNodeJs(ctx) {
24
+ try {
25
+ const { stdout } = await execAsync("node --version", {
26
+ cwd: ctx.workspaceRoot,
27
+ timeout: 5e3
28
+ });
29
+ return {
30
+ category: "deps",
31
+ name: "Node.js",
32
+ status: "pass",
33
+ message: `Node.js ${stdout.trim()} available`
34
+ };
35
+ } catch {
36
+ return {
37
+ category: "deps",
38
+ name: "Node.js",
39
+ status: "fail",
40
+ message: "Node.js not found",
41
+ details: "Install Node.js from https://nodejs.org"
42
+ };
43
+ }
44
+ }
45
+ /**
46
+ * Check if Bun is available.
47
+ */
48
+ async function checkBun(ctx) {
49
+ try {
50
+ const { stdout } = await execAsync("bun --version", {
51
+ cwd: ctx.workspaceRoot,
52
+ timeout: 5e3
53
+ });
54
+ return {
55
+ category: "deps",
56
+ name: "Bun Runtime",
57
+ status: "pass",
58
+ message: `Bun ${stdout.trim()} available`
59
+ };
60
+ } catch {
61
+ return {
62
+ category: "deps",
63
+ name: "Bun Runtime",
64
+ status: "warn",
65
+ message: "Bun not found (optional but recommended)",
66
+ details: "Install Bun from https://bun.sh for faster execution"
67
+ };
68
+ }
69
+ }
70
+ /**
71
+ * Detect and check the package manager.
72
+ */
73
+ async function checkPackageManager(fs, ctx) {
74
+ const lockFiles = [
75
+ {
76
+ file: "bun.lockb",
77
+ name: "bun"
78
+ },
79
+ {
80
+ file: "pnpm-lock.yaml",
81
+ name: "pnpm"
82
+ },
83
+ {
84
+ file: "yarn.lock",
85
+ name: "yarn"
86
+ },
87
+ {
88
+ file: "package-lock.json",
89
+ name: "npm"
90
+ }
91
+ ];
92
+ let detectedManager = null;
93
+ for (const { file, name } of lockFiles) {
94
+ const lockPath = fs.join(ctx.workspaceRoot, file);
95
+ if (await fs.exists(lockPath)) {
96
+ detectedManager = name;
97
+ break;
98
+ }
99
+ }
100
+ if (!detectedManager) return {
101
+ category: "deps",
102
+ name: "Package Manager",
103
+ status: "warn",
104
+ message: "No lock file found",
105
+ details: "Run npm install, yarn, pnpm install, or bun install"
106
+ };
107
+ try {
108
+ await execAsync(`${detectedManager} --version`, {
109
+ cwd: ctx.workspaceRoot,
110
+ timeout: 5e3
111
+ });
112
+ return {
113
+ category: "deps",
114
+ name: "Package Manager",
115
+ status: "pass",
116
+ message: `Using ${detectedManager}`
117
+ };
118
+ } catch {
119
+ return {
120
+ category: "deps",
121
+ name: "Package Manager",
122
+ status: "fail",
123
+ message: `${detectedManager} detected but not available`,
124
+ details: `Install ${detectedManager} or use a different package manager`
125
+ };
126
+ }
127
+ }
128
+ /**
129
+ * Check if node_modules exists.
130
+ */
131
+ async function checkNodeModules(fs, ctx) {
132
+ const nodeModulesPath = fs.join(ctx.workspaceRoot, "node_modules");
133
+ if (await fs.exists(nodeModulesPath)) return {
134
+ category: "deps",
135
+ name: "Dependencies Installed",
136
+ status: "pass",
137
+ message: "node_modules directory exists"
138
+ };
139
+ return {
140
+ category: "deps",
141
+ name: "Dependencies Installed",
142
+ status: "fail",
143
+ message: "node_modules not found",
144
+ details: "Run your package manager install command",
145
+ fix: {
146
+ description: "Install dependencies",
147
+ apply: async () => {
148
+ try {
149
+ try {
150
+ await execAsync("bun install", {
151
+ cwd: ctx.workspaceRoot,
152
+ timeout: 12e4
153
+ });
154
+ return {
155
+ success: true,
156
+ message: "Installed with bun"
157
+ };
158
+ } catch {
159
+ await execAsync("npm install", {
160
+ cwd: ctx.workspaceRoot,
161
+ timeout: 12e4
162
+ });
163
+ return {
164
+ success: true,
165
+ message: "Installed with npm"
166
+ };
167
+ }
168
+ } catch (error) {
169
+ return {
170
+ success: false,
171
+ message: `Failed: ${error instanceof Error ? error.message : String(error)}`
172
+ };
173
+ }
174
+ }
175
+ }
176
+ };
177
+ }
178
+
179
+ //#endregion
180
+ export { runDepsChecks };
@@ -1 +1,6 @@
1
- import{runCliChecks as e}from"./cli.js";import{runConfigChecks as t}from"./config.js";import{runMcpChecks as n}from"./mcp.js";import{runDepsChecks as r}from"./deps.js";import{runWorkspaceChecks as i}from"./workspace.js";import{runAiChecks as a}from"./ai.js";
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";