openclaw-multi-auto 1.5.2 → 1.5.5

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 (428) hide show
  1. package/dist/{accounts-C_lW3Ag9.js → accounts-BOzyfwW4.js} +2 -2
  2. package/dist/{accounts-BVgYdU9W.js → accounts-BtEMxtPK.js} +1 -1
  3. package/dist/{accounts-BU-CeDai.js → accounts-CUYZBSKh.js} +1 -1
  4. package/dist/{accounts-C9HcPI9h.js → accounts-L9ByEpnP.js} +2 -2
  5. package/dist/{accounts-DJaYqD2E.js → accounts-khXX75l1.js} +7 -7
  6. package/dist/{accounts-Tgelvk0C.js → accounts-yfBeCZtS.js} +17 -17
  7. package/dist/{acp-cli-oWFHnS7i.js → acp-cli-CA2oCCEA.js} +8 -8
  8. package/dist/{active-listener-BEdprTkn.js → active-listener-D1yqT1cw.js} +2 -2
  9. package/dist/{agent-scope-BRElciAf.js → agent-scope-NQ9CtXYN.js} +17 -17
  10. package/dist/{agents-CujsWz9d.js → agents-BWVlofyv.js} +14 -14
  11. package/dist/{agents.config-C42STger.js → agents.config-QVfqc4C-.js} +2 -2
  12. package/dist/{api-key-rotation-BJpKWXy0.js → api-key-rotation-DtsNS2Nb.js} +2 -2
  13. package/dist/{api-key-rotation-BbuLHl0_.js → api-key-rotation-Vix80AUw.js} +1 -1
  14. package/dist/{audio-preflight-Yg1vzPE1.js → audio-preflight-DUtdCXjJ.js} +34 -34
  15. package/dist/{audio-preflight-BMvgEQ5j.js → audio-preflight-DpxQCpsA.js} +32 -32
  16. package/dist/{audio-transcription-runner-gLFfz8fr.js → audio-transcription-runner-28fcRNNi.js} +12 -12
  17. package/dist/{audio-transcription-runner-D1cvrZ6s.js → audio-transcription-runner-DYKvqK54.js} +23 -23
  18. package/dist/{audit-membership-runtime-Dntemq07.js → audit-membership-runtime-DWyHWAHM.js} +4 -4
  19. package/dist/{audit-DtlAv66L.js → audit-oC--RZy0.js} +29 -29
  20. package/dist/{auth-Mj21c_GN.js → auth-YB6m93-M.js} +1 -1
  21. package/dist/{auth-choice-CEycltU4.js → auth-choice-CsSQLEkP.js} +13 -13
  22. package/dist/{auth-choice-CGHVedXa.js → auth-choice-gp-h1aBd.js} +11 -11
  23. package/dist/{auth-choice.apply-helpers-D4YQXYfc.js → auth-choice.apply-helpers-CPpuynsT.js} +1 -1
  24. package/dist/{auth-profiles-CdLTlJLc.js → auth-profiles-15pq9j9V.js} +16 -16
  25. package/dist/{auth-token-7kzDLVhb.js → auth-token-Bwn8N6KA.js} +1 -1
  26. package/dist/{banner-CpzKVd4-.js → banner-hcZ0XNXv.js} +2 -2
  27. package/dist/{bonjour-discovery-BuS9wF_p.js → bonjour-discovery-2btw06uD.js} +1 -1
  28. package/dist/{browser-cli-BVtbvQ3Z.js → browser-cli-C4PdLYHy.js} +12 -12
  29. package/dist/build-info.json +3 -3
  30. package/dist/bundled/boot-md/handler.js +51 -51
  31. package/dist/bundled/bootstrap-extra-files/handler.js +6 -6
  32. package/dist/bundled/command-logger/handler.js +2 -2
  33. package/dist/bundled/session-memory/handler.js +51 -51
  34. package/dist/{call-Dp9SDkqK.js → call-CZgRbVYm.js} +10 -10
  35. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  36. package/dist/{channel-account-context-ESLVGdUf.js → channel-account-context-BYiOuxnf.js} +5 -5
  37. package/dist/{channel-activity-LfmEkdDN.js → channel-activity-D9K6yeu8.js} +1 -1
  38. package/dist/{channel-activity-BDnjYF7B.js → channel-activity-xHOMiarp.js} +3 -3
  39. package/dist/{channel-options-CsYaFB_4.js → channel-options-DJkf_8wi.js} +3 -3
  40. package/dist/{channel-selection-DFJsYFPo.js → channel-selection-BpIsCVV5.js} +1 -1
  41. package/dist/{channel-web-DzRsJEE4.js → channel-web-wb1My1Yi.js} +17 -17
  42. package/dist/{channels-cli-CpfeOXtJ.js → channels-cli-DlQONtY9.js} +93 -93
  43. package/dist/{channels-status-issues-6V9ktlZD.js → channels-status-issues-Hj-GOSVm.js} +1 -1
  44. package/dist/{chrome-DxxEKrY7.js → chrome-DwizpzOC.js} +18 -18
  45. package/dist/{chrome-CyM61Cn2.js → chrome-L_icBVLq.js} +4 -4
  46. package/dist/{clawbot-cli-COtnakIJ.js → clawbot-cli-CyTZUVIJ.js} +11 -11
  47. package/dist/cli/daemon-cli.js +1 -1
  48. package/dist/{cli-jnT1hYPO.js → cli-CNTrB-ni.js} +73 -73
  49. package/dist/{client-C-wA75vx.js → client-g0366Z73.js} +2 -2
  50. package/dist/{command-registry-g5tDqdAU.js → command-registry-VOmumlmD.js} +11 -11
  51. package/dist/{command-secret-targets-u3eWn-W3.js → command-secret-targets-CIMuIdbL.js} +4 -4
  52. package/dist/{commands-C8pWcFs_.js → commands-DU7At3rY.js} +1 -1
  53. package/dist/{commands-registry-J6nVL3BQ.js → commands-registry-B_WUa9KB.js} +3 -3
  54. package/dist/{commands-registry-D5qXbFJn.js → commands-registry-V1zZ5pPC.js} +4 -4
  55. package/dist/{completion-cli-DQsyli3B.js → completion-cli-pqdmKVTo.js} +13 -13
  56. package/dist/{config-cli-DUycVHoC.js → config-cli-BqznmzlM.js} +7 -7
  57. package/dist/{config-guard--Obk2MGi.js → config-guard-D8jiLjr7.js} +3 -3
  58. package/dist/{config-validation-iOxszdEd.js → config-validation-BngLiGoq.js} +3 -3
  59. package/dist/{configure-Al_pz_5z.js → configure-B--Umf_O.js} +17 -17
  60. package/dist/{control-ui-assets-DpjfNcTC.js → control-ui-assets-C9ewbI8z.js} +1 -1
  61. package/dist/{cron-cli-CQ5EZw_b.js → cron-cli-DCRPpI1m.js} +11 -11
  62. package/dist/{daemon-cli-Bb80Mzv5.js → daemon-cli-DtBzKM_d.js} +15 -15
  63. package/dist/{daemon-install-B09ifLcJ.js → daemon-install-ckPBUAjJ.js} +4 -4
  64. package/dist/{daemon-install-helpers-CYpECiEx.js → daemon-install-helpers-BWf-PrgA.js} +11 -11
  65. package/dist/{deliver-DbdywYJE.js → deliver-D4o6VIur.js} +21 -21
  66. package/dist/{deliver-CxF9h9PE.js → deliver-b93aBgie.js} +7 -7
  67. package/dist/deliver-runtime-CdWd-JQI.js +61 -0
  68. package/dist/deliver-runtime-P-G3bPjW.js +36 -0
  69. package/dist/deps-send-discord.runtime-BltWu9GW.js +36 -0
  70. package/dist/deps-send-discord.runtime-DnbhTFX9.js +26 -0
  71. package/dist/deps-send-imessage.runtime-BOiQ6mDx.js +25 -0
  72. package/dist/deps-send-imessage.runtime-CdCif3t7.js +35 -0
  73. package/dist/deps-send-signal.runtime-CTcl388M.js +24 -0
  74. package/dist/deps-send-signal.runtime-fHqkSmMW.js +34 -0
  75. package/dist/deps-send-slack.runtime-CCqBz4Kg.js +22 -0
  76. package/dist/deps-send-slack.runtime-CkyZO7ln.js +32 -0
  77. package/dist/{deps-send-telegram.runtime-B6wp3kx8.js → deps-send-telegram.runtime-C--B69CN.js} +16 -16
  78. package/dist/deps-send-telegram.runtime-DGSKTCpH.js +27 -0
  79. package/dist/deps-send-whatsapp.runtime-BkoMLlCM.js +119 -0
  80. package/dist/deps-send-whatsapp.runtime-CJkTHkah.js +60 -0
  81. package/dist/{devices-cli-C0dUbeL4.js → devices-cli-D6V059Dh.js} +8 -8
  82. package/dist/{diagnostic-Co6Kghr-.js → diagnostic-Bn4PZjMZ.js} +2 -2
  83. package/dist/{diagnostic-BfiudAAN.js → diagnostic-BpP9UBCE.js} +1 -1
  84. package/dist/{diagnostics-DCWM_8Ur.js → diagnostics---0c2_jo.js} +5 -5
  85. package/dist/{directory-cli-Dlws13Di.js → directory-cli-RYC34-EU.js} +7 -7
  86. package/dist/{dns-cli-But7QdAw.js → dns-cli-CElNoV5S.js} +5 -5
  87. package/dist/{dock-BbUkruOF.js → dock-nA2DVPCV.js} +4 -4
  88. package/dist/{docs-cli-Ck2IKAtw.js → docs-cli-Bv7ltPvi.js} +4 -4
  89. package/dist/{doctor-completion-Nat1HXE1.js → doctor-completion-CQIiN7rY.js} +2 -2
  90. package/dist/{doctor-config-flow-WCCoUXeB.js → doctor-config-flow-BOAryh5P.js} +15 -15
  91. package/dist/{enable-C3H8BtN4.js → enable-688HYBNS.js} +1 -1
  92. package/dist/entry.js +2 -2
  93. package/dist/{errors-xt401nuk.js → errors-CCLeFWAg.js} +1 -1
  94. package/dist/{exec-approvals-allowlist-ySf2Yo5n.js → exec-approvals-allowlist-C0Eya3rT.js} +1 -1
  95. package/dist/{exec-approvals-cli-DhLLOys6.js → exec-approvals-cli-BYYerKp8.js} +16 -16
  96. package/dist/{exec-safe-bin-runtime-policy-DnXViOlF.js → exec-safe-bin-runtime-policy-BmJmfDRo.js} +2 -2
  97. package/dist/{fetch-D-SiVqBm.js → fetch-BhAHVdwx.js} +3 -3
  98. package/dist/{fetch-DuraYswo.js → fetch-BlJWzEP6.js} +5 -5
  99. package/dist/{fetch-guard-CKYBfJ66.js → fetch-guard-BbBdhWz_.js} +1 -1
  100. package/dist/{fetch-guard-DWr0d00H.js → fetch-guard-ChYBwfiy.js} +2 -2
  101. package/dist/{frontmatter-BkTfEZ93.js → frontmatter-CvaMP376.js} +3 -3
  102. package/dist/{fs-safe-CTYUrIgQ.js → fs-safe-0jAo_Whb.js} +4 -4
  103. package/dist/{fs-safe-jMDpsYew.js → fs-safe-CFLs-j60.js} +24 -24
  104. package/dist/{gateway-cli--atF6LYo.js → gateway-cli-DOYWSRqa.js} +153 -153
  105. package/dist/{gateway-rpc-DYyQQ1z9.js → gateway-rpc-w6t8Eq_1.js} +1 -1
  106. package/dist/{github-copilot-token-BDioPmd6.js → github-copilot-token-D13V9YBz.js} +7 -7
  107. package/dist/{health-BDJ72U4Z.js → health-C1EstYHd.js} +11 -11
  108. package/dist/{hooks-cli-r0UX8B9a.js → hooks-cli-BFMve5sG.js} +81 -81
  109. package/dist/{hooks-status-CxBdpBry.js → hooks-status-DBnEWOEP.js} +1 -1
  110. package/dist/{image-eT7Y-nP5.js → image-Bbn53mzj.js} +6 -6
  111. package/dist/{image-CyHTO86Q.js → image-Bw71y73Q.js} +5 -5
  112. package/dist/{image-ops-pjs5W0CZ.js → image-ops-AJL9tN3_.js} +10 -10
  113. package/dist/{image-ops-BuUnEOE0.js → image-ops-CehkHxmW.js} +2 -2
  114. package/dist/image-runtime-6jhrqcle.js +55 -0
  115. package/dist/image-runtime-CVv2ra9J.js +29 -0
  116. package/dist/{inspect-BeU4yMp2.js → inspect-CUxeDA8c.js} +4 -4
  117. package/dist/{install-safe-path-BiL8OJvK.js → install-safe-path-BX58wFBl.js} +25 -25
  118. package/dist/{installs-BwKmG0Uy.js → installs-B-xr0Fzq.js} +9 -9
  119. package/dist/{ipv4-BoGwfnEw.js → ipv4-C4Yt-xid.js} +1 -1
  120. package/dist/{ir-B83looB-.js → ir-DAP-B-Xw.js} +8 -8
  121. package/dist/{ir-Da7Ahsqc.js → ir-otKVkb4a.js} +8 -8
  122. package/dist/{issue-format-CJ89_-9v.js → issue-format-DSksfKiV.js} +1 -1
  123. package/dist/{json-files-CuJjdF_0.js → json-files-rR19q30D.js} +8 -8
  124. package/dist/{legacy-names-DOC03BkU.js → legacy-names-TyzbVqa_.js} +1 -1
  125. package/dist/{lifecycle-core-BzuWBBm8.js → lifecycle-core-DVwen0ks.js} +5 -5
  126. package/dist/llm-slug-generator.js +51 -51
  127. package/dist/{logger-BfjWMCSD.js → logger-DMZQQtxK.js} +7 -7
  128. package/dist/{login-VkQ9MW3d.js → login-BcRaGQb6.js} +3 -3
  129. package/dist/{login-CrIwcrVI.js → login-DiCctRo1.js} +5 -5
  130. package/dist/{login-qr-BVMQ-xQz.js → login-qr-C9D47WEZ.js} +6 -6
  131. package/dist/{login-qr-BpPDZdl_.js → login-qr-MUbXgjtd.js} +10 -10
  132. package/dist/{logs-cli-DWHhSnWs.js → logs-cli-B3TG2lp8.js} +9 -9
  133. package/dist/{manager-1bvuGrNR.js → manager-BW_NSIMl.js} +13 -13
  134. package/dist/{manager-BUBwl6M6.js → manager-iwcRf3Xc.js} +14 -14
  135. package/dist/manager-runtime-BN6VevdC.js +18 -0
  136. package/dist/{manager-runtime-H9iQnw64.js → manager-runtime-D3KqpRT7.js} +9 -9
  137. package/dist/{manifest-registry-DVviqWVY.js → manifest-registry-CJb8odRF.js} +1 -1
  138. package/dist/{memory-cli-DarWCbU6.js → memory-cli-DGsJx7YM.js} +12 -12
  139. package/dist/{model-BLV8y_N-.js → model-B792l3Cn.js} +2 -2
  140. package/dist/{model-catalog-DTcBkUlX.js → model-catalog-DZ6kl2Ko.js} +3 -3
  141. package/dist/{model-picker-D-fTOOzb.js → model-picker-6fHys0wK.js} +4 -4
  142. package/dist/{model-selection-Dna0Gz1k.js → model-selection-idoqPmw0.js} +43 -43
  143. package/dist/{models-CmjutMmh.js → models-DerrMmwF.js} +17 -17
  144. package/dist/{models-cli-BZFQX22p.js → models-cli-BkTZg_4v.js} +78 -78
  145. package/dist/{models-config-DNcDbV_G.js → models-config-Dabs9Kdv.js} +6 -6
  146. package/dist/{net-D5fSREu4.js → net-BAIqYNz0.js} +2 -2
  147. package/dist/{node-cli-Cnq-PJTp.js → node-cli-DoEq4zeG.js} +33 -33
  148. package/dist/{node-command-policy-B5BMBBJP.js → node-command-policy-DRhSc90G.js} +1 -1
  149. package/dist/{node-service-BpYZAvpl.js → node-service-CcgtNIeT.js} +1 -1
  150. package/dist/{nodes-cli-CkrDOWpv.js → nodes-cli--d9RiCnK.js} +16 -16
  151. package/dist/{nodes-screen-DfsQohWd.js → nodes-screen-BTND5VDq.js} +7 -7
  152. package/dist/{npm-pack-install-E-mkrZ55.js → npm-pack-install-CGUDOSKz.js} +18 -18
  153. package/dist/{npm-resolution-BUUmg5ON.js → npm-resolution-CAoULCWM.js} +4 -4
  154. package/dist/{onboard-DINGSS9R.js → onboard-CMZRkPVc.js} +6 -6
  155. package/dist/{onboard-channels-Di4MjWDY.js → onboard-channels-SlJu6XWJ.js} +21 -21
  156. package/dist/{onboard-custom-DITBQuWQ.js → onboard-custom-EzfL89yz.js} +4 -4
  157. package/dist/{onboard-helpers-DO7u2ZOy.js → onboard-helpers-lGpaVp03.js} +10 -10
  158. package/dist/{onboard-hooks-K02_ZWDq.js → onboard-hooks-B7TMiJoY.js} +4 -4
  159. package/dist/{onboard-remote-5-ugiSN2.js → onboard-remote-nvWS7on7.js} +4 -4
  160. package/dist/{onboard-skills-CSzbC2KZ.js → onboard-skills-hz91W03u.js} +4 -4
  161. package/dist/{onboarding-BM4dvUK6.js → onboarding-CTPuMVQI.js} +14 -14
  162. package/dist/{onboarding.finalize-p_RDh7ET.js → onboarding.finalize-DLzl5ZOg.js} +87 -87
  163. package/dist/{onboarding.gateway-config-DldlRfms.js → onboarding.gateway-config-C4MoTr60.js} +18 -18
  164. package/dist/{onboarding.secret-input-BIRIJiCU.js → onboarding.secret-input-BFD0OW4X.js} +1 -1
  165. package/dist/{openai-model-default-CY2Nk4cn.js → openai-model-default-h4LbSR7f.js} +2 -2
  166. package/dist/{openclaw-root-BFfBQ6FD.js → openclaw-root-BU3lu8pM.js} +8 -8
  167. package/dist/{outbound-ChDjtuD6.js → outbound-C2kanETZ.js} +6 -6
  168. package/dist/{outbound-attachment-DfWsfe2N.js → outbound-attachment-CAJBGcna.js} +2 -2
  169. package/dist/{outbound-attachment-DqHlD21U.js → outbound-attachment-DBrYWX8h.js} +2 -2
  170. package/dist/{outbound-DPdJe7e1.js → outbound-kbHYt1JW.js} +3 -3
  171. package/dist/{pairing-cli-D2VZxWg3.js → pairing-cli-CXbmkz7Z.js} +8 -8
  172. package/dist/{pairing-labels-D4rnJ5pJ.js → pairing-labels-CaPLIhlh.js} +1 -1
  173. package/dist/{pairing-store-BXArq4hn.js → pairing-store-Brs9aNn_.js} +3 -3
  174. package/dist/{path-alias-guards-DbNvNQar.js → path-alias-guards-DhIwq92y.js} +3 -3
  175. package/dist/{path-alias-guards-BzvdLvTI.js → path-alias-guards-DqXRZmsL.js} +1 -1
  176. package/dist/{path-safety-ClQO4BB6.js → path-safety-BjIM4N4t.js} +1 -1
  177. package/dist/{paths-Cvc9EM8Y.js → paths-C6TxBCvO.js} +5 -5
  178. package/dist/{paths-Bkr-BCxW.js → paths-CCxysrzL.js} +4 -4
  179. package/dist/{paths-BB_1ZWOj.js → paths-Cv63xST_.js} +9 -9
  180. package/dist/{pi-embedded-BQQa91aA.js → pi-embedded-BaGj07T0.js} +158 -158
  181. package/dist/{pi-embedded-helpers-oXDyXTD8.js → pi-embedded-helpers-DC2OtKrl.js} +6 -6
  182. package/dist/{pi-embedded-helpers-CLXm10bV.js → pi-embedded-helpers-wy0DZvx1.js} +52 -52
  183. package/dist/{pi-model-discovery-Dymwdjt0.js → pi-model-discovery-BGgOlX8N.js} +7 -7
  184. package/dist/{pi-model-discovery-CECkJMCt.js → pi-model-discovery-DOb5RTev.js} +1 -1
  185. package/dist/pi-model-discovery-runtime-Bwmi4Ev8.js +11 -0
  186. package/dist/{pi-model-discovery-runtime-g7UP-SFR.js → pi-model-discovery-runtime-DShjmiiF.js} +5 -5
  187. package/dist/{pi-tools.before-tool-call.runtime-Df7B-ggW.js → pi-tools.before-tool-call.runtime-B079pVah.js} +5 -5
  188. package/dist/{pi-tools.before-tool-call.runtime-Cwab_5W1.js → pi-tools.before-tool-call.runtime-BuLxSyx9.js} +9 -9
  189. package/dist/{pi-tools.policy-CydUEzFi.js → pi-tools.policy-DZ-X86Va.js} +5 -5
  190. package/dist/{plugin-auto-enable-BE4ZVjAL.js → plugin-auto-enable-BCMqEDjQ.js} +3 -3
  191. package/dist/{plugin-registry-DXW3eyib.js → plugin-registry-BPlCWMur.js} +3 -3
  192. package/dist/plugin-sdk/bluebubbles.js +2 -2
  193. package/dist/plugin-sdk/discord.js +6 -6
  194. package/dist/plugin-sdk/irc.js +2 -2
  195. package/dist/plugin-sdk/mattermost.js +3 -3
  196. package/dist/{plugins-4Rj4OjLY.js → plugins-CWkRQYDj.js} +11 -11
  197. package/dist/{plugins-VAZrrfgw.js → plugins-DCxT-37x.js} +2 -2
  198. package/dist/{plugins-cli-BQJOOVMx.js → plugins-cli-D9ILEfyb.js} +83 -83
  199. package/dist/{ports-DMkRSlnH.js → ports-BlCLhwbc.js} +1 -1
  200. package/dist/{ports-DogAV7pa.js → ports-CER5YPnN.js} +2 -2
  201. package/dist/{program-BA11qFx1.js → program-CV56xn7w.js} +81 -81
  202. package/dist/{prompt-select-styled-B0GS28ia.js → prompt-select-styled-BOa5I_PU.js} +40 -40
  203. package/dist/{provider-auth-helpers-CrGL-jik.js → provider-auth-helpers-c6mNCUXO.js} +5 -5
  204. package/dist/{proxy-env-wKO3g8Yv.js → proxy-env-BMrSVckF.js} +1 -1
  205. package/dist/{proxy-env-DlmzDx8x.js → proxy-env-Cq5gdrbj.js} +1 -1
  206. package/dist/{proxy-fetch-B2pEfjbR.js → proxy-fetch-CCjEYbFm.js} +1 -1
  207. package/dist/{push-apns-BEwBjZ0a.js → push-apns-FOkPD05E.js} +5 -5
  208. package/dist/{pw-ai-DNMjFMqH.js → pw-ai-Cl1Lc7RC.js} +14 -14
  209. package/dist/{pw-ai-CnbxziFP.js → pw-ai-CxBU3aK5.js} +18 -18
  210. package/dist/{qmd-manager-BtIKUaO9.js → qmd-manager-BsYsO9Ii.js} +10 -10
  211. package/dist/{qmd-manager-Dp6PJ8zQ.js → qmd-manager-DEJMqoGd.js} +20 -20
  212. package/dist/{qr-cli-CFz9kS5X.js → qr-cli-BD2jK4fg.js} +2 -2
  213. package/dist/{query-expansion-BrSWVbaE.js → query-expansion-1UTIWjP6.js} +12 -12
  214. package/dist/{query-expansion-CX-1fS52.js → query-expansion-DtLc3wjL.js} +6 -6
  215. package/dist/{redact-COik8ET1.js → redact-ClbcYG1J.js} +1 -1
  216. package/dist/{redact-snapshot-Bs4goggz.js → redact-snapshot-D_qQD4A-.js} +1 -1
  217. package/dist/{register.agent-D641ju8B.js → register.agent-tbPA5YAy.js} +94 -94
  218. package/dist/register.configure-DuwRrXc2.js +165 -0
  219. package/dist/{register.maintenance-BFkk8MEH.js → register.maintenance-DrqDlV5b.js} +95 -95
  220. package/dist/{register.message-D5uE_Hop.js → register.message-CoKXNaU0.js} +74 -74
  221. package/dist/{register.onboard-zHFvSwFr.js → register.onboard-CSWOSL9O.js} +18 -18
  222. package/dist/{register.setup-uTbv3_P1.js → register.setup-DBx5JX6h.js} +21 -21
  223. package/dist/{register.status-health-sessions-CB7t-JQx.js → register.status-health-sessions-D1bPtfep.js} +88 -88
  224. package/dist/{register.subclis-MEiNmuy5.js → register.subclis-QGJNmjss.js} +31 -31
  225. package/dist/{rpc-DVfuVmy9.js → rpc-DkMrTUww.js} +1 -1
  226. package/dist/{run-main-mrvunzuy.js → run-main-CPftxqTe.js} +92 -92
  227. package/dist/{run-with-concurrency-BgYfgkXT.js → run-with-concurrency-D_ZpbgEG.js} +4 -4
  228. package/dist/{runtime-C87FQrrv.js → runtime-MAH2Oph4.js} +3 -3
  229. package/dist/{runtime-config-collectors-BQaC477D.js → runtime-config-collectors-BJMV6Mt1.js} +1 -1
  230. package/dist/{runtime-whatsapp-login.runtime-DjdgScUI.js → runtime-whatsapp-login.runtime-CGYWl9eB.js} +7 -7
  231. package/dist/runtime-whatsapp-login.runtime-IeylZEl4.js +13 -0
  232. package/dist/runtime-whatsapp-outbound.runtime-ClBRuLsq.js +22 -0
  233. package/dist/{runtime-whatsapp-outbound.runtime-B74K7opl.js → runtime-whatsapp-outbound.runtime-hZEfYaRM.js} +15 -15
  234. package/dist/{sandbox-Ct-_lzi1.js → sandbox-0TbzPJaS.js} +18 -18
  235. package/dist/{sandbox-cli-C3RoXFRE.js → sandbox-cli-NLaxffXl.js} +25 -25
  236. package/dist/{secrets-cli-B3hqCxvs.js → secrets-cli-KLGbYet6.js} +11 -11
  237. package/dist/{security-cli-DcHIyXr7.js → security-cli-EIEkcYVb.js} +42 -42
  238. package/dist/{send-dfu6_rgf.js → send-BQERFNyo.js} +5 -5
  239. package/dist/{send-CnRP4P-G.js → send-BW-ZtYG3.js} +5 -5
  240. package/dist/{send-L7gRiwyd.js → send-Bj776ESJ.js} +7 -7
  241. package/dist/{send-2zKwf9NW.js → send-BtZAqquW.js} +11 -11
  242. package/dist/{send-DAQAKa9Z.js → send-CxgWxXZc.js} +6 -6
  243. package/dist/{send-5o2p_xjn.js → send-DAMtu9kK.js} +4 -4
  244. package/dist/{send-PE6cwoTe.js → send-DcxmcFi_.js} +8 -8
  245. package/dist/{send-6lz6rNVP.js → send-Dx2RkUOZ.js} +6 -6
  246. package/dist/{send-u1Bo4CSn.js → send-sC6ka831.js} +8 -8
  247. package/dist/{send-BHTiZcH3.js → send-vmONuVgL.js} +26 -26
  248. package/dist/{server-context-8pDe2iyd.js → server-context-HJVwPQYn.js} +12 -12
  249. package/dist/{server-Ci4xtuR9.js → server-kUElNhlY.js} +20 -20
  250. package/dist/{server-lifecycle-k5daSrde.js → server-lifecycle-BE32unpZ.js} +2 -2
  251. package/dist/{server-middleware-DMiFT9xU.js → server-middleware-AS2VOYkK.js} +1 -1
  252. package/dist/{server-node-events-BmnPjNXE.js → server-node-events-DkbZzI6P.js} +74 -74
  253. package/dist/{service-BhOFtHSw.js → service-CyStNr3d.js} +15 -15
  254. package/dist/{session-D8ImowSs.js → session-A4QhBRvH.js} +8 -8
  255. package/dist/{session-DkOjpX3_.js → session-CaCx4rPH.js} +1 -1
  256. package/dist/{session-utils-DKRmXD2l.js → session-utils-CGqb1oeq.js} +6 -6
  257. package/dist/{sessions-svLGrv0Z.js → sessions-BV6HNW4h.js} +4 -4
  258. package/dist/{sessions-BOWPuhe5.js → sessions-BmVDW-7q.js} +15 -15
  259. package/dist/{shared-CjuadLFV.js → shared-DUQavBtY.js} +3 -3
  260. package/dist/{shared-CbAkLNrg.js → shared-JW74idb0.js} +1 -1
  261. package/dist/{skill-commands-DNqJ-kwn.js → skill-commands-CMzBZKG2.js} +9 -9
  262. package/dist/{skill-commands-TpUsdjev.js → skill-commands-WtIJG0CI.js} +5 -5
  263. package/dist/{skill-scanner-BZvvItef.js → skill-scanner-DIFsGcqE.js} +6 -6
  264. package/dist/{skills-DR-vacol.js → skills-7T9PwwL6.js} +3 -3
  265. package/dist/{skills-7ODkHQYp.js → skills-CE_iqvM5.js} +22 -22
  266. package/dist/{skills-cli-oay0tY8Z.js → skills-cli-DPavvthL.js} +5 -5
  267. package/dist/{skills-install-Vmi7xYfa.js → skills-install-BoLfaoWv.js} +6 -6
  268. package/dist/{skills-status-BmN697ff.js → skills-status-CK5Gnf6i.js} +1 -1
  269. package/dist/{slash-commands.runtime-BfaheruW.js → slash-commands.runtime-CMGx2xHy.js} +11 -11
  270. package/dist/slash-commands.runtime-Cpn2tYW4.js +16 -0
  271. package/dist/slash-dispatch.runtime-BAeJXa56.js +114 -0
  272. package/dist/slash-dispatch.runtime-DoBAQBU5.js +56 -0
  273. package/dist/{slash-skill-commands.runtime-D34BKAN-.js → slash-skill-commands.runtime-ChU2tck2.js} +15 -15
  274. package/dist/slash-skill-commands.runtime-DKMvvdDW.js +20 -0
  275. package/dist/{status-BcQchPaC.js → status-Bp-K1BEf.js} +27 -27
  276. package/dist/{status.update-B20UBTDq.js → status.update-ZYUSggzS.js} +2 -2
  277. package/dist/{store-D89wDcz9.js → store--eR1R_UX.js} +2 -2
  278. package/dist/{store-DDkqo1sO.js → store-DeASfYEV.js} +5 -5
  279. package/dist/{subagent-registry-CPxHbyN5.js → subagent-registry-8qHIVhRq.js} +149 -149
  280. package/dist/subagent-registry-runtime-DVomlbm6.js +114 -0
  281. package/dist/subagent-registry-runtime-ppWS3tVu.js +56 -0
  282. package/dist/{subsystem-B45WV3qB.js → subsystem-Di1z8l0Z.js} +14 -14
  283. package/dist/{system-cli-D2yIJoKU.js → system-cli-C2xNfuQM.js} +9 -9
  284. package/dist/{system-run-command-BmhbnLTE.js → system-run-command-BPWZk7KI.js} +1 -1
  285. package/dist/{systemd-DjWVSbAG.js → systemd-Cf-0XKYu.js} +9 -9
  286. package/dist/{systemd-hints-Do-aQ9jw.js → systemd-hints-CYllYKO0.js} +6 -6
  287. package/dist/{systemd-linger-DpmnYgKU.js → systemd-linger-zllO90bD.js} +1 -1
  288. package/dist/{tables-BxyIF0w4.js → tables-CV7Afb0h.js} +1 -1
  289. package/dist/{tables-mE4cJBN2.js → tables-d739Y1xW.js} +1 -1
  290. package/dist/{tailnet-0_FsdHP-.js → tailnet-DJFUq7_R.js} +1 -1
  291. package/dist/{target-errors-KOHiT_JA.js → target-errors-CBI2Ga0y.js} +2 -2
  292. package/dist/{target-errors-mnlwhAjP.js → target-errors-iVxliVqA.js} +4 -4
  293. package/dist/{thinking-BeGmb5k6.js → thinking-DXYisHiZ.js} +7 -7
  294. package/dist/{tokens-q32vI39c.js → tokens-DxnY9ui_.js} +1 -1
  295. package/dist/{tool-images-RZdHiZcG.js → tool-images-2cBx1W8h.js} +2 -2
  296. package/dist/{tool-images-CNPfeCmU.js → tool-images-Bn6dB14u.js} +1 -1
  297. package/dist/{tui-DL6NZZEa.js → tui-DTVy-YhN.js} +6 -6
  298. package/dist/{tui-cli-BNAYhvpu.js → tui-cli-CexRLJ3a.js} +32 -32
  299. package/dist/{update-DlS-d52F.js → update-DijPxK0g.js} +3 -3
  300. package/dist/{update-cli-D8-DqIs2.js → update-cli-9NslG4yR.js} +104 -104
  301. package/dist/{update-runner-CzTQ7BJT.js → update-runner-B6_UqreW.js} +16 -16
  302. package/dist/{web-Btj-e8kN.js → web-CzWRVmFt.js} +55 -55
  303. package/dist/web-DGoa03ue.js +118 -0
  304. package/dist/{webhooks-cli-QdaQhvbT.js → webhooks-cli-B4ZcXTtw.js} +6 -6
  305. package/dist/{whatsapp-actions-Bp8F0cOF.js → whatsapp-actions-Jm4VW1Ve.js} +17 -17
  306. package/dist/{whatsapp-actions-BHbJJyqw.js → whatsapp-actions-iEArE_Ez.js} +21 -21
  307. package/dist/{with-timeout-BMMWHlH3.js → with-timeout-C8-tY12i.js} +3 -3
  308. package/dist/{workspace-v76gFdZu.js → workspace-CIGzK2_w.js} +1 -1
  309. package/dist/{workspace-U-DyR64O.js → workspace-CUVC6GX1.js} +20 -20
  310. package/dist/{workspace-dirs-Cz_Zgtg2.js → workspace-dirs-D4SMysgC.js} +1 -1
  311. package/dist/{wsl-CvQfS6aU.js → wsl-CsGe5QCP.js} +2 -2
  312. package/package.json +1 -1
  313. package/scripts/create-instance.sh +68 -33
  314. package/scripts/npm_publish.sh +1 -65
  315. package/scripts/npm_publish_backup.sh +185 -0
  316. package/dist/deliver-runtime-BFs7iAZF.js +0 -36
  317. package/dist/deliver-runtime-DixuU_uB.js +0 -61
  318. package/dist/deps-send-discord.runtime-CDcLcDSt.js +0 -36
  319. package/dist/deps-send-discord.runtime-DZUccI6Z.js +0 -26
  320. package/dist/deps-send-imessage.runtime-BGPUVMIE.js +0 -35
  321. package/dist/deps-send-imessage.runtime-CF3OpoqY.js +0 -25
  322. package/dist/deps-send-signal.runtime-Cw4-ozeO.js +0 -24
  323. package/dist/deps-send-signal.runtime-DQDD44_O.js +0 -34
  324. package/dist/deps-send-slack.runtime-BDsDhS1P.js +0 -22
  325. package/dist/deps-send-slack.runtime-Cpy77gBG.js +0 -32
  326. package/dist/deps-send-telegram.runtime-D_4xVasO.js +0 -27
  327. package/dist/deps-send-whatsapp.runtime-D2sVAclS.js +0 -119
  328. package/dist/deps-send-whatsapp.runtime-DK8jqd14.js +0 -60
  329. package/dist/image-runtime-B2qh5seQ.js +0 -55
  330. package/dist/image-runtime-BcAK3n8a.js +0 -29
  331. package/dist/manager-runtime-FO1Sx3W8.js +0 -18
  332. package/dist/pi-model-discovery-runtime-BeY4EUPp.js +0 -11
  333. package/dist/register.configure-BrDOSLIq.js +0 -165
  334. package/dist/runtime-whatsapp-login.runtime-DUb55byQ.js +0 -13
  335. package/dist/runtime-whatsapp-outbound.runtime-Bii_xSfI.js +0 -22
  336. package/dist/slash-commands.runtime-CVw6566g.js +0 -16
  337. package/dist/slash-dispatch.runtime-B9Ygtzi4.js +0 -56
  338. package/dist/slash-dispatch.runtime-D0xInkf3.js +0 -114
  339. package/dist/slash-skill-commands.runtime-DxZ4z5h6.js +0 -20
  340. package/dist/subagent-registry-runtime-DL1Wv7nA.js +0 -56
  341. package/dist/subagent-registry-runtime-SkB2tTaE.js +0 -114
  342. package/dist/web-DWiOofzq.js +0 -118
  343. package/extensions/page-action-cache/dist/actions-executor.d.ts +0 -62
  344. package/extensions/page-action-cache/dist/actions-executor.d.ts.map +0 -1
  345. package/extensions/page-action-cache/dist/actions-executor.js +0 -339
  346. package/extensions/page-action-cache/dist/actions-executor.js.map +0 -1
  347. package/extensions/page-action-cache/dist/cache-invalidator.d.ts +0 -70
  348. package/extensions/page-action-cache/dist/cache-invalidator.d.ts.map +0 -1
  349. package/extensions/page-action-cache/dist/cache-invalidator.js +0 -212
  350. package/extensions/page-action-cache/dist/cache-invalidator.js.map +0 -1
  351. package/extensions/page-action-cache/dist/cache-store.d.ts +0 -80
  352. package/extensions/page-action-cache/dist/cache-store.d.ts.map +0 -1
  353. package/extensions/page-action-cache/dist/cache-store.js +0 -361
  354. package/extensions/page-action-cache/dist/cache-store.js.map +0 -1
  355. package/extensions/page-action-cache/dist/cache-strategy.d.ts +0 -65
  356. package/extensions/page-action-cache/dist/cache-strategy.d.ts.map +0 -1
  357. package/extensions/page-action-cache/dist/cache-strategy.js +0 -237
  358. package/extensions/page-action-cache/dist/cache-strategy.js.map +0 -1
  359. package/extensions/page-action-cache/dist/hooks-entry.d.ts +0 -29
  360. package/extensions/page-action-cache/dist/hooks-entry.d.ts.map +0 -1
  361. package/extensions/page-action-cache/dist/hooks-entry.js +0 -83
  362. package/extensions/page-action-cache/dist/hooks-entry.js.map +0 -1
  363. package/extensions/page-action-cache/dist/hooks.d.ts +0 -10
  364. package/extensions/page-action-cache/dist/hooks.d.ts.map +0 -1
  365. package/extensions/page-action-cache/dist/hooks.js +0 -277
  366. package/extensions/page-action-cache/dist/hooks.js.map +0 -1
  367. package/extensions/page-action-cache/dist/index.d.ts +0 -24
  368. package/extensions/page-action-cache/dist/index.d.ts.map +0 -1
  369. package/extensions/page-action-cache/dist/index.js +0 -34
  370. package/extensions/page-action-cache/dist/index.js.map +0 -1
  371. package/extensions/page-action-cache/dist/scenario-recognizer.d.ts +0 -45
  372. package/extensions/page-action-cache/dist/scenario-recognizer.d.ts.map +0 -1
  373. package/extensions/page-action-cache/dist/scenario-recognizer.js +0 -213
  374. package/extensions/page-action-cache/dist/scenario-recognizer.js.map +0 -1
  375. package/extensions/page-action-cache/dist/security-policy.d.ts +0 -62
  376. package/extensions/page-action-cache/dist/security-policy.d.ts.map +0 -1
  377. package/extensions/page-action-cache/dist/security-policy.js +0 -219
  378. package/extensions/page-action-cache/dist/security-policy.js.map +0 -1
  379. package/extensions/page-action-cache/dist/tools.d.ts +0 -209
  380. package/extensions/page-action-cache/dist/tools.d.ts.map +0 -1
  381. package/extensions/page-action-cache/dist/tools.js +0 -383
  382. package/extensions/page-action-cache/dist/tools.js.map +0 -1
  383. package/extensions/page-action-cache/dist/types.d.ts +0 -336
  384. package/extensions/page-action-cache/dist/types.d.ts.map +0 -1
  385. package/extensions/page-action-cache/dist/types.js +0 -8
  386. package/extensions/page-action-cache/dist/types.js.map +0 -1
  387. package/extensions/page-action-cache/dist/ux-enhancer.d.ts +0 -60
  388. package/extensions/page-action-cache/dist/ux-enhancer.d.ts.map +0 -1
  389. package/extensions/page-action-cache/dist/ux-enhancer.js +0 -218
  390. package/extensions/page-action-cache/dist/ux-enhancer.js.map +0 -1
  391. package/extensions/page-action-cache/dist/variable-resolver.d.ts +0 -28
  392. package/extensions/page-action-cache/dist/variable-resolver.d.ts.map +0 -1
  393. package/extensions/page-action-cache/dist/variable-resolver.js +0 -201
  394. package/extensions/page-action-cache/dist/variable-resolver.js.map +0 -1
  395. package/extensions/page-action-cache/docs/API.md +0 -555
  396. package/extensions/page-action-cache/docs/IMPLEMENTATION.md +0 -1792
  397. package/extensions/page-action-cache/docs/INTEGRATION.md +0 -387
  398. package/extensions/page-action-cache/docs/README.md +0 -183
  399. package/extensions/page-action-cache/index.ts +0 -118
  400. package/extensions/page-action-cache/node_modules/.bin/nlc +0 -21
  401. package/extensions/page-action-cache/node_modules/.bin/node-llama-cpp +0 -21
  402. package/extensions/page-action-cache/node_modules/.bin/openclaw +0 -21
  403. package/extensions/page-action-cache/node_modules/.bin/tsc +0 -21
  404. package/extensions/page-action-cache/node_modules/.bin/tsserver +0 -21
  405. package/extensions/page-action-cache/node_modules/.bin/vitest +0 -21
  406. package/extensions/page-action-cache/openclaw.plugin.json +0 -208
  407. package/extensions/page-action-cache/package.json +0 -74
  408. package/extensions/page-action-cache/scripts/npm_publish.sh +0 -80
  409. package/extensions/page-action-cache/skills/page-action-cache/SKILL.md +0 -216
  410. package/extensions/page-action-cache/src/actions-executor.ts +0 -441
  411. package/extensions/page-action-cache/src/cache-invalidator.ts +0 -271
  412. package/extensions/page-action-cache/src/cache-store.ts +0 -457
  413. package/extensions/page-action-cache/src/cache-strategy.ts +0 -327
  414. package/extensions/page-action-cache/src/hooks-entry.ts +0 -114
  415. package/extensions/page-action-cache/src/hooks.ts +0 -332
  416. package/extensions/page-action-cache/src/index.ts +0 -89
  417. package/extensions/page-action-cache/src/scenario-recognizer.ts +0 -259
  418. package/extensions/page-action-cache/src/security-policy.ts +0 -268
  419. package/extensions/page-action-cache/src/tools.ts +0 -437
  420. package/extensions/page-action-cache/src/types.ts +0 -482
  421. package/extensions/page-action-cache/src/ux-enhancer.ts +0 -266
  422. package/extensions/page-action-cache/src/variable-resolver.ts +0 -258
  423. package/extensions/page-action-cache/tests/actions-executor.test.ts +0 -424
  424. package/extensions/page-action-cache/tests/cache-store.test.ts +0 -267
  425. package/extensions/page-action-cache/tests/integration-test.ts +0 -62
  426. package/extensions/page-action-cache/tests/scenario-recognizer.test.ts +0 -140
  427. package/extensions/page-action-cache/tests/variable-resolver.test.ts +0 -187
  428. package/extensions/page-action-cache/tsconfig.json +0 -39
@@ -1,268 +0,0 @@
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
- }
@@ -1,437 +0,0 @@
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
- }