@aion0/bastion 0.1.7

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 (377) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +183 -0
  3. package/README.zh.md +468 -0
  4. package/config/default.yaml +73 -0
  5. package/dist/cli/commands/config.d.ts +3 -0
  6. package/dist/cli/commands/config.d.ts.map +1 -0
  7. package/dist/cli/commands/config.js +31 -0
  8. package/dist/cli/commands/config.js.map +1 -0
  9. package/dist/cli/commands/env.d.ts +3 -0
  10. package/dist/cli/commands/env.d.ts.map +1 -0
  11. package/dist/cli/commands/env.js +83 -0
  12. package/dist/cli/commands/env.js.map +1 -0
  13. package/dist/cli/commands/health.d.ts +3 -0
  14. package/dist/cli/commands/health.d.ts.map +1 -0
  15. package/dist/cli/commands/health.js +45 -0
  16. package/dist/cli/commands/health.js.map +1 -0
  17. package/dist/cli/commands/openclaw.d.ts +3 -0
  18. package/dist/cli/commands/openclaw.d.ts.map +1 -0
  19. package/dist/cli/commands/openclaw.js +1062 -0
  20. package/dist/cli/commands/openclaw.js.map +1 -0
  21. package/dist/cli/commands/proxy.d.ts +8 -0
  22. package/dist/cli/commands/proxy.d.ts.map +1 -0
  23. package/dist/cli/commands/proxy.js +433 -0
  24. package/dist/cli/commands/proxy.js.map +1 -0
  25. package/dist/cli/commands/start.d.ts +3 -0
  26. package/dist/cli/commands/start.d.ts.map +1 -0
  27. package/dist/cli/commands/start.js +62 -0
  28. package/dist/cli/commands/start.js.map +1 -0
  29. package/dist/cli/commands/stats.d.ts +3 -0
  30. package/dist/cli/commands/stats.d.ts.map +1 -0
  31. package/dist/cli/commands/stats.js +32 -0
  32. package/dist/cli/commands/stats.js.map +1 -0
  33. package/dist/cli/commands/stop.d.ts +3 -0
  34. package/dist/cli/commands/stop.d.ts.map +1 -0
  35. package/dist/cli/commands/stop.js +28 -0
  36. package/dist/cli/commands/stop.js.map +1 -0
  37. package/dist/cli/commands/token.d.ts +3 -0
  38. package/dist/cli/commands/token.d.ts.map +1 -0
  39. package/dist/cli/commands/token.js +32 -0
  40. package/dist/cli/commands/token.js.map +1 -0
  41. package/dist/cli/commands/trust-ca.d.ts +3 -0
  42. package/dist/cli/commands/trust-ca.d.ts.map +1 -0
  43. package/dist/cli/commands/trust-ca.js +44 -0
  44. package/dist/cli/commands/trust-ca.js.map +1 -0
  45. package/dist/cli/commands/wrap.d.ts +3 -0
  46. package/dist/cli/commands/wrap.d.ts.map +1 -0
  47. package/dist/cli/commands/wrap.js +70 -0
  48. package/dist/cli/commands/wrap.js.map +1 -0
  49. package/dist/cli/daemon.d.ts +11 -0
  50. package/dist/cli/daemon.d.ts.map +1 -0
  51. package/dist/cli/daemon.js +82 -0
  52. package/dist/cli/daemon.js.map +1 -0
  53. package/dist/cli/index.d.ts +3 -0
  54. package/dist/cli/index.d.ts.map +1 -0
  55. package/dist/cli/index.js +35 -0
  56. package/dist/cli/index.js.map +1 -0
  57. package/dist/config/index.d.ts +3 -0
  58. package/dist/config/index.d.ts.map +1 -0
  59. package/dist/config/index.js +60 -0
  60. package/dist/config/index.js.map +1 -0
  61. package/dist/config/manager.d.ts +12 -0
  62. package/dist/config/manager.d.ts.map +1 -0
  63. package/dist/config/manager.js +73 -0
  64. package/dist/config/manager.js.map +1 -0
  65. package/dist/config/paths.d.ts +10 -0
  66. package/dist/config/paths.d.ts.map +1 -0
  67. package/dist/config/paths.js +16 -0
  68. package/dist/config/paths.js.map +1 -0
  69. package/dist/config/schema.d.ts +85 -0
  70. package/dist/config/schema.d.ts.map +1 -0
  71. package/dist/config/schema.js +3 -0
  72. package/dist/config/schema.js.map +1 -0
  73. package/dist/dashboard/api-routes.d.ts +6 -0
  74. package/dist/dashboard/api-routes.d.ts.map +1 -0
  75. package/dist/dashboard/api-routes.js +671 -0
  76. package/dist/dashboard/api-routes.js.map +1 -0
  77. package/dist/dashboard/api.d.ts +4 -0
  78. package/dist/dashboard/api.d.ts.map +1 -0
  79. package/dist/dashboard/api.js +25 -0
  80. package/dist/dashboard/api.js.map +1 -0
  81. package/dist/dashboard/page.d.ts +3 -0
  82. package/dist/dashboard/page.d.ts.map +1 -0
  83. package/dist/dashboard/page.js +1622 -0
  84. package/dist/dashboard/page.js.map +1 -0
  85. package/dist/dlp/actions.d.ts +13 -0
  86. package/dist/dlp/actions.d.ts.map +1 -0
  87. package/dist/dlp/actions.js +3 -0
  88. package/dist/dlp/actions.js.map +1 -0
  89. package/dist/dlp/ai-validator.d.ts +28 -0
  90. package/dist/dlp/ai-validator.d.ts.map +1 -0
  91. package/dist/dlp/ai-validator.js +214 -0
  92. package/dist/dlp/ai-validator.js.map +1 -0
  93. package/dist/dlp/engine.d.ts +34 -0
  94. package/dist/dlp/engine.d.ts.map +1 -0
  95. package/dist/dlp/engine.js +342 -0
  96. package/dist/dlp/engine.js.map +1 -0
  97. package/dist/dlp/entropy.d.ts +22 -0
  98. package/dist/dlp/entropy.d.ts.map +1 -0
  99. package/dist/dlp/entropy.js +43 -0
  100. package/dist/dlp/entropy.js.map +1 -0
  101. package/dist/dlp/message-cache.d.ts +45 -0
  102. package/dist/dlp/message-cache.d.ts.map +1 -0
  103. package/dist/dlp/message-cache.js +251 -0
  104. package/dist/dlp/message-cache.js.map +1 -0
  105. package/dist/dlp/patterns/context-aware.d.ts +4 -0
  106. package/dist/dlp/patterns/context-aware.d.ts.map +1 -0
  107. package/dist/dlp/patterns/context-aware.js +45 -0
  108. package/dist/dlp/patterns/context-aware.js.map +1 -0
  109. package/dist/dlp/patterns/high-confidence.d.ts +4 -0
  110. package/dist/dlp/patterns/high-confidence.d.ts.map +1 -0
  111. package/dist/dlp/patterns/high-confidence.js +140 -0
  112. package/dist/dlp/patterns/high-confidence.js.map +1 -0
  113. package/dist/dlp/patterns/prompt-injection.d.ts +4 -0
  114. package/dist/dlp/patterns/prompt-injection.d.ts.map +1 -0
  115. package/dist/dlp/patterns/prompt-injection.js +244 -0
  116. package/dist/dlp/patterns/prompt-injection.js.map +1 -0
  117. package/dist/dlp/patterns/validated.d.ts +4 -0
  118. package/dist/dlp/patterns/validated.d.ts.map +1 -0
  119. package/dist/dlp/patterns/validated.js +21 -0
  120. package/dist/dlp/patterns/validated.js.map +1 -0
  121. package/dist/dlp/remote-sync.d.ts +47 -0
  122. package/dist/dlp/remote-sync.d.ts.map +1 -0
  123. package/dist/dlp/remote-sync.js +252 -0
  124. package/dist/dlp/remote-sync.js.map +1 -0
  125. package/dist/dlp/semantics.d.ts +27 -0
  126. package/dist/dlp/semantics.d.ts.map +1 -0
  127. package/dist/dlp/semantics.js +93 -0
  128. package/dist/dlp/semantics.js.map +1 -0
  129. package/dist/dlp/structure.d.ts +25 -0
  130. package/dist/dlp/structure.d.ts.map +1 -0
  131. package/dist/dlp/structure.js +86 -0
  132. package/dist/dlp/structure.js.map +1 -0
  133. package/dist/dlp/validators.d.ts +6 -0
  134. package/dist/dlp/validators.d.ts.map +1 -0
  135. package/dist/dlp/validators.js +46 -0
  136. package/dist/dlp/validators.js.map +1 -0
  137. package/dist/index.d.ts +2 -0
  138. package/dist/index.d.ts.map +1 -0
  139. package/dist/index.js +200 -0
  140. package/dist/index.js.map +1 -0
  141. package/dist/license/verify.d.ts +18 -0
  142. package/dist/license/verify.d.ts.map +1 -0
  143. package/dist/license/verify.js +71 -0
  144. package/dist/license/verify.js.map +1 -0
  145. package/dist/metrics/collector.d.ts +11 -0
  146. package/dist/metrics/collector.d.ts.map +1 -0
  147. package/dist/metrics/collector.js +17 -0
  148. package/dist/metrics/collector.js.map +1 -0
  149. package/dist/metrics/dashboard.d.ts +6 -0
  150. package/dist/metrics/dashboard.d.ts.map +1 -0
  151. package/dist/metrics/dashboard.js +66 -0
  152. package/dist/metrics/dashboard.js.map +1 -0
  153. package/dist/metrics/pricing.d.ts +10 -0
  154. package/dist/metrics/pricing.d.ts.map +1 -0
  155. package/dist/metrics/pricing.js +62 -0
  156. package/dist/metrics/pricing.js.map +1 -0
  157. package/dist/optimizer/cache.d.ts +14 -0
  158. package/dist/optimizer/cache.d.ts.map +1 -0
  159. package/dist/optimizer/cache.js +58 -0
  160. package/dist/optimizer/cache.js.map +1 -0
  161. package/dist/optimizer/estimator.d.ts +6 -0
  162. package/dist/optimizer/estimator.d.ts.map +1 -0
  163. package/dist/optimizer/estimator.js +12 -0
  164. package/dist/optimizer/estimator.js.map +1 -0
  165. package/dist/optimizer/reorder.d.ts +9 -0
  166. package/dist/optimizer/reorder.d.ts.map +1 -0
  167. package/dist/optimizer/reorder.js +27 -0
  168. package/dist/optimizer/reorder.js.map +1 -0
  169. package/dist/optimizer/trimmer.d.ts +9 -0
  170. package/dist/optimizer/trimmer.d.ts.map +1 -0
  171. package/dist/optimizer/trimmer.js +47 -0
  172. package/dist/optimizer/trimmer.js.map +1 -0
  173. package/dist/plugin-api/index.d.ts +3 -0
  174. package/dist/plugin-api/index.d.ts.map +1 -0
  175. package/dist/plugin-api/index.js +6 -0
  176. package/dist/plugin-api/index.js.map +1 -0
  177. package/dist/plugin-api/types.d.ts +77 -0
  178. package/dist/plugin-api/types.d.ts.map +1 -0
  179. package/dist/plugin-api/types.js +6 -0
  180. package/dist/plugin-api/types.js.map +1 -0
  181. package/dist/plugins/adapter.d.ts +12 -0
  182. package/dist/plugins/adapter.d.ts.map +1 -0
  183. package/dist/plugins/adapter.js +116 -0
  184. package/dist/plugins/adapter.js.map +1 -0
  185. package/dist/plugins/builtin/audit-logger.d.ts +9 -0
  186. package/dist/plugins/builtin/audit-logger.d.ts.map +1 -0
  187. package/dist/plugins/builtin/audit-logger.js +53 -0
  188. package/dist/plugins/builtin/audit-logger.js.map +1 -0
  189. package/dist/plugins/builtin/dlp-scanner.d.ts +19 -0
  190. package/dist/plugins/builtin/dlp-scanner.d.ts.map +1 -0
  191. package/dist/plugins/builtin/dlp-scanner.js +284 -0
  192. package/dist/plugins/builtin/dlp-scanner.js.map +1 -0
  193. package/dist/plugins/builtin/metrics-collector.d.ts +4 -0
  194. package/dist/plugins/builtin/metrics-collector.d.ts.map +1 -0
  195. package/dist/plugins/builtin/metrics-collector.js +111 -0
  196. package/dist/plugins/builtin/metrics-collector.js.map +1 -0
  197. package/dist/plugins/builtin/token-optimizer.d.ts +10 -0
  198. package/dist/plugins/builtin/token-optimizer.d.ts.map +1 -0
  199. package/dist/plugins/builtin/token-optimizer.js +120 -0
  200. package/dist/plugins/builtin/token-optimizer.js.map +1 -0
  201. package/dist/plugins/builtin/tool-guard.d.ts +20 -0
  202. package/dist/plugins/builtin/tool-guard.d.ts.map +1 -0
  203. package/dist/plugins/builtin/tool-guard.js +259 -0
  204. package/dist/plugins/builtin/tool-guard.js.map +1 -0
  205. package/dist/plugins/context.d.ts +8 -0
  206. package/dist/plugins/context.d.ts.map +1 -0
  207. package/dist/plugins/context.js +33 -0
  208. package/dist/plugins/context.js.map +1 -0
  209. package/dist/plugins/event-bus.d.ts +9 -0
  210. package/dist/plugins/event-bus.d.ts.map +1 -0
  211. package/dist/plugins/event-bus.js +25 -0
  212. package/dist/plugins/event-bus.js.map +1 -0
  213. package/dist/plugins/index.d.ts +18 -0
  214. package/dist/plugins/index.d.ts.map +1 -0
  215. package/dist/plugins/index.js +148 -0
  216. package/dist/plugins/index.js.map +1 -0
  217. package/dist/plugins/loader.d.ts +14 -0
  218. package/dist/plugins/loader.d.ts.map +1 -0
  219. package/dist/plugins/loader.js +98 -0
  220. package/dist/plugins/loader.js.map +1 -0
  221. package/dist/plugins/types.d.ts +91 -0
  222. package/dist/plugins/types.d.ts.map +1 -0
  223. package/dist/plugins/types.js +3 -0
  224. package/dist/plugins/types.js.map +1 -0
  225. package/dist/proxy/certs.d.ts +10 -0
  226. package/dist/proxy/certs.d.ts.map +1 -0
  227. package/dist/proxy/certs.js +110 -0
  228. package/dist/proxy/certs.js.map +1 -0
  229. package/dist/proxy/connect.d.ts +11 -0
  230. package/dist/proxy/connect.d.ts.map +1 -0
  231. package/dist/proxy/connect.js +298 -0
  232. package/dist/proxy/connect.js.map +1 -0
  233. package/dist/proxy/forwarder.d.ts +14 -0
  234. package/dist/proxy/forwarder.d.ts.map +1 -0
  235. package/dist/proxy/forwarder.js +342 -0
  236. package/dist/proxy/forwarder.js.map +1 -0
  237. package/dist/proxy/passthrough.d.ts +4 -0
  238. package/dist/proxy/passthrough.d.ts.map +1 -0
  239. package/dist/proxy/passthrough.js +68 -0
  240. package/dist/proxy/passthrough.js.map +1 -0
  241. package/dist/proxy/providers/anthropic.d.ts +4 -0
  242. package/dist/proxy/providers/anthropic.d.ts.map +1 -0
  243. package/dist/proxy/providers/anthropic.js +46 -0
  244. package/dist/proxy/providers/anthropic.js.map +1 -0
  245. package/dist/proxy/providers/classify.d.ts +14 -0
  246. package/dist/proxy/providers/classify.d.ts.map +1 -0
  247. package/dist/proxy/providers/classify.js +37 -0
  248. package/dist/proxy/providers/classify.js.map +1 -0
  249. package/dist/proxy/providers/claude-web.d.ts +8 -0
  250. package/dist/proxy/providers/claude-web.d.ts.map +1 -0
  251. package/dist/proxy/providers/claude-web.js +50 -0
  252. package/dist/proxy/providers/claude-web.js.map +1 -0
  253. package/dist/proxy/providers/gemini.d.ts +4 -0
  254. package/dist/proxy/providers/gemini.d.ts.map +1 -0
  255. package/dist/proxy/providers/gemini.js +38 -0
  256. package/dist/proxy/providers/gemini.js.map +1 -0
  257. package/dist/proxy/providers/index.d.ts +27 -0
  258. package/dist/proxy/providers/index.d.ts.map +1 -0
  259. package/dist/proxy/providers/index.js +32 -0
  260. package/dist/proxy/providers/index.js.map +1 -0
  261. package/dist/proxy/providers/messaging.d.ts +2 -0
  262. package/dist/proxy/providers/messaging.d.ts.map +1 -0
  263. package/dist/proxy/providers/messaging.js +53 -0
  264. package/dist/proxy/providers/messaging.js.map +1 -0
  265. package/dist/proxy/providers/openai.d.ts +4 -0
  266. package/dist/proxy/providers/openai.d.ts.map +1 -0
  267. package/dist/proxy/providers/openai.js +38 -0
  268. package/dist/proxy/providers/openai.js.map +1 -0
  269. package/dist/proxy/providers/telegram.d.ts +8 -0
  270. package/dist/proxy/providers/telegram.d.ts.map +1 -0
  271. package/dist/proxy/providers/telegram.js +35 -0
  272. package/dist/proxy/providers/telegram.js.map +1 -0
  273. package/dist/proxy/router.d.ts +12 -0
  274. package/dist/proxy/router.d.ts.map +1 -0
  275. package/dist/proxy/router.js +26 -0
  276. package/dist/proxy/router.js.map +1 -0
  277. package/dist/proxy/safety.d.ts +13 -0
  278. package/dist/proxy/safety.d.ts.map +1 -0
  279. package/dist/proxy/safety.js +58 -0
  280. package/dist/proxy/safety.js.map +1 -0
  281. package/dist/proxy/server.d.ts +8 -0
  282. package/dist/proxy/server.d.ts.map +1 -0
  283. package/dist/proxy/server.js +126 -0
  284. package/dist/proxy/server.js.map +1 -0
  285. package/dist/proxy/streaming.d.ts +21 -0
  286. package/dist/proxy/streaming.d.ts.map +1 -0
  287. package/dist/proxy/streaming.js +70 -0
  288. package/dist/proxy/streaming.js.map +1 -0
  289. package/dist/storage/database.d.ts +6 -0
  290. package/dist/storage/database.d.ts.map +1 -0
  291. package/dist/storage/database.js +44 -0
  292. package/dist/storage/database.js.map +1 -0
  293. package/dist/storage/encryption.d.ts +11 -0
  294. package/dist/storage/encryption.d.ts.map +1 -0
  295. package/dist/storage/encryption.js +47 -0
  296. package/dist/storage/encryption.js.map +1 -0
  297. package/dist/storage/migrations.d.ts +3 -0
  298. package/dist/storage/migrations.d.ts.map +1 -0
  299. package/dist/storage/migrations.js +265 -0
  300. package/dist/storage/migrations.js.map +1 -0
  301. package/dist/storage/repositories/audit-log.d.ts +115 -0
  302. package/dist/storage/repositories/audit-log.d.ts.map +1 -0
  303. package/dist/storage/repositories/audit-log.js +586 -0
  304. package/dist/storage/repositories/audit-log.js.map +1 -0
  305. package/dist/storage/repositories/cache.d.ts +26 -0
  306. package/dist/storage/repositories/cache.d.ts.map +1 -0
  307. package/dist/storage/repositories/cache.js +44 -0
  308. package/dist/storage/repositories/cache.js.map +1 -0
  309. package/dist/storage/repositories/dlp-config-history.d.ts +17 -0
  310. package/dist/storage/repositories/dlp-config-history.d.ts.map +1 -0
  311. package/dist/storage/repositories/dlp-config-history.js +30 -0
  312. package/dist/storage/repositories/dlp-config-history.js.map +1 -0
  313. package/dist/storage/repositories/dlp-events.d.ts +35 -0
  314. package/dist/storage/repositories/dlp-events.d.ts.map +1 -0
  315. package/dist/storage/repositories/dlp-events.js +57 -0
  316. package/dist/storage/repositories/dlp-events.js.map +1 -0
  317. package/dist/storage/repositories/dlp-patterns.d.ts +70 -0
  318. package/dist/storage/repositories/dlp-patterns.d.ts.map +1 -0
  319. package/dist/storage/repositories/dlp-patterns.js +187 -0
  320. package/dist/storage/repositories/dlp-patterns.js.map +1 -0
  321. package/dist/storage/repositories/optimizer-events.d.ts +28 -0
  322. package/dist/storage/repositories/optimizer-events.d.ts.map +1 -0
  323. package/dist/storage/repositories/optimizer-events.js +49 -0
  324. package/dist/storage/repositories/optimizer-events.js.map +1 -0
  325. package/dist/storage/repositories/plugin-events.d.ts +34 -0
  326. package/dist/storage/repositories/plugin-events.d.ts.map +1 -0
  327. package/dist/storage/repositories/plugin-events.js +64 -0
  328. package/dist/storage/repositories/plugin-events.js.map +1 -0
  329. package/dist/storage/repositories/requests.d.ts +68 -0
  330. package/dist/storage/repositories/requests.d.ts.map +1 -0
  331. package/dist/storage/repositories/requests.js +113 -0
  332. package/dist/storage/repositories/requests.js.map +1 -0
  333. package/dist/storage/repositories/sessions.d.ts +23 -0
  334. package/dist/storage/repositories/sessions.d.ts.map +1 -0
  335. package/dist/storage/repositories/sessions.js +42 -0
  336. package/dist/storage/repositories/sessions.js.map +1 -0
  337. package/dist/storage/repositories/tool-calls.d.ts +49 -0
  338. package/dist/storage/repositories/tool-calls.d.ts.map +1 -0
  339. package/dist/storage/repositories/tool-calls.js +61 -0
  340. package/dist/storage/repositories/tool-calls.js.map +1 -0
  341. package/dist/storage/repositories/tool-guard-rules.d.ts +50 -0
  342. package/dist/storage/repositories/tool-guard-rules.d.ts.map +1 -0
  343. package/dist/storage/repositories/tool-guard-rules.js +120 -0
  344. package/dist/storage/repositories/tool-guard-rules.js.map +1 -0
  345. package/dist/tool-guard/alert.d.ts +30 -0
  346. package/dist/tool-guard/alert.d.ts.map +1 -0
  347. package/dist/tool-guard/alert.js +113 -0
  348. package/dist/tool-guard/alert.js.map +1 -0
  349. package/dist/tool-guard/extractor.d.ts +10 -0
  350. package/dist/tool-guard/extractor.d.ts.map +1 -0
  351. package/dist/tool-guard/extractor.js +309 -0
  352. package/dist/tool-guard/extractor.js.map +1 -0
  353. package/dist/tool-guard/rules.d.ts +18 -0
  354. package/dist/tool-guard/rules.d.ts.map +1 -0
  355. package/dist/tool-guard/rules.js +255 -0
  356. package/dist/tool-guard/rules.js.map +1 -0
  357. package/dist/tool-guard/streaming-guard.d.ts +57 -0
  358. package/dist/tool-guard/streaming-guard.d.ts.map +1 -0
  359. package/dist/tool-guard/streaming-guard.js +389 -0
  360. package/dist/tool-guard/streaming-guard.js.map +1 -0
  361. package/dist/utils/hash.d.ts +2 -0
  362. package/dist/utils/hash.d.ts.map +1 -0
  363. package/dist/utils/hash.js +8 -0
  364. package/dist/utils/hash.js.map +1 -0
  365. package/dist/utils/logger.d.ts +11 -0
  366. package/dist/utils/logger.d.ts.map +1 -0
  367. package/dist/utils/logger.js +54 -0
  368. package/dist/utils/logger.js.map +1 -0
  369. package/dist/utils/timeout.d.ts +5 -0
  370. package/dist/utils/timeout.d.ts.map +1 -0
  371. package/dist/utils/timeout.js +26 -0
  372. package/dist/utils/timeout.js.map +1 -0
  373. package/dist/version.d.ts +5 -0
  374. package/dist/version.d.ts.map +1 -0
  375. package/dist/version.js +23 -0
  376. package/dist/version.js.map +1 -0
  377. package/package.json +67 -0
