@lssm/bundle.contractspec-workspace 0.0.0-canary-20251217083314 → 1.41.1

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 (350) hide show
  1. package/dist/_virtual/rolldown_runtime.js +1 -22
  2. package/dist/adapters/ai.js +1 -82
  3. package/dist/adapters/factory.js +1 -36
  4. package/dist/adapters/fs.js +1 -118
  5. package/dist/adapters/git.js +1 -54
  6. package/dist/adapters/index.js +1 -7
  7. package/dist/adapters/logger.js +1 -80
  8. package/dist/adapters/watcher.js +1 -69
  9. package/dist/adapters/workspace.js +2 -190
  10. package/dist/ai/agents/claude-code-agent.js +9 -146
  11. package/dist/ai/agents/cursor-agent.js +17 -286
  12. package/dist/ai/agents/index.js +1 -5
  13. package/dist/ai/agents/openai-codex-agent.js +8 -140
  14. package/dist/ai/agents/orchestrator.js +1 -142
  15. package/dist/ai/agents/simple-agent.js +4 -80
  16. package/dist/ai/client.js +1 -162
  17. package/dist/ai/index.js +1 -27
  18. package/dist/ai/prompts/code-generation.js +13 -55
  19. package/dist/ai/prompts/index.js +1 -12
  20. package/dist/ai/prompts/spec-creation.js +20 -61
  21. package/dist/ai/providers.js +1 -40
  22. package/dist/formatters/index.js +1 -18
  23. package/dist/formatters/json.js +1 -71
  24. package/dist/formatters/sarif.js +1 -163
  25. package/dist/formatters/text.js +2 -208
  26. package/dist/index.js +1 -81
  27. package/dist/services/agent-guide/adapters/claude-code.js +3 -144
  28. package/dist/services/agent-guide/adapters/cursor-cli.js +3 -135
  29. package/dist/services/agent-guide/adapters/generic-mcp.js +3 -159
  30. package/dist/services/agent-guide/adapters/index.js +1 -30
  31. package/dist/services/agent-guide/agent-guide-service.js +1 -148
  32. package/dist/services/agent-guide/index.js +1 -5
  33. package/dist/services/build.js +1 -140
  34. package/dist/services/ci-check/ci-check-service.js +1 -393
  35. package/dist/services/ci-check/index.js +1 -2
  36. package/dist/services/ci-check/types.js +1 -28
  37. package/dist/services/clean.js +1 -71
  38. package/dist/services/config.js +1 -76
  39. package/dist/services/deps.js +1 -62
  40. package/dist/services/diff.js +1 -33
  41. package/dist/services/doctor/checks/ai.js +2 -118
  42. package/dist/services/doctor/checks/cli.js +1 -146
  43. package/dist/services/doctor/checks/config.js +1 -170
  44. package/dist/services/doctor/checks/deps.js +1 -180
  45. package/dist/services/doctor/checks/index.js +1 -6
  46. package/dist/services/doctor/checks/mcp.js +1 -144
  47. package/dist/services/doctor/checks/workspace.js +1 -243
  48. package/dist/services/doctor/doctor-service.js +2 -115
  49. package/dist/services/doctor/index.js +1 -2
  50. package/dist/services/doctor/types.js +1 -26
  51. package/dist/services/implementation/discovery.js +2 -143
  52. package/dist/services/implementation/index.js +1 -2
  53. package/dist/services/implementation/resolver.js +1 -223
  54. package/dist/services/index.js +1 -53
  55. package/dist/services/integrity-diagram.js +6 -274
  56. package/dist/services/integrity.js +1 -272
  57. package/dist/services/list.js +1 -35
  58. package/dist/services/openapi/export-service.js +2 -51
  59. package/dist/services/openapi/import-service.js +1 -75
  60. package/dist/services/openapi/index.js +1 -4
  61. package/dist/services/openapi/sync-service.js +1 -121
  62. package/dist/services/openapi/validate-service.js +1 -130
  63. package/dist/services/regenerator.js +1 -23
  64. package/dist/services/registry.js +1 -73
  65. package/dist/services/setup/config-generators.js +26 -113
  66. package/dist/services/setup/file-merger.js +2 -60
  67. package/dist/services/setup/index.js +1 -4
  68. package/dist/services/setup/setup-service.js +1 -95
  69. package/dist/services/setup/targets/agents-md.js +1 -46
  70. package/dist/services/setup/targets/cli-config.js +1 -59
  71. package/dist/services/setup/targets/cursor-rules.js +1 -47
  72. package/dist/services/setup/targets/mcp-claude.js +1 -59
  73. package/dist/services/setup/targets/mcp-cursor.js +1 -58
  74. package/dist/services/setup/targets/vscode-settings.js +1 -62
  75. package/dist/services/setup/types.js +1 -26
  76. package/dist/services/sync.js +1 -62
  77. package/dist/services/test.js +1 -30
  78. package/dist/services/validate-implementation.js +1 -69
  79. package/dist/services/validate.js +1 -47
  80. package/dist/services/verification-cache/adapters/filesystem.js +1 -121
  81. package/dist/services/verification-cache/adapters/in-memory.js +1 -45
  82. package/dist/services/verification-cache/adapters/index.js +1 -3
  83. package/dist/services/verification-cache/adapters/workspace-state.js +1 -90
  84. package/dist/services/verification-cache/cache-service.js +1 -255
  85. package/dist/services/verification-cache/index.js +1 -6
  86. package/dist/services/verification-cache/types.js +1 -15
  87. package/dist/services/verify/ai-verifier.js +9 -336
  88. package/dist/services/verify/behavior-verifier.js +1 -185
  89. package/dist/services/verify/index.js +1 -4
  90. package/dist/services/verify/structure-verifier.js +2 -195
  91. package/dist/services/verify/verify-service.js +3 -203
  92. package/dist/services/watch.js +1 -31
  93. package/dist/services/workspace-info.js +2 -102
  94. package/dist/templates/app-config.template.js +28 -101
  95. package/dist/templates/data-view.template.js +27 -42
  96. package/dist/templates/event.template.js +14 -29
  97. package/dist/templates/experiment.template.js +51 -77
  98. package/dist/templates/handler.template.js +17 -53
  99. package/dist/templates/index.js +1 -36
  100. package/dist/templates/integration.template.js +50 -134
  101. package/dist/templates/knowledge.template.js +21 -62
  102. package/dist/templates/migration.template.js +26 -50
  103. package/dist/templates/operation.template.js +28 -44
  104. package/dist/templates/presentation.template.js +20 -46
  105. package/dist/templates/telemetry.template.js +53 -74
  106. package/dist/templates/workflow-runner.template.js +6 -12
  107. package/dist/templates/workflow.template.js +24 -51
  108. package/package.json +10 -15
  109. package/dist/adapters/ai.d.ts +0 -11
  110. package/dist/adapters/factory.d.ts +0 -28
  111. package/dist/adapters/fs.d.ts +0 -10
  112. package/dist/adapters/git.d.ts +0 -10
  113. package/dist/adapters/logger.d.ts +0 -17
  114. package/dist/adapters/watcher.d.ts +0 -10
  115. package/dist/adapters/workspace.d.ts +0 -93
  116. package/dist/ai/agents/claude-code-agent.d.ts +0 -21
  117. package/dist/ai/agents/cursor-agent.d.ts +0 -67
  118. package/dist/ai/agents/openai-codex-agent.d.ts +0 -21
  119. package/dist/ai/agents/orchestrator.d.ts +0 -49
  120. package/dist/ai/agents/simple-agent.d.ts +0 -16
  121. package/dist/ai/agents/types.d.ts +0 -35
  122. package/dist/ai/client.d.ts +0 -82
  123. package/dist/ai/index.d.ts +0 -16
  124. package/dist/ai/prompts/code-generation.d.ts +0 -25
  125. package/dist/ai/prompts/index.d.ts +0 -9
  126. package/dist/ai/prompts/spec-creation.d.ts +0 -28
  127. package/dist/ai/providers.d.ts +0 -28
  128. package/dist/formatters/index.d.ts +0 -10
  129. package/dist/formatters/json.d.ts +0 -88
  130. package/dist/formatters/sarif.d.ts +0 -100
  131. package/dist/formatters/text.d.ts +0 -34
  132. package/dist/index.d.ts +0 -66
  133. package/dist/libs/ai-providers/dist/factory.js +0 -154
  134. package/dist/libs/ai-providers/dist/index.js +0 -4
  135. package/dist/libs/ai-providers/dist/legacy.js +0 -72
  136. package/dist/libs/ai-providers/dist/models.js +0 -287
  137. package/dist/libs/ai-providers/dist/validation.js +0 -1
  138. package/dist/libs/contracts/dist/capabilities/openbanking.js +0 -88
  139. package/dist/libs/contracts/dist/client/index.js +0 -5
  140. package/dist/libs/contracts/dist/client/react/feature-render.js +0 -2
  141. package/dist/libs/contracts/dist/client/react/form-render.js +0 -4
  142. package/dist/libs/contracts/dist/client/react/index.js +0 -4
  143. package/dist/libs/contracts/dist/contract-registry/index.js +0 -1
  144. package/dist/libs/contracts/dist/contract-registry/schemas.js +0 -60
  145. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +0 -16
  146. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +0 -16
  147. package/dist/libs/contracts/dist/docs/index.js +0 -29
  148. package/dist/libs/contracts/dist/docs/presentations.js +0 -71
  149. package/dist/libs/contracts/dist/docs/registry.js +0 -44
  150. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +0 -16
  151. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +0 -16
  152. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +0 -16
  153. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +0 -16
  154. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +0 -16
  155. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +0 -80
  156. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +0 -57
  157. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +0 -16
  158. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +0 -357
  159. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +0 -37
  160. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +0 -16
  161. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +0 -20
  162. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +0 -48
  163. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +0 -79
  164. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +0 -84
  165. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +0 -45
  166. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +0 -67
  167. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +0 -40
  168. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +0 -69
  169. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +0 -47
  170. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +0 -62
  171. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +0 -155
  172. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +0 -20
  173. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +0 -101
  174. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +0 -20
  175. package/dist/libs/contracts/dist/events.js +0 -8
  176. package/dist/libs/contracts/dist/experiments/evaluator.js +0 -1
  177. package/dist/libs/contracts/dist/index.js +0 -72
  178. package/dist/libs/contracts/dist/install.js +0 -2
  179. package/dist/libs/contracts/dist/integrations/contracts.js +0 -377
  180. package/dist/libs/contracts/dist/integrations/index.js +0 -18
  181. package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +0 -228
  182. package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +0 -159
  183. package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +0 -3
  184. package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +0 -210
  185. package/dist/libs/contracts/dist/integrations/openbanking/models.js +0 -242
  186. package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +0 -13
  187. package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +0 -52
  188. package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +0 -75
  189. package/dist/libs/contracts/dist/integrations/providers/gmail.js +0 -87
  190. package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +0 -66
  191. package/dist/libs/contracts/dist/integrations/providers/index.js +0 -11
  192. package/dist/libs/contracts/dist/integrations/providers/mistral.js +0 -68
  193. package/dist/libs/contracts/dist/integrations/providers/postmark.js +0 -68
  194. package/dist/libs/contracts/dist/integrations/providers/powens.js +0 -116
  195. package/dist/libs/contracts/dist/integrations/providers/qdrant.js +0 -73
  196. package/dist/libs/contracts/dist/integrations/providers/registry.js +0 -10
  197. package/dist/libs/contracts/dist/integrations/providers/stripe.js +0 -83
  198. package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +0 -61
  199. package/dist/libs/contracts/dist/jsonschema.js +0 -24
  200. package/dist/libs/contracts/dist/knowledge/contracts.js +0 -306
  201. package/dist/libs/contracts/dist/knowledge/index.js +0 -7
  202. package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +0 -34
  203. package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +0 -34
  204. package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +0 -38
  205. package/dist/libs/contracts/dist/knowledge/spaces/index.js +0 -6
  206. package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +0 -34
  207. package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +0 -37
  208. package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +0 -34
  209. package/dist/libs/contracts/dist/llm/exporters.js +0 -352
  210. package/dist/libs/contracts/dist/llm/index.js +0 -2
  211. package/dist/libs/contracts/dist/llm/prompts.js +0 -211
  212. package/dist/libs/contracts/dist/onboarding-base.js +0 -196
  213. package/dist/libs/contracts/dist/openapi.js +0 -75
  214. package/dist/libs/contracts/dist/ownership.js +0 -21
  215. package/dist/libs/contracts/dist/presentations.js +0 -1
  216. package/dist/libs/contracts/dist/presentations.v2.js +0 -11
  217. package/dist/libs/contracts/dist/prompt.js +0 -1
  218. package/dist/libs/contracts/dist/promptRegistry.js +0 -1
  219. package/dist/libs/contracts/dist/regenerator/index.js +0 -2
  220. package/dist/libs/contracts/dist/regenerator/service.js +0 -92
  221. package/dist/libs/contracts/dist/regenerator/utils.js +0 -51
  222. package/dist/libs/contracts/dist/registry.js +0 -208
  223. package/dist/libs/contracts/dist/resources.js +0 -1
  224. package/dist/libs/contracts/dist/schema/dist/EnumType.js +0 -2
  225. package/dist/libs/contracts/dist/schema/dist/FieldType.js +0 -49
  226. package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +0 -236
  227. package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +0 -34
  228. package/dist/libs/contracts/dist/schema/dist/entity/defineEntity.js +0 -1
  229. package/dist/libs/contracts/dist/schema/dist/entity/index.js +0 -2
  230. package/dist/libs/contracts/dist/schema/dist/entity/types.js +0 -1
  231. package/dist/libs/contracts/dist/schema/dist/index.js +0 -6
  232. package/dist/libs/contracts/dist/server/graphql-pothos.js +0 -6
  233. package/dist/libs/contracts/dist/server/index.js +0 -8
  234. package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +0 -4
  235. package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +0 -2
  236. package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +0 -1
  237. package/dist/libs/contracts/dist/server/mcp/registerResources.js +0 -2
  238. package/dist/libs/contracts/dist/server/mcp/registerTools.js +0 -1
  239. package/dist/libs/contracts/dist/server/provider-mcp.js +0 -1
  240. package/dist/libs/contracts/dist/server/rest-elysia.js +0 -1
  241. package/dist/libs/contracts/dist/server/rest-express.js +0 -1
  242. package/dist/libs/contracts/dist/server/rest-generic.js +0 -1
  243. package/dist/libs/contracts/dist/server/rest-next-app.js +0 -1
  244. package/dist/libs/contracts/dist/server/rest-next-pages.js +0 -1
  245. package/dist/libs/contracts/dist/spec.js +0 -35
  246. package/dist/libs/contracts/dist/telemetry/index.js +0 -1
  247. package/dist/libs/contracts/dist/telemetry/tracker.js +0 -1
  248. package/dist/libs/contracts/dist/tests/index.js +0 -1
  249. package/dist/libs/contracts/dist/tests/runner.js +0 -150
  250. package/dist/libs/contracts/dist/workflow/index.js +0 -1
  251. package/dist/libs/contracts/dist/workflow/runner.js +0 -1
  252. package/dist/libs/contracts-transformers/dist/common/utils.js +0 -47
  253. package/dist/libs/contracts-transformers/dist/openapi/exporter.js +0 -1
  254. package/dist/libs/contracts-transformers/dist/openapi/importer.js +0 -255
  255. package/dist/libs/contracts-transformers/dist/openapi/index.js +0 -4
  256. package/dist/libs/contracts-transformers/dist/openapi/parser.js +0 -231
  257. package/dist/libs/contracts-transformers/dist/openapi/schema-converter.js +0 -201
  258. package/dist/modules/contractspec-workspace/dist/ai/code-generation.js +0 -137
  259. package/dist/modules/contractspec-workspace/dist/ai/spec-creation.js +0 -101
  260. package/dist/modules/contractspec-workspace/dist/analysis/deps/graph.js +0 -84
  261. package/dist/modules/contractspec-workspace/dist/analysis/deps/parse-imports.js +0 -30
  262. package/dist/modules/contractspec-workspace/dist/analysis/diff/semantic.js +0 -96
  263. package/dist/modules/contractspec-workspace/dist/analysis/feature-scan.js +0 -151
  264. package/dist/modules/contractspec-workspace/dist/analysis/spec-scan.js +0 -344
  265. package/dist/modules/contractspec-workspace/dist/analysis/validate/spec-structure.js +0 -122
  266. package/dist/modules/contractspec-workspace/dist/templates/app-config.js +0 -105
  267. package/dist/modules/contractspec-workspace/dist/templates/data-view.js +0 -68
  268. package/dist/modules/contractspec-workspace/dist/templates/event.js +0 -38
  269. package/dist/modules/contractspec-workspace/dist/templates/experiment.js +0 -87
  270. package/dist/modules/contractspec-workspace/dist/templates/handler.js +0 -95
  271. package/dist/modules/contractspec-workspace/dist/templates/integration-utils.js +0 -104
  272. package/dist/modules/contractspec-workspace/dist/templates/integration.js +0 -62
  273. package/dist/modules/contractspec-workspace/dist/templates/knowledge.js +0 -68
  274. package/dist/modules/contractspec-workspace/dist/templates/migration.js +0 -60
  275. package/dist/modules/contractspec-workspace/dist/templates/operation.js +0 -100
  276. package/dist/modules/contractspec-workspace/dist/templates/presentation.js +0 -78
  277. package/dist/modules/contractspec-workspace/dist/templates/telemetry.js +0 -89
  278. package/dist/modules/contractspec-workspace/dist/templates/utils.js +0 -38
  279. package/dist/modules/contractspec-workspace/dist/templates/workflow-runner.js +0 -48
  280. package/dist/modules/contractspec-workspace/dist/templates/workflow.js +0 -67
  281. package/dist/modules/contractspec-workspace/dist/types/generation-types.js +0 -20
  282. package/dist/ports/ai.d.ts +0 -58
  283. package/dist/ports/fs.d.ts +0 -80
  284. package/dist/ports/git.d.ts +0 -32
  285. package/dist/ports/logger.d.ts +0 -87
  286. package/dist/ports/watcher.d.ts +0 -51
  287. package/dist/services/agent-guide/adapters/claude-code.d.ts +0 -34
  288. package/dist/services/agent-guide/adapters/cursor-cli.d.ts +0 -38
  289. package/dist/services/agent-guide/adapters/generic-mcp.d.ts +0 -52
  290. package/dist/services/agent-guide/adapters/index.d.ts +0 -22
  291. package/dist/services/agent-guide/agent-guide-service.d.ts +0 -55
  292. package/dist/services/agent-guide/types.d.ts +0 -57
  293. package/dist/services/build.d.ts +0 -58
  294. package/dist/services/ci-check/ci-check-service.d.ts +0 -15
  295. package/dist/services/ci-check/types.d.ts +0 -142
  296. package/dist/services/clean.d.ts +0 -40
  297. package/dist/services/config.d.ts +0 -25
  298. package/dist/services/deps.d.ts +0 -52
  299. package/dist/services/diff.d.ts +0 -33
  300. package/dist/services/doctor/doctor-service.d.ts +0 -23
  301. package/dist/services/doctor/types.d.ts +0 -117
  302. package/dist/services/implementation/discovery.d.ts +0 -29
  303. package/dist/services/implementation/resolver.d.ts +0 -43
  304. package/dist/services/implementation/types.d.ts +0 -78
  305. package/dist/services/integrity-diagram.d.ts +0 -35
  306. package/dist/services/integrity.d.ts +0 -133
  307. package/dist/services/list.d.ts +0 -30
  308. package/dist/services/openapi/export-service.d.ts +0 -52
  309. package/dist/services/openapi/import-service.d.ts +0 -15
  310. package/dist/services/openapi/sync-service.d.ts +0 -18
  311. package/dist/services/openapi/types.d.ts +0 -184
  312. package/dist/services/openapi/validate-service.d.ts +0 -15
  313. package/dist/services/regenerator.d.ts +0 -17
  314. package/dist/services/registry.d.ts +0 -52
  315. package/dist/services/setup/config-generators.d.ts +0 -41
  316. package/dist/services/setup/file-merger.d.ts +0 -26
  317. package/dist/services/setup/setup-service.d.ts +0 -11
  318. package/dist/services/setup/types.d.ts +0 -84
  319. package/dist/services/sync.d.ts +0 -40
  320. package/dist/services/test.d.ts +0 -14
  321. package/dist/services/validate-implementation.d.ts +0 -31
  322. package/dist/services/validate.d.ts +0 -40
  323. package/dist/services/verification-cache/adapters/filesystem.d.ts +0 -45
  324. package/dist/services/verification-cache/adapters/in-memory.d.ts +0 -26
  325. package/dist/services/verification-cache/adapters/workspace-state.d.ts +0 -48
  326. package/dist/services/verification-cache/cache-service.d.ts +0 -69
  327. package/dist/services/verification-cache/types.d.ts +0 -123
  328. package/dist/services/verify/ai-verifier.d.ts +0 -24
  329. package/dist/services/verify/behavior-verifier.d.ts +0 -11
  330. package/dist/services/verify/structure-verifier.d.ts +0 -11
  331. package/dist/services/verify/types.d.ts +0 -136
  332. package/dist/services/verify/verify-service.d.ts +0 -59
  333. package/dist/services/watch.d.ts +0 -24
  334. package/dist/services/workspace-info.d.ts +0 -61
  335. package/dist/templates/app-config.template.d.ts +0 -6
  336. package/dist/templates/data-view.template.d.ts +0 -6
  337. package/dist/templates/event.template.d.ts +0 -10
  338. package/dist/templates/experiment.template.d.ts +0 -6
  339. package/dist/templates/handler.template.d.ts +0 -15
  340. package/dist/templates/index.d.ts +0 -20
  341. package/dist/templates/integration.template.d.ts +0 -6
  342. package/dist/templates/knowledge.template.d.ts +0 -6
  343. package/dist/templates/migration.template.d.ts +0 -6
  344. package/dist/templates/operation.template.d.ts +0 -10
  345. package/dist/templates/presentation.template.d.ts +0 -10
  346. package/dist/templates/telemetry.template.d.ts +0 -6
  347. package/dist/templates/workflow-runner.template.d.ts +0 -15
  348. package/dist/templates/workflow.template.d.ts +0 -6
  349. package/dist/types/config.d.ts +0 -33
  350. package/dist/types.d.ts +0 -323
