airlock-bot 0.0.1 → 0.2.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 (342) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +337 -0
  3. package/airlock.service +27 -0
  4. package/dist/allowlist/engine.d.ts +9 -0
  5. package/dist/allowlist/engine.d.ts.map +1 -0
  6. package/dist/allowlist/engine.js +24 -0
  7. package/dist/allowlist/engine.js.map +1 -0
  8. package/dist/allowlist/pattern.d.ts +13 -0
  9. package/dist/allowlist/pattern.d.ts.map +1 -0
  10. package/dist/allowlist/pattern.js +33 -0
  11. package/dist/allowlist/pattern.js.map +1 -0
  12. package/dist/audit/api.d.ts +7 -0
  13. package/dist/audit/api.d.ts.map +1 -0
  14. package/dist/audit/api.js +31 -0
  15. package/dist/audit/api.js.map +1 -0
  16. package/dist/audit/db.d.ts +44 -0
  17. package/dist/audit/db.d.ts.map +1 -0
  18. package/dist/audit/db.js +121 -0
  19. package/dist/audit/db.js.map +1 -0
  20. package/dist/audit/logger.d.ts +25 -0
  21. package/dist/audit/logger.d.ts.map +1 -0
  22. package/dist/audit/logger.js +58 -0
  23. package/dist/audit/logger.js.map +1 -0
  24. package/dist/audit/redactor.d.ts +5 -0
  25. package/dist/audit/redactor.d.ts.map +1 -0
  26. package/dist/audit/redactor.js +27 -0
  27. package/dist/audit/redactor.js.map +1 -0
  28. package/dist/backend/cli/adapter.d.ts +23 -0
  29. package/dist/backend/cli/adapter.d.ts.map +1 -0
  30. package/dist/backend/cli/adapter.js +176 -0
  31. package/dist/backend/cli/adapter.js.map +1 -0
  32. package/dist/backend/cli/builder.d.ts +3 -0
  33. package/dist/backend/cli/builder.d.ts.map +1 -0
  34. package/dist/backend/cli/builder.js +52 -0
  35. package/dist/backend/cli/builder.js.map +1 -0
  36. package/dist/backend/cli/escaper.d.ts +2 -0
  37. package/dist/backend/cli/escaper.d.ts.map +1 -0
  38. package/dist/backend/cli/escaper.js +8 -0
  39. package/dist/backend/cli/escaper.js.map +1 -0
  40. package/dist/backend/exec-adapter.d.ts +13 -0
  41. package/dist/backend/exec-adapter.d.ts.map +1 -0
  42. package/dist/backend/exec-adapter.js +39 -0
  43. package/dist/backend/exec-adapter.js.map +1 -0
  44. package/dist/backend/factory.d.ts +9 -0
  45. package/dist/backend/factory.d.ts.map +1 -0
  46. package/dist/backend/factory.js +35 -0
  47. package/dist/backend/factory.js.map +1 -0
  48. package/dist/backend/http-adapter.d.ts +15 -0
  49. package/dist/backend/http-adapter.d.ts.map +1 -0
  50. package/dist/backend/http-adapter.js +39 -0
  51. package/dist/backend/http-adapter.js.map +1 -0
  52. package/dist/backend/mcp-adapter.d.ts +14 -0
  53. package/dist/backend/mcp-adapter.d.ts.map +1 -0
  54. package/dist/backend/mcp-adapter.js +38 -0
  55. package/dist/backend/mcp-adapter.js.map +1 -0
  56. package/dist/backend/openapi/adapter.d.ts +17 -0
  57. package/dist/backend/openapi/adapter.d.ts.map +1 -0
  58. package/dist/backend/openapi/adapter.js +144 -0
  59. package/dist/backend/openapi/adapter.js.map +1 -0
  60. package/dist/backend/openapi/parser.d.ts +21 -0
  61. package/dist/backend/openapi/parser.d.ts.map +1 -0
  62. package/dist/backend/openapi/parser.js +145 -0
  63. package/dist/backend/openapi/parser.js.map +1 -0
  64. package/dist/backend/types.d.ts +9 -0
  65. package/dist/backend/types.d.ts.map +1 -0
  66. package/dist/backend/types.js +2 -0
  67. package/dist/backend/types.js.map +1 -0
  68. package/dist/config/loader.d.ts +12 -0
  69. package/dist/config/loader.d.ts.map +1 -0
  70. package/dist/config/loader.js +178 -0
  71. package/dist/config/loader.js.map +1 -0
  72. package/dist/config/profiles.d.ts +12 -0
  73. package/dist/config/profiles.d.ts.map +1 -0
  74. package/dist/config/profiles.js +34 -0
  75. package/dist/config/profiles.js.map +1 -0
  76. package/dist/config/schema.d.ts +2034 -0
  77. package/dist/config/schema.d.ts.map +1 -0
  78. package/dist/config/schema.js +257 -0
  79. package/dist/config/schema.js.map +1 -0
  80. package/dist/config/watcher.d.ts +11 -0
  81. package/dist/config/watcher.d.ts.map +1 -0
  82. package/dist/config/watcher.js +39 -0
  83. package/dist/config/watcher.js.map +1 -0
  84. package/dist/configure-agent/cli.d.ts +2 -0
  85. package/dist/configure-agent/cli.d.ts.map +1 -0
  86. package/dist/configure-agent/cli.js +390 -0
  87. package/dist/configure-agent/cli.js.map +1 -0
  88. package/dist/discover/cli.d.ts +2 -0
  89. package/dist/discover/cli.d.ts.map +1 -0
  90. package/dist/discover/cli.js +97 -0
  91. package/dist/discover/cli.js.map +1 -0
  92. package/dist/discover/index.d.ts +19 -0
  93. package/dist/discover/index.d.ts.map +1 -0
  94. package/dist/discover/index.js +70 -0
  95. package/dist/discover/index.js.map +1 -0
  96. package/dist/discover/openapi.d.ts +9 -0
  97. package/dist/discover/openapi.d.ts.map +1 -0
  98. package/dist/discover/openapi.js +47 -0
  99. package/dist/discover/openapi.js.map +1 -0
  100. package/dist/discover/strategies/fig.d.ts +29 -0
  101. package/dist/discover/strategies/fig.d.ts.map +1 -0
  102. package/dist/discover/strategies/fig.js +82 -0
  103. package/dist/discover/strategies/fig.js.map +1 -0
  104. package/dist/discover/strategies/help-parser.d.ts +21 -0
  105. package/dist/discover/strategies/help-parser.d.ts.map +1 -0
  106. package/dist/discover/strategies/help-parser.js +121 -0
  107. package/dist/discover/strategies/help-parser.js.map +1 -0
  108. package/dist/discover/writer.d.ts +5 -0
  109. package/dist/discover/writer.d.ts.map +1 -0
  110. package/dist/discover/writer.js +14 -0
  111. package/dist/discover/writer.js.map +1 -0
  112. package/dist/gateway.d.ts +20 -0
  113. package/dist/gateway.d.ts.map +1 -0
  114. package/dist/gateway.js +125 -0
  115. package/dist/gateway.js.map +1 -0
  116. package/dist/hitl/api.d.ts +7 -0
  117. package/dist/hitl/api.d.ts.map +1 -0
  118. package/dist/hitl/api.js +35 -0
  119. package/dist/hitl/api.js.map +1 -0
  120. package/dist/hitl/batcher.d.ts +11 -0
  121. package/dist/hitl/batcher.d.ts.map +1 -0
  122. package/dist/hitl/batcher.js +37 -0
  123. package/dist/hitl/batcher.js.map +1 -0
  124. package/dist/hitl/engine.d.ts +36 -0
  125. package/dist/hitl/engine.d.ts.map +1 -0
  126. package/dist/hitl/engine.js +150 -0
  127. package/dist/hitl/engine.js.map +1 -0
  128. package/dist/hitl/formatter.d.ts +4 -0
  129. package/dist/hitl/formatter.d.ts.map +1 -0
  130. package/dist/hitl/formatter.js +31 -0
  131. package/dist/hitl/formatter.js.map +1 -0
  132. package/dist/hitl/parser.d.ts +7 -0
  133. package/dist/hitl/parser.d.ts.map +1 -0
  134. package/dist/hitl/parser.js +17 -0
  135. package/dist/hitl/parser.js.map +1 -0
  136. package/dist/hitl/provider-factory.d.ts +4 -0
  137. package/dist/hitl/provider-factory.d.ts.map +1 -0
  138. package/dist/hitl/provider-factory.js +42 -0
  139. package/dist/hitl/provider-factory.js.map +1 -0
  140. package/dist/hitl/providers/composite.d.ts +9 -0
  141. package/dist/hitl/providers/composite.d.ts.map +1 -0
  142. package/dist/hitl/providers/composite.js +23 -0
  143. package/dist/hitl/providers/composite.js.map +1 -0
  144. package/dist/hitl/providers/dashboard.d.ts +17 -0
  145. package/dist/hitl/providers/dashboard.d.ts.map +1 -0
  146. package/dist/hitl/providers/dashboard.js +210 -0
  147. package/dist/hitl/providers/dashboard.js.map +1 -0
  148. package/dist/hitl/providers/macos.d.ts +10 -0
  149. package/dist/hitl/providers/macos.d.ts.map +1 -0
  150. package/dist/hitl/providers/macos.js +65 -0
  151. package/dist/hitl/providers/macos.js.map +1 -0
  152. package/dist/hitl/providers/openclaw.d.ts +21 -0
  153. package/dist/hitl/providers/openclaw.d.ts.map +1 -0
  154. package/dist/hitl/providers/openclaw.js +106 -0
  155. package/dist/hitl/providers/openclaw.js.map +1 -0
  156. package/dist/hitl/providers/slack.d.ts +12 -0
  157. package/dist/hitl/providers/slack.d.ts.map +1 -0
  158. package/dist/hitl/providers/slack.js +24 -0
  159. package/dist/hitl/providers/slack.js.map +1 -0
  160. package/dist/hitl/providers/stdio.d.ts +12 -0
  161. package/dist/hitl/providers/stdio.d.ts.map +1 -0
  162. package/dist/hitl/providers/stdio.js +41 -0
  163. package/dist/hitl/providers/stdio.js.map +1 -0
  164. package/dist/hitl/providers/telegram.d.ts +22 -0
  165. package/dist/hitl/providers/telegram.d.ts.map +1 -0
  166. package/dist/hitl/providers/telegram.js +87 -0
  167. package/dist/hitl/providers/telegram.js.map +1 -0
  168. package/dist/hitl/providers/tui.d.ts +16 -0
  169. package/dist/hitl/providers/tui.d.ts.map +1 -0
  170. package/dist/hitl/providers/tui.js +169 -0
  171. package/dist/hitl/providers/tui.js.map +1 -0
  172. package/dist/hitl/providers/types.d.ts +18 -0
  173. package/dist/hitl/providers/types.d.ts.map +1 -0
  174. package/dist/hitl/providers/types.js +2 -0
  175. package/dist/hitl/providers/types.js.map +1 -0
  176. package/dist/hitl/providers/webhook.d.ts +13 -0
  177. package/dist/hitl/providers/webhook.d.ts.map +1 -0
  178. package/dist/hitl/providers/webhook.js +27 -0
  179. package/dist/hitl/providers/webhook.js.map +1 -0
  180. package/dist/index.d.ts +3 -0
  181. package/dist/index.d.ts.map +1 -0
  182. package/dist/index.js +115 -0
  183. package/dist/index.js.map +1 -0
  184. package/dist/middleware/chain-builder.d.ts +16 -0
  185. package/dist/middleware/chain-builder.d.ts.map +1 -0
  186. package/dist/middleware/chain-builder.js +139 -0
  187. package/dist/middleware/chain-builder.js.map +1 -0
  188. package/dist/middleware/compose.d.ts +3 -0
  189. package/dist/middleware/compose.d.ts.map +1 -0
  190. package/dist/middleware/compose.js +15 -0
  191. package/dist/middleware/compose.js.map +1 -0
  192. package/dist/middleware/core/allowlist.d.ts +3 -0
  193. package/dist/middleware/core/allowlist.d.ts.map +1 -0
  194. package/dist/middleware/core/allowlist.js +23 -0
  195. package/dist/middleware/core/allowlist.js.map +1 -0
  196. package/dist/middleware/core/exec-policy.d.ts +3 -0
  197. package/dist/middleware/core/exec-policy.d.ts.map +1 -0
  198. package/dist/middleware/core/exec-policy.js +30 -0
  199. package/dist/middleware/core/exec-policy.js.map +1 -0
  200. package/dist/middleware/core/execute.d.ts +3 -0
  201. package/dist/middleware/core/execute.d.ts.map +1 -0
  202. package/dist/middleware/core/execute.js +35 -0
  203. package/dist/middleware/core/execute.js.map +1 -0
  204. package/dist/middleware/core/hitl-gate.d.ts +3 -0
  205. package/dist/middleware/core/hitl-gate.d.ts.map +1 -0
  206. package/dist/middleware/core/hitl-gate.js +38 -0
  207. package/dist/middleware/core/hitl-gate.js.map +1 -0
  208. package/dist/middleware/core/rate-limiter.d.ts +10 -0
  209. package/dist/middleware/core/rate-limiter.d.ts.map +1 -0
  210. package/dist/middleware/core/rate-limiter.js +32 -0
  211. package/dist/middleware/core/rate-limiter.js.map +1 -0
  212. package/dist/middleware/core/schema-validator.d.ts +3 -0
  213. package/dist/middleware/core/schema-validator.d.ts.map +1 -0
  214. package/dist/middleware/core/schema-validator.js +31 -0
  215. package/dist/middleware/core/schema-validator.js.map +1 -0
  216. package/dist/middleware/detectors/injection-detector.d.ts +12 -0
  217. package/dist/middleware/detectors/injection-detector.d.ts.map +1 -0
  218. package/dist/middleware/detectors/injection-detector.js +129 -0
  219. package/dist/middleware/detectors/injection-detector.js.map +1 -0
  220. package/dist/middleware/detectors/sensitivity-classifier.d.ts +12 -0
  221. package/dist/middleware/detectors/sensitivity-classifier.d.ts.map +1 -0
  222. package/dist/middleware/detectors/sensitivity-classifier.js +125 -0
  223. package/dist/middleware/detectors/sensitivity-classifier.js.map +1 -0
  224. package/dist/middleware/post/canary-token-injector.d.ts +10 -0
  225. package/dist/middleware/post/canary-token-injector.d.ts.map +1 -0
  226. package/dist/middleware/post/canary-token-injector.js +53 -0
  227. package/dist/middleware/post/canary-token-injector.js.map +1 -0
  228. package/dist/middleware/post/output-injection-detector.d.ts +7 -0
  229. package/dist/middleware/post/output-injection-detector.d.ts.map +1 -0
  230. package/dist/middleware/post/output-injection-detector.js +46 -0
  231. package/dist/middleware/post/output-injection-detector.js.map +1 -0
  232. package/dist/middleware/post/output-size-limiter.d.ts +7 -0
  233. package/dist/middleware/post/output-size-limiter.d.ts.map +1 -0
  234. package/dist/middleware/post/output-size-limiter.js +47 -0
  235. package/dist/middleware/post/output-size-limiter.js.map +1 -0
  236. package/dist/middleware/post/output-summarizer.d.ts +15 -0
  237. package/dist/middleware/post/output-summarizer.d.ts.map +1 -0
  238. package/dist/middleware/post/output-summarizer.js +38 -0
  239. package/dist/middleware/post/output-summarizer.js.map +1 -0
  240. package/dist/middleware/post/strip-query-params.d.ts +3 -0
  241. package/dist/middleware/post/strip-query-params.d.ts.map +1 -0
  242. package/dist/middleware/post/strip-query-params.js +22 -0
  243. package/dist/middleware/post/strip-query-params.js.map +1 -0
  244. package/dist/middleware/post/untrusted-envelope.d.ts +3 -0
  245. package/dist/middleware/post/untrusted-envelope.d.ts.map +1 -0
  246. package/dist/middleware/post/untrusted-envelope.js +10 -0
  247. package/dist/middleware/post/untrusted-envelope.js.map +1 -0
  248. package/dist/middleware/types.d.ts +32 -0
  249. package/dist/middleware/types.d.ts.map +1 -0
  250. package/dist/middleware/types.js +2 -0
  251. package/dist/middleware/types.js.map +1 -0
  252. package/dist/pool/http-client.d.ts +26 -0
  253. package/dist/pool/http-client.d.ts.map +1 -0
  254. package/dist/pool/http-client.js +109 -0
  255. package/dist/pool/http-client.js.map +1 -0
  256. package/dist/pool/oauth-provider.d.ts +34 -0
  257. package/dist/pool/oauth-provider.d.ts.map +1 -0
  258. package/dist/pool/oauth-provider.js +135 -0
  259. package/dist/pool/oauth-provider.js.map +1 -0
  260. package/dist/pool/pool.d.ts +30 -0
  261. package/dist/pool/pool.d.ts.map +1 -0
  262. package/dist/pool/pool.js +119 -0
  263. package/dist/pool/pool.js.map +1 -0
  264. package/dist/pool/required-mcps.d.ts +7 -0
  265. package/dist/pool/required-mcps.d.ts.map +1 -0
  266. package/dist/pool/required-mcps.js +18 -0
  267. package/dist/pool/required-mcps.js.map +1 -0
  268. package/dist/pool/sse-client.d.ts +22 -0
  269. package/dist/pool/sse-client.d.ts.map +1 -0
  270. package/dist/pool/sse-client.js +70 -0
  271. package/dist/pool/sse-client.js.map +1 -0
  272. package/dist/pool/stdio-client.d.ts +24 -0
  273. package/dist/pool/stdio-client.d.ts.map +1 -0
  274. package/dist/pool/stdio-client.js +77 -0
  275. package/dist/pool/stdio-client.js.map +1 -0
  276. package/dist/registry/registry.d.ts +19 -0
  277. package/dist/registry/registry.d.ts.map +1 -0
  278. package/dist/registry/registry.js +85 -0
  279. package/dist/registry/registry.js.map +1 -0
  280. package/dist/registry/sanitizer.d.ts +2 -0
  281. package/dist/registry/sanitizer.d.ts.map +1 -0
  282. package/dist/registry/sanitizer.js +31 -0
  283. package/dist/registry/sanitizer.js.map +1 -0
  284. package/dist/security/blocked-hosts.d.ts +6 -0
  285. package/dist/security/blocked-hosts.d.ts.map +1 -0
  286. package/dist/security/blocked-hosts.js +26 -0
  287. package/dist/security/blocked-hosts.js.map +1 -0
  288. package/dist/security/domain-allowlist.d.ts +7 -0
  289. package/dist/security/domain-allowlist.d.ts.map +1 -0
  290. package/dist/security/domain-allowlist.js +19 -0
  291. package/dist/security/domain-allowlist.js.map +1 -0
  292. package/dist/stdio-mode.d.ts +3 -0
  293. package/dist/stdio-mode.d.ts.map +1 -0
  294. package/dist/stdio-mode.js +130 -0
  295. package/dist/stdio-mode.js.map +1 -0
  296. package/dist/tools/exec.d.ts +20 -0
  297. package/dist/tools/exec.d.ts.map +1 -0
  298. package/dist/tools/exec.js +105 -0
  299. package/dist/tools/exec.js.map +1 -0
  300. package/dist/tools/http.d.ts +13 -0
  301. package/dist/tools/http.d.ts.map +1 -0
  302. package/dist/tools/http.js +99 -0
  303. package/dist/tools/http.js.map +1 -0
  304. package/dist/transport/agent-server.d.ts +26 -0
  305. package/dist/transport/agent-server.d.ts.map +1 -0
  306. package/dist/transport/agent-server.js +55 -0
  307. package/dist/transport/agent-server.js.map +1 -0
  308. package/dist/transport/mcp-normalizer.d.ts +9 -0
  309. package/dist/transport/mcp-normalizer.d.ts.map +1 -0
  310. package/dist/transport/mcp-normalizer.js +12 -0
  311. package/dist/transport/mcp-normalizer.js.map +1 -0
  312. package/dist/transport/sse-server.d.ts +7 -0
  313. package/dist/transport/sse-server.d.ts.map +1 -0
  314. package/dist/transport/sse-server.js +94 -0
  315. package/dist/transport/sse-server.js.map +1 -0
  316. package/dist/transport/stdio-server.d.ts +3 -0
  317. package/dist/transport/stdio-server.d.ts.map +1 -0
  318. package/dist/transport/stdio-server.js +12 -0
  319. package/dist/transport/stdio-server.js.map +1 -0
  320. package/dist/types.d.ts +15 -0
  321. package/dist/types.d.ts.map +1 -0
  322. package/dist/types.js +2 -0
  323. package/dist/types.js.map +1 -0
  324. package/dist/util/id.d.ts +5 -0
  325. package/dist/util/id.d.ts.map +1 -0
  326. package/dist/util/id.js +16 -0
  327. package/dist/util/id.js.map +1 -0
  328. package/dist/util/logger.d.ts +4 -0
  329. package/dist/util/logger.d.ts.map +1 -0
  330. package/dist/util/logger.js +24 -0
  331. package/dist/util/logger.js.map +1 -0
  332. package/dist/version.d.ts +2 -0
  333. package/dist/version.d.ts.map +1 -0
  334. package/dist/version.js +4 -0
  335. package/dist/version.js.map +1 -0
  336. package/examples/claude-code-setup.md +77 -0
  337. package/examples/gateway.yaml +118 -0
  338. package/examples/local-dev.yaml +41 -0
  339. package/examples/openclaw-setup.md +52 -0
  340. package/examples/profiles.yaml +103 -0
  341. package/package.json +80 -3
  342. package/schema.json +943 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pool.js","sourceRoot":"","sources":["../../src/pool/pool.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { AgentConfig } from '../config/schema.js';
