@namzu/sdk 0.1.3 → 0.1.4-rc.2

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 (412) hide show
  1. package/CHANGELOG.md +45 -29
  2. package/README.md +14 -2
  3. package/dist/advisory/context.d.ts +23 -0
  4. package/dist/advisory/context.d.ts.map +1 -0
  5. package/dist/advisory/context.js +33 -0
  6. package/dist/advisory/context.js.map +1 -0
  7. package/dist/advisory/evaluator.d.ts +14 -0
  8. package/dist/advisory/evaluator.d.ts.map +1 -0
  9. package/dist/advisory/evaluator.js +87 -0
  10. package/dist/advisory/evaluator.js.map +1 -0
  11. package/dist/advisory/executor.d.ts +40 -0
  12. package/dist/advisory/executor.d.ts.map +1 -0
  13. package/dist/advisory/executor.js +132 -0
  14. package/dist/advisory/executor.js.map +1 -0
  15. package/dist/advisory/index.d.ts +6 -0
  16. package/dist/advisory/index.d.ts.map +1 -0
  17. package/dist/advisory/index.js +5 -0
  18. package/dist/advisory/index.js.map +1 -0
  19. package/dist/advisory/registry.d.ts +14 -0
  20. package/dist/advisory/registry.d.ts.map +1 -0
  21. package/dist/advisory/registry.js +36 -0
  22. package/dist/advisory/registry.js.map +1 -0
  23. package/dist/agents/ReactiveAgent.d.ts.map +1 -1
  24. package/dist/agents/ReactiveAgent.js +1 -0
  25. package/dist/agents/ReactiveAgent.js.map +1 -1
  26. package/dist/agents/SupervisorAgent.d.ts.map +1 -1
  27. package/dist/agents/SupervisorAgent.js +12 -1
  28. package/dist/agents/SupervisorAgent.js.map +1 -1
  29. package/dist/bridge/a2a/mapper.d.ts.map +1 -1
  30. package/dist/bridge/a2a/mapper.js +2 -0
  31. package/dist/bridge/a2a/mapper.js.map +1 -1
  32. package/dist/bridge/sse/mapper.d.ts.map +1 -1
  33. package/dist/bridge/sse/mapper.js +17 -0
  34. package/dist/bridge/sse/mapper.js.map +1 -1
  35. package/dist/bus/breaker.d.ts +18 -0
  36. package/dist/bus/breaker.d.ts.map +1 -0
  37. package/dist/bus/breaker.js +158 -0
  38. package/dist/bus/breaker.js.map +1 -0
  39. package/dist/bus/index.d.ts +33 -0
  40. package/dist/bus/index.d.ts.map +1 -0
  41. package/dist/bus/index.js +72 -0
  42. package/dist/bus/index.js.map +1 -0
  43. package/dist/bus/lock.d.ts +27 -0
  44. package/dist/bus/lock.d.ts.map +1 -0
  45. package/dist/bus/lock.js +194 -0
  46. package/dist/bus/lock.js.map +1 -0
  47. package/dist/bus/ownership.d.ts +18 -0
  48. package/dist/bus/ownership.d.ts.map +1 -0
  49. package/dist/bus/ownership.js +111 -0
  50. package/dist/bus/ownership.js.map +1 -0
  51. package/dist/compaction/extractor.d.ts +7 -0
  52. package/dist/compaction/extractor.d.ts.map +1 -0
  53. package/dist/compaction/extractor.js +131 -0
  54. package/dist/compaction/extractor.js.map +1 -0
  55. package/dist/compaction/index.d.ts +6 -0
  56. package/dist/compaction/index.d.ts.map +1 -0
  57. package/dist/compaction/index.js +5 -0
  58. package/dist/compaction/index.js.map +1 -0
  59. package/dist/compaction/manager.d.ts +22 -0
  60. package/dist/compaction/manager.d.ts.map +1 -0
  61. package/dist/compaction/manager.js +91 -0
  62. package/dist/compaction/manager.js.map +1 -0
  63. package/dist/compaction/serializer.d.ts +3 -0
  64. package/dist/compaction/serializer.d.ts.map +1 -0
  65. package/dist/compaction/serializer.js +67 -0
  66. package/dist/compaction/serializer.js.map +1 -0
  67. package/dist/compaction/types.d.ts +40 -0
  68. package/dist/compaction/types.d.ts.map +1 -0
  69. package/dist/compaction/types.js +2 -0
  70. package/dist/compaction/types.js.map +1 -0
  71. package/dist/compaction/verifier.d.ts +6 -0
  72. package/dist/compaction/verifier.d.ts.map +1 -0
  73. package/dist/compaction/verifier.js +68 -0
  74. package/dist/compaction/verifier.js.map +1 -0
  75. package/dist/config/runtime.d.ts +328 -0
  76. package/dist/config/runtime.d.ts.map +1 -1
  77. package/dist/config/runtime.js +51 -0
  78. package/dist/config/runtime.js.map +1 -1
  79. package/dist/constants/advisory/index.d.ts +8 -0
  80. package/dist/constants/advisory/index.d.ts.map +1 -0
  81. package/dist/constants/advisory/index.js +8 -0
  82. package/dist/constants/advisory/index.js.map +1 -0
  83. package/dist/constants/bus/index.d.ts +7 -0
  84. package/dist/constants/bus/index.d.ts.map +1 -0
  85. package/dist/constants/bus/index.js +7 -0
  86. package/dist/constants/bus/index.js.map +1 -0
  87. package/dist/constants/compaction/index.d.ts +17 -0
  88. package/dist/constants/compaction/index.d.ts.map +1 -0
  89. package/dist/constants/compaction/index.js +17 -0
  90. package/dist/constants/compaction/index.js.map +1 -0
  91. package/dist/constants/emergency.d.ts +4 -0
  92. package/dist/constants/emergency.d.ts.map +1 -0
  93. package/dist/constants/emergency.js +4 -0
  94. package/dist/constants/emergency.js.map +1 -0
  95. package/dist/constants/index.d.ts +6 -0
  96. package/dist/constants/index.d.ts.map +1 -1
  97. package/dist/constants/index.js +6 -0
  98. package/dist/constants/index.js.map +1 -1
  99. package/dist/constants/limits.d.ts +1 -0
  100. package/dist/constants/limits.d.ts.map +1 -1
  101. package/dist/constants/limits.js +1 -0
  102. package/dist/constants/limits.js.map +1 -1
  103. package/dist/constants/plugin/index.d.ts +21 -0
  104. package/dist/constants/plugin/index.d.ts.map +1 -0
  105. package/dist/constants/plugin/index.js +21 -0
  106. package/dist/constants/plugin/index.js.map +1 -0
  107. package/dist/constants/verification/index.d.ts +2 -0
  108. package/dist/constants/verification/index.d.ts.map +1 -0
  109. package/dist/constants/verification/index.js +2 -0
  110. package/dist/constants/verification/index.js.map +1 -0
  111. package/dist/contracts/api.d.ts +1 -1
  112. package/dist/contracts/api.d.ts.map +1 -1
  113. package/dist/contracts/schemas.d.ts +20 -20
  114. package/dist/index.d.ts +24 -2
  115. package/dist/index.d.ts.map +1 -1
  116. package/dist/index.js +17 -1
  117. package/dist/index.js.map +1 -1
  118. package/dist/manager/run/emergency.d.ts +19 -0
  119. package/dist/manager/run/emergency.d.ts.map +1 -0
  120. package/dist/manager/run/emergency.js +88 -0
  121. package/dist/manager/run/emergency.js.map +1 -0
  122. package/dist/manager/run/persistence.d.ts +2 -0
  123. package/dist/manager/run/persistence.d.ts.map +1 -1
  124. package/dist/manager/run/persistence.js +14 -0
  125. package/dist/manager/run/persistence.js.map +1 -1
  126. package/dist/persona/assembler.d.ts +2 -1
  127. package/dist/persona/assembler.d.ts.map +1 -1
  128. package/dist/persona/assembler.js +23 -0
  129. package/dist/persona/assembler.js.map +1 -1
  130. package/dist/plugin/index.d.ts +4 -0
  131. package/dist/plugin/index.d.ts.map +1 -0
  132. package/dist/plugin/index.js +4 -0
  133. package/dist/plugin/index.js.map +1 -0
  134. package/dist/plugin/lifecycle.d.ts +30 -0
  135. package/dist/plugin/lifecycle.d.ts.map +1 -0
  136. package/dist/plugin/lifecycle.js +227 -0
  137. package/dist/plugin/lifecycle.js.map +1 -0
  138. package/dist/plugin/loader.d.ts +25 -0
  139. package/dist/plugin/loader.d.ts.map +1 -0
  140. package/dist/plugin/loader.js +76 -0
  141. package/dist/plugin/loader.js.map +1 -0
  142. package/dist/plugin/resolver.d.ts +36 -0
  143. package/dist/plugin/resolver.d.ts.map +1 -0
  144. package/dist/plugin/resolver.js +80 -0
  145. package/dist/plugin/resolver.js.map +1 -0
  146. package/dist/registry/plugin/index.d.ts +9 -0
  147. package/dist/registry/plugin/index.d.ts.map +1 -0
  148. package/dist/registry/plugin/index.js +16 -0
  149. package/dist/registry/plugin/index.js.map +1 -0
  150. package/dist/registry/tool/execute.d.ts +3 -0
  151. package/dist/registry/tool/execute.d.ts.map +1 -1
  152. package/dist/registry/tool/execute.js +45 -11
  153. package/dist/registry/tool/execute.js.map +1 -1
  154. package/dist/router/index.d.ts +2 -0
  155. package/dist/router/index.d.ts.map +1 -0
  156. package/dist/router/index.js +2 -0
  157. package/dist/router/index.js.map +1 -0
  158. package/dist/router/task-router.d.ts +8 -0
  159. package/dist/router/task-router.d.ts.map +1 -0
  160. package/dist/router/task-router.js +19 -0
  161. package/dist/router/task-router.js.map +1 -0
  162. package/dist/run/reporter.d.ts.map +1 -1
  163. package/dist/run/reporter.js +15 -0
  164. package/dist/run/reporter.js.map +1 -1
  165. package/dist/runtime/query/context-cache.d.ts +6 -0
  166. package/dist/runtime/query/context-cache.d.ts.map +1 -1
  167. package/dist/runtime/query/context-cache.js +36 -0
  168. package/dist/runtime/query/context-cache.js.map +1 -1
  169. package/dist/runtime/query/executor.d.ts +4 -0
  170. package/dist/runtime/query/executor.d.ts.map +1 -1
  171. package/dist/runtime/query/executor.js +30 -1
  172. package/dist/runtime/query/executor.js.map +1 -1
  173. package/dist/runtime/query/index.d.ts +10 -0
  174. package/dist/runtime/query/index.d.ts.map +1 -1
  175. package/dist/runtime/query/index.js +77 -12
  176. package/dist/runtime/query/index.js.map +1 -1
  177. package/dist/runtime/query/iteration/index.d.ts +9 -0
  178. package/dist/runtime/query/iteration/index.d.ts.map +1 -1
  179. package/dist/runtime/query/iteration/index.js +40 -0
  180. package/dist/runtime/query/iteration/index.js.map +1 -1
  181. package/dist/runtime/query/iteration/phases/advisory.d.ts +4 -0
  182. package/dist/runtime/query/iteration/phases/advisory.d.ts.map +1 -0
  183. package/dist/runtime/query/iteration/phases/advisory.js +150 -0
  184. package/dist/runtime/query/iteration/phases/advisory.js.map +1 -0
  185. package/dist/runtime/query/iteration/phases/compaction.d.ts +3 -0
  186. package/dist/runtime/query/iteration/phases/compaction.d.ts.map +1 -0
  187. package/dist/runtime/query/iteration/phases/compaction.js +87 -0
  188. package/dist/runtime/query/iteration/phases/compaction.js.map +1 -0
  189. package/dist/runtime/query/iteration/phases/context.d.ts +10 -0
  190. package/dist/runtime/query/iteration/phases/context.d.ts.map +1 -1
  191. package/dist/runtime/query/iteration/phases/context.js.map +1 -1
  192. package/dist/runtime/query/iteration/phases/index.d.ts +2 -0
  193. package/dist/runtime/query/iteration/phases/index.d.ts.map +1 -1
  194. package/dist/runtime/query/iteration/phases/index.js +2 -0
  195. package/dist/runtime/query/iteration/phases/index.js.map +1 -1
  196. package/dist/runtime/query/iteration/phases/tool-review.d.ts +6 -1
  197. package/dist/runtime/query/iteration/phases/tool-review.d.ts.map +1 -1
  198. package/dist/runtime/query/iteration/phases/tool-review.js +39 -0
  199. package/dist/runtime/query/iteration/phases/tool-review.js.map +1 -1
  200. package/dist/runtime/query/prompt.d.ts +7 -0
  201. package/dist/runtime/query/prompt.d.ts.map +1 -1
  202. package/dist/runtime/query/prompt.js +44 -0
  203. package/dist/runtime/query/prompt.js.map +1 -1
  204. package/dist/store/memory/disk.d.ts +30 -0
  205. package/dist/store/memory/disk.d.ts.map +1 -0
  206. package/dist/store/memory/disk.js +154 -0
  207. package/dist/store/memory/disk.js.map +1 -0
  208. package/dist/store/memory/index.d.ts +13 -0
  209. package/dist/store/memory/index.d.ts.map +1 -0
  210. package/dist/store/memory/index.js +46 -0
  211. package/dist/store/memory/index.js.map +1 -0
  212. package/dist/store/memory/memory.d.ts +17 -0
  213. package/dist/store/memory/memory.d.ts.map +1 -0
  214. package/dist/store/memory/memory.js +72 -0
  215. package/dist/store/memory/memory.js.map +1 -0
  216. package/dist/tools/advisory/index.d.ts +7 -0
  217. package/dist/tools/advisory/index.d.ts.map +1 -0
  218. package/dist/tools/advisory/index.js +125 -0
  219. package/dist/tools/advisory/index.js.map +1 -0
  220. package/dist/tools/defineTool.d.ts +1 -0
  221. package/dist/tools/defineTool.d.ts.map +1 -1
  222. package/dist/tools/defineTool.js +1 -0
  223. package/dist/tools/defineTool.js.map +1 -1
  224. package/dist/tools/memory/index.d.ts +7 -0
  225. package/dist/tools/memory/index.d.ts.map +1 -0
  226. package/dist/tools/memory/index.js +10 -0
  227. package/dist/tools/memory/index.js.map +1 -0
  228. package/dist/tools/memory/read.d.ts +4 -0
  229. package/dist/tools/memory/read.d.ts.map +1 -0
  230. package/dist/tools/memory/read.js +37 -0
  231. package/dist/tools/memory/read.js.map +1 -0
  232. package/dist/tools/memory/save.d.ts +4 -0
  233. package/dist/tools/memory/save.d.ts.map +1 -0
  234. package/dist/tools/memory/save.js +37 -0
  235. package/dist/tools/memory/save.js.map +1 -0
  236. package/dist/tools/memory/search.d.ts +4 -0
  237. package/dist/tools/memory/search.d.ts.map +1 -0
  238. package/dist/tools/memory/search.js +41 -0
  239. package/dist/tools/memory/search.js.map +1 -0
  240. package/dist/types/advisory/config.d.ts +33 -0
  241. package/dist/types/advisory/config.d.ts.map +1 -0
  242. package/dist/types/advisory/config.js +2 -0
  243. package/dist/types/advisory/config.js.map +1 -0
  244. package/dist/types/advisory/index.d.ts +4 -0
  245. package/dist/types/advisory/index.d.ts.map +1 -0
  246. package/dist/types/advisory/index.js +2 -0
  247. package/dist/types/advisory/index.js.map +1 -0
  248. package/dist/types/advisory/result.d.ts +35 -0
  249. package/dist/types/advisory/result.d.ts.map +1 -0
  250. package/dist/types/advisory/result.js +2 -0
  251. package/dist/types/advisory/result.js.map +1 -0
  252. package/dist/types/advisory/trigger.d.ts +44 -0
  253. package/dist/types/advisory/trigger.d.ts.map +1 -0
  254. package/dist/types/advisory/trigger.js +2 -0
  255. package/dist/types/advisory/trigger.js.map +1 -0
  256. package/dist/types/agent/factory.d.ts +2 -0
  257. package/dist/types/agent/factory.d.ts.map +1 -1
  258. package/dist/types/agent/reactive.d.ts +2 -0
  259. package/dist/types/agent/reactive.d.ts.map +1 -1
  260. package/dist/types/agent/supervisor.d.ts +4 -0
  261. package/dist/types/agent/supervisor.d.ts.map +1 -1
  262. package/dist/types/bus/index.d.ts +96 -0
  263. package/dist/types/bus/index.d.ts.map +1 -0
  264. package/dist/types/bus/index.js +2 -0
  265. package/dist/types/bus/index.js.map +1 -0
  266. package/dist/types/ids/index.d.ts +6 -0
  267. package/dist/types/ids/index.d.ts.map +1 -1
  268. package/dist/types/memory/index.d.ts +54 -0
  269. package/dist/types/memory/index.d.ts.map +1 -0
  270. package/dist/types/memory/index.js +12 -0
  271. package/dist/types/memory/index.js.map +1 -0
  272. package/dist/types/message/index.d.ts +3 -1
  273. package/dist/types/message/index.d.ts.map +1 -1
  274. package/dist/types/message/index.js +7 -2
  275. package/dist/types/message/index.js.map +1 -1
  276. package/dist/types/persona/index.d.ts +9 -0
  277. package/dist/types/persona/index.d.ts.map +1 -1
  278. package/dist/types/plugin/index.d.ts +186 -0
  279. package/dist/types/plugin/index.d.ts.map +1 -0
  280. package/dist/types/plugin/index.js +90 -0
  281. package/dist/types/plugin/index.js.map +1 -0
  282. package/dist/types/router/index.d.ts +2 -0
  283. package/dist/types/router/index.d.ts.map +1 -0
  284. package/dist/types/router/index.js +2 -0
  285. package/dist/types/router/index.js.map +1 -0
  286. package/dist/types/router/task-router.d.ts +12 -0
  287. package/dist/types/router/task-router.d.ts.map +1 -0
  288. package/dist/types/router/task-router.js +2 -0
  289. package/dist/types/router/task-router.js.map +1 -0
  290. package/dist/types/run/emergency.d.ts +27 -0
  291. package/dist/types/run/emergency.d.ts.map +1 -0
  292. package/dist/types/run/emergency.js +6 -0
  293. package/dist/types/run/emergency.js.map +1 -0
  294. package/dist/types/run/events.d.ts +13 -1
  295. package/dist/types/run/events.d.ts.map +1 -1
  296. package/dist/types/run/index.d.ts +1 -0
  297. package/dist/types/run/index.d.ts.map +1 -1
  298. package/dist/types/run/index.js +1 -0
  299. package/dist/types/run/index.js.map +1 -1
  300. package/dist/types/tool/index.d.ts +13 -0
  301. package/dist/types/tool/index.d.ts.map +1 -1
  302. package/dist/types/verification/index.d.ts +219 -0
  303. package/dist/types/verification/index.d.ts.map +1 -0
  304. package/dist/types/verification/index.js +43 -0
  305. package/dist/types/verification/index.js.map +1 -0
  306. package/dist/utils/id.d.ts +7 -1
  307. package/dist/utils/id.d.ts.map +1 -1
  308. package/dist/utils/id.js +18 -0
  309. package/dist/utils/id.js.map +1 -1
  310. package/dist/utils/shell-compress.d.ts +13 -0
  311. package/dist/utils/shell-compress.d.ts.map +1 -0
  312. package/dist/utils/shell-compress.js +97 -0
  313. package/dist/utils/shell-compress.js.map +1 -0
  314. package/dist/verification/gate.d.ts +19 -0
  315. package/dist/verification/gate.d.ts.map +1 -0
  316. package/dist/verification/gate.js +103 -0
  317. package/dist/verification/gate.js.map +1 -0
  318. package/dist/verification/index.d.ts +3 -0
  319. package/dist/verification/index.d.ts.map +1 -0
  320. package/dist/verification/index.js +3 -0
  321. package/dist/verification/index.js.map +1 -0
  322. package/dist/verification/rules.d.ts +4 -0
  323. package/dist/verification/rules.d.ts.map +1 -0
  324. package/dist/verification/rules.js +61 -0
  325. package/dist/verification/rules.js.map +1 -0
  326. package/package.json +5 -1
  327. package/src/advisory/context.ts +47 -0
  328. package/src/advisory/evaluator.ts +98 -0
  329. package/src/advisory/executor.ts +187 -0
  330. package/src/advisory/index.ts +5 -0
  331. package/src/advisory/registry.ts +42 -0
  332. package/src/agents/ReactiveAgent.ts +1 -0
  333. package/src/agents/SupervisorAgent.ts +13 -1
  334. package/src/bridge/a2a/mapper.ts +3 -0
  335. package/src/bridge/sse/mapper.ts +19 -0
  336. package/src/bus/breaker.ts +192 -0
  337. package/src/bus/index.ts +120 -0
  338. package/src/bus/lock.ts +233 -0
  339. package/src/bus/ownership.ts +133 -0
  340. package/src/compaction/extractor.ts +149 -0
  341. package/src/compaction/index.ts +21 -0
  342. package/src/compaction/manager.ts +107 -0
  343. package/src/compaction/serializer.ts +88 -0
  344. package/src/compaction/types.ts +37 -0
  345. package/src/compaction/verifier.ts +91 -0
  346. package/src/config/runtime.ts +64 -0
  347. package/src/constants/advisory/index.ts +7 -0
  348. package/src/constants/bus/index.ts +6 -0
  349. package/src/constants/compaction/index.ts +20 -0
  350. package/src/constants/emergency.ts +3 -0
  351. package/src/constants/index.ts +6 -0
  352. package/src/constants/limits.ts +2 -0
  353. package/src/constants/plugin/index.ts +25 -0
  354. package/src/constants/verification/index.ts +1 -0
  355. package/src/contracts/api.ts +2 -0
  356. package/src/index.ts +69 -2
  357. package/src/manager/run/emergency.ts +117 -0
  358. package/src/manager/run/persistence.ts +16 -0
  359. package/src/persona/assembler.ts +36 -1
  360. package/src/plugin/index.ts +3 -0
  361. package/src/plugin/lifecycle.ts +308 -0
  362. package/src/plugin/loader.ts +91 -0
  363. package/src/plugin/resolver.ts +95 -0
  364. package/src/registry/plugin/index.ts +20 -0
  365. package/src/registry/tool/execute.ts +51 -11
  366. package/src/router/index.ts +1 -0
  367. package/src/router/task-router.ts +24 -0
  368. package/src/run/reporter.ts +17 -0
  369. package/src/runtime/query/context-cache.ts +50 -0
  370. package/src/runtime/query/executor.ts +37 -1
  371. package/src/runtime/query/index.ts +125 -12
  372. package/src/runtime/query/iteration/index.ts +60 -0
  373. package/src/runtime/query/iteration/phases/advisory.ts +185 -0
  374. package/src/runtime/query/iteration/phases/compaction.ts +98 -0
  375. package/src/runtime/query/iteration/phases/context.ts +16 -0
  376. package/src/runtime/query/iteration/phases/index.ts +2 -0
  377. package/src/runtime/query/iteration/phases/tool-review.ts +52 -1
  378. package/src/runtime/query/prompt.ts +64 -0
  379. package/src/store/memory/disk.ts +205 -0
  380. package/src/store/memory/index.ts +68 -0
  381. package/src/store/memory/memory.ts +103 -0
  382. package/src/tools/advisory/index.ts +157 -0
  383. package/src/tools/defineTool.ts +2 -0
  384. package/src/tools/memory/index.ts +13 -0
  385. package/src/tools/memory/read.ts +42 -0
  386. package/src/tools/memory/save.ts +40 -0
  387. package/src/tools/memory/search.ts +52 -0
  388. package/src/types/advisory/config.ts +35 -0
  389. package/src/types/advisory/index.ts +18 -0
  390. package/src/types/advisory/result.ts +34 -0
  391. package/src/types/advisory/trigger.ts +39 -0
  392. package/src/types/agent/factory.ts +3 -0
  393. package/src/types/agent/reactive.ts +3 -0
  394. package/src/types/agent/supervisor.ts +6 -0
  395. package/src/types/bus/index.ts +53 -0
  396. package/src/types/ids/index.ts +6 -0
  397. package/src/types/memory/index.ts +69 -0
  398. package/src/types/message/index.ts +10 -2
  399. package/src/types/persona/index.ts +11 -0
  400. package/src/types/plugin/index.ts +231 -0
  401. package/src/types/router/index.ts +1 -0
  402. package/src/types/router/task-router.ts +20 -0
  403. package/src/types/run/emergency.ts +23 -0
  404. package/src/types/run/events.ts +15 -1
  405. package/src/types/run/index.ts +1 -0
  406. package/src/types/tool/index.ts +15 -0
  407. package/src/types/verification/index.ts +69 -0
  408. package/src/utils/id.ts +28 -0
  409. package/src/utils/shell-compress.ts +137 -0
  410. package/src/verification/gate.ts +136 -0
  411. package/src/verification/index.ts +2 -0
  412. package/src/verification/rules.ts +78 -0
