@vurb/core 3.2.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 (642) hide show
  1. package/README.md +677 -0
  2. package/dist/cli/args.d.ts +26 -0
  3. package/dist/cli/args.d.ts.map +1 -0
  4. package/dist/cli/args.js +117 -0
  5. package/dist/cli/args.js.map +1 -0
  6. package/dist/cli/commands/create.d.ts +11 -0
  7. package/dist/cli/commands/create.d.ts.map +1 -0
  8. package/dist/cli/commands/create.js +121 -0
  9. package/dist/cli/commands/create.js.map +1 -0
  10. package/dist/cli/commands/deploy.d.ts +3 -0
  11. package/dist/cli/commands/deploy.d.ts.map +1 -0
  12. package/dist/cli/commands/deploy.js +268 -0
  13. package/dist/cli/commands/deploy.js.map +1 -0
  14. package/dist/cli/commands/dev.d.ts +9 -0
  15. package/dist/cli/commands/dev.d.ts.map +1 -0
  16. package/dist/cli/commands/dev.js +58 -0
  17. package/dist/cli/commands/dev.js.map +1 -0
  18. package/dist/cli/commands/lock.d.ts +5 -0
  19. package/dist/cli/commands/lock.d.ts.map +1 -0
  20. package/dist/cli/commands/lock.js +94 -0
  21. package/dist/cli/commands/lock.js.map +1 -0
  22. package/dist/cli/commands/remote.d.ts +3 -0
  23. package/dist/cli/commands/remote.d.ts.map +1 -0
  24. package/dist/cli/commands/remote.js +37 -0
  25. package/dist/cli/commands/remote.js.map +1 -0
  26. package/dist/cli/constants.d.ts +18 -0
  27. package/dist/cli/constants.d.ts.map +1 -0
  28. package/dist/cli/constants.js +95 -0
  29. package/dist/cli/constants.js.map +1 -0
  30. package/dist/cli/progress.d.ts +34 -0
  31. package/dist/cli/progress.d.ts.map +1 -0
  32. package/dist/cli/progress.js +102 -0
  33. package/dist/cli/progress.js.map +1 -0
  34. package/dist/cli/rc.d.ts +11 -0
  35. package/dist/cli/rc.d.ts.map +1 -0
  36. package/dist/cli/rc.js +75 -0
  37. package/dist/cli/rc.js.map +1 -0
  38. package/dist/cli/registry.d.ts +25 -0
  39. package/dist/cli/registry.d.ts.map +1 -0
  40. package/dist/cli/registry.js +86 -0
  41. package/dist/cli/registry.js.map +1 -0
  42. package/dist/cli/scaffold.d.ts +10 -0
  43. package/dist/cli/scaffold.d.ts.map +1 -0
  44. package/dist/cli/scaffold.js +105 -0
  45. package/dist/cli/scaffold.js.map +1 -0
  46. package/dist/cli/templates/config.d.ts +14 -0
  47. package/dist/cli/templates/config.d.ts.map +1 -0
  48. package/dist/cli/templates/config.js +133 -0
  49. package/dist/cli/templates/config.js.map +1 -0
  50. package/dist/cli/templates/constants.d.ts +9 -0
  51. package/dist/cli/templates/constants.d.ts.map +1 -0
  52. package/dist/cli/templates/constants.js +9 -0
  53. package/dist/cli/templates/constants.js.map +1 -0
  54. package/dist/cli/templates/core.d.ts +14 -0
  55. package/dist/cli/templates/core.d.ts.map +1 -0
  56. package/dist/cli/templates/core.js +186 -0
  57. package/dist/cli/templates/core.js.map +1 -0
  58. package/dist/cli/templates/cursor.d.ts +8 -0
  59. package/dist/cli/templates/cursor.d.ts.map +1 -0
  60. package/dist/cli/templates/cursor.js +13 -0
  61. package/dist/cli/templates/cursor.js.map +1 -0
  62. package/dist/cli/templates/index.d.ts +17 -0
  63. package/dist/cli/templates/index.d.ts.map +1 -0
  64. package/dist/cli/templates/index.js +27 -0
  65. package/dist/cli/templates/index.js.map +1 -0
  66. package/dist/cli/templates/middleware.d.ts +7 -0
  67. package/dist/cli/templates/middleware.d.ts.map +1 -0
  68. package/dist/cli/templates/middleware.js +34 -0
  69. package/dist/cli/templates/middleware.js.map +1 -0
  70. package/dist/cli/templates/presenter.d.ts +7 -0
  71. package/dist/cli/templates/presenter.d.ts.map +1 -0
  72. package/dist/cli/templates/presenter.js +46 -0
  73. package/dist/cli/templates/presenter.js.map +1 -0
  74. package/dist/cli/templates/prompt.d.ts +7 -0
  75. package/dist/cli/templates/prompt.d.ts.map +1 -0
  76. package/dist/cli/templates/prompt.js +42 -0
  77. package/dist/cli/templates/prompt.js.map +1 -0
  78. package/dist/cli/templates/readme.d.ts +8 -0
  79. package/dist/cli/templates/readme.d.ts.map +1 -0
  80. package/dist/cli/templates/readme.js +173 -0
  81. package/dist/cli/templates/readme.js.map +1 -0
  82. package/dist/cli/templates/testing.d.ts +11 -0
  83. package/dist/cli/templates/testing.d.ts.map +1 -0
  84. package/dist/cli/templates/testing.js +101 -0
  85. package/dist/cli/templates/testing.js.map +1 -0
  86. package/dist/cli/templates/tools.d.ts +13 -0
  87. package/dist/cli/templates/tools.d.ts.map +1 -0
  88. package/dist/cli/templates/tools.js +63 -0
  89. package/dist/cli/templates/tools.js.map +1 -0
  90. package/dist/cli/templates/vectors/database.d.ts +9 -0
  91. package/dist/cli/templates/vectors/database.d.ts.map +1 -0
  92. package/dist/cli/templates/vectors/database.js +82 -0
  93. package/dist/cli/templates/vectors/database.js.map +1 -0
  94. package/dist/cli/templates/vectors/index.d.ts +9 -0
  95. package/dist/cli/templates/vectors/index.d.ts.map +1 -0
  96. package/dist/cli/templates/vectors/index.js +9 -0
  97. package/dist/cli/templates/vectors/index.js.map +1 -0
  98. package/dist/cli/templates/vectors/oauth.d.ts +10 -0
  99. package/dist/cli/templates/vectors/oauth.d.ts.map +1 -0
  100. package/dist/cli/templates/vectors/oauth.js +76 -0
  101. package/dist/cli/templates/vectors/oauth.js.map +1 -0
  102. package/dist/cli/templates/vectors/openapi.d.ts +10 -0
  103. package/dist/cli/templates/vectors/openapi.d.ts.map +1 -0
  104. package/dist/cli/templates/vectors/openapi.js +106 -0
  105. package/dist/cli/templates/vectors/openapi.js.map +1 -0
  106. package/dist/cli/templates/vectors/workflow.d.ts +7 -0
  107. package/dist/cli/templates/vectors/workflow.d.ts.map +1 -0
  108. package/dist/cli/templates/vectors/workflow.js +49 -0
  109. package/dist/cli/templates/vectors/workflow.js.map +1 -0
  110. package/dist/cli/types.d.ts +36 -0
  111. package/dist/cli/types.d.ts.map +1 -0
  112. package/dist/cli/types.js +10 -0
  113. package/dist/cli/types.js.map +1 -0
  114. package/dist/cli/utils.d.ts +27 -0
  115. package/dist/cli/utils.d.ts.map +1 -0
  116. package/dist/cli/utils.js +73 -0
  117. package/dist/cli/utils.js.map +1 -0
  118. package/dist/cli/vurb.d.ts +15 -0
  119. package/dist/cli/vurb.d.ts.map +1 -0
  120. package/dist/cli/vurb.js +87 -0
  121. package/dist/cli/vurb.js.map +1 -0
  122. package/dist/client/InferRouter.d.ts +92 -0
  123. package/dist/client/InferRouter.d.ts.map +1 -0
  124. package/dist/client/InferRouter.js +31 -0
  125. package/dist/client/InferRouter.js.map +1 -0
  126. package/dist/client/VurbClient.d.ts +282 -0
  127. package/dist/client/VurbClient.d.ts.map +1 -0
  128. package/dist/client/VurbClient.js +287 -0
  129. package/dist/client/VurbClient.js.map +1 -0
  130. package/dist/client/createTypedRegistry.d.ts +25 -0
  131. package/dist/client/createTypedRegistry.d.ts.map +1 -0
  132. package/dist/client/createTypedRegistry.js +74 -0
  133. package/dist/client/createTypedRegistry.js.map +1 -0
  134. package/dist/client/index.d.ts +6 -0
  135. package/dist/client/index.d.ts.map +1 -0
  136. package/dist/client/index.js +4 -0
  137. package/dist/client/index.js.map +1 -0
  138. package/dist/converters/ConverterBase.d.ts +68 -0
  139. package/dist/converters/ConverterBase.d.ts.map +1 -0
  140. package/dist/converters/ConverterBase.js +62 -0
  141. package/dist/converters/ConverterBase.js.map +1 -0
  142. package/dist/converters/GroupConverter.d.ts +33 -0
  143. package/dist/converters/GroupConverter.d.ts.map +1 -0
  144. package/dist/converters/GroupConverter.js +26 -0
  145. package/dist/converters/GroupConverter.js.map +1 -0
  146. package/dist/converters/PromptConverter.d.ts +33 -0
  147. package/dist/converters/PromptConverter.d.ts.map +1 -0
  148. package/dist/converters/PromptConverter.js +26 -0
  149. package/dist/converters/PromptConverter.js.map +1 -0
  150. package/dist/converters/ResourceConverter.d.ts +35 -0
  151. package/dist/converters/ResourceConverter.d.ts.map +1 -0
  152. package/dist/converters/ResourceConverter.js +28 -0
  153. package/dist/converters/ResourceConverter.js.map +1 -0
  154. package/dist/converters/ToolAnnotationsConverter.d.ts +33 -0
  155. package/dist/converters/ToolAnnotationsConverter.d.ts.map +1 -0
  156. package/dist/converters/ToolAnnotationsConverter.js +26 -0
  157. package/dist/converters/ToolAnnotationsConverter.js.map +1 -0
  158. package/dist/converters/ToolConverter.d.ts +35 -0
  159. package/dist/converters/ToolConverter.d.ts.map +1 -0
  160. package/dist/converters/ToolConverter.js +28 -0
  161. package/dist/converters/ToolConverter.js.map +1 -0
  162. package/dist/converters/index.d.ts +7 -0
  163. package/dist/converters/index.d.ts.map +1 -0
  164. package/dist/converters/index.js +7 -0
  165. package/dist/converters/index.js.map +1 -0
  166. package/dist/core/StandardSchema.d.ts +178 -0
  167. package/dist/core/StandardSchema.d.ts.map +1 -0
  168. package/dist/core/StandardSchema.js +174 -0
  169. package/dist/core/StandardSchema.js.map +1 -0
  170. package/dist/core/builder/ActionGroupBuilder.d.ts +208 -0
  171. package/dist/core/builder/ActionGroupBuilder.d.ts.map +1 -0
  172. package/dist/core/builder/ActionGroupBuilder.js +193 -0
  173. package/dist/core/builder/ActionGroupBuilder.js.map +1 -0
  174. package/dist/core/builder/ErrorBuilder.d.ts +59 -0
  175. package/dist/core/builder/ErrorBuilder.d.ts.map +1 -0
  176. package/dist/core/builder/ErrorBuilder.js +99 -0
  177. package/dist/core/builder/ErrorBuilder.js.map +1 -0
  178. package/dist/core/builder/FluentRouter.d.ts +96 -0
  179. package/dist/core/builder/FluentRouter.d.ts.map +1 -0
  180. package/dist/core/builder/FluentRouter.js +116 -0
  181. package/dist/core/builder/FluentRouter.js.map +1 -0
  182. package/dist/core/builder/FluentSchemaHelpers.d.ts +237 -0
  183. package/dist/core/builder/FluentSchemaHelpers.d.ts.map +1 -0
  184. package/dist/core/builder/FluentSchemaHelpers.js +227 -0
  185. package/dist/core/builder/FluentSchemaHelpers.js.map +1 -0
  186. package/dist/core/builder/FluentToolBuilder.d.ts +419 -0
  187. package/dist/core/builder/FluentToolBuilder.d.ts.map +1 -0
  188. package/dist/core/builder/FluentToolBuilder.js +643 -0
  189. package/dist/core/builder/FluentToolBuilder.js.map +1 -0
  190. package/dist/core/builder/GroupedToolBuilder.d.ts +832 -0
  191. package/dist/core/builder/GroupedToolBuilder.d.ts.map +1 -0
  192. package/dist/core/builder/GroupedToolBuilder.js +1306 -0
  193. package/dist/core/builder/GroupedToolBuilder.js.map +1 -0
  194. package/dist/core/builder/ParamDescriptors.d.ts +142 -0
  195. package/dist/core/builder/ParamDescriptors.d.ts.map +1 -0
  196. package/dist/core/builder/ParamDescriptors.js +164 -0
  197. package/dist/core/builder/ParamDescriptors.js.map +1 -0
  198. package/dist/core/builder/ToolDefinitionCompiler.d.ts +37 -0
  199. package/dist/core/builder/ToolDefinitionCompiler.d.ts.map +1 -0
  200. package/dist/core/builder/ToolDefinitionCompiler.js +72 -0
  201. package/dist/core/builder/ToolDefinitionCompiler.js.map +1 -0
  202. package/dist/core/builder/defineTool.d.ts +180 -0
  203. package/dist/core/builder/defineTool.d.ts.map +1 -0
  204. package/dist/core/builder/defineTool.js +164 -0
  205. package/dist/core/builder/defineTool.js.map +1 -0
  206. package/dist/core/builder/index.d.ts +13 -0
  207. package/dist/core/builder/index.d.ts.map +1 -0
  208. package/dist/core/builder/index.js +13 -0
  209. package/dist/core/builder/index.js.map +1 -0
  210. package/dist/core/createGroup.d.ts +140 -0
  211. package/dist/core/createGroup.d.ts.map +1 -0
  212. package/dist/core/createGroup.js +144 -0
  213. package/dist/core/createGroup.js.map +1 -0
  214. package/dist/core/execution/ConcurrencyGuard.d.ts +103 -0
  215. package/dist/core/execution/ConcurrencyGuard.d.ts.map +1 -0
  216. package/dist/core/execution/ConcurrencyGuard.js +147 -0
  217. package/dist/core/execution/ConcurrencyGuard.js.map +1 -0
  218. package/dist/core/execution/EgressGuard.d.ts +72 -0
  219. package/dist/core/execution/EgressGuard.d.ts.map +1 -0
  220. package/dist/core/execution/EgressGuard.js +163 -0
  221. package/dist/core/execution/EgressGuard.js.map +1 -0
  222. package/dist/core/execution/ExecutionPipeline.d.ts +67 -0
  223. package/dist/core/execution/ExecutionPipeline.d.ts.map +1 -0
  224. package/dist/core/execution/ExecutionPipeline.js +176 -0
  225. package/dist/core/execution/ExecutionPipeline.js.map +1 -0
  226. package/dist/core/execution/MiddlewareCompiler.d.ts +35 -0
  227. package/dist/core/execution/MiddlewareCompiler.d.ts.map +1 -0
  228. package/dist/core/execution/MiddlewareCompiler.js +111 -0
  229. package/dist/core/execution/MiddlewareCompiler.js.map +1 -0
  230. package/dist/core/execution/MutationSerializer.d.ts +78 -0
  231. package/dist/core/execution/MutationSerializer.d.ts.map +1 -0
  232. package/dist/core/execution/MutationSerializer.js +106 -0
  233. package/dist/core/execution/MutationSerializer.js.map +1 -0
  234. package/dist/core/execution/PipelineHooks.d.ts +46 -0
  235. package/dist/core/execution/PipelineHooks.d.ts.map +1 -0
  236. package/dist/core/execution/PipelineHooks.js +66 -0
  237. package/dist/core/execution/PipelineHooks.js.map +1 -0
  238. package/dist/core/execution/ProgressHelper.d.ts +67 -0
  239. package/dist/core/execution/ProgressHelper.d.ts.map +1 -0
  240. package/dist/core/execution/ProgressHelper.js +59 -0
  241. package/dist/core/execution/ProgressHelper.js.map +1 -0
  242. package/dist/core/execution/ValidationErrorFormatter.d.ts +34 -0
  243. package/dist/core/execution/ValidationErrorFormatter.d.ts.map +1 -0
  244. package/dist/core/execution/ValidationErrorFormatter.js +193 -0
  245. package/dist/core/execution/ValidationErrorFormatter.js.map +1 -0
  246. package/dist/core/execution/index.d.ts +9 -0
  247. package/dist/core/execution/index.d.ts.map +1 -0
  248. package/dist/core/execution/index.js +9 -0
  249. package/dist/core/execution/index.js.map +1 -0
  250. package/dist/core/index.d.ts +34 -0
  251. package/dist/core/index.d.ts.map +1 -0
  252. package/dist/core/index.js +29 -0
  253. package/dist/core/index.js.map +1 -0
  254. package/dist/core/initVurb.d.ts +295 -0
  255. package/dist/core/initVurb.d.ts.map +1 -0
  256. package/dist/core/initVurb.js +171 -0
  257. package/dist/core/initVurb.js.map +1 -0
  258. package/dist/core/middleware/ContextDerivation.d.ts +124 -0
  259. package/dist/core/middleware/ContextDerivation.d.ts.map +1 -0
  260. package/dist/core/middleware/ContextDerivation.js +117 -0
  261. package/dist/core/middleware/ContextDerivation.js.map +1 -0
  262. package/dist/core/middleware/index.d.ts +4 -0
  263. package/dist/core/middleware/index.d.ts.map +1 -0
  264. package/dist/core/middleware/index.js +3 -0
  265. package/dist/core/middleware/index.js.map +1 -0
  266. package/dist/core/registry/ToolFilterEngine.d.ts +27 -0
  267. package/dist/core/registry/ToolFilterEngine.d.ts.map +1 -0
  268. package/dist/core/registry/ToolFilterEngine.js +45 -0
  269. package/dist/core/registry/ToolFilterEngine.js.map +1 -0
  270. package/dist/core/registry/ToolRegistry.d.ts +259 -0
  271. package/dist/core/registry/ToolRegistry.d.ts.map +1 -0
  272. package/dist/core/registry/ToolRegistry.js +343 -0
  273. package/dist/core/registry/ToolRegistry.js.map +1 -0
  274. package/dist/core/registry/index.d.ts +4 -0
  275. package/dist/core/registry/index.d.ts.map +1 -0
  276. package/dist/core/registry/index.js +3 -0
  277. package/dist/core/registry/index.js.map +1 -0
  278. package/dist/core/response.d.ts +289 -0
  279. package/dist/core/response.d.ts.map +1 -0
  280. package/dist/core/response.js +286 -0
  281. package/dist/core/response.js.map +1 -0
  282. package/dist/core/result.d.ts +93 -0
  283. package/dist/core/result.d.ts.map +1 -0
  284. package/dist/core/result.js +66 -0
  285. package/dist/core/result.js.map +1 -0
  286. package/dist/core/schema/AnnotationAggregator.d.ts +11 -0
  287. package/dist/core/schema/AnnotationAggregator.d.ts.map +1 -0
  288. package/dist/core/schema/AnnotationAggregator.js +40 -0
  289. package/dist/core/schema/AnnotationAggregator.js.map +1 -0
  290. package/dist/core/schema/DescriptionGenerator.d.ts +12 -0
  291. package/dist/core/schema/DescriptionGenerator.d.ts.map +1 -0
  292. package/dist/core/schema/DescriptionGenerator.js +81 -0
  293. package/dist/core/schema/DescriptionGenerator.js.map +1 -0
  294. package/dist/core/schema/SchemaGenerator.d.ts +15 -0
  295. package/dist/core/schema/SchemaGenerator.d.ts.map +1 -0
  296. package/dist/core/schema/SchemaGenerator.js +192 -0
  297. package/dist/core/schema/SchemaGenerator.js.map +1 -0
  298. package/dist/core/schema/SchemaUtils.d.ts +26 -0
  299. package/dist/core/schema/SchemaUtils.d.ts.map +1 -0
  300. package/dist/core/schema/SchemaUtils.js +85 -0
  301. package/dist/core/schema/SchemaUtils.js.map +1 -0
  302. package/dist/core/schema/ToonDescriptionGenerator.d.ts +3 -0
  303. package/dist/core/schema/ToonDescriptionGenerator.d.ts.map +1 -0
  304. package/dist/core/schema/ToonDescriptionGenerator.js +65 -0
  305. package/dist/core/schema/ToonDescriptionGenerator.js.map +1 -0
  306. package/dist/core/schema/index.d.ts +7 -0
  307. package/dist/core/schema/index.d.ts.map +1 -0
  308. package/dist/core/schema/index.js +7 -0
  309. package/dist/core/schema/index.js.map +1 -0
  310. package/dist/core/serialization/JsonSerializer.d.ts +71 -0
  311. package/dist/core/serialization/JsonSerializer.d.ts.map +1 -0
  312. package/dist/core/serialization/JsonSerializer.js +192 -0
  313. package/dist/core/serialization/JsonSerializer.js.map +1 -0
  314. package/dist/core/serialization/index.d.ts +7 -0
  315. package/dist/core/serialization/index.d.ts.map +1 -0
  316. package/dist/core/serialization/index.js +7 -0
  317. package/dist/core/serialization/index.js.map +1 -0
  318. package/dist/core/types.d.ts +303 -0
  319. package/dist/core/types.d.ts.map +1 -0
  320. package/dist/core/types.js +17 -0
  321. package/dist/core/types.js.map +1 -0
  322. package/dist/domain/Annotations.d.ts +42 -0
  323. package/dist/domain/Annotations.d.ts.map +1 -0
  324. package/dist/domain/Annotations.js +16 -0
  325. package/dist/domain/Annotations.js.map +1 -0
  326. package/dist/domain/BaseModel.d.ts +50 -0
  327. package/dist/domain/BaseModel.d.ts.map +1 -0
  328. package/dist/domain/BaseModel.js +41 -0
  329. package/dist/domain/BaseModel.js.map +1 -0
  330. package/dist/domain/Group.d.ts +99 -0
  331. package/dist/domain/Group.d.ts.map +1 -0
  332. package/dist/domain/Group.js +172 -0
  333. package/dist/domain/Group.js.map +1 -0
  334. package/dist/domain/GroupItem.d.ts +46 -0
  335. package/dist/domain/GroupItem.d.ts.map +1 -0
  336. package/dist/domain/GroupItem.js +58 -0
  337. package/dist/domain/GroupItem.js.map +1 -0
  338. package/dist/domain/Icon.d.ts +41 -0
  339. package/dist/domain/Icon.d.ts.map +1 -0
  340. package/dist/domain/Icon.js +15 -0
  341. package/dist/domain/Icon.js.map +1 -0
  342. package/dist/domain/Prompt.d.ts +49 -0
  343. package/dist/domain/Prompt.d.ts.map +1 -0
  344. package/dist/domain/Prompt.js +59 -0
  345. package/dist/domain/Prompt.js.map +1 -0
  346. package/dist/domain/PromptArgument.d.ts +23 -0
  347. package/dist/domain/PromptArgument.d.ts.map +1 -0
  348. package/dist/domain/PromptArgument.js +27 -0
  349. package/dist/domain/PromptArgument.js.map +1 -0
  350. package/dist/domain/Resource.d.ts +37 -0
  351. package/dist/domain/Resource.d.ts.map +1 -0
  352. package/dist/domain/Resource.js +39 -0
  353. package/dist/domain/Resource.js.map +1 -0
  354. package/dist/domain/Role.d.ts +23 -0
  355. package/dist/domain/Role.d.ts.map +1 -0
  356. package/dist/domain/Role.js +24 -0
  357. package/dist/domain/Role.js.map +1 -0
  358. package/dist/domain/Tool.d.ts +39 -0
  359. package/dist/domain/Tool.d.ts.map +1 -0
  360. package/dist/domain/Tool.js +41 -0
  361. package/dist/domain/Tool.js.map +1 -0
  362. package/dist/domain/ToolAnnotations.d.ts +48 -0
  363. package/dist/domain/ToolAnnotations.d.ts.map +1 -0
  364. package/dist/domain/ToolAnnotations.js +15 -0
  365. package/dist/domain/ToolAnnotations.js.map +1 -0
  366. package/dist/domain/index.d.ts +16 -0
  367. package/dist/domain/index.d.ts.map +1 -0
  368. package/dist/domain/index.js +13 -0
  369. package/dist/domain/index.js.map +1 -0
  370. package/dist/domain/utils.d.ts +6 -0
  371. package/dist/domain/utils.d.ts.map +1 -0
  372. package/dist/domain/utils.js +12 -0
  373. package/dist/domain/utils.js.map +1 -0
  374. package/dist/edge-stub.d.ts +73 -0
  375. package/dist/edge-stub.d.ts.map +1 -0
  376. package/dist/edge-stub.js +83 -0
  377. package/dist/edge-stub.js.map +1 -0
  378. package/dist/exposition/ExpositionCompiler.d.ts +66 -0
  379. package/dist/exposition/ExpositionCompiler.d.ts.map +1 -0
  380. package/dist/exposition/ExpositionCompiler.js +279 -0
  381. package/dist/exposition/ExpositionCompiler.js.map +1 -0
  382. package/dist/exposition/index.d.ts +4 -0
  383. package/dist/exposition/index.d.ts.map +1 -0
  384. package/dist/exposition/index.js +2 -0
  385. package/dist/exposition/index.js.map +1 -0
  386. package/dist/exposition/types.d.ts +58 -0
  387. package/dist/exposition/types.d.ts.map +1 -0
  388. package/dist/exposition/types.js +11 -0
  389. package/dist/exposition/types.js.map +1 -0
  390. package/dist/fsm/StateMachineGate.d.ts +294 -0
  391. package/dist/fsm/StateMachineGate.d.ts.map +1 -0
  392. package/dist/fsm/StateMachineGate.js +400 -0
  393. package/dist/fsm/StateMachineGate.js.map +1 -0
  394. package/dist/index.d.ts +148 -0
  395. package/dist/index.d.ts.map +1 -0
  396. package/dist/index.js +112 -0
  397. package/dist/index.js.map +1 -0
  398. package/dist/introspection/BehaviorDigest.d.ts +112 -0
  399. package/dist/introspection/BehaviorDigest.d.ts.map +1 -0
  400. package/dist/introspection/BehaviorDigest.js +149 -0
  401. package/dist/introspection/BehaviorDigest.js.map +1 -0
  402. package/dist/introspection/CapabilityLockfile.d.ts +261 -0
  403. package/dist/introspection/CapabilityLockfile.d.ts.map +1 -0
  404. package/dist/introspection/CapabilityLockfile.js +395 -0
  405. package/dist/introspection/CapabilityLockfile.js.map +1 -0
  406. package/dist/introspection/ContractAwareSelfHealing.d.ts +90 -0
  407. package/dist/introspection/ContractAwareSelfHealing.d.ts.map +1 -0
  408. package/dist/introspection/ContractAwareSelfHealing.js +132 -0
  409. package/dist/introspection/ContractAwareSelfHealing.js.map +1 -0
  410. package/dist/introspection/ContractDiff.d.ts +91 -0
  411. package/dist/introspection/ContractDiff.d.ts.map +1 -0
  412. package/dist/introspection/ContractDiff.js +466 -0
  413. package/dist/introspection/ContractDiff.js.map +1 -0
  414. package/dist/introspection/CryptoAttestation.d.ts +143 -0
  415. package/dist/introspection/CryptoAttestation.d.ts.map +1 -0
  416. package/dist/introspection/CryptoAttestation.js +192 -0
  417. package/dist/introspection/CryptoAttestation.js.map +1 -0
  418. package/dist/introspection/EntitlementScanner.d.ts +177 -0
  419. package/dist/introspection/EntitlementScanner.d.ts.map +1 -0
  420. package/dist/introspection/EntitlementScanner.js +459 -0
  421. package/dist/introspection/EntitlementScanner.js.map +1 -0
  422. package/dist/introspection/GovernanceObserver.d.ts +88 -0
  423. package/dist/introspection/GovernanceObserver.d.ts.map +1 -0
  424. package/dist/introspection/GovernanceObserver.js +136 -0
  425. package/dist/introspection/GovernanceObserver.js.map +1 -0
  426. package/dist/introspection/IntrospectionResource.d.ts +20 -0
  427. package/dist/introspection/IntrospectionResource.d.ts.map +1 -0
  428. package/dist/introspection/IntrospectionResource.js +112 -0
  429. package/dist/introspection/IntrospectionResource.js.map +1 -0
  430. package/dist/introspection/ManifestCompiler.d.ts +33 -0
  431. package/dist/introspection/ManifestCompiler.d.ts.map +1 -0
  432. package/dist/introspection/ManifestCompiler.js +88 -0
  433. package/dist/introspection/ManifestCompiler.js.map +1 -0
  434. package/dist/introspection/SemanticProbe.d.ts +207 -0
  435. package/dist/introspection/SemanticProbe.d.ts.map +1 -0
  436. package/dist/introspection/SemanticProbe.js +274 -0
  437. package/dist/introspection/SemanticProbe.js.map +1 -0
  438. package/dist/introspection/TokenEconomics.d.ts +210 -0
  439. package/dist/introspection/TokenEconomics.d.ts.map +1 -0
  440. package/dist/introspection/TokenEconomics.js +292 -0
  441. package/dist/introspection/TokenEconomics.js.map +1 -0
  442. package/dist/introspection/ToolContract.d.ts +161 -0
  443. package/dist/introspection/ToolContract.d.ts.map +1 -0
  444. package/dist/introspection/ToolContract.js +218 -0
  445. package/dist/introspection/ToolContract.js.map +1 -0
  446. package/dist/introspection/canonicalize.d.ts +35 -0
  447. package/dist/introspection/canonicalize.d.ts.map +1 -0
  448. package/dist/introspection/canonicalize.js +72 -0
  449. package/dist/introspection/canonicalize.js.map +1 -0
  450. package/dist/introspection/index.d.ts +26 -0
  451. package/dist/introspection/index.d.ts.map +1 -0
  452. package/dist/introspection/index.js +24 -0
  453. package/dist/introspection/index.js.map +1 -0
  454. package/dist/introspection/types.d.ts +120 -0
  455. package/dist/introspection/types.d.ts.map +1 -0
  456. package/dist/introspection/types.js +13 -0
  457. package/dist/introspection/types.js.map +1 -0
  458. package/dist/observability/DebugObserver.d.ts +185 -0
  459. package/dist/observability/DebugObserver.d.ts.map +1 -0
  460. package/dist/observability/DebugObserver.js +102 -0
  461. package/dist/observability/DebugObserver.js.map +1 -0
  462. package/dist/observability/TelemetryBus.d.ts +88 -0
  463. package/dist/observability/TelemetryBus.d.ts.map +1 -0
  464. package/dist/observability/TelemetryBus.js +463 -0
  465. package/dist/observability/TelemetryBus.js.map +1 -0
  466. package/dist/observability/TelemetryEvent.d.ts +177 -0
  467. package/dist/observability/TelemetryEvent.d.ts.map +1 -0
  468. package/dist/observability/TelemetryEvent.js +2 -0
  469. package/dist/observability/TelemetryEvent.js.map +1 -0
  470. package/dist/observability/Tracing.d.ts +155 -0
  471. package/dist/observability/Tracing.d.ts.map +1 -0
  472. package/dist/observability/Tracing.js +67 -0
  473. package/dist/observability/Tracing.js.map +1 -0
  474. package/dist/observability/index.d.ts +13 -0
  475. package/dist/observability/index.d.ts.map +1 -0
  476. package/dist/observability/index.js +12 -0
  477. package/dist/observability/index.js.map +1 -0
  478. package/dist/presenter/PostProcessor.d.ts +52 -0
  479. package/dist/presenter/PostProcessor.d.ts.map +1 -0
  480. package/dist/presenter/PostProcessor.js +148 -0
  481. package/dist/presenter/PostProcessor.js.map +1 -0
  482. package/dist/presenter/Presenter.d.ts +575 -0
  483. package/dist/presenter/Presenter.d.ts.map +1 -0
  484. package/dist/presenter/Presenter.js +768 -0
  485. package/dist/presenter/Presenter.js.map +1 -0
  486. package/dist/presenter/PresenterValidationError.d.ts +42 -0
  487. package/dist/presenter/PresenterValidationError.d.ts.map +1 -0
  488. package/dist/presenter/PresenterValidationError.js +55 -0
  489. package/dist/presenter/PresenterValidationError.js.map +1 -0
  490. package/dist/presenter/RedactEngine.d.ts +110 -0
  491. package/dist/presenter/RedactEngine.d.ts.map +1 -0
  492. package/dist/presenter/RedactEngine.js +128 -0
  493. package/dist/presenter/RedactEngine.js.map +1 -0
  494. package/dist/presenter/ResponseBuilder.d.ts +262 -0
  495. package/dist/presenter/ResponseBuilder.d.ts.map +1 -0
  496. package/dist/presenter/ResponseBuilder.js +374 -0
  497. package/dist/presenter/ResponseBuilder.js.map +1 -0
  498. package/dist/presenter/SelectUtils.d.ts +78 -0
  499. package/dist/presenter/SelectUtils.d.ts.map +1 -0
  500. package/dist/presenter/SelectUtils.js +141 -0
  501. package/dist/presenter/SelectUtils.js.map +1 -0
  502. package/dist/presenter/ZodDescriptionExtractor.d.ts +54 -0
  503. package/dist/presenter/ZodDescriptionExtractor.d.ts.map +1 -0
  504. package/dist/presenter/ZodDescriptionExtractor.js +131 -0
  505. package/dist/presenter/ZodDescriptionExtractor.js.map +1 -0
  506. package/dist/presenter/definePresenter.d.ts +193 -0
  507. package/dist/presenter/definePresenter.d.ts.map +1 -0
  508. package/dist/presenter/definePresenter.js +99 -0
  509. package/dist/presenter/definePresenter.js.map +1 -0
  510. package/dist/presenter/index.d.ts +21 -0
  511. package/dist/presenter/index.d.ts.map +1 -0
  512. package/dist/presenter/index.js +28 -0
  513. package/dist/presenter/index.js.map +1 -0
  514. package/dist/presenter/suggest.d.ts +39 -0
  515. package/dist/presenter/suggest.d.ts.map +1 -0
  516. package/dist/presenter/suggest.js +41 -0
  517. package/dist/presenter/suggest.js.map +1 -0
  518. package/dist/presenter/typeHelpers.d.ts +147 -0
  519. package/dist/presenter/typeHelpers.d.ts.map +1 -0
  520. package/dist/presenter/typeHelpers.js +152 -0
  521. package/dist/presenter/typeHelpers.js.map +1 -0
  522. package/dist/presenter/ui.d.ts +205 -0
  523. package/dist/presenter/ui.d.ts.map +1 -0
  524. package/dist/presenter/ui.js +222 -0
  525. package/dist/presenter/ui.js.map +1 -0
  526. package/dist/prompt/CursorCodec.d.ts +43 -0
  527. package/dist/prompt/CursorCodec.d.ts.map +1 -0
  528. package/dist/prompt/CursorCodec.js +171 -0
  529. package/dist/prompt/CursorCodec.js.map +1 -0
  530. package/dist/prompt/FluentPromptBuilder.d.ts +155 -0
  531. package/dist/prompt/FluentPromptBuilder.d.ts.map +1 -0
  532. package/dist/prompt/FluentPromptBuilder.js +195 -0
  533. package/dist/prompt/FluentPromptBuilder.js.map +1 -0
  534. package/dist/prompt/HydrationSandbox.d.ts +55 -0
  535. package/dist/prompt/HydrationSandbox.d.ts.map +1 -0
  536. package/dist/prompt/HydrationSandbox.js +122 -0
  537. package/dist/prompt/HydrationSandbox.js.map +1 -0
  538. package/dist/prompt/PromptExecutionPipeline.d.ts +61 -0
  539. package/dist/prompt/PromptExecutionPipeline.d.ts.map +1 -0
  540. package/dist/prompt/PromptExecutionPipeline.js +177 -0
  541. package/dist/prompt/PromptExecutionPipeline.js.map +1 -0
  542. package/dist/prompt/PromptMessage.d.ts +133 -0
  543. package/dist/prompt/PromptMessage.d.ts.map +1 -0
  544. package/dist/prompt/PromptMessage.js +182 -0
  545. package/dist/prompt/PromptMessage.js.map +1 -0
  546. package/dist/prompt/PromptRegistry.d.ts +236 -0
  547. package/dist/prompt/PromptRegistry.d.ts.map +1 -0
  548. package/dist/prompt/PromptRegistry.js +399 -0
  549. package/dist/prompt/PromptRegistry.js.map +1 -0
  550. package/dist/prompt/definePrompt.d.ts +111 -0
  551. package/dist/prompt/definePrompt.d.ts.map +1 -0
  552. package/dist/prompt/definePrompt.js +130 -0
  553. package/dist/prompt/definePrompt.js.map +1 -0
  554. package/dist/prompt/index.d.ts +12 -0
  555. package/dist/prompt/index.d.ts.map +1 -0
  556. package/dist/prompt/index.js +13 -0
  557. package/dist/prompt/index.js.map +1 -0
  558. package/dist/prompt/types.d.ts +425 -0
  559. package/dist/prompt/types.d.ts.map +1 -0
  560. package/dist/prompt/types.js +19 -0
  561. package/dist/prompt/types.js.map +1 -0
  562. package/dist/sandbox/SandboxEngine.d.ts +225 -0
  563. package/dist/sandbox/SandboxEngine.d.ts.map +1 -0
  564. package/dist/sandbox/SandboxEngine.js +437 -0
  565. package/dist/sandbox/SandboxEngine.js.map +1 -0
  566. package/dist/sandbox/SandboxGuard.d.ts +47 -0
  567. package/dist/sandbox/SandboxGuard.d.ts.map +1 -0
  568. package/dist/sandbox/SandboxGuard.js +127 -0
  569. package/dist/sandbox/SandboxGuard.js.map +1 -0
  570. package/dist/sandbox/index.d.ts +23 -0
  571. package/dist/sandbox/index.d.ts.map +1 -0
  572. package/dist/sandbox/index.js +26 -0
  573. package/dist/sandbox/index.js.map +1 -0
  574. package/dist/server/DevServer.d.ts +120 -0
  575. package/dist/server/DevServer.d.ts.map +1 -0
  576. package/dist/server/DevServer.js +252 -0
  577. package/dist/server/DevServer.js.map +1 -0
  578. package/dist/server/ServerAttachment.d.ts +354 -0
  579. package/dist/server/ServerAttachment.d.ts.map +1 -0
  580. package/dist/server/ServerAttachment.js +709 -0
  581. package/dist/server/ServerAttachment.js.map +1 -0
  582. package/dist/server/ServerResolver.d.ts +24 -0
  583. package/dist/server/ServerResolver.d.ts.map +1 -0
  584. package/dist/server/ServerResolver.js +50 -0
  585. package/dist/server/ServerResolver.js.map +1 -0
  586. package/dist/server/autoDiscover.d.ts +75 -0
  587. package/dist/server/autoDiscover.d.ts.map +1 -0
  588. package/dist/server/autoDiscover.js +164 -0
  589. package/dist/server/autoDiscover.js.map +1 -0
  590. package/dist/server/index.d.ts +12 -0
  591. package/dist/server/index.d.ts.map +1 -0
  592. package/dist/server/index.js +11 -0
  593. package/dist/server/index.js.map +1 -0
  594. package/dist/server/startServer.d.ts +81 -0
  595. package/dist/server/startServer.d.ts.map +1 -0
  596. package/dist/server/startServer.js +143 -0
  597. package/dist/server/startServer.js.map +1 -0
  598. package/dist/state-sync/CausalEngine.d.ts +28 -0
  599. package/dist/state-sync/CausalEngine.d.ts.map +1 -0
  600. package/dist/state-sync/CausalEngine.js +17 -0
  601. package/dist/state-sync/CausalEngine.js.map +1 -0
  602. package/dist/state-sync/DescriptionDecorator.d.ts +31 -0
  603. package/dist/state-sync/DescriptionDecorator.d.ts.map +1 -0
  604. package/dist/state-sync/DescriptionDecorator.js +38 -0
  605. package/dist/state-sync/DescriptionDecorator.js.map +1 -0
  606. package/dist/state-sync/GlobMatcher.d.ts +29 -0
  607. package/dist/state-sync/GlobMatcher.d.ts.map +1 -0
  608. package/dist/state-sync/GlobMatcher.js +79 -0
  609. package/dist/state-sync/GlobMatcher.js.map +1 -0
  610. package/dist/state-sync/PolicyEngine.d.ts +75 -0
  611. package/dist/state-sync/PolicyEngine.d.ts.map +1 -0
  612. package/dist/state-sync/PolicyEngine.js +107 -0
  613. package/dist/state-sync/PolicyEngine.js.map +1 -0
  614. package/dist/state-sync/PolicyValidator.d.ts +67 -0
  615. package/dist/state-sync/PolicyValidator.d.ts.map +1 -0
  616. package/dist/state-sync/PolicyValidator.js +122 -0
  617. package/dist/state-sync/PolicyValidator.js.map +1 -0
  618. package/dist/state-sync/ResponseDecorator.d.ts +33 -0
  619. package/dist/state-sync/ResponseDecorator.d.ts.map +1 -0
  620. package/dist/state-sync/ResponseDecorator.js +20 -0
  621. package/dist/state-sync/ResponseDecorator.js.map +1 -0
  622. package/dist/state-sync/StateSyncBuilder.d.ts +77 -0
  623. package/dist/state-sync/StateSyncBuilder.d.ts.map +1 -0
  624. package/dist/state-sync/StateSyncBuilder.js +129 -0
  625. package/dist/state-sync/StateSyncBuilder.js.map +1 -0
  626. package/dist/state-sync/StateSyncLayer.d.ts +107 -0
  627. package/dist/state-sync/StateSyncLayer.d.ts.map +1 -0
  628. package/dist/state-sync/StateSyncLayer.js +158 -0
  629. package/dist/state-sync/StateSyncLayer.js.map +1 -0
  630. package/dist/state-sync/index.d.ts +27 -0
  631. package/dist/state-sync/index.d.ts.map +1 -0
  632. package/dist/state-sync/index.js +27 -0
  633. package/dist/state-sync/index.js.map +1 -0
  634. package/dist/state-sync/types.d.ts +174 -0
  635. package/dist/state-sync/types.d.ts.map +1 -0
  636. package/dist/state-sync/types.js +17 -0
  637. package/dist/state-sync/types.js.map +1 -0
  638. package/dist/testing/MvaMetaSymbol.d.ts +45 -0
  639. package/dist/testing/MvaMetaSymbol.d.ts.map +1 -0
  640. package/dist/testing/MvaMetaSymbol.js +34 -0
  641. package/dist/testing/MvaMetaSymbol.js.map +1 -0
  642. package/package.json +153 -0
