@vauban-org/agent-sdk 1.0.0 → 1.3.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 (513) hide show
  1. package/CONTRACT.md +6918 -742
  2. package/dist/adapters/llm/anthropic-direct.d.ts +1 -0
  3. package/dist/adapters/llm/anthropic-direct.d.ts.map +1 -1
  4. package/dist/adapters/llm/anthropic-direct.js +43 -0
  5. package/dist/adapters/llm/anthropic-direct.js.map +1 -1
  6. package/dist/adapters/llm/cascade.d.ts.map +1 -1
  7. package/dist/adapters/llm/cascade.js +57 -14
  8. package/dist/adapters/llm/cascade.js.map +1 -1
  9. package/dist/adapters/llm/litellm.d.ts +2 -0
  10. package/dist/adapters/llm/litellm.d.ts.map +1 -1
  11. package/dist/adapters/llm/litellm.js +44 -0
  12. package/dist/adapters/llm/litellm.js.map +1 -1
  13. package/dist/compute/difficulty-estimator.d.ts +53 -0
  14. package/dist/compute/difficulty-estimator.d.ts.map +1 -0
  15. package/dist/compute/difficulty-estimator.js +82 -0
  16. package/dist/compute/difficulty-estimator.js.map +1 -0
  17. package/dist/compute/strategies/mixture-of-agents.d.ts +40 -0
  18. package/dist/compute/strategies/mixture-of-agents.d.ts.map +1 -0
  19. package/dist/compute/strategies/mixture-of-agents.js +110 -0
  20. package/dist/compute/strategies/mixture-of-agents.js.map +1 -0
  21. package/dist/compute/strategies/tree-of-thoughts.d.ts +48 -0
  22. package/dist/compute/strategies/tree-of-thoughts.d.ts.map +1 -0
  23. package/dist/compute/strategies/tree-of-thoughts.js +242 -0
  24. package/dist/compute/strategies/tree-of-thoughts.js.map +1 -0
  25. package/dist/compute/strategies/two-phase-orient.d.ts +72 -0
  26. package/dist/compute/strategies/two-phase-orient.d.ts.map +1 -0
  27. package/dist/compute/strategies/two-phase-orient.js +85 -0
  28. package/dist/compute/strategies/two-phase-orient.js.map +1 -0
  29. package/dist/constitution/types.d.ts +10 -10
  30. package/dist/container/protocol.d.ts +134 -0
  31. package/dist/container/protocol.d.ts.map +1 -0
  32. package/dist/container/protocol.js +157 -0
  33. package/dist/container/protocol.js.map +1 -0
  34. package/dist/container/runtime.d.ts +140 -0
  35. package/dist/container/runtime.d.ts.map +1 -0
  36. package/dist/container/runtime.js +256 -0
  37. package/dist/container/runtime.js.map +1 -0
  38. package/dist/events/catalogue.d.ts +46 -46
  39. package/dist/events/schemas/agent.completed.v1.d.ts +4 -4
  40. package/dist/events/schemas/agent.failed.v1.d.ts +2 -2
  41. package/dist/events/schemas/agent.hitl_resolved.v1.d.ts +2 -2
  42. package/dist/events/schemas/agent.started.v1.d.ts +2 -2
  43. package/dist/events/schemas/brain.skill.extracted.v1.d.ts +4 -4
  44. package/dist/events/schemas/cc.cost.anomaly_detected.v1.d.ts +2 -2
  45. package/dist/events/schemas/cc.cost.recorded.v1.d.ts +4 -4
  46. package/dist/events/schemas/citadel.sprint.analyzed.v1.d.ts +6 -6
  47. package/dist/events/schemas/citadel.sprint.closed.v1.d.ts +2 -2
  48. package/dist/events/schemas/forge.inbox.reply_classified.v1.d.ts +6 -6
  49. package/dist/events/schemas/forge.lead.qualified.v1.d.ts +2 -2
  50. package/dist/events/schemas/forge.outreach.sent.v1.d.ts +4 -4
  51. package/dist/events/schemas/incident.detected.v1.d.ts +2 -2
  52. package/dist/events/schemas/vauban.goal.checked.v1.d.ts +2 -2
  53. package/dist/events/schemas/vauban.rebalancing.checked.v1.d.ts +2 -2
  54. package/dist/events/schemas/vauban.tax.checked.v1.d.ts +2 -2
  55. package/dist/events/schemas/vauban.vault.analyzed.v1.d.ts +6 -6
  56. package/dist/identity/agent-persona.d.ts +73 -0
  57. package/dist/identity/agent-persona.d.ts.map +1 -0
  58. package/dist/identity/agent-persona.js +165 -0
  59. package/dist/identity/agent-persona.js.map +1 -0
  60. package/dist/identity/persona-prompt.d.ts +25 -0
  61. package/dist/identity/persona-prompt.d.ts.map +1 -0
  62. package/dist/identity/persona-prompt.js +71 -0
  63. package/dist/identity/persona-prompt.js.map +1 -0
  64. package/dist/identity/persona-schema.d.ts +120 -0
  65. package/dist/identity/persona-schema.d.ts.map +1 -0
  66. package/dist/identity/persona-schema.js +103 -0
  67. package/dist/identity/persona-schema.js.map +1 -0
  68. package/dist/index.d.ts +41 -3
  69. package/dist/index.d.ts.map +1 -1
  70. package/dist/index.js +31 -1
  71. package/dist/index.js.map +1 -1
  72. package/dist/loop/minimal-loop.js +293 -287
  73. package/dist/memory/episodic-rrf.d.ts +114 -0
  74. package/dist/memory/episodic-rrf.d.ts.map +1 -0
  75. package/dist/memory/episodic-rrf.js +148 -0
  76. package/dist/memory/episodic-rrf.js.map +1 -0
  77. package/dist/mesh/attenuation.d.ts +78 -0
  78. package/dist/mesh/attenuation.d.ts.map +1 -0
  79. package/dist/mesh/attenuation.js +141 -0
  80. package/dist/mesh/attenuation.js.map +1 -0
  81. package/dist/mesh/delegate.d.ts +96 -0
  82. package/dist/mesh/delegate.d.ts.map +1 -0
  83. package/dist/mesh/delegate.js +172 -0
  84. package/dist/mesh/delegate.js.map +1 -0
  85. package/dist/mesh/dispatcher.d.ts +119 -0
  86. package/dist/mesh/dispatcher.d.ts.map +1 -0
  87. package/dist/mesh/dispatcher.js +207 -0
  88. package/dist/mesh/dispatcher.js.map +1 -0
  89. package/dist/mesh/index.d.ts +12 -0
  90. package/dist/mesh/index.d.ts.map +1 -0
  91. package/dist/mesh/index.js +11 -0
  92. package/dist/mesh/index.js.map +1 -0
  93. package/dist/mesh/types.d.ts +30 -0
  94. package/dist/mesh/types.d.ts.map +1 -0
  95. package/dist/mesh/types.js +11 -0
  96. package/dist/mesh/types.js.map +1 -0
  97. package/dist/orchestration/ooda/agent.d.ts.map +1 -1
  98. package/dist/orchestration/ooda/agent.js +36 -0
  99. package/dist/orchestration/ooda/agent.js.map +1 -1
  100. package/dist/orchestration/ooda/skills.d.ts +104 -0
  101. package/dist/orchestration/ooda/skills.d.ts.map +1 -1
  102. package/dist/orchestration/ooda/skills.js +106 -0
  103. package/dist/orchestration/ooda/skills.js.map +1 -1
  104. package/dist/orchestration/ooda/types.d.ts +11 -0
  105. package/dist/orchestration/ooda/types.d.ts.map +1 -1
  106. package/dist/ports/bastion-action.contract.test.d.ts +11 -0
  107. package/dist/ports/bastion-action.contract.test.d.ts.map +1 -0
  108. package/dist/ports/bastion-action.contract.test.js +238 -0
  109. package/dist/ports/bastion-action.contract.test.js.map +1 -0
  110. package/dist/ports/bastion-action.d.ts +133 -0
  111. package/dist/ports/bastion-action.d.ts.map +1 -0
  112. package/dist/ports/bastion-action.js +73 -0
  113. package/dist/ports/bastion-action.js.map +1 -0
  114. package/dist/ports/brain.d.ts +31 -0
  115. package/dist/ports/brain.d.ts.map +1 -1
  116. package/dist/ports/brain.js +115 -1
  117. package/dist/ports/brain.js.map +1 -1
  118. package/dist/ports/citadel-action.contract.test.d.ts +11 -0
  119. package/dist/ports/citadel-action.contract.test.d.ts.map +1 -0
  120. package/dist/ports/citadel-action.contract.test.js +317 -0
  121. package/dist/ports/citadel-action.contract.test.js.map +1 -0
  122. package/dist/ports/citadel-action.d.ts +111 -0
  123. package/dist/ports/citadel-action.d.ts.map +1 -0
  124. package/dist/ports/citadel-action.js +62 -0
  125. package/dist/ports/citadel-action.js.map +1 -0
  126. package/dist/ports/compliance-contract.d.ts +123 -0
  127. package/dist/ports/compliance-contract.d.ts.map +1 -0
  128. package/dist/ports/compliance-contract.js +35 -0
  129. package/dist/ports/compliance-contract.js.map +1 -0
  130. package/dist/ports/db.d.ts +38 -0
  131. package/dist/ports/db.d.ts.map +1 -1
  132. package/dist/ports/db.js +88 -1
  133. package/dist/ports/db.js.map +1 -1
  134. package/dist/ports/delegation.contract.test.d.ts +9 -0
  135. package/dist/ports/delegation.contract.test.d.ts.map +1 -0
  136. package/dist/ports/delegation.contract.test.js +337 -0
  137. package/dist/ports/delegation.contract.test.js.map +1 -0
  138. package/dist/ports/delegation.d.ts +134 -0
  139. package/dist/ports/delegation.d.ts.map +1 -0
  140. package/dist/ports/delegation.js +105 -0
  141. package/dist/ports/delegation.js.map +1 -0
  142. package/dist/ports/event-bus.d.ts +29 -0
  143. package/dist/ports/event-bus.d.ts.map +1 -1
  144. package/dist/ports/event-bus.js +106 -1
  145. package/dist/ports/event-bus.js.map +1 -1
  146. package/dist/ports/federation.contract.test.d.ts +9 -0
  147. package/dist/ports/federation.contract.test.d.ts.map +1 -0
  148. package/dist/ports/federation.contract.test.js +279 -0
  149. package/dist/ports/federation.contract.test.js.map +1 -0
  150. package/dist/ports/federation.d.ts +140 -0
  151. package/dist/ports/federation.d.ts.map +1 -0
  152. package/dist/ports/federation.js +57 -0
  153. package/dist/ports/federation.js.map +1 -0
  154. package/dist/ports/index.d.ts +28 -2
  155. package/dist/ports/index.d.ts.map +1 -1
  156. package/dist/ports/index.js +17 -2
  157. package/dist/ports/index.js.map +1 -1
  158. package/dist/ports/llm-provider.d.ts +37 -0
  159. package/dist/ports/llm-provider.d.ts.map +1 -1
  160. package/dist/ports/llm-provider.js +99 -1
  161. package/dist/ports/llm-provider.js.map +1 -1
  162. package/dist/ports/logger.d.ts +27 -0
  163. package/dist/ports/logger.d.ts.map +1 -1
  164. package/dist/ports/logger.js +87 -0
  165. package/dist/ports/logger.js.map +1 -1
  166. package/dist/ports/manifest-registry.contract.test.d.ts +9 -0
  167. package/dist/ports/manifest-registry.contract.test.d.ts.map +1 -0
  168. package/dist/ports/manifest-registry.contract.test.js +246 -0
  169. package/dist/ports/manifest-registry.contract.test.js.map +1 -0
  170. package/dist/ports/manifest-registry.d.ts +116 -0
  171. package/dist/ports/manifest-registry.d.ts.map +1 -0
  172. package/dist/ports/manifest-registry.js +79 -0
  173. package/dist/ports/manifest-registry.js.map +1 -0
  174. package/dist/ports/observability.contract.test.d.ts +12 -0
  175. package/dist/ports/observability.contract.test.d.ts.map +1 -0
  176. package/dist/ports/observability.contract.test.js +260 -0
  177. package/dist/ports/observability.contract.test.js.map +1 -0
  178. package/dist/ports/observability.d.ts +98 -0
  179. package/dist/ports/observability.d.ts.map +1 -0
  180. package/dist/ports/observability.js +59 -0
  181. package/dist/ports/observability.js.map +1 -0
  182. package/dist/ports/outcome.d.ts +26 -0
  183. package/dist/ports/outcome.d.ts.map +1 -1
  184. package/dist/ports/outcome.js +62 -1
  185. package/dist/ports/outcome.js.map +1 -1
  186. package/dist/ports/privacy.contract.test.d.ts +12 -0
  187. package/dist/ports/privacy.contract.test.d.ts.map +1 -0
  188. package/dist/ports/privacy.contract.test.js +325 -0
  189. package/dist/ports/privacy.contract.test.js.map +1 -0
  190. package/dist/ports/privacy.d.ts +132 -0
  191. package/dist/ports/privacy.d.ts.map +1 -0
  192. package/dist/ports/privacy.js +83 -0
  193. package/dist/ports/privacy.js.map +1 -0
  194. package/dist/ports/tenant-context.contract.test.d.ts +14 -0
  195. package/dist/ports/tenant-context.contract.test.d.ts.map +1 -0
  196. package/dist/ports/tenant-context.contract.test.js +352 -0
  197. package/dist/ports/tenant-context.contract.test.js.map +1 -0
  198. package/dist/ports/tenant-context.d.ts +103 -0
  199. package/dist/ports/tenant-context.d.ts.map +1 -0
  200. package/dist/ports/tenant-context.js +48 -0
  201. package/dist/ports/tenant-context.js.map +1 -0
  202. package/dist/ports/vauban-finance-action.contract.test.d.ts +11 -0
  203. package/dist/ports/vauban-finance-action.contract.test.d.ts.map +1 -0
  204. package/dist/ports/vauban-finance-action.contract.test.js +260 -0
  205. package/dist/ports/vauban-finance-action.contract.test.js.map +1 -0
  206. package/dist/ports/vauban-finance-action.d.ts +106 -0
  207. package/dist/ports/vauban-finance-action.d.ts.map +1 -0
  208. package/dist/ports/vauban-finance-action.js +60 -0
  209. package/dist/ports/vauban-finance-action.js.map +1 -0
  210. package/dist/ports/workflow-runtime.d.ts +204 -0
  211. package/dist/ports/workflow-runtime.d.ts.map +1 -0
  212. package/dist/ports/workflow-runtime.js +72 -0
  213. package/dist/ports/workflow-runtime.js.map +1 -0
  214. package/dist/proof/cert-verify.d.ts +80 -0
  215. package/dist/proof/cert-verify.d.ts.map +1 -0
  216. package/dist/proof/cert-verify.js +178 -0
  217. package/dist/proof/cert-verify.js.map +1 -0
  218. package/dist/replay/replay.d.ts.map +1 -1
  219. package/dist/replay/replay.js +5 -1
  220. package/dist/replay/replay.js.map +1 -1
  221. package/dist/retry/index.d.ts +129 -0
  222. package/dist/retry/index.d.ts.map +1 -0
  223. package/dist/retry/index.js +156 -0
  224. package/dist/retry/index.js.map +1 -0
  225. package/dist/retry/presets.d.ts +39 -0
  226. package/dist/retry/presets.d.ts.map +1 -0
  227. package/dist/retry/presets.js +69 -0
  228. package/dist/retry/presets.js.map +1 -0
  229. package/dist/skill-loop/ab-runner.d.ts +67 -0
  230. package/dist/skill-loop/ab-runner.d.ts.map +1 -0
  231. package/dist/skill-loop/ab-runner.js +160 -0
  232. package/dist/skill-loop/ab-runner.js.map +1 -0
  233. package/dist/skill-loop/adoption.d.ts +67 -0
  234. package/dist/skill-loop/adoption.d.ts.map +1 -0
  235. package/dist/skill-loop/adoption.js +126 -0
  236. package/dist/skill-loop/adoption.js.map +1 -0
  237. package/dist/skill-loop/candidate.d.ts +45 -0
  238. package/dist/skill-loop/candidate.d.ts.map +1 -0
  239. package/dist/skill-loop/candidate.js +43 -0
  240. package/dist/skill-loop/candidate.js.map +1 -0
  241. package/dist/skill-loop/evaluator.d.ts +42 -0
  242. package/dist/skill-loop/evaluator.d.ts.map +1 -0
  243. package/dist/skill-loop/evaluator.js +184 -0
  244. package/dist/skill-loop/evaluator.js.map +1 -0
  245. package/dist/skill-loop/index.d.ts +27 -0
  246. package/dist/skill-loop/index.d.ts.map +1 -0
  247. package/dist/skill-loop/index.js +27 -0
  248. package/dist/skill-loop/index.js.map +1 -0
  249. package/dist/skill-loop/reflexion-replay.d.ts +87 -0
  250. package/dist/skill-loop/reflexion-replay.d.ts.map +1 -0
  251. package/dist/skill-loop/reflexion-replay.js +110 -0
  252. package/dist/skill-loop/reflexion-replay.js.map +1 -0
  253. package/dist/skill-loop/sign-off.d.ts +88 -0
  254. package/dist/skill-loop/sign-off.d.ts.map +1 -0
  255. package/dist/skill-loop/sign-off.js +146 -0
  256. package/dist/skill-loop/sign-off.js.map +1 -0
  257. package/dist/skill-loop/value-metric.d.ts +55 -0
  258. package/dist/skill-loop/value-metric.d.ts.map +1 -0
  259. package/dist/skill-loop/value-metric.js +69 -0
  260. package/dist/skill-loop/value-metric.js.map +1 -0
  261. package/dist/skill-loop/versioning.d.ts +36 -0
  262. package/dist/skill-loop/versioning.d.ts.map +1 -0
  263. package/dist/skill-loop/versioning.js +47 -0
  264. package/dist/skill-loop/versioning.js.map +1 -0
  265. package/dist/skill-manifest/anchor.d.ts +91 -0
  266. package/dist/skill-manifest/anchor.d.ts.map +1 -0
  267. package/dist/skill-manifest/anchor.js +331 -0
  268. package/dist/skill-manifest/anchor.js.map +1 -0
  269. package/dist/skill-manifest/builder.d.ts +47 -0
  270. package/dist/skill-manifest/builder.d.ts.map +1 -0
  271. package/dist/skill-manifest/builder.js +93 -0
  272. package/dist/skill-manifest/builder.js.map +1 -0
  273. package/dist/skill-manifest/index.d.ts +13 -0
  274. package/dist/skill-manifest/index.d.ts.map +1 -0
  275. package/dist/skill-manifest/index.js +9 -0
  276. package/dist/skill-manifest/index.js.map +1 -0
  277. package/dist/skill-manifest/types.d.ts +67 -0
  278. package/dist/skill-manifest/types.d.ts.map +1 -0
  279. package/dist/skill-manifest/types.js +16 -0
  280. package/dist/skill-manifest/types.js.map +1 -0
  281. package/dist/skill-manifest/verifier.d.ts +42 -0
  282. package/dist/skill-manifest/verifier.d.ts.map +1 -0
  283. package/dist/skill-manifest/verifier.js +136 -0
  284. package/dist/skill-manifest/verifier.js.map +1 -0
  285. package/dist/skills/_secrets.d.ts +16 -0
  286. package/dist/skills/_secrets.d.ts.map +1 -0
  287. package/dist/skills/_secrets.js +20 -0
  288. package/dist/skills/_secrets.js.map +1 -0
  289. package/dist/skills/alpaca-quote.d.ts +2 -2
  290. package/dist/skills/alpaca-quote.d.ts.map +1 -1
  291. package/dist/skills/alpaca-quote.js +51 -20
  292. package/dist/skills/alpaca-quote.js.map +1 -1
  293. package/dist/skills/brain-query.d.ts +4 -4
  294. package/dist/skills/brain-store.d.ts +6 -6
  295. package/dist/skills/errors.d.ts +15 -0
  296. package/dist/skills/errors.d.ts.map +1 -1
  297. package/dist/skills/errors.js +21 -0
  298. package/dist/skills/errors.js.map +1 -1
  299. package/dist/skills/hitl-request.d.ts +2 -2
  300. package/dist/skills/index.d.ts +3 -1
  301. package/dist/skills/index.d.ts.map +1 -1
  302. package/dist/skills/index.js +4 -1
  303. package/dist/skills/index.js.map +1 -1
  304. package/dist/skills/markdown/loader.d.ts +52 -0
  305. package/dist/skills/markdown/loader.d.ts.map +1 -0
  306. package/dist/skills/markdown/loader.js +93 -0
  307. package/dist/skills/markdown/loader.js.map +1 -0
  308. package/dist/skills/markdown/schema.d.ts +432 -0
  309. package/dist/skills/markdown/schema.d.ts.map +1 -0
  310. package/dist/skills/markdown/schema.js +121 -0
  311. package/dist/skills/markdown/schema.js.map +1 -0
  312. package/dist/skills/poc-md-loader/markdown-loader.d.ts +77 -0
  313. package/dist/skills/poc-md-loader/markdown-loader.d.ts.map +1 -0
  314. package/dist/skills/poc-md-loader/markdown-loader.js +125 -0
  315. package/dist/skills/poc-md-loader/markdown-loader.js.map +1 -0
  316. package/dist/skills/poc-md-loader/runner.d.ts +24 -0
  317. package/dist/skills/poc-md-loader/runner.d.ts.map +1 -0
  318. package/dist/skills/poc-md-loader/runner.js +57 -0
  319. package/dist/skills/poc-md-loader/runner.js.map +1 -0
  320. package/dist/skills/poc-md-loader/vitest.poc.config.d.ts +3 -0
  321. package/dist/skills/poc-md-loader/vitest.poc.config.d.ts.map +1 -0
  322. package/dist/skills/poc-md-loader/vitest.poc.config.js +13 -0
  323. package/dist/skills/poc-md-loader/vitest.poc.config.js.map +1 -0
  324. package/dist/skills/poc-md-loader/web-search/script.d.ts +33 -0
  325. package/dist/skills/poc-md-loader/web-search/script.d.ts.map +1 -0
  326. package/dist/skills/poc-md-loader/web-search/script.js +75 -0
  327. package/dist/skills/poc-md-loader/web-search/script.js.map +1 -0
  328. package/dist/skills/record-outcome.d.ts +4 -4
  329. package/dist/skills/send-email.d.ts +2 -2
  330. package/dist/skills/send-email.d.ts.map +1 -1
  331. package/dist/skills/send-email.js +4 -3
  332. package/dist/skills/send-email.js.map +1 -1
  333. package/dist/skills/slack-notify.d.ts +4 -4
  334. package/dist/skills/slack-notify.d.ts.map +1 -1
  335. package/dist/skills/slack-notify.js +52 -21
  336. package/dist/skills/slack-notify.js.map +1 -1
  337. package/dist/skills/starknet-balance.d.ts +1 -1
  338. package/dist/skills/telegram-notify.d.ts +4 -4
  339. package/dist/skills/telegram-notify.d.ts.map +1 -1
  340. package/dist/skills/telegram-notify.js +48 -19
  341. package/dist/skills/telegram-notify.js.map +1 -1
  342. package/dist/skills/web-search.d.ts +1 -1
  343. package/dist/skills/web-search.d.ts.map +1 -1
  344. package/dist/skills/web-search.js +85 -40
  345. package/dist/skills/web-search.js.map +1 -1
  346. package/dist/telemetry/bus.d.ts +54 -0
  347. package/dist/telemetry/bus.d.ts.map +1 -0
  348. package/dist/telemetry/bus.js +159 -0
  349. package/dist/telemetry/bus.js.map +1 -0
  350. package/dist/telemetry/index.d.ts +35 -0
  351. package/dist/telemetry/index.d.ts.map +1 -0
  352. package/dist/telemetry/index.js +30 -0
  353. package/dist/telemetry/index.js.map +1 -0
  354. package/dist/telemetry/port.d.ts +121 -0
  355. package/dist/telemetry/port.d.ts.map +1 -0
  356. package/dist/telemetry/port.js +48 -0
  357. package/dist/telemetry/port.js.map +1 -0
  358. package/dist/telemetry/sinks/otlp.d.ts +45 -0
  359. package/dist/telemetry/sinks/otlp.d.ts.map +1 -0
  360. package/dist/telemetry/sinks/otlp.js +195 -0
  361. package/dist/telemetry/sinks/otlp.js.map +1 -0
  362. package/dist/telemetry/sinks/sqlite.d.ts +32 -0
  363. package/dist/telemetry/sinks/sqlite.d.ts.map +1 -0
  364. package/dist/telemetry/sinks/sqlite.js +170 -0
  365. package/dist/telemetry/sinks/sqlite.js.map +1 -0
  366. package/dist/telemetry/sinks/stdout.d.ts +22 -0
  367. package/dist/telemetry/sinks/stdout.d.ts.map +1 -0
  368. package/dist/telemetry/sinks/stdout.js +38 -0
  369. package/dist/telemetry/sinks/stdout.js.map +1 -0
  370. package/dist/testing/index.d.ts +3 -0
  371. package/dist/testing/test-brain-port.d.ts +4 -0
  372. package/dist/testing/test-brain-port.d.ts.map +1 -1
  373. package/dist/testing/test-brain-port.js +75 -20
  374. package/dist/testing/test-brain-port.js.map +1 -1
  375. package/dist/testing/test-event-bus.d.ts.map +1 -1
  376. package/dist/testing/test-event-bus.js +89 -36
  377. package/dist/testing/test-event-bus.js.map +1 -1
  378. package/dist/trace/schema.d.ts +1 -1
  379. package/dist/trace/schema.d.ts.map +1 -1
  380. package/dist/trace/schema.js +1 -1
  381. package/dist/trace/schema.js.map +1 -1
  382. package/dist/verify/formal/index.d.ts +44 -0
  383. package/dist/verify/formal/index.d.ts.map +1 -0
  384. package/dist/verify/formal/index.js +98 -0
  385. package/dist/verify/formal/index.js.map +1 -0
  386. package/dist/verify/formal/policy.d.ts +105 -0
  387. package/dist/verify/formal/policy.d.ts.map +1 -0
  388. package/dist/verify/formal/policy.js +159 -0
  389. package/dist/verify/formal/policy.js.map +1 -0
  390. package/dist/verify/formal/result.d.ts +50 -0
  391. package/dist/verify/formal/result.d.ts.map +1 -0
  392. package/dist/verify/formal/result.js +21 -0
  393. package/dist/verify/formal/result.js.map +1 -0
  394. package/dist/verify/formal/solver.d.ts +67 -0
  395. package/dist/verify/formal/solver.d.ts.map +1 -0
  396. package/dist/verify/formal/solver.js +184 -0
  397. package/dist/verify/formal/solver.js.map +1 -0
  398. package/dist/verify/formal/spec-language.d.ts +80 -0
  399. package/dist/verify/formal/spec-language.d.ts.map +1 -0
  400. package/dist/verify/formal/spec-language.js +219 -0
  401. package/dist/verify/formal/spec-language.js.map +1 -0
  402. package/docs/attestation.md +199 -0
  403. package/docs/identity.md +193 -0
  404. package/docs/telemetry/migration.md +155 -0
  405. package/docs/telemetry/overview.md +154 -0
  406. package/docs/telemetry/privacy.md +127 -0
  407. package/docs/telemetry/sinks/cc.md +155 -0
  408. package/docs/telemetry/sinks/otlp.md +146 -0
  409. package/docs/telemetry/sinks/sqlite.md +126 -0
  410. package/docs/telemetry/sinks/stdout.md +82 -0
  411. package/package.json +18 -2
  412. package/src/adapters/llm/anthropic-direct.ts +51 -0
  413. package/src/adapters/llm/cascade.ts +64 -19
  414. package/src/adapters/llm/litellm.ts +49 -0
  415. package/src/compute/difficulty-estimator.ts +111 -0
  416. package/src/compute/strategies/mixture-of-agents.ts +150 -0
  417. package/src/compute/strategies/tree-of-thoughts.ts +293 -0
  418. package/src/compute/strategies/two-phase-orient.ts +147 -0
  419. package/src/container/protocol.ts +243 -0
  420. package/src/container/runtime.ts +424 -0
  421. package/src/db/migrations/026_formal_verify_results.sql +30 -0
  422. package/src/identity/agent-persona.ts +203 -0
  423. package/src/identity/persona-prompt.ts +84 -0
  424. package/src/identity/persona-schema.ts +127 -0
  425. package/src/index.ts +368 -2
  426. package/src/memory/episodic-rrf.ts +224 -0
  427. package/src/mesh/attenuation.ts +190 -0
  428. package/src/mesh/delegate.ts +254 -0
  429. package/src/mesh/dispatcher.ts +301 -0
  430. package/src/mesh/index.ts +39 -0
  431. package/src/mesh/types.ts +31 -0
  432. package/src/orchestration/ooda/agent.ts +50 -0
  433. package/src/orchestration/ooda/skills.ts +177 -0
  434. package/src/orchestration/ooda/types.ts +12 -0
  435. package/src/ports/bastion-action.contract.test.ts +355 -0
  436. package/src/ports/bastion-action.ts +198 -0
  437. package/src/ports/brain.ts +177 -15
  438. package/src/ports/citadel-action.contract.test.ts +430 -0
  439. package/src/ports/citadel-action.ts +174 -0
  440. package/src/ports/compliance-contract.ts +191 -0
  441. package/src/ports/db.ts +98 -0
  442. package/src/ports/delegation.contract.test.ts +428 -0
  443. package/src/ports/delegation.ts +211 -0
  444. package/src/ports/event-bus.ts +133 -0
  445. package/src/ports/federation.contract.test.ts +355 -0
  446. package/src/ports/federation.ts +190 -0
  447. package/src/ports/index.ts +186 -1
  448. package/src/ports/llm-provider.ts +123 -0
  449. package/src/ports/logger.ts +104 -0
  450. package/src/ports/manifest-registry.contract.test.ts +324 -0
  451. package/src/ports/manifest-registry.ts +188 -0
  452. package/src/ports/observability.contract.test.ts +315 -0
  453. package/src/ports/observability.ts +150 -0
  454. package/src/ports/outcome.ts +69 -0
  455. package/src/ports/privacy.contract.test.ts +413 -0
  456. package/src/ports/privacy.ts +207 -0
  457. package/src/ports/tenant-context.contract.test.ts +454 -0
  458. package/src/ports/tenant-context.ts +150 -0
  459. package/src/ports/vauban-finance-action.contract.test.ts +335 -0
  460. package/src/ports/vauban-finance-action.ts +166 -0
  461. package/src/ports/workflow-runtime.ts +327 -0
  462. package/src/proof/cert-verify.ts +249 -0
  463. package/src/replay/replay.ts +11 -8
  464. package/src/retry/index.ts +227 -0
  465. package/src/retry/presets.ts +75 -0
  466. package/src/skill-loop/ab-runner.ts +196 -0
  467. package/src/skill-loop/adoption.ts +188 -0
  468. package/src/skill-loop/candidate.ts +75 -0
  469. package/src/skill-loop/evaluator.ts +238 -0
  470. package/src/skill-loop/index.ts +51 -0
  471. package/src/skill-loop/reflexion-replay.ts +173 -0
  472. package/src/skill-loop/sign-off.ts +247 -0
  473. package/src/skill-loop/value-metric.ts +120 -0
  474. package/src/skill-loop/versioning.ts +75 -0
  475. package/src/skill-manifest/anchor.ts +401 -0
  476. package/src/skill-manifest/builder.ts +129 -0
  477. package/src/skill-manifest/index.ts +18 -0
  478. package/src/skill-manifest/types.ts +72 -0
  479. package/src/skill-manifest/verifier.ts +198 -0
  480. package/src/skills/_secrets.ts +25 -0
  481. package/src/skills/alpaca-quote.ts +68 -23
  482. package/src/skills/errors.ts +30 -2
  483. package/src/skills/index.ts +19 -0
  484. package/src/skills/markdown/loader.ts +129 -0
  485. package/src/skills/markdown/schema.ts +144 -0
  486. package/src/skills/poc-md-loader/e2e-parity.test.ts +237 -0
  487. package/src/skills/poc-md-loader/markdown-loader.ts +161 -0
  488. package/src/skills/poc-md-loader/runner.ts +82 -0
  489. package/src/skills/poc-md-loader/vitest.poc.config.ts +13 -0
  490. package/src/skills/poc-md-loader/web-search/SKILL.md +42 -0
  491. package/src/skills/poc-md-loader/web-search/script.ts +109 -0
  492. package/src/skills/send-email.ts +4 -3
  493. package/src/skills/slack-notify.ts +73 -30
  494. package/src/skills/telegram-notify.ts +70 -24
  495. package/src/skills/web-search.ts +132 -50
  496. package/src/telemetry/bus.test.ts +231 -0
  497. package/src/telemetry/bus.ts +241 -0
  498. package/src/telemetry/index.ts +49 -0
  499. package/src/telemetry/port.ts +160 -0
  500. package/src/telemetry/sinks/otlp.test.ts +146 -0
  501. package/src/telemetry/sinks/otlp.ts +250 -0
  502. package/src/telemetry/sinks/sqlite.test.ts +121 -0
  503. package/src/telemetry/sinks/sqlite.ts +260 -0
  504. package/src/telemetry/sinks/stdout.test.ts +109 -0
  505. package/src/telemetry/sinks/stdout.ts +59 -0
  506. package/src/testing/test-brain-port.ts +98 -24
  507. package/src/testing/test-event-bus.ts +104 -43
  508. package/src/trace/schema.ts +1 -1
  509. package/src/verify/formal/index.ts +154 -0
  510. package/src/verify/formal/policy.ts +253 -0
  511. package/src/verify/formal/result.ts +52 -0
  512. package/src/verify/formal/solver.ts +235 -0
  513. package/src/verify/formal/spec-language.ts +274 -0
