@amodalai/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 (463) hide show
  1. package/LICENSE +21 -0
  2. package/dist/.last_build +0 -0
  3. package/dist/src/amodal-config.d.ts +194 -0
  4. package/dist/src/amodal-config.js +326 -0
  5. package/dist/src/amodal-config.js.map +1 -0
  6. package/dist/src/audit/audit-logger.d.ts +52 -0
  7. package/dist/src/audit/audit-logger.js +137 -0
  8. package/dist/src/audit/audit-logger.js.map +1 -0
  9. package/dist/src/audit/audit-outputs.d.ts +34 -0
  10. package/dist/src/audit/audit-outputs.js +73 -0
  11. package/dist/src/audit/audit-outputs.js.map +1 -0
  12. package/dist/src/audit/audit-redact.d.ts +14 -0
  13. package/dist/src/audit/audit-redact.js +55 -0
  14. package/dist/src/audit/audit-redact.js.map +1 -0
  15. package/dist/src/audit/audit-types.d.ts +122 -0
  16. package/dist/src/audit/audit-types.js +64 -0
  17. package/dist/src/audit/audit-types.js.map +1 -0
  18. package/dist/src/audit/index.d.ts +10 -0
  19. package/dist/src/audit/index.js +10 -0
  20. package/dist/src/audit/index.js.map +1 -0
  21. package/dist/src/eval/eval-cost.d.ts +33 -0
  22. package/dist/src/eval/eval-cost.js +73 -0
  23. package/dist/src/eval/eval-cost.js.map +1 -0
  24. package/dist/src/eval/eval-diff.d.ts +11 -0
  25. package/dist/src/eval/eval-diff.js +97 -0
  26. package/dist/src/eval/eval-diff.js.map +1 -0
  27. package/dist/src/eval/eval-formatter.d.ts +23 -0
  28. package/dist/src/eval/eval-formatter.js +221 -0
  29. package/dist/src/eval/eval-formatter.js.map +1 -0
  30. package/dist/src/eval/eval-judge.d.ts +26 -0
  31. package/dist/src/eval/eval-judge.js +76 -0
  32. package/dist/src/eval/eval-judge.js.map +1 -0
  33. package/dist/src/eval/eval-run-builder.d.ts +25 -0
  34. package/dist/src/eval/eval-run-builder.js +78 -0
  35. package/dist/src/eval/eval-run-builder.js.map +1 -0
  36. package/dist/src/eval/eval-runner.d.ts +36 -0
  37. package/dist/src/eval/eval-runner.js +92 -0
  38. package/dist/src/eval/eval-runner.js.map +1 -0
  39. package/dist/src/eval/eval-session-provider.d.ts +40 -0
  40. package/dist/src/eval/eval-session-provider.js +46 -0
  41. package/dist/src/eval/eval-session-provider.js.map +1 -0
  42. package/dist/src/eval/eval-types.d.ts +146 -0
  43. package/dist/src/eval/eval-types.js +7 -0
  44. package/dist/src/eval/eval-types.js.map +1 -0
  45. package/dist/src/eval/experiment-runner.d.ts +16 -0
  46. package/dist/src/eval/experiment-runner.js +73 -0
  47. package/dist/src/eval/experiment-runner.js.map +1 -0
  48. package/dist/src/eval/experiment-types.d.ts +56 -0
  49. package/dist/src/eval/experiment-types.js +7 -0
  50. package/dist/src/eval/experiment-types.js.map +1 -0
  51. package/dist/src/eval/index.d.ts +22 -0
  52. package/dist/src/eval/index.js +18 -0
  53. package/dist/src/eval/index.js.map +1 -0
  54. package/dist/src/eval/multi-model-runner.d.ts +42 -0
  55. package/dist/src/eval/multi-model-runner.js +70 -0
  56. package/dist/src/eval/multi-model-runner.js.map +1 -0
  57. package/dist/src/eval/platform-eval-client.d.ts +105 -0
  58. package/dist/src/eval/platform-eval-client.js +155 -0
  59. package/dist/src/eval/platform-eval-client.js.map +1 -0
  60. package/dist/src/index.d.ts +41 -0
  61. package/dist/src/index.js +68 -0
  62. package/dist/src/index.js.map +1 -0
  63. package/dist/src/knowledge/index.d.ts +11 -0
  64. package/dist/src/knowledge/index.js +12 -0
  65. package/dist/src/knowledge/index.js.map +1 -0
  66. package/dist/src/knowledge/kb-formatter.d.ts +15 -0
  67. package/dist/src/knowledge/kb-formatter.js +78 -0
  68. package/dist/src/knowledge/kb-formatter.js.map +1 -0
  69. package/dist/src/knowledge/kb-index.d.ts +27 -0
  70. package/dist/src/knowledge/kb-index.js +66 -0
  71. package/dist/src/knowledge/kb-index.js.map +1 -0
  72. package/dist/src/knowledge/kb-types.d.ts +54 -0
  73. package/dist/src/knowledge/kb-types.js +7 -0
  74. package/dist/src/knowledge/kb-types.js.map +1 -0
  75. package/dist/src/knowledge/knowledge-store.d.ts +56 -0
  76. package/dist/src/knowledge/knowledge-store.js +141 -0
  77. package/dist/src/knowledge/knowledge-store.js.map +1 -0
  78. package/dist/src/knowledge/load-knowledge.d.ts +30 -0
  79. package/dist/src/knowledge/load-knowledge.js +161 -0
  80. package/dist/src/knowledge/load-knowledge.js.map +1 -0
  81. package/dist/src/knowledge/propose-kb-update.d.ts +32 -0
  82. package/dist/src/knowledge/propose-kb-update.js +148 -0
  83. package/dist/src/knowledge/propose-kb-update.js.map +1 -0
  84. package/dist/src/knowledge/propose-knowledge.d.ts +34 -0
  85. package/dist/src/knowledge/propose-knowledge.js +163 -0
  86. package/dist/src/knowledge/propose-knowledge.js.map +1 -0
  87. package/dist/src/mcp/index.d.ts +7 -0
  88. package/dist/src/mcp/index.js +7 -0
  89. package/dist/src/mcp/index.js.map +1 -0
  90. package/dist/src/mcp/mcp-manager.d.ts +96 -0
  91. package/dist/src/mcp/mcp-manager.js +192 -0
  92. package/dist/src/mcp/mcp-manager.js.map +1 -0
  93. package/dist/src/packages/config-deps.d.ts +20 -0
  94. package/dist/src/packages/config-deps.js +77 -0
  95. package/dist/src/packages/config-deps.js.map +1 -0
  96. package/dist/src/packages/env-file.d.ts +28 -0
  97. package/dist/src/packages/env-file.js +143 -0
  98. package/dist/src/packages/env-file.js.map +1 -0
  99. package/dist/src/packages/frontmatter.d.ts +28 -0
  100. package/dist/src/packages/frontmatter.js +77 -0
  101. package/dist/src/packages/frontmatter.js.map +1 -0
  102. package/dist/src/packages/index.d.ts +16 -0
  103. package/dist/src/packages/index.js +17 -0
  104. package/dist/src/packages/index.js.map +1 -0
  105. package/dist/src/packages/lock-file.d.ts +35 -0
  106. package/dist/src/packages/lock-file.js +117 -0
  107. package/dist/src/packages/lock-file.js.map +1 -0
  108. package/dist/src/packages/manifest-reader.d.ts +19 -0
  109. package/dist/src/packages/manifest-reader.js +91 -0
  110. package/dist/src/packages/manifest-reader.js.map +1 -0
  111. package/dist/src/packages/merge-engine.d.ts +63 -0
  112. package/dist/src/packages/merge-engine.js +357 -0
  113. package/dist/src/packages/merge-engine.js.map +1 -0
  114. package/dist/src/packages/npm-context.d.ts +56 -0
  115. package/dist/src/packages/npm-context.js +235 -0
  116. package/dist/src/packages/npm-context.js.map +1 -0
  117. package/dist/src/packages/npm-registry.d.ts +35 -0
  118. package/dist/src/packages/npm-registry.js +107 -0
  119. package/dist/src/packages/npm-registry.js.map +1 -0
  120. package/dist/src/packages/package-error.d.ts +16 -0
  121. package/dist/src/packages/package-error.js +17 -0
  122. package/dist/src/packages/package-error.js.map +1 -0
  123. package/dist/src/packages/package-types.d.ts +477 -0
  124. package/dist/src/packages/package-types.js +156 -0
  125. package/dist/src/packages/package-types.js.map +1 -0
  126. package/dist/src/packages/resolver.d.ts +41 -0
  127. package/dist/src/packages/resolver.js +353 -0
  128. package/dist/src/packages/resolver.js.map +1 -0
  129. package/dist/src/platform/config-builder.d.ts +24 -0
  130. package/dist/src/platform/config-builder.js +70 -0
  131. package/dist/src/platform/config-builder.js.map +1 -0
  132. package/dist/src/platform/index.d.ts +8 -0
  133. package/dist/src/platform/index.js +9 -0
  134. package/dist/src/platform/index.js.map +1 -0
  135. package/dist/src/platform/platform-client.d.ts +160 -0
  136. package/dist/src/platform/platform-client.js +486 -0
  137. package/dist/src/platform/platform-client.js.map +1 -0
  138. package/dist/src/platform/platform-types.d.ts +81 -0
  139. package/dist/src/platform/platform-types.js +18 -0
  140. package/dist/src/platform/platform-types.js.map +1 -0
  141. package/dist/src/providers/content-generator/google-to-llm.d.ts +87 -0
  142. package/dist/src/providers/content-generator/google-to-llm.js +226 -0
  143. package/dist/src/providers/content-generator/google-to-llm.js.map +1 -0
  144. package/dist/src/providers/content-generator/index.d.ts +10 -0
  145. package/dist/src/providers/content-generator/index.js +9 -0
  146. package/dist/src/providers/content-generator/index.js.map +1 -0
  147. package/dist/src/providers/content-generator/llm-to-google.d.ts +59 -0
  148. package/dist/src/providers/content-generator/llm-to-google.js +178 -0
  149. package/dist/src/providers/content-generator/llm-to-google.js.map +1 -0
  150. package/dist/src/providers/content-generator/multi-provider-content-generator.d.ts +61 -0
  151. package/dist/src/providers/content-generator/multi-provider-content-generator.js +144 -0
  152. package/dist/src/providers/content-generator/multi-provider-content-generator.js.map +1 -0
  153. package/dist/src/providers/runtime/anthropic-provider.d.ts +18 -0
  154. package/dist/src/providers/runtime/anthropic-provider.js +253 -0
  155. package/dist/src/providers/runtime/anthropic-provider.js.map +1 -0
  156. package/dist/src/providers/runtime/azure-provider.d.ts +25 -0
  157. package/dist/src/providers/runtime/azure-provider.js +206 -0
  158. package/dist/src/providers/runtime/azure-provider.js.map +1 -0
  159. package/dist/src/providers/runtime/bedrock-provider.d.ts +22 -0
  160. package/dist/src/providers/runtime/bedrock-provider.js +276 -0
  161. package/dist/src/providers/runtime/bedrock-provider.js.map +1 -0
  162. package/dist/src/providers/runtime/failover-provider.d.ts +30 -0
  163. package/dist/src/providers/runtime/failover-provider.js +124 -0
  164. package/dist/src/providers/runtime/failover-provider.js.map +1 -0
  165. package/dist/src/providers/runtime/google-provider.d.ts +17 -0
  166. package/dist/src/providers/runtime/google-provider.js +239 -0
  167. package/dist/src/providers/runtime/google-provider.js.map +1 -0
  168. package/dist/src/providers/runtime/index.d.ts +16 -0
  169. package/dist/src/providers/runtime/index.js +16 -0
  170. package/dist/src/providers/runtime/index.js.map +1 -0
  171. package/dist/src/providers/runtime/openai-provider.d.ts +21 -0
  172. package/dist/src/providers/runtime/openai-provider.js +266 -0
  173. package/dist/src/providers/runtime/openai-provider.js.map +1 -0
  174. package/dist/src/providers/runtime/provider-errors.d.ts +39 -0
  175. package/dist/src/providers/runtime/provider-errors.js +50 -0
  176. package/dist/src/providers/runtime/provider-errors.js.map +1 -0
  177. package/dist/src/providers/runtime/provider-factory.d.ts +19 -0
  178. package/dist/src/providers/runtime/provider-factory.js +45 -0
  179. package/dist/src/providers/runtime/provider-factory.js.map +1 -0
  180. package/dist/src/providers/runtime/runtime-provider-types.d.ts +63 -0
  181. package/dist/src/providers/runtime/runtime-provider-types.js +7 -0
  182. package/dist/src/providers/runtime/runtime-provider-types.js.map +1 -0
  183. package/dist/src/providers/runtime/streaming-types.d.ts +40 -0
  184. package/dist/src/providers/runtime/streaming-types.js +7 -0
  185. package/dist/src/providers/runtime/streaming-types.js.map +1 -0
  186. package/dist/src/repo/config-schema.d.ts +238 -0
  187. package/dist/src/repo/config-schema.js +155 -0
  188. package/dist/src/repo/config-schema.js.map +1 -0
  189. package/dist/src/repo/connection-schemas.d.ts +449 -0
  190. package/dist/src/repo/connection-schemas.js +109 -0
  191. package/dist/src/repo/connection-schemas.js.map +1 -0
  192. package/dist/src/repo/connection-types.d.ts +29 -0
  193. package/dist/src/repo/connection-types.js +7 -0
  194. package/dist/src/repo/connection-types.js.map +1 -0
  195. package/dist/src/repo/drift-detector.d.ts +26 -0
  196. package/dist/src/repo/drift-detector.js +66 -0
  197. package/dist/src/repo/drift-detector.js.map +1 -0
  198. package/dist/src/repo/graphql-drift-detector.d.ts +27 -0
  199. package/dist/src/repo/graphql-drift-detector.js +66 -0
  200. package/dist/src/repo/graphql-drift-detector.js.map +1 -0
  201. package/dist/src/repo/graphql-parser.d.ts +30 -0
  202. package/dist/src/repo/graphql-parser.js +125 -0
  203. package/dist/src/repo/graphql-parser.js.map +1 -0
  204. package/dist/src/repo/graphql-surface-parser.d.ts +20 -0
  205. package/dist/src/repo/graphql-surface-parser.js +74 -0
  206. package/dist/src/repo/graphql-surface-parser.js.map +1 -0
  207. package/dist/src/repo/index.d.ts +30 -0
  208. package/dist/src/repo/index.js +29 -0
  209. package/dist/src/repo/index.js.map +1 -0
  210. package/dist/src/repo/local-reader.d.ts +10 -0
  211. package/dist/src/repo/local-reader.js +299 -0
  212. package/dist/src/repo/local-reader.js.map +1 -0
  213. package/dist/src/repo/openapi-parser.d.ts +35 -0
  214. package/dist/src/repo/openapi-parser.js +93 -0
  215. package/dist/src/repo/openapi-parser.js.map +1 -0
  216. package/dist/src/repo/parsers.d.ts +91 -0
  217. package/dist/src/repo/parsers.js +454 -0
  218. package/dist/src/repo/parsers.js.map +1 -0
  219. package/dist/src/repo/platform-reader.d.ts +10 -0
  220. package/dist/src/repo/platform-reader.js +206 -0
  221. package/dist/src/repo/platform-reader.js.map +1 -0
  222. package/dist/src/repo/repo-loader.d.ts +14 -0
  223. package/dist/src/repo/repo-loader.js +25 -0
  224. package/dist/src/repo/repo-loader.js.map +1 -0
  225. package/dist/src/repo/repo-types.d.ts +159 -0
  226. package/dist/src/repo/repo-types.js +17 -0
  227. package/dist/src/repo/repo-types.js.map +1 -0
  228. package/dist/src/repo/spec-syncer.d.ts +30 -0
  229. package/dist/src/repo/spec-syncer.js +85 -0
  230. package/dist/src/repo/spec-syncer.js.map +1 -0
  231. package/dist/src/repo/store-loader.d.ts +19 -0
  232. package/dist/src/repo/store-loader.js +94 -0
  233. package/dist/src/repo/store-loader.js.map +1 -0
  234. package/dist/src/repo/store-schemas.d.ts +313 -0
  235. package/dist/src/repo/store-schemas.js +103 -0
  236. package/dist/src/repo/store-schemas.js.map +1 -0
  237. package/dist/src/repo/store-tool-schema.d.ts +29 -0
  238. package/dist/src/repo/store-tool-schema.js +103 -0
  239. package/dist/src/repo/store-tool-schema.js.map +1 -0
  240. package/dist/src/repo/store-types.d.ts +91 -0
  241. package/dist/src/repo/store-types.js +7 -0
  242. package/dist/src/repo/store-types.js.map +1 -0
  243. package/dist/src/repo/surface-parser.d.ts +17 -0
  244. package/dist/src/repo/surface-parser.js +75 -0
  245. package/dist/src/repo/surface-parser.js.map +1 -0
  246. package/dist/src/repo/tool-loader.d.ts +33 -0
  247. package/dist/src/repo/tool-loader.js +240 -0
  248. package/dist/src/repo/tool-loader.js.map +1 -0
  249. package/dist/src/repo/tool-types.d.ts +205 -0
  250. package/dist/src/repo/tool-types.js +61 -0
  251. package/dist/src/repo/tool-types.js.map +1 -0
  252. package/dist/src/roles/index.d.ts +7 -0
  253. package/dist/src/roles/index.js +8 -0
  254. package/dist/src/roles/index.js.map +1 -0
  255. package/dist/src/roles/role-filter.d.ts +33 -0
  256. package/dist/src/roles/role-filter.js +55 -0
  257. package/dist/src/roles/role-filter.js.map +1 -0
  258. package/dist/src/roles/role-types.d.ts +76 -0
  259. package/dist/src/roles/role-types.js +38 -0
  260. package/dist/src/roles/role-types.js.map +1 -0
  261. package/dist/src/runtime/connection-bridge.d.ts +19 -0
  262. package/dist/src/runtime/connection-bridge.js +103 -0
  263. package/dist/src/runtime/connection-bridge.js.map +1 -0
  264. package/dist/src/runtime/context-compiler.d.ts +35 -0
  265. package/dist/src/runtime/context-compiler.js +183 -0
  266. package/dist/src/runtime/context-compiler.js.map +1 -0
  267. package/dist/src/runtime/default-prompt.d.ts +28 -0
  268. package/dist/src/runtime/default-prompt.js +71 -0
  269. package/dist/src/runtime/default-prompt.js.map +1 -0
  270. package/dist/src/runtime/explore-tool.d.ts +96 -0
  271. package/dist/src/runtime/explore-tool.js +111 -0
  272. package/dist/src/runtime/explore-tool.js.map +1 -0
  273. package/dist/src/runtime/index.d.ts +26 -0
  274. package/dist/src/runtime/index.js +19 -0
  275. package/dist/src/runtime/index.js.map +1 -0
  276. package/dist/src/runtime/output-pipeline.d.ts +62 -0
  277. package/dist/src/runtime/output-pipeline.js +69 -0
  278. package/dist/src/runtime/output-pipeline.js.map +1 -0
  279. package/dist/src/runtime/plan-mode.d.ts +39 -0
  280. package/dist/src/runtime/plan-mode.js +81 -0
  281. package/dist/src/runtime/plan-mode.js.map +1 -0
  282. package/dist/src/runtime/preference-client.d.ts +39 -0
  283. package/dist/src/runtime/preference-client.js +70 -0
  284. package/dist/src/runtime/preference-client.js.map +1 -0
  285. package/dist/src/runtime/preference-detector.d.ts +22 -0
  286. package/dist/src/runtime/preference-detector.js +95 -0
  287. package/dist/src/runtime/preference-detector.js.map +1 -0
  288. package/dist/src/runtime/request-integration.d.ts +18 -0
  289. package/dist/src/runtime/request-integration.js +36 -0
  290. package/dist/src/runtime/request-integration.js.map +1 -0
  291. package/dist/src/runtime/runtime-types.d.ts +48 -0
  292. package/dist/src/runtime/runtime-types.js +7 -0
  293. package/dist/src/runtime/runtime-types.js.map +1 -0
  294. package/dist/src/runtime/session-setup.d.ts +53 -0
  295. package/dist/src/runtime/session-setup.js +90 -0
  296. package/dist/src/runtime/session-setup.js.map +1 -0
  297. package/dist/src/runtime/telemetry-client.d.ts +39 -0
  298. package/dist/src/runtime/telemetry-client.js +87 -0
  299. package/dist/src/runtime/telemetry-client.js.map +1 -0
  300. package/dist/src/runtime/telemetry-hooks.d.ts +47 -0
  301. package/dist/src/runtime/telemetry-hooks.js +115 -0
  302. package/dist/src/runtime/telemetry-hooks.js.map +1 -0
  303. package/dist/src/runtime/token-allocator.d.ts +34 -0
  304. package/dist/src/runtime/token-allocator.js +86 -0
  305. package/dist/src/runtime/token-allocator.js.map +1 -0
  306. package/dist/src/runtime/user-context.d.ts +49 -0
  307. package/dist/src/runtime/user-context.js +135 -0
  308. package/dist/src/runtime/user-context.js.map +1 -0
  309. package/dist/src/sdk.d.ts +57 -0
  310. package/dist/src/sdk.js +377 -0
  311. package/dist/src/sdk.js.map +1 -0
  312. package/dist/src/security/action-gate.d.ts +23 -0
  313. package/dist/src/security/action-gate.js +78 -0
  314. package/dist/src/security/action-gate.js.map +1 -0
  315. package/dist/src/security/field-scrubber.d.ts +27 -0
  316. package/dist/src/security/field-scrubber.js +152 -0
  317. package/dist/src/security/field-scrubber.js.map +1 -0
  318. package/dist/src/security/index.d.ts +14 -0
  319. package/dist/src/security/index.js +15 -0
  320. package/dist/src/security/index.js.map +1 -0
  321. package/dist/src/security/leak-detector.d.ts +23 -0
  322. package/dist/src/security/leak-detector.js +51 -0
  323. package/dist/src/security/leak-detector.js.map +1 -0
  324. package/dist/src/security/output-guard.d.ts +33 -0
  325. package/dist/src/security/output-guard.js +118 -0
  326. package/dist/src/security/output-guard.js.map +1 -0
  327. package/dist/src/security/pattern-scanner.d.ts +19 -0
  328. package/dist/src/security/pattern-scanner.js +66 -0
  329. package/dist/src/security/pattern-scanner.js.map +1 -0
  330. package/dist/src/security/scope-checker.d.ts +27 -0
  331. package/dist/src/security/scope-checker.js +52 -0
  332. package/dist/src/security/scope-checker.js.map +1 -0
  333. package/dist/src/security/scrub-tracker.d.ts +21 -0
  334. package/dist/src/security/scrub-tracker.js +39 -0
  335. package/dist/src/security/scrub-tracker.js.map +1 -0
  336. package/dist/src/security/security-types.d.ts +69 -0
  337. package/dist/src/security/security-types.js +17 -0
  338. package/dist/src/security/security-types.js.map +1 -0
  339. package/dist/src/security/threshold-evaluator.d.ts +13 -0
  340. package/dist/src/security/threshold-evaluator.js +44 -0
  341. package/dist/src/security/threshold-evaluator.js.map +1 -0
  342. package/dist/src/snapshot/index.d.ts +8 -0
  343. package/dist/src/snapshot/index.js +9 -0
  344. package/dist/src/snapshot/index.js.map +1 -0
  345. package/dist/src/snapshot/snapshot-builder.d.ts +37 -0
  346. package/dist/src/snapshot/snapshot-builder.js +152 -0
  347. package/dist/src/snapshot/snapshot-builder.js.map +1 -0
  348. package/dist/src/snapshot/snapshot-loader.d.ts +29 -0
  349. package/dist/src/snapshot/snapshot-loader.js +188 -0
  350. package/dist/src/snapshot/snapshot-loader.js.map +1 -0
  351. package/dist/src/snapshot/snapshot-types.d.ts +1940 -0
  352. package/dist/src/snapshot/snapshot-types.js +145 -0
  353. package/dist/src/snapshot/snapshot-types.js.map +1 -0
  354. package/dist/src/stores/index.d.ts +6 -0
  355. package/dist/src/stores/index.js +7 -0
  356. package/dist/src/stores/index.js.map +1 -0
  357. package/dist/src/stores/store-backend.d.ts +135 -0
  358. package/dist/src/stores/store-backend.js +7 -0
  359. package/dist/src/stores/store-backend.js.map +1 -0
  360. package/dist/src/templates/connections.d.ts +14 -0
  361. package/dist/src/templates/connections.js +7 -0
  362. package/dist/src/templates/connections.js.map +1 -0
  363. package/dist/src/templates/index.d.ts +7 -0
  364. package/dist/src/templates/index.js +8 -0
  365. package/dist/src/templates/index.js.map +1 -0
  366. package/dist/src/templates/template-resolver.d.ts +45 -0
  367. package/dist/src/templates/template-resolver.js +121 -0
  368. package/dist/src/templates/template-resolver.js.map +1 -0
  369. package/dist/src/tool-context.d.ts +33 -0
  370. package/dist/src/tool-context.js +7 -0
  371. package/dist/src/tool-context.js.map +1 -0
  372. package/dist/src/tool-registration.d.ts +14 -0
  373. package/dist/src/tool-registration.js +51 -0
  374. package/dist/src/tool-registration.js.map +1 -0
  375. package/dist/src/tools/amodal-tool-errors.d.ts +24 -0
  376. package/dist/src/tools/amodal-tool-errors.js +28 -0
  377. package/dist/src/tools/amodal-tool-errors.js.map +1 -0
  378. package/dist/src/tools/amodal-tool-names.d.ts +14 -0
  379. package/dist/src/tools/amodal-tool-names.js +15 -0
  380. package/dist/src/tools/amodal-tool-names.js.map +1 -0
  381. package/dist/src/tools/chain-tool-registry.d.ts +20 -0
  382. package/dist/src/tools/chain-tool-registry.js +49 -0
  383. package/dist/src/tools/chain-tool-registry.js.map +1 -0
  384. package/dist/src/tools/chain-tool-types.d.ts +190 -0
  385. package/dist/src/tools/chain-tool-types.js +50 -0
  386. package/dist/src/tools/chain-tool-types.js.map +1 -0
  387. package/dist/src/tools/chain-tool.d.ts +34 -0
  388. package/dist/src/tools/chain-tool.js +294 -0
  389. package/dist/src/tools/chain-tool.js.map +1 -0
  390. package/dist/src/tools/custom-tool-registrar.d.ts +8 -0
  391. package/dist/src/tools/custom-tool-registrar.js +10 -0
  392. package/dist/src/tools/custom-tool-registrar.js.map +1 -0
  393. package/dist/src/tools/definitions/amodal-tools.d.ts +9 -0
  394. package/dist/src/tools/definitions/amodal-tools.js +192 -0
  395. package/dist/src/tools/definitions/amodal-tools.js.map +1 -0
  396. package/dist/src/tools/function-tool-registry.d.ts +22 -0
  397. package/dist/src/tools/function-tool-registry.js +45 -0
  398. package/dist/src/tools/function-tool-registry.js.map +1 -0
  399. package/dist/src/tools/function-tool-types.d.ts +76 -0
  400. package/dist/src/tools/function-tool-types.js +27 -0
  401. package/dist/src/tools/function-tool-types.js.map +1 -0
  402. package/dist/src/tools/function-tool.d.ts +34 -0
  403. package/dist/src/tools/function-tool.js +97 -0
  404. package/dist/src/tools/function-tool.js.map +1 -0
  405. package/dist/src/tools/http-tool-registry.d.ts +20 -0
  406. package/dist/src/tools/http-tool-registry.js +34 -0
  407. package/dist/src/tools/http-tool-registry.js.map +1 -0
  408. package/dist/src/tools/http-tool-types.d.ts +92 -0
  409. package/dist/src/tools/http-tool-types.js +44 -0
  410. package/dist/src/tools/http-tool-types.js.map +1 -0
  411. package/dist/src/tools/http-tool.d.ts +32 -0
  412. package/dist/src/tools/http-tool.js +176 -0
  413. package/dist/src/tools/http-tool.js.map +1 -0
  414. package/dist/src/tools/merge-template.d.ts +33 -0
  415. package/dist/src/tools/merge-template.js +65 -0
  416. package/dist/src/tools/merge-template.js.map +1 -0
  417. package/dist/src/tools/request-tool-types.d.ts +46 -0
  418. package/dist/src/tools/request-tool-types.js +20 -0
  419. package/dist/src/tools/request-tool-types.js.map +1 -0
  420. package/dist/src/tools/request-tool.d.ts +29 -0
  421. package/dist/src/tools/request-tool.js +268 -0
  422. package/dist/src/tools/request-tool.js.map +1 -0
  423. package/dist/src/tools/store-query-tool.d.ts +29 -0
  424. package/dist/src/tools/store-query-tool.js +82 -0
  425. package/dist/src/tools/store-query-tool.js.map +1 -0
  426. package/dist/src/tools/store-write-tool.d.ts +26 -0
  427. package/dist/src/tools/store-write-tool.js +84 -0
  428. package/dist/src/tools/store-write-tool.js.map +1 -0
  429. package/dist/src/tools/tool-definition-types.d.ts +21 -0
  430. package/dist/src/tools/tool-definition-types.js +7 -0
  431. package/dist/src/tools/tool-definition-types.js.map +1 -0
  432. package/dist/src/tools/tool-utils.d.ts +29 -0
  433. package/dist/src/tools/tool-utils.js +66 -0
  434. package/dist/src/tools/tool-utils.js.map +1 -0
  435. package/dist/src/versions/bundle-loader.d.ts +37 -0
  436. package/dist/src/versions/bundle-loader.js +99 -0
  437. package/dist/src/versions/bundle-loader.js.map +1 -0
  438. package/dist/src/versions/dependency-manager.d.ts +54 -0
  439. package/dist/src/versions/dependency-manager.js +132 -0
  440. package/dist/src/versions/dependency-manager.js.map +1 -0
  441. package/dist/src/versions/handler-loader.d.ts +27 -0
  442. package/dist/src/versions/handler-loader.js +62 -0
  443. package/dist/src/versions/handler-loader.js.map +1 -0
  444. package/dist/src/versions/index.d.ts +10 -0
  445. package/dist/src/versions/index.js +11 -0
  446. package/dist/src/versions/index.js.map +1 -0
  447. package/dist/src/versions/version-bundle-types.d.ts +1278 -0
  448. package/dist/src/versions/version-bundle-types.js +207 -0
  449. package/dist/src/versions/version-bundle-types.js.map +1 -0
  450. package/dist/src/versions/version-manager.d.ts +89 -0
  451. package/dist/src/versions/version-manager.js +124 -0
  452. package/dist/src/versions/version-manager.js.map +1 -0
  453. package/dist/src/widgets/index.d.ts +8 -0
  454. package/dist/src/widgets/index.js +8 -0
  455. package/dist/src/widgets/index.js.map +1 -0
  456. package/dist/src/widgets/present-tool.d.ts +21 -0
  457. package/dist/src/widgets/present-tool.js +107 -0
  458. package/dist/src/widgets/present-tool.js.map +1 -0
  459. package/dist/src/widgets/widget-types.d.ts +78 -0
  460. package/dist/src/widgets/widget-types.js +28 -0
  461. package/dist/src/widgets/widget-types.js.map +1 -0
  462. package/dist/tsconfig.tsbuildinfo +1 -0
  463. package/package.json +50 -0
