clawsec 0.0.1

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 (361) hide show
  1. package/README.md +560 -0
  2. package/dist/bin/clawsec.d.ts +7 -0
  3. package/dist/bin/clawsec.d.ts.map +1 -0
  4. package/dist/bin/clawsec.js +12 -0
  5. package/dist/bin/clawsec.js.map +1 -0
  6. package/dist/src/actions/block.d.ts +22 -0
  7. package/dist/src/actions/block.d.ts.map +1 -0
  8. package/dist/src/actions/block.js +83 -0
  9. package/dist/src/actions/block.js.map +1 -0
  10. package/dist/src/actions/confirm.d.ts +35 -0
  11. package/dist/src/actions/confirm.d.ts.map +1 -0
  12. package/dist/src/actions/confirm.js +156 -0
  13. package/dist/src/actions/confirm.js.map +1 -0
  14. package/dist/src/actions/executor.d.ts +64 -0
  15. package/dist/src/actions/executor.d.ts.map +1 -0
  16. package/dist/src/actions/executor.js +114 -0
  17. package/dist/src/actions/executor.js.map +1 -0
  18. package/dist/src/actions/index.d.ts +13 -0
  19. package/dist/src/actions/index.d.ts.map +1 -0
  20. package/dist/src/actions/index.js +15 -0
  21. package/dist/src/actions/index.js.map +1 -0
  22. package/dist/src/actions/log.d.ts +19 -0
  23. package/dist/src/actions/log.d.ts.map +1 -0
  24. package/dist/src/actions/log.js +63 -0
  25. package/dist/src/actions/log.js.map +1 -0
  26. package/dist/src/actions/types.d.ts +85 -0
  27. package/dist/src/actions/types.d.ts.map +1 -0
  28. package/dist/src/actions/types.js +78 -0
  29. package/dist/src/actions/types.js.map +1 -0
  30. package/dist/src/actions/warn.d.ts +22 -0
  31. package/dist/src/actions/warn.d.ts.map +1 -0
  32. package/dist/src/actions/warn.js +84 -0
  33. package/dist/src/actions/warn.js.map +1 -0
  34. package/dist/src/approval/agent-confirm.d.ts +104 -0
  35. package/dist/src/approval/agent-confirm.d.ts.map +1 -0
  36. package/dist/src/approval/agent-confirm.js +173 -0
  37. package/dist/src/approval/agent-confirm.js.map +1 -0
  38. package/dist/src/approval/index.d.ts +14 -0
  39. package/dist/src/approval/index.d.ts.map +1 -0
  40. package/dist/src/approval/index.js +9 -0
  41. package/dist/src/approval/index.js.map +1 -0
  42. package/dist/src/approval/native.d.ts +56 -0
  43. package/dist/src/approval/native.d.ts.map +1 -0
  44. package/dist/src/approval/native.js +196 -0
  45. package/dist/src/approval/native.js.map +1 -0
  46. package/dist/src/approval/store.d.ts +88 -0
  47. package/dist/src/approval/store.d.ts.map +1 -0
  48. package/dist/src/approval/store.js +192 -0
  49. package/dist/src/approval/store.js.map +1 -0
  50. package/dist/src/approval/types.d.ts +119 -0
  51. package/dist/src/approval/types.d.ts.map +1 -0
  52. package/dist/src/approval/types.js +6 -0
  53. package/dist/src/approval/types.js.map +1 -0
  54. package/dist/src/approval/webhook.d.ts +170 -0
  55. package/dist/src/approval/webhook.d.ts.map +1 -0
  56. package/dist/src/approval/webhook.js +362 -0
  57. package/dist/src/approval/webhook.js.map +1 -0
  58. package/dist/src/cli/commands/audit.d.ts +43 -0
  59. package/dist/src/cli/commands/audit.d.ts.map +1 -0
  60. package/dist/src/cli/commands/audit.js +115 -0
  61. package/dist/src/cli/commands/audit.js.map +1 -0
  62. package/dist/src/cli/commands/feedback.d.ts +27 -0
  63. package/dist/src/cli/commands/feedback.d.ts.map +1 -0
  64. package/dist/src/cli/commands/feedback.js +228 -0
  65. package/dist/src/cli/commands/feedback.js.map +1 -0
  66. package/dist/src/cli/commands/index.d.ts +11 -0
  67. package/dist/src/cli/commands/index.d.ts.map +1 -0
  68. package/dist/src/cli/commands/index.js +13 -0
  69. package/dist/src/cli/commands/index.js.map +1 -0
  70. package/dist/src/cli/commands/status.d.ts +20 -0
  71. package/dist/src/cli/commands/status.d.ts.map +1 -0
  72. package/dist/src/cli/commands/status.js +122 -0
  73. package/dist/src/cli/commands/status.js.map +1 -0
  74. package/dist/src/cli/commands/test.d.ts +23 -0
  75. package/dist/src/cli/commands/test.d.ts.map +1 -0
  76. package/dist/src/cli/commands/test.js +134 -0
  77. package/dist/src/cli/commands/test.js.map +1 -0
  78. package/dist/src/cli/commands/types.d.ts +81 -0
  79. package/dist/src/cli/commands/types.d.ts.map +1 -0
  80. package/dist/src/cli/commands/types.js +6 -0
  81. package/dist/src/cli/commands/types.js.map +1 -0
  82. package/dist/src/cli/index.d.ts +17 -0
  83. package/dist/src/cli/index.d.ts.map +1 -0
  84. package/dist/src/cli/index.js +267 -0
  85. package/dist/src/cli/index.js.map +1 -0
  86. package/dist/src/config/defaults.d.ts +20 -0
  87. package/dist/src/config/defaults.d.ts.map +1 -0
  88. package/dist/src/config/defaults.js +123 -0
  89. package/dist/src/config/defaults.js.map +1 -0
  90. package/dist/src/config/index.d.ts +8 -0
  91. package/dist/src/config/index.d.ts.map +1 -0
  92. package/dist/src/config/index.js +41 -0
  93. package/dist/src/config/index.js.map +1 -0
  94. package/dist/src/config/loader.d.ts +99 -0
  95. package/dist/src/config/loader.d.ts.map +1 -0
  96. package/dist/src/config/loader.js +242 -0
  97. package/dist/src/config/loader.js.map +1 -0
  98. package/dist/src/config/schema.d.ts +627 -0
  99. package/dist/src/config/schema.d.ts.map +1 -0
  100. package/dist/src/config/schema.js +585 -0
  101. package/dist/src/config/schema.js.map +1 -0
  102. package/dist/src/detectors/destructive/cloud-detector.d.ts +51 -0
  103. package/dist/src/detectors/destructive/cloud-detector.d.ts.map +1 -0
  104. package/dist/src/detectors/destructive/cloud-detector.js +556 -0
  105. package/dist/src/detectors/destructive/cloud-detector.js.map +1 -0
  106. package/dist/src/detectors/destructive/code-detector.d.ts +59 -0
  107. package/dist/src/detectors/destructive/code-detector.d.ts.map +1 -0
  108. package/dist/src/detectors/destructive/code-detector.js +558 -0
  109. package/dist/src/detectors/destructive/code-detector.js.map +1 -0
  110. package/dist/src/detectors/destructive/index.d.ts +54 -0
  111. package/dist/src/detectors/destructive/index.d.ts.map +1 -0
  112. package/dist/src/detectors/destructive/index.js +168 -0
  113. package/dist/src/detectors/destructive/index.js.map +1 -0
  114. package/dist/src/detectors/destructive/shell-detector.d.ts +43 -0
  115. package/dist/src/detectors/destructive/shell-detector.d.ts.map +1 -0
  116. package/dist/src/detectors/destructive/shell-detector.js +302 -0
  117. package/dist/src/detectors/destructive/shell-detector.js.map +1 -0
  118. package/dist/src/detectors/destructive/types.d.ts +143 -0
  119. package/dist/src/detectors/destructive/types.d.ts.map +1 -0
  120. package/dist/src/detectors/destructive/types.js +6 -0
  121. package/dist/src/detectors/destructive/types.js.map +1 -0
  122. package/dist/src/detectors/exfiltration/cloud-detector.d.ts +51 -0
  123. package/dist/src/detectors/exfiltration/cloud-detector.d.ts.map +1 -0
  124. package/dist/src/detectors/exfiltration/cloud-detector.js +427 -0
  125. package/dist/src/detectors/exfiltration/cloud-detector.js.map +1 -0
  126. package/dist/src/detectors/exfiltration/http-detector.d.ts +47 -0
  127. package/dist/src/detectors/exfiltration/http-detector.d.ts.map +1 -0
  128. package/dist/src/detectors/exfiltration/http-detector.js +429 -0
  129. package/dist/src/detectors/exfiltration/http-detector.js.map +1 -0
  130. package/dist/src/detectors/exfiltration/index.d.ts +44 -0
  131. package/dist/src/detectors/exfiltration/index.d.ts.map +1 -0
  132. package/dist/src/detectors/exfiltration/index.js +118 -0
  133. package/dist/src/detectors/exfiltration/index.js.map +1 -0
  134. package/dist/src/detectors/exfiltration/network-detector.d.ts +55 -0
  135. package/dist/src/detectors/exfiltration/network-detector.d.ts.map +1 -0
  136. package/dist/src/detectors/exfiltration/network-detector.js +504 -0
  137. package/dist/src/detectors/exfiltration/network-detector.js.map +1 -0
  138. package/dist/src/detectors/exfiltration/types.d.ts +139 -0
  139. package/dist/src/detectors/exfiltration/types.d.ts.map +1 -0
  140. package/dist/src/detectors/exfiltration/types.js +6 -0
  141. package/dist/src/detectors/exfiltration/types.js.map +1 -0
  142. package/dist/src/detectors/purchase/domain-detector.d.ts +44 -0
  143. package/dist/src/detectors/purchase/domain-detector.d.ts.map +1 -0
  144. package/dist/src/detectors/purchase/domain-detector.js +296 -0
  145. package/dist/src/detectors/purchase/domain-detector.js.map +1 -0
  146. package/dist/src/detectors/purchase/form-detector.d.ts +27 -0
  147. package/dist/src/detectors/purchase/form-detector.d.ts.map +1 -0
  148. package/dist/src/detectors/purchase/form-detector.js +344 -0
  149. package/dist/src/detectors/purchase/form-detector.js.map +1 -0
  150. package/dist/src/detectors/purchase/index.d.ts +65 -0
  151. package/dist/src/detectors/purchase/index.d.ts.map +1 -0
  152. package/dist/src/detectors/purchase/index.js +216 -0
  153. package/dist/src/detectors/purchase/index.js.map +1 -0
  154. package/dist/src/detectors/purchase/spend-tracker.d.ts +132 -0
  155. package/dist/src/detectors/purchase/spend-tracker.d.ts.map +1 -0
  156. package/dist/src/detectors/purchase/spend-tracker.js +313 -0
  157. package/dist/src/detectors/purchase/spend-tracker.js.map +1 -0
  158. package/dist/src/detectors/purchase/types.d.ts +139 -0
  159. package/dist/src/detectors/purchase/types.d.ts.map +1 -0
  160. package/dist/src/detectors/purchase/types.js +6 -0
  161. package/dist/src/detectors/purchase/types.js.map +1 -0
  162. package/dist/src/detectors/purchase/url-detector.d.ts +31 -0
  163. package/dist/src/detectors/purchase/url-detector.d.ts.map +1 -0
  164. package/dist/src/detectors/purchase/url-detector.js +292 -0
  165. package/dist/src/detectors/purchase/url-detector.js.map +1 -0
  166. package/dist/src/detectors/secrets/api-key-detector.d.ts +30 -0
  167. package/dist/src/detectors/secrets/api-key-detector.d.ts.map +1 -0
  168. package/dist/src/detectors/secrets/api-key-detector.js +297 -0
  169. package/dist/src/detectors/secrets/api-key-detector.js.map +1 -0
  170. package/dist/src/detectors/secrets/index.d.ts +43 -0
  171. package/dist/src/detectors/secrets/index.d.ts.map +1 -0
  172. package/dist/src/detectors/secrets/index.js +261 -0
  173. package/dist/src/detectors/secrets/index.js.map +1 -0
  174. package/dist/src/detectors/secrets/pii-detector.d.ts +54 -0
  175. package/dist/src/detectors/secrets/pii-detector.d.ts.map +1 -0
  176. package/dist/src/detectors/secrets/pii-detector.js +286 -0
  177. package/dist/src/detectors/secrets/pii-detector.js.map +1 -0
  178. package/dist/src/detectors/secrets/token-detector.d.ts +51 -0
  179. package/dist/src/detectors/secrets/token-detector.d.ts.map +1 -0
  180. package/dist/src/detectors/secrets/token-detector.js +233 -0
  181. package/dist/src/detectors/secrets/token-detector.js.map +1 -0
  182. package/dist/src/detectors/secrets/types.d.ts +157 -0
  183. package/dist/src/detectors/secrets/types.d.ts.map +1 -0
  184. package/dist/src/detectors/secrets/types.js +6 -0
  185. package/dist/src/detectors/secrets/types.js.map +1 -0
  186. package/dist/src/detectors/website/category-detector.d.ts +22 -0
  187. package/dist/src/detectors/website/category-detector.d.ts.map +1 -0
  188. package/dist/src/detectors/website/category-detector.js +162 -0
  189. package/dist/src/detectors/website/category-detector.js.map +1 -0
  190. package/dist/src/detectors/website/index.d.ts +53 -0
  191. package/dist/src/detectors/website/index.d.ts.map +1 -0
  192. package/dist/src/detectors/website/index.js +232 -0
  193. package/dist/src/detectors/website/index.js.map +1 -0
  194. package/dist/src/detectors/website/pattern-matcher.d.ts +33 -0
  195. package/dist/src/detectors/website/pattern-matcher.d.ts.map +1 -0
  196. package/dist/src/detectors/website/pattern-matcher.js +121 -0
  197. package/dist/src/detectors/website/pattern-matcher.js.map +1 -0
  198. package/dist/src/detectors/website/types.d.ts +105 -0
  199. package/dist/src/detectors/website/types.d.ts.map +1 -0
  200. package/dist/src/detectors/website/types.js +6 -0
  201. package/dist/src/detectors/website/types.js.map +1 -0
  202. package/dist/src/engine/analyzer.d.ts +87 -0
  203. package/dist/src/engine/analyzer.d.ts.map +1 -0
  204. package/dist/src/engine/analyzer.js +427 -0
  205. package/dist/src/engine/analyzer.js.map +1 -0
  206. package/dist/src/engine/cache.d.ts +80 -0
  207. package/dist/src/engine/cache.d.ts.map +1 -0
  208. package/dist/src/engine/cache.js +167 -0
  209. package/dist/src/engine/cache.js.map +1 -0
  210. package/dist/src/engine/index.d.ts +11 -0
  211. package/dist/src/engine/index.d.ts.map +1 -0
  212. package/dist/src/engine/index.js +11 -0
  213. package/dist/src/engine/index.js.map +1 -0
  214. package/dist/src/engine/llm-client.d.ts +210 -0
  215. package/dist/src/engine/llm-client.d.ts.map +1 -0
  216. package/dist/src/engine/llm-client.js +506 -0
  217. package/dist/src/engine/llm-client.js.map +1 -0
  218. package/dist/src/engine/types.d.ts +163 -0
  219. package/dist/src/engine/types.d.ts.map +1 -0
  220. package/dist/src/engine/types.js +21 -0
  221. package/dist/src/engine/types.js.map +1 -0
  222. package/dist/src/feedback/index.d.ts +9 -0
  223. package/dist/src/feedback/index.d.ts.map +1 -0
  224. package/dist/src/feedback/index.js +8 -0
  225. package/dist/src/feedback/index.js.map +1 -0
  226. package/dist/src/feedback/learner.d.ts +222 -0
  227. package/dist/src/feedback/learner.d.ts.map +1 -0
  228. package/dist/src/feedback/learner.js +401 -0
  229. package/dist/src/feedback/learner.js.map +1 -0
  230. package/dist/src/feedback/store.d.ts +113 -0
  231. package/dist/src/feedback/store.d.ts.map +1 -0
  232. package/dist/src/feedback/store.js +228 -0
  233. package/dist/src/feedback/store.js.map +1 -0
  234. package/dist/src/feedback/types.d.ts +126 -0
  235. package/dist/src/feedback/types.d.ts.map +1 -0
  236. package/dist/src/feedback/types.js +6 -0
  237. package/dist/src/feedback/types.js.map +1 -0
  238. package/dist/src/hooks/before-agent-start/handler.d.ts +37 -0
  239. package/dist/src/hooks/before-agent-start/handler.d.ts.map +1 -0
  240. package/dist/src/hooks/before-agent-start/handler.js +109 -0
  241. package/dist/src/hooks/before-agent-start/handler.js.map +1 -0
  242. package/dist/src/hooks/before-agent-start/index.d.ts +8 -0
  243. package/dist/src/hooks/before-agent-start/index.d.ts.map +1 -0
  244. package/dist/src/hooks/before-agent-start/index.js +7 -0
  245. package/dist/src/hooks/before-agent-start/index.js.map +1 -0
  246. package/dist/src/hooks/before-agent-start/prompts.d.ts +48 -0
  247. package/dist/src/hooks/before-agent-start/prompts.d.ts.map +1 -0
  248. package/dist/src/hooks/before-agent-start/prompts.js +103 -0
  249. package/dist/src/hooks/before-agent-start/prompts.js.map +1 -0
  250. package/dist/src/hooks/before-tool-call/handler.d.ts +42 -0
  251. package/dist/src/hooks/before-tool-call/handler.d.ts.map +1 -0
  252. package/dist/src/hooks/before-tool-call/handler.js +226 -0
  253. package/dist/src/hooks/before-tool-call/handler.js.map +1 -0
  254. package/dist/src/hooks/before-tool-call/index.d.ts +7 -0
  255. package/dist/src/hooks/before-tool-call/index.d.ts.map +1 -0
  256. package/dist/src/hooks/before-tool-call/index.js +6 -0
  257. package/dist/src/hooks/before-tool-call/index.js.map +1 -0
  258. package/dist/src/hooks/tool-result-persist/filter.d.ts +72 -0
  259. package/dist/src/hooks/tool-result-persist/filter.d.ts.map +1 -0
  260. package/dist/src/hooks/tool-result-persist/filter.js +305 -0
  261. package/dist/src/hooks/tool-result-persist/filter.js.map +1 -0
  262. package/dist/src/hooks/tool-result-persist/handler.d.ts +49 -0
  263. package/dist/src/hooks/tool-result-persist/handler.d.ts.map +1 -0
  264. package/dist/src/hooks/tool-result-persist/handler.js +217 -0
  265. package/dist/src/hooks/tool-result-persist/handler.js.map +1 -0
  266. package/dist/src/hooks/tool-result-persist/index.d.ts +11 -0
  267. package/dist/src/hooks/tool-result-persist/index.d.ts.map +1 -0
  268. package/dist/src/hooks/tool-result-persist/index.js +11 -0
  269. package/dist/src/hooks/tool-result-persist/index.js.map +1 -0
  270. package/dist/src/index.d.ts +256 -0
  271. package/dist/src/index.d.ts.map +1 -0
  272. package/dist/src/index.js +222 -0
  273. package/dist/src/index.js.map +1 -0
  274. package/dist/src/notifications/discord.d.ts +10 -0
  275. package/dist/src/notifications/discord.d.ts.map +1 -0
  276. package/dist/src/notifications/discord.js +218 -0
  277. package/dist/src/notifications/discord.js.map +1 -0
  278. package/dist/src/notifications/index.d.ts +37 -0
  279. package/dist/src/notifications/index.d.ts.map +1 -0
  280. package/dist/src/notifications/index.js +68 -0
  281. package/dist/src/notifications/index.js.map +1 -0
  282. package/dist/src/notifications/slack.d.ts +10 -0
  283. package/dist/src/notifications/slack.d.ts.map +1 -0
  284. package/dist/src/notifications/slack.js +218 -0
  285. package/dist/src/notifications/slack.js.map +1 -0
  286. package/dist/src/notifications/telegram.d.ts +10 -0
  287. package/dist/src/notifications/telegram.d.ts.map +1 -0
  288. package/dist/src/notifications/telegram.js +242 -0
  289. package/dist/src/notifications/telegram.js.map +1 -0
  290. package/dist/src/notifications/types.d.ts +119 -0
  291. package/dist/src/notifications/types.d.ts.map +1 -0
  292. package/dist/src/notifications/types.js +6 -0
  293. package/dist/src/notifications/types.js.map +1 -0
  294. package/dist/src/proxy/index.d.ts +8 -0
  295. package/dist/src/proxy/index.d.ts.map +1 -0
  296. package/dist/src/proxy/index.js +9 -0
  297. package/dist/src/proxy/index.js.map +1 -0
  298. package/dist/src/proxy/middleware.d.ts +55 -0
  299. package/dist/src/proxy/middleware.d.ts.map +1 -0
  300. package/dist/src/proxy/middleware.js +215 -0
  301. package/dist/src/proxy/middleware.js.map +1 -0
  302. package/dist/src/proxy/server.d.ts +57 -0
  303. package/dist/src/proxy/server.d.ts.map +1 -0
  304. package/dist/src/proxy/server.js +298 -0
  305. package/dist/src/proxy/server.js.map +1 -0
  306. package/dist/src/proxy/types.d.ts +136 -0
  307. package/dist/src/proxy/types.d.ts.map +1 -0
  308. package/dist/src/proxy/types.js +6 -0
  309. package/dist/src/proxy/types.js.map +1 -0
  310. package/dist/src/sanitization/index.d.ts +10 -0
  311. package/dist/src/sanitization/index.d.ts.map +1 -0
  312. package/dist/src/sanitization/index.js +9 -0
  313. package/dist/src/sanitization/index.js.map +1 -0
  314. package/dist/src/sanitization/patterns.d.ts +51 -0
  315. package/dist/src/sanitization/patterns.d.ts.map +1 -0
  316. package/dist/src/sanitization/patterns.js +266 -0
  317. package/dist/src/sanitization/patterns.js.map +1 -0
  318. package/dist/src/sanitization/scanner.d.ts +29 -0
  319. package/dist/src/sanitization/scanner.d.ts.map +1 -0
  320. package/dist/src/sanitization/scanner.js +328 -0
  321. package/dist/src/sanitization/scanner.js.map +1 -0
  322. package/dist/src/sanitization/types.d.ts +57 -0
  323. package/dist/src/sanitization/types.d.ts.map +1 -0
  324. package/dist/src/sanitization/types.js +5 -0
  325. package/dist/src/sanitization/types.js.map +1 -0
  326. package/openclaw.plugin.json +114 -0
  327. package/package.json +63 -0
  328. package/rules/builtin/README.md +139 -0
  329. package/rules/builtin/ai-services.yaml +70 -0
  330. package/rules/builtin/api-keys.yaml +64 -0
  331. package/rules/builtin/authentication.yaml +56 -0
  332. package/rules/builtin/aws-security.yaml +57 -0
  333. package/rules/builtin/azure-security.yaml +58 -0
  334. package/rules/builtin/cicd-security.yaml +64 -0
  335. package/rules/builtin/cloud-storage.yaml +64 -0
  336. package/rules/builtin/container-registry.yaml +55 -0
  337. package/rules/builtin/crypto-wallets.yaml +71 -0
  338. package/rules/builtin/database-nosql.yaml +58 -0
  339. package/rules/builtin/database-sql.yaml +62 -0
  340. package/rules/builtin/development-env.yaml +67 -0
  341. package/rules/builtin/docker.yaml +57 -0
  342. package/rules/builtin/filesystem.yaml +71 -0
  343. package/rules/builtin/financial-pci.yaml +61 -0
  344. package/rules/builtin/gcp-security.yaml +57 -0
  345. package/rules/builtin/git-operations.yaml +68 -0
  346. package/rules/builtin/healthcare-hipaa.yaml +64 -0
  347. package/rules/builtin/kubernetes.yaml +60 -0
  348. package/rules/builtin/messaging-services.yaml +53 -0
  349. package/rules/builtin/minimal.yaml +47 -0
  350. package/rules/builtin/mobile-development.yaml +61 -0
  351. package/rules/builtin/monitoring.yaml +63 -0
  352. package/rules/builtin/network-security.yaml +57 -0
  353. package/rules/builtin/package-managers.yaml +74 -0
  354. package/rules/builtin/payment-processing.yaml +66 -0
  355. package/rules/builtin/pii-protection.yaml +48 -0
  356. package/rules/builtin/production-strict.yaml +55 -0
  357. package/rules/builtin/secrets-management.yaml +63 -0
  358. package/rules/builtin/serverless.yaml +74 -0
  359. package/rules/builtin/ssh-security.yaml +66 -0
  360. package/rules/builtin/terraform.yaml +51 -0
  361. package/rules/builtin/web-security.yaml +62 -0