@@ -0,0 +1,219 @@
1
+ import { z } from 'zod';
2
+ export type GateDecision = 'allow' | 'deny' | 'review';
3
+ export interface GateEvaluationResult {
4
+ readonly decision: GateDecision;
5
+ readonly matchedRule: VerificationRule | null;
6
+ readonly reason: string;
7
+ }
8
+ export type VerificationRule = {
9
+ type: 'allow_read_only';
10
+ } | {
11
+ type: 'deny_dangerous_patterns';
12
+ } | {
13
+ type: 'allow_by_category';
14
+ categories: string[];
15
+ } | {
16
+ type: 'allow_by_name';
17
+ toolNames: string[];
18
+ } | {
19
+ type: 'deny_by_name';
20
+ toolNames: string[];
21
+ } | {
22
+ type: 'custom_pattern';
23
+ pattern: string;
24
+ target: 'name' | 'args' | 'both';
25
+ decision: 'allow' | 'deny';
26
+ } | {
27
+ type: 'allow_by_tier';
28
+ tiers: string[];
29
+ };
30
+ export declare const VerificationRuleSchema: z.ZodDiscriminatedUnion<"type", [z.ZodObject<{
31
+ type: z.ZodLiteral<"allow_read_only">;
32
+ }, "strip", z.ZodTypeAny, {
33
+ type: "allow_read_only";
34
+ }, {
35
+ type: "allow_read_only";
36
+ }>, z.ZodObject<{
37
+ type: z.ZodLiteral<"deny_dangerous_patterns">;
38
+ }, "strip", z.ZodTypeAny, {
39
+ type: "deny_dangerous_patterns";
40
+ }, {
41
+ type: "deny_dangerous_patterns";
42
+ }>, z.ZodObject<{
43
+ type: z.ZodLiteral<"allow_by_category">;
44
+ categories: z.ZodArray<z.ZodString, "many">;
45
+ }, "strip", z.ZodTypeAny, {
46
+ categories: string[];
47
+ type: "allow_by_category";
48
+ }, {
49
+ categories: string[];
50
+ type: "allow_by_category";
51
+ }>, z.ZodObject<{
52
+ type: z.ZodLiteral<"allow_by_name">;
53
+ toolNames: z.ZodArray<z.ZodString, "many">;
54
+ }, "strip", z.ZodTypeAny, {
55
+ type: "allow_by_name";
56
+ toolNames: string[];
57
+ }, {
58
+ type: "allow_by_name";
59
+ toolNames: string[];
60
+ }>, z.ZodObject<{
61
+ type: z.ZodLiteral<"deny_by_name">;
62
+ toolNames: z.ZodArray<z.ZodString, "many">;
63
+ }, "strip", z.ZodTypeAny, {
64
+ type: "deny_by_name";
65
+ toolNames: string[];
66
+ }, {
67
+ type: "deny_by_name";
68
+ toolNames: string[];
69
+ }>, z.ZodObject<{
70
+ type: z.ZodLiteral<"custom_pattern">;
71
+ pattern: z.ZodString;
72
+ target: z.ZodEnum<["name", "args", "both"]>;
73
+ decision: z.ZodEnum<["allow", "deny"]>;
74
+ }, "strip", z.ZodTypeAny, {
75
+ type: "custom_pattern";
76
+ decision: "allow" | "deny";
77
+ target: "name" | "args" | "both";
78
+ pattern: string;
79
+ }, {
80
+ type: "custom_pattern";
81
+ decision: "allow" | "deny";
82
+ target: "name" | "args" | "both";
83
+ pattern: string;
84
+ }>, z.ZodObject<{
85
+ type: z.ZodLiteral<"allow_by_tier">;
86
+ tiers: z.ZodArray<z.ZodString, "many">;
87
+ }, "strip", z.ZodTypeAny, {
88
+ type: "allow_by_tier";
89
+ tiers: string[];
90
+ }, {
91
+ type: "allow_by_tier";
92
+ tiers: string[];
93
+ }>]>;
94
+ export declare const VerificationGateConfigSchema: z.ZodObject<{
95
+ enabled: z.ZodDefault<z.ZodBoolean>;
96
+ rules: z.ZodDefault<z.ZodArray<z.ZodDiscriminatedUnion<"type", [z.ZodObject<{
97
+ type: z.ZodLiteral<"allow_read_only">;
98
+ }, "strip", z.ZodTypeAny, {
99
+ type: "allow_read_only";
100
+ }, {
101
+ type: "allow_read_only";
102
+ }>, z.ZodObject<{
103
+ type: z.ZodLiteral<"deny_dangerous_patterns">;
104
+ }, "strip", z.ZodTypeAny, {
105
+ type: "deny_dangerous_patterns";
106
+ }, {
107
+ type: "deny_dangerous_patterns";
108
+ }>, z.ZodObject<{
109
+ type: z.ZodLiteral<"allow_by_category">;
110
+ categories: z.ZodArray<z.ZodString, "many">;
111
+ }, "strip", z.ZodTypeAny, {
112
+ categories: string[];
113
+ type: "allow_by_category";
114
+ }, {
115
+ categories: string[];
116
+ type: "allow_by_category";
117
+ }>, z.ZodObject<{
118
+ type: z.ZodLiteral<"allow_by_name">;
119
+ toolNames: z.ZodArray<z.ZodString, "many">;
120
+ }, "strip", z.ZodTypeAny, {
121
+ type: "allow_by_name";
122
+ toolNames: string[];
123
+ }, {
124
+ type: "allow_by_name";
125
+ toolNames: string[];
126
+ }>, z.ZodObject<{
127
+ type: z.ZodLiteral<"deny_by_name">;
128
+ toolNames: z.ZodArray<z.ZodString, "many">;
129
+ }, "strip", z.ZodTypeAny, {
130
+ type: "deny_by_name";
131
+ toolNames: string[];
132
+ }, {
133
+ type: "deny_by_name";
134
+ toolNames: string[];
135
+ }>, z.ZodObject<{
136
+ type: z.ZodLiteral<"custom_pattern">;
137
+ pattern: z.ZodString;
138
+ target: z.ZodEnum<["name", "args", "both"]>;
139
+ decision: z.ZodEnum<["allow", "deny"]>;
140
+ }, "strip", z.ZodTypeAny, {
141
+ type: "custom_pattern";
142
+ decision: "allow" | "deny";
143
+ target: "name" | "args" | "both";
144
+ pattern: string;
145
+ }, {
146
+ type: "custom_pattern";
147
+ decision: "allow" | "deny";
148
+ target: "name" | "args" | "both";
149
+ pattern: string;
150
+ }>, z.ZodObject<{
151
+ type: z.ZodLiteral<"allow_by_tier">;
152
+ tiers: z.ZodArray<z.ZodString, "many">;
153
+ }, "strip", z.ZodTypeAny, {
154
+ type: "allow_by_tier";
155
+ tiers: string[];
156
+ }, {
157
+ type: "allow_by_tier";
158
+ tiers: string[];
159
+ }>]>, "many">>;
160
+ allowReadOnlyTools: z.ZodDefault<z.ZodBoolean>;
161
+ denyDangerousPatterns: z.ZodDefault<z.ZodBoolean>;
162
+ logDecisions: z.ZodDefault<z.ZodBoolean>;
163
+ }, "strip", z.ZodTypeAny, {
164
+ enabled: boolean;
165
+ rules: ({
166
+ type: "allow_read_only";
167
+ } | {
168
+ type: "deny_dangerous_patterns";
169
+ } | {
170
+ categories: string[];
171
+ type: "allow_by_category";
172
+ } | {
173
+ type: "allow_by_name";
174
+ toolNames: string[];
175
+ } | {
176
+ type: "deny_by_name";
177
+ toolNames: string[];
178
+ } | {
179
+ type: "custom_pattern";
180
+ decision: "allow" | "deny";
181
+ target: "name" | "args" | "both";
182
+ pattern: string;
183
+ } | {
184
+ type: "allow_by_tier";
185
+ tiers: string[];
186
+ })[];
187
+ allowReadOnlyTools: boolean;
188
+ denyDangerousPatterns: boolean;
189
+ logDecisions: boolean;
190
+ }, {
191
+ enabled?: boolean | undefined;
192
+ rules?: ({
193
+ type: "allow_read_only";
194
+ } | {
195
+ type: "deny_dangerous_patterns";
196
+ } | {
197
+ categories: string[];
198
+ type: "allow_by_category";
199
+ } | {
200
+ type: "allow_by_name";
201
+ toolNames: string[];
202
+ } | {
203
+ type: "deny_by_name";
204
+ toolNames: string[];
205
+ } | {
206
+ type: "custom_pattern";
207
+ decision: "allow" | "deny";
208
+ target: "name" | "args" | "both";
209
+ pattern: string;
210
+ } | {
211
+ type: "allow_by_tier";
212
+ tiers: string[];
213
+ })[] | undefined;
214
+ allowReadOnlyTools?: boolean | undefined;
215
+ denyDangerousPatterns?: boolean | undefined;
216
+ logDecisions?: boolean | undefined;
217
+ }>;
218
+ export type VerificationGateConfig = z.infer<typeof VerificationGateConfigSchema>;
219
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAGvB,MAAM,MAAM,YAAY,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAA;AAEtD,MAAM,WAAW,oBAAoB;IACpC,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAA;IAC/B,QAAQ,CAAC,WAAW,EAAE,gBAAgB,GAAG,IAAI,CAAA;IAC7C,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;CACvB;AAED,MAAM,MAAM,gBAAgB,GACzB;IAAE,IAAI,EAAE,iBAAiB,CAAA;CAAE,GAC3B;IAAE,IAAI,EAAE,yBAAyB,CAAA;CAAE,GACnC;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,UAAU,EAAE,MAAM,EAAE,CAAA;CAAE,GACnD;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,SAAS,EAAE,MAAM,EAAE,CAAA;CAAE,GAC9C;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,SAAS,EAAE,MAAM,EAAE,CAAA;CAAE,GAC7C;IACA,IAAI,EAAE,gBAAgB,CAAA;IACtB,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;IAChC,QAAQ,EAAE,OAAO,GAAG,MAAM,CAAA;CACzB,GACD;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,KAAK,EAAE,MAAM,EAAE,CAAA;CAAE,CAAA;AA2B7C,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAQjC,CAAA;AAEF,eAAO,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAMvC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,4BAA4B,CAAC,CAAA"}
@@ -0,0 +1,43 @@
1
+ import { z } from 'zod';
2
+ import { MAX_CUSTOM_PATTERN_LENGTH } from '../../constants/verification/index.js';
3
+ const AllowReadOnlySchema = z.object({ type: z.literal('allow_read_only') });
4
+ const DenyDangerousPatternsSchema = z.object({ type: z.literal('deny_dangerous_patterns') });
5
+ const AllowByCategorySchema = z.object({
6
+ type: z.literal('allow_by_category'),
7
+ categories: z.array(z.string()),
8
+ });
9
+ const AllowByNameSchema = z.object({
10
+ type: z.literal('allow_by_name'),
11
+ toolNames: z.array(z.string()),
12
+ });
13
+ const DenyByNameSchema = z.object({
14
+ type: z.literal('deny_by_name'),
15
+ toolNames: z.array(z.string()),
16
+ });
17
+ const CustomPatternSchema = z.object({
18
+ type: z.literal('custom_pattern'),
19
+ pattern: z.string().max(MAX_CUSTOM_PATTERN_LENGTH),
20
+ target: z.enum(['name', 'args', 'both']),
21
+ decision: z.enum(['allow', 'deny']),
22
+ });
23
+ const AllowByTierSchema = z.object({
24
+ type: z.literal('allow_by_tier'),
25
+ tiers: z.array(z.string()),
26
+ });
27
+ export const VerificationRuleSchema = z.discriminatedUnion('type', [
28
+ AllowReadOnlySchema,
29
+ DenyDangerousPatternsSchema,
30
+ AllowByCategorySchema,
31
+ AllowByNameSchema,
32
+ DenyByNameSchema,
33
+ CustomPatternSchema,
34
+ AllowByTierSchema,
35
+ ]);
36
+ export const VerificationGateConfigSchema = z.object({
37
+ enabled: z.boolean().default(false),
38
+ rules: z.array(VerificationRuleSchema).default([]),
39
+ allowReadOnlyTools: z.boolean().default(false),
40
+ denyDangerousPatterns: z.boolean().default(false),
41
+ logDecisions: z.boolean().default(true),
42
+ });
43
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AACvB,OAAO,EAAE,yBAAyB,EAAE,MAAM,uCAAuC,CAAA;AAwBjF,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAA;AAC5E,MAAM,2BAA2B,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAA;AAC5F,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC;IACpC,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC/B,CAAC,CAAA;AACF,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC9B,CAAC,CAAA;AACF,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC;IACjC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC;IAC/B,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC9B,CAAC,CAAA;AACF,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IACpC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC;IACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,yBAAyB,CAAC;IAClD,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;CACnC,CAAC,CAAA;AACF,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC1B,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,kBAAkB,CAAC,MAAM,EAAE;IAClE,mBAAmB;IACnB,2BAA2B;IAC3B,qBAAqB;IACrB,iBAAiB;IACjB,gBAAgB;IAChB,mBAAmB;IACnB,iBAAiB;CACjB,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAAC,CAAC,MAAM,CAAC;IACpD,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACnC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IAClD,kBAAkB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9C,qBAAqB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACjD,YAAY,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;CACvC,CAAC,CAAA"}
@@ -1,4 +1,4 @@
1
- import type { ActivityId, CheckpointId, ChunkId, ConnectorId, ConnectorInstanceId, CredentialId, DocumentId, EnvironmentId, ExecutionContextId, KnowledgeBaseId, MCPClientId, MCPServerId, MCPSessionId, MessageId, PlanId, RunId, SessionId, TaskId, TenantId, ThreadId, ToolCallId } from '../types/ids/index.js';
1
+ import type { ActivityId, AdvisoryCallId, AdvisoryId, CheckpointId, ChunkId, ConnectorId, ConnectorInstanceId, CredentialId, DocumentId, EmergencySaveId, EnvironmentId, ExecutionContextId, KnowledgeBaseId, MCPClientId, MCPServerId, MCPSessionId, MemoryId, MessageId, PlanId, PluginId, RunId, SessionId, TaskId, TenantId, ThreadId, ToolCallId } from '../types/ids/index.js';
2
2
  export declare function generateThreadId(): ThreadId;