@@ -0,0 +1,78 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import { ThresholdEvaluator } from './threshold-evaluator.js';
7
+ /**
8
+ * Controls write operations based on confirmation tiers from access config.
9
+ */
10
+ export class ActionGate {
11
+ accessConfigs;
12
+ isDelegated;
13
+ thresholdEvaluator;
14
+ constructor(config) {
15
+ this.accessConfigs = config.accessConfigs;
16
+ this.isDelegated = config.isDelegated;
17
+ this.thresholdEvaluator = new ThresholdEvaluator();
18
+ }
19
+ evaluate(endpointPath, connectionName, params) {
20
+ const accessConfig = this.accessConfigs.get(connectionName);
21
+ if (!accessConfig) {
22
+ return {
23
+ decision: 'allow',
24
+ endpointPath,
25
+ escalated: false,
26
+ };
27
+ }
28
+ const endpoint = accessConfig['endpoints'][endpointPath];
29
+ if (!endpoint) {
30
+ return {
31
+ decision: 'allow',
32
+ endpointPath,
33
+ escalated: false,
34
+ };
35
+ }
36
+ // Base tier from confirm field
37
+ let decision = this.resolveBaseTier(endpoint.confirm);
38
+ let reason = endpoint.reason;
39
+ let escalated = false;
40
+ // Threshold evaluation
41
+ if (endpoint.thresholds &&
42
+ endpoint.thresholds.length > 0 &&
43
+ params) {
44
+ const thresholdResult = this.thresholdEvaluator.evaluate(endpoint.thresholds, params);
45
+ if (thresholdResult !== null) {
46
+ const escalatedDecision = this.escalateDecision(decision, thresholdResult);
47
+ if (escalatedDecision !== decision) {
48
+ decision = escalatedDecision;
49
+ escalated = true;
50
+ reason = `Threshold escalation: ${reason ?? 'parameter exceeded limit'}`;
51
+ }
52
+ }
53
+ }
54
+ // Delegation escalation
55
+ if (this.isDelegated && accessConfig.delegations?.escalateConfirm) {
56
+ if (decision === 'confirm') {
57
+ decision = 'review';
58
+ escalated = true;
59
+ reason = `Delegated agent escalation: ${reason ?? 'confirm → review'}`;
60
+ }
61
+ }
62
+ return { decision, reason, escalated, endpointPath };
63
+ }
64
+ resolveBaseTier(confirm) {
65
+ if (confirm === undefined)
66
+ return 'allow';
67
+ if (confirm === true)
68
+ return 'confirm';
69
+ return confirm;
70
+ }
71
+ escalateDecision(current, escalation) {
72
+ const hierarchy = ['allow', 'confirm', 'review', 'never'];
73
+ const currentIdx = hierarchy.indexOf(current);
74
+ const escalationIdx = hierarchy.indexOf(escalation);
75
+ return escalationIdx > currentIdx ? escalation : current;
76
+ }
77
+ }
78
+ //# sourceMappingURL=action-gate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action-gate.js","sourceRoot":"","sources":["../../../src/security/action-gate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import type { AccessConfig } from '../repo/connection-schemas.js';
7
+ import type { ScrubResult } from './security-types.js';
8
+ import type { ScrubTracker } from './scrub-tracker.js';
9
+ export interface FieldScrubberConfig {
10
+ accessConfigs: Map<string, AccessConfig>;
11
+ userRoles: string[];
12
+ tracker: ScrubTracker;
13
+ }
14
+ /**
15
+ * Intercepts API responses and strips restricted fields before
16
+ * the data reaches the LLM context.
17
+ */
18
+ export declare class FieldScrubber {
19
+ private readonly accessConfigs;
20
+ private readonly userRoles;
21
+ private readonly tracker;
22
+ constructor(config: FieldScrubberConfig);
23
+ scrub(data: unknown, endpointPath: string, connectionName: string): ScrubResult;
24
+ private findRestriction;
25
+ private hasRole;
26
+ private walkAndScrub;
27
+ }
@@ -0,0 +1,152 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * Intercepts API responses and strips restricted fields before
8
+ * the data reaches the LLM context.
9
+ */
10
+ export class FieldScrubber {
11
+ accessConfigs;
12
+ userRoles;
13
+ tracker;
14
+ constructor(config) {
15
+ this.accessConfigs = config.accessConfigs;
16
+ this.userRoles = config.userRoles;
17
+ this.tracker = config.tracker;
18
+ }
19
+ scrub(data, endpointPath, connectionName) {
20
+ const accessConfig = this.accessConfigs.get(connectionName);
21
+ if (!accessConfig) {
22
+ return { data, records: [], strippedCount: 0, redactableCount: 0 };
23
+ }
24
+ const endpoint = accessConfig['endpoints'][endpointPath];
25
+ if (!endpoint) {
26
+ return { data, records: [], strippedCount: 0, redactableCount: 0 };
27
+ }
28
+ const entityTypes = new Set(endpoint.returns);
29
+ const restrictions = (accessConfig.fieldRestrictions ?? []).filter((r) => entityTypes.has(r.entity));
30
+ if (restrictions.length === 0) {
31
+ return { data, records: [], strippedCount: 0, redactableCount: 0 };
32
+ }
33
+ const restrictionsByEntity = new Map();
34
+ for (const r of restrictions) {
35
+ const existing = restrictionsByEntity.get(r.entity) ?? [];
36
+ existing.push(r);
37
+ restrictionsByEntity.set(r.entity, existing);
38
+ }
39
+ const records = [];
40
+ let strippedCount = 0;
41
+ let redactableCount = 0;
42
+ const scrubbed = this.walkAndScrub(data, restrictionsByEntity, connectionName, records);
43
+ for (const record of records) {
44
+ if (record.policy === 'never_retrieve') {
45
+ strippedCount++;
46
+ }
47
+ else if (record.policy === 'retrieve_but_redact') {
48
+ redactableCount++;
49
+ }
50
+ else if (record.policy === 'role_gated') {
51
+ if (!this.hasRole(this.findRestriction(restrictions, record))) {
52
+ strippedCount++;
53
+ }
54
+ else {
55
+ redactableCount++;
56
+ }
57
+ }
58
+ }
59
+ this.tracker.addRecords(records);
60
+ return { data: scrubbed, records, strippedCount, redactableCount };
61
+ }
62
+ findRestriction(restrictions, record) {
63
+ return restrictions.find((r) => r.entity === record.entity && r.field === record.field);
64
+ }
65
+ hasRole(restriction) {
66
+ if (!restriction)
67
+ return false;
68
+ const allowed = restriction.allowedRoles;
69
+ if (!allowed || allowed.length === 0)
70
+ return false;
71
+ return this.userRoles.some((role) => allowed.includes(role));
72
+ }
73
+ walkAndScrub(data, restrictionsByEntity, connectionName, records, entityHint) {
74
+ if (data === null || data === undefined)
75
+ return data;
76
+ if (Array.isArray(data)) {
77
+ return data.map((item) => this.walkAndScrub(item, restrictionsByEntity, connectionName, records, entityHint));
78
+ }
79
+ if (typeof data === 'object') {
80
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-type-assertion -- SDK boundary: data is verified object
81
+ const obj = data;
82
+ const result = {};
83
+ for (const key of Object.keys(obj)) {
84
+ const value = obj[key];
85
+ // Determine entity hint from key name
86
+ const singularKey = depluralize(key);
87
+ const childEntityHint = restrictionsByEntity.has(singularKey)
88
+ ? singularKey
89
+ : restrictionsByEntity.has(key)
90
+ ? key
91
+ : entityHint;
92
+ // Check if this field is restricted for the current entity
93
+ if (entityHint) {
94
+ const entityRestrictions = restrictionsByEntity.get(entityHint);
95
+ if (entityRestrictions) {
96
+ const restriction = entityRestrictions.find((r) => r.field === key);
97
+ if (restriction) {
98
+ const strValue = String(value ?? '');
99
+ const record = {
100
+ value: strValue,
101
+ entity: restriction.entity,
102
+ field: restriction.field,
103
+ sensitivity: restriction.sensitivity,
104
+ policy: restriction.policy,
105
+ connectionName,
106
+ timestamp: Date.now(),
107
+ };
108
+ if (restriction.policy === 'never_retrieve') {
109
+ records.push(record);
110
+ continue; // strip field entirely
111
+ }
112
+ else if (restriction.policy === 'retrieve_but_redact') {
113
+ records.push(record);
114
+ result[key] = value; // keep for now, output guard redacts
115
+ }
116
+ else if (restriction.policy === 'role_gated') {
117
+ if (this.hasRole(restriction)) {
118
+ records.push(record);
119
+ result[key] = value; // keep, redactable
120
+ }
121
+ else {
122
+ records.push(record);
123
+ continue; // strip — no role access
124
+ }
125
+ }
126
+ continue;
127
+ }
128
+ }
129
+ }
130
+ // Recurse into nested objects/arrays
131
+ if (typeof value === 'object' && value !== null) {
132
+ result[key] = this.walkAndScrub(value, restrictionsByEntity, connectionName, records, Array.isArray(value) ? singularKey : childEntityHint);
133
+ }
134
+ else {
135
+ result[key] = value;
136
+ }
137
+ }
138
+ return result;
139
+ }
140
+ return data;
141
+ }
142
+ }
143
+ /**
144
+ * Naive depluralize: strip trailing 's'.
145
+ */
146
+ function depluralize(key) {
147
+ if (key.endsWith('s') && key.length > 1) {
148
+ return key.slice(0, -1);
149
+ }
150
+ return key;
151
+ }
152
+ //# sourceMappingURL=field-scrubber.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"field-scrubber.js","sourceRoot":"","sources":["../../../src/security/field-scrubber.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ export * from './security-types.js';
7
+ export * from './scrub-tracker.js';
8
+ export * from './field-scrubber.js';
9
+ export * from './pattern-scanner.js';
10
+ export * from './leak-detector.js';
11
+ export * from './scope-checker.js';
12
+ export * from './output-guard.js';
13
+ export * from './threshold-evaluator.js';
14
+ export * from './action-gate.js';
@@ -0,0 +1,15 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ export * from './security-types.js';
7
+ export * from './scrub-tracker.js';
8
+ export * from './field-scrubber.js';
9
+ export * from './pattern-scanner.js';
10
+ export * from './leak-detector.js';
11
+ export * from './scope-checker.js';
12
+ export * from './output-guard.js';
13
+ export * from './threshold-evaluator.js';
14
+ export * from './action-gate.js';
15
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import type { ScrubRecord } from './security-types.js';
7
+ import type { ScrubTracker } from './scrub-tracker.js';
8
+ /**
9
+ * A detected leak of a previously scrubbed value.
10
+ */
11
+ export interface LeakMatch {
12
+ record: ScrubRecord;
13
+ matchedText: string;
14
+ contextual: boolean;
15
+ }
16
+ /**
17
+ * Compares agent output against tracked scrubbed values to detect leaks.
18
+ */
19
+ export declare class LeakDetector {
20
+ private readonly tracker;
21
+ constructor(tracker: ScrubTracker);
22
+ detect(text: string): LeakMatch[];
23
+ }
@@ -0,0 +1,51 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * Compares agent output against tracked scrubbed values to detect leaks.
8
+ */
9
+ export class LeakDetector {
10
+ tracker;
11
+ constructor(tracker) {
12
+ this.tracker = tracker;
13
+ }
14
+ detect(text) {
15
+ const matches = [];
16
+ const records = this.tracker.getAllRecords();
17
+ for (const record of records) {
18
+ if (record.value.length < 2)
19
+ continue;
20
+ const index = text.indexOf(record.value);
21
+ if (index === -1)
22
+ continue;
23
+ if (record.sensitivity === 'pii_name') {
24
+ // Only flag pii_name if near entity name/ID context
25
+ const contextStart = Math.max(0, index - 200);
26
+ const contextEnd = Math.min(text.length, index + record.value.length + 200);
27
+ const context = text.slice(contextStart, contextEnd);
28
+ const hasEntityContext = context.toLowerCase().includes(record.entity.toLowerCase()) ||
29
+ (record.entityId !== undefined &&
30
+ context.includes(record.entityId));
31
+ if (hasEntityContext) {
32
+ matches.push({
33
+ record,
34
+ matchedText: record.value,
35
+ contextual: true,
36
+ });
37
+ }
38
+ }
39
+ else {
40
+ // pii_identifier, financial, etc.: always flag
41
+ matches.push({
42
+ record,
43
+ matchedText: record.value,
44
+ contextual: false,
45
+ });
46
+ }
47
+ }
48
+ return matches;
49
+ }
50
+ }
51
+ //# sourceMappingURL=leak-detector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"leak-detector.js","sourceRoot":"","sources":["../../../src/security/leak-detector.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAcH;;GAEG;AACH,MAAM,OAAO,YAAY;IACN,OAAO,CAAe;IAEvC,YAAY,OAAqB;QAC/B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,MAAM,CAAC,IAAY;QACjB,MAAM,OAAO,GAAgB,EAAE,CAAC;QAChC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QAE7C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;gBAAE,SAAS;YAEtC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,KAAK,KAAK,CAAC,CAAC;gBAAE,SAAS;YAE3B,IAAI,MAAM,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;gBACtC,oDAAoD;gBACpD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,GAAG,CAAC,CAAC;gBAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;gBAC5E,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;gBAErD,MAAM,gBAAgB,GACpB,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;oBAC3D,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS;wBAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAEvC,IAAI,gBAAgB,EAAE,CAAC;oBACrB,OAAO,CAAC,IAAI,CAAC;wBACX,MAAM;wBACN,WAAW,EAAE,MAAM,CAAC,KAAK;wBACzB,UAAU,EAAE,IAAI;qBACjB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,+CAA+C;gBAC/C,OAAO,CAAC,IAAI,CAAC;oBACX,MAAM;oBACN,WAAW,EAAE,MAAM,CAAC,KAAK;oBACzB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;CACF"}
@@ -0,0 +1,33 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import type { AccessConfig } from '../repo/connection-schemas.js';
7
+ import type { ScrubTracker } from './scrub-tracker.js';
8
+ import type { GuardResult } from './security-types.js';
9
+ import type { ScopeCheckerContext } from './scope-checker.js';
10
+ export interface OutputGuardConfig {
11
+ tracker: ScrubTracker;
12
+ accessConfigs: Map<string, AccessConfig>;
13
+ userRoles: string[];
14
+ scopeContext?: ScopeCheckerContext;
15
+ }
16
+ /**
17
+ * Orchestrates four output guard stages to filter agent responses
18
+ * before the user sees them.
19
+ */
20
+ export declare class OutputGuard {
21
+ private readonly tracker;
22
+ private readonly userRoles;
23
+ private readonly patternScanner;
24
+ private readonly leakDetector;
25
+ private readonly scopeChecker;
26
+ constructor(config: OutputGuardConfig);
27
+ guard(output: string): GuardResult;
28
+ /**
29
+ * Look up the original restriction for a scrub record.
30
+ * Returns a minimal object with allowedRoles for the role check.
31
+ */
32
+ private findRestrictionForRecord;
33
+ }
@@ -0,0 +1,118 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import { PatternScanner } from './pattern-scanner.js';
7
+ import { LeakDetector } from './leak-detector.js';
8
+ import { ScopeChecker } from './scope-checker.js';
9
+ /**
10
+ * Orchestrates four output guard stages to filter agent responses
11
+ * before the user sees them.
12
+ */
13
+ export class OutputGuard {
14
+ tracker;
15
+ userRoles;
16
+ patternScanner;
17
+ leakDetector;
18
+ scopeChecker;
19
+ constructor(config) {
20
+ this.tracker = config.tracker;
21
+ this.userRoles = config.userRoles;
22
+ this.patternScanner = new PatternScanner();
23
+ this.leakDetector = new LeakDetector(config.tracker);
24
+ this.scopeChecker = config.scopeContext
25
+ ? new ScopeChecker(config.scopeContext)
26
+ : null;
27
+ }
28
+ guard(output) {
29
+ const findings = [];
30
+ let text = output;
31
+ let modified = false;
32
+ // Stage 1: Field redaction — replace retrieve_but_redact and denied role_gated values
33
+ const redactableRecords = this.tracker.getAllRecords().filter((r) => {
34
+ if (r.policy === 'retrieve_but_redact')
35
+ return true;
36
+ if (r.policy === 'role_gated') {
37
+ // Check if user lacks role
38
+ const restriction = this.findRestrictionForRecord(r);
39
+ if (!restriction)
40
+ return true; // conservative
41
+ const allowed = restriction.allowedRoles;
42
+ if (!allowed || allowed.length === 0)
43
+ return true;
44
+ return !this.userRoles.some((role) => allowed.includes(role));
45
+ }
46
+ return false;
47
+ });
48
+ for (const record of redactableRecords) {
49
+ if (record.value.length < 2)
50
+ continue;
51
+ if (text.includes(record.value)) {
52
+ text = text.split(record.value).join('[REDACTED]');
53
+ modified = true;
54
+ findings.push({
55
+ type: 'field_redaction',
56
+ description: `Redacted ${record.sensitivity} field "${record.field}" from ${record.entity}`,
57
+ severity: 'info',
58
+ });
59
+ }
60
+ }
61
+ // Stage 2: Pattern scan — regex for SSN/CC/bank patterns
62
+ const patterns = this.patternScanner.scan(text);
63
+ for (const p of patterns) {
64
+ text = text.split(p.match).join('[REDACTED]');
65
+ modified = true;
66
+ findings.push({
67
+ type: 'pattern_match',
68
+ description: `Detected ${p.pattern} pattern`,
69
+ location: `index ${p.index}`,
70
+ severity: 'critical',
71
+ });
72
+ }
73
+ // Stage 3: Leak detection — compare against tracker values
74
+ const leaks = this.leakDetector.detect(text);
75
+ for (const leak of leaks) {
76
+ const severity = leak.record.sensitivity === 'pii_identifier' ? 'critical' : 'warning';
77
+ if (severity === 'critical') {
78
+ text = text.split(leak.matchedText).join('[REDACTED]');
79
+ modified = true;
80
+ }
81
+ findings.push({
82
+ type: 'leak_detected',
83
+ description: `Leaked ${leak.record.sensitivity} value for ${leak.record.entity}.${leak.record.field}`,
84
+ severity,
85
+ });
86
+ }
87
+ // Stage 4: Scope check — flag unqualified aggregates
88
+ if (this.scopeChecker) {
89
+ const violations = this.scopeChecker.check(text);
90
+ for (const v of violations) {
91
+ findings.push({
92
+ type: 'scope_violation',
93
+ description: `Unqualified aggregate for "${v.entity}" — expected: ${v.expectedQualification}`,
94
+ location: v.snippet,
95
+ severity: 'warning',
96
+ });
97
+ }
98
+ }
99
+ const blocked = findings.some((f) => f.severity === 'critical');
100
+ return { output: text, modified, findings, blocked };
101
+ }
102
+ /**
103
+ * Look up the original restriction for a scrub record.
104
+ * Returns a minimal object with allowedRoles for the role check.
105
+ */
106
+ findRestrictionForRecord(record) {
107
+ const accessConfig = this.tracker
108
+ .getAllRecords()
109
+ .find((r) => r.entity === record.entity &&
110
+ r.field === record.field &&
111
+ r.connectionName === record.connectionName);
112
+ // We don't have direct access to the restriction, but we stored policy
113
+ // For role_gated, we need the original restriction's allowedRoles
114
+ // Since we only have the record, treat missing roles as denied (conservative)
115
+ return accessConfig ? { allowedRoles: [] } : undefined;
116
+ }
117
+ }
118
+ //# sourceMappingURL=output-guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-guard.js","sourceRoot":"","sources":["../../../src/security/output-guard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * A match found by the pattern scanner.
8
+ */
9
+ export interface PatternMatch {
10
+ pattern: string;
11
+ match: string;
12
+ index: number;
13
+ }
14
+ /**
15
+ * Regex-based PII pattern detection.
16
+ */
17
+ export declare class PatternScanner {
18
+ scan(text: string): PatternMatch[];
19
+ }
@@ -0,0 +1,66 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Amodal Labs, Inc.
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * Luhn check for credit card validation.
8
+ */
9
+ function passesLuhn(digits) {
10
+ let sum = 0;
11
+ let alternate = false;
12
+ for (let i = digits.length - 1; i >= 0; i--) {
13
+ let n = parseInt(digits[i], 10);
14
+ if (alternate) {
15
+ n *= 2;
16
+ if (n > 9) {
17
+ n -= 9;
18
+ }
19
+ }
20
+ sum += n;
21
+ alternate = !alternate;
22
+ }
23
+ return sum % 10 === 0;
24
+ }
25
+ const SSN_PATTERN = /\b\d{3}-\d{2}-\d{4}\b/g;
26
+ const CC_PATTERN = /\b(\d[\d\s-]{8,22}\d)\b/g;
27
+ const BANK_ACCOUNT_KEYWORD = /\b(?:account|routing|acct|aba)\b/i;
28
+ /**
29
+ * Regex-based PII pattern detection.
30
+ */
31
+ export class PatternScanner {
32
+ scan(text) {
33
+ const matches = [];
34
+ // SSN
35
+ let m;
36
+ const ssnRe = new RegExp(SSN_PATTERN.source, 'g');
37
+ while ((m = ssnRe.exec(text)) !== null) {
38
+ matches.push({ pattern: 'ssn', match: m[0], index: m.index });
39
+ }
40
+ // Credit card (13-19 digits with Luhn)
41
+ const ccRe = new RegExp(CC_PATTERN.source, 'g');
42
+ while ((m = ccRe.exec(text)) !== null) {
43
+ const raw = m[0];
44
+ const digits = raw.replace(/[\s-]/g, '');
45
+ if (digits.length >= 13 && digits.length <= 19 && passesLuhn(digits)) {
46
+ matches.push({ pattern: 'credit_card', match: raw, index: m.index });
47
+ }
48
+ }
49
+ // Bank account (8-17 digits near keywords)
50
+ const bankRe = /\b(\d{8,17})\b/g;
51
+ while ((m = bankRe.exec(text)) !== null) {
52
+ const start = Math.max(0, m.index - 100);
53
+ const end = Math.min(text.length, m.index + m[0].length + 100);
54
+ const context = text.slice(start, end);
55
+ if (BANK_ACCOUNT_KEYWORD.test(context)) {
56
+ matches.push({
57
+ pattern: 'bank_account',
58
+ match: m[0],
59
+ index: m.index,
60
+ });
61
+ }
62
+ }
63
+ return matches;
64
+ }
65
+ }
66
+ //# sourceMappingURL=pattern-scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pattern-scanner.js","sourceRoot":"","sources":["../../../src/security/pattern-scanner.ts"],"names":[],"mappings":"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"}