@@ -0,0 +1,30 @@
1
+ import type { RuleMatch } from './rules.js';
2
+ export interface AlertConfig {
3
+ /** Minimum severity to trigger alerts: 'critical' | 'high' | 'medium' | 'low' */
4
+ minSeverity: string;
5
+ /** macOS Notification Center */
6
+ desktop: boolean;
7
+ /** Webhook URL for POST alerts (Slack, Discord, etc.) */
8
+ webhookUrl: string;
9
+ }
10
+ export declare function shouldAlert(severity: string, minSeverity: string): boolean;
11
+ export interface AlertPayload {
12
+ toolName: string;
13
+ ruleName: string;
14
+ ruleId: string;
15
+ severity: string;
16
+ category: string;
17
+ matchedText: string;
18
+ requestId: string;
19
+ sessionId?: string;
20
+ timestamp: string;
21
+ }
22
+ export interface AlertEntry extends AlertPayload {
23
+ id: string;
24
+ acknowledged: boolean;
25
+ }
26
+ export declare function getRecentAlerts(): AlertEntry[];
27
+ export declare function getUnacknowledgedCount(): number;
28
+ export declare function acknowledgeAlerts(): void;
29
+ export declare function dispatchAlert(config: AlertConfig, toolName: string, ruleMatch: RuleMatch, requestId: string, sessionId?: string): void;
30
+ //# sourceMappingURL=alert.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../src/tool-guard/alert.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAI5C,MAAM,WAAW,WAAW;IAC1B,iFAAiF;IACjF,WAAW,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,yDAAyD;IACzD,UAAU,EAAE,MAAM,CAAC;CACpB;AASD,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAM1E;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;CACnB;AA6DD,MAAM,WAAW,UAAW,SAAQ,YAAY;IAC9C,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE,OAAO,CAAC;CACvB;AAKD,wBAAgB,eAAe,IAAI,UAAU,EAAE,CAE9C;AAED,wBAAgB,sBAAsB,IAAI,MAAM,CAE/C;AAED,wBAAgB,iBAAiB,IAAI,IAAI,CAExC;AAID,wBAAgB,aAAa,CAC3B,MAAM,EAAE,WAAW,EACnB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,MAAM,EACjB,SAAS,CAAC,EAAE,MAAM,GACjB,IAAI,CA4BN"}
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.shouldAlert = shouldAlert;
4
+ exports.getRecentAlerts = getRecentAlerts;
5
+ exports.getUnacknowledgedCount = getUnacknowledgedCount;
6
+ exports.acknowledgeAlerts = acknowledgeAlerts;
7
+ exports.dispatchAlert = dispatchAlert;
8
+ const node_child_process_1 = require("node:child_process");
9
+ const node_os_1 = require("node:os");
10
+ const logger_js_1 = require("../utils/logger.js");
11
+ const log = (0, logger_js_1.createLogger)('tool-guard-alert');
12
+ const SEVERITY_RANK = {
13
+ critical: 4,
14
+ high: 3,
15
+ medium: 2,
16
+ low: 1,
17
+ };
18
+ function shouldAlert(severity, minSeverity) {
19
+ const minRank = SEVERITY_RANK[minSeverity];
20
+ // Unknown minSeverity (empty string, 'none', undefined coerced to string, etc.) →
21
+ // treat as "never block" rather than defaulting to rank 0 which would match everything.
22
+ if (minRank === undefined)
23
+ return false;
24
+ return (SEVERITY_RANK[severity] ?? 0) >= minRank;
25
+ }
26
+ function buildPayload(toolName, ruleMatch, requestId, sessionId) {
27
+ return {
28
+ toolName,
29
+ ruleName: ruleMatch.rule.name,
30
+ ruleId: ruleMatch.rule.id,
31
+ severity: ruleMatch.rule.severity,
32
+ category: ruleMatch.rule.category,
33
+ matchedText: ruleMatch.matchedText,
34
+ requestId,
35
+ sessionId,
36
+ timestamp: new Date().toISOString(),
37
+ };
38
+ }
39
+ // ── Desktop notification (macOS) ──
40
+ function sendDesktopNotification(payload) {
41
+ if ((0, node_os_1.platform)() !== 'darwin')
42
+ return;
43
+ const title = `Bastion: ${payload.severity.toUpperCase()} tool call`;
44
+ const message = `${payload.toolName}: ${payload.ruleName}\\n${payload.matchedText.slice(0, 100)}`;
45
+ (0, node_child_process_1.execFile)('osascript', [
46
+ '-e',
47
+ `display notification "${message}" with title "${title}" sound name "Purr"`,
48
+ ], (err) => {
49
+ if (err)
50
+ log.debug('Desktop notification failed', { error: err.message });
51
+ });
52
+ }
53
+ // ── Webhook ──
54
+ async function sendWebhook(url, payload) {
55
+ try {
56
+ const body = JSON.stringify({
57
+ text: `[Bastion Tool Guard] **${payload.severity.toUpperCase()}**: \`${payload.toolName}\` — ${payload.ruleName}\nMatched: \`${payload.matchedText.slice(0, 200)}\`\nRequest: ${payload.requestId}`,
58
+ ...payload,
59
+ });
60
+ const res = await fetch(url, {
61
+ method: 'POST',
62
+ headers: { 'content-type': 'application/json' },
63
+ body,
64
+ signal: AbortSignal.timeout(5000),
65
+ });
66
+ if (!res.ok) {
67
+ log.debug('Webhook response not OK', { status: res.status });
68
+ }
69
+ }
70
+ catch (err) {
71
+ log.debug('Webhook send failed', { error: err.message });
72
+ }
73
+ }
74
+ const recentAlerts = [];
75
+ const MAX_ALERTS = 100;
76
+ function getRecentAlerts() {
77
+ return recentAlerts;
78
+ }
79
+ function getUnacknowledgedCount() {
80
+ return recentAlerts.filter(a => !a.acknowledged).length;
81
+ }
82
+ function acknowledgeAlerts() {
83
+ for (const a of recentAlerts)
84
+ a.acknowledged = true;
85
+ }
86
+ // ── Main dispatch ──
87
+ function dispatchAlert(config, toolName, ruleMatch, requestId, sessionId) {
88
+ if (!shouldAlert(ruleMatch.rule.severity, config.minSeverity))
89
+ return;
90
+ const payload = buildPayload(toolName, ruleMatch, requestId, sessionId);
91
+ // Always add to in-memory queue
92
+ recentAlerts.unshift({
93
+ ...payload,
94
+ id: crypto.randomUUID(),
95
+ acknowledged: false,
96
+ });
97
+ if (recentAlerts.length > MAX_ALERTS)
98
+ recentAlerts.length = MAX_ALERTS;
99
+ // Desktop notification
100
+ if (config.desktop) {
101
+ sendDesktopNotification(payload);
102
+ }
103
+ // Webhook
104
+ if (config.webhookUrl) {
105
+ sendWebhook(config.webhookUrl, payload).catch(() => { });
106
+ }
107
+ log.info('Alert dispatched', {
108
+ severity: payload.severity,
109
+ toolName: payload.toolName,
110
+ rule: payload.ruleId,
111
+ });
112
+ }
113
+ //# sourceMappingURL=alert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert.js","sourceRoot":"","sources":["../../src/tool-guard/alert.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ export interface ExtractedToolCall {
2
+ toolName: string;
3
+ toolInput: Record<string, unknown> | string;
4
+ provider: 'anthropic' | 'openai' | 'gemini' | 'unknown';
5
+ }
6
+ export declare function extractToolCallsFromJSON(body: string): ExtractedToolCall[];
7
+ export declare function extractToolCallsFromSSE(body: string): ExtractedToolCall[];
8
+ export declare function extractToolCallsFromParsedEvents(events: Record<string, unknown>[]): ExtractedToolCall[];
9
+ export declare function extractToolCalls(body: string, isStreaming: boolean): ExtractedToolCall[];
10
+ //# sourceMappingURL=extractor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractor.d.ts","sourceRoot":"","sources":["../../src/tool-guard/extractor.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IAC5C,QAAQ,EAAE,WAAW,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;CACzD;AAkED,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,iBAAiB,EAAE,CA0B1E;AAwJD,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,GAAG,iBAAiB,EAAE,CAIzE;AA4BD,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,iBAAiB,EAAE,CAGvG;AAID,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,GAAG,iBAAiB,EAAE,CAKxF"}
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractToolCallsFromJSON = extractToolCallsFromJSON;
4
+ exports.extractToolCallsFromSSE = extractToolCallsFromSSE;
5
+ exports.extractToolCallsFromParsedEvents = extractToolCallsFromParsedEvents;
6
+ exports.extractToolCalls = extractToolCalls;
7
+ // ---------- Buffered JSON extraction ----------
8
+ function extractAnthropicJSON(body) {
9
+ const content = body.content;
10
+ if (!Array.isArray(content))
11
+ return [];
12
+ return content
13
+ .filter((b) => b?.type === 'tool_use')
14
+ .map((b) => ({
15
+ toolName: b.name ?? 'unknown',
16
+ toolInput: b.input ?? {},
17
+ provider: 'anthropic',
18
+ }));
19
+ }
20
+ function extractOpenAIJSON(body) {
21
+ const choices = body.choices;
22
+ if (!Array.isArray(choices))
23
+ return [];
24
+ const results = [];
25
+ for (const choice of choices) {
26
+ const msg = choice.message;
27
+ if (!msg)
28
+ continue;
29
+ const toolCalls = msg.tool_calls;
30
+ if (!Array.isArray(toolCalls))
31
+ continue;
32
+ for (const tc of toolCalls) {
33
+ const fn = tc.function;
34
+ if (!fn)
35
+ continue;
36
+ let input = {};
37
+ try {
38
+ input = JSON.parse(fn.arguments ?? '{}');
39
+ }
40
+ catch {
41
+ input = fn.arguments ?? '';
42
+ }
43
+ results.push({
44
+ toolName: fn.name ?? 'unknown',
45
+ toolInput: input,
46
+ provider: 'openai',
47
+ });
48
+ }
49
+ }
50
+ return results;
51
+ }
52
+ function extractGeminiJSON(body) {
53
+ const candidates = body.candidates;
54
+ if (!Array.isArray(candidates))
55
+ return [];
56
+ const results = [];
57
+ for (const candidate of candidates) {
58
+ const content = candidate.content;
59
+ if (!content)
60
+ continue;
61
+ const parts = content.parts;
62
+ if (!Array.isArray(parts))
63
+ continue;
64
+ for (const part of parts) {
65
+ const fc = part.functionCall;
66
+ if (!fc)
67
+ continue;
68
+ results.push({
69
+ toolName: fc.name ?? 'unknown',
70
+ toolInput: fc.args ?? {},
71
+ provider: 'gemini',
72
+ });
73
+ }
74
+ }
75
+ return results;
76
+ }
77
+ function extractToolCallsFromJSON(body) {
78
+ try {
79
+ const parsed = JSON.parse(body);
80
+ // Anthropic format: content[].type === 'tool_use'
81
+ if (Array.isArray(parsed.content)) {
82
+ const results = extractAnthropicJSON(parsed);
83
+ if (results.length > 0)
84
+ return results;
85
+ }
86
+ // OpenAI format: choices[].message.tool_calls[]
87
+ if (Array.isArray(parsed.choices)) {
88
+ const results = extractOpenAIJSON(parsed);
89
+ if (results.length > 0)
90
+ return results;
91
+ }
92
+ // Gemini format: candidates[].content.parts[].functionCall
93
+ if (Array.isArray(parsed.candidates)) {
94
+ const results = extractGeminiJSON(parsed);
95
+ if (results.length > 0)
96
+ return results;
97
+ }
98
+ return [];
99
+ }
100
+ catch {
101
+ return [];
102
+ }
103
+ }
104
+ // ---------- SSE extraction ----------
105
+ function parseSSEEvents(text) {
106
+ const events = [];
107
+ const lines = text.split('\n');
108
+ const curData = [];
109
+ for (const line of lines) {
110
+ if (line.startsWith('data: ')) {
111
+ curData.push(line.slice(6));
112
+ }
113
+ else if (line.trim() === '' && curData.length > 0) {
114
+ const raw = curData.join('\n');
115
+ curData.length = 0;
116
+ if (raw !== '[DONE]') {
117
+ try {
118
+ events.push(JSON.parse(raw));
119
+ }
120
+ catch { /* skip */ }
121
+ }
122
+ }
123
+ }
124
+ if (curData.length > 0) {
125
+ const raw = curData.join('\n');
126
+ if (raw !== '[DONE]') {
127
+ try {
128
+ events.push(JSON.parse(raw));
129
+ }
130
+ catch { /* skip */ }
131
+ }
132
+ }
133
+ return events;
134
+ }
135
+ function extractAnthropicSSE(events) {
136
+ const results = [];
137
+ let curToolName = '';
138
+ let curToolInput = '';
139
+ for (const d of events) {
140
+ if (d.type === 'content_block_start') {
141
+ const cb = d.content_block;
142
+ if (cb?.type === 'tool_use') {
143
+ curToolName = cb.name ?? '';
144
+ curToolInput = '';
145
+ }
146
+ }
147
+ if (d.type === 'content_block_delta') {
148
+ const delta = d.delta;
149
+ if (delta?.type === 'input_json_delta') {
150
+ curToolInput += delta.partial_json ?? '';
151
+ }
152
+ }
153
+ if (d.type === 'content_block_stop') {
154
+ if (curToolName) {
155
+ let input = curToolInput;
156
+ try {
157
+ input = JSON.parse(curToolInput);
158
+ }
159
+ catch { /* keep as string */ }
160
+ results.push({ toolName: curToolName, toolInput: input, provider: 'anthropic' });
161
+ curToolName = '';
162
+ curToolInput = '';
163
+ }
164
+ }
165
+ }
166
+ return results;
167
+ }
168
+ function extractOpenAISSE(events) {
169
+ // OpenAI streams tool calls as: choices[].delta.tool_calls[].function.{name,arguments}
170
+ // We need to accumulate name + arguments across chunks, keyed by tool call index
171
+ const toolMap = new Map();
172
+ for (const d of events) {
173
+ const choices = d.choices;
174
+ if (!Array.isArray(choices))
175
+ continue;
176
+ for (const choice of choices) {
177
+ const delta = choice.delta;
178
+ if (!delta)
179
+ continue;
180
+ const toolCalls = delta.tool_calls;
181
+ if (!Array.isArray(toolCalls))
182
+ continue;
183
+ for (const tc of toolCalls) {
184
+ const idx = tc.index ?? 0;
185
+ if (!toolMap.has(idx))
186
+ toolMap.set(idx, { name: '', args: '' });
187
+ const entry = toolMap.get(idx);
188
+ const fn = tc.function;
189
+ if (fn?.name)
190
+ entry.name += fn.name;
191
+ if (fn?.arguments)
192
+ entry.args += fn.arguments;
193
+ }
194
+ }
195
+ }
196
+ const results = [];
197
+ for (const [, entry] of toolMap) {
198
+ if (!entry.name)
199
+ continue;
200
+ let input = entry.args;
201
+ try {
202
+ input = JSON.parse(entry.args);
203
+ }
204
+ catch { /* keep as string */ }
205
+ results.push({ toolName: entry.name, toolInput: input, provider: 'openai' });
206
+ }
207
+ return results;
208
+ }
209
+ /**
210
+ * OpenAI Responses API SSE format (used by chatgpt.com/backend-api/codex/responses):
211
+ * response.output_item.added → item.type === 'function_call', item.name
212
+ * response.function_call_arguments.delta → delta (partial JSON)
213
+ * response.function_call_arguments.done → name, arguments (complete)
214
+ * response.output_item.done → item with complete function call
215
+ */
216
+ function extractOpenAIResponsesSSE(events) {
217
+ // Strategy: use .done events as ground truth (they have complete name + arguments)
218
+ const results = [];
219
+ for (const d of events) {
220
+ const eventType = d.type;
221
+ // response.function_call_arguments.done has complete data
222
+ if (eventType === 'response.function_call_arguments.done') {
223
+ const name = d.name;
224
+ const args = d.arguments;
225
+ if (name) {
226
+ let input = args ?? '';
227
+ try {
228
+ input = JSON.parse(args ?? '{}');
229
+ }
230
+ catch { /* keep as string */ }
231
+ results.push({ toolName: name, toolInput: input, provider: 'openai' });
232
+ }
233
+ continue;
234
+ }
235
+ // Fallback: response.output_item.done with type=function_call
236
+ if (eventType === 'response.output_item.done') {
237
+ const item = d.item;
238
+ if (item?.type === 'function_call') {
239
+ const name = item.name ?? '';
240
+ const args = item.arguments ?? '';
241
+ if (name) {
242
+ // Check if we already captured this via function_call_arguments.done
243
+ const alreadyCaptured = results.some(r => r.toolName === name);
244
+ if (!alreadyCaptured) {
245
+ let input = args;
246
+ try {
247
+ input = JSON.parse(args);
248
+ }
249
+ catch { /* keep as string */ }
250
+ results.push({ toolName: name, toolInput: input, provider: 'openai' });
251
+ }
252
+ }
253
+ }
254
+ }
255
+ }
256
+ return results;
257
+ }
258
+ function extractGeminiSSE(events) {
259
+ // Each Gemini SSE event has the same candidates[] structure as the JSON response
260
+ const results = [];
261
+ for (const d of events) {
262
+ const extracted = extractGeminiJSON(d);
263
+ results.push(...extracted);
264
+ }
265
+ return results;
266
+ }
267
+ function extractToolCallsFromSSE(body) {
268
+ const events = parseSSEEvents(body);
269
+ if (events.length === 0)
270
+ return [];
271
+ return extractToolCallsFromParsedEventsInternal(events);
272
+ }
273
+ // ---------- Pre-parsed events (skip text parsing) ----------
274
+ /** Shared detection logic for pre-parsed events */
275
+ function extractToolCallsFromParsedEventsInternal(events) {
276
+ // Anthropic: content_block_start / message_start
277
+ const hasAnthropicEvents = events.some(e => e.type === 'content_block_start' || e.type === 'message_start');
278
+ if (hasAnthropicEvents)
279
+ return extractAnthropicSSE(events);
280
+ // OpenAI Chat Completions: choices[]
281
+ const hasOpenAIEvents = events.some(e => Array.isArray(e.choices));
282
+ if (hasOpenAIEvents)
283
+ return extractOpenAISSE(events);
284
+ // OpenAI Responses API: response.output_item.added / response.function_call_arguments.*
285
+ const hasResponsesEvents = events.some(e => {
286
+ const t = e.type;
287
+ return t?.startsWith('response.');
288
+ });
289
+ if (hasResponsesEvents)
290
+ return extractOpenAIResponsesSSE(events);
291
+ // Gemini: candidates[]
292
+ const hasGeminiEvents = events.some(e => Array.isArray(e.candidates));
293
+ if (hasGeminiEvents)
294
+ return extractGeminiSSE(events);
295
+ return [];
296
+ }
297
+ function extractToolCallsFromParsedEvents(events) {
298
+ if (events.length === 0)
299
+ return [];
300
+ return extractToolCallsFromParsedEventsInternal(events);
301
+ }
302
+ // ---------- Auto-detect ----------
303
+ function extractToolCalls(body, isStreaming) {
304
+ if (isStreaming || body.includes('data: ')) {
305
+ return extractToolCallsFromSSE(body);
306
+ }
307
+ return extractToolCallsFromJSON(body);
308
+ }
309
+ //# sourceMappingURL=extractor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractor.js","sourceRoot":"","sources":["../../src/tool-guard/extractor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ export interface ToolGuardRule {
2
+ id: string;
3
+ name: string;
4
+ description: string;
5
+ severity: 'critical' | 'high' | 'medium' | 'low';
6
+ category: string;
7
+ match: {
8
+ toolName?: RegExp;
9
+ inputPattern?: RegExp;
10
+ };
11
+ }
12
+ export declare const BUILTIN_RULES: ToolGuardRule[];
13
+ export interface RuleMatch {
14
+ rule: ToolGuardRule;
15
+ matchedText: string;
16
+ }
17
+ export declare function matchRules(toolName: string, toolInput: Record<string, unknown> | string, rules?: ToolGuardRule[]): RuleMatch | null;
18
+ //# sourceMappingURL=rules.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rules.d.ts","sourceRoot":"","sources":["../../src/tool-guard/rules.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACjD,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE;QACL,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACH;AAeD,eAAO,MAAM,aAAa,EAAE,aAAa,EAqOxC,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,aAAa,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,UAAU,CACxB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,EAC3C,KAAK,GAAE,aAAa,EAAkB,GACrC,SAAS,GAAG,IAAI,CAiBlB"}