3
3
  export declare function generateRunId(): RunId;
4
4
  export declare function generateMessageId(): MessageId;
@@ -20,7 +20,13 @@ export declare function generateMCPClientId(): MCPClientId;
20
20
  export declare function generateMCPSessionId(): MCPSessionId;
21
21
  export declare function generateEnvironmentId(): EnvironmentId;
22
22
  export declare function generateCheckpointId(): CheckpointId;
23
+ export declare function generateAdvisoryId(): AdvisoryId;
24
+ export declare function generateAdvisoryCallId(): AdvisoryCallId;
25
+ export declare function generateEmergencySaveId(): EmergencySaveId;
26
+ export declare function generateMemoryId(): MemoryId;
27
+ export declare function generatePluginId(): PluginId;
23
28
  export declare function parseThreadId(raw: string): ThreadId;
24
29
  export declare function parseRunId(raw: string): RunId;
25
30
  export declare function parseConnectorInstanceId(raw: string): ConnectorInstanceId;
31
+ export declare function parsePluginId(raw: string): PluginId;
26
32
  //# sourceMappingURL=id.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"id.d.ts","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,UAAU,EACV,YAAY,EACZ,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,YAAY,EACZ,UAAU,EACV,aAAa,EACb,kBAAkB,EAClB,eAAe,EACf,WAAW,EACX,WAAW,EACX,YAAY,EACZ,SAAS,EACT,MAAM,EACN,KAAK,EACL,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,uBAAuB,CAAA;AAsB9B,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,aAAa,IAAI,KAAK,CAErC;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,eAAe,IAAI,OAAO,CAEzC;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,2BAA2B,IAAI,mBAAmB,CAEjE;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,0BAA0B,IAAI,kBAAkB,CAE/D;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,qBAAqB,IAAI,aAAa,CAErD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AASD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD;AACD,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAE7C;AACD,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,mBAAmB,CAEzE"}
