palaryn 0.1.0 → 0.3.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 (328) hide show
  1. package/README.md +243 -588
  2. package/dist/sdk/typescript/src/client.js +2 -2
  3. package/dist/sdk/typescript/src/client.js.map +1 -1
  4. package/dist/src/audit/logger.d.ts +10 -0
  5. package/dist/src/audit/logger.d.ts.map +1 -1
  6. package/dist/src/audit/logger.js +52 -38
  7. package/dist/src/audit/logger.js.map +1 -1
  8. package/dist/src/auth/routes.js.map +1 -1
  9. package/dist/src/budget/manager.d.ts +5 -0
  10. package/dist/src/budget/manager.d.ts.map +1 -1
  11. package/dist/src/budget/manager.js +32 -0
  12. package/dist/src/budget/manager.js.map +1 -1
  13. package/dist/src/budget/model-pricing.d.ts +20 -0
  14. package/dist/src/budget/model-pricing.d.ts.map +1 -0
  15. package/dist/src/budget/model-pricing.js +107 -0
  16. package/dist/src/budget/model-pricing.js.map +1 -0
  17. package/dist/src/budget/usage-extractor.d.ts +3 -1
  18. package/dist/src/budget/usage-extractor.d.ts.map +1 -1
  19. package/dist/src/budget/usage-extractor.js +47 -3
  20. package/dist/src/budget/usage-extractor.js.map +1 -1
  21. package/dist/src/config/defaults.d.ts.map +1 -1
  22. package/dist/src/config/defaults.js +65 -13
  23. package/dist/src/config/defaults.js.map +1 -1
  24. package/dist/src/dlp/tool-patterns.d.ts +7 -0
  25. package/dist/src/dlp/tool-patterns.d.ts.map +1 -0
  26. package/dist/src/dlp/tool-patterns.js +34 -0
  27. package/dist/src/dlp/tool-patterns.js.map +1 -0
  28. package/dist/src/executor/filesystem-executor.d.ts +28 -0
  29. package/dist/src/executor/filesystem-executor.d.ts.map +1 -0
  30. package/dist/src/executor/filesystem-executor.js +192 -0
  31. package/dist/src/executor/filesystem-executor.js.map +1 -0
  32. package/dist/src/executor/http-executor.d.ts.map +1 -1
  33. package/dist/src/executor/http-executor.js +4 -0
  34. package/dist/src/executor/http-executor.js.map +1 -1
  35. package/dist/src/executor/index.d.ts +4 -0
  36. package/dist/src/executor/index.d.ts.map +1 -1
  37. package/dist/src/executor/index.js +9 -1
  38. package/dist/src/executor/index.js.map +1 -1
  39. package/dist/src/executor/shell-executor.d.ts +22 -0
  40. package/dist/src/executor/shell-executor.d.ts.map +1 -0
  41. package/dist/src/executor/shell-executor.js +119 -0
  42. package/dist/src/executor/shell-executor.js.map +1 -0
  43. package/dist/src/executor/sql-executor.d.ts +29 -0
  44. package/dist/src/executor/sql-executor.d.ts.map +1 -0
  45. package/dist/src/executor/sql-executor.js +114 -0
  46. package/dist/src/executor/sql-executor.js.map +1 -0
  47. package/dist/src/executor/websocket-executor.d.ts +26 -0
  48. package/dist/src/executor/websocket-executor.d.ts.map +1 -0
  49. package/dist/src/executor/websocket-executor.js +205 -0
  50. package/dist/src/executor/websocket-executor.js.map +1 -0
  51. package/dist/src/interceptor/index.d.ts +2 -0
  52. package/dist/src/interceptor/index.d.ts.map +1 -0
  53. package/dist/src/interceptor/index.js +6 -0
  54. package/dist/src/interceptor/index.js.map +1 -0
  55. package/dist/src/interceptor/provider-interceptor.d.ts +36 -0
  56. package/dist/src/interceptor/provider-interceptor.d.ts.map +1 -0
  57. package/dist/src/interceptor/provider-interceptor.js +302 -0
  58. package/dist/src/interceptor/provider-interceptor.js.map +1 -0
  59. package/dist/src/mcp/auth-verifier.d.ts.map +1 -1
  60. package/dist/src/mcp/auth-verifier.js +3 -2
  61. package/dist/src/mcp/auth-verifier.js.map +1 -1
  62. package/dist/src/mcp/bridge.d.ts +14 -10
  63. package/dist/src/mcp/bridge.d.ts.map +1 -1
  64. package/dist/src/mcp/bridge.js +51 -227
  65. package/dist/src/mcp/bridge.js.map +1 -1
  66. package/dist/src/mcp/http-transport.d.ts.map +1 -1
  67. package/dist/src/mcp/http-transport.js +101 -65
  68. package/dist/src/mcp/http-transport.js.map +1 -1
  69. package/dist/src/mcp/tool-definitions.d.ts +41 -0
  70. package/dist/src/mcp/tool-definitions.d.ts.map +1 -0
  71. package/dist/src/mcp/tool-definitions.js +491 -0
  72. package/dist/src/mcp/tool-definitions.js.map +1 -0
  73. package/dist/src/middleware/auth.js.map +1 -1
  74. package/dist/src/middleware/session.js.map +1 -1
  75. package/dist/src/middleware/validate.d.ts +8 -0
  76. package/dist/src/middleware/validate.d.ts.map +1 -1
  77. package/dist/src/middleware/validate.js +45 -0
  78. package/dist/src/middleware/validate.js.map +1 -1
  79. package/dist/src/policy/engine.d.ts +4 -0
  80. package/dist/src/policy/engine.d.ts.map +1 -1
  81. package/dist/src/policy/engine.js +117 -0
  82. package/dist/src/policy/engine.js.map +1 -1
  83. package/dist/src/saas/routes.d.ts.map +1 -1
  84. package/dist/src/saas/routes.js +327 -10
  85. package/dist/src/saas/routes.js.map +1 -1
  86. package/dist/src/server/app.d.ts.map +1 -1
  87. package/dist/src/server/app.js +19 -2
  88. package/dist/src/server/app.js.map +1 -1
  89. package/dist/src/server/gateway.d.ts.map +1 -1
  90. package/dist/src/server/gateway.js +17 -0
  91. package/dist/src/server/gateway.js.map +1 -1
  92. package/dist/src/server/index.d.ts.map +1 -1
  93. package/dist/src/server/index.js +18 -0
  94. package/dist/src/server/index.js.map +1 -1
  95. package/dist/src/storage/interfaces.d.ts +14 -3
  96. package/dist/src/storage/interfaces.d.ts.map +1 -1
  97. package/dist/src/storage/memory.d.ts +2 -0
  98. package/dist/src/storage/memory.d.ts.map +1 -1
  99. package/dist/src/storage/memory.js +6 -0
  100. package/dist/src/storage/memory.js.map +1 -1
  101. package/dist/src/storage/postgres.d.ts +5 -0
  102. package/dist/src/storage/postgres.d.ts.map +1 -1
  103. package/dist/src/storage/postgres.js +16 -0
  104. package/dist/src/storage/postgres.js.map +1 -1
  105. package/dist/src/storage/redis.d.ts +10 -0
  106. package/dist/src/storage/redis.d.ts.map +1 -1
  107. package/dist/src/storage/redis.js +65 -0
  108. package/dist/src/storage/redis.js.map +1 -1
  109. package/dist/src/types/budget.d.ts +4 -0
  110. package/dist/src/types/budget.d.ts.map +1 -1
  111. package/dist/src/types/config.d.ts +58 -0
  112. package/dist/src/types/config.d.ts.map +1 -1
  113. package/dist/src/types/events.d.ts +1 -0
  114. package/dist/src/types/events.d.ts.map +1 -1
  115. package/dist/src/types/policy.d.ts +11 -1
  116. package/dist/src/types/policy.d.ts.map +1 -1
  117. package/dist/src/types/tool-result.d.ts +11 -0
  118. package/dist/src/types/tool-result.d.ts.map +1 -1
  119. package/dist/tests/unit/app-routes.test.d.ts +2 -0
  120. package/dist/tests/unit/app-routes.test.d.ts.map +1 -0
  121. package/dist/tests/unit/app-routes.test.js +715 -0
  122. package/dist/tests/unit/app-routes.test.js.map +1 -0
  123. package/dist/tests/unit/audit-logger.test.js +105 -0
  124. package/dist/tests/unit/audit-logger.test.js.map +1 -1
  125. package/dist/tests/unit/auth-providers.test.d.ts +2 -0
  126. package/dist/tests/unit/auth-providers.test.d.ts.map +1 -0
  127. package/dist/tests/unit/auth-providers.test.js +279 -0
  128. package/dist/tests/unit/auth-providers.test.js.map +1 -0
  129. package/dist/tests/unit/auth-routes-extended.test.d.ts +2 -0
  130. package/dist/tests/unit/auth-routes-extended.test.d.ts.map +1 -0
  131. package/dist/tests/unit/auth-routes-extended.test.js +993 -0
  132. package/dist/tests/unit/auth-routes-extended.test.js.map +1 -0
  133. package/dist/tests/unit/auth-verifier.test.d.ts +2 -0
  134. package/dist/tests/unit/auth-verifier.test.d.ts.map +1 -0
  135. package/dist/tests/unit/auth-verifier.test.js +505 -0
  136. package/dist/tests/unit/auth-verifier.test.js.map +1 -0
  137. package/dist/tests/unit/billing-routes.test.d.ts +2 -0
  138. package/dist/tests/unit/billing-routes.test.d.ts.map +1 -0
  139. package/dist/tests/unit/billing-routes.test.js +432 -0
  140. package/dist/tests/unit/billing-routes.test.js.map +1 -0
  141. package/dist/tests/unit/config-defaults.test.d.ts +2 -0
  142. package/dist/tests/unit/config-defaults.test.d.ts.map +1 -0
  143. package/dist/tests/unit/config-defaults.test.js +119 -0
  144. package/dist/tests/unit/config-defaults.test.js.map +1 -0
  145. package/dist/tests/unit/defaults.test.js +0 -10
  146. package/dist/tests/unit/defaults.test.js.map +1 -1
  147. package/dist/tests/unit/filesystem-executor.test.d.ts +2 -0
  148. package/dist/tests/unit/filesystem-executor.test.d.ts.map +1 -0
  149. package/dist/tests/unit/filesystem-executor.test.js +280 -0
  150. package/dist/tests/unit/filesystem-executor.test.js.map +1 -0
  151. package/dist/tests/unit/gateway-branches.test.d.ts +2 -0
  152. package/dist/tests/unit/gateway-branches.test.d.ts.map +1 -0
  153. package/dist/tests/unit/gateway-branches.test.js +1039 -0
  154. package/dist/tests/unit/gateway-branches.test.js.map +1 -0
  155. package/dist/tests/unit/http-executor-branches.test.d.ts +2 -0
  156. package/dist/tests/unit/http-executor-branches.test.d.ts.map +1 -0
  157. package/dist/tests/unit/http-executor-branches.test.js +495 -0
  158. package/dist/tests/unit/http-executor-branches.test.js.map +1 -0
  159. package/dist/tests/unit/logger.test.d.ts +2 -0
  160. package/dist/tests/unit/logger.test.d.ts.map +1 -0
  161. package/dist/tests/unit/logger.test.js +97 -0
  162. package/dist/tests/unit/logger.test.js.map +1 -0
  163. package/dist/tests/unit/metrics.test.js +102 -0
  164. package/dist/tests/unit/metrics.test.js.map +1 -1
  165. package/dist/tests/unit/model-pricing.test.d.ts +2 -0
  166. package/dist/tests/unit/model-pricing.test.d.ts.map +1 -0
  167. package/dist/tests/unit/model-pricing.test.js +87 -0
  168. package/dist/tests/unit/model-pricing.test.js.map +1 -0
  169. package/dist/tests/unit/oauth-stores.test.d.ts +2 -0
  170. package/dist/tests/unit/oauth-stores.test.d.ts.map +1 -0
  171. package/dist/tests/unit/oauth-stores.test.js +260 -0
  172. package/dist/tests/unit/oauth-stores.test.js.map +1 -0
  173. package/dist/tests/unit/policy-engine.test.js +466 -0
  174. package/dist/tests/unit/policy-engine.test.js.map +1 -1
  175. package/dist/tests/unit/provider-interceptor.test.d.ts +2 -0
  176. package/dist/tests/unit/provider-interceptor.test.d.ts.map +1 -0
  177. package/dist/tests/unit/provider-interceptor.test.js +472 -0
  178. package/dist/tests/unit/provider-interceptor.test.js.map +1 -0
  179. package/dist/tests/unit/saas-routes-branches.test.d.ts +2 -0
  180. package/dist/tests/unit/saas-routes-branches.test.d.ts.map +1 -0
  181. package/dist/tests/unit/saas-routes-branches.test.js +2040 -0
  182. package/dist/tests/unit/saas-routes-branches.test.js.map +1 -0
  183. package/dist/tests/unit/saas-routes-crud.test.d.ts +2 -0
  184. package/dist/tests/unit/saas-routes-crud.test.d.ts.map +1 -0
  185. package/dist/tests/unit/saas-routes-crud.test.js +332 -0
  186. package/dist/tests/unit/saas-routes-crud.test.js.map +1 -0
  187. package/dist/tests/unit/saas-routes-data.test.d.ts +2 -0
  188. package/dist/tests/unit/saas-routes-data.test.d.ts.map +1 -0
  189. package/dist/tests/unit/saas-routes-data.test.js +405 -0
  190. package/dist/tests/unit/saas-routes-data.test.js.map +1 -0
  191. package/dist/tests/unit/saas-routes.test.js +3 -3
  192. package/dist/tests/unit/saas-routes.test.js.map +1 -1
  193. package/dist/tests/unit/shell-executor.test.d.ts +2 -0
  194. package/dist/tests/unit/shell-executor.test.d.ts.map +1 -0
  195. package/dist/tests/unit/shell-executor.test.js +145 -0
  196. package/dist/tests/unit/shell-executor.test.js.map +1 -0
  197. package/dist/tests/unit/sql-executor.test.d.ts +2 -0
  198. package/dist/tests/unit/sql-executor.test.d.ts.map +1 -0
  199. package/dist/tests/unit/sql-executor.test.js +177 -0
  200. package/dist/tests/unit/sql-executor.test.js.map +1 -0
  201. package/dist/tests/unit/stream-proxy.test.d.ts +2 -0
  202. package/dist/tests/unit/stream-proxy.test.d.ts.map +1 -0
  203. package/dist/tests/unit/stream-proxy.test.js +147 -0
  204. package/dist/tests/unit/stream-proxy.test.js.map +1 -0
  205. package/dist/tests/unit/tool-definitions.test.d.ts +2 -0
  206. package/dist/tests/unit/tool-definitions.test.d.ts.map +1 -0
  207. package/dist/tests/unit/tool-definitions.test.js +184 -0
  208. package/dist/tests/unit/tool-definitions.test.js.map +1 -0
  209. package/dist/tests/unit/usage-extractor.test.js +140 -0
  210. package/dist/tests/unit/usage-extractor.test.js.map +1 -1
  211. package/dist/tests/unit/webhook-handler.test.d.ts +2 -0
  212. package/dist/tests/unit/webhook-handler.test.d.ts.map +1 -0
  213. package/dist/tests/unit/webhook-handler.test.js +453 -0
  214. package/dist/tests/unit/webhook-handler.test.js.map +1 -0
  215. package/dist/tests/unit/webhook-routes.test.d.ts +2 -0
  216. package/dist/tests/unit/webhook-routes.test.d.ts.map +1 -0
  217. package/dist/tests/unit/webhook-routes.test.js +69 -0
  218. package/dist/tests/unit/webhook-routes.test.js.map +1 -0
  219. package/dist/tests/unit/websocket-executor.test.d.ts +2 -0
  220. package/dist/tests/unit/websocket-executor.test.d.ts.map +1 -0
  221. package/dist/tests/unit/websocket-executor.test.js +121 -0
  222. package/dist/tests/unit/websocket-executor.test.js.map +1 -0
  223. package/package.json +8 -2
  224. package/policy-packs/demo_fail.yaml +41 -0
  225. package/policy-packs/full_tools.yaml +136 -0
  226. package/src/admin/index.ts +1 -0
  227. package/src/admin/routes.ts +509 -0
  228. package/src/admin/templates.ts +572 -0
  229. package/src/anomaly/detector.ts +717 -0
  230. package/src/anomaly/index.ts +1 -0
  231. package/src/approval/manager.ts +569 -0
  232. package/src/approval/webhook.ts +133 -0
  233. package/src/audit/logger.ts +490 -0
  234. package/src/auth/index.ts +5 -0
  235. package/src/auth/password.ts +21 -0
  236. package/src/auth/pkce.ts +22 -0
  237. package/src/auth/providers.ts +208 -0
  238. package/src/auth/routes.ts +521 -0
  239. package/src/auth/session.ts +84 -0
  240. package/src/billing/index.ts +6 -0
  241. package/src/billing/plan-enforcer.ts +135 -0
  242. package/src/billing/routes.ts +229 -0
  243. package/src/billing/stripe-client.ts +58 -0
  244. package/src/billing/webhook-handler.ts +182 -0
  245. package/src/billing/webhook-routes.ts +28 -0
  246. package/src/budget/manager.ts +679 -0
  247. package/src/budget/model-pricing.ts +119 -0
  248. package/src/budget/usage-extractor.ts +214 -0
  249. package/src/cli.ts +91 -0
  250. package/src/config/defaults.ts +261 -0
  251. package/src/config/validate.ts +88 -0
  252. package/src/dlp/composite-scanner.ts +213 -0
  253. package/src/dlp/index.ts +9 -0
  254. package/src/dlp/interfaces.ts +34 -0
  255. package/src/dlp/patterns.ts +30 -0
  256. package/src/dlp/prompt-injection-backend.ts +181 -0
  257. package/src/dlp/prompt-injection-patterns.ts +302 -0
  258. package/src/dlp/regex-backend.ts +181 -0
  259. package/src/dlp/scanner.ts +502 -0
  260. package/src/dlp/text-normalizer.ts +225 -0
  261. package/src/dlp/tool-patterns.ts +35 -0
  262. package/src/dlp/trufflehog-backend.ts +190 -0
  263. package/src/executor/filesystem-executor.ts +196 -0
  264. package/src/executor/http-executor.ts +330 -0
  265. package/src/executor/index.ts +9 -0
  266. package/src/executor/interfaces.ts +11 -0
  267. package/src/executor/noop-executor.ts +23 -0
  268. package/src/executor/registry.ts +64 -0
  269. package/src/executor/shell-executor.ts +148 -0
  270. package/src/executor/slack-executor.ts +176 -0
  271. package/src/executor/sql-executor.ts +146 -0
  272. package/src/executor/websocket-executor.ts +211 -0
  273. package/src/index.ts +24 -0
  274. package/src/interceptor/index.ts +1 -0
  275. package/src/interceptor/provider-interceptor.ts +315 -0
  276. package/src/mcp/auth-verifier.ts +152 -0
  277. package/src/mcp/bridge.ts +703 -0
  278. package/src/mcp/http-transport.ts +672 -0
  279. package/src/mcp/index.ts +9 -0
  280. package/src/mcp/oauth-pages.ts +139 -0
  281. package/src/mcp/oauth-postgres-stores.ts +278 -0
  282. package/src/mcp/oauth-provider.ts +536 -0
  283. package/src/mcp/oauth-stores.ts +202 -0
  284. package/src/mcp/server.ts +55 -0
  285. package/src/mcp/tool-definitions.ts +562 -0
  286. package/src/metrics/collector.ts +357 -0
  287. package/src/metrics/index.ts +1 -0
  288. package/src/middleware/auth.ts +814 -0
  289. package/src/middleware/session.ts +85 -0
  290. package/src/middleware/validate.ts +130 -0
  291. package/src/policy/engine.ts +815 -0
  292. package/src/policy/index.ts +2 -0
  293. package/src/policy/opa-engine.ts +829 -0
  294. package/src/proxy/forward-proxy.ts +649 -0
  295. package/src/proxy/index.ts +1 -0
  296. package/src/ratelimit/limiter.ts +196 -0
  297. package/src/replay/engine.ts +142 -0
  298. package/src/replay/index.ts +1 -0
  299. package/src/saas/index.ts +1 -0
  300. package/src/saas/routes.ts +2161 -0
  301. package/src/server/app.ts +981 -0
  302. package/src/server/errors.ts +49 -0
  303. package/src/server/gateway.ts +1130 -0
  304. package/src/server/index.ts +307 -0
  305. package/src/server/logger.ts +255 -0
  306. package/src/server/stream-proxy.ts +202 -0
  307. package/src/storage/file-persistence.ts +315 -0
  308. package/src/storage/index.ts +4 -0
  309. package/src/storage/interfaces.ts +287 -0
  310. package/src/storage/memory.ts +686 -0
  311. package/src/storage/postgres.ts +1831 -0
  312. package/src/storage/redis.ts +835 -0
  313. package/src/tracing/index.ts +1 -0
  314. package/src/tracing/provider.ts +100 -0
  315. package/src/trust/calculator.ts +141 -0
  316. package/src/trust/index.ts +7 -0
  317. package/src/types/budget.ts +36 -0
  318. package/src/types/config.ts +278 -0
  319. package/src/types/events.ts +41 -0
  320. package/src/types/express.d.ts +14 -0
  321. package/src/types/index.ts +7 -0
  322. package/src/types/policy.ts +83 -0
  323. package/src/types/stripe-config.ts +11 -0
  324. package/src/types/subscription.ts +59 -0
  325. package/src/types/tool-call.ts +47 -0
  326. package/src/types/tool-result.ts +82 -0
  327. package/src/types/user.ts +125 -0
  328. package/tsconfig.json +24 -0
