openclaw-multi-auto 1.4.6 → 1.4.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 (424) hide show
  1. package/dist/{accounts-CUYZBSKh.js → accounts-BU-CeDai.js} +1 -1
  2. package/dist/{accounts-BtEMxtPK.js → accounts-BVgYdU9W.js} +1 -1
  3. package/dist/{accounts-khXX75l1.js → accounts-DJaYqD2E.js} +7 -7
  4. package/dist/{acp-cli-CA2oCCEA.js → acp-cli-oWFHnS7i.js} +8 -8
  5. package/dist/{agent-scope-NQ9CtXYN.js → agent-scope-BRElciAf.js} +17 -17
  6. package/dist/{agents-BWVlofyv.js → agents-CujsWz9d.js} +14 -14
  7. package/dist/{agents.config-QVfqc4C-.js → agents.config-C42STger.js} +2 -2
  8. package/dist/{api-key-rotation-Vix80AUw.js → api-key-rotation-BbuLHl0_.js} +1 -1
  9. package/dist/{audio-preflight-DUtdCXjJ.js → audio-preflight-Yg1vzPE1.js} +34 -34
  10. package/dist/{audio-transcription-runner-DYKvqK54.js → audio-transcription-runner-D1cvrZ6s.js} +23 -23
  11. package/dist/{audit-oC--RZy0.js → audit-DtlAv66L.js} +29 -29
  12. package/dist/{auth-YB6m93-M.js → auth-Mj21c_GN.js} +1 -1
  13. package/dist/{auth-choice-CsSQLEkP.js → auth-choice-CEycltU4.js} +13 -13
  14. package/dist/{auth-choice-gp-h1aBd.js → auth-choice-CGHVedXa.js} +11 -11
  15. package/dist/{auth-choice.apply-helpers-CPpuynsT.js → auth-choice.apply-helpers-D4YQXYfc.js} +1 -1
  16. package/dist/{auth-profiles-15pq9j9V.js → auth-profiles-CdLTlJLc.js} +16 -16
  17. package/dist/{auth-token-Bwn8N6KA.js → auth-token-7kzDLVhb.js} +1 -1
  18. package/dist/{banner-hcZ0XNXv.js → banner-CpzKVd4-.js} +2 -2
  19. package/dist/{bonjour-discovery-2btw06uD.js → bonjour-discovery-BuS9wF_p.js} +1 -1
  20. package/dist/{browser-cli-C4PdLYHy.js → browser-cli-BVtbvQ3Z.js} +12 -12
  21. package/dist/build-info.json +3 -3
  22. package/dist/{call-CZgRbVYm.js → call-Dp9SDkqK.js} +10 -10
  23. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  24. package/dist/{channel-account-context-BYiOuxnf.js → channel-account-context-ESLVGdUf.js} +5 -5
  25. package/dist/{channel-activity-D9K6yeu8.js → channel-activity-LfmEkdDN.js} +1 -1
  26. package/dist/{channel-options-DJkf_8wi.js → channel-options-CsYaFB_4.js} +3 -3
  27. package/dist/{channel-selection-BpIsCVV5.js → channel-selection-DFJsYFPo.js} +1 -1
  28. package/dist/{channel-web-wb1My1Yi.js → channel-web-DzRsJEE4.js} +17 -17
  29. package/dist/{channels-cli-DlQONtY9.js → channels-cli-CpfeOXtJ.js} +93 -93
  30. package/dist/{channels-status-issues-Hj-GOSVm.js → channels-status-issues-6V9ktlZD.js} +1 -1
  31. package/dist/{chrome-L_icBVLq.js → chrome-CyM61Cn2.js} +4 -4
  32. package/dist/{clawbot-cli-CyTZUVIJ.js → clawbot-cli-COtnakIJ.js} +11 -11
  33. package/dist/cli/daemon-cli.js +1 -1
  34. package/dist/{cli-CNTrB-ni.js → cli-jnT1hYPO.js} +73 -73
  35. package/dist/{client-g0366Z73.js → client-C-wA75vx.js} +2 -2
  36. package/dist/{command-registry-VOmumlmD.js → command-registry-g5tDqdAU.js} +11 -11
  37. package/dist/{command-secret-targets-CIMuIdbL.js → command-secret-targets-u3eWn-W3.js} +4 -4
  38. package/dist/{commands-DU7At3rY.js → commands-C8pWcFs_.js} +1 -1
  39. package/dist/{commands-registry-B_WUa9KB.js → commands-registry-J6nVL3BQ.js} +3 -3
  40. package/dist/{completion-cli-pqdmKVTo.js → completion-cli-DQsyli3B.js} +13 -13
  41. package/dist/{config-cli-BqznmzlM.js → config-cli-DUycVHoC.js} +7 -7
  42. package/dist/{config-guard-D8jiLjr7.js → config-guard--Obk2MGi.js} +3 -3
  43. package/dist/{config-validation-BngLiGoq.js → config-validation-iOxszdEd.js} +3 -3
  44. package/dist/{configure-B--Umf_O.js → configure-Al_pz_5z.js} +17 -17
  45. package/dist/{control-ui-assets-C9ewbI8z.js → control-ui-assets-DpjfNcTC.js} +1 -1
  46. package/dist/{cron-cli-DCRPpI1m.js → cron-cli-CQ5EZw_b.js} +11 -11
  47. package/dist/{daemon-cli-DtBzKM_d.js → daemon-cli-Bb80Mzv5.js} +15 -15
  48. package/dist/{daemon-install-ckPBUAjJ.js → daemon-install-B09ifLcJ.js} +4 -4
  49. package/dist/{daemon-install-helpers-BWf-PrgA.js → daemon-install-helpers-CYpECiEx.js} +11 -11
  50. package/dist/{deliver-b93aBgie.js → deliver-CxF9h9PE.js} +7 -7
  51. package/dist/deliver-runtime-DixuU_uB.js +61 -0
  52. package/dist/deps-send-discord.runtime-CDcLcDSt.js +36 -0
  53. package/dist/deps-send-imessage.runtime-BGPUVMIE.js +35 -0
  54. package/dist/deps-send-signal.runtime-DQDD44_O.js +34 -0
  55. package/dist/deps-send-slack.runtime-Cpy77gBG.js +32 -0
  56. package/dist/{deps-send-telegram.runtime-C--B69CN.js → deps-send-telegram.runtime-B6wp3kx8.js} +16 -16
  57. package/dist/deps-send-whatsapp.runtime-D2sVAclS.js +119 -0
  58. package/dist/{devices-cli-D6V059Dh.js → devices-cli-C0dUbeL4.js} +8 -8
  59. package/dist/{diagnostic-BpP9UBCE.js → diagnostic-BfiudAAN.js} +1 -1
  60. package/dist/{diagnostics---0c2_jo.js → diagnostics-DCWM_8Ur.js} +5 -5
  61. package/dist/{directory-cli-RYC34-EU.js → directory-cli-Dlws13Di.js} +7 -7
  62. package/dist/{dns-cli-CElNoV5S.js → dns-cli-But7QdAw.js} +5 -5
  63. package/dist/{dock-nA2DVPCV.js → dock-BbUkruOF.js} +4 -4
  64. package/dist/{docs-cli-Bv7ltPvi.js → docs-cli-Ck2IKAtw.js} +4 -4
  65. package/dist/{doctor-completion-CQIiN7rY.js → doctor-completion-Nat1HXE1.js} +2 -2
  66. package/dist/{doctor-config-flow-BOAryh5P.js → doctor-config-flow-WCCoUXeB.js} +15 -15
  67. package/dist/{enable-688HYBNS.js → enable-C3H8BtN4.js} +1 -1
  68. package/dist/entry.js +2 -2
  69. package/dist/{exec-approvals-allowlist-C0Eya3rT.js → exec-approvals-allowlist-ySf2Yo5n.js} +1 -1
  70. package/dist/{exec-approvals-cli-BYYerKp8.js → exec-approvals-cli-DhLLOys6.js} +16 -16
  71. package/dist/{exec-safe-bin-runtime-policy-BmJmfDRo.js → exec-safe-bin-runtime-policy-DnXViOlF.js} +2 -2
  72. package/dist/{fetch-BhAHVdwx.js → fetch-D-SiVqBm.js} +3 -3
  73. package/dist/{fetch-guard-BbBdhWz_.js → fetch-guard-CKYBfJ66.js} +1 -1
  74. package/dist/{fs-safe-CFLs-j60.js → fs-safe-jMDpsYew.js} +24 -24
  75. package/dist/{gateway-cli-DOYWSRqa.js → gateway-cli--atF6LYo.js} +153 -153
  76. package/dist/{gateway-rpc-w6t8Eq_1.js → gateway-rpc-DYyQQ1z9.js} +1 -1
  77. package/dist/{health-C1EstYHd.js → health-BDJ72U4Z.js} +11 -11
  78. package/dist/{hooks-cli-BFMve5sG.js → hooks-cli-r0UX8B9a.js} +81 -81
  79. package/dist/{hooks-status-DBnEWOEP.js → hooks-status-CxBdpBry.js} +1 -1
  80. package/dist/{image-Bw71y73Q.js → image-CyHTO86Q.js} +5 -5
  81. package/dist/{image-ops-AJL9tN3_.js → image-ops-pjs5W0CZ.js} +10 -10
  82. package/dist/image-runtime-B2qh5seQ.js +55 -0
  83. package/dist/{inspect-CUxeDA8c.js → inspect-BeU4yMp2.js} +4 -4
  84. package/dist/{install-safe-path-BX58wFBl.js → install-safe-path-BiL8OJvK.js} +25 -25
  85. package/dist/{installs-B-xr0Fzq.js → installs-BwKmG0Uy.js} +9 -9
  86. package/dist/{ipv4-C4Yt-xid.js → ipv4-BoGwfnEw.js} +1 -1
  87. package/dist/{ir-otKVkb4a.js → ir-Da7Ahsqc.js} +8 -8
  88. package/dist/{issue-format-DSksfKiV.js → issue-format-CJ89_-9v.js} +1 -1
  89. package/dist/{json-files-rR19q30D.js → json-files-CuJjdF_0.js} +8 -8
  90. package/dist/{lifecycle-core-DVwen0ks.js → lifecycle-core-BzuWBBm8.js} +5 -5
  91. package/dist/{login-BcRaGQb6.js → login-VkQ9MW3d.js} +3 -3
  92. package/dist/{login-qr-C9D47WEZ.js → login-qr-BVMQ-xQz.js} +6 -6
  93. package/dist/{logs-cli-B3TG2lp8.js → logs-cli-DWHhSnWs.js} +9 -9
  94. package/dist/{manager-iwcRf3Xc.js → manager-BUBwl6M6.js} +14 -14
  95. package/dist/{manager-runtime-D3KqpRT7.js → manager-runtime-H9iQnw64.js} +9 -9
  96. package/dist/{manifest-registry-CJb8odRF.js → manifest-registry-DVviqWVY.js} +1 -1
  97. package/dist/{memory-cli-DGsJx7YM.js → memory-cli-DarWCbU6.js} +12 -12
  98. package/dist/{model-B792l3Cn.js → model-BLV8y_N-.js} +2 -2
  99. package/dist/{model-catalog-DZ6kl2Ko.js → model-catalog-DTcBkUlX.js} +3 -3
  100. package/dist/{model-picker-6fHys0wK.js → model-picker-D-fTOOzb.js} +4 -4
  101. package/dist/{models-DerrMmwF.js → models-CmjutMmh.js} +17 -17
  102. package/dist/{models-cli-BkTZg_4v.js → models-cli-BZFQX22p.js} +78 -78
  103. package/dist/{models-config-Dabs9Kdv.js → models-config-DNcDbV_G.js} +6 -6
  104. package/dist/{net-BAIqYNz0.js → net-D5fSREu4.js} +2 -2
  105. package/dist/{node-cli-DoEq4zeG.js → node-cli-Cnq-PJTp.js} +33 -33
  106. package/dist/{node-command-policy-DRhSc90G.js → node-command-policy-B5BMBBJP.js} +1 -1
  107. package/dist/{node-service-CcgtNIeT.js → node-service-BpYZAvpl.js} +1 -1
  108. package/dist/{nodes-cli--d9RiCnK.js → nodes-cli-CkrDOWpv.js} +16 -16
  109. package/dist/{nodes-screen-BTND5VDq.js → nodes-screen-DfsQohWd.js} +7 -7
  110. package/dist/{npm-pack-install-CGUDOSKz.js → npm-pack-install-E-mkrZ55.js} +18 -18
  111. package/dist/{npm-resolution-CAoULCWM.js → npm-resolution-BUUmg5ON.js} +4 -4
  112. package/dist/{onboard-CMZRkPVc.js → onboard-DINGSS9R.js} +6 -6
  113. package/dist/{onboard-channels-SlJu6XWJ.js → onboard-channels-Di4MjWDY.js} +21 -21
  114. package/dist/{onboard-custom-EzfL89yz.js → onboard-custom-DITBQuWQ.js} +4 -4
  115. package/dist/{onboard-helpers-lGpaVp03.js → onboard-helpers-DO7u2ZOy.js} +10 -10
  116. package/dist/{onboard-hooks-B7TMiJoY.js → onboard-hooks-K02_ZWDq.js} +4 -4
  117. package/dist/{onboard-remote-nvWS7on7.js → onboard-remote-5-ugiSN2.js} +4 -4
  118. package/dist/{onboard-skills-hz91W03u.js → onboard-skills-CSzbC2KZ.js} +4 -4
  119. package/dist/{onboarding-CTPuMVQI.js → onboarding-BM4dvUK6.js} +14 -14
  120. package/dist/{onboarding.finalize-DLzl5ZOg.js → onboarding.finalize-p_RDh7ET.js} +87 -87
  121. package/dist/{onboarding.gateway-config-C4MoTr60.js → onboarding.gateway-config-DldlRfms.js} +18 -18
  122. package/dist/{onboarding.secret-input-BFD0OW4X.js → onboarding.secret-input-BIRIJiCU.js} +1 -1
  123. package/dist/{openai-model-default-h4LbSR7f.js → openai-model-default-CY2Nk4cn.js} +2 -2
  124. package/dist/{openclaw-root-BU3lu8pM.js → openclaw-root-BFfBQ6FD.js} +8 -8
  125. package/dist/{outbound-kbHYt1JW.js → outbound-DPdJe7e1.js} +3 -3
  126. package/dist/{outbound-attachment-CAJBGcna.js → outbound-attachment-DfWsfe2N.js} +2 -2
  127. package/dist/{pairing-cli-CXbmkz7Z.js → pairing-cli-D2VZxWg3.js} +8 -8
  128. package/dist/{pairing-labels-CaPLIhlh.js → pairing-labels-D4rnJ5pJ.js} +1 -1
  129. package/dist/{pairing-store-Brs9aNn_.js → pairing-store-BXArq4hn.js} +3 -3
  130. package/dist/{path-alias-guards-DhIwq92y.js → path-alias-guards-DbNvNQar.js} +3 -3
  131. package/dist/{path-safety-BjIM4N4t.js → path-safety-ClQO4BB6.js} +1 -1
  132. package/dist/{paths-Cv63xST_.js → paths-BB_1ZWOj.js} +9 -9
  133. package/dist/{pi-embedded-helpers-DC2OtKrl.js → pi-embedded-helpers-oXDyXTD8.js} +6 -6
  134. package/dist/{pi-model-discovery-DOb5RTev.js → pi-model-discovery-CECkJMCt.js} +1 -1
  135. package/dist/{pi-model-discovery-runtime-DShjmiiF.js → pi-model-discovery-runtime-g7UP-SFR.js} +5 -5
  136. package/dist/{pi-tools.before-tool-call.runtime-B079pVah.js → pi-tools.before-tool-call.runtime-Df7B-ggW.js} +5 -5
  137. package/dist/{pi-tools.policy-DZ-X86Va.js → pi-tools.policy-CydUEzFi.js} +5 -5
  138. package/dist/{plugin-auto-enable-BCMqEDjQ.js → plugin-auto-enable-BE4ZVjAL.js} +3 -3
  139. package/dist/{plugin-registry-BPlCWMur.js → plugin-registry-DXW3eyib.js} +3 -3
  140. package/dist/plugin-sdk/{accounts-C3m65--E.js → accounts-BJAXxY46.js} +2 -2
  141. package/dist/plugin-sdk/{accounts-CNCCkdEF.js → accounts-C1j7HSL0.js} +3 -3
  142. package/dist/plugin-sdk/{accounts-BslAlVYS.js → accounts-DyFCXtHv.js} +2 -2
  143. package/dist/plugin-sdk/{active-listener-CkPnMUkB.js → active-listener-CftX5jLD.js} +2 -2
  144. package/dist/plugin-sdk/{api-key-rotation-BXnNsojA.js → api-key-rotation-8nyyt1kx.js} +2 -2
  145. package/dist/plugin-sdk/{audio-preflight-CtO4fFvp.js → audio-preflight-C_aSAPR1.js} +26 -26
  146. package/dist/plugin-sdk/{audio-transcription-runner-DnxvOS1-.js → audio-transcription-runner-CB53F7_7.js} +11 -11
  147. package/dist/plugin-sdk/{audit-membership-runtime-BpfoSk8M.js → audit-membership-runtime-BXndI4LG.js} +2 -2
  148. package/dist/plugin-sdk/{channel-activity-WJYxcJ3S.js → channel-activity-C5y8AgAV.js} +3 -3
  149. package/dist/plugin-sdk/{channel-web-dO5k3ubM.js → channel-web-DBTRO03V.js} +18 -18
  150. package/dist/plugin-sdk/{chrome-CjNTuJML.js → chrome-f00sZkDX.js} +6 -6
  151. package/dist/plugin-sdk/{commands-registry-CdYjoI0i.js → commands-registry-BJ_NxG2F.js} +4 -4
  152. package/dist/plugin-sdk/{common-oYc5vPFl.js → common-Cf27Jwxu.js} +2 -2
  153. package/dist/plugin-sdk/{config-B1z-UxQ3.js → config-CHQrpx-Q.js} +7 -7
  154. package/dist/plugin-sdk/{deliver-D5_6T567.js → deliver-DNEuetST.js} +10 -10
  155. package/dist/plugin-sdk/deliver-runtime-BFdqklJM.js +32 -0
  156. package/dist/plugin-sdk/deps-send-discord.runtime-DuqpYwU0.js +23 -0
  157. package/dist/plugin-sdk/deps-send-imessage.runtime-CZ2rS8Lb.js +22 -0
  158. package/dist/plugin-sdk/deps-send-signal.runtime-BdqiWhIh.js +21 -0
  159. package/dist/plugin-sdk/deps-send-slack.runtime-04s36qiC.js +19 -0
  160. package/dist/plugin-sdk/deps-send-telegram.runtime-LE5tkPvr.js +24 -0
  161. package/dist/plugin-sdk/deps-send-whatsapp.runtime-Bz57lobC.js +57 -0
  162. package/dist/plugin-sdk/{diagnostic-Bxxu0ig-.js → diagnostic-LYUUmjJ5.js} +2 -2
  163. package/dist/plugin-sdk/{errors-B3cHyZZA.js → errors-CtMWwS2Z.js} +1 -1
  164. package/dist/plugin-sdk/{fetch-guard-Dcgod0tg.js → fetch-guard-CxYB5Kg6.js} +2 -2
  165. package/dist/plugin-sdk/{fs-safe-BaKqI3G4.js → fs-safe-DtfhxbrI.js} +3 -3
  166. package/dist/plugin-sdk/{image-B2mQW9Rb.js → image-BwjYjRHx.js} +6 -6
  167. package/dist/plugin-sdk/{image-ops-Cbzr4U9l.js → image-ops-BnZKcbd6.js} +2 -2
  168. package/dist/plugin-sdk/image-runtime-B8twoubs.js +25 -0
  169. package/dist/plugin-sdk/{ir-ZEmrTr4J.js → ir-Z4hX67TJ.js} +7 -7
  170. package/dist/plugin-sdk/{local-roots-CIPRxA-4.js → local-roots-KhjQw04O.js} +4 -4
  171. package/dist/plugin-sdk/{logger-CvPFVOgT.js → logger-DHIIvMxj.js} +2 -2
  172. package/dist/plugin-sdk/{login-CCTew9bt.js → login-C31642Ld.js} +4 -4
  173. package/dist/plugin-sdk/{login-qr-BI3Vi_wJ.js → login-qr--y2SG_Ue.js} +5 -5
  174. package/dist/plugin-sdk/{manager-BEoYPn7R.js → manager-2UZBMCc7.js} +8 -8
  175. package/dist/plugin-sdk/manager-runtime-CMeLwose.js +15 -0
  176. package/dist/plugin-sdk/{outbound-ByOw1K6W.js → outbound-Ba0QUI5h.js} +5 -5
  177. package/dist/plugin-sdk/{outbound-attachment-BzVhxRRw.js → outbound-attachment-B1Laso-8.js} +2 -2
  178. package/dist/plugin-sdk/{path-alias-guards-sWayacde.js → path-alias-guards-C7Vm5DZ1.js} +1 -1
  179. package/dist/plugin-sdk/{paths-Dpg3qxcl.js → paths-DopV9PQG.js} +1 -1
  180. package/dist/plugin-sdk/{pi-embedded-helpers-DIxXkGJf.js → pi-embedded-helpers-DnA_OCzP.js} +16 -16
  181. package/dist/plugin-sdk/{pi-model-discovery-DM_2uFtj.js → pi-model-discovery-DdPqXk8f.js} +1 -1
  182. package/dist/plugin-sdk/pi-model-discovery-runtime-D8CJhtJY.js +8 -0
  183. package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-w1dqL_ty.js → pi-tools.before-tool-call.runtime-DxFHiLUE.js} +4 -4
  184. package/dist/plugin-sdk/{plugins-C4USiH29.js → plugins-CbCt4osF.js} +4 -4
  185. package/dist/plugin-sdk/{proxy-env-ET-rp8eg.js → proxy-env-C63mMdas.js} +1 -1
  186. package/dist/plugin-sdk/{proxy-fetch-uDXGKG3Z.js → proxy-fetch-Ch95c_Y2.js} +1 -1
  187. package/dist/plugin-sdk/{pw-ai-CyOt3RDA.js → pw-ai-DpJk62D4.js} +9 -9
  188. package/dist/plugin-sdk/{qmd-manager-BySdoVR7.js → qmd-manager-Ca-iSfEE.js} +7 -7
  189. package/dist/plugin-sdk/{query-expansion-C6uS-7lj.js → query-expansion-B_Xe41Ab.js} +4 -4
  190. package/dist/plugin-sdk/{redact-Bvxt1T_Q.js → redact-hp9TOulW.js} +1 -1
  191. package/dist/plugin-sdk/{reply-CTCSeQqW.js → reply-CovBlFea.js} +73 -73
  192. package/dist/plugin-sdk/{resolve-outbound-target-Bw8YNANu.js → resolve-outbound-target-BbrHgyUk.js} +2 -2
  193. package/dist/plugin-sdk/{run-with-concurrency-C_KCHwvf.js → run-with-concurrency-BR1DXa8T.js} +1 -1
  194. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-SkO91TZH.js +10 -0
  195. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-B0VWK5hm.js +19 -0
  196. package/dist/plugin-sdk/{send-C0w6xP2x.js → send-BTztm3D2.js} +6 -6
  197. package/dist/plugin-sdk/{send-qPyNGSe4.js → send-BXpXBwM_.js} +13 -13
  198. package/dist/plugin-sdk/{send-BZ6nYFZr.js → send-BvAtLLPl.js} +5 -5
  199. package/dist/plugin-sdk/{send-CFf-1V89.js → send-CWJUuG0i.js} +8 -8
  200. package/dist/plugin-sdk/{send-CY-Qfwia.js → send-EcglC4cG.js} +7 -7
  201. package/dist/plugin-sdk/{session-COrvpvUQ.js → session-k256LJZT.js} +3 -3
  202. package/dist/plugin-sdk/signal.js +2 -2
  203. package/dist/plugin-sdk/{skill-commands-DZqhtmiv.js → skill-commands-DoRqLzxm.js} +4 -4
  204. package/dist/plugin-sdk/{skills-Cw_vXEJb.js → skills-QudILG6e.js} +6 -6
  205. package/dist/plugin-sdk/slash-commands.runtime-DS6vCNSL.js +13 -0
  206. package/dist/plugin-sdk/slash-dispatch.runtime-BXrxb2wd.js +52 -0
  207. package/dist/plugin-sdk/slash-skill-commands.runtime-Bd6qQ2oT.js +16 -0
  208. package/dist/plugin-sdk/{store-CMHj6IIw.js → store-BbDQw3g6.js} +2 -2
  209. package/dist/plugin-sdk/subagent-registry-runtime-1uwQbuXj.js +52 -0
  210. package/dist/plugin-sdk/{tables-CSqrHsKL.js → tables-BhvloMKN.js} +1 -1
  211. package/dist/plugin-sdk/{thinking-DOnsR_A8.js → thinking-URzkT-3p.js} +7 -7
  212. package/dist/plugin-sdk/{tokens-BDr0Z9o3.js → tokens-B1PW5Ayy.js} +1 -1
  213. package/dist/plugin-sdk/{tool-images-eEfOVkzf.js → tool-images-xpqbP6RR.js} +2 -2
  214. package/dist/plugin-sdk/web-B74yhL2N.js +56 -0
  215. package/dist/plugin-sdk/{whatsapp-actions-xcleMoMv.js → whatsapp-actions-RcZ6vp61.js} +17 -17
  216. package/dist/plugin-sdk/whatsapp.js +50 -50
  217. package/dist/{plugins-DCxT-37x.js → plugins-VAZrrfgw.js} +2 -2
  218. package/dist/{plugins-cli-D9ILEfyb.js → plugins-cli-BQJOOVMx.js} +83 -83
  219. package/dist/{ports-BlCLhwbc.js → ports-DMkRSlnH.js} +1 -1
  220. package/dist/{ports-CER5YPnN.js → ports-DogAV7pa.js} +2 -2
  221. package/dist/{program-CV56xn7w.js → program-BA11qFx1.js} +81 -81
  222. package/dist/{prompt-select-styled-BOa5I_PU.js → prompt-select-styled-B0GS28ia.js} +40 -40
  223. package/dist/{provider-auth-helpers-c6mNCUXO.js → provider-auth-helpers-CrGL-jik.js} +5 -5
  224. package/dist/{proxy-env-BMrSVckF.js → proxy-env-wKO3g8Yv.js} +1 -1
  225. package/dist/{push-apns-FOkPD05E.js → push-apns-BEwBjZ0a.js} +5 -5
  226. package/dist/{pw-ai-CxBU3aK5.js → pw-ai-CnbxziFP.js} +18 -18
  227. package/dist/{qmd-manager-DEJMqoGd.js → qmd-manager-Dp6PJ8zQ.js} +20 -20
  228. package/dist/{qr-cli-BD2jK4fg.js → qr-cli-CFz9kS5X.js} +2 -2
  229. package/dist/{query-expansion-1UTIWjP6.js → query-expansion-BrSWVbaE.js} +12 -12
  230. package/dist/{redact-snapshot-D_qQD4A-.js → redact-snapshot-Bs4goggz.js} +1 -1
  231. package/dist/{register.agent-tbPA5YAy.js → register.agent-D641ju8B.js} +94 -94
  232. package/dist/register.configure-BrDOSLIq.js +165 -0
  233. package/dist/{register.maintenance-DrqDlV5b.js → register.maintenance-BFkk8MEH.js} +95 -95
  234. package/dist/{register.message-CoKXNaU0.js → register.message-D5uE_Hop.js} +74 -74
  235. package/dist/{register.onboard-CSWOSL9O.js → register.onboard-zHFvSwFr.js} +18 -18
  236. package/dist/{register.setup-DBx5JX6h.js → register.setup-uTbv3_P1.js} +21 -21
  237. package/dist/{register.status-health-sessions-D1bPtfep.js → register.status-health-sessions-CB7t-JQx.js} +88 -88
  238. package/dist/{register.subclis-QGJNmjss.js → register.subclis-MEiNmuy5.js} +31 -31
  239. package/dist/{rpc-DkMrTUww.js → rpc-DVfuVmy9.js} +1 -1
  240. package/dist/{run-main-CPftxqTe.js → run-main-mrvunzuy.js} +92 -92
  241. package/dist/{runtime-MAH2Oph4.js → runtime-C87FQrrv.js} +3 -3
  242. package/dist/{runtime-config-collectors-BJMV6Mt1.js → runtime-config-collectors-BQaC477D.js} +1 -1
  243. package/dist/{runtime-whatsapp-login.runtime-CGYWl9eB.js → runtime-whatsapp-login.runtime-DjdgScUI.js} +7 -7
  244. package/dist/{runtime-whatsapp-outbound.runtime-hZEfYaRM.js → runtime-whatsapp-outbound.runtime-B74K7opl.js} +15 -15
  245. package/dist/{sandbox-0TbzPJaS.js → sandbox-Ct-_lzi1.js} +18 -18
  246. package/dist/{sandbox-cli-NLaxffXl.js → sandbox-cli-C3RoXFRE.js} +25 -25
  247. package/dist/{secrets-cli-KLGbYet6.js → secrets-cli-B3hqCxvs.js} +11 -11
  248. package/dist/{security-cli-EIEkcYVb.js → security-cli-DcHIyXr7.js} +42 -42
  249. package/dist/{send-BtZAqquW.js → send-2zKwf9NW.js} +11 -11
  250. package/dist/{send-DAMtu9kK.js → send-5o2p_xjn.js} +4 -4
  251. package/dist/{send-BW-ZtYG3.js → send-CnRP4P-G.js} +5 -5
  252. package/dist/{send-CxgWxXZc.js → send-DAQAKa9Z.js} +6 -6
  253. package/dist/{send-sC6ka831.js → send-u1Bo4CSn.js} +8 -8
  254. package/dist/{server-kUElNhlY.js → server-Ci4xtuR9.js} +20 -20
  255. package/dist/{server-context-HJVwPQYn.js → server-context-8pDe2iyd.js} +12 -12
  256. package/dist/{server-lifecycle-BE32unpZ.js → server-lifecycle-k5daSrde.js} +2 -2
  257. package/dist/{server-middleware-AS2VOYkK.js → server-middleware-DMiFT9xU.js} +1 -1
  258. package/dist/{server-node-events-DkbZzI6P.js → server-node-events-BmnPjNXE.js} +74 -74
  259. package/dist/{service-CyStNr3d.js → service-BhOFtHSw.js} +15 -15
  260. package/dist/{session-CaCx4rPH.js → session-DkOjpX3_.js} +1 -1
  261. package/dist/{session-utils-CGqb1oeq.js → session-utils-DKRmXD2l.js} +6 -6
  262. package/dist/{sessions-BmVDW-7q.js → sessions-BOWPuhe5.js} +15 -15
  263. package/dist/{sessions-BV6HNW4h.js → sessions-svLGrv0Z.js} +4 -4
  264. package/dist/{shared-JW74idb0.js → shared-CbAkLNrg.js} +1 -1
  265. package/dist/{shared-DUQavBtY.js → shared-CjuadLFV.js} +3 -3
  266. package/dist/{skill-commands-WtIJG0CI.js → skill-commands-TpUsdjev.js} +5 -5
  267. package/dist/{skill-scanner-DIFsGcqE.js → skill-scanner-BZvvItef.js} +6 -6
  268. package/dist/{skills-7T9PwwL6.js → skills-DR-vacol.js} +3 -3
  269. package/dist/{skills-cli-DPavvthL.js → skills-cli-oay0tY8Z.js} +5 -5
  270. package/dist/{skills-install-BoLfaoWv.js → skills-install-Vmi7xYfa.js} +6 -6
  271. package/dist/{skills-status-CK5Gnf6i.js → skills-status-BmN697ff.js} +1 -1
  272. package/dist/{slash-commands.runtime-CMGx2xHy.js → slash-commands.runtime-BfaheruW.js} +11 -11
  273. package/dist/slash-dispatch.runtime-D0xInkf3.js +114 -0
  274. package/dist/{slash-skill-commands.runtime-ChU2tck2.js → slash-skill-commands.runtime-D34BKAN-.js} +15 -15
  275. package/dist/{status-Bp-K1BEf.js → status-BcQchPaC.js} +27 -27
  276. package/dist/{status.update-ZYUSggzS.js → status.update-B20UBTDq.js} +2 -2
  277. package/dist/{store-DeASfYEV.js → store-DDkqo1sO.js} +5 -5
  278. package/dist/{subagent-registry-8qHIVhRq.js → subagent-registry-CPxHbyN5.js} +149 -149
  279. package/dist/subagent-registry-runtime-SkB2tTaE.js +114 -0
  280. package/dist/{system-cli-C2xNfuQM.js → system-cli-D2yIJoKU.js} +9 -9
  281. package/dist/{system-run-command-BPWZk7KI.js → system-run-command-BmhbnLTE.js} +1 -1
  282. package/dist/{systemd-Cf-0XKYu.js → systemd-DjWVSbAG.js} +9 -9
  283. package/dist/{systemd-hints-CYllYKO0.js → systemd-hints-Do-aQ9jw.js} +6 -6
  284. package/dist/{systemd-linger-zllO90bD.js → systemd-linger-DpmnYgKU.js} +1 -1
  285. package/dist/{tables-CV7Afb0h.js → tables-BxyIF0w4.js} +1 -1
  286. package/dist/{tailnet-DJFUq7_R.js → tailnet-0_FsdHP-.js} +1 -1
  287. package/dist/{target-errors-iVxliVqA.js → target-errors-KOHiT_JA.js} +4 -4
  288. package/dist/{tool-images-Bn6dB14u.js → tool-images-CNPfeCmU.js} +1 -1
  289. package/dist/{tui-DTVy-YhN.js → tui-DL6NZZEa.js} +6 -6
  290. package/dist/{tui-cli-CexRLJ3a.js → tui-cli-BNAYhvpu.js} +32 -32
  291. package/dist/{update-DijPxK0g.js → update-DlS-d52F.js} +3 -3
  292. package/dist/{update-cli-9NslG4yR.js → update-cli-D8-DqIs2.js} +104 -104
  293. package/dist/{update-runner-B6_UqreW.js → update-runner-CzTQ7BJT.js} +16 -16
  294. package/dist/web-DWiOofzq.js +118 -0
  295. package/dist/{webhooks-cli-B4ZcXTtw.js → webhooks-cli-QdaQhvbT.js} +6 -6
  296. package/dist/{whatsapp-actions-Jm4VW1Ve.js → whatsapp-actions-Bp8F0cOF.js} +17 -17
  297. package/dist/{with-timeout-C8-tY12i.js → with-timeout-BMMWHlH3.js} +3 -3
  298. package/dist/{workspace-dirs-D4SMysgC.js → workspace-dirs-Cz_Zgtg2.js} +1 -1
  299. package/dist/{workspace-CIGzK2_w.js → workspace-v76gFdZu.js} +1 -1
  300. package/dist/{wsl-CsGe5QCP.js → wsl-CvQfS6aU.js} +2 -2
  301. package/docs/browser-architecture.md +602 -0
  302. package/extensions/googlechat/node_modules/.bin/openclaw +2 -2
  303. package/extensions/memory-core/node_modules/.bin/openclaw +2 -2
  304. package/extensions/memory-lancedb/node_modules/.bin/openai +2 -2
  305. package/extensions/page-action-cache/dist/actions-executor.d.ts +62 -0
  306. package/extensions/page-action-cache/dist/actions-executor.d.ts.map +1 -0
  307. package/extensions/page-action-cache/dist/actions-executor.js +339 -0
  308. package/extensions/page-action-cache/dist/actions-executor.js.map +1 -0
  309. package/extensions/page-action-cache/dist/cache-invalidator.d.ts +70 -0
  310. package/extensions/page-action-cache/dist/cache-invalidator.d.ts.map +1 -0
  311. package/extensions/page-action-cache/dist/cache-invalidator.js +212 -0
  312. package/extensions/page-action-cache/dist/cache-invalidator.js.map +1 -0
  313. package/extensions/page-action-cache/dist/cache-store.d.ts +80 -0
  314. package/extensions/page-action-cache/dist/cache-store.d.ts.map +1 -0
  315. package/extensions/page-action-cache/dist/cache-store.js +361 -0
  316. package/extensions/page-action-cache/dist/cache-store.js.map +1 -0
  317. package/extensions/page-action-cache/dist/cache-strategy.d.ts +65 -0
  318. package/extensions/page-action-cache/dist/cache-strategy.d.ts.map +1 -0
  319. package/extensions/page-action-cache/dist/cache-strategy.js +237 -0
  320. package/extensions/page-action-cache/dist/cache-strategy.js.map +1 -0
  321. package/extensions/page-action-cache/dist/hooks-entry.d.ts +18 -0
  322. package/extensions/page-action-cache/dist/hooks-entry.d.ts.map +1 -0
  323. package/extensions/page-action-cache/dist/hooks-entry.js +27 -0
  324. package/extensions/page-action-cache/dist/hooks-entry.js.map +1 -0
  325. package/extensions/page-action-cache/dist/hooks.d.ts +10 -0
  326. package/extensions/page-action-cache/dist/hooks.d.ts.map +1 -0
  327. package/extensions/page-action-cache/dist/hooks.js +277 -0
  328. package/extensions/page-action-cache/dist/hooks.js.map +1 -0
  329. package/extensions/page-action-cache/dist/index.d.ts +24 -0
  330. package/extensions/page-action-cache/dist/index.d.ts.map +1 -0
  331. package/extensions/page-action-cache/dist/index.js +34 -0
  332. package/extensions/page-action-cache/dist/index.js.map +1 -0
  333. package/extensions/page-action-cache/dist/scenario-recognizer.d.ts +45 -0
  334. package/extensions/page-action-cache/dist/scenario-recognizer.d.ts.map +1 -0
  335. package/extensions/page-action-cache/dist/scenario-recognizer.js +213 -0
  336. package/extensions/page-action-cache/dist/scenario-recognizer.js.map +1 -0
  337. package/extensions/page-action-cache/dist/security-policy.d.ts +62 -0
  338. package/extensions/page-action-cache/dist/security-policy.d.ts.map +1 -0
  339. package/extensions/page-action-cache/dist/security-policy.js +219 -0
  340. package/extensions/page-action-cache/dist/security-policy.js.map +1 -0
  341. package/extensions/page-action-cache/dist/tools.d.ts +209 -0
  342. package/extensions/page-action-cache/dist/tools.d.ts.map +1 -0
  343. package/extensions/page-action-cache/dist/tools.js +383 -0
  344. package/extensions/page-action-cache/dist/tools.js.map +1 -0
  345. package/extensions/page-action-cache/dist/types.d.ts +336 -0
  346. package/extensions/page-action-cache/dist/types.d.ts.map +1 -0
  347. package/extensions/page-action-cache/dist/types.js +8 -0
  348. package/extensions/page-action-cache/dist/types.js.map +1 -0
  349. package/extensions/page-action-cache/dist/ux-enhancer.d.ts +60 -0
  350. package/extensions/page-action-cache/dist/ux-enhancer.d.ts.map +1 -0
  351. package/extensions/page-action-cache/dist/ux-enhancer.js +218 -0
  352. package/extensions/page-action-cache/dist/ux-enhancer.js.map +1 -0
  353. package/extensions/page-action-cache/dist/variable-resolver.d.ts +28 -0
  354. package/extensions/page-action-cache/dist/variable-resolver.d.ts.map +1 -0
  355. package/extensions/page-action-cache/dist/variable-resolver.js +201 -0
  356. package/extensions/page-action-cache/dist/variable-resolver.js.map +1 -0
  357. package/extensions/page-action-cache/docs/API.md +555 -0
  358. package/extensions/page-action-cache/docs/IMPLEMENTATION.md +1792 -0
  359. package/extensions/page-action-cache/docs/INTEGRATION.md +387 -0
  360. package/extensions/page-action-cache/docs/README.md +183 -0
  361. package/extensions/page-action-cache/index.ts +118 -0
  362. package/extensions/page-action-cache/node_modules/.bin/nlc +21 -0
  363. package/extensions/page-action-cache/node_modules/.bin/node-llama-cpp +21 -0
  364. package/extensions/page-action-cache/node_modules/.bin/openclaw +21 -0
  365. package/extensions/page-action-cache/node_modules/.bin/tsc +21 -0
  366. package/extensions/page-action-cache/node_modules/.bin/tsserver +21 -0
  367. package/extensions/page-action-cache/node_modules/.bin/vitest +21 -0
  368. package/extensions/page-action-cache/openclaw.plugin.json +208 -0
  369. package/extensions/page-action-cache/package.json +76 -0
  370. package/extensions/page-action-cache/scripts/npm_publish.sh +80 -0
  371. package/extensions/page-action-cache/skills/page-action-cache/SKILL.md +216 -0
  372. package/extensions/page-action-cache/src/actions-executor.ts +441 -0
  373. package/extensions/page-action-cache/src/cache-invalidator.ts +271 -0
  374. package/extensions/page-action-cache/src/cache-store.ts +457 -0
  375. package/extensions/page-action-cache/src/cache-strategy.ts +327 -0
  376. package/extensions/page-action-cache/src/hooks-entry.ts +114 -0
  377. package/extensions/page-action-cache/src/hooks.ts +332 -0
  378. package/extensions/page-action-cache/src/index.ts +104 -0
  379. package/extensions/page-action-cache/src/scenario-recognizer.ts +259 -0
  380. package/extensions/page-action-cache/src/security-policy.ts +268 -0
  381. package/extensions/page-action-cache/src/tools.ts +437 -0
  382. package/extensions/page-action-cache/src/types.ts +482 -0
  383. package/extensions/page-action-cache/src/ux-enhancer.ts +266 -0
  384. package/extensions/page-action-cache/src/variable-resolver.ts +258 -0
  385. package/extensions/page-action-cache/tests/actions-executor.test.ts +424 -0
  386. package/extensions/page-action-cache/tests/cache-store.test.ts +267 -0
  387. package/extensions/page-action-cache/tests/integration-test.ts +62 -0
  388. package/extensions/page-action-cache/tests/scenario-recognizer.test.ts +140 -0
  389. package/extensions/page-action-cache/tests/variable-resolver.test.ts +187 -0
  390. package/extensions/page-action-cache/tsconfig.json +39 -0
  391. package/package.json +1 -1
  392. package/scripts/create-instance.sh +25 -1
  393. package/scripts/npm_publish.sh +59 -1
  394. package/scripts/publish-extension.sh +343 -0
  395. package/ui/node_modules/.bin/vite +2 -2
  396. package/ui/node_modules/.bin/vitest +2 -2
  397. package/dist/deliver-runtime-CdWd-JQI.js +0 -61
  398. package/dist/deps-send-discord.runtime-BltWu9GW.js +0 -36
  399. package/dist/deps-send-imessage.runtime-CdCif3t7.js +0 -35
  400. package/dist/deps-send-signal.runtime-fHqkSmMW.js +0 -34
  401. package/dist/deps-send-slack.runtime-CkyZO7ln.js +0 -32
  402. package/dist/deps-send-whatsapp.runtime-BkoMLlCM.js +0 -119
  403. package/dist/image-runtime-6jhrqcle.js +0 -55
  404. package/dist/plugin-sdk/deliver-runtime-C5dgvvga.js +0 -32
  405. package/dist/plugin-sdk/deps-send-discord.runtime-Dg4N7PHJ.js +0 -23
  406. package/dist/plugin-sdk/deps-send-imessage.runtime-0OEwzMQm.js +0 -22
  407. package/dist/plugin-sdk/deps-send-signal.runtime-BM1jRt3G.js +0 -21
  408. package/dist/plugin-sdk/deps-send-slack.runtime-1E3BYRdF.js +0 -19
  409. package/dist/plugin-sdk/deps-send-telegram.runtime-DNCxIflA.js +0 -24
  410. package/dist/plugin-sdk/deps-send-whatsapp.runtime-OLwr-9c8.js +0 -57
  411. package/dist/plugin-sdk/image-runtime-BFm45j49.js +0 -25
  412. package/dist/plugin-sdk/manager-runtime-DxclHQ4U.js +0 -15
  413. package/dist/plugin-sdk/pi-model-discovery-runtime-BuzvkvNR.js +0 -8
  414. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-BxgRDkhc.js +0 -10
  415. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-elOqrkfg.js +0 -19
  416. package/dist/plugin-sdk/slash-commands.runtime-D67JLweo.js +0 -13
  417. package/dist/plugin-sdk/slash-dispatch.runtime-DvcpvCJ0.js +0 -52
  418. package/dist/plugin-sdk/slash-skill-commands.runtime-BM1x3azR.js +0 -16
  419. package/dist/plugin-sdk/subagent-registry-runtime-1lbDyRzz.js +0 -52
  420. package/dist/plugin-sdk/web-BLyT64pW.js +0 -56
  421. package/dist/register.configure-DuwRrXc2.js +0 -165
  422. package/dist/slash-dispatch.runtime-BAeJXa56.js +0 -114
  423. package/dist/subagent-registry-runtime-DVomlbm6.js +0 -114
  424. package/dist/web-DGoa03ue.js +0 -118
