@actrun_ai/tastekit-core 0.1.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 (389) hide show
  1. package/dist/compiler/compiler.d.ts +24 -0
  2. package/dist/compiler/compiler.d.ts.map +1 -0
  3. package/dist/compiler/compiler.js +153 -0
  4. package/dist/compiler/compiler.js.map +1 -0
  5. package/dist/compiler/constitution-compiler.d.ts +11 -0
  6. package/dist/compiler/constitution-compiler.d.ts.map +1 -0
  7. package/dist/compiler/constitution-compiler.js +154 -0
  8. package/dist/compiler/constitution-compiler.js.map +1 -0
  9. package/dist/compiler/derivation.d.ts +125 -0
  10. package/dist/compiler/derivation.d.ts.map +1 -0
  11. package/dist/compiler/derivation.js +109 -0
  12. package/dist/compiler/derivation.js.map +1 -0
  13. package/dist/compiler/guardrails-compiler.d.ts +11 -0
  14. package/dist/compiler/guardrails-compiler.d.ts.map +1 -0
  15. package/dist/compiler/guardrails-compiler.js +362 -0
  16. package/dist/compiler/guardrails-compiler.js.map +1 -0
  17. package/dist/compiler/index.d.ts +13 -0
  18. package/dist/compiler/index.d.ts.map +1 -0
  19. package/dist/compiler/index.js +13 -0
  20. package/dist/compiler/index.js.map +1 -0
  21. package/dist/compiler/memory-compiler.d.ts +12 -0
  22. package/dist/compiler/memory-compiler.d.ts.map +1 -0
  23. package/dist/compiler/memory-compiler.js +293 -0
  24. package/dist/compiler/memory-compiler.js.map +1 -0
  25. package/dist/compiler/playbook-compiler.d.ts +15 -0
  26. package/dist/compiler/playbook-compiler.d.ts.map +1 -0
  27. package/dist/compiler/playbook-compiler.js +1143 -0
  28. package/dist/compiler/playbook-compiler.js.map +1 -0
  29. package/dist/compiler/skills-compiler.d.ts +15 -0
  30. package/dist/compiler/skills-compiler.d.ts.map +1 -0
  31. package/dist/compiler/skills-compiler.js +203 -0
  32. package/dist/compiler/skills-compiler.js.map +1 -0
  33. package/dist/domains/development-agent/domain.d.ts +8 -0
  34. package/dist/domains/development-agent/domain.d.ts.map +1 -0
  35. package/dist/domains/development-agent/domain.js +35 -0
  36. package/dist/domains/development-agent/domain.js.map +1 -0
  37. package/dist/domains/development-agent/index.d.ts +3 -0
  38. package/dist/domains/development-agent/index.d.ts.map +1 -0
  39. package/dist/domains/development-agent/index.js +3 -0
  40. package/dist/domains/development-agent/index.js.map +1 -0
  41. package/dist/domains/development-agent/rubric.d.ts +13 -0
  42. package/dist/domains/development-agent/rubric.d.ts.map +1 -0
  43. package/dist/domains/development-agent/rubric.js +451 -0
  44. package/dist/domains/development-agent/rubric.js.map +1 -0
  45. package/dist/domains/development-agent/skills/code-review.d.ts +25 -0
  46. package/dist/domains/development-agent/skills/code-review.d.ts.map +1 -0
  47. package/dist/domains/development-agent/skills/code-review.js +146 -0
  48. package/dist/domains/development-agent/skills/code-review.js.map +1 -0
  49. package/dist/domains/development-agent/skills/debugging-issues.d.ts +25 -0
  50. package/dist/domains/development-agent/skills/debugging-issues.d.ts.map +1 -0
  51. package/dist/domains/development-agent/skills/debugging-issues.js +155 -0
  52. package/dist/domains/development-agent/skills/debugging-issues.js.map +1 -0
  53. package/dist/domains/development-agent/skills/documenting-code.d.ts +19 -0
  54. package/dist/domains/development-agent/skills/documenting-code.d.ts.map +1 -0
  55. package/dist/domains/development-agent/skills/documenting-code.js +92 -0
  56. package/dist/domains/development-agent/skills/documenting-code.js.map +1 -0
  57. package/dist/domains/development-agent/skills/index.d.ts +55 -0
  58. package/dist/domains/development-agent/skills/index.d.ts.map +1 -0
  59. package/dist/domains/development-agent/skills/index.js +19 -0
  60. package/dist/domains/development-agent/skills/index.js.map +1 -0
  61. package/dist/domains/development-agent/skills/refactor-plan.d.ts +19 -0
  62. package/dist/domains/development-agent/skills/refactor-plan.d.ts.map +1 -0
  63. package/dist/domains/development-agent/skills/refactor-plan.js +117 -0
  64. package/dist/domains/development-agent/skills/refactor-plan.js.map +1 -0
  65. package/dist/domains/development-agent/skills/writing-tests.d.ts +20 -0
  66. package/dist/domains/development-agent/skills/writing-tests.d.ts.map +1 -0
  67. package/dist/domains/development-agent/skills/writing-tests.js +93 -0
  68. package/dist/domains/development-agent/skills/writing-tests.js.map +1 -0
  69. package/dist/domains/general-agent/domain.d.ts +9 -0
  70. package/dist/domains/general-agent/domain.d.ts.map +1 -0
  71. package/dist/domains/general-agent/domain.js +36 -0
  72. package/dist/domains/general-agent/domain.js.map +1 -0
  73. package/dist/domains/general-agent/index.d.ts +4 -0
  74. package/dist/domains/general-agent/index.d.ts.map +1 -0
  75. package/dist/domains/general-agent/index.js +4 -0
  76. package/dist/domains/general-agent/index.js.map +1 -0
  77. package/dist/domains/general-agent/rubric.d.ts +8 -0
  78. package/dist/domains/general-agent/rubric.d.ts.map +1 -0
  79. package/dist/domains/general-agent/rubric.js +332 -0
  80. package/dist/domains/general-agent/rubric.js.map +1 -0
  81. package/dist/domains/general-agent/skills/context-synthesis.d.ts +19 -0
  82. package/dist/domains/general-agent/skills/context-synthesis.d.ts.map +1 -0
  83. package/dist/domains/general-agent/skills/context-synthesis.js +94 -0
  84. package/dist/domains/general-agent/skills/context-synthesis.js.map +1 -0
  85. package/dist/domains/general-agent/skills/index.d.ts +32 -0
  86. package/dist/domains/general-agent/skills/index.d.ts.map +1 -0
  87. package/dist/domains/general-agent/skills/index.js +11 -0
  88. package/dist/domains/general-agent/skills/index.js.map +1 -0
  89. package/dist/domains/general-agent/skills/task-orchestration.d.ts +19 -0
  90. package/dist/domains/general-agent/skills/task-orchestration.d.ts.map +1 -0
  91. package/dist/domains/general-agent/skills/task-orchestration.js +101 -0
  92. package/dist/domains/general-agent/skills/task-orchestration.js.map +1 -0
  93. package/dist/domains/index.d.ts +21 -0
  94. package/dist/domains/index.d.ts.map +1 -0
  95. package/dist/domains/index.js +37 -0
  96. package/dist/domains/index.js.map +1 -0
  97. package/dist/domains/types.d.ts +22 -0
  98. package/dist/domains/types.d.ts.map +1 -0
  99. package/dist/domains/types.js +2 -0
  100. package/dist/domains/types.js.map +1 -0
  101. package/dist/drift/consolidator.d.ts +47 -0
  102. package/dist/drift/consolidator.d.ts.map +1 -0
  103. package/dist/drift/consolidator.js +116 -0
  104. package/dist/drift/consolidator.js.map +1 -0
  105. package/dist/drift/detector.d.ts +79 -0
  106. package/dist/drift/detector.d.ts.map +1 -0
  107. package/dist/drift/detector.js +424 -0
  108. package/dist/drift/detector.js.map +1 -0
  109. package/dist/drift/index.d.ts +9 -0
  110. package/dist/drift/index.d.ts.map +1 -0
  111. package/dist/drift/index.js +9 -0
  112. package/dist/drift/index.js.map +1 -0
  113. package/dist/drift/proposal.d.ts +108 -0
  114. package/dist/drift/proposal.d.ts.map +1 -0
  115. package/dist/drift/proposal.js +2 -0
  116. package/dist/drift/proposal.js.map +1 -0
  117. package/dist/eval/index.d.ts +9 -0
  118. package/dist/eval/index.d.ts.map +1 -0
  119. package/dist/eval/index.js +9 -0
  120. package/dist/eval/index.js.map +1 -0
  121. package/dist/eval/judge.d.ts +33 -0
  122. package/dist/eval/judge.d.ts.map +1 -0
  123. package/dist/eval/judge.js +209 -0
  124. package/dist/eval/judge.js.map +1 -0
  125. package/dist/eval/replay.d.ts +23 -0
  126. package/dist/eval/replay.d.ts.map +1 -0
  127. package/dist/eval/replay.js +42 -0
  128. package/dist/eval/replay.js.map +1 -0
  129. package/dist/eval/runner.d.ts +35 -0
  130. package/dist/eval/runner.d.ts.map +1 -0
  131. package/dist/eval/runner.js +52 -0
  132. package/dist/eval/runner.js.map +1 -0
  133. package/dist/generators/agents-md-generator.d.ts +9 -0
  134. package/dist/generators/agents-md-generator.d.ts.map +1 -0
  135. package/dist/generators/agents-md-generator.js +71 -0
  136. package/dist/generators/agents-md-generator.js.map +1 -0
  137. package/dist/generators/blocks/domain-context.d.ts +7 -0
  138. package/dist/generators/blocks/domain-context.d.ts.map +1 -0
  139. package/dist/generators/blocks/domain-context.js +26 -0
  140. package/dist/generators/blocks/domain-context.js.map +1 -0
  141. package/dist/generators/blocks/drift-awareness.d.ts +6 -0
  142. package/dist/generators/blocks/drift-awareness.d.ts.map +1 -0
  143. package/dist/generators/blocks/drift-awareness.js +28 -0
  144. package/dist/generators/blocks/drift-awareness.js.map +1 -0
  145. package/dist/generators/blocks/evaluation-criteria.d.ts +7 -0
  146. package/dist/generators/blocks/evaluation-criteria.d.ts.map +1 -0
  147. package/dist/generators/blocks/evaluation-criteria.js +18 -0
  148. package/dist/generators/blocks/evaluation-criteria.js.map +1 -0
  149. package/dist/generators/blocks/guardrails.d.ts +6 -0
  150. package/dist/generators/blocks/guardrails.d.ts.map +1 -0
  151. package/dist/generators/blocks/guardrails.js +44 -0
  152. package/dist/generators/blocks/guardrails.js.map +1 -0
  153. package/dist/generators/blocks/identity.d.ts +6 -0
  154. package/dist/generators/blocks/identity.d.ts.map +1 -0
  155. package/dist/generators/blocks/identity.js +36 -0
  156. package/dist/generators/blocks/identity.js.map +1 -0
  157. package/dist/generators/blocks/memory-policy.d.ts +6 -0
  158. package/dist/generators/blocks/memory-policy.d.ts.map +1 -0
  159. package/dist/generators/blocks/memory-policy.js +34 -0
  160. package/dist/generators/blocks/memory-policy.js.map +1 -0
  161. package/dist/generators/blocks/playbook-index.d.ts +7 -0
  162. package/dist/generators/blocks/playbook-index.d.ts.map +1 -0
  163. package/dist/generators/blocks/playbook-index.js +14 -0
  164. package/dist/generators/blocks/playbook-index.js.map +1 -0
  165. package/dist/generators/blocks/session-rhythm.d.ts +6 -0
  166. package/dist/generators/blocks/session-rhythm.d.ts.map +1 -0
  167. package/dist/generators/blocks/session-rhythm.js +11 -0
  168. package/dist/generators/blocks/session-rhythm.js.map +1 -0
  169. package/dist/generators/blocks/skills-index.d.ts +6 -0
  170. package/dist/generators/blocks/skills-index.d.ts.map +1 -0
  171. package/dist/generators/blocks/skills-index.js +36 -0
  172. package/dist/generators/blocks/skills-index.js.map +1 -0
  173. package/dist/generators/blocks/tool-usage.d.ts +6 -0
  174. package/dist/generators/blocks/tool-usage.d.ts.map +1 -0
  175. package/dist/generators/blocks/tool-usage.js +31 -0
  176. package/dist/generators/blocks/tool-usage.js.map +1 -0
  177. package/dist/generators/blocks/vocabulary.d.ts +7 -0
  178. package/dist/generators/blocks/vocabulary.d.ts.map +1 -0
  179. package/dist/generators/blocks/vocabulary.js +27 -0
  180. package/dist/generators/blocks/vocabulary.js.map +1 -0
  181. package/dist/generators/claude-hooks-compat.d.ts +33 -0
  182. package/dist/generators/claude-hooks-compat.d.ts.map +1 -0
  183. package/dist/generators/claude-hooks-compat.js +322 -0
  184. package/dist/generators/claude-hooks-compat.js.map +1 -0
  185. package/dist/generators/claude-md-generator.d.ts +12 -0
  186. package/dist/generators/claude-md-generator.d.ts.map +1 -0
  187. package/dist/generators/claude-md-generator.js +60 -0
  188. package/dist/generators/claude-md-generator.js.map +1 -0
  189. package/dist/generators/index.d.ts +11 -0
  190. package/dist/generators/index.d.ts.map +1 -0
  191. package/dist/generators/index.js +11 -0
  192. package/dist/generators/index.js.map +1 -0
  193. package/dist/generators/soul-md-generator.d.ts +9 -0
  194. package/dist/generators/soul-md-generator.d.ts.map +1 -0
  195. package/dist/generators/soul-md-generator.js +104 -0
  196. package/dist/generators/soul-md-generator.js.map +1 -0
  197. package/dist/generators/types.d.ts +55 -0
  198. package/dist/generators/types.d.ts.map +1 -0
  199. package/dist/generators/types.js +7 -0
  200. package/dist/generators/types.js.map +1 -0
  201. package/dist/index.d.ts +19 -0
  202. package/dist/index.d.ts.map +1 -0
  203. package/dist/index.js +20 -0
  204. package/dist/index.js.map +1 -0
  205. package/dist/interview/index.d.ts +11 -0
  206. package/dist/interview/index.d.ts.map +1 -0
  207. package/dist/interview/index.js +11 -0
  208. package/dist/interview/index.js.map +1 -0
  209. package/dist/interview/interviewer.d.ts +94 -0
  210. package/dist/interview/interviewer.d.ts.map +1 -0
  211. package/dist/interview/interviewer.js +516 -0
  212. package/dist/interview/interviewer.js.map +1 -0
  213. package/dist/interview/questions.d.ts +15 -0
  214. package/dist/interview/questions.d.ts.map +1 -0
  215. package/dist/interview/questions.js +86 -0
  216. package/dist/interview/questions.js.map +1 -0
  217. package/dist/interview/rubric.d.ts +265 -0
  218. package/dist/interview/rubric.d.ts.map +1 -0
  219. package/dist/interview/rubric.js +74 -0
  220. package/dist/interview/rubric.js.map +1 -0
  221. package/dist/interview/session.d.ts +9 -0
  222. package/dist/interview/session.d.ts.map +1 -0
  223. package/dist/interview/session.js +33 -0
  224. package/dist/interview/session.js.map +1 -0
  225. package/dist/interview/universal-rubric.d.ts +11 -0
  226. package/dist/interview/universal-rubric.d.ts.map +1 -0
  227. package/dist/interview/universal-rubric.js +165 -0
  228. package/dist/interview/universal-rubric.js.map +1 -0
  229. package/dist/llm/index.d.ts +8 -0
  230. package/dist/llm/index.d.ts.map +1 -0
  231. package/dist/llm/index.js +8 -0
  232. package/dist/llm/index.js.map +1 -0
  233. package/dist/llm/provider.d.ts +62 -0
  234. package/dist/llm/provider.d.ts.map +1 -0
  235. package/dist/llm/provider.js +24 -0
  236. package/dist/llm/provider.js.map +1 -0
  237. package/dist/llm/providers/anthropic.d.ts +18 -0
  238. package/dist/llm/providers/anthropic.d.ts.map +1 -0
  239. package/dist/llm/providers/anthropic.js +56 -0
  240. package/dist/llm/providers/anthropic.js.map +1 -0
  241. package/dist/llm/providers/ollama.d.ts +17 -0
  242. package/dist/llm/providers/ollama.d.ts.map +1 -0
  243. package/dist/llm/providers/ollama.js +45 -0
  244. package/dist/llm/providers/ollama.js.map +1 -0
  245. package/dist/llm/providers/openai.d.ts +19 -0
  246. package/dist/llm/providers/openai.d.ts.map +1 -0
  247. package/dist/llm/providers/openai.js +52 -0
  248. package/dist/llm/providers/openai.js.map +1 -0
  249. package/dist/llm/resolve.d.ts +11 -0
  250. package/dist/llm/resolve.d.ts.map +1 -0
  251. package/dist/llm/resolve.js +56 -0
  252. package/dist/llm/resolve.js.map +1 -0
  253. package/dist/mcp/binder.d.ts +28 -0
  254. package/dist/mcp/binder.d.ts.map +1 -0
  255. package/dist/mcp/binder.js +87 -0
  256. package/dist/mcp/binder.js.map +1 -0
  257. package/dist/mcp/client.d.ts +99 -0
  258. package/dist/mcp/client.d.ts.map +1 -0
  259. package/dist/mcp/client.js +196 -0
  260. package/dist/mcp/client.js.map +1 -0
  261. package/dist/mcp/index.d.ts +9 -0
  262. package/dist/mcp/index.d.ts.map +1 -0
  263. package/dist/mcp/index.js +9 -0
  264. package/dist/mcp/index.js.map +1 -0
  265. package/dist/mcp/inspector.d.ts +29 -0
  266. package/dist/mcp/inspector.d.ts.map +1 -0
  267. package/dist/mcp/inspector.js +44 -0
  268. package/dist/mcp/inspector.js.map +1 -0
  269. package/dist/schemas/bindings.d.ts +248 -0
  270. package/dist/schemas/bindings.d.ts.map +1 -0
  271. package/dist/schemas/bindings.js +34 -0
  272. package/dist/schemas/bindings.js.map +1 -0
  273. package/dist/schemas/constitution.d.ts +229 -0
  274. package/dist/schemas/constitution.d.ts.map +1 -0
  275. package/dist/schemas/constitution.js +47 -0
  276. package/dist/schemas/constitution.js.map +1 -0
  277. package/dist/schemas/evalpack.d.ts +322 -0
  278. package/dist/schemas/evalpack.d.ts.map +1 -0
  279. package/dist/schemas/evalpack.js +43 -0
  280. package/dist/schemas/evalpack.js.map +1 -0
  281. package/dist/schemas/guardrails.d.ts +171 -0
  282. package/dist/schemas/guardrails.d.ts.map +1 -0
  283. package/dist/schemas/guardrails.js +35 -0
  284. package/dist/schemas/guardrails.js.map +1 -0
  285. package/dist/schemas/index.d.ts +18 -0
  286. package/dist/schemas/index.d.ts.map +1 -0
  287. package/dist/schemas/index.js +18 -0
  288. package/dist/schemas/index.js.map +1 -0
  289. package/dist/schemas/memory.d.ts +277 -0
  290. package/dist/schemas/memory.d.ts.map +1 -0
  291. package/dist/schemas/memory.js +42 -0
  292. package/dist/schemas/memory.js.map +1 -0
  293. package/dist/schemas/playbook.d.ts +270 -0
  294. package/dist/schemas/playbook.d.ts.map +1 -0
  295. package/dist/schemas/playbook.js +52 -0
  296. package/dist/schemas/playbook.js.map +1 -0
  297. package/dist/schemas/skills.d.ts +320 -0
  298. package/dist/schemas/skills.d.ts.map +1 -0
  299. package/dist/schemas/skills.js +84 -0
  300. package/dist/schemas/skills.js.map +1 -0
  301. package/dist/schemas/trace.d.ts +126 -0
  302. package/dist/schemas/trace.d.ts.map +1 -0
  303. package/dist/schemas/trace.js +70 -0
  304. package/dist/schemas/trace.js.map +1 -0
  305. package/dist/schemas/trust.d.ts +142 -0
  306. package/dist/schemas/trust.d.ts.map +1 -0
  307. package/dist/schemas/trust.js +30 -0
  308. package/dist/schemas/trust.js.map +1 -0
  309. package/dist/schemas/validators.d.ts +26 -0
  310. package/dist/schemas/validators.d.ts.map +1 -0
  311. package/dist/schemas/validators.js +79 -0
  312. package/dist/schemas/validators.js.map +1 -0
  313. package/dist/schemas/workspace.d.ts +725 -0
  314. package/dist/schemas/workspace.d.ts.map +1 -0
  315. package/dist/schemas/workspace.js +119 -0
  316. package/dist/schemas/workspace.js.map +1 -0
  317. package/dist/skills/constraints.d.ts +19 -0
  318. package/dist/skills/constraints.d.ts.map +1 -0
  319. package/dist/skills/constraints.js +91 -0
  320. package/dist/skills/constraints.js.map +1 -0
  321. package/dist/skills/generator.d.ts +13 -0
  322. package/dist/skills/generator.d.ts.map +1 -0
  323. package/dist/skills/generator.js +126 -0
  324. package/dist/skills/generator.js.map +1 -0
  325. package/dist/skills/graph.d.ts +42 -0
  326. package/dist/skills/graph.d.ts.map +1 -0
  327. package/dist/skills/graph.js +217 -0
  328. package/dist/skills/graph.js.map +1 -0
  329. package/dist/skills/index.d.ts +13 -0
  330. package/dist/skills/index.d.ts.map +1 -0
  331. package/dist/skills/index.js +13 -0
  332. package/dist/skills/index.js.map +1 -0
  333. package/dist/skills/linter.d.ts +22 -0
  334. package/dist/skills/linter.d.ts.map +1 -0
  335. package/dist/skills/linter.js +201 -0
  336. package/dist/skills/linter.js.map +1 -0
  337. package/dist/skills/packer.d.ts +27 -0
  338. package/dist/skills/packer.d.ts.map +1 -0
  339. package/dist/skills/packer.js +72 -0
  340. package/dist/skills/packer.js.map +1 -0
  341. package/dist/skills/tracker.d.ts +27 -0
  342. package/dist/skills/tracker.d.ts.map +1 -0
  343. package/dist/skills/tracker.js +131 -0
  344. package/dist/skills/tracker.js.map +1 -0
  345. package/dist/skills/versioner.d.ts +19 -0
  346. package/dist/skills/versioner.d.ts.map +1 -0
  347. package/dist/skills/versioner.js +76 -0
  348. package/dist/skills/versioner.js.map +1 -0
  349. package/dist/tracing/index.d.ts +8 -0
  350. package/dist/tracing/index.d.ts.map +1 -0
  351. package/dist/tracing/index.js +8 -0
  352. package/dist/tracing/index.js.map +1 -0
  353. package/dist/tracing/reader.d.ts +18 -0
  354. package/dist/tracing/reader.d.ts.map +1 -0
  355. package/dist/tracing/reader.js +34 -0
  356. package/dist/tracing/reader.js.map +1 -0
  357. package/dist/tracing/tracer.d.ts +22 -0
  358. package/dist/tracing/tracer.d.ts.map +1 -0
  359. package/dist/tracing/tracer.js +105 -0
  360. package/dist/tracing/tracer.js.map +1 -0
  361. package/dist/trust/auditor.d.ts +35 -0
  362. package/dist/trust/auditor.d.ts.map +1 -0
  363. package/dist/trust/auditor.js +78 -0
  364. package/dist/trust/auditor.js.map +1 -0
  365. package/dist/trust/index.d.ts +8 -0
  366. package/dist/trust/index.d.ts.map +1 -0
  367. package/dist/trust/index.js +8 -0
  368. package/dist/trust/index.js.map +1 -0
  369. package/dist/trust/manager.d.ts +18 -0
  370. package/dist/trust/manager.d.ts.map +1 -0
  371. package/dist/trust/manager.js +60 -0
  372. package/dist/trust/manager.js.map +1 -0
  373. package/dist/utils/filesystem.d.ts +15 -0
  374. package/dist/utils/filesystem.d.ts.map +1 -0
  375. package/dist/utils/filesystem.js +53 -0
  376. package/dist/utils/filesystem.js.map +1 -0
  377. package/dist/utils/hash.d.ts +7 -0
  378. package/dist/utils/hash.d.ts.map +1 -0
  379. package/dist/utils/hash.js +15 -0
  380. package/dist/utils/hash.js.map +1 -0
  381. package/dist/utils/index.d.ts +7 -0
  382. package/dist/utils/index.d.ts.map +1 -0
  383. package/dist/utils/index.js +7 -0
  384. package/dist/utils/index.js.map +1 -0
  385. package/dist/utils/yaml.d.ts +6 -0
  386. package/dist/utils/yaml.d.ts.map +1 -0
  387. package/dist/utils/yaml.js +14 -0
  388. package/dist/utils/yaml.js.map +1 -0
  389. package/package.json +58 -0
