@contractspec/bundle.workspace 1.44.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (425) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +79 -0
  3. package/dist/_virtual/rolldown_runtime.js +36 -0
  4. package/dist/adapters/ai.d.ts +12 -0
  5. package/dist/adapters/ai.d.ts.map +1 -0
  6. package/dist/adapters/ai.js +83 -0
  7. package/dist/adapters/ai.js.map +1 -0
  8. package/dist/adapters/factory.d.ts +29 -0
  9. package/dist/adapters/factory.d.ts.map +1 -0
  10. package/dist/adapters/factory.js +37 -0
  11. package/dist/adapters/factory.js.map +1 -0
  12. package/dist/adapters/fs.d.ts +11 -0
  13. package/dist/adapters/fs.d.ts.map +1 -0
  14. package/dist/adapters/fs.js +131 -0
  15. package/dist/adapters/fs.js.map +1 -0
  16. package/dist/adapters/git.d.ts +11 -0
  17. package/dist/adapters/git.d.ts.map +1 -0
  18. package/dist/adapters/git.js +55 -0
  19. package/dist/adapters/git.js.map +1 -0
  20. package/dist/adapters/index.d.ts +7 -0
  21. package/dist/adapters/index.js +7 -0
  22. package/dist/adapters/logger.d.ts +18 -0
  23. package/dist/adapters/logger.d.ts.map +1 -0
  24. package/dist/adapters/logger.js +81 -0
  25. package/dist/adapters/logger.js.map +1 -0
  26. package/dist/adapters/watcher.d.ts +11 -0
  27. package/dist/adapters/watcher.d.ts.map +1 -0
  28. package/dist/adapters/watcher.js +74 -0
  29. package/dist/adapters/watcher.js.map +1 -0
  30. package/dist/adapters/workspace.d.ts +148 -0
  31. package/dist/adapters/workspace.d.ts.map +1 -0
  32. package/dist/adapters/workspace.js +275 -0
  33. package/dist/adapters/workspace.js.map +1 -0
  34. package/dist/ai/agents/claude-code-agent.d.ts +22 -0
  35. package/dist/ai/agents/claude-code-agent.d.ts.map +1 -0
  36. package/dist/ai/agents/claude-code-agent.js +182 -0
  37. package/dist/ai/agents/claude-code-agent.js.map +1 -0
  38. package/dist/ai/agents/cursor-agent.d.ts +68 -0
  39. package/dist/ai/agents/cursor-agent.d.ts.map +1 -0
  40. package/dist/ai/agents/cursor-agent.js +436 -0
  41. package/dist/ai/agents/cursor-agent.js.map +1 -0
  42. package/dist/ai/agents/index.js +5 -0
  43. package/dist/ai/agents/openai-codex-agent.d.ts +22 -0
  44. package/dist/ai/agents/openai-codex-agent.d.ts.map +1 -0
  45. package/dist/ai/agents/openai-codex-agent.js +167 -0
  46. package/dist/ai/agents/openai-codex-agent.js.map +1 -0
  47. package/dist/ai/agents/orchestrator.d.ts +50 -0
  48. package/dist/ai/agents/orchestrator.d.ts.map +1 -0
  49. package/dist/ai/agents/orchestrator.js +143 -0
  50. package/dist/ai/agents/orchestrator.js.map +1 -0
  51. package/dist/ai/agents/simple-agent.d.ts +17 -0
  52. package/dist/ai/agents/simple-agent.d.ts.map +1 -0
  53. package/dist/ai/agents/simple-agent.js +92 -0
  54. package/dist/ai/agents/simple-agent.js.map +1 -0
  55. package/dist/ai/agents/types.d.ts +36 -0
  56. package/dist/ai/agents/types.d.ts.map +1 -0
  57. package/dist/ai/client.d.ts +83 -0
  58. package/dist/ai/client.d.ts.map +1 -0
  59. package/dist/ai/client.js +163 -0
  60. package/dist/ai/client.js.map +1 -0
  61. package/dist/ai/index.d.ts +17 -0
  62. package/dist/ai/index.d.ts.map +1 -0
  63. package/dist/ai/index.js +28 -0
  64. package/dist/ai/index.js.map +1 -0
  65. package/dist/ai/prompts/code-generation.d.ts +26 -0
  66. package/dist/ai/prompts/code-generation.d.ts.map +1 -0
  67. package/dist/ai/prompts/code-generation.js +143 -0
  68. package/dist/ai/prompts/code-generation.js.map +1 -0
  69. package/dist/ai/prompts/index.d.ts +10 -0
  70. package/dist/ai/prompts/index.d.ts.map +1 -0
  71. package/dist/ai/prompts/index.js +13 -0
  72. package/dist/ai/prompts/index.js.map +1 -0
  73. package/dist/ai/prompts/spec-creation.d.ts +29 -0
  74. package/dist/ai/prompts/spec-creation.d.ts.map +1 -0
  75. package/dist/ai/prompts/spec-creation.js +111 -0
  76. package/dist/ai/prompts/spec-creation.js.map +1 -0
  77. package/dist/ai/providers.d.ts +29 -0
  78. package/dist/ai/providers.d.ts.map +1 -0
  79. package/dist/ai/providers.js +39 -0
  80. package/dist/ai/providers.js.map +1 -0
  81. package/dist/formatters/index.d.ts +11 -0
  82. package/dist/formatters/index.d.ts.map +1 -0
  83. package/dist/formatters/index.js +19 -0
  84. package/dist/formatters/index.js.map +1 -0
  85. package/dist/formatters/json.d.ts +89 -0
  86. package/dist/formatters/json.d.ts.map +1 -0
  87. package/dist/formatters/json.js +72 -0
  88. package/dist/formatters/json.js.map +1 -0
  89. package/dist/formatters/sarif.d.ts +101 -0
  90. package/dist/formatters/sarif.d.ts.map +1 -0
  91. package/dist/formatters/sarif.js +163 -0
  92. package/dist/formatters/sarif.js.map +1 -0
  93. package/dist/formatters/text.d.ts +35 -0
  94. package/dist/formatters/text.d.ts.map +1 -0
  95. package/dist/formatters/text.js +209 -0
  96. package/dist/formatters/text.js.map +1 -0
  97. package/dist/index.d.ts +82 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +204 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/ports/ai.d.ts +59 -0
  102. package/dist/ports/ai.d.ts.map +1 -0
  103. package/dist/ports/fs.d.ts +81 -0
  104. package/dist/ports/fs.d.ts.map +1 -0
  105. package/dist/ports/git.d.ts +33 -0
  106. package/dist/ports/git.d.ts.map +1 -0
  107. package/dist/ports/index.d.ts +5 -0
  108. package/dist/ports/logger.d.ts +88 -0
  109. package/dist/ports/logger.d.ts.map +1 -0
  110. package/dist/ports/watcher.d.ts +52 -0
  111. package/dist/ports/watcher.d.ts.map +1 -0
  112. package/dist/services/agent-guide/adapters/claude-code.d.ts +35 -0
  113. package/dist/services/agent-guide/adapters/claude-code.d.ts.map +1 -0
  114. package/dist/services/agent-guide/adapters/claude-code.js +144 -0
  115. package/dist/services/agent-guide/adapters/claude-code.js.map +1 -0
  116. package/dist/services/agent-guide/adapters/cursor-cli.d.ts +39 -0
  117. package/dist/services/agent-guide/adapters/cursor-cli.d.ts.map +1 -0
  118. package/dist/services/agent-guide/adapters/cursor-cli.js +135 -0
  119. package/dist/services/agent-guide/adapters/cursor-cli.js.map +1 -0
  120. package/dist/services/agent-guide/adapters/generic-mcp.d.ts +53 -0
  121. package/dist/services/agent-guide/adapters/generic-mcp.d.ts.map +1 -0
  122. package/dist/services/agent-guide/adapters/generic-mcp.js +159 -0
  123. package/dist/services/agent-guide/adapters/generic-mcp.js.map +1 -0
  124. package/dist/services/agent-guide/adapters/index.d.ts +23 -0
  125. package/dist/services/agent-guide/adapters/index.d.ts.map +1 -0
  126. package/dist/services/agent-guide/adapters/index.js +31 -0
  127. package/dist/services/agent-guide/adapters/index.js.map +1 -0
  128. package/dist/services/agent-guide/agent-guide-service.d.ts +56 -0
  129. package/dist/services/agent-guide/agent-guide-service.d.ts.map +1 -0
  130. package/dist/services/agent-guide/agent-guide-service.js +147 -0
  131. package/dist/services/agent-guide/agent-guide-service.js.map +1 -0
  132. package/dist/services/agent-guide/index.d.ts +6 -0
  133. package/dist/services/agent-guide/index.js +5 -0
  134. package/dist/services/agent-guide/types.d.ts +58 -0
  135. package/dist/services/agent-guide/types.d.ts.map +1 -0
  136. package/dist/services/build.d.ts +59 -0
  137. package/dist/services/build.d.ts.map +1 -0
  138. package/dist/services/build.js +140 -0
  139. package/dist/services/build.js.map +1 -0
  140. package/dist/services/ci-check/ci-check-service.d.ts +16 -0
  141. package/dist/services/ci-check/ci-check-service.d.ts.map +1 -0
  142. package/dist/services/ci-check/ci-check-service.js +392 -0
  143. package/dist/services/ci-check/ci-check-service.js.map +1 -0
  144. package/dist/services/ci-check/index.d.ts +2 -0
  145. package/dist/services/ci-check/index.js +2 -0
  146. package/dist/services/ci-check/types.d.ts +143 -0
  147. package/dist/services/ci-check/types.d.ts.map +1 -0
  148. package/dist/services/ci-check/types.js +29 -0
  149. package/dist/services/ci-check/types.js.map +1 -0
  150. package/dist/services/clean.d.ts +41 -0
  151. package/dist/services/clean.d.ts.map +1 -0
  152. package/dist/services/clean.js +72 -0
  153. package/dist/services/clean.js.map +1 -0
  154. package/dist/services/config.d.ts +26 -0
  155. package/dist/services/config.d.ts.map +1 -0
  156. package/dist/services/config.js +77 -0
  157. package/dist/services/config.js.map +1 -0
  158. package/dist/services/deps.d.ts +53 -0
  159. package/dist/services/deps.d.ts.map +1 -0
  160. package/dist/services/deps.js +62 -0
  161. package/dist/services/deps.js.map +1 -0
  162. package/dist/services/diff.d.ts +34 -0
  163. package/dist/services/diff.d.ts.map +1 -0
  164. package/dist/services/diff.js +34 -0
  165. package/dist/services/diff.js.map +1 -0
  166. package/dist/services/doctor/checks/ai.js +119 -0
  167. package/dist/services/doctor/checks/ai.js.map +1 -0
  168. package/dist/services/doctor/checks/cli.js +147 -0
  169. package/dist/services/doctor/checks/cli.js.map +1 -0
  170. package/dist/services/doctor/checks/config.js +171 -0
  171. package/dist/services/doctor/checks/config.js.map +1 -0
  172. package/dist/services/doctor/checks/deps.js +247 -0
  173. package/dist/services/doctor/checks/deps.js.map +1 -0
  174. package/dist/services/doctor/checks/index.js +6 -0
  175. package/dist/services/doctor/checks/mcp.js +145 -0
  176. package/dist/services/doctor/checks/mcp.js.map +1 -0
  177. package/dist/services/doctor/checks/workspace.js +244 -0
  178. package/dist/services/doctor/checks/workspace.js.map +1 -0
  179. package/dist/services/doctor/doctor-service.d.ts +24 -0
  180. package/dist/services/doctor/doctor-service.d.ts.map +1 -0
  181. package/dist/services/doctor/doctor-service.js +116 -0
  182. package/dist/services/doctor/doctor-service.js.map +1 -0
  183. package/dist/services/doctor/index.d.ts +2 -0
  184. package/dist/services/doctor/index.js +2 -0
  185. package/dist/services/doctor/types.d.ts +118 -0
  186. package/dist/services/doctor/types.d.ts.map +1 -0
  187. package/dist/services/doctor/types.js +27 -0
  188. package/dist/services/doctor/types.js.map +1 -0
  189. package/dist/services/impact/formatters.d.ts +27 -0
  190. package/dist/services/impact/formatters.d.ts.map +1 -0
  191. package/dist/services/impact/formatters.js +111 -0
  192. package/dist/services/impact/formatters.js.map +1 -0
  193. package/dist/services/impact/impact-detection-service.d.ts +22 -0
  194. package/dist/services/impact/impact-detection-service.d.ts.map +1 -0
  195. package/dist/services/impact/impact-detection-service.js +96 -0
  196. package/dist/services/impact/impact-detection-service.js.map +1 -0
  197. package/dist/services/impact/index.d.ts +11 -0
  198. package/dist/services/impact/index.d.ts.map +1 -0
  199. package/dist/services/impact/index.js +16 -0
  200. package/dist/services/impact/index.js.map +1 -0
  201. package/dist/services/impact/types.d.ts +58 -0
  202. package/dist/services/impact/types.d.ts.map +1 -0
  203. package/dist/services/implementation/discovery.d.ts +30 -0
  204. package/dist/services/implementation/discovery.d.ts.map +1 -0
  205. package/dist/services/implementation/discovery.js +144 -0
  206. package/dist/services/implementation/discovery.js.map +1 -0
  207. package/dist/services/implementation/index.d.ts +3 -0
  208. package/dist/services/implementation/index.js +2 -0
  209. package/dist/services/implementation/resolver.d.ts +44 -0
  210. package/dist/services/implementation/resolver.d.ts.map +1 -0
  211. package/dist/services/implementation/resolver.js +224 -0
  212. package/dist/services/implementation/resolver.js.map +1 -0
  213. package/dist/services/implementation/types.d.ts +79 -0
  214. package/dist/services/implementation/types.d.ts.map +1 -0
  215. package/dist/services/index.d.ts +60 -0
  216. package/dist/services/index.js +57 -0
  217. package/dist/services/integrity-diagram.d.ts +36 -0
  218. package/dist/services/integrity-diagram.d.ts.map +1 -0
  219. package/dist/services/integrity-diagram.js +275 -0
  220. package/dist/services/integrity-diagram.js.map +1 -0
  221. package/dist/services/integrity.d.ts +134 -0
  222. package/dist/services/integrity.d.ts.map +1 -0
  223. package/dist/services/integrity.js +272 -0
  224. package/dist/services/integrity.js.map +1 -0
  225. package/dist/services/list.d.ts +31 -0
  226. package/dist/services/list.d.ts.map +1 -0
  227. package/dist/services/list.js +36 -0
  228. package/dist/services/list.js.map +1 -0
  229. package/dist/services/openapi/export-service.d.ts +53 -0
  230. package/dist/services/openapi/export-service.d.ts.map +1 -0
  231. package/dist/services/openapi/export-service.js +50 -0
  232. package/dist/services/openapi/export-service.js.map +1 -0
  233. package/dist/services/openapi/import-service.d.ts +17 -0
  234. package/dist/services/openapi/import-service.d.ts.map +1 -0
  235. package/dist/services/openapi/import-service.js +74 -0
  236. package/dist/services/openapi/import-service.js.map +1 -0
  237. package/dist/services/openapi/index.d.ts +5 -0
  238. package/dist/services/openapi/index.js +4 -0
  239. package/dist/services/openapi/sync-service.d.ts +17 -0
  240. package/dist/services/openapi/sync-service.d.ts.map +1 -0
  241. package/dist/services/openapi/sync-service.js +120 -0
  242. package/dist/services/openapi/sync-service.js.map +1 -0
  243. package/dist/services/openapi/types.d.ts +162 -0
  244. package/dist/services/openapi/types.d.ts.map +1 -0
  245. package/dist/services/openapi/validate-service.d.ts +16 -0
  246. package/dist/services/openapi/validate-service.d.ts.map +1 -0
  247. package/dist/services/openapi/validate-service.js +130 -0
  248. package/dist/services/openapi/validate-service.js.map +1 -0
  249. package/dist/services/quickstart/dependencies.d.ts +31 -0
  250. package/dist/services/quickstart/dependencies.d.ts.map +1 -0
  251. package/dist/services/quickstart/dependencies.js +57 -0
  252. package/dist/services/quickstart/dependencies.js.map +1 -0
  253. package/dist/services/quickstart/index.js +2 -0
  254. package/dist/services/quickstart/quickstart-service.d.ts +20 -0
  255. package/dist/services/quickstart/quickstart-service.d.ts.map +1 -0
  256. package/dist/services/quickstart/quickstart-service.js +196 -0
  257. package/dist/services/quickstart/quickstart-service.js.map +1 -0
  258. package/dist/services/quickstart/types.d.ts +81 -0
  259. package/dist/services/quickstart/types.d.ts.map +1 -0
  260. package/dist/services/regenerator.d.ts +18 -0
  261. package/dist/services/regenerator.d.ts.map +1 -0
  262. package/dist/services/regenerator.js +23 -0
  263. package/dist/services/regenerator.js.map +1 -0
  264. package/dist/services/registry.d.ts +53 -0
  265. package/dist/services/registry.d.ts.map +1 -0
  266. package/dist/services/registry.js +74 -0
  267. package/dist/services/registry.js.map +1 -0
  268. package/dist/services/setup/config-generators.d.ts +42 -0
  269. package/dist/services/setup/config-generators.d.ts.map +1 -0
  270. package/dist/services/setup/config-generators.js +238 -0
  271. package/dist/services/setup/config-generators.js.map +1 -0
  272. package/dist/services/setup/file-merger.d.ts +27 -0
  273. package/dist/services/setup/file-merger.d.ts.map +1 -0
  274. package/dist/services/setup/file-merger.js +61 -0
  275. package/dist/services/setup/file-merger.js.map +1 -0
  276. package/dist/services/setup/index.js +4 -0
  277. package/dist/services/setup/setup-service.d.ts +12 -0
  278. package/dist/services/setup/setup-service.d.ts.map +1 -0
  279. package/dist/services/setup/setup-service.js +96 -0
  280. package/dist/services/setup/setup-service.js.map +1 -0
  281. package/dist/services/setup/targets/agents-md.js +47 -0
  282. package/dist/services/setup/targets/agents-md.js.map +1 -0
  283. package/dist/services/setup/targets/cli-config.js +60 -0
  284. package/dist/services/setup/targets/cli-config.js.map +1 -0
  285. package/dist/services/setup/targets/cursor-rules.js +48 -0
  286. package/dist/services/setup/targets/cursor-rules.js.map +1 -0
  287. package/dist/services/setup/targets/mcp-claude.js +60 -0
  288. package/dist/services/setup/targets/mcp-claude.js.map +1 -0
  289. package/dist/services/setup/targets/mcp-cursor.js +59 -0
  290. package/dist/services/setup/targets/mcp-cursor.js.map +1 -0
  291. package/dist/services/setup/targets/vscode-settings.js +63 -0
  292. package/dist/services/setup/targets/vscode-settings.js.map +1 -0
  293. package/dist/services/setup/types.d.ts +85 -0
  294. package/dist/services/setup/types.d.ts.map +1 -0
  295. package/dist/services/setup/types.js +27 -0
  296. package/dist/services/setup/types.js.map +1 -0
  297. package/dist/services/sync.d.ts +41 -0
  298. package/dist/services/sync.d.ts.map +1 -0
  299. package/dist/services/sync.js +63 -0
  300. package/dist/services/sync.js.map +1 -0
  301. package/dist/services/test.d.ts +15 -0
  302. package/dist/services/test.d.ts.map +1 -0
  303. package/dist/services/test.js +30 -0
  304. package/dist/services/test.js.map +1 -0
  305. package/dist/services/validate-implementation.d.ts +32 -0
  306. package/dist/services/validate-implementation.d.ts.map +1 -0
  307. package/dist/services/validate-implementation.js +64 -0
  308. package/dist/services/validate-implementation.js.map +1 -0
  309. package/dist/services/validate.d.ts +41 -0
  310. package/dist/services/validate.d.ts.map +1 -0
  311. package/dist/services/validate.js +48 -0
  312. package/dist/services/validate.js.map +1 -0
  313. package/dist/services/verification-cache/adapters/filesystem.d.ts +46 -0
  314. package/dist/services/verification-cache/adapters/filesystem.d.ts.map +1 -0
  315. package/dist/services/verification-cache/adapters/filesystem.js +120 -0
  316. package/dist/services/verification-cache/adapters/filesystem.js.map +1 -0
  317. package/dist/services/verification-cache/adapters/in-memory.d.ts +27 -0
  318. package/dist/services/verification-cache/adapters/in-memory.d.ts.map +1 -0
  319. package/dist/services/verification-cache/adapters/in-memory.js +46 -0
  320. package/dist/services/verification-cache/adapters/in-memory.js.map +1 -0
  321. package/dist/services/verification-cache/adapters/index.d.ts +3 -0
  322. package/dist/services/verification-cache/adapters/index.js +3 -0
  323. package/dist/services/verification-cache/adapters/workspace-state.d.ts +49 -0
  324. package/dist/services/verification-cache/adapters/workspace-state.d.ts.map +1 -0
  325. package/dist/services/verification-cache/adapters/workspace-state.js +91 -0
  326. package/dist/services/verification-cache/adapters/workspace-state.js.map +1 -0
  327. package/dist/services/verification-cache/cache-service.d.ts +70 -0
  328. package/dist/services/verification-cache/cache-service.d.ts.map +1 -0
  329. package/dist/services/verification-cache/cache-service.js +256 -0
  330. package/dist/services/verification-cache/cache-service.js.map +1 -0
  331. package/dist/services/verification-cache/index.d.ts +6 -0
  332. package/dist/services/verification-cache/index.js +6 -0
  333. package/dist/services/verification-cache/types.d.ts +124 -0
  334. package/dist/services/verification-cache/types.d.ts.map +1 -0
  335. package/dist/services/verification-cache/types.js +16 -0
  336. package/dist/services/verification-cache/types.js.map +1 -0
  337. package/dist/services/verify/ai-verifier.d.ts +25 -0
  338. package/dist/services/verify/ai-verifier.d.ts.map +1 -0
  339. package/dist/services/verify/ai-verifier.js +403 -0
  340. package/dist/services/verify/ai-verifier.js.map +1 -0
  341. package/dist/services/verify/behavior-verifier.d.ts +12 -0
  342. package/dist/services/verify/behavior-verifier.d.ts.map +1 -0
  343. package/dist/services/verify/behavior-verifier.js +186 -0
  344. package/dist/services/verify/behavior-verifier.js.map +1 -0
  345. package/dist/services/verify/index.d.ts +5 -0
  346. package/dist/services/verify/index.js +4 -0
  347. package/dist/services/verify/structure-verifier.d.ts +12 -0
  348. package/dist/services/verify/structure-verifier.d.ts.map +1 -0
  349. package/dist/services/verify/structure-verifier.js +196 -0
  350. package/dist/services/verify/structure-verifier.js.map +1 -0
  351. package/dist/services/verify/types.d.ts +137 -0
  352. package/dist/services/verify/types.d.ts.map +1 -0
  353. package/dist/services/verify/verify-service.d.ts +60 -0
  354. package/dist/services/verify/verify-service.d.ts.map +1 -0
  355. package/dist/services/verify/verify-service.js +204 -0
  356. package/dist/services/verify/verify-service.js.map +1 -0
  357. package/dist/services/watch.d.ts +25 -0
  358. package/dist/services/watch.d.ts.map +1 -0
  359. package/dist/services/watch.js +32 -0
  360. package/dist/services/watch.js.map +1 -0
  361. package/dist/services/workspace-info.d.ts +62 -0
  362. package/dist/services/workspace-info.d.ts.map +1 -0
  363. package/dist/services/workspace-info.js +103 -0
  364. package/dist/services/workspace-info.js.map +1 -0
  365. package/dist/templates/app-config.template.d.ts +7 -0
  366. package/dist/templates/app-config.template.d.ts.map +1 -0
  367. package/dist/templates/app-config.template.js +107 -0
  368. package/dist/templates/app-config.template.js.map +1 -0
  369. package/dist/templates/data-view.template.d.ts +7 -0
  370. package/dist/templates/data-view.template.d.ts.map +1 -0
  371. package/dist/templates/data-view.template.js +70 -0
  372. package/dist/templates/data-view.template.js.map +1 -0
  373. package/dist/templates/event.template.d.ts +11 -0
  374. package/dist/templates/event.template.d.ts.map +1 -0
  375. package/dist/templates/event.template.js +40 -0
  376. package/dist/templates/event.template.js.map +1 -0
  377. package/dist/templates/experiment.template.d.ts +7 -0
  378. package/dist/templates/experiment.template.d.ts.map +1 -0
  379. package/dist/templates/experiment.template.js +89 -0
  380. package/dist/templates/experiment.template.js.map +1 -0
  381. package/dist/templates/handler.template.d.ts +16 -0
  382. package/dist/templates/handler.template.d.ts.map +1 -0
  383. package/dist/templates/handler.template.js +100 -0
  384. package/dist/templates/handler.template.js.map +1 -0
  385. package/dist/templates/index.d.ts +21 -0
  386. package/dist/templates/index.d.ts.map +1 -0
  387. package/dist/templates/index.js +37 -0
  388. package/dist/templates/index.js.map +1 -0
  389. package/dist/templates/integration.template.d.ts +7 -0
  390. package/dist/templates/integration.template.d.ts.map +1 -0
  391. package/dist/templates/integration.template.js +160 -0
  392. package/dist/templates/integration.template.js.map +1 -0
  393. package/dist/templates/knowledge.template.d.ts +7 -0
  394. package/dist/templates/knowledge.template.d.ts.map +1 -0
  395. package/dist/templates/knowledge.template.js +75 -0
  396. package/dist/templates/knowledge.template.js.map +1 -0
  397. package/dist/templates/migration.template.d.ts +7 -0
  398. package/dist/templates/migration.template.d.ts.map +1 -0
  399. package/dist/templates/migration.template.js +62 -0
  400. package/dist/templates/migration.template.js.map +1 -0
  401. package/dist/templates/operation.template.d.ts +11 -0
  402. package/dist/templates/operation.template.d.ts.map +1 -0
  403. package/dist/templates/operation.template.js +105 -0
  404. package/dist/templates/operation.template.js.map +1 -0
  405. package/dist/templates/presentation.template.d.ts +11 -0
  406. package/dist/templates/presentation.template.d.ts.map +1 -0
  407. package/dist/templates/presentation.template.js +80 -0
  408. package/dist/templates/presentation.template.js.map +1 -0
  409. package/dist/templates/telemetry.template.d.ts +7 -0
  410. package/dist/templates/telemetry.template.d.ts.map +1 -0
  411. package/dist/templates/telemetry.template.js +91 -0
  412. package/dist/templates/telemetry.template.js.map +1 -0
  413. package/dist/templates/workflow-runner.template.d.ts +16 -0
  414. package/dist/templates/workflow-runner.template.d.ts.map +1 -0
  415. package/dist/templates/workflow-runner.template.js +50 -0
  416. package/dist/templates/workflow-runner.template.js.map +1 -0
  417. package/dist/templates/workflow.template.d.ts +7 -0
  418. package/dist/templates/workflow.template.d.ts.map +1 -0
  419. package/dist/templates/workflow.template.js +69 -0
  420. package/dist/templates/workflow.template.js.map +1 -0
  421. package/dist/types/config.d.ts +34 -0
  422. package/dist/types/config.d.ts.map +1 -0
  423. package/dist/types.d.ts +324 -0
  424. package/dist/types.d.ts.map +1 -0
  425. package/package.json +68 -0