@@ -0,0 +1,215 @@
1
+ /**
2
+ * Proxy Middleware
3
+ * Request processing middleware that bridges HTTP requests to the detection engine
4
+ */
5
+ /** Default approval timeout in seconds */
6
+ const DEFAULT_APPROVAL_TIMEOUT_SECONDS = 300;
7
+ /**
8
+ * Generate a unique approval ID
9
+ */
10
+ function generateApprovalId() {
11
+ const timestamp = Date.now().toString(36);
12
+ const random = Math.random().toString(36).slice(2, 10);
13
+ return `approval-${timestamp}-${random}`;
14
+ }
15
+ /**
16
+ * Convert ProxyRequest to ToolCallContext for analysis
17
+ */
18
+ export function toToolCallContext(request) {
19
+ const context = {
20
+ toolName: request.toolName,
21
+ toolInput: request.toolInput,
22
+ };
23
+ // Extract URL from common tool input patterns
24
+ if (typeof request.toolInput.url === 'string') {
25
+ context.url = request.toolInput.url;
26
+ }
27
+ return context;
28
+ }
29
+ /**
30
+ * Convert AnalysisResult to ProxyResponse
31
+ */
32
+ export function toProxyResponse(result, pendingApprovalId, approvalTimeoutSeconds) {
33
+ const response = {
34
+ allowed: result.action === 'allow' || result.action === 'log',
35
+ analysis: {
36
+ action: result.action,
37
+ detections: result.detections,
38
+ cached: result.cached,
39
+ durationMs: result.durationMs,
40
+ },
41
+ };
42
+ // Add message based on action
43
+ switch (result.action) {
44
+ case 'allow':
45
+ response.message = 'Request allowed';
46
+ break;
47
+ case 'block':
48
+ response.message = result.primaryDetection
49
+ ? `Request blocked: ${result.primaryDetection.reason}`
50
+ : 'Request blocked';
51
+ break;
52
+ case 'confirm':
53
+ response.message = result.primaryDetection
54
+ ? `Approval required: ${result.primaryDetection.reason}`
55
+ : 'Approval required';
56
+ if (pendingApprovalId) {
57
+ response.pendingApproval = {
58
+ id: pendingApprovalId,
59
+ timeout: approvalTimeoutSeconds ?? DEFAULT_APPROVAL_TIMEOUT_SECONDS,
60
+ };
61
+ }
62
+ break;
63
+ case 'warn':
64
+ response.message = result.primaryDetection
65
+ ? `Warning: ${result.primaryDetection.reason}`
66
+ : 'Warning';
67
+ response.allowed = true;
68
+ break;
69
+ case 'log':
70
+ response.message = 'Request logged and allowed';
71
+ break;
72
+ }
73
+ return response;
74
+ }
75
+ /**
76
+ * Middleware for processing analysis requests
77
+ */
78
+ export class AnalysisMiddleware {
79
+ analyzer;
80
+ approvalStore;
81
+ approvalTimeoutSeconds;
82
+ constructor(analyzer, approvalStore, approvalTimeoutSeconds = DEFAULT_APPROVAL_TIMEOUT_SECONDS) {
83
+ this.analyzer = analyzer;
84
+ this.approvalStore = approvalStore;
85
+ this.approvalTimeoutSeconds = approvalTimeoutSeconds;
86
+ }
87
+ /**
88
+ * Process an analysis request
89
+ */
90
+ async analyze(request) {
91
+ // Validate and cast request
92
+ const toolName = request.toolName;
93
+ if (!toolName || typeof toolName !== 'string') {
94
+ throw new ValidationError('toolName is required and must be a string');
95
+ }
96
+ const toolInput = request.toolInput;
97
+ if (!toolInput || typeof toolInput !== 'object' || toolInput === null) {
98
+ throw new ValidationError('toolInput is required and must be an object');
99
+ }
100
+ // Build typed request
101
+ const typedRequest = {
102
+ toolName,
103
+ toolInput: toolInput,
104
+ sessionId: typeof request.sessionId === 'string' ? request.sessionId : undefined,
105
+ userId: typeof request.userId === 'string' ? request.userId : undefined,
106
+ };
107
+ // Convert to ToolCallContext
108
+ const context = toToolCallContext(typedRequest);
109
+ // Run analysis
110
+ const result = await this.analyzer.analyze(context);
111
+ // If action is 'confirm', create a pending approval
112
+ let pendingApprovalId;
113
+ if (result.action === 'confirm' && result.primaryDetection) {
114
+ pendingApprovalId = generateApprovalId();
115
+ const now = Date.now();
116
+ const expiresAt = now + this.approvalTimeoutSeconds * 1000;
117
+ const approvalInput = {
118
+ id: pendingApprovalId,
119
+ createdAt: now,
120
+ expiresAt,
121
+ detection: result.primaryDetection,
122
+ toolCall: context,
123
+ };
124
+ this.approvalStore.add(approvalInput);
125
+ }
126
+ return toProxyResponse(result, pendingApprovalId, this.approvalTimeoutSeconds);
127
+ }
128
+ /**
129
+ * Approve a pending request
130
+ */
131
+ approve(id, approvedBy) {
132
+ const record = this.approvalStore.get(id);
133
+ if (!record) {
134
+ return {
135
+ success: false,
136
+ message: `Approval not found: ${id}`,
137
+ };
138
+ }
139
+ if (record.status !== 'pending') {
140
+ return {
141
+ success: false,
142
+ message: `Approval already ${record.status}: ${id}`,
143
+ };
144
+ }
145
+ const success = this.approvalStore.approve(id, approvedBy);
146
+ return {
147
+ success,
148
+ message: success
149
+ ? `Approved: ${id}`
150
+ : `Failed to approve: ${id}`,
151
+ };
152
+ }
153
+ /**
154
+ * Deny a pending request
155
+ */
156
+ deny(id) {
157
+ const record = this.approvalStore.get(id);
158
+ if (!record) {
159
+ return {
160
+ success: false,
161
+ message: `Approval not found: ${id}`,
162
+ };
163
+ }
164
+ if (record.status !== 'pending') {
165
+ return {
166
+ success: false,
167
+ message: `Approval already ${record.status}: ${id}`,
168
+ };
169
+ }
170
+ const success = this.approvalStore.deny(id);
171
+ return {
172
+ success,
173
+ message: success
174
+ ? `Denied: ${id}`
175
+ : `Failed to deny: ${id}`,
176
+ };
177
+ }
178
+ /**
179
+ * Get server status
180
+ */
181
+ getStatus(config, actualPort) {
182
+ const pendingApprovals = this.approvalStore.getPending();
183
+ return {
184
+ active: true,
185
+ config: {
186
+ port: actualPort ?? config.port,
187
+ host: config.host ?? '127.0.0.1',
188
+ enabled: config.clawsecConfig.global?.enabled ?? true,
189
+ },
190
+ pendingApprovals: pendingApprovals.length,
191
+ };
192
+ }
193
+ /**
194
+ * Get health status
195
+ */
196
+ getHealth() {
197
+ return { status: 'ok' };
198
+ }
199
+ }
200
+ /**
201
+ * Custom error for validation failures
202
+ */
203
+ export class ValidationError extends Error {
204
+ constructor(message) {
205
+ super(message);
206
+ this.name = 'ValidationError';
207
+ }
208
+ }
209
+ /**
210
+ * Create an analysis middleware instance
211
+ */
212
+ export function createAnalysisMiddleware(analyzer, approvalStore, approvalTimeoutSeconds) {
213
+ return new AnalysisMiddleware(analyzer, approvalStore, approvalTimeoutSeconds);
214
+ }
215
+ //# sourceMappingURL=middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/proxy/middleware.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ /**
2
+ * Standalone HTTP Proxy Server
3
+ * HTTP server that intercepts and analyzes tool calls without OpenClaw integration
4
+ */
5
+ import type { ProxyConfig, ProxyServer } from './types.js';
6
+ /**
7
+ * HTTP Proxy Server Implementation
8
+ */
9
+ export declare class HttpProxyServer implements ProxyServer {
10
+ private readonly config;
11
+ private readonly middleware;
12
+ private readonly approvalStore;
13
+ private server;
14
+ private actualPort;
15
+ constructor(config: ProxyConfig);
16
+ /**
17
+ * Start the server
18
+ */
19
+ start(): Promise<void>;
20
+ /**
21
+ * Stop the server
22
+ */
23
+ stop(): Promise<void>;
24
+ /**
25
+ * Get the port the server is listening on
26
+ */
27
+ getPort(): number;
28
+ /**
29
+ * Handle incoming HTTP request
30
+ */
31
+ private handleRequest;
32
+ /**
33
+ * Handle POST /analyze
34
+ */
35
+ private handleAnalyze;
36
+ /**
37
+ * Handle POST /approve/:id
38
+ */
39
+ private handleApprove;
40
+ /**
41
+ * Handle POST /deny/:id
42
+ */
43
+ private handleDeny;
44
+ /**
45
+ * Handle GET /status
46
+ */
47
+ private handleStatus;
48
+ /**
49
+ * Handle GET /health
50
+ */
51
+ private handleHealth;
52
+ }
53
+ /**
54
+ * Create a proxy server instance
55
+ */
56
+ export declare function createProxyServer(config: ProxyConfig): ProxyServer;
57
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../../src/proxy/server.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AA0G3D;;GAEG;AACH,qBAAa,eAAgB,YAAW,WAAW;IACjD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;IACrC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAqB;IAChD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAwB;IACtD,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,UAAU,CAAa;gBAEnB,MAAM,EAAE,WAAW;IAmB/B;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAoC5B;;OAEG;IACG,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAsB3B;;OAEG;IACH,OAAO,IAAI,MAAM;IAIjB;;OAEG;YACW,aAAa;IAyE3B;;OAEG;YACW,aAAa;IAM3B;;OAEG;YACW,aAAa;IAM3B;;OAEG;YACW,UAAU;IAMxB;;OAEG;IACH,OAAO,CAAC,YAAY;IAKpB;;OAEG;IACH,OAAO,CAAC,YAAY;CAIrB;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,WAAW,GAAG,WAAW,CAElE"}
@@ -0,0 +1,298 @@
1
+ /**
2
+ * Standalone HTTP Proxy Server
3
+ * HTTP server that intercepts and analyzes tool calls without OpenClaw integration
4
+ */
5
+ import { createServer } from 'http';
6
+ import { ValidationError, createAnalysisMiddleware } from './middleware.js';
7
+ import { HybridAnalyzer } from '../engine/analyzer.js';
8
+ import { createApprovalStore } from '../approval/store.js';
9
+ /** Default host to bind to */
10
+ const DEFAULT_HOST = '127.0.0.1';
11
+ /** Default approval timeout in seconds */
12
+ const DEFAULT_APPROVAL_TIMEOUT = 300;
13
+ /**
14
+ * Parse JSON body from request
15
+ */
16
+ async function parseJsonBody(req) {
17
+ return new Promise((resolve, reject) => {
18
+ const chunks = [];
19
+ req.on('data', (chunk) => {
20
+ chunks.push(chunk);
21
+ });
22
+ req.on('end', () => {
23
+ const body = Buffer.concat(chunks).toString('utf-8');
24
+ if (!body || body.trim() === '') {
25
+ resolve({});
26
+ return;
27
+ }
28
+ try {
29
+ resolve(JSON.parse(body));
30
+ }
31
+ catch {
32
+ reject(new Error('Invalid JSON'));
33
+ }
34
+ });
35
+ req.on('error', reject);
36
+ });
37
+ }
38
+ /**
39
+ * Send JSON response
40
+ */
41
+ function sendJson(res, statusCode, data) {
42
+ res.statusCode = statusCode;
43
+ res.setHeader('Content-Type', 'application/json');
44
+ res.end(JSON.stringify(data));
45
+ }
46
+ /**
47
+ * Send error response
48
+ */
49
+ function sendError(res, statusCode, message) {
50
+ sendJson(res, statusCode, { error: true, message, statusCode });
51
+ }
52
+ /**
53
+ * Extract path parameter from URL pattern
54
+ * Example: extractParam('/approve/:id', '/approve/abc123') returns 'abc123'
55
+ */
56
+ function extractParam(pattern, url) {
57
+ const patternParts = pattern.split('/');
58
+ const urlParts = url.split('?')[0].split('/');
59
+ if (patternParts.length !== urlParts.length) {
60
+ return null;
61
+ }
62
+ for (let i = 0; i < patternParts.length; i++) {
63
+ const patternPart = patternParts[i];
64
+ if (patternPart.startsWith(':')) {
65
+ return urlParts[i];
66
+ }
67
+ if (patternPart !== urlParts[i]) {
68
+ return null;
69
+ }
70
+ }
71
+ return null;
72
+ }
73
+ /**
74
+ * Check if URL matches a pattern
75
+ */
76
+ function matchesPattern(pattern, url) {
77
+ const urlPath = url.split('?')[0];
78
+ const patternParts = pattern.split('/');
79
+ const urlParts = urlPath.split('/');
80
+ if (patternParts.length !== urlParts.length) {
81
+ return false;
82
+ }
83
+ for (let i = 0; i < patternParts.length; i++) {
84
+ const patternPart = patternParts[i];
85
+ if (patternPart.startsWith(':')) {
86
+ continue; // Parameter placeholder matches anything
87
+ }
88
+ if (patternPart !== urlParts[i]) {
89
+ return false;
90
+ }
91
+ }
92
+ return true;
93
+ }
94
+ /**
95
+ * HTTP Proxy Server Implementation
96
+ */
97
+ export class HttpProxyServer {
98
+ config;
99
+ middleware;
100
+ approvalStore;
101
+ server = null;
102
+ actualPort = 0;
103
+ constructor(config) {
104
+ this.config = config;
105
+ // Create approval store
106
+ this.approvalStore = createApprovalStore({
107
+ cleanupIntervalMs: 60_000, // Cleanup every minute
108
+ removeOnExpiry: true,
109
+ });
110
+ // Create analyzer
111
+ const analyzer = new HybridAnalyzer({ config: config.clawsecConfig });
112
+ // Get approval timeout from config
113
+ const approvalTimeout = config.clawsecConfig.approval?.native?.timeout ?? DEFAULT_APPROVAL_TIMEOUT;
114
+ // Create middleware
115
+ this.middleware = createAnalysisMiddleware(analyzer, this.approvalStore, approvalTimeout);
116
+ }
117
+ /**
118
+ * Start the server
119
+ */
120
+ async start() {
121
+ if (this.server) {
122
+ throw new Error('Server already started');
123
+ }
124
+ const host = this.config.host ?? DEFAULT_HOST;
125
+ const port = this.config.port;
126
+ return new Promise((resolve, reject) => {
127
+ this.server = createServer((req, res) => {
128
+ this.handleRequest(req, res).catch((error) => {
129
+ console.error('Unhandled error in request handler:', error);
130
+ sendError(res, 500, 'Internal server error');
131
+ });
132
+ });
133
+ this.server.on('error', (error) => {
134
+ if (error.code === 'EADDRINUSE') {
135
+ reject(new Error(`Port ${port} is already in use`));
136
+ }
137
+ else {
138
+ reject(error);
139
+ }
140
+ });
141
+ this.server.listen(port, host, () => {
142
+ const address = this.server?.address();
143
+ if (address && typeof address === 'object') {
144
+ this.actualPort = address.port;
145
+ }
146
+ else {
147
+ this.actualPort = port;
148
+ }
149
+ resolve();
150
+ });
151
+ });
152
+ }
153
+ /**
154
+ * Stop the server
155
+ */
156
+ async stop() {
157
+ if (!this.server) {
158
+ return;
159
+ }
160
+ return new Promise((resolve, reject) => {
161
+ // Stop the approval store cleanup timer
162
+ this.approvalStore.stopCleanupTimer();
163
+ this.approvalStore.clear();
164
+ this.server.close((error) => {
165
+ if (error) {
166
+ reject(error);
167
+ }
168
+ else {
169
+ this.server = null;
170
+ this.actualPort = 0;
171
+ resolve();
172
+ }
173
+ });
174
+ });
175
+ }
176
+ /**
177
+ * Get the port the server is listening on
178
+ */
179
+ getPort() {
180
+ return this.actualPort;
181
+ }
182
+ /**
183
+ * Handle incoming HTTP request
184
+ */
185
+ async handleRequest(req, res) {
186
+ const method = req.method?.toUpperCase() ?? 'GET';
187
+ const url = req.url ?? '/';
188
+ // Set CORS headers for all responses
189
+ res.setHeader('Access-Control-Allow-Origin', '*');
190
+ res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
191
+ res.setHeader('Access-Control-Allow-Headers', 'Content-Type');
192
+ // Handle CORS preflight
193
+ if (method === 'OPTIONS') {
194
+ res.statusCode = 204;
195
+ res.end();
196
+ return;
197
+ }
198
+ // Route the request
199
+ try {
200
+ // POST /analyze
201
+ if (method === 'POST' && url === '/analyze') {
202
+ await this.handleAnalyze(req, res);
203
+ return;
204
+ }
205
+ // POST /approve/:id
206
+ if (method === 'POST' && matchesPattern('/approve/:id', url)) {
207
+ const id = extractParam('/approve/:id', url);
208
+ if (id) {
209
+ await this.handleApprove(id, res);
210
+ return;
211
+ }
212
+ }
213
+ // POST /deny/:id
214
+ if (method === 'POST' && matchesPattern('/deny/:id', url)) {
215
+ const id = extractParam('/deny/:id', url);
216
+ if (id) {
217
+ await this.handleDeny(id, res);
218
+ return;
219
+ }
220
+ }
221
+ // GET /status
222
+ if (method === 'GET' && url === '/status') {
223
+ this.handleStatus(res);
224
+ return;
225
+ }
226
+ // GET /health
227
+ if (method === 'GET' && url === '/health') {
228
+ this.handleHealth(res);
229
+ return;
230
+ }
231
+ // Not found
232
+ sendError(res, 404, `Not found: ${method} ${url}`);
233
+ }
234
+ catch (error) {
235
+ if (error instanceof ValidationError) {
236
+ sendError(res, 400, error.message);
237
+ }
238
+ else if (error instanceof Error) {
239
+ if (error.message === 'Invalid JSON') {
240
+ sendError(res, 400, 'Invalid JSON in request body');
241
+ }
242
+ else {
243
+ console.error('Request handler error:', error);
244
+ sendError(res, 500, 'Internal server error');
245
+ }
246
+ }
247
+ else {
248
+ console.error('Unknown error:', error);
249
+ sendError(res, 500, 'Internal server error');
250
+ }
251
+ }
252
+ }
253
+ /**
254
+ * Handle POST /analyze
255
+ */
256
+ async handleAnalyze(req, res) {
257
+ const body = await parseJsonBody(req);
258
+ const response = await this.middleware.analyze(body);
259
+ sendJson(res, 200, response);
260
+ }
261
+ /**
262
+ * Handle POST /approve/:id
263
+ */
264
+ async handleApprove(id, res) {
265
+ const response = this.middleware.approve(id);
266
+ const statusCode = response.success ? 200 : 404;
267
+ sendJson(res, statusCode, response);
268
+ }
269
+ /**
270
+ * Handle POST /deny/:id
271
+ */
272
+ async handleDeny(id, res) {
273
+ const response = this.middleware.deny(id);
274
+ const statusCode = response.success ? 200 : 404;
275
+ sendJson(res, statusCode, response);
276
+ }
277
+ /**
278
+ * Handle GET /status
279
+ */
280
+ handleStatus(res) {
281
+ const response = this.middleware.getStatus(this.config, this.actualPort);
282
+ sendJson(res, 200, response);
283
+ }
284
+ /**
285
+ * Handle GET /health
286
+ */
287
+ handleHealth(res) {
288
+ const response = this.middleware.getHealth();
289
+ sendJson(res, 200, response);
290
+ }
291
+ }
292
+ /**
293
+ * Create a proxy server instance
294
+ */
295
+ export function createProxyServer(config) {
296
+ return new HttpProxyServer(config);
297
+ }
298
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../../src/proxy/server.ts"],"names":[],"mappings":"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"}