@@ -0,0 +1,196 @@
1
+ /**
2
+ * MCP Client
3
+ *
4
+ * Client for connecting to MCP servers and discovering tools/resources/prompts.
5
+ * Wraps the official @modelcontextprotocol/sdk for transport, discovery, and invocation.
6
+ *
7
+ * Supports two transport modes:
8
+ * - stdio: launches a local process (command + args)
9
+ * - streamable-http: connects to a remote HTTP endpoint
10
+ */
11
+ import { hashString } from '../utils/hash.js';
12
+ // -- Client implementation ----------------------------------------------------
13
+ export class MCPClient {
14
+ config;
15
+ connected = false;
16
+ // The official SDK client and transport are loaded dynamically
17
+ // so the rest of TasteKit can function even if the SDK is not installed.
18
+ sdkClient = null;
19
+ sdkTransport = null;
20
+ constructor(server) {
21
+ this.config = server;
22
+ }
23
+ /**
24
+ * Connect to the MCP server using the appropriate transport.
25
+ *
26
+ * Requires `@modelcontextprotocol/sdk` to be installed. If it is not,
27
+ * throws with a clear install instruction.
28
+ */
29
+ async connect() {
30
+ if (this.connected)
31
+ return;
32
+ const transport = this.resolveTransport();
33
+ try {
34
+ const sdk = await this.loadSDK();
35
+ if (transport === 'stdio') {
36
+ if (!this.config.command) {
37
+ throw new Error('stdio transport requires a command');
38
+ }
39
+ const { StdioClientTransport } = sdk;
40
+ this.sdkTransport = new StdioClientTransport({
41
+ command: this.config.command,
42
+ args: this.config.args ?? [],
43
+ env: { ...process.env, ...(this.config.env ?? {}) },
44
+ });
45
+ }
46
+ else {
47
+ if (!this.config.url) {
48
+ throw new Error('streamable-http transport requires a url');
49
+ }
50
+ const { StreamableHTTPClientTransport } = sdk;
51
+ this.sdkTransport = new StreamableHTTPClientTransport(new URL(this.config.url));
52
+ }
53
+ const { Client } = sdk;
54
+ this.sdkClient = new Client({ name: 'tastekit', version: '0.5.0' }, { capabilities: {} });
55
+ await this.sdkClient.connect(this.sdkTransport);
56
+ this.connected = true;
57
+ }
58
+ catch (err) {
59
+ if (err?.code === 'ERR_MODULE_NOT_FOUND' || err?.code === 'MODULE_NOT_FOUND') {
60
+ throw new Error('MCP SDK not installed. Run: npm install @modelcontextprotocol/sdk\n' +
61
+ 'The official SDK provides stdio and HTTP transports for MCP servers.');
62
+ }
63
+ throw err;
64
+ }
65
+ }
66
+ async disconnect() {
67
+ if (!this.connected)
68
+ return;
69
+ try {
70
+ await this.sdkClient?.close?.();
71
+ await this.sdkTransport?.close?.();
72
+ }
73
+ finally {
74
+ this.connected = false;
75
+ this.sdkClient = null;
76
+ this.sdkTransport = null;
77
+ }
78
+ }
79
+ async listTools() {
80
+ this.ensureConnected();
81
+ const result = await this.sdkClient.listTools();
82
+ return (result.tools ?? []).map((t) => ({
83
+ name: t.name,
84
+ description: t.description,
85
+ inputSchema: t.inputSchema,
86
+ annotations: t.annotations,
87
+ }));
88
+ }
89
+ async listResources() {
90
+ this.ensureConnected();
91
+ try {
92
+ const result = await this.sdkClient.listResources();
93
+ return (result.resources ?? []).map((r) => ({
94
+ uri: r.uri,
95
+ name: r.name,
96
+ mimeType: r.mimeType,
97
+ description: r.description,
98
+ }));
99
+ }
100
+ catch {
101
+ // Server may not support resources
102
+ return [];
103
+ }
104
+ }
105
+ async listPrompts() {
106
+ this.ensureConnected();
107
+ try {
108
+ const result = await this.sdkClient.listPrompts();
109
+ return (result.prompts ?? []).map((p) => ({
110
+ name: p.name,
111
+ description: p.description,
112
+ arguments: p.arguments,
113
+ }));
114
+ }
115
+ catch {
116
+ // Server may not support prompts
117
+ return [];
118
+ }
119
+ }
120
+ async callTool(name, args = {}) {
121
+ this.ensureConnected();
122
+ const result = await this.sdkClient.callTool({ name, arguments: args });
123
+ return {
124
+ content: result.content ?? [],
125
+ isError: result.isError,
126
+ };
127
+ }
128
+ /**
129
+ * Compute a fingerprint for trust pinning.
130
+ * Based on server identity + tool names + tool schemas (sorted, hashed).
131
+ */
132
+ async getFingerprint() {
133
+ this.ensureConnected();
134
+ const tools = await this.listTools();
135
+ const resources = await this.listResources();
136
+ const prompts = await this.listPrompts();
137
+ const identity = {
138
+ name: this.config.name,
139
+ tools: tools.map(t => ({ name: t.name, inputSchema: t.inputSchema })),
140
+ resources: resources.map(r => ({ uri: r.uri })),
141
+ prompts: prompts.map(p => ({ name: p.name })),
142
+ };
143
+ return hashString(JSON.stringify(identity));
144
+ }
145
+ async getCapabilities() {
146
+ this.ensureConnected();
147
+ const caps = this.sdkClient.getServerCapabilities?.() ?? {};
148
+ return {
149
+ tools: !!caps.tools,
150
+ resources: !!caps.resources,
151
+ prompts: !!caps.prompts,
152
+ logging: !!caps.logging,
153
+ };
154
+ }
155
+ isConnected() {
156
+ return this.connected;
157
+ }
158
+ getConfig() {
159
+ return this.config;
160
+ }
161
+ // -- Private helpers --------------------------------------------------------
162
+ resolveTransport() {
163
+ if (this.config.transport)
164
+ return this.config.transport;
165
+ if (this.config.command)
166
+ return 'stdio';
167
+ if (this.config.url)
168
+ return 'streamable-http';
169
+ throw new Error('MCPServerConfig must specify either command (stdio) or url (http)');
170
+ }
171
+ ensureConnected() {
172
+ if (!this.connected || !this.sdkClient) {
173
+ throw new Error('MCPClient is not connected. Call connect() first.');
174
+ }
175
+ }
176
+ async loadSDK() {
177
+ // Dynamic import so the rest of TasteKit works without the SDK installed
178
+ const clientModule = await import('@modelcontextprotocol/sdk/client/index.js');
179
+ let stdioModule = {};
180
+ let httpModule = {};
181
+ try {
182
+ stdioModule = await import('@modelcontextprotocol/sdk/client/stdio.js');
183
+ }
184
+ catch { /* stdio transport not needed for HTTP connections */ }
185
+ try {
186
+ httpModule = await import('@modelcontextprotocol/sdk/client/streamableHttp.js');
187
+ }
188
+ catch { /* HTTP transport not needed for stdio connections */ }
189
+ return {
190
+ Client: clientModule.Client,
191
+ StdioClientTransport: stdioModule.StdioClientTransport,
192
+ StreamableHTTPClientTransport: httpModule.StreamableHTTPClientTransport,
193
+ };
194
+ }
195
+ }
196
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../mcp/client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * TasteKit MCP Integration
3
+ *
4
+ * Model Context Protocol server management and tool binding.
5
+ */
6
+ export * from './client.js';
7
+ export * from './binder.js';
8
+ export * from './inspector.js';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../mcp/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * TasteKit MCP Integration
3
+ *
4
+ * Model Context Protocol server management and tool binding.
5
+ */
6
+ export * from './client.js';
7
+ export * from './binder.js';
8
+ export * from './inspector.js';
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../mcp/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,29 @@
1
+ import { MCPServer } from './client.js';
2
+ /**
3
+ * MCP Inspector
4
+ *
5
+ * Inspects MCP servers and provides detailed information about capabilities.
6
+ */
7
+ export interface InspectionResult {
8
+ server: MCPServer;
9
+ tools: Array<{
10
+ name: string;
11
+ description?: string;
12
+ risk_level: 'low' | 'medium' | 'high';
13
+ destructive: boolean;
14
+ }>;
15
+ resources: Array<{
16
+ uri: string;
17
+ name?: string;
18
+ }>;
19
+ prompts: Array<{
20
+ name: string;
21
+ description?: string;
22
+ }>;
23
+ fingerprint: string;
24
+ }
25
+ export declare class MCPInspector {
26
+ inspect(server: MCPServer): Promise<InspectionResult>;
27
+ private assessRiskLevel;
28
+ }
29
+ //# sourceMappingURL=inspector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector.d.ts","sourceRoot":"","sources":["../../mcp/inspector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,aAAa,CAAC;AAEnD;;;;GAIG;AAEH,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,SAAS,CAAC;IAClB,KAAK,EAAE,KAAK,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;QACtC,WAAW,EAAE,OAAO,CAAC;KACtB,CAAC,CAAC;IACH,SAAS,EAAE,KAAK,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC,CAAC;IACH,OAAO,EAAE,KAAK,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,CAAC,CAAC;IACH,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,qBAAa,YAAY;IACjB,OAAO,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAmC3D,OAAO,CAAC,eAAe;CASxB"}
@@ -0,0 +1,44 @@
1
+ import { MCPClient } from './client.js';
2
+ export class MCPInspector {
3
+ async inspect(server) {
4
+ const client = new MCPClient(server);
5
+ try {
6
+ await client.connect();
7
+ const tools = await client.listTools();
8
+ const resources = await client.listResources();
9
+ const prompts = await client.listPrompts();
10
+ const fingerprint = await client.getFingerprint();
11
+ return {
12
+ server,
13
+ tools: tools.map(tool => ({
14
+ name: tool.name,
15
+ description: tool.description,
16
+ risk_level: this.assessRiskLevel(tool),
17
+ destructive: tool.annotations?.destructive || false,
18
+ })),
19
+ resources: resources.map(r => ({
20
+ uri: r.uri,
21
+ name: r.name,
22
+ })),
23
+ prompts: prompts.map(p => ({
24
+ name: p.name,
25
+ description: p.description,
26
+ })),
27
+ fingerprint,
28
+ };
29
+ }
30
+ finally {
31
+ await client.disconnect();
32
+ }
33
+ }
34
+ assessRiskLevel(tool) {
35
+ if (tool.annotations?.risk === 'high' || tool.annotations?.destructive) {
36
+ return 'high';
37
+ }
38
+ if (tool.annotations?.risk === 'medium') {
39
+ return 'medium';
40
+ }
41
+ return 'low';
42
+ }
43
+ }
44
+ //# sourceMappingURL=inspector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector.js","sourceRoot":"","sources":["../../mcp/inspector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,aAAa,CAAC;AA2BnD,MAAM,OAAO,YAAY;IACvB,KAAK,CAAC,OAAO,CAAC,MAAiB;QAC7B,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;QAErC,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;YAEvB,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,SAAS,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,aAAa,EAAE,CAAC;YAC/C,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,WAAW,EAAE,CAAC;YAC3C,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,cAAc,EAAE,CAAC;YAElD,OAAO;gBACL,MAAM;gBACN,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBACxB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,WAAW,EAAE,IAAI,CAAC,WAAW;oBAC7B,UAAU,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;oBACtC,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,IAAI,KAAK;iBACpD,CAAC,CAAC;gBACH,SAAS,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;oBAC7B,GAAG,EAAE,CAAC,CAAC,GAAG;oBACV,IAAI,EAAE,CAAC,CAAC,IAAI;iBACb,CAAC,CAAC;gBACH,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;oBACzB,IAAI,EAAE,CAAC,CAAC,IAAI;oBACZ,WAAW,EAAE,CAAC,CAAC,WAAW;iBAC3B,CAAC,CAAC;gBACH,WAAW;aACZ,CAAC;QAEJ,CAAC;gBAAS,CAAC;YACT,MAAM,MAAM,CAAC,UAAU,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;IAEO,eAAe,CAAC,IAAS;QAC/B,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE,WAAW,EAAE,CAAC;YACvE,OAAO,MAAM,CAAC;QAChB,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,KAAK,QAAQ,EAAE,CAAC;YACxC,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;CACF"}
@@ -0,0 +1,248 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Bindings v1 Schema
4
+ *
5
+ * MCP server bindings - selected tools, resources, and prompts.
6
+ */
7
+ export declare const BindingsToolSchema: z.ZodObject<{
8
+ tool_ref: z.ZodString;
9
+ risk_hints: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
10
+ default_permission_scope_id: z.ZodOptional<z.ZodString>;
11
+ }, "strip", z.ZodTypeAny, {
12
+ tool_ref: string;
13
+ risk_hints?: string[] | undefined;
14
+ default_permission_scope_id?: string | undefined;
15
+ }, {
16
+ tool_ref: string;
17
+ risk_hints?: string[] | undefined;
18
+ default_permission_scope_id?: string | undefined;
19
+ }>;
20
+ export declare const BindingsResourceSchema: z.ZodObject<{
21
+ resource_ref: z.ZodString;
22
+ uri_pattern: z.ZodOptional<z.ZodString>;
23
+ }, "strip", z.ZodTypeAny, {
24
+ resource_ref: string;
25
+ uri_pattern?: string | undefined;
26
+ }, {
27
+ resource_ref: string;
28
+ uri_pattern?: string | undefined;
29
+ }>;
30
+ export declare const BindingsPromptSchema: z.ZodObject<{
31
+ prompt_ref: z.ZodString;
32
+ description: z.ZodOptional<z.ZodString>;
33
+ }, "strip", z.ZodTypeAny, {
34
+ prompt_ref: string;
35
+ description?: string | undefined;
36
+ }, {
37
+ prompt_ref: string;
38
+ description?: string | undefined;
39
+ }>;
40
+ export declare const BindingsServerSchema: z.ZodObject<{
41
+ name: z.ZodString;
42
+ url: z.ZodString;
43
+ pinned_fingerprint: z.ZodOptional<z.ZodString>;
44
+ auth: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
45
+ tools: z.ZodArray<z.ZodObject<{
46
+ tool_ref: z.ZodString;
47
+ risk_hints: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
48
+ default_permission_scope_id: z.ZodOptional<z.ZodString>;
49
+ }, "strip", z.ZodTypeAny, {
50
+ tool_ref: string;
51
+ risk_hints?: string[] | undefined;
52
+ default_permission_scope_id?: string | undefined;
53
+ }, {
54
+ tool_ref: string;
55
+ risk_hints?: string[] | undefined;
56
+ default_permission_scope_id?: string | undefined;
57
+ }>, "many">;
58
+ resources: z.ZodOptional<z.ZodArray<z.ZodObject<{
59
+ resource_ref: z.ZodString;
60
+ uri_pattern: z.ZodOptional<z.ZodString>;
61
+ }, "strip", z.ZodTypeAny, {
62
+ resource_ref: string;
63
+ uri_pattern?: string | undefined;
64
+ }, {
65
+ resource_ref: string;
66
+ uri_pattern?: string | undefined;
67
+ }>, "many">>;
68
+ prompts: z.ZodOptional<z.ZodArray<z.ZodObject<{
69
+ prompt_ref: z.ZodString;
70
+ description: z.ZodOptional<z.ZodString>;
71
+ }, "strip", z.ZodTypeAny, {
72
+ prompt_ref: string;
73
+ description?: string | undefined;
74
+ }, {
75
+ prompt_ref: string;
76
+ description?: string | undefined;
77
+ }>, "many">>;
78
+ last_bind_at: z.ZodString;
79
+ }, "strip", z.ZodTypeAny, {
80
+ name: string;
81
+ url: string;
82
+ tools: {
83
+ tool_ref: string;
84
+ risk_hints?: string[] | undefined;
85
+ default_permission_scope_id?: string | undefined;
86
+ }[];
87
+ last_bind_at: string;
88
+ pinned_fingerprint?: string | undefined;
89
+ auth?: Record<string, string> | undefined;
90
+ resources?: {
91
+ resource_ref: string;
92
+ uri_pattern?: string | undefined;
93
+ }[] | undefined;
94
+ prompts?: {
95
+ prompt_ref: string;
96
+ description?: string | undefined;
97
+ }[] | undefined;
98
+ }, {
99
+ name: string;
100
+ url: string;
101
+ tools: {
102
+ tool_ref: string;
103
+ risk_hints?: string[] | undefined;
104
+ default_permission_scope_id?: string | undefined;
105
+ }[];
106
+ last_bind_at: string;
107
+ pinned_fingerprint?: string | undefined;
108
+ auth?: Record<string, string> | undefined;
109
+ resources?: {
110
+ resource_ref: string;
111
+ uri_pattern?: string | undefined;
112
+ }[] | undefined;
113
+ prompts?: {
114
+ prompt_ref: string;
115
+ description?: string | undefined;
116
+ }[] | undefined;
117
+ }>;
118
+ export declare const BindingsV1Schema: z.ZodObject<{
119
+ schema_version: z.ZodLiteral<"bindings.v1">;
120
+ servers: z.ZodArray<z.ZodObject<{
121
+ name: z.ZodString;
122
+ url: z.ZodString;
123
+ pinned_fingerprint: z.ZodOptional<z.ZodString>;
124
+ auth: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
125
+ tools: z.ZodArray<z.ZodObject<{
126
+ tool_ref: z.ZodString;
127
+ risk_hints: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
128
+ default_permission_scope_id: z.ZodOptional<z.ZodString>;
129
+ }, "strip", z.ZodTypeAny, {
130
+ tool_ref: string;
131
+ risk_hints?: string[] | undefined;
132
+ default_permission_scope_id?: string | undefined;
133
+ }, {
134
+ tool_ref: string;
135
+ risk_hints?: string[] | undefined;
136
+ default_permission_scope_id?: string | undefined;
137
+ }>, "many">;
138
+ resources: z.ZodOptional<z.ZodArray<z.ZodObject<{
139
+ resource_ref: z.ZodString;
140
+ uri_pattern: z.ZodOptional<z.ZodString>;
141
+ }, "strip", z.ZodTypeAny, {
142
+ resource_ref: string;
143
+ uri_pattern?: string | undefined;
144
+ }, {
145
+ resource_ref: string;
146
+ uri_pattern?: string | undefined;
147
+ }>, "many">>;
148
+ prompts: z.ZodOptional<z.ZodArray<z.ZodObject<{
149
+ prompt_ref: z.ZodString;
150
+ description: z.ZodOptional<z.ZodString>;
151
+ }, "strip", z.ZodTypeAny, {
152
+ prompt_ref: string;
153
+ description?: string | undefined;
154
+ }, {
155
+ prompt_ref: string;
156
+ description?: string | undefined;
157
+ }>, "many">>;
158
+ last_bind_at: z.ZodString;
159
+ }, "strip", z.ZodTypeAny, {
160
+ name: string;
161
+ url: string;
162
+ tools: {
163
+ tool_ref: string;
164
+ risk_hints?: string[] | undefined;
165
+ default_permission_scope_id?: string | undefined;
166
+ }[];
167
+ last_bind_at: string;
168
+ pinned_fingerprint?: string | undefined;
169
+ auth?: Record<string, string> | undefined;
170
+ resources?: {
171
+ resource_ref: string;
172
+ uri_pattern?: string | undefined;
173
+ }[] | undefined;
174
+ prompts?: {
175
+ prompt_ref: string;
176
+ description?: string | undefined;
177
+ }[] | undefined;
178
+ }, {
179
+ name: string;
180
+ url: string;
181
+ tools: {
182
+ tool_ref: string;
183
+ risk_hints?: string[] | undefined;
184
+ default_permission_scope_id?: string | undefined;
185
+ }[];
186
+ last_bind_at: string;
187
+ pinned_fingerprint?: string | undefined;
188
+ auth?: Record<string, string> | undefined;
189
+ resources?: {
190
+ resource_ref: string;
191
+ uri_pattern?: string | undefined;
192
+ }[] | undefined;
193
+ prompts?: {
194
+ prompt_ref: string;
195
+ description?: string | undefined;
196
+ }[] | undefined;
197
+ }>, "many">;
198
+ }, "strip", z.ZodTypeAny, {
199
+ schema_version: "bindings.v1";
200
+ servers: {
201
+ name: string;
202
+ url: string;
203
+ tools: {
204
+ tool_ref: string;
205
+ risk_hints?: string[] | undefined;
206
+ default_permission_scope_id?: string | undefined;
207
+ }[];
208
+ last_bind_at: string;
209
+ pinned_fingerprint?: string | undefined;
210
+ auth?: Record<string, string> | undefined;
211
+ resources?: {
212
+ resource_ref: string;
213
+ uri_pattern?: string | undefined;
214
+ }[] | undefined;
215
+ prompts?: {
216
+ prompt_ref: string;
217
+ description?: string | undefined;
218
+ }[] | undefined;
219
+ }[];
220
+ }, {
221
+ schema_version: "bindings.v1";
222
+ servers: {
223
+ name: string;
224
+ url: string;
225
+ tools: {
226
+ tool_ref: string;
227
+ risk_hints?: string[] | undefined;
228
+ default_permission_scope_id?: string | undefined;
229
+ }[];
230
+ last_bind_at: string;
231
+ pinned_fingerprint?: string | undefined;
232
+ auth?: Record<string, string> | undefined;
233
+ resources?: {
234
+ resource_ref: string;
235
+ uri_pattern?: string | undefined;
236
+ }[] | undefined;
237
+ prompts?: {
238
+ prompt_ref: string;
239
+ description?: string | undefined;
240
+ }[] | undefined;
241
+ }[];
242
+ }>;
243
+ export type BindingsV1 = z.infer<typeof BindingsV1Schema>;
244
+ export type BindingsServer = z.infer<typeof BindingsServerSchema>;
245
+ export type BindingsTool = z.infer<typeof BindingsToolSchema>;
246
+ export type BindingsResource = z.infer<typeof BindingsResourceSchema>;
247
+ export type BindingsPrompt = z.infer<typeof BindingsPromptSchema>;
248
+ //# sourceMappingURL=bindings.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bindings.d.ts","sourceRoot":"","sources":["../../schemas/bindings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;;GAIG;AAEH,eAAO,MAAM,kBAAkB;;;;;;;;;;;;EAI7B,CAAC;AAEH,eAAO,MAAM,sBAAsB;;;;;;;;;EAGjC,CAAC;AAEH,eAAO,MAAM,oBAAoB;;;;;;;;;EAG/B,CAAC;AAEH,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAW/B,CAAC;AAEH,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAG3B,CAAC;AAEH,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAC1D,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAClE,MAAM,MAAM,YAAY,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAC9D,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC;AACtE,MAAM,MAAM,cAAc,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,oBAAoB,CAAC,CAAC"}
@@ -0,0 +1,34 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Bindings v1 Schema
4
+ *
5
+ * MCP server bindings - selected tools, resources, and prompts.
6
+ */
7
+ export const BindingsToolSchema = z.object({
8
+ tool_ref: z.string().describe('Tool reference (server:tool)'),
9
+ risk_hints: z.array(z.string()).optional().describe('Risk hints from MCP annotations'),
10
+ default_permission_scope_id: z.string().optional(),
11
+ });
12
+ export const BindingsResourceSchema = z.object({
13
+ resource_ref: z.string().describe('Resource reference (server:resource)'),
14
+ uri_pattern: z.string().optional(),
15
+ });
16
+ export const BindingsPromptSchema = z.object({
17
+ prompt_ref: z.string().describe('Prompt reference (server:prompt)'),
18
+ description: z.string().optional(),
19
+ });
20
+ export const BindingsServerSchema = z.object({
21
+ name: z.string().describe('Server name'),
22
+ url: z.string().describe('Server URL or connection string'),
23
+ pinned_fingerprint: z.string().optional().describe('Pinned server fingerprint for trust'),
24
+ auth: z.record(z.string()).optional().describe('Auth references (no secrets)'),
25
+ tools: z.array(BindingsToolSchema).describe('Selected tools from this server'),
26
+ resources: z.array(BindingsResourceSchema).optional().describe('Selected resources'),
27
+ prompts: z.array(BindingsPromptSchema).optional().describe('Selected prompts'),
28
+ last_bind_at: z.string().datetime().describe('Last binding timestamp'),
29
+ });
30
+ export const BindingsV1Schema = z.object({
31
+ schema_version: z.literal('bindings.v1'),
32
+ servers: z.array(BindingsServerSchema),
33
+ });
34
+ //# sourceMappingURL=bindings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bindings.js","sourceRoot":"","sources":["../../schemas/bindings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;;GAIG;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,8BAA8B,CAAC;IAC7D,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,iCAAiC,CAAC;IACtF,2BAA2B,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACnD,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC7C,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,sCAAsC,CAAC;IACzE,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACnC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC3C,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,kCAAkC,CAAC;IACnE,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACnC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC3C,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC;IACxC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,iCAAiC,CAAC;IAC3D,kBAAkB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,qCAAqC,CAAC;IACzF,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,8BAA8B,CAAC;IAE9E,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,QAAQ,CAAC,iCAAiC,CAAC;IAC9E,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC;IACpF,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC;IAE9E,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC;CACvE,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC;IACvC,cAAc,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IACxC,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC;CACvC,CAAC,CAAC"}