@@ -0,0 +1,403 @@
1
+ import { generateVerificationPrompt } from "@contractspec/lib.contracts/llm";
2
+
3
+ //#region src/services/verify/ai-verifier.ts
4
+ /**
5
+ * Parse AI response to structured result.
6
+ */
7
+ function parseAIResponse(response) {
8
+ const jsonMatch = response.match(/```json\n?([\s\S]*?)\n?```/);
9
+ if (jsonMatch?.[1]) try {
10
+ const parsed = JSON.parse(jsonMatch[1]);
11
+ return {
12
+ compliant: parsed.passed ?? false,
13
+ confidence: (parsed.score ?? 0) / 100,
14
+ findings: (parsed.issues ?? []).map((issue) => ({
15
+ category: String(issue.category ?? "semantic"),
16
+ severity: String(issue.severity ?? "warning"),
17
+ message: String(issue.message ?? ""),
18
+ location: issue.location ? String(issue.location) : void 0,
19
+ suggestion: issue.suggestion ? String(issue.suggestion) : void 0
20
+ })),
21
+ rawResponse: response
22
+ };
23
+ } catch {}
24
+ const findings = [];
25
+ const lines = response.split("\n");
26
+ let currentSeverity = "info";
27
+ for (const line of lines) {
28
+ const lineLower = line.toLowerCase();
29
+ if (lineLower.includes("error") || lineLower.includes("critical")) currentSeverity = "error";
30
+ else if (lineLower.includes("warning") || lineLower.includes("should")) currentSeverity = "warning";
31
+ else if (lineLower.includes("info") || lineLower.includes("note")) currentSeverity = "info";
32
+ const bulletMatch = line.match(/^[-*•]\s*(.+)$/);
33
+ const numberedMatch = line.match(/^\d+\.\s*(.+)$/);
34
+ if (bulletMatch || numberedMatch) {
35
+ const content = bulletMatch?.[1] ?? numberedMatch?.[1] ?? "";
36
+ if (content.length > 10) findings.push({
37
+ category: "semantic",
38
+ severity: currentSeverity,
39
+ message: content
40
+ });
41
+ }
42
+ }
43
+ const hasErrors = findings.some((f) => f.severity === "error");
44
+ return {
45
+ compliant: !hasErrors,
46
+ confidence: hasErrors ? .3 : findings.length === 0 ? .9 : .7,
47
+ findings,
48
+ rawResponse: response
49
+ };
50
+ }
51
+ /**
52
+ * Call AI provider for verification.
53
+ * This is a placeholder - actual implementation would use AI SDK.
54
+ */
55
+ async function callAI(prompt, config) {
56
+ if (!config.aiApiKey) return `\`\`\`json
57
+ {
58
+ "passed": true,
59
+ "score": 50,
60
+ "compliance": {
61
+ "inputTypes": { "match": true, "issues": [] },
62
+ "outputTypes": { "match": true, "issues": [] },
63
+ "errorHandling": { "coverage": "unknown", "missing": [] },
64
+ "eventEmission": { "correct": true, "issues": [] },
65
+ "policyCompliance": { "auth": true, "rateLimit": true, "pii": true }
66
+ },
67
+ "scenarios": [],
68
+ "issues": [
69
+ { "severity": "info", "category": "semantic", "message": "AI verification not available - configure AI API key for full analysis" }
70
+ ],
71
+ "summary": "AI verification skipped - no API key configured. Structure and behavior checks have been performed."
72
+ }
73
+ \`\`\``;
74
+ try {
75
+ const provider = config.aiProvider ?? "anthropic";
76
+ if (provider === "anthropic") {
77
+ const { anthropic } = await import("@ai-sdk/anthropic");
78
+ const { generateText } = await import("ai");
79
+ return (await generateText({
80
+ model: anthropic("claude-3-5-sonnet-20241022"),
81
+ prompt,
82
+ system: "You are an expert code reviewer analyzing implementation compliance with specifications. Respond with structured JSON."
83
+ })).text;
84
+ } else if (provider === "openai") {
85
+ const { openai } = await import("@ai-sdk/openai");
86
+ const { generateText } = await import("ai");
87
+ return (await generateText({
88
+ model: openai("gpt-4o"),
89
+ prompt,
90
+ system: "You are an expert code reviewer analyzing implementation compliance with specifications. Respond with structured JSON."
91
+ })).text;
92
+ }
93
+ throw new Error(`Unknown AI provider: ${provider}`);
94
+ } catch (error) {
95
+ return `\`\`\`json
96
+ {
97
+ "passed": false,
98
+ "score": 0,
99
+ "issues": [
100
+ { "severity": "error", "category": "semantic", "message": "AI verification failed: ${error instanceof Error ? error.message : "Unknown error"}" }
101
+ ],
102
+ "summary": "AI verification encountered an error"
103
+ }
104
+ \`\`\``;
105
+ }
106
+ }
107
+ /**
108
+ * Run AI-powered verification.
109
+ */
110
+ async function verifyWithAI(input, config = {}) {
111
+ const { spec, implementationCode, implementationPath } = input;
112
+ const startTime = Date.now();
113
+ const result = parseAIResponse(await callAI(generateVerificationPrompt(spec, implementationCode).taskPrompt, config));
114
+ const issues = result.findings.map((f) => ({
115
+ severity: f.severity,
116
+ category: "semantic",
117
+ message: f.message,
118
+ location: f.location ? { file: f.location } : implementationPath ? { file: implementationPath } : void 0,
119
+ suggestion: f.suggestion
120
+ }));
121
+ const score = Math.round(result.confidence * 100);
122
+ const passed = result.compliant;
123
+ return {
124
+ tier: "ai_review",
125
+ passed,
126
+ score,
127
+ issues,
128
+ suggestions: result.findings.filter((f) => f.suggestion).map((f) => f.suggestion),
129
+ coverage: {
130
+ scenarios: {
131
+ total: 0,
132
+ covered: 0
133
+ },
134
+ errors: {
135
+ total: 0,
136
+ handled: 0
137
+ },
138
+ fields: {
139
+ total: 1,
140
+ implemented: passed ? 1 : 0
141
+ }
142
+ },
143
+ meta: {
144
+ specName: spec.meta.key,
145
+ specVersion: spec.meta.version,
146
+ implementationPath: implementationPath ?? "unknown",
147
+ verifiedAt: (/* @__PURE__ */ new Date()).toISOString(),
148
+ duration: Date.now() - startTime
149
+ }
150
+ };
151
+ }
152
+ /**
153
+ * Create a simpler AI review without calling the API.
154
+ * Used as fallback or for quick checks.
155
+ */
156
+ function createQuickAIReview(input) {
157
+ const { spec, implementationCode, implementationPath } = input;
158
+ const startTime = Date.now();
159
+ const issues = [];
160
+ if (implementationCode.includes("console.log")) issues.push({
161
+ severity: "warning",
162
+ category: "semantic",
163
+ message: "Console.log statements found - consider using proper logging",
164
+ suggestion: "Use a structured logger instead of console.log"
165
+ });
166
+ if (implementationCode.includes("// TODO") || implementationCode.includes("// FIXME")) issues.push({
167
+ severity: "info",
168
+ category: "semantic",
169
+ message: "TODO/FIXME comments found - implementation may be incomplete",
170
+ suggestion: "Address TODO items before finalizing implementation"
171
+ });
172
+ if (spec.policy.auth !== "anonymous" && !implementationCode.includes("auth")) issues.push({
173
+ severity: "warning",
174
+ category: "semantic",
175
+ message: `Spec requires ${spec.policy.auth} auth but no auth check found`,
176
+ suggestion: "Add authentication check at the handler entry point"
177
+ });
178
+ const score = issues.filter((i) => i.severity === "error").length === 0 ? 80 : 40;
179
+ const passed = issues.filter((i) => i.severity === "error").length === 0;
180
+ return {
181
+ tier: "ai_review",
182
+ passed,
183
+ score,
184
+ issues,
185
+ suggestions: issues.filter((i) => i.suggestion).map((i) => i.suggestion),
186
+ coverage: {
187
+ scenarios: {
188
+ total: 0,
189
+ covered: 0
190
+ },
191
+ errors: {
192
+ total: 0,
193
+ handled: 0
194
+ },
195
+ fields: {
196
+ total: 1,
197
+ implemented: passed ? 1 : 0
198
+ }
199
+ },
200
+ meta: {
201
+ specName: spec.meta.key,
202
+ specVersion: spec.meta.version,
203
+ implementationPath: implementationPath ?? "unknown",
204
+ verifiedAt: (/* @__PURE__ */ new Date()).toISOString(),
205
+ duration: Date.now() - startTime
206
+ }
207
+ };
208
+ }
209
+ /**
210
+ * Generate a prompt for semantic field verification.
211
+ */
212
+ function generateSemanticFieldPrompt(specFields, implCode) {
213
+ return `You are analyzing a code implementation against its specification.
214
+
215
+ ## Spec Schema Fields
216
+ ${specFields}
217
+
218
+ ## Implementation Code
219
+ \`\`\`typescript
220
+ ${implCode}
221
+ \`\`\`
222
+
223
+ ## Task
224
+ Analyze the implementation to verify it correctly implements the spec schema fields.
225
+
226
+ For each field in the spec:
227
+ 1. Find the corresponding field/property in the implementation
228
+ 2. Determine if the naming matches (exact, compatible synonym, or mismatch)
229
+ 3. Check if the types are compatible
230
+ 4. Identify any missing fields
231
+
232
+ Respond with JSON in this format:
233
+ \`\`\`json
234
+ {
235
+ "fieldMappings": [
236
+ {
237
+ "specField": "nickname",
238
+ "specType": "string",
239
+ "implementationField": "username",
240
+ "implementationType": "string",
241
+ "match": "compatible",
242
+ "aiConfidence": 0.85,
243
+ "suggestion": "Consider renaming 'username' to 'nickname' for exact spec compliance"
244
+ }
245
+ ],
246
+ "intentAlignment": {
247
+ "score": 85,
248
+ "issues": ["Field naming differs from spec"],
249
+ "suggestions": ["Rename fields to match spec exactly for better maintainability"]
250
+ },
251
+ "semanticIssues": []
252
+ }
253
+ \`\`\`
254
+
255
+ Match types:
256
+ - "exact": Field name and type match exactly
257
+ - "compatible": Semantically similar (e.g., "email" vs "emailAddress")
258
+ - "mismatch": Different meaning despite similar naming
259
+ - "missing": Spec field not found in implementation
260
+ `;
261
+ }
262
+ /**
263
+ * Extract field definitions from spec schema.
264
+ */
265
+ function extractSpecFields(spec) {
266
+ const fields = [];
267
+ /**
268
+ * Helper to safely extract fields from a schema.
269
+ */
270
+ const extractFromSchema = (schema, direction) => {
271
+ try {
272
+ const shapeFn = schema?._def?.shape;
273
+ if (shapeFn && typeof shapeFn === "function") {
274
+ const shapeObj = shapeFn();
275
+ for (const [key, value] of Object.entries(shapeObj)) {
276
+ const typeName = value?._def?.typeName ?? "unknown";
277
+ fields.push(`- ${key}: ${String(typeName).replace("Zod", "").toLowerCase()} (${direction})`);
278
+ }
279
+ }
280
+ } catch {
281
+ fields.push(`- [unable to extract ${direction} fields]`);
282
+ }
283
+ };
284
+ if (spec.io.input) extractFromSchema(spec.io.input, "input");
285
+ if (spec.io.output && !("resourceRef" in spec.io.output)) extractFromSchema(spec.io.output, "output");
286
+ if (fields.length === 0) return "- [no schema fields could be extracted]";
287
+ return fields.join("\n");
288
+ }
289
+ /**
290
+ * Parse semantic verification response from AI.
291
+ */
292
+ function parseSemanticResponse(response) {
293
+ const jsonMatch = response.match(/```json\n?([\s\S]*?)\n?```/);
294
+ if (jsonMatch?.[1]) try {
295
+ const parsed = JSON.parse(jsonMatch[1]);
296
+ return {
297
+ fieldMappings: (parsed.fieldMappings ?? []).map((m) => ({
298
+ specField: String(m.specField ?? ""),
299
+ specType: String(m.specType ?? "unknown"),
300
+ implementationField: m.implementationField ? String(m.implementationField) : void 0,
301
+ implementationType: m.implementationType ? String(m.implementationType) : void 0,
302
+ match: m.match ?? "missing",
303
+ aiConfidence: typeof m.aiConfidence === "number" ? m.aiConfidence : .5,
304
+ suggestion: m.suggestion ? String(m.suggestion) : void 0
305
+ })),
306
+ intentAlignment: {
307
+ score: typeof parsed.intentAlignment?.score === "number" ? parsed.intentAlignment.score : 50,
308
+ issues: Array.isArray(parsed.intentAlignment?.issues) ? parsed.intentAlignment.issues : [],
309
+ suggestions: Array.isArray(parsed.intentAlignment?.suggestions) ? parsed.intentAlignment.suggestions : []
310
+ },
311
+ semanticIssues: (parsed.semanticIssues ?? []).map((i) => ({
312
+ category: String(i.category ?? "semantic"),
313
+ severity: i.severity ?? "warning",
314
+ message: String(i.message ?? ""),
315
+ suggestion: i.suggestion ? String(i.suggestion) : void 0
316
+ })),
317
+ rawResponse: response
318
+ };
319
+ } catch {}
320
+ return {
321
+ fieldMappings: [],
322
+ intentAlignment: {
323
+ score: 50,
324
+ issues: ["Unable to parse AI response for semantic analysis"],
325
+ suggestions: []
326
+ },
327
+ semanticIssues: [],
328
+ rawResponse: response
329
+ };
330
+ }
331
+ /**
332
+ * Run semantic field-level verification using AI.
333
+ */
334
+ async function verifySemanticFields(input, config = {}) {
335
+ const { spec, implementationCode } = input;
336
+ return parseSemanticResponse(await callAI(generateSemanticFieldPrompt(extractSpecFields(spec), implementationCode), config));
337
+ }
338
+ /**
339
+ * Run enhanced AI verification with semantic field analysis.
340
+ */
341
+ async function verifyWithAIEnhanced(input, config = {}) {
342
+ const { spec: _spec, implementationCode: _implementationCode, implementationPath: _implementationPath } = input;
343
+ const startTime = Date.now();
344
+ const baseReport = await verifyWithAI(input, config);
345
+ let semanticResult;
346
+ if (config.aiApiKey) try {
347
+ semanticResult = await verifySemanticFields(input, config);
348
+ } catch {}
349
+ if (semanticResult) {
350
+ const semanticIssues = [];
351
+ for (const mapping of semanticResult.fieldMappings) if (mapping.match === "missing") semanticIssues.push({
352
+ severity: "error",
353
+ category: "semantic",
354
+ message: `Missing field: '${mapping.specField}' (${mapping.specType}) not found in implementation`,
355
+ suggestion: mapping.suggestion ?? `Add field '${mapping.specField}' to implementation`
356
+ });
357
+ else if (mapping.match === "mismatch") semanticIssues.push({
358
+ severity: "warning",
359
+ category: "semantic",
360
+ message: `Field mismatch: '${mapping.specField}' has incorrect implementation as '${mapping.implementationField}'`,
361
+ suggestion: mapping.suggestion
362
+ });
363
+ else if (mapping.match === "compatible" && mapping.aiConfidence < .8) semanticIssues.push({
364
+ severity: "info",
365
+ category: "semantic",
366
+ message: `Field naming: '${mapping.specField}' implemented as '${mapping.implementationField}' (compatible but not exact)`,
367
+ suggestion: mapping.suggestion
368
+ });
369
+ for (const issue of semanticResult.intentAlignment.issues) semanticIssues.push({
370
+ severity: "warning",
371
+ category: "semantic",
372
+ message: issue
373
+ });
374
+ for (const issue of semanticResult.semanticIssues) semanticIssues.push({
375
+ severity: issue.severity,
376
+ category: "semantic",
377
+ message: issue.message,
378
+ suggestion: issue.suggestion
379
+ });
380
+ baseReport.issues = [...baseReport.issues, ...semanticIssues];
381
+ const totalFields = semanticResult.fieldMappings.length;
382
+ const implementedFields = semanticResult.fieldMappings.filter((m) => m.match === "exact" || m.match === "compatible").length;
383
+ if (totalFields > 0) {
384
+ const fieldScore = Math.round(implementedFields / totalFields * 100);
385
+ baseReport.score = Math.round((baseReport.score + fieldScore) / 2);
386
+ baseReport.coverage.fields = {
387
+ total: totalFields,
388
+ implemented: implementedFields
389
+ };
390
+ }
391
+ if (semanticIssues.some((i) => i.severity === "error")) baseReport.passed = false;
392
+ baseReport.suggestions = [...baseReport.suggestions, ...semanticResult.intentAlignment.suggestions];
393
+ }
394
+ baseReport.meta = {
395
+ ...baseReport.meta,
396
+ duration: Date.now() - startTime
397
+ };
398
+ return baseReport;
399
+ }
400
+
401
+ //#endregion
402
+ export { createQuickAIReview, verifySemanticFields, verifyWithAI, verifyWithAIEnhanced };
403
+ //# sourceMappingURL=ai-verifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-verifier.js","names":["findings: AIReviewResult['findings']","currentSeverity: 'error' | 'warning' | 'info'","issues: VerificationIssue[]","fields: string[]","semanticResult: SemanticVerificationResult | undefined","semanticIssues: VerificationIssue[]"],"sources":["../../../src/services/verify/ai-verifier.ts"],"sourcesContent":["/**\n * Tier 3: AI-Powered Verification\n *\n * Uses an LLM to semantically analyze the implementation against\n * the specification for deeper compliance checking.\n */\n\nimport type { AnyOperationSpec } from '@contractspec/lib.contracts';\nimport type {\n VerificationIssue,\n VerificationReport,\n} from '@contractspec/lib.contracts/llm';\nimport { generateVerificationPrompt } from '@contractspec/lib.contracts/llm';\nimport type {\n AIReviewResult,\n FieldMapping,\n SemanticVerificationResult,\n VerifyConfig,\n VerifyInput,\n} from './types';\n\n/**\n * Parse AI response to structured result.\n */\nfunction parseAIResponse(response: string): AIReviewResult {\n // Try to extract JSON from the response\n const jsonMatch = response.match(/```json\\n?([\\s\\S]*?)\\n?```/);\n if (jsonMatch?.[1]) {\n try {\n const parsed = JSON.parse(jsonMatch[1]);\n return {\n compliant: parsed.passed ?? false,\n confidence: (parsed.score ?? 0) / 100,\n findings: (parsed.issues ?? []).map(\n (issue: Record<string, unknown>) => ({\n category: String(issue.category ?? 'semantic'),\n severity: String(issue.severity ?? 'warning') as\n | 'error'\n | 'warning'\n | 'info',\n message: String(issue.message ?? ''),\n location: issue.location ? String(issue.location) : undefined,\n suggestion: issue.suggestion ? String(issue.suggestion) : undefined,\n })\n ),\n rawResponse: response,\n };\n } catch {\n // JSON parse failed, fall through to text parsing\n }\n }\n\n // Fallback: parse text response\n const findings: AIReviewResult['findings'] = [];\n\n // Look for issue patterns\n const lines = response.split('\\n');\n let currentSeverity: 'error' | 'warning' | 'info' = 'info';\n\n for (const line of lines) {\n const lineLower = line.toLowerCase();\n\n // Detect severity changes\n if (lineLower.includes('error') || lineLower.includes('critical')) {\n currentSeverity = 'error';\n } else if (lineLower.includes('warning') || lineLower.includes('should')) {\n currentSeverity = 'warning';\n } else if (lineLower.includes('info') || lineLower.includes('note')) {\n currentSeverity = 'info';\n }\n\n // Look for bullet points or numbered items\n const bulletMatch = line.match(/^[-*•]\\s*(.+)$/);\n const numberedMatch = line.match(/^\\d+\\.\\s*(.+)$/);\n\n if (bulletMatch || numberedMatch) {\n const content = bulletMatch?.[1] ?? numberedMatch?.[1] ?? '';\n if (content.length > 10) {\n findings.push({\n category: 'semantic',\n severity: currentSeverity,\n message: content,\n });\n }\n }\n }\n\n // Determine overall compliance\n const hasErrors = findings.some((f) => f.severity === 'error');\n const compliant = !hasErrors;\n const confidence = hasErrors ? 0.3 : findings.length === 0 ? 0.9 : 0.7;\n\n return {\n compliant,\n confidence,\n findings,\n rawResponse: response,\n };\n}\n\n/**\n * Call AI provider for verification.\n * This is a placeholder - actual implementation would use AI SDK.\n */\nasync function callAI(prompt: string, config: VerifyConfig): Promise<string> {\n // Check if we have an API key configured\n if (!config.aiApiKey) {\n // Return a placeholder response indicating AI is not configured\n return `\\`\\`\\`json\n{\n \"passed\": true,\n \"score\": 50,\n \"compliance\": {\n \"inputTypes\": { \"match\": true, \"issues\": [] },\n \"outputTypes\": { \"match\": true, \"issues\": [] },\n \"errorHandling\": { \"coverage\": \"unknown\", \"missing\": [] },\n \"eventEmission\": { \"correct\": true, \"issues\": [] },\n \"policyCompliance\": { \"auth\": true, \"rateLimit\": true, \"pii\": true }\n },\n \"scenarios\": [],\n \"issues\": [\n { \"severity\": \"info\", \"category\": \"semantic\", \"message\": \"AI verification not available - configure AI API key for full analysis\" }\n ],\n \"summary\": \"AI verification skipped - no API key configured. Structure and behavior checks have been performed.\"\n}\n\\`\\`\\``;\n }\n\n // In a real implementation, this would call the AI provider\n // For now, we'll use a dynamic import to avoid hard dependency\n try {\n const provider = config.aiProvider ?? 'anthropic';\n\n if (provider === 'anthropic') {\n // Dynamic import to avoid hard dependency\n const { anthropic } = await import('@ai-sdk/anthropic');\n const { generateText } = await import('ai');\n\n const result = await generateText({\n model: anthropic('claude-3-5-sonnet-20241022'),\n prompt,\n system:\n 'You are an expert code reviewer analyzing implementation compliance with specifications. Respond with structured JSON.',\n });\n\n return result.text;\n } else if (provider === 'openai') {\n const { openai } = await import('@ai-sdk/openai');\n const { generateText } = await import('ai');\n\n const result = await generateText({\n model: openai('gpt-4o'),\n prompt,\n system:\n 'You are an expert code reviewer analyzing implementation compliance with specifications. Respond with structured JSON.',\n });\n\n return result.text;\n }\n\n throw new Error(`Unknown AI provider: ${provider}`);\n } catch (error) {\n // Return error as structured response\n return `\\`\\`\\`json\n{\n \"passed\": false,\n \"score\": 0,\n \"issues\": [\n { \"severity\": \"error\", \"category\": \"semantic\", \"message\": \"AI verification failed: ${error instanceof Error ? error.message : 'Unknown error'}\" }\n ],\n \"summary\": \"AI verification encountered an error\"\n}\n\\`\\`\\``;\n }\n}\n\n/**\n * Run AI-powered verification.\n */\nexport async function verifyWithAI(\n input: VerifyInput,\n config: VerifyConfig = {}\n): Promise<VerificationReport> {\n const { spec, implementationCode, implementationPath } = input;\n const startTime = Date.now();\n\n // Generate the verification prompt\n const prompt = generateVerificationPrompt(spec, implementationCode);\n\n // Call AI\n const aiResponse = await callAI(prompt.taskPrompt, config);\n\n // Parse response\n const result = parseAIResponse(aiResponse);\n\n // Convert to verification issues\n const issues: VerificationIssue[] = result.findings.map((f) => ({\n severity: f.severity,\n category: 'semantic' as const,\n message: f.message,\n location: f.location\n ? { file: f.location }\n : implementationPath\n ? { file: implementationPath }\n : undefined,\n suggestion: f.suggestion,\n }));\n\n const score = Math.round(result.confidence * 100);\n const passed = result.compliant;\n\n // Generate suggestions from findings\n const suggestions = result.findings\n .filter((f) => f.suggestion)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n .map((f) => f.suggestion!);\n\n return {\n tier: 'ai_review',\n passed,\n score,\n issues,\n suggestions,\n coverage: {\n scenarios: { total: 0, covered: 0 }, // AI doesn't track these explicitly\n errors: { total: 0, handled: 0 },\n fields: { total: 1, implemented: passed ? 1 : 0 },\n },\n meta: {\n specName: spec.meta.key,\n specVersion: spec.meta.version,\n implementationPath: implementationPath ?? 'unknown',\n verifiedAt: new Date().toISOString(),\n duration: Date.now() - startTime,\n },\n };\n}\n\n/**\n * Create a simpler AI review without calling the API.\n * Used as fallback or for quick checks.\n */\nexport function createQuickAIReview(input: VerifyInput): VerificationReport {\n const { spec, implementationCode, implementationPath } = input;\n const startTime = Date.now();\n\n // Simple heuristic checks that approximate AI review\n const issues: VerificationIssue[] = [];\n\n // Check for common anti-patterns\n if (implementationCode.includes('console.log')) {\n issues.push({\n severity: 'warning',\n category: 'semantic',\n message: 'Console.log statements found - consider using proper logging',\n suggestion: 'Use a structured logger instead of console.log',\n });\n }\n\n if (\n implementationCode.includes('// TODO') ||\n implementationCode.includes('// FIXME')\n ) {\n issues.push({\n severity: 'info',\n category: 'semantic',\n message: 'TODO/FIXME comments found - implementation may be incomplete',\n suggestion: 'Address TODO items before finalizing implementation',\n });\n }\n\n // Check for hardcoded values that should come from spec\n if (\n spec.policy.auth !== 'anonymous' &&\n !implementationCode.includes('auth')\n ) {\n issues.push({\n severity: 'warning',\n category: 'semantic',\n message: `Spec requires ${spec.policy.auth} auth but no auth check found`,\n suggestion: 'Add authentication check at the handler entry point',\n });\n }\n\n const score =\n issues.filter((i) => i.severity === 'error').length === 0 ? 80 : 40;\n const passed = issues.filter((i) => i.severity === 'error').length === 0;\n\n return {\n tier: 'ai_review',\n passed,\n score,\n issues,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n suggestions: issues.filter((i) => i.suggestion).map((i) => i.suggestion!),\n coverage: {\n scenarios: { total: 0, covered: 0 },\n errors: { total: 0, handled: 0 },\n fields: { total: 1, implemented: passed ? 1 : 0 },\n },\n meta: {\n specName: spec.meta.key,\n specVersion: spec.meta.version,\n implementationPath: implementationPath ?? 'unknown',\n verifiedAt: new Date().toISOString(),\n duration: Date.now() - startTime,\n },\n };\n}\n\n/**\n * Generate a prompt for semantic field verification.\n */\nfunction generateSemanticFieldPrompt(\n specFields: string,\n implCode: string\n): string {\n return `You are analyzing a code implementation against its specification.\n\n## Spec Schema Fields\n${specFields}\n\n## Implementation Code\n\\`\\`\\`typescript\n${implCode}\n\\`\\`\\`\n\n## Task\nAnalyze the implementation to verify it correctly implements the spec schema fields.\n\nFor each field in the spec:\n1. Find the corresponding field/property in the implementation\n2. Determine if the naming matches (exact, compatible synonym, or mismatch)\n3. Check if the types are compatible\n4. Identify any missing fields\n\nRespond with JSON in this format:\n\\`\\`\\`json\n{\n \"fieldMappings\": [\n {\n \"specField\": \"nickname\",\n \"specType\": \"string\",\n \"implementationField\": \"username\",\n \"implementationType\": \"string\",\n \"match\": \"compatible\",\n \"aiConfidence\": 0.85,\n \"suggestion\": \"Consider renaming 'username' to 'nickname' for exact spec compliance\"\n }\n ],\n \"intentAlignment\": {\n \"score\": 85,\n \"issues\": [\"Field naming differs from spec\"],\n \"suggestions\": [\"Rename fields to match spec exactly for better maintainability\"]\n },\n \"semanticIssues\": []\n}\n\\`\\`\\`\n\nMatch types:\n- \"exact\": Field name and type match exactly\n- \"compatible\": Semantically similar (e.g., \"email\" vs \"emailAddress\")\n- \"mismatch\": Different meaning despite similar naming\n- \"missing\": Spec field not found in implementation\n`;\n}\n\n/**\n * Extract field definitions from spec schema.\n */\nfunction extractSpecFields(spec: AnyOperationSpec): string {\n const fields: string[] = [];\n\n /**\n * Helper to safely extract fields from a schema.\n */\n const extractFromSchema = (\n schema: unknown,\n direction: 'input' | 'output'\n ) => {\n try {\n // Cast to any to access internal Zod structure\n const schemaAny = schema as {\n _def?: { shape?: () => Record<string, unknown> };\n };\n const shapeFn = schemaAny?._def?.shape;\n\n if (shapeFn && typeof shapeFn === 'function') {\n const shapeObj = shapeFn();\n for (const [key, value] of Object.entries(shapeObj)) {\n const valueAny = value as { _def?: { typeName?: string } };\n const typeName = valueAny?._def?.typeName ?? 'unknown';\n fields.push(\n `- ${key}: ${String(typeName).replace('Zod', '').toLowerCase()} (${direction})`\n );\n }\n }\n } catch {\n fields.push(`- [unable to extract ${direction} fields]`);\n }\n };\n\n // Try to extract from input schema\n if (spec.io.input) {\n extractFromSchema(spec.io.input, 'input');\n }\n\n // Try to extract from output schema (skip if it's a resource ref)\n if (spec.io.output && !('resourceRef' in spec.io.output)) {\n extractFromSchema(spec.io.output, 'output');\n }\n\n if (fields.length === 0) {\n return '- [no schema fields could be extracted]';\n }\n\n return fields.join('\\n');\n}\n\n/**\n * Parse semantic verification response from AI.\n */\nfunction parseSemanticResponse(response: string): SemanticVerificationResult {\n // Try to extract JSON\n const jsonMatch = response.match(/```json\\n?([\\s\\S]*?)\\n?```/);\n if (jsonMatch?.[1]) {\n try {\n const parsed = JSON.parse(jsonMatch[1]);\n return {\n fieldMappings: (parsed.fieldMappings ?? []).map(\n (m: Record<string, unknown>) => ({\n specField: String(m.specField ?? ''),\n specType: String(m.specType ?? 'unknown'),\n implementationField: m.implementationField\n ? String(m.implementationField)\n : undefined,\n implementationType: m.implementationType\n ? String(m.implementationType)\n : undefined,\n match: (m.match ?? 'missing') as FieldMapping['match'],\n aiConfidence:\n typeof m.aiConfidence === 'number' ? m.aiConfidence : 0.5,\n suggestion: m.suggestion ? String(m.suggestion) : undefined,\n })\n ),\n intentAlignment: {\n score:\n typeof parsed.intentAlignment?.score === 'number'\n ? parsed.intentAlignment.score\n : 50,\n issues: Array.isArray(parsed.intentAlignment?.issues)\n ? parsed.intentAlignment.issues\n : [],\n suggestions: Array.isArray(parsed.intentAlignment?.suggestions)\n ? parsed.intentAlignment.suggestions\n : [],\n },\n semanticIssues: (parsed.semanticIssues ?? []).map(\n (i: Record<string, unknown>) => ({\n category: String(i.category ?? 'semantic'),\n severity: (i.severity ?? 'warning') as 'error' | 'warning' | 'info',\n message: String(i.message ?? ''),\n suggestion: i.suggestion ? String(i.suggestion) : undefined,\n })\n ),\n rawResponse: response,\n };\n } catch {\n // Fall through to default\n }\n }\n\n // Default result if parsing fails\n return {\n fieldMappings: [],\n intentAlignment: {\n score: 50,\n issues: ['Unable to parse AI response for semantic analysis'],\n suggestions: [],\n },\n semanticIssues: [],\n rawResponse: response,\n };\n}\n\n/**\n * Run semantic field-level verification using AI.\n */\nexport async function verifySemanticFields(\n input: VerifyInput,\n config: VerifyConfig = {}\n): Promise<SemanticVerificationResult> {\n const { spec, implementationCode } = input;\n\n // Extract spec fields\n const specFields = extractSpecFields(spec);\n\n // Generate prompt\n const prompt = generateSemanticFieldPrompt(specFields, implementationCode);\n\n // Call AI\n const aiResponse = await callAI(prompt, config);\n\n // Parse response\n return parseSemanticResponse(aiResponse);\n}\n\n/**\n * Run enhanced AI verification with semantic field analysis.\n */\nexport async function verifyWithAIEnhanced(\n input: VerifyInput,\n config: VerifyConfig = {}\n): Promise<VerificationReport> {\n const {\n spec: _spec,\n implementationCode: _implementationCode,\n implementationPath: _implementationPath,\n } = input;\n const startTime = Date.now();\n\n // Run standard AI verification\n const baseReport = await verifyWithAI(input, config);\n\n // Run semantic field verification if AI is available\n let semanticResult: SemanticVerificationResult | undefined;\n if (config.aiApiKey) {\n try {\n semanticResult = await verifySemanticFields(input, config);\n } catch {\n // Semantic verification failed, continue with base report\n }\n }\n\n // Merge semantic issues into base report\n if (semanticResult) {\n const semanticIssues: VerificationIssue[] = [];\n\n // Add field mapping issues\n for (const mapping of semanticResult.fieldMappings) {\n if (mapping.match === 'missing') {\n semanticIssues.push({\n severity: 'error',\n category: 'semantic',\n message: `Missing field: '${mapping.specField}' (${mapping.specType}) not found in implementation`,\n suggestion:\n mapping.suggestion ??\n `Add field '${mapping.specField}' to implementation`,\n });\n } else if (mapping.match === 'mismatch') {\n semanticIssues.push({\n severity: 'warning',\n category: 'semantic',\n message: `Field mismatch: '${mapping.specField}' has incorrect implementation as '${mapping.implementationField}'`,\n suggestion: mapping.suggestion,\n });\n } else if (mapping.match === 'compatible' && mapping.aiConfidence < 0.8) {\n semanticIssues.push({\n severity: 'info',\n category: 'semantic',\n message: `Field naming: '${mapping.specField}' implemented as '${mapping.implementationField}' (compatible but not exact)`,\n suggestion: mapping.suggestion,\n });\n }\n }\n\n // Add intent alignment issues\n for (const issue of semanticResult.intentAlignment.issues) {\n semanticIssues.push({\n severity: 'warning',\n category: 'semantic',\n message: issue,\n });\n }\n\n // Add other semantic issues\n for (const issue of semanticResult.semanticIssues) {\n semanticIssues.push({\n severity: issue.severity,\n category: 'semantic',\n message: issue.message,\n suggestion: issue.suggestion,\n });\n }\n\n // Merge issues\n baseReport.issues = [...baseReport.issues, ...semanticIssues];\n\n // Update score based on field coverage\n const totalFields = semanticResult.fieldMappings.length;\n const implementedFields = semanticResult.fieldMappings.filter(\n (m) => m.match === 'exact' || m.match === 'compatible'\n ).length;\n\n if (totalFields > 0) {\n const fieldScore = Math.round((implementedFields / totalFields) * 100);\n baseReport.score = Math.round((baseReport.score + fieldScore) / 2);\n baseReport.coverage.fields = {\n total: totalFields,\n implemented: implementedFields,\n };\n }\n\n // Update pass status\n const hasFieldErrors = semanticIssues.some((i) => i.severity === 'error');\n if (hasFieldErrors) {\n baseReport.passed = false;\n }\n\n // Add semantic suggestions\n baseReport.suggestions = [\n ...baseReport.suggestions,\n ...semanticResult.intentAlignment.suggestions,\n ];\n }\n\n // Update duration\n baseReport.meta = {\n ...baseReport.meta,\n duration: Date.now() - startTime,\n };\n\n return baseReport;\n}\n"],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { VerifyInput } from "./types.js";
2
+ import { VerificationReport } from "@contractspec/lib.contracts/llm";
3
+
4
+ //#region src/services/verify/behavior-verifier.d.ts
5
+
6
+ /**
7
+ * Run all behavior checks and produce a verification report.
8
+ */
9
+ declare function verifyBehavior(input: VerifyInput): VerificationReport;
10
+ //#endregion
11
+ export { verifyBehavior };
12
+ //# sourceMappingURL=behavior-verifier.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"behavior-verifier.d.ts","names":[],"sources":["../../../src/services/verify/behavior-verifier.ts"],"sourcesContent":[],"mappings":";;;;;;;;iBAoQgB,cAAA,QAAsB,cAAc"}
@@ -0,0 +1,186 @@
1
+ import { isEmitDeclRef } from "@contractspec/lib.contracts/operations";
2
+
3
+ //#region src/services/verify/behavior-verifier.ts
4
+ /**
5
+ * Check if a scenario is likely covered by the implementation.
6
+ */
7
+ function checkScenarioCoverage(code, scenario) {
8
+ const keywords = [
9
+ ...scenario.given,
10
+ ...scenario.when,
11
+ ...scenario.then
12
+ ].flatMap((s) => s.toLowerCase().split(/\s+/).filter((w) => w.length > 3));
13
+ const codeLower = code.toLowerCase();
14
+ const foundKeywords = keywords.filter((kw) => codeLower.includes(kw));
15
+ const coverage = keywords.length > 0 ? foundKeywords.length / keywords.length : 0;
16
+ const scenarioNameLower = scenario.key.toLowerCase().replace(/\s+/g, "");
17
+ const hasTestForScenario = codeLower.includes(scenarioNameLower) || codeLower.includes(`test('${scenario.key.toLowerCase()}'`) || codeLower.includes(`it('${scenario.key.toLowerCase()}'`) || codeLower.includes(`describe('${scenario.key.toLowerCase()}'`);
18
+ const passed = coverage >= .3 || hasTestForScenario;
19
+ return {
20
+ name: scenario.key,
21
+ type: "scenario",
22
+ passed,
23
+ expected: `Given: ${scenario.given.join("; ")}; When: ${scenario.when.join("; ")}; Then: ${scenario.then.join("; ")}`,
24
+ details: passed ? void 0 : `Scenario keywords not found in implementation (${Math.round(coverage * 100)}% coverage)`
25
+ };
26
+ }
27
+ /**
28
+ * Check if an example is likely handled.
29
+ */
30
+ function checkExampleCoverage(code, example) {
31
+ const inputStr = JSON.stringify(example.input);
32
+ const outputStr = JSON.stringify(example.output);
33
+ const inputValues = extractStringValues(example.input);
34
+ const outputValues = extractStringValues(example.output);
35
+ const codeLower = code.toLowerCase();
36
+ const foundInputValues = inputValues.filter((v) => codeLower.includes(v.toLowerCase()));
37
+ const foundOutputValues = outputValues.filter((v) => codeLower.includes(v.toLowerCase()));
38
+ const avgCoverage = ((inputValues.length > 0 ? foundInputValues.length / inputValues.length : 1) + (outputValues.length > 0 ? foundOutputValues.length / outputValues.length : 1)) / 2;
39
+ const passed = avgCoverage >= .2;
40
+ return {
41
+ name: example.key,
42
+ type: "example",
43
+ passed,
44
+ expected: `Input: ${inputStr.slice(0, 100)}...; Output: ${outputStr.slice(0, 100)}...`,
45
+ details: passed ? void 0 : `Example values not found in implementation (${Math.round(avgCoverage * 100)}% coverage)`
46
+ };
47
+ }
48
+ /**
49
+ * Extract string values from an object for comparison.
50
+ */
51
+ function extractStringValues(obj) {
52
+ const values = [];
53
+ function extract(value) {
54
+ if (typeof value === "string" && value.length > 2) values.push(value);
55
+ else if (Array.isArray(value)) value.forEach(extract);
56
+ else if (value && typeof value === "object") Object.values(value).forEach(extract);
57
+ }
58
+ extract(obj);
59
+ return values;
60
+ }
61
+ /**
62
+ * Check if an error case is handled.
63
+ */
64
+ function checkErrorCaseCoverage(code, errorCode, errorDef) {
65
+ const hasErrorCode = code.includes(errorCode);
66
+ const hasHttpStatus = errorDef.http ? code.includes(String(errorDef.http)) : true;
67
+ const whenKeywords = errorDef.when.toLowerCase().split(/\s+/).filter((w) => w.length > 3);
68
+ const codeLower = code.toLowerCase();
69
+ const foundWhenKeywords = whenKeywords.filter((kw) => codeLower.includes(kw));
70
+ const whenCoverage = whenKeywords.length > 0 ? foundWhenKeywords.length / whenKeywords.length : 1;
71
+ const passed = hasErrorCode && (hasHttpStatus || whenCoverage >= .3);
72
+ return {
73
+ name: `Error: ${errorCode}`,
74
+ type: "error",
75
+ passed,
76
+ expected: `When: ${errorDef.when}; Return: ${errorCode} (HTTP ${errorDef.http ?? 400})`,
77
+ details: passed ? void 0 : !hasErrorCode ? `Error code '${errorCode}' not found in implementation` : `Error condition not properly implemented`
78
+ };
79
+ }
80
+ /**
81
+ * Check if events are emitted in the right conditions.
82
+ */
83
+ function checkEventConditions(code, spec) {
84
+ const events = spec.sideEffects?.emits ?? [];
85
+ const checks = [];
86
+ for (const event of events) {
87
+ const eventName = isEmitDeclRef(event) ? event.ref.key : event.key;
88
+ const when = event.when;
89
+ const whenKeywords = when.toLowerCase().split(/\s+/).filter((w) => w.length > 3);
90
+ const codeLower = code.toLowerCase();
91
+ const hasEvent = codeLower.includes(eventName.toLowerCase());
92
+ const foundKeywords = whenKeywords.filter((kw) => codeLower.includes(kw));
93
+ const conditionCoverage = whenKeywords.length > 0 ? foundKeywords.length / whenKeywords.length : 1;
94
+ checks.push({
95
+ name: `Event: ${eventName}`,
96
+ type: "scenario",
97
+ passed: hasEvent && conditionCoverage >= .3,
98
+ expected: `Emit ${eventName} when: ${when}`,
99
+ details: !hasEvent ? `Event '${eventName}' not found` : conditionCoverage < .3 ? `Event condition not properly implemented` : void 0
100
+ });
101
+ }
102
+ return checks;
103
+ }
104
+ /**
105
+ * Check if idempotency is properly handled.
106
+ */
107
+ function checkIdempotency(code, spec) {
108
+ if (spec.policy.idempotent === void 0) return null;
109
+ if (!spec.policy.idempotent) return null;
110
+ const idempotentPatterns = [
111
+ "idempotency",
112
+ "idempotent",
113
+ "already exists",
114
+ "upsert",
115
+ "on conflict",
116
+ "if not exists",
117
+ "dedupe",
118
+ "duplicate"
119
+ ];
120
+ const codeLower = code.toLowerCase();
121
+ const hasIdempotentPattern = idempotentPatterns.some((p) => codeLower.includes(p));
122
+ return {
123
+ name: "Idempotency",
124
+ type: "scenario",
125
+ passed: hasIdempotentPattern,
126
+ expected: "Operation should be idempotent (safe to retry)",
127
+ details: hasIdempotentPattern ? void 0 : "No idempotency pattern found for idempotent operation"
128
+ };
129
+ }
130
+ /**
131
+ * Run all behavior checks and produce a verification report.
132
+ */
133
+ function verifyBehavior(input) {
134
+ const { spec, implementationCode, implementationPath } = input;
135
+ const startTime = Date.now();
136
+ const checks = [];
137
+ for (const scenario of spec.acceptance?.scenarios ?? []) checks.push(checkScenarioCoverage(implementationCode, scenario));
138
+ for (const example of spec.acceptance?.examples ?? []) checks.push(checkExampleCoverage(implementationCode, example));
139
+ for (const [code, errorDef] of Object.entries(spec.io.errors ?? {})) checks.push(checkErrorCaseCoverage(implementationCode, code, errorDef));
140
+ checks.push(...checkEventConditions(implementationCode, spec));
141
+ const idempotencyCheck = checkIdempotency(implementationCode, spec);
142
+ if (idempotencyCheck) checks.push(idempotencyCheck);
143
+ const issues = checks.filter((c) => !c.passed).map((c) => ({
144
+ severity: c.type === "error" ? "error" : "warning",
145
+ category: c.type === "scenario" ? "scenario" : c.type === "example" ? "scenario" : "error_handling",
146
+ message: c.details ?? `${c.type} not covered: ${c.name}`,
147
+ location: implementationPath ? { file: implementationPath } : void 0,
148
+ suggestion: c.expected ? `Expected: ${c.expected}` : void 0
149
+ }));
150
+ const scenarioChecks = checks.filter((c) => c.type === "scenario");
151
+ const errorChecks = checks.filter((c) => c.type === "error");
152
+ const passedCount = checks.filter((c) => c.passed).length;
153
+ const score = checks.length > 0 ? Math.round(passedCount / checks.length * 100) : 100;
154
+ return {
155
+ tier: "behavior",
156
+ passed: issues.filter((i) => i.severity === "error").length === 0,
157
+ score,
158
+ issues,
159
+ suggestions: checks.filter((c) => !c.passed && c.expected).map((c) => `${c.name}: ${c.expected}`),
160
+ coverage: {
161
+ scenarios: {
162
+ total: scenarioChecks.length,
163
+ covered: scenarioChecks.filter((c) => c.passed).length
164
+ },
165
+ errors: {
166
+ total: errorChecks.length,
167
+ handled: errorChecks.filter((c) => c.passed).length
168
+ },
169
+ fields: {
170
+ total: checks.length,
171
+ implemented: passedCount
172
+ }
173
+ },
174
+ meta: {
175
+ specName: spec.meta.key,
176
+ specVersion: spec.meta.version,
177
+ implementationPath: implementationPath ?? "unknown",
178
+ verifiedAt: (/* @__PURE__ */ new Date()).toISOString(),
179
+ duration: Date.now() - startTime
180
+ }
181
+ };
182
+ }
183
+
184
+ //#endregion
185
+ export { verifyBehavior };
186
+ //# sourceMappingURL=behavior-verifier.js.map