@@ -1,393 +1 @@
1
- import { isFeatureFile } from "../../modules/contractspec-workspace/dist/analysis/feature-scan.js";
2
- import { validateSpecStructure } from "../../modules/contractspec-workspace/dist/analysis/validate/spec-structure.js";
3
- import { validateImplementationFiles } from "../validate-implementation.js";
4
- import { analyzeDeps } from "../deps.js";
5
- import { loadWorkspaceConfig } from "../config.js";
6
- import { analyzeIntegrity } from "../integrity.js";
7
- import { runDoctor } from "../doctor/doctor-service.js";
8
- import { resolveAllImplementations } from "../implementation/resolver.js";
9
- import "../verification-cache/index.js";
10
-
11
- //#region src/services/ci-check/ci-check-service.ts
12
- /**
13
- * CI Check service.
14
- *
15
- * Orchestrates all validation checks for CI/CD pipelines.
16
- * Returns structured results suitable for multiple output formats.
17
- */
18
- /**
19
- * Run all CI checks and return structured results.
20
- */
21
- async function runCIChecks(adapters, options = {}) {
22
- const startTime = Date.now();
23
- const { fs, logger } = adapters;
24
- const issues = [];
25
- const categorySummaries = [];
26
- const checksToRun = getChecksToRun(options);
27
- logger.info("Starting CI checks...", { checks: checksToRun });
28
- const specFiles = (await fs.glob({ pattern: options.pattern })).filter((f) => !isFeatureFile(f) && !f.includes(".test.") && !f.includes(".spec."));
29
- if (checksToRun.includes("structure")) {
30
- const categoryStart = Date.now();
31
- const structureIssues = await runStructureChecks(adapters, specFiles);
32
- issues.push(...structureIssues);
33
- categorySummaries.push(createCategorySummary("structure", structureIssues, Date.now() - categoryStart));
34
- }
35
- if (checksToRun.includes("integrity")) {
36
- const categoryStart = Date.now();
37
- const integrityIssues = await runIntegrityChecks(adapters, options);
38
- issues.push(...integrityIssues);
39
- categorySummaries.push(createCategorySummary("integrity", integrityIssues, Date.now() - categoryStart));
40
- }
41
- if (checksToRun.includes("deps")) {
42
- const categoryStart = Date.now();
43
- const depsIssues = await runDepsChecks(adapters, options);
44
- issues.push(...depsIssues);
45
- categorySummaries.push(createCategorySummary("deps", depsIssues, Date.now() - categoryStart));
46
- }
47
- if (checksToRun.includes("doctor")) {
48
- const categoryStart = Date.now();
49
- const doctorIssues = await runDoctorChecks(adapters, options);
50
- issues.push(...doctorIssues);
51
- categorySummaries.push(createCategorySummary("doctor", doctorIssues, Date.now() - categoryStart));
52
- }
53
- if (checksToRun.includes("handlers") || options.checkHandlers) {
54
- const categoryStart = Date.now();
55
- const handlerIssues = await runHandlerChecks(adapters, specFiles);
56
- issues.push(...handlerIssues);
57
- categorySummaries.push(createCategorySummary("handlers", handlerIssues, Date.now() - categoryStart));
58
- }
59
- if (checksToRun.includes("tests") || options.checkTests) {
60
- const categoryStart = Date.now();
61
- const testIssues = await runTestChecks(adapters, specFiles);
62
- issues.push(...testIssues);
63
- categorySummaries.push(createCategorySummary("tests", testIssues, Date.now() - categoryStart));
64
- }
65
- if (checksToRun.includes("implementation")) {
66
- const categoryStart = Date.now();
67
- const implIssues = await runImplementationChecks(adapters, specFiles, options);
68
- issues.push(...implIssues);
69
- categorySummaries.push(createCategorySummary("implementation", implIssues, Date.now() - categoryStart));
70
- }
71
- const totalErrors = issues.filter((i) => i.severity === "error").length;
72
- const totalWarnings = issues.filter((i) => i.severity === "warning").length;
73
- const totalNotes = issues.filter((i) => i.severity === "note").length;
74
- const success = options.failOnWarnings ? totalErrors === 0 && totalWarnings === 0 : totalErrors === 0;
75
- const gitInfo = await getGitInfo(fs);
76
- const result = {
77
- success,
78
- totalErrors,
79
- totalWarnings,
80
- totalNotes,
81
- issues,
82
- categories: categorySummaries,
83
- durationMs: Date.now() - startTime,
84
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
85
- ...gitInfo
86
- };
87
- logger.info("CI checks complete", {
88
- success,
89
- errors: totalErrors,
90
- warnings: totalWarnings,
91
- durationMs: result.durationMs
92
- });
93
- return result;
94
- }
95
- /**
96
- * Determine which checks to run based on options.
97
- */
98
- function getChecksToRun(options) {
99
- const allCategories = [
100
- "structure",
101
- "integrity",
102
- "deps",
103
- "doctor"
104
- ];
105
- if (options.checkHandlers) allCategories.push("handlers");
106
- if (options.checkTests) allCategories.push("tests");
107
- if (options.implementation) allCategories.push("implementation");
108
- if (options.checks && options.checks.length > 0) return options.checks;
109
- if (options.skip && options.skip.length > 0) return allCategories.filter((c) => !options.skip?.includes(c));
110
- return allCategories;
111
- }
112
- /**
113
- * Run spec structure validation checks.
114
- */
115
- async function runStructureChecks(adapters, specFiles) {
116
- const { fs } = adapters;
117
- const issues = [];
118
- for (const file of specFiles) {
119
- const result = validateSpecStructure(await fs.readFile(file), fs.basename(file));
120
- for (const error of result.errors) issues.push({
121
- ruleId: "spec-structure-error",
122
- severity: "error",
123
- message: error,
124
- category: "structure",
125
- file
126
- });
127
- for (const warning of result.warnings) issues.push({
128
- ruleId: "spec-structure-warning",
129
- severity: "warning",
130
- message: warning,
131
- category: "structure",
132
- file
133
- });
134
- }
135
- return issues;
136
- }
137
- /**
138
- * Run integrity analysis checks.
139
- */
140
- async function runIntegrityChecks(adapters, options) {
141
- const issues = [];
142
- const result = await analyzeIntegrity(adapters, {
143
- pattern: options.pattern,
144
- all: true
145
- });
146
- for (const issue of result.issues) issues.push({
147
- ruleId: `integrity-${issue.type}`,
148
- severity: issue.severity === "error" ? "error" : "warning",
149
- message: issue.message,
150
- category: "integrity",
151
- file: issue.file,
152
- context: {
153
- specName: issue.specName,
154
- specType: issue.specType,
155
- featureKey: issue.featureKey,
156
- ref: issue.ref
157
- }
158
- });
159
- return issues;
160
- }
161
- /**
162
- * Run dependency analysis checks.
163
- */
164
- async function runDepsChecks(adapters, options) {
165
- const issues = [];
166
- const result = await analyzeDeps(adapters, { pattern: options.pattern });
167
- for (const cycle of result.cycles) issues.push({
168
- ruleId: "deps-circular",
169
- severity: "error",
170
- message: `Circular dependency detected: ${cycle.join(" → ")}`,
171
- category: "deps",
172
- context: { cycle }
173
- });
174
- for (const item of result.missing) for (const missing of item.missing) issues.push({
175
- ruleId: "deps-missing",
176
- severity: "error",
177
- message: `Missing dependency: ${item.contract} requires ${missing}`,
178
- category: "deps",
179
- context: {
180
- contract: item.contract,
181
- missing
182
- }
183
- });
184
- return issues;
185
- }
186
- /**
187
- * Run doctor checks (skipping AI in CI).
188
- */
189
- async function runDoctorChecks(adapters, options) {
190
- const issues = [];
191
- const result = await runDoctor(adapters, {
192
- workspaceRoot: options.workspaceRoot ?? process.cwd(),
193
- skipAi: true,
194
- categories: [
195
- "cli",
196
- "config",
197
- "deps",
198
- "workspace"
199
- ]
200
- });
201
- for (const check of result.checks) if (check.status === "fail") issues.push({
202
- ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\s+/g, "-")}`,
203
- severity: "error",
204
- message: `${check.name}: ${check.message}`,
205
- category: "doctor",
206
- context: { details: check.details }
207
- });
208
- else if (check.status === "warn") issues.push({
209
- ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\s+/g, "-")}`,
210
- severity: "warning",
211
- message: `${check.name}: ${check.message}`,
212
- category: "doctor",
213
- context: { details: check.details }
214
- });
215
- return issues;
216
- }
217
- /**
218
- * Run handler implementation checks.
219
- */
220
- async function runHandlerChecks(adapters, specFiles) {
221
- const { fs } = adapters;
222
- const issues = [];
223
- const config = await loadWorkspaceConfig(fs);
224
- for (const specFile of specFiles) {
225
- if (!specFile.includes(".contracts.")) continue;
226
- const result = await validateImplementationFiles(specFile, { fs }, config, {
227
- checkHandlers: true,
228
- outputDir: config.outputDir
229
- });
230
- for (const error of result.errors) issues.push({
231
- ruleId: "handler-missing",
232
- severity: "warning",
233
- message: error,
234
- category: "handlers",
235
- file: specFile
236
- });
237
- for (const warning of result.warnings) issues.push({
238
- ruleId: "handler-warning",
239
- severity: "warning",
240
- message: warning,
241
- category: "handlers",
242
- file: specFile
243
- });
244
- }
245
- return issues;
246
- }
247
- /**
248
- * Run test coverage checks.
249
- */
250
- async function runTestChecks(adapters, specFiles) {
251
- const { fs } = adapters;
252
- const issues = [];
253
- const config = await loadWorkspaceConfig(fs);
254
- for (const specFile of specFiles) {
255
- if (!specFile.includes(".contracts.")) continue;
256
- const result = await validateImplementationFiles(specFile, { fs }, config, {
257
- checkTests: true,
258
- outputDir: config.outputDir
259
- });
260
- for (const error of result.errors) issues.push({
261
- ruleId: "test-missing",
262
- severity: "warning",
263
- message: error,
264
- category: "tests",
265
- file: specFile
266
- });
267
- for (const warning of result.warnings) issues.push({
268
- ruleId: "test-warning",
269
- severity: "warning",
270
- message: warning,
271
- category: "tests",
272
- file: specFile
273
- });
274
- }
275
- return issues;
276
- }
277
- /**
278
- * Run implementation verification checks.
279
- */
280
- async function runImplementationChecks(adapters, specFiles, options) {
281
- const { fs } = adapters;
282
- const issues = [];
283
- const config = await loadWorkspaceConfig(fs);
284
- const implOptions = options.implementation ?? {};
285
- const results = await resolveAllImplementations(specFiles.filter((f) => f.includes(".contracts.")), { fs }, config, { computeHashes: implOptions.useCache ?? true });
286
- for (const result of results) {
287
- if (implOptions.requireImplemented && result.status === "missing") issues.push({
288
- ruleId: "impl-missing",
289
- severity: "error",
290
- message: `Spec ${result.specName} has no implementation`,
291
- category: "implementation",
292
- file: result.specPath,
293
- context: {
294
- specName: result.specName,
295
- specVersion: result.specVersion,
296
- status: result.status
297
- }
298
- });
299
- else if (result.status === "missing") issues.push({
300
- ruleId: "impl-missing",
301
- severity: "warning",
302
- message: `Spec ${result.specName} has no implementation`,
303
- category: "implementation",
304
- file: result.specPath,
305
- context: {
306
- specName: result.specName,
307
- specVersion: result.specVersion,
308
- status: result.status
309
- }
310
- });
311
- if (!implOptions.allowPartial && result.status === "partial") {
312
- const missingImpls = result.implementations.filter((i) => !i.exists && i.type !== "test").map((i) => i.path);
313
- issues.push({
314
- ruleId: "impl-partial",
315
- severity: "warning",
316
- message: `Spec ${result.specName} has partial implementation: missing ${missingImpls.join(", ")}`,
317
- category: "implementation",
318
- file: result.specPath,
319
- context: {
320
- specName: result.specName,
321
- specVersion: result.specVersion,
322
- status: result.status,
323
- missingFiles: missingImpls
324
- }
325
- });
326
- }
327
- const missingTests = result.implementations.filter((i) => !i.exists && i.type === "test");
328
- if (missingTests.length > 0) issues.push({
329
- ruleId: "impl-missing-tests",
330
- severity: "note",
331
- message: `Spec ${result.specName} missing test files: ${missingTests.map((t) => t.path).join(", ")}`,
332
- category: "implementation",
333
- file: result.specPath,
334
- context: {
335
- specName: result.specName,
336
- missingTests: missingTests.map((t) => t.path)
337
- }
338
- });
339
- }
340
- return issues;
341
- }
342
- /**
343
- * Create a category summary from issues.
344
- */
345
- function createCategorySummary(category, issues, durationMs) {
346
- const categoryLabels = {
347
- structure: "Spec Structure Validation",
348
- integrity: "Contract Integrity Analysis",
349
- deps: "Dependency Analysis",
350
- doctor: "Installation Health",
351
- handlers: "Handler Implementation",
352
- tests: "Test Coverage",
353
- implementation: "Implementation Verification"
354
- };
355
- const errors = issues.filter((i) => i.severity === "error").length;
356
- const warnings = issues.filter((i) => i.severity === "warning").length;
357
- const notes = issues.filter((i) => i.severity === "note").length;
358
- return {
359
- category,
360
- label: categoryLabels[category],
361
- errors,
362
- warnings,
363
- notes,
364
- passed: errors === 0,
365
- durationMs
366
- };
367
- }
368
- /**
369
- * Get git information if available.
370
- */
371
- async function getGitInfo(fs) {
372
- try {
373
- const gitHeadPath = ".git/HEAD";
374
- if (!await fs.exists(gitHeadPath)) return {};
375
- const headContent = await fs.readFile(gitHeadPath);
376
- const refMatch = headContent.match(/^ref: (.+)$/m);
377
- if (refMatch) {
378
- const branch = refMatch[1]?.replace("refs/heads/", "");
379
- const refPath = `.git/${refMatch[1]}`;
380
- if (await fs.exists(refPath)) return {
381
- commitSha: (await fs.readFile(refPath)).trim(),
382
- branch
383
- };
384
- return { branch };
385
- }
386
- return { commitSha: headContent.trim() };
387
- } catch {
388
- return {};
389
- }
390
- }
391
-
392
- //#endregion
393
- export { runCIChecks };
1
+ import{validateImplementationFiles as e}from"../validate-implementation.js";import{analyzeDeps as t}from"../deps.js";import{loadWorkspaceConfig as n}from"../config.js";import{analyzeIntegrity as r}from"../integrity.js";import{runDoctor as i}from"../doctor/doctor-service.js";import{resolveAllImplementations as a}from"../implementation/resolver.js";import"../verification-cache/index.js";import{isFeatureFile as o,validateSpecStructure as s}from"@lssm/module.contractspec-workspace";async function c(e,t={}){let n=Date.now(),{fs:r,logger:i}=e,a=[],s=[],c=l(t);i.info(`Starting CI checks...`,{checks:c});let y=(await r.glob({pattern:t.pattern})).filter(e=>!o(e)&&!e.includes(`.test.`)&&!e.includes(`.spec.`));if(c.includes(`structure`)){let t=Date.now(),n=await u(e,y);a.push(...n),s.push(_(`structure`,n,Date.now()-t))}if(c.includes(`integrity`)){let n=Date.now(),r=await d(e,t);a.push(...r),s.push(_(`integrity`,r,Date.now()-n))}if(c.includes(`deps`)){let n=Date.now(),r=await f(e,t);a.push(...r),s.push(_(`deps`,r,Date.now()-n))}if(c.includes(`doctor`)){let n=Date.now(),r=await p(e,t);a.push(...r),s.push(_(`doctor`,r,Date.now()-n))}if(c.includes(`handlers`)||t.checkHandlers){let t=Date.now(),n=await m(e,y);a.push(...n),s.push(_(`handlers`,n,Date.now()-t))}if(c.includes(`tests`)||t.checkTests){let t=Date.now(),n=await h(e,y);a.push(...n),s.push(_(`tests`,n,Date.now()-t))}if(c.includes(`implementation`)){let n=Date.now(),r=await g(e,y,t);a.push(...r),s.push(_(`implementation`,r,Date.now()-n))}let b=a.filter(e=>e.severity===`error`).length,x=a.filter(e=>e.severity===`warning`).length,S=a.filter(e=>e.severity===`note`).length,C=t.failOnWarnings?b===0&&x===0:b===0,w=await v(r),T={success:C,totalErrors:b,totalWarnings:x,totalNotes:S,issues:a,categories:s,durationMs:Date.now()-n,timestamp:new Date().toISOString(),...w};return i.info(`CI checks complete`,{success:C,errors:b,warnings:x,durationMs:T.durationMs}),T}function l(e){let t=[`structure`,`integrity`,`deps`,`doctor`];return e.checkHandlers&&t.push(`handlers`),e.checkTests&&t.push(`tests`),e.implementation&&t.push(`implementation`),e.checks&&e.checks.length>0?e.checks:e.skip&&e.skip.length>0?t.filter(t=>!e.skip?.includes(t)):t}async function u(e,t){let{fs:n}=e,r=[];for(let e of t){let t=s(await n.readFile(e),n.basename(e));for(let n of t.errors)r.push({ruleId:`spec-structure-error`,severity:`error`,message:n,category:`structure`,file:e});for(let n of t.warnings)r.push({ruleId:`spec-structure-warning`,severity:`warning`,message:n,category:`structure`,file:e})}return r}async function d(e,t){let n=[],i=await r(e,{pattern:t.pattern,all:!0});for(let e of i.issues)n.push({ruleId:`integrity-${e.type}`,severity:e.severity===`error`?`error`:`warning`,message:e.message,category:`integrity`,file:e.file,context:{specName:e.specName,specType:e.specType,featureKey:e.featureKey,ref:e.ref}});return n}async function f(e,n){let r=[],i=await t(e,{pattern:n.pattern});for(let e of i.cycles)r.push({ruleId:`deps-circular`,severity:`error`,message:`Circular dependency detected: ${e.join(` → `)}`,category:`deps`,context:{cycle:e}});for(let e of i.missing)for(let t of e.missing)r.push({ruleId:`deps-missing`,severity:`error`,message:`Missing dependency: ${e.contract} requires ${t}`,category:`deps`,context:{contract:e.contract,missing:t}});return r}async function p(e,t){let n=[],r=await i(e,{workspaceRoot:t.workspaceRoot??process.cwd(),skipAi:!0,categories:[`cli`,`config`,`deps`,`workspace`]});for(let e of r.checks)e.status===`fail`?n.push({ruleId:`doctor-${e.category}-${e.name.toLowerCase().replace(/\s+/g,`-`)}`,severity:`error`,message:`${e.name}: ${e.message}`,category:`doctor`,context:{details:e.details}}):e.status===`warn`&&n.push({ruleId:`doctor-${e.category}-${e.name.toLowerCase().replace(/\s+/g,`-`)}`,severity:`warning`,message:`${e.name}: ${e.message}`,category:`doctor`,context:{details:e.details}});return n}async function m(t,r){let{fs:i}=t,a=[],o=await n(i);for(let t of r){if(!t.includes(`.contracts.`))continue;let n=await e(t,{fs:i},o,{checkHandlers:!0,outputDir:o.outputDir});for(let e of n.errors)a.push({ruleId:`handler-missing`,severity:`warning`,message:e,category:`handlers`,file:t});for(let e of n.warnings)a.push({ruleId:`handler-warning`,severity:`warning`,message:e,category:`handlers`,file:t})}return a}async function h(t,r){let{fs:i}=t,a=[],o=await n(i);for(let t of r){if(!t.includes(`.contracts.`))continue;let n=await e(t,{fs:i},o,{checkTests:!0,outputDir:o.outputDir});for(let e of n.errors)a.push({ruleId:`test-missing`,severity:`warning`,message:e,category:`tests`,file:t});for(let e of n.warnings)a.push({ruleId:`test-warning`,severity:`warning`,message:e,category:`tests`,file:t})}return a}async function g(e,t,r){let{fs:i}=e,o=[],s=await n(i),c=r.implementation??{},l=await a(t.filter(e=>e.includes(`.contracts.`)),{fs:i},s,{computeHashes:c.useCache??!0});for(let e of l){if(c.requireImplemented&&e.status===`missing`?o.push({ruleId:`impl-missing`,severity:`error`,message:`Spec ${e.specName} has no implementation`,category:`implementation`,file:e.specPath,context:{specName:e.specName,specVersion:e.specVersion,status:e.status}}):e.status===`missing`&&o.push({ruleId:`impl-missing`,severity:`warning`,message:`Spec ${e.specName} has no implementation`,category:`implementation`,file:e.specPath,context:{specName:e.specName,specVersion:e.specVersion,status:e.status}}),!c.allowPartial&&e.status===`partial`){let t=e.implementations.filter(e=>!e.exists&&e.type!==`test`).map(e=>e.path);o.push({ruleId:`impl-partial`,severity:`warning`,message:`Spec ${e.specName} has partial implementation: missing ${t.join(`, `)}`,category:`implementation`,file:e.specPath,context:{specName:e.specName,specVersion:e.specVersion,status:e.status,missingFiles:t}})}let t=e.implementations.filter(e=>!e.exists&&e.type===`test`);t.length>0&&o.push({ruleId:`impl-missing-tests`,severity:`note`,message:`Spec ${e.specName} missing test files: ${t.map(e=>e.path).join(`, `)}`,category:`implementation`,file:e.specPath,context:{specName:e.specName,missingTests:t.map(e=>e.path)}})}return o}function _(e,t,n){let r={structure:`Spec Structure Validation`,integrity:`Contract Integrity Analysis`,deps:`Dependency Analysis`,doctor:`Installation Health`,handlers:`Handler Implementation`,tests:`Test Coverage`,implementation:`Implementation Verification`},i=t.filter(e=>e.severity===`error`).length,a=t.filter(e=>e.severity===`warning`).length,o=t.filter(e=>e.severity===`note`).length;return{category:e,label:r[e],errors:i,warnings:a,notes:o,passed:i===0,durationMs:n}}async function v(e){try{let t=`.git/HEAD`;if(!await e.exists(t))return{};let n=await e.readFile(t),r=n.match(/^ref: (.+)$/m);if(r){let t=r[1]?.replace(`refs/heads/`,``),n=`.git/${r[1]}`;return await e.exists(n)?{commitSha:(await e.readFile(n)).trim(),branch:t}:{branch:t}}return{commitSha:n.trim()}}catch{return{}}}export{c as runCIChecks};
@@ -1,2 +1 @@
1
- import { ALL_CI_CHECK_CATEGORIES, CI_CHECK_CATEGORY_LABELS } from "./types.js";
2
- import { runCIChecks } from "./ci-check-service.js";
1
+ import{ALL_CI_CHECK_CATEGORIES as e,CI_CHECK_CATEGORY_LABELS as t}from"./types.js";import{runCIChecks as n}from"./ci-check-service.js";
@@ -1,28 +1 @@
1
- //#region src/services/ci-check/types.ts
2
- /**
3
- * All available CI check categories.
4
- */
5
- const ALL_CI_CHECK_CATEGORIES = [
6
- "structure",
7
- "integrity",
8
- "deps",
9
- "doctor",
10
- "handlers",
11
- "tests",
12
- "implementation"
13
- ];
14
- /**
15
- * Human-readable labels for CI check categories.
16
- */
17
- const CI_CHECK_CATEGORY_LABELS = {
18
- structure: "Spec Structure Validation",
19
- integrity: "Contract Integrity Analysis",
20
- deps: "Dependency Analysis",
21
- doctor: "Installation Health",
22
- handlers: "Handler Implementation",
23
- tests: "Test Coverage",
24
- implementation: "Implementation Verification"
25
- };
26
-
27
- //#endregion
28
- export { ALL_CI_CHECK_CATEGORIES, CI_CHECK_CATEGORY_LABELS };
1
+ const e=[`structure`,`integrity`,`deps`,`doctor`,`handlers`,`tests`,`implementation`],t={structure:`Spec Structure Validation`,integrity:`Contract Integrity Analysis`,deps:`Dependency Analysis`,doctor:`Installation Health`,handlers:`Handler Implementation`,tests:`Test Coverage`,implementation:`Implementation Verification`};export{e as ALL_CI_CHECK_CATEGORIES,t as CI_CHECK_CATEGORY_LABELS};
@@ -1,71 +1 @@
1
- //#region src/services/clean.ts
2
- async function cleanArtifacts(adapters, options = {}) {
3
- const { fs, logger } = adapters;
4
- const outputDir = (options.outputDir ?? "./src").replace(/\\/g, "/");
5
- const basePatterns = [
6
- "generated/**",
7
- "dist/**",
8
- ".turbo/**"
9
- ];
10
- const outputDirPatterns = [
11
- `${outputDir}/handlers/**/*.handler.ts`,
12
- `${outputDir}/handlers/**/*.handler.test.ts`,
13
- `${outputDir}/components/**/*.tsx`,
14
- `${outputDir}/components/**/*.test.tsx`,
15
- `${outputDir}/forms/**/*.form.tsx`,
16
- `${outputDir}/forms/**/*.form.test.tsx`,
17
- `${outputDir}/**/*.runner.ts`,
18
- `${outputDir}/**/*.renderer.tsx`
19
- ];
20
- const patterns = options.generatedOnly ? [...basePatterns, ...outputDirPatterns] : [
21
- ...basePatterns,
22
- "**/*.generated.ts",
23
- "**/*.generated.js",
24
- "**/*.generated.d.ts",
25
- ...outputDirPatterns
26
- ];
27
- const candidates = await fs.glob({
28
- patterns,
29
- ignore: ["node_modules/**"]
30
- });
31
- const removed = [];
32
- const skipped = [];
33
- for (const p of candidates) try {
34
- const st = await fs.stat(p);
35
- const ageDays = (Date.now() - st.mtime.getTime()) / (1e3 * 60 * 60 * 24);
36
- if (typeof options.olderThanDays === "number" && ageDays < options.olderThanDays) {
37
- skipped.push({
38
- path: p,
39
- reason: `younger_than_${options.olderThanDays}_days`
40
- });
41
- continue;
42
- }
43
- if (options.dryRun) logger.info("[dry-run] clean would remove", {
44
- path: p,
45
- size: st.size
46
- });
47
- else {
48
- await fs.remove(p);
49
- logger.info("clean.removed", {
50
- path: p,
51
- size: st.size
52
- });
53
- }
54
- removed.push({
55
- path: p,
56
- size: st.size
57
- });
58
- } catch (error) {
59
- skipped.push({
60
- path: p,
61
- reason: error instanceof Error ? error.message : String(error)
62
- });
63
- }
64
- return {
65
- removed,
66
- skipped
67
- };
68
- }
69
-
70
- //#endregion
71
- export { cleanArtifacts };
1
+ async function e(e,t={}){let{fs:n,logger:r}=e,i=(t.outputDir??`./src`).replace(/\\/g,`/`),a=[`generated/**`,`dist/**`,`.turbo/**`],o=[`${i}/handlers/**/*.handler.ts`,`${i}/handlers/**/*.handler.test.ts`,`${i}/components/**/*.tsx`,`${i}/components/**/*.test.tsx`,`${i}/forms/**/*.form.tsx`,`${i}/forms/**/*.form.test.tsx`,`${i}/**/*.runner.ts`,`${i}/**/*.renderer.tsx`],s=t.generatedOnly?[...a,...o]:[...a,`**/*.generated.ts`,`**/*.generated.js`,`**/*.generated.d.ts`,...o],c=await n.glob({patterns:s,ignore:[`node_modules/**`]}),l=[],u=[];for(let e of c)try{let i=await n.stat(e),a=(Date.now()-i.mtime.getTime())/(1e3*60*60*24);if(typeof t.olderThanDays==`number`&&a<t.olderThanDays){u.push({path:e,reason:`younger_than_${t.olderThanDays}_days`});continue}t.dryRun?r.info(`[dry-run] clean would remove`,{path:e,size:i.size}):(await n.remove(e),r.info(`clean.removed`,{path:e,size:i.size})),l.push({path:e,size:i.size})}catch(t){u.push({path:e,reason:t instanceof Error?t.message:String(t)})}return{removed:l,skipped:u}}export{e as cleanArtifacts};
@@ -1,76 +1 @@
1
- import { DEFAULT_WORKSPACE_CONFIG } from "../modules/contractspec-workspace/dist/types/generation-types.js";
2
- import * as z$1 from "zod";
3
-
4
- //#region src/services/config.ts
5
- /**
6
- * Workspace configuration service.
7
- */
8
- const ConfigSchema = z$1.object({
9
- aiProvider: z$1.enum([
10
- "claude",
11
- "openai",
12
- "ollama",
13
- "custom"
14
- ]).default("claude"),
15
- aiModel: z$1.string().optional(),
16
- agentMode: z$1.enum([
17
- "simple",
18
- "cursor",
19
- "claude-code",
20
- "openai-codex"
21
- ]).default("simple"),
22
- customEndpoint: z$1.string().url().nullable().optional(),
23
- customApiKey: z$1.string().nullable().optional(),
24
- outputDir: z$1.string().default("./src"),
25
- conventions: z$1.object({
26
- operations: z$1.string().default("interactions/commands|queries"),
27
- events: z$1.string().default("events"),
28
- presentations: z$1.string().default("presentations"),
29
- forms: z$1.string().default("forms")
30
- }),
31
- defaultOwners: z$1.array(z$1.string()).default([]),
32
- defaultTags: z$1.array(z$1.string()).default([])
33
- });
34
- /**
35
- * Load workspace configuration from .contractsrc.json.
36
- */
37
- async function loadWorkspaceConfig(fs, cwd) {
38
- const configPath = fs.join(cwd ?? ".", ".contractsrc.json");
39
- if (!await fs.exists(configPath)) return DEFAULT_WORKSPACE_CONFIG;
40
- try {
41
- const content = await fs.readFile(configPath);
42
- const parsed = JSON.parse(content);
43
- return ConfigSchema.parse(parsed);
44
- } catch {
45
- return DEFAULT_WORKSPACE_CONFIG;
46
- }
47
- }
48
- /**
49
- * Merge config with CLI options and environment variables.
50
- */
51
- function mergeWorkspaceConfig(config, options) {
52
- return {
53
- ...config,
54
- aiProvider: options.provider ?? process.env["CONTRACTSPEC_AI_PROVIDER"] ?? config.aiProvider,
55
- aiModel: options.model ?? process.env["CONTRACTSPEC_AI_MODEL"] ?? config.aiModel,
56
- agentMode: options.agentMode ?? process.env["CONTRACTSPEC_AGENT_MODE"] ?? config.agentMode,
57
- customEndpoint: options.endpoint ?? process.env["CONTRACTSPEC_LLM_ENDPOINT"] ?? config.customEndpoint ?? void 0,
58
- customApiKey: process.env["CONTRACTSPEC_LLM_API_KEY"] ?? config.customApiKey ?? void 0,
59
- outputDir: options.outputDir ?? config.outputDir
60
- };
61
- }
62
- /**
63
- * Get API key for the configured provider.
64
- */
65
- function getApiKey(provider) {
66
- switch (provider) {
67
- case "claude": return process.env["ANTHROPIC_API_KEY"];
68
- case "openai": return process.env["OPENAI_API_KEY"];
69
- case "custom": return process.env["CONTRACTSPEC_LLM_API_KEY"];
70
- case "ollama": return;
71
- default: return;
72
- }
73
- }
74
-
75
- //#endregion
76
- export { getApiKey, loadWorkspaceConfig, mergeWorkspaceConfig };
1
+ import{DEFAULT_WORKSPACE_CONFIG as e}from"@lssm/module.contractspec-workspace";import*as t from"zod";const n=t.object({aiProvider:t.enum([`claude`,`openai`,`ollama`,`custom`]).default(`claude`),aiModel:t.string().optional(),agentMode:t.enum([`simple`,`cursor`,`claude-code`,`openai-codex`]).default(`simple`),customEndpoint:t.string().url().nullable().optional(),customApiKey:t.string().nullable().optional(),outputDir:t.string().default(`./src`),conventions:t.object({operations:t.string().default(`interactions/commands|queries`),events:t.string().default(`events`),presentations:t.string().default(`presentations`),forms:t.string().default(`forms`)}),defaultOwners:t.array(t.string()).default([]),defaultTags:t.array(t.string()).default([])});async function r(t,r){let i=t.join(r??`.`,`.contractsrc.json`);if(!await t.exists(i))return e;try{let e=await t.readFile(i),r=JSON.parse(e);return n.parse(r)}catch{return e}}function i(e,t){return{...e,aiProvider:t.provider??process.env.CONTRACTSPEC_AI_PROVIDER??e.aiProvider,aiModel:t.model??process.env.CONTRACTSPEC_AI_MODEL??e.aiModel,agentMode:t.agentMode??process.env.CONTRACTSPEC_AGENT_MODE??e.agentMode,customEndpoint:t.endpoint??process.env.CONTRACTSPEC_LLM_ENDPOINT??e.customEndpoint??void 0,customApiKey:process.env.CONTRACTSPEC_LLM_API_KEY??e.customApiKey??void 0,outputDir:t.outputDir??e.outputDir}}function a(e){switch(e){case`claude`:return process.env.ANTHROPIC_API_KEY;case`openai`:return process.env.OPENAI_API_KEY;case`custom`:return process.env.CONTRACTSPEC_LLM_API_KEY;case`ollama`:return;default:return}}export{a as getApiKey,r as loadWorkspaceConfig,i as mergeWorkspaceConfig};
@@ -1,62 +1 @@
1
- import { addContractNode, buildReverseEdges, createContractGraph, detectCycles, findMissingDependencies, toDot } from "../modules/contractspec-workspace/dist/analysis/deps/graph.js";
2
- import { parseImportedSpecNames } from "../modules/contractspec-workspace/dist/analysis/deps/parse-imports.js";
3
-
4
- //#region src/services/deps.ts
5
- /**
6
- * Dependency analysis service.
7
- */
8
- /**
9
- * Analyze contract dependencies.
10
- */
11
- async function analyzeDeps(adapters, options = {}) {
12
- const { fs } = adapters;
13
- const files = await fs.glob({ pattern: options.pattern });
14
- const graph = createContractGraph();
15
- for (const file of files) {
16
- const content = await fs.readFile(file);
17
- const relativePath = fs.relative(".", file);
18
- const nameMatch = content.match(/name:\s*['"]([^'"]+)['"]/);
19
- addContractNode(graph, (nameMatch?.[1] ? nameMatch[1] : fs.basename(file).replace(/\.[jt]s$/, "").replace(/\.(contracts|event|presentation|workflow|data-view|migration|telemetry|experiment|app-config|integration|knowledge)$/, "")) || "unknown", relativePath, parseImportedSpecNames(content, file));
20
- }
21
- buildReverseEdges(graph);
22
- const cycles = detectCycles(graph);
23
- const missing = findMissingDependencies(graph);
24
- return {
25
- graph,
26
- total: graph.size,
27
- cycles,
28
- missing
29
- };
30
- }
31
- /**
32
- * Get contract node by name.
33
- */
34
- function getContractNode(graph, name) {
35
- return graph.get(name);
36
- }
37
- /**
38
- * Export graph as DOT format.
39
- */
40
- function exportGraphAsDot(graph) {
41
- return toDot(graph);
42
- }
43
- /**
44
- * Get graph statistics.
45
- */
46
- function getGraphStats(graph) {
47
- const all = Array.from(graph.values());
48
- const withDeps = all.filter((c) => c.dependencies.length > 0);
49
- const withoutDeps = all.filter((c) => c.dependencies.length === 0);
50
- const used = all.filter((c) => c.dependents.length > 0);
51
- const unused = all.filter((c) => c.dependents.length === 0);
52
- return {
53
- total: graph.size,
54
- withDeps: withDeps.length,
55
- withoutDeps: withoutDeps.length,
56
- used: used.length,
57
- unused: unused.length
58
- };
59
- }
60
-
61
- //#endregion
62
- export { analyzeDeps, exportGraphAsDot, getContractNode, getGraphStats };
1
+ import{addContractNode as e,buildReverseEdges as t,createContractGraph as n,detectCycles as r,findMissingDependencies as i,parseImportedSpecNames as a,toDot as o}from"@lssm/module.contractspec-workspace";async function s(o,s={}){let{fs:c}=o,l=await c.glob({pattern:s.pattern}),u=n();for(let t of l){let n=await c.readFile(t),r=c.relative(`.`,t),i=n.match(/name:\s*['"]([^'"]+)['"]/);e(u,(i?.[1]?i[1]:c.basename(t).replace(/\.[jt]s$/,``).replace(/\.(contracts|event|presentation|workflow|data-view|migration|telemetry|experiment|app-config|integration|knowledge)$/,``))||`unknown`,r,a(n,t))}t(u);let d=r(u),f=i(u);return{graph:u,total:u.size,cycles:d,missing:f}}function c(e,t){return e.get(t)}function l(e){return o(e)}function u(e){let t=Array.from(e.values()),n=t.filter(e=>e.dependencies.length>0),r=t.filter(e=>e.dependencies.length===0),i=t.filter(e=>e.dependents.length>0),a=t.filter(e=>e.dependents.length===0);return{total:e.size,withDeps:n.length,withoutDeps:r.length,used:i.length,unused:a.length}}export{s as analyzeDeps,l as exportGraphAsDot,c as getContractNode,u as getGraphStats};