1
+ {"version":3,"file":"id.d.ts","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,UAAU,EACV,cAAc,EACd,UAAU,EACV,YAAY,EACZ,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,YAAY,EACZ,UAAU,EACV,eAAe,EACf,aAAa,EACb,kBAAkB,EAClB,eAAe,EACf,WAAW,EACX,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,MAAM,EACN,QAAQ,EACR,KAAK,EACL,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,uBAAuB,CAAA;AAsB9B,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,aAAa,IAAI,KAAK,CAErC;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,eAAe,IAAI,OAAO,CAEzC;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,2BAA2B,IAAI,mBAAmB,CAEjE;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,0BAA0B,IAAI,kBAAkB,CAE/D;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,qBAAqB,IAAI,aAAa,CAErD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,sBAAsB,IAAI,cAAc,CAEvD;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AASD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD;AACD,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAE7C;AACD,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,mBAAmB,CAEzE;AACD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD"}
package/dist/utils/id.js CHANGED
@@ -81,6 +81,21 @@ export function generateEnvironmentId() {
81
81
  export function generateCheckpointId() {
82
82
  return generateId('cp_');
83
83
  }
84
+ export function generateAdvisoryId() {
85
+ return generateId('adv_');
86
+ }
87
+ export function generateAdvisoryCallId() {
88
+ return generateId('advc_');
89
+ }
90
+ export function generateEmergencySaveId() {
91
+ return generateId('esave_');
92
+ }
93
+ export function generateMemoryId() {
94
+ return generateId('mem_');
95
+ }
96
+ export function generatePluginId() {
97
+ return generateId('plg_');
98
+ }
84
99
  function parseId(raw, prefix, typeName) {
85
100
  if (!raw.startsWith(prefix)) {
86
101
  throw new Error(`Invalid ${typeName}: expected "${prefix}" prefix, got "${raw}"`);
@@ -96,4 +111,7 @@ export function parseRunId(raw) {
96
111
  export function parseConnectorInstanceId(raw) {
97
112
  return parseId(raw, 'ci_', 'ConnectorInstanceId');
98
113
  }
114
+ export function parsePluginId(raw) {
115
+ return parseId(raw, 'plg_', 'PluginId');
116
+ }
99
117
  //# sourceMappingURL=id.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"id.js","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"id.js","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ export interface ShellCompressResult {
2
+ text: string;
3
+ original: string | null;
4
+ }
5
+ export interface ShellCompressOptions {
6
+ minLines?: number;
7
+ minReductionPercent?: number;
8
+ maxStackFrames?: number;
9
+ maxPassLines?: number;
10
+ }
11
+ export declare function compressShellOutputFull(raw: string, options?: ShellCompressOptions): ShellCompressResult;
12
+ export declare function compressShellOutput(raw: string, options?: ShellCompressOptions): string;
13
+ //# sourceMappingURL=shell-compress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-compress.d.ts","sourceRoot":"","sources":["../../src/utils/shell-compress.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,mBAAmB;IACnC,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;CACvB;AAED,MAAM,WAAW,oBAAoB;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,mBAAmB,CAAC,EAAE,MAAM,CAAA;IAC5B,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,YAAY,CAAC,EAAE,MAAM,CAAA;CACrB;AAgCD,wBAAgB,uBAAuB,CACtC,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,oBAAoB,GAC5B,mBAAmB,CAyErB;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,oBAAoB,GAAG,MAAM,CAEvF"}
@@ -0,0 +1,97 @@
1
+ const STACK_FRAME_RE = /^\s+at\s+|^\s+File\s+"[^"]+",\s+line\s+\d+|^\s+at\s+[\w.$]+\(|^\s+\d+:\s+\w|^\s+from\s+\//;
2
+ const PASS_LINE_RE = /[\s✓✔√●∙·►▸▹]+\s*(PASS|pass|ok|OK|✓|✔|√)\s|^\s*(PASS|ok)\s+[\w/.-]+|^ok\s+\d+\s|PASSED\s*$|^---\s*PASS:|^test\s+\S+\s+\.\.\.\s+ok\s*$/;
3
+ const NOISE_RE = /^\s*[\\\/|─━░▓█▒■□◻◼⠋⠙⠹⠸⠼⠴⠦⠧⠇⠏⣾⣽⣻⢿⡿⣟⣯⣷]+\s*$|^\s*\d+%\s*[|█▓░]+|^(Downloading|Fetching|Installing|Resolving|Compiling)\b.*\.\.\./;
4
+ const DEFAULT_MIN_LINES = 20;
5
+ const DEFAULT_MIN_REDUCTION = 0.1;
6
+ const DEFAULT_MAX_STACK_FRAMES = 5;
7
+ const DEFAULT_MAX_PASS_LINES = 3;
8
+ function normalizeLine(line) {
9
+ return line.replace(/^\s*\d+[\s:.|)]+/, '').replace(/\d+/g, 'N');
10
+ }
11
+ function collapseRepeated(lines) {
12
+ const result = [];
13
+ let prevNorm = '';
14
+ let repeatCount = 0;
15
+ for (const line of lines) {
16
+ const norm = normalizeLine(line);
17
+ if (norm === prevNorm && norm.trim().length > 0) {
18
+ repeatCount++;
19
+ }
20
+ else {
21
+ if (repeatCount > 0) {
22
+ result.push(`... ${repeatCount} similar line${repeatCount === 1 ? '' : 's'} omitted`);
23
+ }
24
+ result.push(line);
25
+ prevNorm = norm;
26
+ repeatCount = 0;
27
+ }
28
+ }
29
+ if (repeatCount > 0) {
30
+ result.push(`... ${repeatCount} similar line${repeatCount === 1 ? '' : 's'} omitted`);
31
+ }
32
+ return result;
33
+ }
34
+ export function compressShellOutputFull(raw, options) {
35
+ const minLines = options?.minLines ?? DEFAULT_MIN_LINES;
36
+ const minReduction = options?.minReductionPercent ?? DEFAULT_MIN_REDUCTION;
37
+ const maxStackFrames = options?.maxStackFrames ?? DEFAULT_MAX_STACK_FRAMES;
38
+ const maxPassLines = options?.maxPassLines ?? DEFAULT_MAX_PASS_LINES;
39
+ const lines = raw.split('\n');
40
+ if (lines.length < minLines) {
41
+ return { text: raw, original: null };
42
+ }
43
+ // Pass 1: stack frame compression, pass test suppression, noise removal
44
+ const pass1 = [];
45
+ let stackCount = 0;
46
+ let passCount = 0;
47
+ for (const line of lines) {
48
+ // Noise removal
49
+ if (NOISE_RE.test(line)) {
50
+ continue;
51
+ }
52
+ // Stack frame compression
53
+ if (STACK_FRAME_RE.test(line)) {
54
+ stackCount++;
55
+ if (stackCount <= maxStackFrames) {
56
+ pass1.push(line);
57
+ }
58
+ continue;
59
+ }
60
+ if (stackCount > maxStackFrames) {
61
+ pass1.push(`... ${stackCount - maxStackFrames} more frames`);
62
+ }
63
+ stackCount = 0;
64
+ // Pass test suppression
65
+ if (PASS_LINE_RE.test(line)) {
66
+ passCount++;
67
+ if (passCount <= maxPassLines) {
68
+ pass1.push(line);
69
+ }
70
+ continue;
71
+ }
72
+ if (passCount > maxPassLines) {
73
+ pass1.push(`... ${passCount - maxPassLines} passing tests omitted`);
74
+ }
75
+ passCount = 0;
76
+ pass1.push(line);
77
+ }
78
+ // Flush trailing counters
79
+ if (stackCount > maxStackFrames) {
80
+ pass1.push(`... ${stackCount - maxStackFrames} more frames`);
81
+ }
82
+ if (passCount > maxPassLines) {
83
+ pass1.push(`... ${passCount - maxPassLines} passing tests omitted`);
84
+ }
85
+ // Pass 2: collapse repeated lines
86
+ const pass2 = collapseRepeated(pass1);
87
+ const compressed = pass2.join('\n');
88
+ const reduction = 1 - compressed.length / raw.length;
89
+ if (reduction < minReduction) {
90
+ return { text: raw, original: null };
91
+ }
92
+ return { text: compressed, original: raw };
93
+ }
94
+ export function compressShellOutput(raw, options) {
95
+ return compressShellOutputFull(raw, options).text;
96
+ }
97
+ //# sourceMappingURL=shell-compress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-compress.js","sourceRoot":"","sources":["../../src/utils/shell-compress.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import type { ToolDefinition } from '../types/tool/index.js';
2
+ import type { GateEvaluationResult, VerificationGateConfig } from '../types/verification/index.js';
3
+ import type { Logger } from '../utils/logger.js';
4
+ export interface ToolCallContext {
5
+ readonly toolName: string;
6
+ readonly toolInput: unknown;
7
+ readonly toolDef: ToolDefinition | undefined;
8
+ }
9
+ export declare class VerificationGate {
10
+ private readonly rules;
11
+ private readonly compiledPatterns;
12
+ private readonly nameSets;
13
+ private readonly log;
14
+ private readonly logDecisions;
15
+ private readonly enabled;
16
+ constructor(config: VerificationGateConfig, log: Logger);
17
+ evaluate(ctx: ToolCallContext): GateEvaluationResult;
18
+ }
19
+ //# sourceMappingURL=gate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gate.d.ts","sourceRoot":"","sources":["../../src/verification/gate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,KAAK,EACX,oBAAoB,EACpB,sBAAsB,EAEtB,MAAM,gCAAgC,CAAA;AAEvC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAGhD,MAAM,WAAW,eAAe;IAC/B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAA;IAC3B,QAAQ,CAAC,OAAO,EAAE,cAAc,GAAG,SAAS,CAAA;CAC5C;AAED,qBAAa,gBAAgB;IAC5B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAoB;IAC1C,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAqB;IACtD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;IACnD,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAQ;IAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAErB,MAAM,EAAE,sBAAsB,EAAE,GAAG,EAAE,MAAM;IAsDvD,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,oBAAoB;CAwDpD"}
@@ -0,0 +1,103 @@
1
+ import { MAX_CUSTOM_PATTERN_LENGTH } from '../constants/verification/index.js';
2
+ import { VerificationGateConfigSchema } from '../types/verification/index.js';
3
+ import { evaluateRule } from './rules.js';
4
+ export class VerificationGate {
5
+ rules;
6
+ compiledPatterns;
7
+ nameSets;
8
+ log;
9
+ logDecisions;
10
+ enabled;
11
+ constructor(config, log) {
12
+ const parsed = VerificationGateConfigSchema.parse(config);
13
+ this.log = log.child({ component: 'VerificationGate' });
14
+ this.logDecisions = parsed.logDecisions;
15
+ this.enabled = parsed.enabled;
16
+ const expandedRules = [];
17
+ if (parsed.denyDangerousPatterns) {
18
+ expandedRules.push({ type: 'deny_dangerous_patterns' });
19
+ }
20
+ if (parsed.allowReadOnlyTools) {
21
+ expandedRules.push({ type: 'allow_read_only' });
22
+ }
23
+ expandedRules.push(...parsed.rules);
24
+ this.rules = expandedRules;
25
+ this.compiledPatterns = new Map();
26
+ this.nameSets = new Map();
27
+ for (let i = 0; i < this.rules.length; i++) {
28
+ const rule = this.rules[i];
29
+ if (!rule)
30
+ continue;
31
+ if (rule.type === 'custom_pattern') {
32
+ if (rule.pattern.length > MAX_CUSTOM_PATTERN_LENGTH) {
33
+ this.log.warn('Custom pattern exceeds max length, skipping', {
34
+ index: i,
35
+ length: rule.pattern.length,
36
+ maxLength: MAX_CUSTOM_PATTERN_LENGTH,
37
+ });
38
+ continue;
39
+ }
40
+ try {
41
+ this.compiledPatterns.set(i, new RegExp(rule.pattern));
42
+ }
43
+ catch (err) {
44
+ this.log.warn('Invalid custom pattern regex, skipping', {
45
+ index: i,
46
+ pattern: rule.pattern,
47
+ error: err instanceof Error ? err.message : String(err),
48
+ });
49
+ }
50
+ }
51
+ if (rule.type === 'allow_by_name') {
52
+ this.nameSets.set(i, new Set(rule.toolNames));
53
+ }
54
+ if (rule.type === 'deny_by_name') {
55
+ this.nameSets.set(i, new Set(rule.toolNames));
56
+ }
57
+ }
58
+ }
59
+ evaluate(ctx) {
60
+ if (!this.enabled) {
61
+ return {
62
+ decision: 'review',
63
+ matchedRule: null,
64
+ reason: 'Gate disabled',
65
+ };
66
+ }
67
+ for (let i = 0; i < this.rules.length; i++) {
68
+ const rule = this.rules[i];
69
+ if (!rule)
70
+ continue;
71
+ const decision = evaluateRule(rule, ctx.toolName, ctx.toolInput, ctx.toolDef, this.compiledPatterns.get(i), this.nameSets.get(i));
72
+ if (decision !== null) {
73
+ const result = {
74
+ decision,
75
+ matchedRule: rule,
76
+ reason: `Matched rule: ${rule.type}`,
77
+ };
78
+ if (this.logDecisions) {
79
+ this.log.debug('Gate decision', {
80
+ toolName: ctx.toolName,
81
+ decision,
82
+ ruleType: rule.type,
83
+ ruleIndex: i,
84
+ });
85
+ }
86
+ return result;
87
+ }
88
+ }
89
+ const result = {
90
+ decision: 'review',
91
+ matchedRule: null,
92
+ reason: 'No matching rule found',
93
+ };
94
+ if (this.logDecisions) {
95
+ this.log.debug('Gate decision (default)', {
96
+ toolName: ctx.toolName,
97
+ decision: 'review',
98
+ });
99
+ }
100
+ return result;
101
+ }
102
+ }
103
+ //# sourceMappingURL=gate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gate.js","sourceRoot":"","sources":["../../src/verification/gate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAA;AAO9E,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAA;AAE7E,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAQzC,MAAM,OAAO,gBAAgB;IACX,KAAK,CAAoB;IACzB,gBAAgB,CAAqB;IACrC,QAAQ,CAA0B;IAClC,GAAG,CAAQ;IACX,YAAY,CAAS;IACrB,OAAO,CAAS;IAEjC,YAAY,MAA8B,EAAE,GAAW;QACtD,MAAM,MAAM,GAAG,4BAA4B,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QACzD,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAA;QACvD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAA;QAE7B,MAAM,aAAa,GAAuB,EAAE,CAAA;QAE5C,IAAI,MAAM,CAAC,qBAAqB,EAAE,CAAC;YAClC,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,yBAAyB,EAAE,CAAC,CAAA;QACxD,CAAC;QACD,IAAI,MAAM,CAAC,kBAAkB,EAAE,CAAC;YAC/B,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,CAAA;QAChD,CAAC;QAED,aAAa,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;QACnC,IAAI,CAAC,KAAK,GAAG,aAAa,CAAA;QAE1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAA;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAE,CAAA;QAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAC1B,IAAI,CAAC,IAAI;gBAAE,SAAQ;YAEnB,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;gBACpC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,yBAAyB,EAAE,CAAC;oBACrD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,6CAA6C,EAAE;wBAC5D,KAAK,EAAE,CAAC;wBACR,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;wBAC3B,SAAS,EAAE,yBAAyB;qBACpC,CAAC,CAAA;oBACF,SAAQ;gBACT,CAAC;gBACD,IAAI,CAAC;oBACJ,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;gBACvD,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACd,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,wCAAwC,EAAE;wBACvD,KAAK,EAAE,CAAC;wBACR,OAAO,EAAE,IAAI,CAAC,OAAO;wBACrB,KAAK,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;qBACvD,CAAC,CAAA;gBACH,CAAC;YACF,CAAC;YAED,IAAI,IAAI,CAAC,IAAI,KAAK,eAAe,EAAE,CAAC;gBACnC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;YAC9C,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;gBAClC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;YAC9C,CAAC;QACF,CAAC;IACF,CAAC;IAED,QAAQ,CAAC,GAAoB;QAC5B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO;gBACN,QAAQ,EAAE,QAAQ;gBAClB,WAAW,EAAE,IAAI;gBACjB,MAAM,EAAE,eAAe;aACvB,CAAA;QACF,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAC1B,IAAI,CAAC,IAAI;gBAAE,SAAQ;YACnB,MAAM,QAAQ,GAAG,YAAY,CAC5B,IAAI,EACJ,GAAG,CAAC,QAAQ,EACZ,GAAG,CAAC,SAAS,EACb,GAAG,CAAC,OAAO,EACX,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAC5B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CACpB,CAAA;YAED,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;gBACvB,MAAM,MAAM,GAAyB;oBACpC,QAAQ;oBACR,WAAW,EAAE,IAAI;oBACjB,MAAM,EAAE,iBAAiB,IAAI,CAAC,IAAI,EAAE;iBACpC,CAAA;gBAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACvB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,EAAE;wBAC/B,QAAQ,EAAE,GAAG,CAAC,QAAQ;wBACtB,QAAQ;wBACR,QAAQ,EAAE,IAAI,CAAC,IAAI;wBACnB,SAAS,EAAE,CAAC;qBACZ,CAAC,CAAA;gBACH,CAAC;gBAED,OAAO,MAAM,CAAA;YACd,CAAC;QACF,CAAC;QAED,MAAM,MAAM,GAAyB;YACpC,QAAQ,EAAE,QAAQ;YAClB,WAAW,EAAE,IAAI;YACjB,MAAM,EAAE,wBAAwB;SAChC,CAAA;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,yBAAyB,EAAE;gBACzC,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACtB,QAAQ,EAAE,QAAQ;aAClB,CAAC,CAAA;QACH,CAAC;QAED,OAAO,MAAM,CAAA;IACd,CAAC;CACD"}
@@ -0,0 +1,3 @@
1
+ export { VerificationGate, type ToolCallContext } from './gate.js';
2
+ export { evaluateRule } from './rules.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,KAAK,eAAe,EAAE,MAAM,WAAW,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
@@ -0,0 +1,3 @@
1
+ export { VerificationGate } from './gate.js';
2
+ export { evaluateRule } from './rules.js';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAwB,MAAM,WAAW,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
@@ -0,0 +1,4 @@
1
+ import type { ToolDefinition } from '../types/tool/index.js';
2
+ import type { GateDecision, VerificationRule } from '../types/verification/index.js';
3
+ export declare function evaluateRule(rule: VerificationRule, toolName: string, toolInput: unknown, toolDef: ToolDefinition | undefined, compiledPattern?: RegExp, nameSet?: Set<string>): GateDecision | null;
4
+ //# sourceMappingURL=rules.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rules.d.ts","sourceRoot":"","sources":["../../src/verification/rules.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAEpF,wBAAgB,YAAY,CAC3B,IAAI,EAAE,gBAAgB,EACtB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,OAAO,EAClB,OAAO,EAAE,cAAc,GAAG,SAAS,EACnC,eAAe,CAAC,EAAE,MAAM,EACxB,OAAO,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,GACnB,YAAY,GAAG,IAAI,CAkErB"}