2
+ /**
3
+ * Return the MCP IDs from `availableMcpIds` that are actually referenced
4
+ * by the agent's allow or ask lists. Built-in namespaces (http, exec) are excluded.
5
+ */
6
+ export declare function requiredMcpsForAgent(agentConfig: AgentConfig, availableMcpIds: string[]): string[];
7
+ //# sourceMappingURL=required-mcps.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"required-mcps.d.ts","sourceRoot":"","sources":["../../src/pool/required-mcps.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAIvD;;;GAGG;AACH,wBAAgB,oBAAoB,CAClC,WAAW,EAAE,WAAW,EACxB,eAAe,EAAE,MAAM,EAAE,GACxB,MAAM,EAAE,CAaV"}
@@ -0,0 +1,18 @@
1
+ const BUILTIN_NAMESPACES = new Set(['http', 'exec']);
2
+ /**
3
+ * Return the MCP IDs from `availableMcpIds` that are actually referenced
4
+ * by the agent's allow or ask lists. Built-in namespaces (http, exec) are excluded.
5
+ */
6
+ export function requiredMcpsForAgent(agentConfig, availableMcpIds) {
7
+ const available = new Set(availableMcpIds);
8
+ const needed = new Set();
9
+ // Check both allow and ask — ask implies the tool will be used
10
+ for (const pattern of [...agentConfig.allow, ...agentConfig.ask]) {
11
+ const namespace = pattern.split('/')[0];
12
+ if (namespace && !BUILTIN_NAMESPACES.has(namespace) && available.has(namespace)) {
13
+ needed.add(namespace);
14
+ }
15
+ }
16
+ return Array.from(needed);
17
+ }
18
+ //# sourceMappingURL=required-mcps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"required-mcps.js","sourceRoot":"","sources":["../../src/pool/required-mcps.ts"],"names":[],"mappings":"AAEA,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;AAErD;;;GAGG;AACH,MAAM,UAAU,oBAAoB,CAClC,WAAwB,EACxB,eAAyB;IAEzB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,eAAe,CAAC,CAAC;IAC3C,MAAM,MAAM,GAAG,IAAI,GAAG,EAAU,CAAC;IAEjC,+DAA+D;IAC/D,KAAK,MAAM,OAAO,IAAI,CAAC,GAAG,WAAW,CAAC,KAAK,EAAE,GAAG,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;QACjE,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,IAAI,SAAS,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAChF,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAC5B,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { Tool } from '@modelcontextprotocol/sdk/types.js';
2
+ export declare class SseMcpClient {
3
+ private id;
4
+ private url;
5
+ private headers?;
6
+ private client?;
7
+ private transport?;
8
+ private reconnectAttempt;
9
+ private stopped;
10
+ private ready;
11
+ constructor(id: string, url: string, headers?: Record<string, string> | undefined);
12
+ connect(): Promise<void>;
13
+ listTools(): Promise<Tool[]>;
14
+ callTool(name: string, args: Record<string, unknown>): Promise<unknown>;
15
+ getServerInfo(): {
16
+ name: string;
17
+ version: string;
18
+ } | undefined;
19
+ isReady(): boolean;
20
+ stop(): Promise<void>;
21
+ }
22
+ //# sourceMappingURL=sse-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sse-client.d.ts","sourceRoot":"","sources":["../../src/pool/sse-client.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC;AAQ/D,qBAAa,YAAY;IAQrB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,OAAO,CAAC;IATlB,OAAO,CAAC,MAAM,CAAC,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAqB;IACvC,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,KAAK,CAAS;gBAGZ,EAAE,EAAE,MAAM,EACV,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,YAAA;IAGpC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAiCxB,SAAS,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAM5B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAK7E,aAAa,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS;IAI9D,OAAO,IAAI,OAAO;IAIZ,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAI5B"}
@@ -0,0 +1,70 @@
1
+ import { Client } from '@modelcontextprotocol/sdk/client/index.js';
2
+ import { SSEClientTransport } from '@modelcontextprotocol/sdk/client/sse.js';
3
+ import { childLogger } from '../util/logger.js';
4
+ import { VERSION } from '../version.js';
5
+ const log = childLogger('sse-client');
6
+ const BACKOFF_STEPS = [1000, 2000, 4000, 8000, 16000, 30000];
7
+ export class SseMcpClient {
8
+ id;
9
+ url;
10
+ headers;
11
+ client;
12
+ transport;
13
+ reconnectAttempt = 0;
14
+ stopped = false;
15
+ ready = false;
16
+ constructor(id, url, headers) {
17
+ this.id = id;
18
+ this.url = url;
19
+ this.headers = headers;
20
+ }
21
+ async connect() {
22
+ this.transport = new SSEClientTransport(new URL(this.url), {
23
+ requestInit: this.headers ? { headers: this.headers } : undefined,
24
+ });
25
+ this.client = new Client({ name: 'airlock', version: VERSION });
26
+ this.transport.onclose = () => {
27
+ this.ready = false;
28
+ if (!this.stopped) {
29
+ const delay = BACKOFF_STEPS[Math.min(this.reconnectAttempt, BACKOFF_STEPS.length - 1)];
30
+ log.warn({ id: this.id, attempt: this.reconnectAttempt, delay }, 'SSE MCP disconnected, reconnecting');
31
+ this.reconnectAttempt++;
32
+ setTimeout(() => {
33
+ void this.connect().catch((err) => log.error({ err, id: this.id }, 'Reconnect failed'));
34
+ }, delay);
35
+ }
36
+ };
37
+ try {
38
+ await this.client.connect(this.transport);
39
+ this.reconnectAttempt = 0;
40
+ this.ready = true;
41
+ log.info({ id: this.id, url: this.url }, 'MCP SSE client connected');
42
+ }
43
+ catch (err) {
44
+ log.error({ err, id: this.id }, 'MCP SSE connect failed');
45
+ throw err;
46
+ }
47
+ }
48
+ async listTools() {
49
+ if (!this.client || !this.ready)
50
+ throw new Error(`MCP ${this.id} not connected`);
51
+ const result = await this.client.listTools();
52
+ return result.tools;
53
+ }
54
+ async callTool(name, args) {
55
+ if (!this.client || !this.ready)
56
+ throw new Error(`MCP ${this.id} not connected`);
57
+ return this.client.callTool({ name, arguments: args });
58
+ }
59
+ getServerInfo() {
60
+ return this.client?.getServerVersion();
61
+ }
62
+ isReady() {
63
+ return this.ready;
64
+ }
65
+ async stop() {
66
+ this.stopped = true;
67
+ await this.transport?.close();
68
+ }
69
+ }
70
+ //# sourceMappingURL=sse-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sse-client.js","sourceRoot":"","sources":["../../src/pool/sse-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { Tool } from '@modelcontextprotocol/sdk/types.js';
2
+ export declare class StdioMcpClient {
3
+ private id;
4
+ private command;
5
+ private args;
6
+ private env?;
7
+ private stderr?;
8
+ private client?;
9
+ private transport?;
10
+ private reconnectAttempt;
11
+ private stopped;
12
+ private ready;
13
+ constructor(id: string, command: string, args: string[], env?: Record<string, string> | undefined, stderr?: "inherit" | "ignore" | "pipe" | undefined);
14
+ connect(): Promise<void>;
15
+ listTools(): Promise<Tool[]>;
16
+ callTool(name: string, args: Record<string, unknown>): Promise<unknown>;
17
+ getServerInfo(): {
18
+ name: string;
19
+ version: string;
20
+ } | undefined;
21
+ isReady(): boolean;
22
+ stop(): Promise<void>;
23
+ }
24
+ //# sourceMappingURL=stdio-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stdio-client.d.ts","sourceRoot":"","sources":["../../src/pool/stdio-client.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC;AAQ/D,qBAAa,cAAc;IAQvB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,GAAG,CAAC;IACZ,OAAO,CAAC,MAAM,CAAC;IAXjB,OAAO,CAAC,MAAM,CAAC,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAuB;IACzC,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,KAAK,CAAS;gBAGZ,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EAAE,EACd,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,YAAA,EAC5B,MAAM,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM,YAAA;IAG1C,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAoCxB,SAAS,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAM5B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAK7E,aAAa,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS;IAI9D,OAAO,IAAI,OAAO;IAIZ,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAI5B"}
@@ -0,0 +1,77 @@
1
+ import { Client } from '@modelcontextprotocol/sdk/client/index.js';
2
+ import { StdioClientTransport } from '@modelcontextprotocol/sdk/client/stdio.js';
3
+ import { childLogger } from '../util/logger.js';
4
+ import { VERSION } from '../version.js';
5
+ const log = childLogger('stdio-client');
6
+ const BACKOFF_STEPS = [1000, 2000, 4000, 8000, 16000, 30000];
7
+ export class StdioMcpClient {
8
+ id;
9
+ command;
10
+ args;
11
+ env;
12
+ stderr;
13
+ client;
14
+ transport;
15
+ reconnectAttempt = 0;
16
+ stopped = false;
17
+ ready = false;
18
+ constructor(id, command, args, env, stderr) {
19
+ this.id = id;
20
+ this.command = command;
21
+ this.args = args;
22
+ this.env = env;
23
+ this.stderr = stderr;
24
+ }
25
+ async connect() {
26
+ this.transport = new StdioClientTransport({
27
+ command: this.command,
28
+ args: this.args,
29
+ env: this.env,
30
+ stderr: this.stderr,
31
+ });
32
+ this.client = new Client({ name: 'airlock', version: VERSION });
33
+ this.transport.onclose = () => {
34
+ this.ready = false;
35
+ if (!this.stopped) {
36
+ const delay = BACKOFF_STEPS[Math.min(this.reconnectAttempt, BACKOFF_STEPS.length - 1)];
37
+ log.warn({ id: this.id, attempt: this.reconnectAttempt, delay }, 'MCP disconnected, reconnecting');
38
+ this.reconnectAttempt++;
39
+ setTimeout(() => {
40
+ void this.connect().catch((err) => log.error({ err, id: this.id }, 'Reconnect failed'));
41
+ }, delay);
42
+ }
43
+ };
44
+ try {
45
+ await this.client.connect(this.transport);
46
+ this.reconnectAttempt = 0;
47
+ this.ready = true;
48
+ log.info({ id: this.id }, 'MCP stdio client connected');
49
+ }
50
+ catch (err) {
51
+ log.error({ err, id: this.id }, 'MCP stdio connect failed');
52
+ throw err;
53
+ }
54
+ }
55
+ async listTools() {
56
+ if (!this.client || !this.ready)
57
+ throw new Error(`MCP ${this.id} not connected`);
58
+ const result = await this.client.listTools();
59
+ return result.tools;
60
+ }
61
+ async callTool(name, args) {
62
+ if (!this.client || !this.ready)
63
+ throw new Error(`MCP ${this.id} not connected`);
64
+ return this.client.callTool({ name, arguments: args });
65
+ }
66
+ getServerInfo() {
67
+ return this.client?.getServerVersion();
68
+ }
69
+ isReady() {
70
+ return this.ready;
71
+ }
72
+ async stop() {
73
+ this.stopped = true;
74
+ await this.transport?.close();
75
+ }
76
+ }
77
+ //# sourceMappingURL=stdio-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stdio-client.js","sourceRoot":"","sources":["../../src/pool/stdio-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import type { Tool } from '@modelcontextprotocol/sdk/types.js';
2
+ import type { BackendAdapter } from '../backend/types.js';
3
+ import type { AllowlistEngine } from '../allowlist/engine.js';
4
+ import type { AgentConfig } from '../config/schema.js';
5
+ export declare class ToolRegistry {
6
+ private adapters;
7
+ private allowlist;
8
+ private agents;
9
+ private cachedTools;
10
+ constructor(adapters: BackendAdapter[], allowlist: AllowlistEngine, agents: Record<string, AgentConfig>);
11
+ reloadAgents(agents: Record<string, AgentConfig>): void;
12
+ setAdapters(adapters: BackendAdapter[]): void;
13
+ refresh(): Promise<void>;
14
+ getFiltered(agentId: string): Tool[];
15
+ call(namespacedName: string, args: Record<string, unknown>, agentId: string): Promise<unknown>;
16
+ getAllTools(): Tool[];
17
+ stopAll(): Promise<void>;
18
+ }
19
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/registry/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC;AAC/D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAMvD,qBAAa,YAAY;IAIrB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,MAAM;IALhB,OAAO,CAAC,WAAW,CAAc;gBAGvB,QAAQ,EAAE,cAAc,EAAE,EAC1B,SAAS,EAAE,eAAe,EAC1B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC;IAG7C,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,GAAG,IAAI;IAIvD,WAAW,CAAC,QAAQ,EAAE,cAAc,EAAE,GAAG,IAAI;IAIvC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAqB9B,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,EAAE;IAY9B,IAAI,CACR,cAAc,EAAE,MAAM,EACtB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,OAAO,CAAC;IAgBnB,WAAW,IAAI,IAAI,EAAE;IAIf,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;CAG/B"}
@@ -0,0 +1,85 @@
1
+ import { sanitizeToolDescription } from './sanitizer.js';
2
+ import { childLogger } from '../util/logger.js';
3
+ const log = childLogger('registry');
4
+ export class ToolRegistry {
5
+ adapters;
6
+ allowlist;
7
+ agents;
8
+ cachedTools = [];
9
+ constructor(adapters, allowlist, agents) {
10
+ this.adapters = adapters;
11
+ this.allowlist = allowlist;
12
+ this.agents = agents;
13
+ }
14
+ reloadAgents(agents) {
15
+ this.agents = agents;
16
+ }
17
+ setAdapters(adapters) {
18
+ this.adapters = adapters;
19
+ }
20
+ async refresh() {
21
+ const tools = [];
22
+ for (const adapter of this.adapters) {
23
+ try {
24
+ const adapterTools = await adapter.listTools();
25
+ for (const tool of adapterTools) {
26
+ tools.push({
27
+ ...tool,
28
+ description: sanitizeToolDescription(tool.name, tool.description),
29
+ });
30
+ }
31
+ }
32
+ catch (err) {
33
+ log.warn({ err, adapterId: adapter.id }, 'Failed to list tools from adapter');
34
+ }
35
+ }
36
+ this.cachedTools = tools;
37
+ log.info({ count: tools.length }, 'Tool registry refreshed');
38
+ }
39
+ getFiltered(agentId) {
40
+ const agent = this.agents[agentId];
41
+ const overrides = agent?.tool_overrides ?? {};
42
+ return this.cachedTools
43
+ .filter((t) => this.allowlist.evaluate(agentId, t.name) !== 'deny')
44
+ .map((t) => ({
45
+ ...t,
46
+ description: sanitizeToolDescription(t.name, t.description, overrides[t.name]?.description),
47
+ }));
48
+ }
49
+ async call(namespacedName, args, agentId) {
50
+ // Find the adapter that owns this tool by matching its prefix
51
+ for (const adapter of this.adapters) {
52
+ const prefix = getAdapterPrefix(adapter);
53
+ if (prefix && namespacedName.startsWith(prefix)) {
54
+ const result = await adapter.call({ tool: namespacedName, args, agentId });
55
+ if (!result.success) {
56
+ throw new Error(result.error ?? 'Tool call failed');
57
+ }
58
+ return result.data;
59
+ }
60
+ }
61
+ throw new Error(`Unknown tool: ${namespacedName}`);
62
+ }
63
+ getAllTools() {
64
+ return this.cachedTools;
65
+ }
66
+ async stopAll() {
67
+ await Promise.allSettled(this.adapters.map((a) => a.stop()));
68
+ }
69
+ }
70
+ /** Map adapter ID conventions to the tool name prefix they own. */
71
+ function getAdapterPrefix(adapter) {
72
+ const id = adapter.id;
73
+ if (id.startsWith('mcp:'))
74
+ return id.slice(4) + '/';
75
+ if (id === 'builtin:exec')
76
+ return 'exec/';
77
+ if (id === 'builtin:http')
78
+ return 'http/';
79
+ if (id.startsWith('cli:'))
80
+ return id.slice(4) + '/';
81
+ if (id.startsWith('api:'))
82
+ return id.slice(4) + '/';
83
+ return null;
84
+ }
85
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/registry/registry.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function sanitizeToolDescription(toolName: string, description: string | undefined, override?: string): string;
2
+ //# sourceMappingURL=sanitizer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanitizer.d.ts","sourceRoot":"","sources":["../../src/registry/sanitizer.ts"],"names":[],"mappings":"AAeA,wBAAgB,uBAAuB,CACrC,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,GAAG,SAAS,EAC/B,QAAQ,CAAC,EAAE,MAAM,GAChB,MAAM,CAsBR"}
@@ -0,0 +1,31 @@
1
+ import { childLogger } from '../util/logger.js';
2
+ const log = childLogger('sanitizer');
3
+ const SUSPICIOUS_PATTERNS = [
4
+ /ignore\s+(previous|above|prior)/i,
5
+ /you\s+are\s+/i,
6
+ /new\s+instruction/i,
7
+ /override/i,
8
+ /\[SYSTEM\]/i,
9
+ /system:/i,
10
+ ];
11
+ const MAX_DESCRIPTION_LENGTH = 500;
12
+ export function sanitizeToolDescription(toolName, description, override) {
13
+ if (override !== undefined)
14
+ return override;
15
+ if (!description)
16
+ return '';
17
+ // Strip suspicious patterns (possible prompt injection from downstream MCPs)
18
+ let cleaned = description;
19
+ for (const pattern of SUSPICIOUS_PATTERNS) {
20
+ if (pattern.test(cleaned)) {
21
+ log.warn({ toolName, pattern: pattern.source }, 'Stripping suspicious pattern from tool description (possible prompt injection)');
22
+ cleaned = cleaned.replace(pattern, '[removed]');
23
+ }
24
+ }
25
+ // Truncate
26
+ if (cleaned.length > MAX_DESCRIPTION_LENGTH) {
27
+ return cleaned.slice(0, MAX_DESCRIPTION_LENGTH) + '…';
28
+ }
29
+ return cleaned;
30
+ }
31
+ //# sourceMappingURL=sanitizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sanitizer.js","sourceRoot":"","sources":["../../src/registry/sanitizer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM,GAAG,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC;AAErC,MAAM,mBAAmB,GAAG;IAC1B,kCAAkC;IAClC,eAAe;IACf,oBAAoB;IACpB,WAAW;IACX,aAAa;IACb,UAAU;CACX,CAAC;AAEF,MAAM,sBAAsB,GAAG,GAAG,CAAC;AAEnC,MAAM,UAAU,uBAAuB,CACrC,QAAgB,EAChB,WAA+B,EAC/B,QAAiB;IAEjB,IAAI,QAAQ,KAAK,SAAS;QAAE,OAAO,QAAQ,CAAC;IAC5C,IAAI,CAAC,WAAW;QAAE,OAAO,EAAE,CAAC;IAE5B,6EAA6E;IAC7E,IAAI,OAAO,GAAG,WAAW,CAAC;IAC1B,KAAK,MAAM,OAAO,IAAI,mBAAmB,EAAE,CAAC;QAC1C,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YAC1B,GAAG,CAAC,IAAI,CACN,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EACrC,gFAAgF,CACjF,CAAC;YACF,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAClD,CAAC;IACH,CAAC;IAED,WAAW;IACX,IAAI,OAAO,CAAC,MAAM,GAAG,sBAAsB,EAAE,CAAC;QAC5C,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,sBAAsB,CAAC,GAAG,GAAG,CAAC;IACxD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Check if a hostname is blocked.
3
+ * Supports: exact match, *.prefix (subdomains), 10.* / 192.168.* / 172.16.* CIDR-like patterns.
4
+ */
5
+ export declare function isBlockedHost(hostname: string, blockedList: string[], allowedLocal: string[]): boolean;
6
+ //# sourceMappingURL=blocked-hosts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocked-hosts.d.ts","sourceRoot":"","sources":["../../src/security/blocked-hosts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EAAE,EACrB,YAAY,EAAE,MAAM,EAAE,GACrB,OAAO,CAKT"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Check if a hostname is blocked.
3
+ * Supports: exact match, *.prefix (subdomains), 10.* / 192.168.* / 172.16.* CIDR-like patterns.
4
+ */
5
+ export function isBlockedHost(hostname, blockedList, allowedLocal) {
6
+ // If explicitly allowed, override block
7
+ if (allowedLocal.some((p) => hostPatternMatches(p, hostname)))
8
+ return false;
9
+ return blockedList.some((p) => hostPatternMatches(p, hostname));
10
+ }
11
+ function hostPatternMatches(pattern, hostname) {
12
+ if (pattern === hostname)
13
+ return true;
14
+ // *.local style — matches subdomains only, not the apex
15
+ if (pattern.startsWith('*.')) {
16
+ const suffix = pattern.slice(2);
17
+ return hostname.endsWith('.' + suffix);
18
+ }
19
+ // CIDR-like: 192.168.* , 10.* , 172.16.*
20
+ if (pattern.endsWith('*')) {
21
+ const prefix = pattern.slice(0, -1);
22
+ return hostname.startsWith(prefix);
23
+ }
24
+ return false;
25
+ }
26
+ //# sourceMappingURL=blocked-hosts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocked-hosts.js","sourceRoot":"","sources":["../../src/security/blocked-hosts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,QAAgB,EAChB,WAAqB,EACrB,YAAsB;IAEtB,wCAAwC;IACxC,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;QAAE,OAAO,KAAK,CAAC;IAE5E,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC;AAClE,CAAC;AAED,SAAS,kBAAkB,CAAC,OAAe,EAAE,QAAgB;IAC3D,IAAI,OAAO,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAEtC,wDAAwD;IACxD,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QAC7B,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAChC,OAAO,QAAQ,CAAC,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC;IACzC,CAAC;IAED,yCAAyC;IACzC,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QAC1B,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACpC,OAAO,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Check if a hostname is permitted by the agent's domain allowlist.
3
+ * Empty allowlist = allow all.
4
+ * Supports *.sentry.io style wildcards.
5
+ */
6
+ export declare function isDomainAllowed(hostname: string, allowlist: string[]): boolean;
7
+ //# sourceMappingURL=domain-allowlist.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"domain-allowlist.d.ts","sourceRoot":"","sources":["../../src/security/domain-allowlist.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAW9E"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Check if a hostname is permitted by the agent's domain allowlist.
3
+ * Empty allowlist = allow all.
4
+ * Supports *.sentry.io style wildcards.
5
+ */
6
+ export function isDomainAllowed(hostname, allowlist) {
7
+ if (allowlist.length === 0)
8
+ return true;
9
+ return allowlist.some((pattern) => {
10
+ if (pattern === hostname)
11
+ return true;
12
+ if (pattern.startsWith('*.')) {
13
+ const suffix = pattern.slice(2);
14
+ return hostname === suffix || hostname.endsWith('.' + suffix);
15
+ }
16
+ return false;
17
+ });
18
+ }
19
+ //# sourceMappingURL=domain-allowlist.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"domain-allowlist.js","sourceRoot":"","sources":["../../src/security/domain-allowlist.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,UAAU,eAAe,CAAC,QAAgB,EAAE,SAAmB;IACnE,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAExC,OAAO,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;QAChC,IAAI,OAAO,KAAK,QAAQ;YAAE,OAAO,IAAI,CAAC;QACtC,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAC7B,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAChC,OAAO,QAAQ,KAAK,MAAM,IAAI,QAAQ,CAAC,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC;QAChE,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Config } from './config/loader.js';
2
+ export declare function runStdioMode(config: Config, agentId: string, configPath: string): Promise<void>;
3
+ //# sourceMappingURL=stdio-mode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stdio-mode.d.ts","sourceRoot":"","sources":["../src/stdio-mode.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAQjD,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,IAAI,CAAC,CAuIf"}