@@ -0,0 +1,235 @@
1
+ /**
2
+ * src/verify/formal/solver.ts
3
+ *
4
+ * Sprint-587 — Z3 SMT solver wrapper.
5
+ *
6
+ * Strategy : avoid adding `z3-solver` as a hard npm dependency (heavy WASM
7
+ * package, ~5MB) by spawning the `z3` binary as a subprocess and piping
8
+ * SMT-LIB v2 source on stdin. If `z3` is not in PATH, the wrapper degrades
9
+ * gracefully by returning `{ sat: null }` so callers can map that to the
10
+ * UNKNOWN state.
11
+ *
12
+ * This keeps the SDK lean : consumers that want formal verification install
13
+ * `z3` system-wide (apt / brew / scoop). Consumers that do not, get UNKNOWN
14
+ * results and can route them according to their policy.
15
+ *
16
+ * @module verify/formal/solver
17
+ */
18
+
19
+ import { spawn } from "node:child_process";
20
+ import { performance } from "node:perf_hooks";
21
+
22
+ /**
23
+ * Options accepted by {@link checkSmt}.
24
+ */
25
+ export interface SolverOptions {
26
+ /** Wall-clock timeout in milliseconds. Defaults to 5000ms. */
27
+ timeout_ms?: number;
28
+ /** Optional path to the z3 binary (defaults to `z3` resolved via PATH). */
29
+ z3_path?: string;
30
+ }
31
+
32
+ /**
33
+ * Outcome of a single SMT-LIB check-sat invocation.
34
+ *
35
+ * `sat` : `true` → solver returned `sat` (formula is satisfiable, i.e.
36
+ * a counterexample exists for a violation query)
37
+ * `false` → solver returned `unsat` (no counterexample, the
38
+ * property holds)
39
+ * `null` → solver returned `unknown`, timed out, was not
40
+ * installed, or failed to run
41
+ * `model` : when `sat === true`, the textual SMT-LIB model string emitted
42
+ * by `(get-model)` — useful as a counterexample witness
43
+ * `time_ms` : wall-clock time spent waiting on the solver subprocess
44
+ * `reason` : optional human-readable diagnostic for UNKNOWN / null outcomes
45
+ */
46
+ export interface SmtCheckResult {
47
+ sat: boolean | null;
48
+ model?: string;
49
+ time_ms: number;
50
+ reason?: string;
51
+ }
52
+
53
+ const DEFAULT_TIMEOUT_MS = 5000;
54
+
55
+ /**
56
+ * Run a single SMT-LIB v2 formula through Z3 and return the satisfiability
57
+ * outcome.
58
+ *
59
+ * Convention : the caller frames the property as a NEGATION (i.e. asserts the
60
+ * conjunction of preconditions AND the negation of the postcondition). Then :
61
+ * - `sat` → counterexample found → property VIOLATED → UNSAFE
62
+ * - `unsat` → no counterexample exists → property HOLDS → SAFE
63
+ * - `unknown` / timeout / missing binary → UNKNOWN
64
+ *
65
+ * The function never throws : transport errors and missing binaries are
66
+ * surfaced via `sat: null` with a `reason` string.
67
+ */
68
+ export async function checkSmt(
69
+ smtFormula: string,
70
+ options: SolverOptions = {}
71
+ ): Promise<SmtCheckResult> {
72
+ const timeoutMs = options.timeout_ms ?? DEFAULT_TIMEOUT_MS;
73
+ const z3Path = options.z3_path ?? "z3";
74
+
75
+ const start = performance.now();
76
+
77
+ return new Promise<SmtCheckResult>((resolve) => {
78
+ let child;
79
+ try {
80
+ child = spawn(z3Path, ["-in", `-T:${Math.ceil(timeoutMs / 1000)}`], {
81
+ stdio: ["pipe", "pipe", "pipe"],
82
+ });
83
+ } catch (err) {
84
+ resolve({
85
+ sat: null,
86
+ time_ms: performance.now() - start,
87
+ reason: `z3 spawn failed : ${
88
+ err instanceof Error ? err.message : String(err)
89
+ }`,
90
+ });
91
+ return;
92
+ }
93
+
94
+ let stdout = "";
95
+ let stderr = "";
96
+ let settled = false;
97
+
98
+ const settle = (r: SmtCheckResult): void => {
99
+ if (settled) return;
100
+ settled = true;
101
+ resolve(r);
102
+ };
103
+
104
+ const timer = setTimeout(() => {
105
+ try {
106
+ child.kill("SIGKILL");
107
+ } catch {
108
+ /* ignored */
109
+ }
110
+ settle({
111
+ sat: null,
112
+ time_ms: performance.now() - start,
113
+ reason: `z3 timeout after ${timeoutMs}ms`,
114
+ });
115
+ }, timeoutMs);
116
+
117
+ child.stdout.on("data", (chunk: Buffer) => {
118
+ stdout += chunk.toString();
119
+ });
120
+ child.stderr.on("data", (chunk: Buffer) => {
121
+ stderr += chunk.toString();
122
+ });
123
+
124
+ child.on("error", (err) => {
125
+ clearTimeout(timer);
126
+ settle({
127
+ sat: null,
128
+ time_ms: performance.now() - start,
129
+ reason: `z3 not available : ${err.message}`,
130
+ });
131
+ });
132
+
133
+ child.on("close", (code) => {
134
+ clearTimeout(timer);
135
+ const time_ms = performance.now() - start;
136
+ // z3 exits 0 even on `unsat`; non-zero usually means parse error.
137
+ const out = stdout.trim();
138
+ const firstLine = out.split(/\r?\n/)[0]?.trim() ?? "";
139
+
140
+ if (firstLine === "sat") {
141
+ // Extract model block if present (everything after the first line).
142
+ const modelStart = out.indexOf("\n");
143
+ const model =
144
+ modelStart >= 0 ? out.slice(modelStart + 1).trim() : undefined;
145
+ settle({ sat: true, model: model || undefined, time_ms });
146
+ return;
147
+ }
148
+ if (firstLine === "unsat") {
149
+ settle({ sat: false, time_ms });
150
+ return;
151
+ }
152
+ if (firstLine === "unknown") {
153
+ settle({
154
+ sat: null,
155
+ time_ms,
156
+ reason:
157
+ "z3 returned unknown (likely timeout or undecidable fragment)",
158
+ });
159
+ return;
160
+ }
161
+ // Parse error or other failure : surface stderr.
162
+ settle({
163
+ sat: null,
164
+ time_ms,
165
+ reason: `z3 unexpected output (exit ${code}) : ${(stderr || out).slice(
166
+ 0,
167
+ 200
168
+ )}`,
169
+ });
170
+ });
171
+
172
+ try {
173
+ child.stdin.write(smtFormula);
174
+ child.stdin.end();
175
+ } catch (err) {
176
+ clearTimeout(timer);
177
+ settle({
178
+ sat: null,
179
+ time_ms: performance.now() - start,
180
+ reason: `z3 stdin write failed : ${
181
+ err instanceof Error ? err.message : String(err)
182
+ }`,
183
+ });
184
+ }
185
+ });
186
+ }
187
+
188
+ /**
189
+ * Probe : check whether a usable `z3` binary is reachable.
190
+ * Returns `true` if `z3 --version` exits 0 within 1s.
191
+ *
192
+ * Cached for the lifetime of the process — the binary's presence does not
193
+ * change at runtime.
194
+ */
195
+ let z3Available: boolean | undefined;
196
+
197
+ export async function isZ3Available(z3Path = "z3"): Promise<boolean> {
198
+ if (z3Available !== undefined) return z3Available;
199
+ z3Available = await new Promise<boolean>((resolve) => {
200
+ let child;
201
+ try {
202
+ child = spawn(z3Path, ["--version"], {
203
+ stdio: ["ignore", "pipe", "pipe"],
204
+ });
205
+ } catch {
206
+ resolve(false);
207
+ return;
208
+ }
209
+ const t = setTimeout(() => {
210
+ try {
211
+ child.kill("SIGKILL");
212
+ } catch {
213
+ /* ignored */
214
+ }
215
+ resolve(false);
216
+ }, 1000);
217
+ child.on("error", () => {
218
+ clearTimeout(t);
219
+ resolve(false);
220
+ });
221
+ child.on("close", (code) => {
222
+ clearTimeout(t);
223
+ resolve(code === 0);
224
+ });
225
+ });
226
+ return z3Available;
227
+ }
228
+
229
+ /**
230
+ * Test-only helper to reset the cached availability probe.
231
+ * @internal
232
+ */
233
+ export function __resetZ3AvailabilityCache(): void {
234
+ z3Available = undefined;
235
+ }
@@ -0,0 +1,274 @@
1
+ /**
2
+ * src/verify/formal/spec-language.ts
3
+ *
4
+ * Sprint-587 — DSL for axiom specifications, compiled to SMT-LIB v2.
5
+ *
6
+ * Design philosophy (inspired by FormalJudge, arXiv:2602.11136) : agent-cycle
7
+ * properties are expressed as small, typed pre/post-condition tuples. Each
8
+ * condition is mapped to an SMT-LIB fragment by {@link compileToSmt}, which
9
+ * frames the property as a NEGATION of the post-conditions under the
10
+ * pre-conditions. This way, Z3 returning `sat` means a counterexample exists
11
+ * (= UNSAFE) and `unsat` means the post-conditions hold (= SAFE).
12
+ *
13
+ * Bound types : Reals for budgets and ratios, Bools for binary properties,
14
+ * Sets-as-symbols for scope subset checks.
15
+ *
16
+ * @module verify/formal/spec-language
17
+ */
18
+
19
+ /**
20
+ * One verifiable axiom-level property.
21
+ */
22
+ export interface AxiomSpec {
23
+ /** Human-readable axiom label (e.g. "Robuste", "Profitable"). */
24
+ axiom: string;
25
+ /** Conditions that must hold for the spec to be meaningful. */
26
+ preconditions: Condition[];
27
+ /** Conditions whose conjunction defines the post-state to verify. */
28
+ postconditions: Condition[];
29
+ /** Solver timeout in ms — see {@link DEFAULT_POLICIES}. */
30
+ timeout_ms?: number;
31
+ }
32
+
33
+ /**
34
+ * Tagged union of all supported condition kinds.
35
+ *
36
+ * `custom_smt` is the escape hatch : the consumer supplies a raw SMT-LIB
37
+ * fragment that will be inlined under an `(assert ...)`. Use sparingly —
38
+ * mistakes here are silent semantic bugs.
39
+ */
40
+ export type Condition =
41
+ | { type: "budget_constraint"; child_max_fraction: number }
42
+ | { type: "scope_subset"; parent_scope: string[]; child_scope: string[] }
43
+ | { type: "no_pii_in_output"; pii_count_var?: string }
44
+ | { type: "cost_positive_roi"; min_roi_ratio: number }
45
+ | { type: "response_time"; max_ms: number }
46
+ | { type: "custom_smt"; smt_fragment: string };
47
+
48
+ // ---------------------------------------------------------------------------
49
+ // Compilation : condition → SMT-LIB fragment
50
+ // ---------------------------------------------------------------------------
51
+
52
+ interface CompileContext {
53
+ /** Declared symbols (so we don't double-declare). */
54
+ declared: Set<string>;
55
+ /** Accumulated declarations. */
56
+ declarations: string[];
57
+ /** Accumulated assertions (precondition + negated postcondition). */
58
+ assertions: string[];
59
+ }
60
+
61
+ function ensureDecl(ctx: CompileContext, decl: string, name: string): void {
62
+ if (ctx.declared.has(name)) return;
63
+ ctx.declared.add(name);
64
+ ctx.declarations.push(decl);
65
+ }
66
+
67
+ /**
68
+ * Lower a single Condition into SMT-LIB assertions appended to `ctx`.
69
+ * `negated` flag : when true, the condition is being added as a negated
70
+ * post-condition (i.e. we want to find a counterexample).
71
+ */
72
+ function lowerCondition(
73
+ c: Condition,
74
+ ctx: CompileContext,
75
+ negated: boolean
76
+ ): void {
77
+ switch (c.type) {
78
+ case "budget_constraint": {
79
+ // parent_budget >= 0, child_budget >= 0, child_budget <= parent_budget * fraction
80
+ ensureDecl(ctx, "(declare-const parent_budget Real)", "parent_budget");
81
+ ensureDecl(ctx, "(declare-const child_budget Real)", "child_budget");
82
+ // Positivity is part of the pre-state, always assert.
83
+ ctx.assertions.push("(assert (>= parent_budget 0))");
84
+ ctx.assertions.push("(assert (>= child_budget 0))");
85
+ const expr = `(<= child_budget (* parent_budget ${c.child_max_fraction}))`;
86
+ ctx.assertions.push(`(assert ${negated ? `(not ${expr})` : expr})`);
87
+ return;
88
+ }
89
+
90
+ case "scope_subset": {
91
+ // Encode each child element as a Bool : it must be present in parent.
92
+ // We do this by reducing to a boolean conjunction over the listed
93
+ // child elements. Mismatches surface as a counterexample.
94
+ const parentSet = new Set(c.parent_scope);
95
+ const childOk = c.child_scope.every((s) => parentSet.has(s));
96
+ // No declarations needed — fold the result statically into a bool.
97
+ const expr = childOk ? "true" : "false";
98
+ ctx.assertions.push(`(assert ${negated ? `(not ${expr})` : expr})`);
99
+ return;
100
+ }
101
+
102
+ case "no_pii_in_output": {
103
+ const name = c.pii_count_var ?? "pii_count";
104
+ ensureDecl(ctx, `(declare-const ${name} Int)`, name);
105
+ // pii_count >= 0 (always)
106
+ ctx.assertions.push(`(assert (>= ${name} 0))`);
107
+ const expr = `(= ${name} 0)`;
108
+ ctx.assertions.push(`(assert ${negated ? `(not ${expr})` : expr})`);
109
+ return;
110
+ }
111
+
112
+ case "cost_positive_roi": {
113
+ ensureDecl(ctx, "(declare-const cost Real)", "cost");
114
+ ensureDecl(ctx, "(declare-const value Real)", "value");
115
+ ctx.assertions.push("(assert (> cost 0))");
116
+ ctx.assertions.push("(assert (>= value 0))");
117
+ const expr = `(>= (/ value cost) ${c.min_roi_ratio})`;
118
+ ctx.assertions.push(`(assert ${negated ? `(not ${expr})` : expr})`);
119
+ return;
120
+ }
121
+
122
+ case "response_time": {
123
+ ensureDecl(ctx, "(declare-const response_ms Real)", "response_ms");
124
+ ctx.assertions.push("(assert (>= response_ms 0))");
125
+ const expr = `(<= response_ms ${c.max_ms})`;
126
+ ctx.assertions.push(`(assert ${negated ? `(not ${expr})` : expr})`);
127
+ return;
128
+ }
129
+
130
+ case "custom_smt": {
131
+ const frag = c.smt_fragment.trim();
132
+ // The custom fragment is expected to be a parenthesised assertion body.
133
+ if (negated) {
134
+ ctx.assertions.push(`(assert (not ${frag}))`);
135
+ } else {
136
+ ctx.assertions.push(`(assert ${frag})`);
137
+ }
138
+ return;
139
+ }
140
+ }
141
+ }
142
+
143
+ /**
144
+ * Compile an {@link AxiomSpec} into an SMT-LIB v2 program string.
145
+ *
146
+ * Pattern : preconditions are asserted as-is ; postconditions are joined by
147
+ * conjunction and asserted NEGATED. A counterexample (z3 returns `sat`)
148
+ * therefore means : "pre-conditions hold AND at least one post-condition
149
+ * fails" — i.e. an UNSAFE outcome.
150
+ *
151
+ * Includes `(check-sat)` and `(get-model)` as terminating commands.
152
+ */
153
+ export function compileToSmt(spec: AxiomSpec): string {
154
+ const ctx: CompileContext = {
155
+ declared: new Set(),
156
+ declarations: [],
157
+ assertions: [],
158
+ };
159
+
160
+ // Header — set logic to QF_LRA (quantifier-free linear real arithmetic
161
+ // plus integers) which covers all our supported condition kinds.
162
+ const header = ["(set-logic ALL)", `; AxiomSpec : ${spec.axiom}`];
163
+
164
+ // Preconditions : assert as-is (positive form).
165
+ for (const pre of spec.preconditions) {
166
+ lowerCondition(pre, ctx, false);
167
+ }
168
+
169
+ // Postconditions : conjoin and negate.
170
+ // Strategy : assert each one negated separately using De Morgan. We want
171
+ // NOT (post1 AND post2 AND …) ≡ (NOT post1) OR (NOT post2) OR …
172
+ // For check-sat-as-counterexample, we want the solver to find *any*
173
+ // violation, so we encode the disjunction with an auxiliary Bool flag
174
+ // per postcondition. Simpler equivalent : assert (or (not post1) (not post2) …).
175
+ if (spec.postconditions.length === 0) {
176
+ // Empty postcondition set : trivially SAFE (no obligation to verify).
177
+ ctx.assertions.push("(assert false)");
178
+ } else if (spec.postconditions.length === 1) {
179
+ lowerCondition(spec.postconditions[0]!, ctx, true);
180
+ } else {
181
+ // Build per-postcondition expression strings via a side-context, then
182
+ // emit a single `(assert (or ...))`.
183
+ const subCtx: CompileContext = {
184
+ declared: ctx.declared,
185
+ declarations: ctx.declarations,
186
+ assertions: [],
187
+ };
188
+ const negatedExprs: string[] = [];
189
+ for (const post of spec.postconditions) {
190
+ const before = subCtx.assertions.length;
191
+ lowerCondition(post, subCtx, true);
192
+ // The last appended assertion is "(assert <neg expr>)" or pre-assertions.
193
+ // To recover only the negated post-condition body, we accept that some
194
+ // conditions append additional non-negotiable preconditions (positivity).
195
+ // Those are valid in any case and stay in the main assertion list.
196
+ for (let i = before; i < subCtx.assertions.length; i++) {
197
+ const a = subCtx.assertions[i]!;
198
+ // Heuristic : split positivity asserts (>= x 0) and the negated body.
199
+ // The negated body always contains "(not ".
200
+ if (a.includes("(not ")) {
201
+ // Extract the inner expr "(not …)" inside the outer assert.
202
+ const inner = a.slice("(assert ".length, -1);
203
+ negatedExprs.push(inner);
204
+ }
205
+ }
206
+ // Drop the negated body assertions from subCtx so we only keep
207
+ // the positivity ones in the main assertion list.
208
+ subCtx.assertions = subCtx.assertions.filter((a) => !a.includes("(not "));
209
+ }
210
+ ctx.assertions = subCtx.assertions;
211
+ ctx.assertions.push(`(assert (or ${negatedExprs.join(" ")}))`);
212
+ }
213
+
214
+ return [
215
+ ...header,
216
+ ...ctx.declarations,
217
+ ...ctx.assertions,
218
+ "(check-sat)",
219
+ "(get-model)",
220
+ ].join("\n");
221
+ }
222
+
223
+ // ---------------------------------------------------------------------------
224
+ // Pre-built specs for the 5 Vauban axioms
225
+ // ---------------------------------------------------------------------------
226
+
227
+ /**
228
+ * Default per-axiom AxiomSpec presets. Consumers can override the timeout
229
+ * or augment with additional conditions before passing to `formalVerify`.
230
+ *
231
+ * Robuste : 5s — engineering robustness, may need richer checks
232
+ * Institutionnel : 10s — strongest spec, PII + scope-subset + budget
233
+ * SOTA : 2s — lightweight (single ROI check on cost)
234
+ * AntiFragile : 1s — response-time bound only
235
+ * Profitable : 1s — cost-vs-value ROI check
236
+ */
237
+ export const AXIOM_SPECS: Record<string, AxiomSpec> = {
238
+ Robuste: {
239
+ axiom: "Robuste",
240
+ preconditions: [],
241
+ postconditions: [
242
+ { type: "budget_constraint", child_max_fraction: 1.0 },
243
+ { type: "response_time", max_ms: 30_000 },
244
+ ],
245
+ timeout_ms: 5000,
246
+ },
247
+ Institutionnel: {
248
+ axiom: "Institutionnel",
249
+ preconditions: [],
250
+ postconditions: [
251
+ { type: "no_pii_in_output" },
252
+ { type: "budget_constraint", child_max_fraction: 1.0 },
253
+ ],
254
+ timeout_ms: 10_000,
255
+ },
256
+ SOTA: {
257
+ axiom: "SOTA",
258
+ preconditions: [],
259
+ postconditions: [{ type: "cost_positive_roi", min_roi_ratio: 1.0 }],
260
+ timeout_ms: 2000,
261
+ },
262
+ AntiFragile: {
263
+ axiom: "AntiFragile",
264
+ preconditions: [],
265
+ postconditions: [{ type: "response_time", max_ms: 60_000 }],
266
+ timeout_ms: 1000,
267
+ },
268
+ Profitable: {
269
+ axiom: "Profitable",
270
+ preconditions: [],
271
+ postconditions: [{ type: "cost_positive_roi", min_roi_ratio: 1.5 }],
272
+ timeout_ms: 1000,
273
+ },
274
+ };