@@ -0,0 +1,26 @@
1
+ import { ToolCall } from '../types/tool-call';
2
+ import { ToolOutput } from '../types/tool-result';
3
+ import { ToolExecutor } from './interfaces';
4
+ import { WebSocketExecutorConfig } from '../types/config';
5
+ /**
6
+ * WebSocket executor for managed WebSocket connections.
7
+ * Handles tool calls with tool name `ws.*` (e.g., ws.connect, ws.send, ws.close).
8
+ * Manages a connection pool by connection_id with URL allowlisting.
9
+ */
10
+ export declare class WebSocketExecutor implements ToolExecutor {
11
+ private config;
12
+ private connections;
13
+ constructor(config: WebSocketExecutorConfig);
14
+ execute(toolCall: ToolCall): Promise<ToolOutput>;
15
+ private resolveAction;
16
+ /**
17
+ * Check if a URL matches any of the allowed URL patterns.
18
+ */
19
+ private isUrlAllowed;
20
+ private connect;
21
+ private send;
22
+ private wsClose;
23
+ /** Close all managed connections. */
24
+ closeAll(): Promise<void>;
25
+ }
26
+ //# sourceMappingURL=websocket-executor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-executor.d.ts","sourceRoot":"","sources":["../../../src/executor/websocket-executor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAQ1D;;;;GAIG;AACH,qBAAa,iBAAkB,YAAW,YAAY;IACpD,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,WAAW,CAA6C;gBAEpD,MAAM,EAAE,uBAAuB;IAIrC,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC;IAetD,OAAO,CAAC,aAAa;IAcrB;;OAEG;IACH,OAAO,CAAC,YAAY;YAiBN,OAAO;YA6CP,IAAI;YA8DJ,OAAO;IAqBrB,qCAAqC;IAC/B,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAMhC"}
@@ -0,0 +1,205 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.WebSocketExecutor = void 0;
40
+ const ws_1 = __importDefault(require("ws"));
41
+ const crypto = __importStar(require("crypto"));
42
+ /**
43
+ * WebSocket executor for managed WebSocket connections.
44
+ * Handles tool calls with tool name `ws.*` (e.g., ws.connect, ws.send, ws.close).
45
+ * Manages a connection pool by connection_id with URL allowlisting.
46
+ */
47
+ class WebSocketExecutor {
48
+ constructor(config) {
49
+ this.connections = new Map();
50
+ this.config = config;
51
+ }
52
+ async execute(toolCall) {
53
+ const action = this.resolveAction(toolCall);
54
+ switch (action) {
55
+ case 'connect':
56
+ return this.connect(toolCall);
57
+ case 'send':
58
+ return this.send(toolCall);
59
+ case 'close':
60
+ return this.wsClose(toolCall);
61
+ default:
62
+ throw new Error(`Unsupported WebSocket action: ${action}`);
63
+ }
64
+ }
65
+ resolveAction(toolCall) {
66
+ if (toolCall.args.action && typeof toolCall.args.action === 'string') {
67
+ return toolCall.args.action;
68
+ }
69
+ const toolName = toolCall.tool.name;
70
+ const dotIndex = toolName.indexOf('.');
71
+ if (dotIndex !== -1) {
72
+ return toolName.substring(dotIndex + 1);
73
+ }
74
+ throw new Error(`Unsupported WebSocket action: ${toolName}`);
75
+ }
76
+ /**
77
+ * Check if a URL matches any of the allowed URL patterns.
78
+ */
79
+ isUrlAllowed(url) {
80
+ if (!this.config.allowed_urls || this.config.allowed_urls.length === 0) {
81
+ return false;
82
+ }
83
+ for (const pattern of this.config.allowed_urls) {
84
+ // Convert glob-like pattern to regex
85
+ const escaped = pattern.replace(/[.+?^${}()|[\]\\]/g, '\\$&').replace(/\*/g, '.*');
86
+ const regex = new RegExp(`^${escaped}$`);
87
+ if (regex.test(url)) {
88
+ return true;
89
+ }
90
+ }
91
+ return false;
92
+ }
93
+ async connect(toolCall) {
94
+ const { url, connection_id: providedId } = toolCall.args;
95
+ if (!url || typeof url !== 'string') {
96
+ throw new Error('Missing or invalid "url" argument for ws.connect');
97
+ }
98
+ if (!this.isUrlAllowed(url)) {
99
+ throw new Error(`URL "${url}" is not in the allowed URLs list`);
100
+ }
101
+ const connectionId = (typeof providedId === 'string' ? providedId : null)
102
+ || crypto.randomUUID();
103
+ return new Promise((resolve, reject) => {
104
+ const timeout = setTimeout(() => {
105
+ ws.close();
106
+ reject(new Error(`WebSocket connection timeout after ${this.config.connect_timeout_ms}ms`));
107
+ }, this.config.connect_timeout_ms);
108
+ const ws = new ws_1.default(url, {
109
+ maxPayload: this.config.max_message_size_bytes,
110
+ });
111
+ ws.on('open', () => {
112
+ clearTimeout(timeout);
113
+ this.connections.set(connectionId, {
114
+ ws,
115
+ url,
116
+ createdAt: Date.now(),
117
+ });
118
+ resolve({
119
+ body: { connected: true, connection_id: connectionId },
120
+ metadata: { url },
121
+ });
122
+ });
123
+ ws.on('error', (err) => {
124
+ clearTimeout(timeout);
125
+ reject(new Error(`WebSocket connection failed: ${err.message}`));
126
+ });
127
+ });
128
+ }
129
+ async send(toolCall) {
130
+ const { connection_id, message, wait_for_response } = toolCall.args;
131
+ if (!connection_id || typeof connection_id !== 'string') {
132
+ throw new Error('Missing or invalid "connection_id" argument for ws.send');
133
+ }
134
+ if (message === undefined || message === null) {
135
+ throw new Error('Missing "message" argument for ws.send');
136
+ }
137
+ const conn = this.connections.get(connection_id);
138
+ if (!conn) {
139
+ throw new Error(`No connection found with id "${connection_id}"`);
140
+ }
141
+ if (conn.ws.readyState !== ws_1.default.OPEN) {
142
+ this.connections.delete(connection_id);
143
+ throw new Error(`Connection "${connection_id}" is no longer open`);
144
+ }
145
+ const data = typeof message === 'string' ? message : JSON.stringify(message);
146
+ if (Buffer.byteLength(data) > this.config.max_message_size_bytes) {
147
+ throw new Error(`Message size exceeds max allowed ${this.config.max_message_size_bytes} bytes`);
148
+ }
149
+ return new Promise((resolve, reject) => {
150
+ if (wait_for_response) {
151
+ const responseTimeout = setTimeout(() => {
152
+ conn.ws.removeAllListeners('message');
153
+ resolve({
154
+ body: null,
155
+ metadata: { connection_id, timeout: true },
156
+ });
157
+ }, this.config.connect_timeout_ms);
158
+ conn.ws.once('message', (responseData) => {
159
+ clearTimeout(responseTimeout);
160
+ resolve({
161
+ body: responseData.toString(),
162
+ metadata: { connection_id },
163
+ });
164
+ });
165
+ }
166
+ conn.ws.send(data, (err) => {
167
+ if (err) {
168
+ reject(new Error(`Failed to send message: ${err.message}`));
169
+ return;
170
+ }
171
+ if (!wait_for_response) {
172
+ resolve({
173
+ body: { sent: true },
174
+ metadata: { connection_id },
175
+ });
176
+ }
177
+ });
178
+ });
179
+ }
180
+ async wsClose(toolCall) {
181
+ const { connection_id } = toolCall.args;
182
+ if (!connection_id || typeof connection_id !== 'string') {
183
+ throw new Error('Missing or invalid "connection_id" argument for ws.close');
184
+ }
185
+ const conn = this.connections.get(connection_id);
186
+ if (!conn) {
187
+ throw new Error(`No connection found with id "${connection_id}"`);
188
+ }
189
+ conn.ws.close();
190
+ this.connections.delete(connection_id);
191
+ return {
192
+ body: { closed: true },
193
+ metadata: { connection_id },
194
+ };
195
+ }
196
+ /** Close all managed connections. */
197
+ async closeAll() {
198
+ for (const [id, conn] of this.connections) {
199
+ conn.ws.close();
200
+ this.connections.delete(id);
201
+ }
202
+ }
203
+ }
204
+ exports.WebSocketExecutor = WebSocketExecutor;
205
+ //# sourceMappingURL=websocket-executor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-executor.js","sourceRoot":"","sources":["../../../src/executor/websocket-executor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { ProviderInterceptor, ProviderToolBlock } from './provider-interceptor';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/interceptor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProviderInterceptor = void 0;
4
+ var provider_interceptor_1 = require("./provider-interceptor");
5
+ Object.defineProperty(exports, "ProviderInterceptor", { enumerable: true, get: function () { return provider_interceptor_1.ProviderInterceptor; } });
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/interceptor/index.ts"],"names":[],"mappings":";;;AAAA,+DAAgF;AAAvE,2HAAA,mBAAmB,OAAA"}
@@ -0,0 +1,36 @@
1
+ import { ProviderInterceptConfig } from '../types/config';
2
+ export interface ProviderToolBlock {
3
+ provider: 'claude' | 'openai' | 'gemini' | 'unknown';
4
+ tool_name: string;
5
+ tool_type: string;
6
+ inputs: Record<string, unknown>;
7
+ outputs?: unknown;
8
+ block_index: number;
9
+ }
10
+ type Provider = ProviderToolBlock['provider'];
11
+ export declare class ProviderInterceptor {
12
+ private urlPatterns;
13
+ private scanInputs;
14
+ private scanOutputs;
15
+ constructor(config: ProviderInterceptConfig);
16
+ /** Check if a URL matches any provider pattern */
17
+ matchesProvider(url: string): boolean;
18
+ /** Detect which provider a URL belongs to */
19
+ detectProvider(url: string): Provider;
20
+ /** Extract tool blocks from a request body (pre-execution) */
21
+ extractFromRequest(body: unknown, provider: string): ProviderToolBlock[];
22
+ /** Extract tool blocks from a response body (post-execution) */
23
+ extractFromResponse(body: unknown, provider: string): ProviderToolBlock[];
24
+ /** Get all inputs as a flat object for DLP scanning */
25
+ flattenInputsForDLP(blocks: ProviderToolBlock[]): Record<string, unknown>;
26
+ /** Get all outputs as a flat object for DLP scanning */
27
+ flattenOutputsForDLP(blocks: ProviderToolBlock[]): Record<string, unknown>;
28
+ private extractClaudeRequest;
29
+ private extractClaudeResponse;
30
+ private extractOpenAIRequest;
31
+ private extractOpenAIResponse;
32
+ private extractGeminiRequest;
33
+ private extractGeminiResponse;
34
+ }
35
+ export {};
36
+ //# sourceMappingURL=provider-interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-interceptor.d.ts","sourceRoot":"","sources":["../../../src/interceptor/provider-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAE1D,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;IACrD,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,KAAK,QAAQ,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;AAyB9C,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,WAAW,CAAW;IAC9B,OAAO,CAAC,UAAU,CAAU;IAC5B,OAAO,CAAC,WAAW,CAAU;gBAEjB,MAAM,EAAE,uBAAuB;IAS3C,kDAAkD;IAClD,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIrC,6CAA6C;IAC7C,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ;IAOrC,8DAA8D;IAC9D,kBAAkB,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,iBAAiB,EAAE;IAcxE,gEAAgE;IAChE,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,iBAAiB,EAAE;IAczE,uDAAuD;IACvD,mBAAmB,CAAC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAUzE,wDAAwD;IACxD,oBAAoB,CAAC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAY1E,OAAO,CAAC,oBAAoB;IAkC5B,OAAO,CAAC,qBAAqB;IAsB7B,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,qBAAqB;IA6B7B,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,qBAAqB;CAyB9B"}
@@ -0,0 +1,302 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProviderInterceptor = void 0;
4
+ const DEFAULT_URL_PATTERNS = [
5
+ 'api\\.anthropic\\.com',
6
+ 'api\\.openai\\.com',
7
+ 'generativelanguage\\.googleapis\\.com',
8
+ ];
9
+ const CLAUDE_TOOL_TYPES = {
10
+ computer_20241022: 'computer_use',
11
+ str_replace_editor: 'text_editor',
12
+ bash_20241022: 'bash',
13
+ };
14
+ const OPENAI_TOOL_TYPES = new Set([
15
+ 'code_interpreter',
16
+ 'file_search',
17
+ 'web_search',
18
+ ]);
19
+ const GEMINI_TOOL_TYPES = new Set([
20
+ 'code_execution',
21
+ 'google_search',
22
+ ]);
23
+ class ProviderInterceptor {
24
+ constructor(config) {
25
+ const patterns = config.provider_url_patterns?.length
26
+ ? config.provider_url_patterns
27
+ : DEFAULT_URL_PATTERNS;
28
+ this.urlPatterns = patterns.map((p) => new RegExp(p));
29
+ this.scanInputs = config.scan_inputs;
30
+ this.scanOutputs = config.scan_outputs;
31
+ }
32
+ /** Check if a URL matches any provider pattern */
33
+ matchesProvider(url) {
34
+ return this.urlPatterns.some((re) => re.test(url));
35
+ }
36
+ /** Detect which provider a URL belongs to */
37
+ detectProvider(url) {
38
+ if (/api\.anthropic\.com/.test(url))
39
+ return 'claude';
40
+ if (/api\.openai\.com/.test(url))
41
+ return 'openai';
42
+ if (/generativelanguage\.googleapis\.com/.test(url))
43
+ return 'gemini';
44
+ return 'unknown';
45
+ }
46
+ /** Extract tool blocks from a request body (pre-execution) */
47
+ extractFromRequest(body, provider) {
48
+ if (!this.scanInputs || !body || typeof body !== 'object')
49
+ return [];
50
+ try {
51
+ switch (provider) {
52
+ case 'claude': return this.extractClaudeRequest(body);
53
+ case 'openai': return this.extractOpenAIRequest(body);
54
+ case 'gemini': return this.extractGeminiRequest(body);
55
+ default: return [];
56
+ }
57
+ }
58
+ catch {
59
+ return [];
60
+ }
61
+ }
62
+ /** Extract tool blocks from a response body (post-execution) */
63
+ extractFromResponse(body, provider) {
64
+ if (!this.scanOutputs || !body || typeof body !== 'object')
65
+ return [];
66
+ try {
67
+ switch (provider) {
68
+ case 'claude': return this.extractClaudeResponse(body);
69
+ case 'openai': return this.extractOpenAIResponse(body);
70
+ case 'gemini': return this.extractGeminiResponse(body);
71
+ default: return [];
72
+ }
73
+ }
74
+ catch {
75
+ return [];
76
+ }
77
+ }
78
+ /** Get all inputs as a flat object for DLP scanning */
79
+ flattenInputsForDLP(blocks) {
80
+ const result = {};
81
+ for (const block of blocks) {
82
+ for (const [key, value] of Object.entries(block.inputs)) {
83
+ result[`${block.tool_name}.${key}`] = value;
84
+ }
85
+ }
86
+ return result;
87
+ }
88
+ /** Get all outputs as a flat object for DLP scanning */
89
+ flattenOutputsForDLP(blocks) {
90
+ const result = {};
91
+ for (const block of blocks) {
92
+ if (block.outputs !== undefined) {
93
+ result[`${block.tool_name}.output`] = block.outputs;
94
+ }
95
+ }
96
+ return result;
97
+ }
98
+ // --- Claude extraction ---
99
+ extractClaudeRequest(body) {
100
+ const blocks = [];
101
+ const messages = getArray(body, 'messages');
102
+ let index = 0;
103
+ for (const msg of messages) {
104
+ const content = getArray(msg, 'content');
105
+ for (const part of content) {
106
+ if (!isObject(part))
107
+ continue;
108
+ const type = getString(part, 'type');
109
+ if (type === 'tool_use') {
110
+ const name = getString(part, 'name') || 'unknown';
111
+ blocks.push({
112
+ provider: 'claude',
113
+ tool_name: name,
114
+ tool_type: resolveClaudeToolType(name),
115
+ inputs: isObject(part.input) ? part.input : {},
116
+ block_index: index++,
117
+ });
118
+ }
119
+ else if (type === 'tool_result') {
120
+ const toolUseId = getString(part, 'tool_use_id') || 'unknown';
121
+ blocks.push({
122
+ provider: 'claude',
123
+ tool_name: `tool_result:${toolUseId}`,
124
+ tool_type: 'tool_result',
125
+ inputs: {},
126
+ outputs: part.content,
127
+ block_index: index++,
128
+ });
129
+ }
130
+ }
131
+ }
132
+ return blocks;
133
+ }
134
+ extractClaudeResponse(body) {
135
+ const blocks = [];
136
+ const content = getArray(body, 'content');
137
+ let index = 0;
138
+ for (const part of content) {
139
+ if (!isObject(part))
140
+ continue;
141
+ if (getString(part, 'type') === 'tool_use') {
142
+ const name = getString(part, 'name') || 'unknown';
143
+ blocks.push({
144
+ provider: 'claude',
145
+ tool_name: name,
146
+ tool_type: resolveClaudeToolType(name),
147
+ inputs: isObject(part.input) ? part.input : {},
148
+ block_index: index++,
149
+ });
150
+ }
151
+ }
152
+ return blocks;
153
+ }
154
+ // --- OpenAI extraction ---
155
+ extractOpenAIRequest(body) {
156
+ const blocks = [];
157
+ const messages = getArray(body, 'messages');
158
+ let index = 0;
159
+ for (const msg of messages) {
160
+ const toolCalls = getArray(msg, 'tool_calls');
161
+ for (const tc of toolCalls) {
162
+ if (!isObject(tc))
163
+ continue;
164
+ const fn = isObject(tc.function) ? tc.function : null;
165
+ if (!fn)
166
+ continue;
167
+ const name = getString(fn, 'name') || 'unknown';
168
+ const args = parseJsonString(getString(fn, 'arguments'));
169
+ blocks.push({
170
+ provider: 'openai',
171
+ tool_name: name,
172
+ tool_type: resolveOpenAIToolType(name),
173
+ inputs: args,
174
+ block_index: index++,
175
+ });
176
+ }
177
+ }
178
+ return blocks;
179
+ }
180
+ extractOpenAIResponse(body) {
181
+ const blocks = [];
182
+ const choices = getArray(body, 'choices');
183
+ let index = 0;
184
+ for (const choice of choices) {
185
+ if (!isObject(choice))
186
+ continue;
187
+ const message = isObject(choice.message) ? choice.message : null;
188
+ if (!message)
189
+ continue;
190
+ const toolCalls = getArray(message, 'tool_calls');
191
+ for (const tc of toolCalls) {
192
+ if (!isObject(tc))
193
+ continue;
194
+ const fn = isObject(tc.function) ? tc.function : null;
195
+ if (!fn)
196
+ continue;
197
+ const name = getString(fn, 'name') || 'unknown';
198
+ const args = parseJsonString(getString(fn, 'arguments'));
199
+ blocks.push({
200
+ provider: 'openai',
201
+ tool_name: name,
202
+ tool_type: resolveOpenAIToolType(name),
203
+ inputs: args,
204
+ block_index: index++,
205
+ });
206
+ }
207
+ }
208
+ return blocks;
209
+ }
210
+ // --- Gemini extraction ---
211
+ extractGeminiRequest(body) {
212
+ const blocks = [];
213
+ const contents = getArray(body, 'contents');
214
+ let index = 0;
215
+ for (const content of contents) {
216
+ if (!isObject(content))
217
+ continue;
218
+ const parts = getArray(content, 'parts');
219
+ for (const part of parts) {
220
+ if (!isObject(part))
221
+ continue;
222
+ const fc = isObject(part.functionCall) ? part.functionCall : null;
223
+ if (!fc)
224
+ continue;
225
+ const name = getString(fc, 'name') || 'unknown';
226
+ blocks.push({
227
+ provider: 'gemini',
228
+ tool_name: name,
229
+ tool_type: resolveGeminiToolType(name),
230
+ inputs: isObject(fc.args) ? fc.args : {},
231
+ block_index: index++,
232
+ });
233
+ }
234
+ }
235
+ return blocks;
236
+ }
237
+ extractGeminiResponse(body) {
238
+ const blocks = [];
239
+ const candidates = getArray(body, 'candidates');
240
+ let index = 0;
241
+ for (const candidate of candidates) {
242
+ if (!isObject(candidate))
243
+ continue;
244
+ const content = isObject(candidate.content) ? candidate.content : null;
245
+ if (!content)
246
+ continue;
247
+ const parts = getArray(content, 'parts');
248
+ for (const part of parts) {
249
+ if (!isObject(part))
250
+ continue;
251
+ const fc = isObject(part.functionCall) ? part.functionCall : null;
252
+ if (!fc)
253
+ continue;
254
+ const name = getString(fc, 'name') || 'unknown';
255
+ blocks.push({
256
+ provider: 'gemini',
257
+ tool_name: name,
258
+ tool_type: resolveGeminiToolType(name),
259
+ inputs: isObject(fc.args) ? fc.args : {},
260
+ block_index: index++,
261
+ });
262
+ }
263
+ }
264
+ return blocks;
265
+ }
266
+ }
267
+ exports.ProviderInterceptor = ProviderInterceptor;
268
+ // --- Helpers ---
269
+ function isObject(val) {
270
+ return val !== null && typeof val === 'object' && !Array.isArray(val);
271
+ }
272
+ function getArray(obj, key) {
273
+ if (!isObject(obj))
274
+ return [];
275
+ const val = obj[key];
276
+ return Array.isArray(val) ? val : [];
277
+ }
278
+ function getString(obj, key) {
279
+ const val = obj[key];
280
+ return typeof val === 'string' ? val : '';
281
+ }
282
+ function parseJsonString(str) {
283
+ if (!str)
284
+ return {};
285
+ try {
286
+ const parsed = JSON.parse(str);
287
+ return isObject(parsed) ? parsed : {};
288
+ }
289
+ catch {
290
+ return {};
291
+ }
292
+ }
293
+ function resolveClaudeToolType(name) {
294
+ return CLAUDE_TOOL_TYPES[name] || 'function';
295
+ }
296
+ function resolveOpenAIToolType(name) {
297
+ return OPENAI_TOOL_TYPES.has(name) ? name : 'function';
298
+ }
299
+ function resolveGeminiToolType(name) {
300
+ return GEMINI_TOOL_TYPES.has(name) ? name : 'function';
301
+ }
302
+ //# sourceMappingURL=provider-interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-interceptor.js","sourceRoot":"","sources":["../../../src/interceptor/provider-interceptor.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"auth-verifier.d.ts","sourceRoot":"","sources":["../../../src/mcp/auth-verifier.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,QAAQ,EAAE,MAAM,gDAAgD,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAExD,MAAM,WAAW,kBAAkB;IACjC,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,UAAU,EAAE,UAAU,CAAC;IACvB,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC;AAED,qBAAa,mBAAoB,YAAW,kBAAkB;IAC5D,OAAO,CAAC,aAAa,CAAC,CAAuB;IAC7C,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAkB;gBAE9B,IAAI,EAAE,kBAAkB;IAMpC;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAcpB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAmG1D"}
1
+ {"version":3,"file":"auth-verifier.d.ts","sourceRoot":"","sources":["../../../src/mcp/auth-verifier.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,QAAQ,EAAE,MAAM,gDAAgD,CAAC;AAE1E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAExD,MAAM,WAAW,kBAAkB;IACjC,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,UAAU,EAAE,UAAU,CAAC;IACvB,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC;AAED,qBAAa,mBAAoB,YAAW,kBAAkB;IAC5D,OAAO,CAAC,aAAa,CAAC,CAAuB;IAC7C,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAkB;gBAE9B,IAAI,EAAE,kBAAkB;IAMpC;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAcpB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAmG1D"}
@@ -43,6 +43,7 @@ exports.HybridTokenVerifier = void 0;
43
43
  * `--header "Authorization: Bearer <api-key>"` usage still works.
44
44
  */
45
45
  const crypto = __importStar(require("crypto"));
46
+ const errors_js_1 = require("@modelcontextprotocol/sdk/server/auth/errors.js");
46
47
  const auth_1 = require("../middleware/auth");
47
48
  class HybridTokenVerifier {
48
49
  constructor(deps) {
@@ -83,7 +84,7 @@ class HybridTokenVerifier {
83
84
  if (keyConfig.expires_at) {
84
85
  const expiresAt = new Date(keyConfig.expires_at);
85
86
  if (expiresAt.getTime() <= Date.now()) {
86
- throw new Error('API key has expired');
87
+ throw new errors_js_1.InvalidTokenError('API key has expired');
87
88
  }
88
89
  }
89
90
  // Fire-and-forget: update last_used_at
@@ -155,7 +156,7 @@ class HybridTokenVerifier {
155
156
  },
156
157
  };
157
158
  }
158
- throw new Error('Invalid access token');
159
+ throw new errors_js_1.InvalidTokenError('Invalid access token');
159
160
  }
160
161
  }
161
162
  exports.HybridTokenVerifier = HybridTokenVerifier;