@@ -0,0 +1,268 @@
1
+ /**
2
+ * Security Policy
3
+ * 安全策略 - 敏感变量检测、加密存储、访问控制
4
+ */
5
+
6
+ import { createCipheriv, createDecipheriv, randomBytes } from "node:crypto";
7
+ import type { AtomicAction, PageActionCacheEntry, VariableMap } from "./types.js";
8
+
9
+ // ============================================================================
10
+ // 配置
11
+ // ============================================================================
12
+
13
+ const SENSITIVE_FIELDS = new Set([
14
+ "password",
15
+ "pwd",
16
+ "token",
17
+ "secret",
18
+ "key",
19
+ "code",
20
+ "otp",
21
+ ]);
22
+
23
+ const ENCRYPTION_KEY = "default-key-change-in-production"; // 生产环境应从配置读取
24
+ const ENCRYPTION_ALGORITHM = "aes-256-gcm";
25
+
26
+ // ============================================================================
27
+ // Security Policy 类
28
+ // ============================================================================
29
+
30
+ /**
31
+ * 安全策略
32
+ */
33
+ export class SecurityPolicy {
34
+ private allowedUserIds: Set<string>;
35
+
36
+ constructor(allowedUserIds: string[] = []) {
37
+ this.allowedUserIds = new Set(allowedUserIds);
38
+ }
39
+
40
+ // -------------------------------------------------------------------------
41
+ // 敏感字段检测
42
+ // -------------------------------------------------------------------------
43
+
44
+ /**
45
+ * 检查操作是否包含敏感变量
46
+ */
47
+ isSensitiveAction(action: AtomicAction): boolean {
48
+ if (!action.variable) {
49
+ return false;
50
+ }
51
+
52
+ return SENSITIVE_FIELDS.has(action.variable.toLowerCase());
53
+ }
54
+
55
+ /**
56
+ * 检查变量映射是否包含敏感数据
57
+ */
58
+ hasSensitiveData(variables: VariableMap): boolean {
59
+ for (const key of Object.keys(variables)) {
60
+ if (SENSITIVE_FIELDS.has(key.toLowerCase())) {
61
+ return true;
62
+ }
63
+ }
64
+ return false;
65
+ }
66
+
67
+ /**
68
+ * 获取敏感字段列表
69
+ */
70
+ getSensitiveFields(): string[] {
71
+ return Array.from(SENSITIVE_FIELDS);
72
+ }
73
+
74
+ // -------------------------------------------------------------------------
75
+ // 加密/解密
76
+ // -------------------------------------------------------------------------
77
+
78
+ /**
79
+ * 加密数据
80
+ */
81
+ encrypt(data: string): string {
82
+ try {
83
+ const iv = randomBytes(16);
84
+ const cipher = createCipheriv(
85
+ ENCRYPTION_ALGORITHM,
86
+ Buffer.from(ENCRYPTION_KEY),
87
+ iv
88
+ );
89
+
90
+ let encrypted = cipher.update(data, "utf8", "hex");
91
+ encrypted += cipher.final("hex");
92
+ const authTag = cipher.getAuthTag();
93
+
94
+ return `${iv.toString("hex")}:${authTag.toString("hex")}:${encrypted}`;
95
+ } catch (error) {
96
+ console.error("[SecurityPolicy] Encryption failed:", error);
97
+ return data; // 失败时返回原数据
98
+ }
99
+ }
100
+
101
+ /**
102
+ * 解密数据
103
+ */
104
+ decrypt(encrypted: string): string {
105
+ try {
106
+ const [ivHex, authTagHex, data] = encrypted.split(":");
107
+
108
+ if (!ivHex || !authTagHex || !data) {
109
+ return encrypted; // 格式错误,返回原数据
110
+ }
111
+
112
+ const iv = Buffer.from(ivHex, "hex");
113
+ const authTag = Buffer.from(authTagHex, "hex");
114
+ const decipher = createDecipheriv(
115
+ ENCRYPTION_ALGORITHM,
116
+ Buffer.from(ENCRYPTION_KEY),
117
+ iv
118
+ );
119
+
120
+ decipher.setAuthTag(authTag);
121
+
122
+ let decrypted = decipher.update(data, "hex", "utf8");
123
+ decrypted += decipher.final("utf8");
124
+
125
+ return decrypted;
126
+ } catch (error) {
127
+ console.error("[SecurityPolicy] Decryption failed:", error);
128
+ return encrypted; // 失败时返回原数据
129
+ }
130
+ }
131
+
132
+ /**
133
+ * 加密缓存条目中的敏感变量
134
+ */
135
+ encryptCacheEntry(entry: PageActionCacheEntry): PageActionCacheEntry {
136
+ if (!entry.variables) {
137
+ return entry;
138
+ }
139
+
140
+ const encrypted = { ...entry };
141
+ encrypted.variables = {} as VariableMap;
142
+
143
+ for (const [key, value] of Object.entries(entry.variables)) {
144
+ if (SENSITIVE_FIELDS.has(key.toLowerCase()) && typeof value === "string") {
145
+ // 敏感字段加密
146
+ (encrypted.variables as any)[key] = this.encrypt(value);
147
+ } else {
148
+ (encrypted.variables as any)[key] = value;
149
+ }
150
+ }
151
+
152
+ return encrypted;
153
+ }
154
+
155
+ /**
156
+ * 解密缓存条目中的敏感变量
157
+ */
158
+ decryptCacheEntry(entry: PageActionCacheEntry): PageActionCacheEntry {
159
+ if (!entry.variables) {
160
+ return entry;
161
+ }
162
+
163
+ const decrypted = { ...entry };
164
+ decrypted.variables = {} as VariableMap;
165
+
166
+ for (const [key, value] of Object.entries(entry.variables)) {
167
+ if (SENSITIVE_FIELDS.has(key.toLowerCase()) && typeof value === "string") {
168
+ // 敏感字段解密
169
+ (decrypted.variables as any)[key] = this.decrypt(value);
170
+ } else {
171
+ (decrypted.variables as any)[key] = value;
172
+ }
173
+ }
174
+
175
+ return decrypted;
176
+ }
177
+
178
+ // -------------------------------------------------------------------------
179
+ // 访问控制
180
+ // -------------------------------------------------------------------------
181
+
182
+ /**
183
+ * 检查是否允许访问
184
+ */
185
+ canAccessCache(userId?: string): boolean {
186
+ if (this.allowedUserIds.size === 0) {
187
+ return true; // 没有限制,允许所有用户
188
+ }
189
+
190
+ if (!userId) {
191
+ return false; // 没有用户 ID,拒绝访问
192
+ }
193
+
194
+ return this.allowedUserIds.has(userId);
195
+ }
196
+
197
+ /**
198
+ * 添加允许的用户 ID
199
+ */
200
+ addAllowedUserId(userId: string): void {
201
+ this.allowedUserIds.add(userId);
202
+ }
203
+
204
+ /**
205
+ * 移除允许的用户 ID
206
+ */
207
+ removeAllowedUserId(userId: string): void {
208
+ this.allowedUserIds.delete(userId);
209
+ }
210
+
211
+ // -------------------------------------------------------------------------
212
+ // 日志脱敏
213
+ // -------------------------------------------------------------------------
214
+
215
+ /**
216
+ * 脱敏处理(用于日志输出)
217
+ */
218
+ sanitizeForLogging(data: any): any {
219
+ if (typeof data !== "object" || data === null) {
220
+ return data;
221
+ }
222
+
223
+ const sanitized: any = Array.isArray(data) ? [] : {};
224
+
225
+ for (const [key, value] of Object.entries(data)) {
226
+ if (SENSITIVE_FIELDS.has(key.toLowerCase())) {
227
+ // 敏感字段脱敏
228
+ sanitized[key] = "***REDACTED***";
229
+ } else if (typeof value === "object") {
230
+ // 递归处理嵌套对象
231
+ sanitized[key] = this.sanitizeForLogging(value);
232
+ } else {
233
+ sanitized[key] = value;
234
+ }
235
+ }
236
+
237
+ return sanitized;
238
+ }
239
+
240
+ /**
241
+ * 脱敏处理操作列表
242
+ */
243
+ sanitizeActions(actions: AtomicAction[]): AtomicAction[] {
244
+ return actions.map((action) => {
245
+ const sanitized = { ...action };
246
+
247
+ // 脱敏操作中的敏感文本
248
+ if (sanitized.type === "type" && this.isSensitiveAction(action)) {
249
+ (sanitized as any).text = "***REDACTED***";
250
+ }
251
+
252
+ return sanitized;
253
+ });
254
+ }
255
+ }
256
+
257
+ // ============================================================================
258
+ // 单例
259
+ // ============================================================================
260
+
261
+ let securityPolicyInstance: SecurityPolicy | null = null;
262
+
263
+ export function getSecurityPolicy(allowedUserIds?: string[]): SecurityPolicy {
264
+ if (!securityPolicyInstance) {
265
+ securityPolicyInstance = new SecurityPolicy(allowedUserIds);
266
+ }
267
+ return securityPolicyInstance;
268
+ }
@@ -0,0 +1,437 @@
1
+ /**
2
+ * Custom Tools
3
+ * 自定义工具 - 提供给 LLM 使用的工具接口
4
+ */
5
+
6
+ import type {
7
+ VariableMap,
8
+ PageViewport,
9
+ } from "./types.js";
10
+ import { getCacheStore } from "./cache-store.js";
11
+ import { getScenarioRecognizer } from "./scenario-recognizer.js";
12
+ import { getUXEnhancer } from "./ux-enhancer.js";
13
+ import { getActionsExecutor } from "./actions-executor.js";
14
+
15
+ // ============================================================================
16
+ // 工具定义
17
+ // ============================================================================
18
+
19
+ /**
20
+ * execute_cached 工具 - 执行缓存的页面操作序列
21
+ */
22
+ export function createExecuteCachedTool() {
23
+ return {
24
+ name: "execute_cached",
25
+ label: "Execute Cached Actions",
26
+ description:
27
+ "执行缓存的页面操作序列,跳过 LLM 分析。大幅降低 token 消耗和操作延迟。",
28
+ parameters: {
29
+ type: "object",
30
+ properties: {
31
+ cacheKey: {
32
+ type: "string",
33
+ description: "缓存键(从 cache_info 中获取)",
34
+ },
35
+ fromIndex: {
36
+ type: "number",
37
+ description: "从第几个操作开始执行(默认 0)",
38
+ },
39
+ toIndex: {
40
+ type: "number",
41
+ description: "执行到第几个操作(不指定则执行全部)",
42
+ },
43
+ dryRun: {
44
+ type: "boolean",
45
+ description: "试运行模式,不实际执行",
46
+ },
47
+ force: {
48
+ type: "boolean",
49
+ description: "强制执行(忽略页面变化检测)",
50
+ },
51
+ },
52
+ },
53
+ required: ["cacheKey"],
54
+ };
55
+ }
56
+
57
+ /**
58
+ * execute_cached 工具执行函数
59
+ */
60
+ export async function executeCached(_toolCallId: string, args: any) {
61
+ const {
62
+ cacheKey,
63
+ fromIndex,
64
+ toIndex,
65
+ dryRun = false,
66
+ force = false,
67
+ } = args;
68
+
69
+ const cacheStore = getCacheStore();
70
+ const uxEnhancer = getUXEnhancer();
71
+
72
+ // 获取缓存条目
73
+ const entry = cacheStore.listEntries().find((e) => e.key === cacheKey);
74
+
75
+ if (!entry) {
76
+ return {
77
+ content: [
78
+ {
79
+ type: "text",
80
+ text: "缓存不存在或已过期。请重新分析页面。",
81
+ },
82
+ ],
83
+ };
84
+ }
85
+
86
+ // 检查页面变化(强制模式跳过)
87
+ if (!force && !dryRun) {
88
+ // TODO: 实际获取页面 HTML 进行检测
89
+ // const html = await fetchPageHTML(entry.url, entry.viewport);
90
+ // const changeResult = await cacheInvalidator.detectPageChange(html, entry.url, entry.viewport, entry);
91
+
92
+ // 简化处理:暂时跳过检测
93
+ console.log(`[execute_cached] Skipping page change detection for ${entry.url}`);
94
+ }
95
+
96
+ // 解析变量
97
+ let variables: VariableMap = {};
98
+ if (entry.variables) {
99
+ variables = entry.variables;
100
+ }
101
+
102
+ // 获取执行器
103
+ const executor = getActionsExecutor();
104
+
105
+ if (dryRun) {
106
+ // 试运行模式,只返回不执行
107
+ const actionsToExecute = entry.actions.slice(
108
+ fromIndex || 0,
109
+ toIndex !== undefined ? toIndex + 1 : undefined
110
+ );
111
+
112
+ return {
113
+ content: [
114
+ {
115
+ type: "text",
116
+ text: uxEnhancer.generateDryRunResult(actionsToExecute),
117
+ },
118
+ ],
119
+ };
120
+ }
121
+
122
+ // 逐个执行操作
123
+ const results = await executor.executeBatch(entry.actions, variables, {
124
+ fromIndex,
125
+ toIndex,
126
+ atomic: true, // 原子执行
127
+ });
128
+
129
+ // 更新缓存统计
130
+ cacheStore.updateExecutionStats(cacheKey, results);
131
+
132
+ return {
133
+ content: [
134
+ {
135
+ type: "text",
136
+ text: uxEnhancer.generateExecutionReport(results, force),
137
+ },
138
+ ],
139
+ };
140
+ }
141
+
142
+ /**
143
+ * cache_stats 工具 - 查看缓存统计
144
+ */
145
+ export function createCacheStatsTool() {
146
+ return {
147
+ name: "cache_stats",
148
+ label: "Cache Statistics",
149
+ description: "查看页面操作缓存的统计信息,包括命中率、节省的 token 等。",
150
+ parameters: {
151
+ type: "object",
152
+ properties: {},
153
+ },
154
+ };
155
+ }
156
+
157
+ /**
158
+ * cache_stats 工具执行函数
159
+ */
160
+ export async function cacheStats(_toolCallId: string, _args: any) {
161
+ const uxEnhancer = getUXEnhancer();
162
+
163
+ return {
164
+ content: [
165
+ {
166
+ type: "text",
167
+ text: uxEnhancer.generateStatsReport(),
168
+ },
169
+ ],
170
+ };
171
+ }
172
+
173
+ /**
174
+ * cache_list 工具 - 列出所有缓存
175
+ */
176
+ export function createCacheListTool() {
177
+ return {
178
+ name: "cache_list",
179
+ label: "List Cache Entries",
180
+ description: "列出所有页面操作缓存条目,包括场景、URL、访问次数等。",
181
+ parameters: {
182
+ type: "object",
183
+ properties: {
184
+ limit: {
185
+ type: "number",
186
+ description: "最多返回的条目数(默认 20)",
187
+ },
188
+ filterScenario: {
189
+ type: "string",
190
+ description: "按场景过滤(如 login, checkout)",
191
+ },
192
+ },
193
+ },
194
+ };
195
+ }
196
+
197
+ /**
198
+ * cache_list 工具执行函数
199
+ */
200
+ export async function cacheList(_toolCallId: string, args: any) {
201
+ const { limit = 20, filterScenario } = args;
202
+ const cacheStore = getCacheStore();
203
+
204
+ let entries = cacheStore.listEntries();
205
+
206
+ // 过滤场景
207
+ if (filterScenario) {
208
+ entries = entries.filter((e) => e.scenario === filterScenario);
209
+ }
210
+
211
+ // 限制数量
212
+ entries = entries.slice(0, limit);
213
+
214
+ let text = `\n【缓存条目列表】(共 ${entries.length} 条)\n\n`;
215
+
216
+ entries.forEach((entry, i) => {
217
+ text += `${i + 1}. ${entry.scenario} (${entry.cacheLevel})\n`;
218
+ text += ` URL: ${entry.url}\n`;
219
+ text += ` 访问次数: ${entry.accessCount}\n`;
220
+ text += ` 成功率: ${((entry.successCount / (entry.successCount + entry.failCount || 1)) * 100).toFixed(0)}%\n`;
221
+ text += ` 最后访问: ${new Date(entry.lastAccessTime).toLocaleString()}\n\n`;
222
+ });
223
+
224
+ return {
225
+ content: [
226
+ {
227
+ type: "text",
228
+ text,
229
+ },
230
+ ],
231
+ };
232
+ }
233
+
234
+ /**
235
+ * cache_clear 工具 - 清空缓存
236
+ */
237
+ export function createCacheClearTool() {
238
+ return {
239
+ name: "cache_clear",
240
+ label: "Clear Cache",
241
+ description: "清空所有页面操作缓存。慎用!",
242
+ parameters: {
243
+ type: "object",
244
+ properties: {
245
+ scenario: {
246
+ type: "string",
247
+ description: "只清空指定场景的缓存(可选)",
248
+ },
249
+ },
250
+ },
251
+ };
252
+ }
253
+
254
+ /**
255
+ * cache_clear 工具执行函数
256
+ */
257
+ export async function cacheClear(_toolCallId: string, args: any) {
258
+ const { scenario } = args;
259
+ const cacheStore = getCacheStore();
260
+
261
+ if (scenario) {
262
+ // 清空指定场景
263
+ let count = 0;
264
+ const entries = cacheStore.listEntries();
265
+ for (const entry of entries) {
266
+ if (entry.scenario === scenario) {
267
+ cacheStore.delete(entry.url, entry.viewport);
268
+ count++;
269
+ }
270
+ }
271
+ return {
272
+ content: [
273
+ {
274
+ type: "text",
275
+ text: `已清空场景 "${scenario}" 的 ${count} 条缓存。`,
276
+ },
277
+ ],
278
+ };
279
+ } else {
280
+ // 清空所有缓存
281
+ cacheStore.clear();
282
+ return {
283
+ content: [
284
+ {
285
+ type: "text",
286
+ text: "已清空所有缓存。",
287
+ },
288
+ ],
289
+ };
290
+ }
291
+ }
292
+
293
+ /**
294
+ * scenario_list 工具 - 列出所有场景
295
+ */
296
+ export function createScenarioListTool() {
297
+ return {
298
+ name: "scenario_list",
299
+ label: "List Scenarios",
300
+ description: "列出所有支持的缓存场景及其匹配规则。",
301
+ parameters: {
302
+ type: "object",
303
+ properties: {},
304
+ },
305
+ };
306
+ }
307
+
308
+ /**
309
+ * scenario_list 工具执行函数
310
+ */
311
+ export async function scenarioList(_toolCallId: string, _args: any) {
312
+ const scenarioRecognizer = getScenarioRecognizer();
313
+ const rules = scenarioRecognizer.getRules();
314
+
315
+ let text = "\n【支持的缓存场景】\n\n";
316
+
317
+ rules.forEach((rule, i) => {
318
+ text += `${i + 1}. ${rule.scenario}\n`;
319
+ text += ` 关键词: ${rule.keywords.join(", ")}\n`;
320
+ text += ` URL 模式: ${rule.urlPatterns.join(", ") || "无"}\n`;
321
+ text += ` 缓存层级: ${rule.cacheLevel}\n`;
322
+ text += ` 置信度: ${rule.confidence}\n\n`;
323
+ });
324
+
325
+ return {
326
+ content: [
327
+ {
328
+ type: "text",
329
+ text,
330
+ },
331
+ ],
332
+ };
333
+ }
334
+
335
+ /**
336
+ * force_refresh 工具 - 强制刷新指定缓存
337
+ */
338
+ export function createForceRefreshTool() {
339
+ return {
340
+ name: "force_refresh",
341
+ label: "Force Refresh Cache",
342
+ description: "强制刷新指定页面的缓存,下次访问将重新分析。",
343
+ parameters: {
344
+ type: "object",
345
+ properties: {
346
+ url: {
347
+ type: "string",
348
+ description: "页面 URL",
349
+ },
350
+ viewport: {
351
+ type: "object",
352
+ description: "视口尺寸(可选)",
353
+ properties: {
354
+ width: { type: "number" },
355
+ height: { type: "number" },
356
+ },
357
+ },
358
+ },
359
+ },
360
+ required: ["url"],
361
+ };
362
+ }
363
+
364
+ /**
365
+ * force_refresh 工具执行函数
366
+ */
367
+ export async function forceRefresh(_toolCallId: string, args: any) {
368
+ const { url, viewport } = args;
369
+ const cacheStore = getCacheStore();
370
+
371
+ const vp: PageViewport = viewport || { width: 1920, height: 1080 };
372
+
373
+ const deleted = cacheStore.delete(url, vp);
374
+
375
+ if (deleted) {
376
+ return {
377
+ content: [
378
+ {
379
+ type: "text",
380
+ text: `已强制刷新缓存:${url}`,
381
+ },
382
+ ],
383
+ };
384
+ } else {
385
+ return {
386
+ content: [
387
+ {
388
+ type: "text",
389
+ text: `未找到缓存:${url}`,
390
+ },
391
+ ],
392
+ };
393
+ }
394
+ }
395
+
396
+ // ============================================================================
397
+ // 工具注册表
398
+ // ============================================================================
399
+
400
+ export const CACHE_TOOLS = [
401
+ {
402
+ definition: createExecuteCachedTool(),
403
+ execute: executeCached,
404
+ },
405
+ {
406
+ definition: createCacheStatsTool(),
407
+ execute: cacheStats,
408
+ },
409
+ {
410
+ definition: createCacheListTool(),
411
+ execute: cacheList,
412
+ },
413
+ {
414
+ definition: createCacheClearTool(),
415
+ execute: cacheClear,
416
+ },
417
+ {
418
+ definition: createScenarioListTool(),
419
+ execute: scenarioList,
420
+ },
421
+ {
422
+ definition: createForceRefreshTool(),
423
+ execute: forceRefresh,
424
+ },
425
+ ];
426
+
427
+ /**
428
+ * 获取所有工具定义
429
+ */
430
+ export function getToolDefinitions() {
431
+ return CACHE_TOOLS.map((tool) => ({
432
+ name: tool.definition.name,
433
+ label: tool.definition.label,
434
+ description: tool.definition.description,
435
+ parameters: tool.definition.parameters,
436
+ }));
437
+ }