@@ -0,0 +1,466 @@
1
+ // ============================================================================
2
+ // Diff Engine
3
+ // ============================================================================
4
+ const SEVERITY_ORDER = {
5
+ BREAKING: 3,
6
+ RISKY: 2,
7
+ SAFE: 1,
8
+ COSMETIC: 0,
9
+ };
10
+ /**
11
+ * Compute the semantic diff between two snapshots of a tool contract.
12
+ *
13
+ * @param before - Previous contract snapshot
14
+ * @param after - Current contract snapshot
15
+ * @returns Classified, sorted list of deltas
16
+ */
17
+ export function diffContracts(before, after) {
18
+ const deltas = [];
19
+ // Surface diff
20
+ diffSurface(before, after, deltas);
21
+ // Action-level diff
22
+ diffActions(before, after, deltas);
23
+ // Behavior diff
24
+ diffBehavior(before.behavior, after.behavior, deltas);
25
+ // Token Economics diff
26
+ diffTokenEconomics(before.tokenEconomics, after.tokenEconomics, deltas);
27
+ // Entitlements diff
28
+ diffEntitlements(before.entitlements, after.entitlements, deltas);
29
+ // Sort by severity (BREAKING first)
30
+ deltas.sort((a, b) => SEVERITY_ORDER[b.severity] - SEVERITY_ORDER[a.severity]);
31
+ const maxSeverity = deltas.length > 0
32
+ ? deltas[0].severity
33
+ : 'COSMETIC';
34
+ const digestChanged = before.behavior.egressSchemaDigest !== after.behavior.egressSchemaDigest
35
+ || before.behavior.systemRulesFingerprint !== after.behavior.systemRulesFingerprint;
36
+ return {
37
+ toolName: after.surface.name,
38
+ deltas,
39
+ maxSeverity,
40
+ digestChanged,
41
+ isBackwardsCompatible: maxSeverity !== 'BREAKING',
42
+ };
43
+ }
44
+ /**
45
+ * Diff tool surfaces but exclude actions (handled separately).
46
+ * @internal
47
+ */
48
+ function diffSurface(before, after, out) {
49
+ if (before.surface.name !== after.surface.name) {
50
+ out.push({
51
+ category: 'surface',
52
+ field: 'name',
53
+ severity: 'BREAKING',
54
+ description: 'Tool name changed',
55
+ before: before.surface.name,
56
+ after: after.surface.name,
57
+ });
58
+ }
59
+ if (before.surface.description !== after.surface.description) {
60
+ out.push({
61
+ category: 'surface',
62
+ field: 'description',
63
+ severity: 'COSMETIC',
64
+ description: 'Tool description changed',
65
+ before: before.surface.description ?? null,
66
+ after: after.surface.description ?? null,
67
+ });
68
+ }
69
+ if (before.surface.inputSchemaDigest !== after.surface.inputSchemaDigest) {
70
+ out.push({
71
+ category: 'surface',
72
+ field: 'inputSchemaDigest',
73
+ severity: 'BREAKING',
74
+ description: 'Input schema changed — previously calibrated LLM arguments may fail',
75
+ before: before.surface.inputSchemaDigest,
76
+ after: after.surface.inputSchemaDigest,
77
+ });
78
+ }
79
+ // Tags
80
+ const removedTags = before.surface.tags.filter(t => !after.surface.tags.includes(t));
81
+ const addedTags = after.surface.tags.filter(t => !before.surface.tags.includes(t));
82
+ if (removedTags.length > 0 || addedTags.length > 0) {
83
+ out.push({
84
+ category: 'surface',
85
+ field: 'tags',
86
+ severity: removedTags.length > 0 ? 'SAFE' : 'COSMETIC',
87
+ description: `Tags changed: ${removedTags.length > 0 ? `removed [${removedTags.join(', ')}]` : ''} ${addedTags.length > 0 ? `added [${addedTags.join(', ')}]` : ''}`.trim(),
88
+ before: JSON.stringify(before.surface.tags),
89
+ after: JSON.stringify(after.surface.tags),
90
+ });
91
+ }
92
+ }
93
+ /**
94
+ * Diff action-level contracts. Detects added, removed, and modified actions.
95
+ * @internal
96
+ */
97
+ function diffActions(before, after, out) {
98
+ const beforeKeys = new Set(Object.keys(before.surface.actions));
99
+ const afterKeys = new Set(Object.keys(after.surface.actions));
100
+ // Removed actions → BREAKING
101
+ for (const key of beforeKeys) {
102
+ if (!afterKeys.has(key)) {
103
+ out.push({
104
+ category: 'surface.action',
105
+ field: `actions.${key}`,
106
+ severity: 'BREAKING',
107
+ description: `Action "${key}" was removed`,
108
+ before: key,
109
+ after: null,
110
+ });
111
+ }
112
+ }
113
+ // Added actions → SAFE
114
+ for (const key of afterKeys) {
115
+ if (!beforeKeys.has(key)) {
116
+ out.push({
117
+ category: 'surface.action',
118
+ field: `actions.${key}`,
119
+ severity: 'SAFE',
120
+ description: `Action "${key}" was added`,
121
+ before: null,
122
+ after: key,
123
+ });
124
+ }
125
+ }
126
+ // Modified actions
127
+ for (const key of beforeKeys) {
128
+ if (afterKeys.has(key)) {
129
+ diffSingleAction(key, before.surface.actions[key], after.surface.actions[key], out);
130
+ }
131
+ }
132
+ }
133
+ /**
134
+ * Diff a single action's contract fields.
135
+ * @internal
136
+ */
137
+ function diffSingleAction(actionKey, before, after, out) {
138
+ if (before.destructive !== after.destructive) {
139
+ out.push({
140
+ category: 'surface.action',
141
+ field: `actions.${actionKey}.destructive`,
142
+ severity: 'BREAKING',
143
+ description: `Action "${actionKey}" destructive flag changed: ${before.destructive} → ${after.destructive}`,
144
+ before: String(before.destructive),
145
+ after: String(after.destructive),
146
+ });
147
+ }
148
+ if (before.idempotent !== after.idempotent) {
149
+ out.push({
150
+ category: 'surface.action',
151
+ field: `actions.${actionKey}.idempotent`,
152
+ severity: 'RISKY',
153
+ description: `Action "${actionKey}" idempotent flag changed`,
154
+ before: String(before.idempotent),
155
+ after: String(after.idempotent),
156
+ });
157
+ }
158
+ if (before.readOnly !== after.readOnly) {
159
+ out.push({
160
+ category: 'surface.action',
161
+ field: `actions.${actionKey}.readOnly`,
162
+ severity: 'BREAKING',
163
+ description: `Action "${actionKey}" readOnly flag changed: ${before.readOnly} → ${after.readOnly}`,
164
+ before: String(before.readOnly),
165
+ after: String(after.readOnly),
166
+ });
167
+ }
168
+ // Required fields
169
+ const removedFields = before.requiredFields.filter(f => !after.requiredFields.includes(f));
170
+ const addedFields = after.requiredFields.filter(f => !before.requiredFields.includes(f));
171
+ if (removedFields.length > 0) {
172
+ out.push({
173
+ category: 'surface.action',
174
+ field: `actions.${actionKey}.requiredFields`,
175
+ severity: 'SAFE',
176
+ description: `Action "${actionKey}" no longer requires: [${removedFields.join(', ')}]`,
177
+ before: JSON.stringify(before.requiredFields),
178
+ after: JSON.stringify(after.requiredFields),
179
+ });
180
+ }
181
+ if (addedFields.length > 0) {
182
+ out.push({
183
+ category: 'surface.action',
184
+ field: `actions.${actionKey}.requiredFields`,
185
+ severity: 'BREAKING',
186
+ description: `Action "${actionKey}" now requires new fields: [${addedFields.join(', ')}]`,
187
+ before: JSON.stringify(before.requiredFields),
188
+ after: JSON.stringify(after.requiredFields),
189
+ });
190
+ }
191
+ // Presenter change
192
+ if (before.presenterName !== after.presenterName) {
193
+ out.push({
194
+ category: 'surface.action',
195
+ field: `actions.${actionKey}.presenterName`,
196
+ severity: before.presenterName && !after.presenterName ? 'BREAKING' : 'RISKY',
197
+ description: `Action "${actionKey}" Presenter changed: ${before.presenterName ?? 'none'} → ${after.presenterName ?? 'none'}`,
198
+ before: before.presenterName ?? null,
199
+ after: after.presenterName ?? null,
200
+ });
201
+ }
202
+ if (before.inputSchemaDigest !== after.inputSchemaDigest) {
203
+ out.push({
204
+ category: 'surface.action',
205
+ field: `actions.${actionKey}.inputSchemaDigest`,
206
+ severity: 'RISKY',
207
+ description: `Action "${actionKey}" input schema changed`,
208
+ before: before.inputSchemaDigest,
209
+ after: after.inputSchemaDigest,
210
+ });
211
+ }
212
+ }
213
+ /**
214
+ * Diff behavioral contracts.
215
+ * @internal
216
+ */
217
+ function diffBehavior(before, after, out) {
218
+ // Egress schema
219
+ if (before.egressSchemaDigest !== after.egressSchemaDigest) {
220
+ out.push({
221
+ category: 'behavior.egress',
222
+ field: 'egressSchemaDigest',
223
+ severity: 'BREAKING',
224
+ description: 'Presenter egress schema changed — LLM response parsing may break',
225
+ before: before.egressSchemaDigest,
226
+ after: after.egressSchemaDigest,
227
+ });
228
+ }
229
+ // System rules
230
+ if (before.systemRulesFingerprint !== after.systemRulesFingerprint) {
231
+ out.push({
232
+ category: 'behavior.rules',
233
+ field: 'systemRulesFingerprint',
234
+ severity: 'BREAKING',
235
+ description: 'System rules changed — LLM behavioral calibration invalidated',
236
+ before: before.systemRulesFingerprint,
237
+ after: after.systemRulesFingerprint,
238
+ });
239
+ }
240
+ // Cognitive guardrails
241
+ if (before.cognitiveGuardrails.agentLimitMax !== after.cognitiveGuardrails.agentLimitMax) {
242
+ const severity = after.cognitiveGuardrails.agentLimitMax === null
243
+ ? 'RISKY' // Removed limit → risk of context flooding
244
+ : 'SAFE';
245
+ out.push({
246
+ category: 'behavior.guardrails',
247
+ field: 'agentLimitMax',
248
+ severity,
249
+ description: `Agent limit changed: ${before.cognitiveGuardrails.agentLimitMax ?? 'unlimited'} → ${after.cognitiveGuardrails.agentLimitMax ?? 'unlimited'}`,
250
+ before: String(before.cognitiveGuardrails.agentLimitMax),
251
+ after: String(after.cognitiveGuardrails.agentLimitMax),
252
+ });
253
+ }
254
+ if (before.cognitiveGuardrails.egressMaxBytes !== after.cognitiveGuardrails.egressMaxBytes) {
255
+ const severity = after.cognitiveGuardrails.egressMaxBytes === null
256
+ ? 'RISKY' // Removed cap → risk of payload inflation
257
+ : 'SAFE';
258
+ out.push({
259
+ category: 'behavior.guardrails',
260
+ field: 'egressMaxBytes',
261
+ severity,
262
+ description: `Egress max bytes changed: ${before.cognitiveGuardrails.egressMaxBytes ?? 'unlimited'} → ${after.cognitiveGuardrails.egressMaxBytes ?? 'unlimited'}`,
263
+ before: String(before.cognitiveGuardrails.egressMaxBytes),
264
+ after: String(after.cognitiveGuardrails.egressMaxBytes),
265
+ });
266
+ }
267
+ // Middleware chain
268
+ const beforeMw = before.middlewareChain.join(',');
269
+ const afterMw = after.middlewareChain.join(',');
270
+ if (beforeMw !== afterMw) {
271
+ out.push({
272
+ category: 'behavior.middleware',
273
+ field: 'middlewareChain',
274
+ severity: 'RISKY',
275
+ description: 'Middleware chain changed — execution semantics may differ',
276
+ before: beforeMw || null,
277
+ after: afterMw || null,
278
+ });
279
+ }
280
+ // State sync
281
+ if (before.stateSyncFingerprint !== after.stateSyncFingerprint) {
282
+ out.push({
283
+ category: 'behavior.stateSync',
284
+ field: 'stateSyncFingerprint',
285
+ severity: 'RISKY',
286
+ description: 'State sync policy changed',
287
+ before: before.stateSyncFingerprint,
288
+ after: after.stateSyncFingerprint,
289
+ });
290
+ }
291
+ // Affordance topology
292
+ const beforeAffordances = before.affordanceTopology.join(',');
293
+ const afterAffordances = after.affordanceTopology.join(',');
294
+ if (beforeAffordances !== afterAffordances) {
295
+ out.push({
296
+ category: 'behavior.affordances',
297
+ field: 'affordanceTopology',
298
+ severity: 'RISKY',
299
+ description: 'Affordance topology changed — suggested action navigation graph differs',
300
+ before: beforeAffordances || null,
301
+ after: afterAffordances || null,
302
+ });
303
+ }
304
+ // Concurrency
305
+ if (before.concurrencyFingerprint !== after.concurrencyFingerprint) {
306
+ out.push({
307
+ category: 'behavior.stateSync',
308
+ field: 'concurrencyFingerprint',
309
+ severity: 'RISKY',
310
+ description: 'Concurrency configuration changed',
311
+ before: before.concurrencyFingerprint,
312
+ after: after.concurrencyFingerprint,
313
+ });
314
+ }
315
+ // Embedded presenters
316
+ const beforePresenters = before.embeddedPresenters.join(',');
317
+ const afterPresenters = after.embeddedPresenters.join(',');
318
+ if (beforePresenters !== afterPresenters) {
319
+ out.push({
320
+ category: 'behavior.egress',
321
+ field: 'embeddedPresenters',
322
+ severity: 'RISKY',
323
+ description: 'Embedded Presenter set changed — response composition differs',
324
+ before: beforePresenters || null,
325
+ after: afterPresenters || null,
326
+ });
327
+ }
328
+ }
329
+ /**
330
+ * Diff token economics profiles.
331
+ * @internal
332
+ */
333
+ function diffTokenEconomics(before, after, out) {
334
+ if (before.inflationRisk !== after.inflationRisk) {
335
+ const escalated = SEVERITY_ORDER[riskToSeverity(after.inflationRisk)]
336
+ > SEVERITY_ORDER[riskToSeverity(before.inflationRisk)];
337
+ out.push({
338
+ category: 'tokenEconomics',
339
+ field: 'inflationRisk',
340
+ severity: escalated ? 'BREAKING' : 'SAFE',
341
+ description: `Cognitive overload risk changed: ${before.inflationRisk} → ${after.inflationRisk}`,
342
+ before: before.inflationRisk,
343
+ after: after.inflationRisk,
344
+ });
345
+ }
346
+ if (before.unboundedCollection !== after.unboundedCollection) {
347
+ out.push({
348
+ category: 'tokenEconomics',
349
+ field: 'unboundedCollection',
350
+ severity: after.unboundedCollection ? 'RISKY' : 'SAFE',
351
+ description: `Unbounded collection flag: ${before.unboundedCollection} → ${after.unboundedCollection}`,
352
+ before: String(before.unboundedCollection),
353
+ after: String(after.unboundedCollection),
354
+ });
355
+ }
356
+ }
357
+ /**
358
+ * Map inflation risk to comparable severity.
359
+ * @internal
360
+ */
361
+ function riskToSeverity(risk) {
362
+ switch (risk) {
363
+ case 'critical': return 'BREAKING';
364
+ case 'high': return 'RISKY';
365
+ case 'medium': return 'SAFE';
366
+ case 'low': return 'COSMETIC';
367
+ }
368
+ }
369
+ /**
370
+ * Diff handler entitlements.
371
+ * @internal
372
+ */
373
+ function diffEntitlements(before, after, out) {
374
+ const entitlementFlags = ['filesystem', 'network', 'subprocess', 'crypto', 'codeEvaluation'];
375
+ for (const flag of entitlementFlags) {
376
+ if (!before[flag] && after[flag]) {
377
+ out.push({
378
+ category: 'entitlements',
379
+ field: flag,
380
+ severity: 'BREAKING',
381
+ description: `Handler gained "${flag}" entitlement — blast radius expanded`,
382
+ before: 'false',
383
+ after: 'true',
384
+ });
385
+ }
386
+ else if (before[flag] && !after[flag]) {
387
+ out.push({
388
+ category: 'entitlements',
389
+ field: flag,
390
+ severity: 'SAFE',
391
+ description: `Handler lost "${flag}" entitlement — blast radius reduced`,
392
+ before: 'true',
393
+ after: 'false',
394
+ });
395
+ }
396
+ }
397
+ }
398
+ // ============================================================================
399
+ // Diff Formatting
400
+ // ============================================================================
401
+ /**
402
+ * Format a diff result as a human-readable report.
403
+ *
404
+ * Designed for both terminal output and injection into
405
+ * LLM correction prompts (Self-Healing Context).
406
+ */
407
+ export function formatDiffReport(result) {
408
+ if (result.deltas.length === 0) {
409
+ return `[${result.toolName}] No contract changes detected.`;
410
+ }
411
+ const lines = [
412
+ `[${result.toolName}] Contract diff: ${result.deltas.length} change(s), max severity: ${result.maxSeverity}`,
413
+ '',
414
+ ];
415
+ for (const delta of result.deltas) {
416
+ lines.push(` [${delta.severity}] ${delta.field}: ${delta.description}`);
417
+ lines.push(` ${formatArrow(delta)}`);
418
+ }
419
+ return lines.join('\n');
420
+ }
421
+ /**
422
+ * Format deltas as XML for injection into LLM correction prompts.
423
+ * Compatible with ValidationErrorFormatter's XML format.
424
+ */
425
+ export function formatDeltasAsXml(deltas) {
426
+ if (deltas.length === 0)
427
+ return '';
428
+ const lines = ['<contract_changes>'];
429
+ for (const delta of deltas) {
430
+ lines.push(` <change severity="${escapeXml(delta.severity)}" field="${escapeXml(delta.field)}">`);
431
+ lines.push(` <description>${escapeXml(delta.description)}</description>`);
432
+ if (delta.before !== null)
433
+ lines.push(` <before>${escapeXml(delta.before)}</before>`);
434
+ if (delta.after !== null)
435
+ lines.push(` <after>${escapeXml(delta.after)}</after>`);
436
+ lines.push(' </change>');
437
+ }
438
+ lines.push('</contract_changes>');
439
+ return lines.join('\n');
440
+ }
441
+ // ============================================================================
442
+ // Utility
443
+ // ============================================================================
444
+ function truncate(s, maxLen) {
445
+ return s.length > maxLen ? s.slice(0, maxLen - 3) + '...' : s;
446
+ }
447
+ /**
448
+ * Format the before→after arrow for a contract delta.
449
+ * @internal
450
+ */
451
+ function formatArrow(delta) {
452
+ if (delta.before !== null && delta.after !== null) {
453
+ return `${truncate(delta.before, 40)} → ${truncate(delta.after, 40)}`;
454
+ }
455
+ return delta.after !== null
456
+ ? `(added) ${truncate(delta.after, 40)}`
457
+ : `(removed) ${truncate(delta.before, 40)}`;
458
+ }
459
+ function escapeXml(s) {
460
+ return s
461
+ .replace(/&/g, '&amp;')
462
+ .replace(/</g, '&lt;')
463
+ .replace(/>/g, '&gt;')
464
+ .replace(/"/g, '&quot;');
465
+ }
466
+ //# sourceMappingURL=ContractDiff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ContractDiff.js","sourceRoot":"","sources":["../../src/introspection/ContractDiff.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,143 @@
1
+ import type { ServerDigest } from './BehaviorDigest.js';
2
+ /**
3
+ * Configuration for zero-trust attestation.
4
+ *
5
+ * Passed to `AttachOptions.zeroTrust` in ServerAttachment.
6
+ */
7
+ export interface ZeroTrustConfig {
8
+ /**
9
+ * The signing strategy to use.
10
+ * - `'hmac'` — HMAC-SHA256 with a shared secret (built-in)
11
+ * - A custom `AttestationSigner` for external KMS integration
12
+ */
13
+ readonly signer: 'hmac' | AttestationSigner;
14
+ /**
15
+ * For `'hmac'` mode: the shared secret.
16
+ * Read from environment in production (never hardcode).
17
+ */
18
+ readonly secret?: string;
19
+ /**
20
+ * Expected server digest hash from a known-good build.
21
+ * When set, runtime verification will fail-fast if the
22
+ * re-computed digest doesn't match.
23
+ */
24
+ readonly expectedDigest?: string;
25
+ /**
26
+ * Whether to fail-fast on attestation failure.
27
+ * Default: `true` in production, `false` in development.
28
+ */
29
+ readonly failOnMismatch?: boolean;
30
+ /**
31
+ * Whether to expose the attestation in MCP capabilities.
32
+ * Default: `true`.
33
+ */
34
+ readonly exposeCapability?: boolean;
35
+ }
36
+ /**
37
+ * Pluggable signer interface for external KMS integration.
38
+ *
39
+ * Implementations should be stateless and async-safe.
40
+ * The `sign()` method receives the canonical digest string
41
+ * and returns a signature (hex-encoded or base64).
42
+ */
43
+ export interface AttestationSigner {
44
+ /** Human-readable name (e.g., 'sigstore', 'aws-kms') */
45
+ readonly name: string;
46
+ /** Sign a digest string */
47
+ sign(digest: string): Promise<string>;
48
+ /** Verify a digest against a signature */
49
+ verify(digest: string, signature: string): Promise<boolean>;
50
+ }
51
+ /**
52
+ * Result of an attestation operation.
53
+ */
54
+ export interface AttestationResult {
55
+ /** Whether the attestation was successful */
56
+ readonly valid: boolean;
57
+ /** The computed digest */
58
+ readonly computedDigest: string;
59
+ /** The expected digest (if configured) */
60
+ readonly expectedDigest: string | null;
61
+ /** The signature (if signing was performed) */
62
+ readonly signature: string | null;
63
+ /** Signer identity */
64
+ readonly signerName: string;
65
+ /** ISO-8601 timestamp of attestation */
66
+ readonly attestedAt: string;
67
+ /** Human-readable error message, if invalid */
68
+ readonly error: string | null;
69
+ }
70
+ /**
71
+ * Capability structure exposed via MCP `server.capabilities`.
72
+ *
73
+ * Clients can inspect this to verify the server's behavioral
74
+ * identity before trusting tool responses.
75
+ */
76
+ export interface VurbTrustCapability {
77
+ /** Current server behavioral digest */
78
+ readonly serverDigest: string;
79
+ /** Attestation signature (if signed) */
80
+ readonly signature: string | null;
81
+ /** Signer identity */
82
+ readonly signerName: string;
83
+ /** ISO-8601 timestamp of last attestation */
84
+ readonly attestedAt: string;
85
+ /** Number of tools covered by the attestation */
86
+ readonly toolCount: number;
87
+ /** Whether the attestation passed verification */
88
+ readonly verified: boolean;
89
+ }
90
+ /**
91
+ * Create an HMAC-SHA256 signer from a shared secret.
92
+ *
93
+ * @param secret - The shared secret (should be ≥32 bytes)
94
+ * @returns An `AttestationSigner` using HMAC-SHA256
95
+ */
96
+ export declare function createHmacSigner(secret: string): AttestationSigner;
97
+ /**
98
+ * Sign a server digest and produce an attestation result.
99
+ *
100
+ * @param serverDigest - The server's behavioral digest
101
+ * @param config - Zero-trust configuration
102
+ * @returns Attestation result with signature
103
+ */
104
+ export declare function attestServerDigest(serverDigest: ServerDigest, config: ZeroTrustConfig): Promise<AttestationResult>;
105
+ /**
106
+ * Verify a previously signed attestation.
107
+ *
108
+ * @param serverDigest - The current server digest
109
+ * @param signature - The signature to verify
110
+ * @param config - Zero-trust configuration
111
+ * @returns Attestation result with verification status
112
+ */
113
+ export declare function verifyAttestation(serverDigest: ServerDigest, signature: string, config: ZeroTrustConfig): Promise<AttestationResult>;
114
+ /**
115
+ * Runtime capability pinning — check that the current digest
116
+ * matches what was attested at build time.
117
+ *
118
+ * Designed to be called once at server startup in the `attach()` flow.
119
+ *
120
+ * @param currentDigest - Re-computed server digest
121
+ * @param config - Zero-trust configuration
122
+ * @returns Attestation result
123
+ * @throws If `failOnMismatch` is true and the digest doesn't match
124
+ */
125
+ export declare function verifyCapabilityPin(currentDigest: ServerDigest, config: ZeroTrustConfig): Promise<AttestationResult>;
126
+ /**
127
+ * Build the `vurbTrust` capability object for MCP exposure.
128
+ *
129
+ * @param attestation - A completed attestation result
130
+ * @param toolCount - Number of tools in the registry
131
+ * @returns Capability structure for `server.capabilities`
132
+ */
133
+ export declare function buildTrustCapability(attestation: AttestationResult, toolCount: number): VurbTrustCapability;
134
+ /**
135
+ * Error thrown when zero-trust attestation fails with failOnMismatch.
136
+ *
137
+ * Carries the full `AttestationResult` for programmatic inspection.
138
+ */
139
+ export declare class AttestationError extends Error {
140
+ readonly attestation: AttestationResult;
141
+ constructor(message: string, attestation: AttestationResult);
142
+ }
143
+ //# sourceMappingURL=CryptoAttestation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CryptoAttestation.d.ts","sourceRoot":"","sources":["../../src/introspection/CryptoAttestation.ts"],"names":[],"mappings":"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"}