@bitseek/claw 1.2.0 → 1.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (251) hide show
  1. package/dist/{accounts-B3zSNWIv.js → accounts-2NNZ6Hbp.js} +1 -1
  2. package/dist/{accounts-BQHz8_1_.js → accounts-Cv5CUnT4.js} +7 -7
  3. package/dist/{accounts-DTfEeXyO.js → accounts-NHpMJ0aq.js} +1 -1
  4. package/dist/{acp-cli-DYu2k7v9.js → acp-cli-B0u6no4K.js} +8 -8
  5. package/dist/{agent-scope-CJelRKYY.js → agent-scope-CY2-lUIY.js} +1 -1
  6. package/dist/{agents-B1UgGs6R.js → agents-Cweyfj22.js} +15 -15
  7. package/dist/{agents.config-CmUkQxtt.js → agents.config-DA3Y8w1t.js} +2 -2
  8. package/dist/{api-key-rotation-xfk-b2Sv.js → api-key-rotation-Cf7QM5M_.js} +1 -1
  9. package/dist/{audio-preflight-CHD1xVrt.js → audio-preflight-DdrORTn9.js} +4 -4
  10. package/dist/{audio-preflight-59K4nxSA.js → audio-preflight-SRgix4XS.js} +36 -36
  11. package/dist/{audio-transcription-runner-DwWOJBSn.js → audio-transcription-runner-CGsd7139.js} +1 -1
  12. package/dist/{audio-transcription-runner-DGyS5H3K.js → audio-transcription-runner-DkibzFT2.js} +22 -22
  13. package/dist/{audit-DJfP7KjJ.js → audit-TSVXvoTa.js} +29 -29
  14. package/dist/{auth-B3HDYw4G.js → auth-anvTU0Sb.js} +1 -1
  15. package/dist/{auth-choice-Ko0_UPIV.js → auth-choice-Bhzlukg0.js} +12 -12
  16. package/dist/{auth-choice-f6C6bI9v.js → auth-choice-CR6bBvDU.js} +14 -14
  17. package/dist/{auth-choice.apply-helpers-DR-eUj_5.js → auth-choice.apply-helpers-Du585kvU.js} +1 -1
  18. package/dist/{auth-profiles-D_x1_5v_.js → auth-profiles-CyG9VwU_.js} +16 -16
  19. package/dist/{auth-token-BqjY9MGq.js → auth-token-BIEjzQiE.js} +1 -1
  20. package/dist/{banner-DB1rGYKC.js → banner-D-ha13Xs.js} +2 -2
  21. package/dist/{bindings-Hx6KNJeg.js → bindings-DGvp9FdD.js} +1 -1
  22. package/dist/{bonjour-discovery-t-SAPCsb.js → bonjour-discovery-B68dCYTY.js} +1 -1
  23. package/dist/{browser-cli-CTlLlDFe.js → browser-cli-DREC4EVl.js} +12 -12
  24. package/dist/build-info.json +3 -3
  25. package/dist/{call-CzoM7hPS.js → call-CmAGfSJE.js} +10 -10
  26. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  27. package/dist/{channel-account-context-CiCkIxCu.js → channel-account-context-DNFdIaSr.js} +7 -6
  28. package/dist/{channel-account-context-D0zX-Gup.js → channel-account-context-etfgJrr_.js} +2 -1
  29. package/dist/{channel-options-DLPoMi6B.js → channel-options-6JzQN9nt.js} +3 -3
  30. package/dist/{channel-selection-D8KYuWir.js → channel-selection-DGtYwfd7.js} +1 -1
  31. package/dist/{channel-web-BMZ_oZSK.js → channel-web-oQImOucb.js} +18 -18
  32. package/dist/{channels-cli-sNDA9BU2.js → channels-cli-CzLX8jUv.js} +95 -95
  33. package/dist/{channels-status-issues-5n9kobSz.js → channels-status-issues-BMNB2aMG.js} +1 -1
  34. package/dist/{chrome-DuDCGdf-.js → chrome-DeZyLFsG.js} +4 -4
  35. package/dist/{chrome-CuMCXCQN.js → chrome-xatreDUO.js} +8 -8
  36. package/dist/{clawbot-cli-SIY_fH-I.js → clawbot-cli-H1Uj0ifV.js} +5 -5
  37. package/dist/cli/daemon-cli.js +1 -1
  38. package/dist/{cli-Cjv-J_yg.js → cli-C2xvYknT.js} +76 -76
  39. package/dist/{client-BvL3EdiZ.js → client-vUKV2o6h.js} +2 -2
  40. package/dist/{command-registry-KfIoXPZE.js → command-registry-QcrBU_9X.js} +13 -13
  41. package/dist/{commands-C67IbXs7.js → commands-d8L0zY8O.js} +1 -1
  42. package/dist/{commands-registry-D0_D5hFV.js → commands-registry-C78O6aNi.js} +3 -3
  43. package/dist/{completion-cli-iCWrVHvc.js → completion-cli-BkWPjJyP.js} +13 -13
  44. package/dist/{completion-cli-SYxZGwWD.js → completion-cli-VWIJWtLM.js} +1 -1
  45. package/dist/{config-cli-5lP-lwj0.js → config-cli-B4WnAVfw.js} +7 -7
  46. package/dist/{config-guard-t_xLf16g.js → config-guard-RZw5NkPK.js} +3 -3
  47. package/dist/{config-validation-DkA3FBg8.js → config-validation-tb90Bzho.js} +3 -3
  48. package/dist/{configure-hI0hAw1W.js → configure-DuwIk56q.js} +17 -17
  49. package/dist/control-ui/assets/{index-DPyUb7lL.css → index-B5WC_0Be.css} +1 -1
  50. package/dist/control-ui/assets/{index-BlqD_sH7.js → index-DmJK8e2M.js} +2 -2
  51. package/dist/control-ui/assets/index-DmJK8e2M.js.map +1 -0
  52. package/dist/control-ui/index.html +2 -2
  53. package/dist/{control-ui-assets-M84PR-kz.js → control-ui-assets-Czpjuiah.js} +1 -1
  54. package/dist/{cron-cli-Bg88aQ8Y.js → cron-cli-D5MnhB5f.js} +12 -12
  55. package/dist/{daemon-cli-CFnqQB6M.js → daemon-cli-oCVkh3bg.js} +15 -15
  56. package/dist/{daemon-install-helpers-C1iBqd73.js → daemon-install-helpers-D5tste0V.js} +11 -11
  57. package/dist/{daemon-install-CdoMSH6S.js → daemon-install-vQ6KespE.js} +4 -4
  58. package/dist/{dashboard-CYa-ISxZ.js → dashboard-BstU6qkZ.js} +2 -2
  59. package/dist/{deliver-DTgCZWjU.js → deliver-H0xCFj4j.js} +7 -7
  60. package/dist/{deliver-Dyh8ZsLI.js → deliver-Z7543EnP.js} +1 -1
  61. package/dist/{devices-cli-9aOy3d7K.js → devices-cli-D6b6S-Iy.js} +8 -8
  62. package/dist/{diagnostic-Bvatw1Xn.js → diagnostic-DjxUqpmL.js} +1 -1
  63. package/dist/{diagnostics-DooDWHeF.js → diagnostics-vLzdmcgg.js} +5 -5
  64. package/dist/{directory-cli-Rk2cBm0A.js → directory-cli-D3o7BGMd.js} +8 -8
  65. package/dist/{dns-cli-BXhJBWtC.js → dns-cli-B5kqVfFd.js} +5 -5
  66. package/dist/{dock-DT8sACcR.js → dock-CoclJnwp.js} +4 -4
  67. package/dist/{docs-cli-D606Eb-M.js → docs-cli-CyjlhZAj.js} +4 -4
  68. package/dist/{doctor-completion-C7FCLVKC.js → doctor-completion-DGNL86eP.js} +1 -1
  69. package/dist/{doctor-completion-DNAwhmlY.js → doctor-completion-SBDS3edN.js} +2 -2
  70. package/dist/{doctor-config-flow-ePZ7ejQj.js → doctor-config-flow-DclZbGUP.js} +15 -15
  71. package/dist/{enable-CnvIWic7.js → enable-CKAw_GCd.js} +1 -1
  72. package/dist/entry.js +2 -2
  73. package/dist/{exec-approvals-allowlist-B4DS6FIn.js → exec-approvals-allowlist-CFjPSbxI.js} +1 -1
  74. package/dist/{exec-approvals-cli-Czp8csm7.js → exec-approvals-cli-U46MdeMi.js} +16 -16
  75. package/dist/{exec-safe-bin-runtime-policy-BP6ImlkB.js → exec-safe-bin-runtime-policy-CpMj95vJ.js} +2 -2
  76. package/dist/extensionAPI.js +6 -6
  77. package/dist/{fetch-DC-NMnAU.js → fetch-DOjg912W.js} +3 -3
  78. package/dist/{fetch-guard-B62rgaSw.js → fetch-guard-Csbz9pui.js} +1 -1
  79. package/dist/{fs-safe-CJDtl_QU.js → fs-safe-BqJ9egpm.js} +24 -24
  80. package/dist/{gateway-cli-BKhQZ6rL.js → gateway-cli-ADJ8WFzB.js} +267 -93
  81. package/dist/{gateway-cli-Cb1IDsaH.js → gateway-cli-D5wMqxbT.js} +423 -249
  82. package/dist/{gateway-rpc-BgV_ZJ92.js → gateway-rpc-DFqEAyI_.js} +1 -1
  83. package/dist/{health-DugDjq1f.js → health-Dzwp2cfK.js} +14 -14
  84. package/dist/{hooks-cli-VjmNvsLG.js → hooks-cli-DKAhHxZp.js} +84 -84
  85. package/dist/{hooks-status-DE20AAEu.js → hooks-status-6tcOdcYp.js} +1 -1
  86. package/dist/{image-BfqphdQM.js → image-BjuH1GKB.js} +5 -5
  87. package/dist/{image-DihIv8Eo.js → image-DQV2jl6F.js} +1 -1
  88. package/dist/{image-ops-BGTBZMuE.js → image-ops-B2L37gT8.js} +10 -10
  89. package/dist/index.js +1 -1
  90. package/dist/{inspect-DeP74OJO.js → inspect-DJUXn0vX.js} +4 -4
  91. package/dist/{install-safe-path-CWo3RPkH.js → install-safe-path-DVQh7rEs.js} +25 -25
  92. package/dist/{installs-BYqcA-ke.js → installs-jXfyPi74.js} +9 -9
  93. package/dist/{ipv4-BB1Ro6so.js → ipv4-DQS0lTwQ.js} +1 -1
  94. package/dist/{ir-DziC-P4Z.js → ir-CEwBpxhC.js} +6 -6
  95. package/dist/{issue-format-CqVkT3gT.js → issue-format-NBMJ5xAP.js} +1 -1
  96. package/dist/{json-files-CuJjdF_0.js → json-files-rR19q30D.js} +8 -8
  97. package/dist/{lifecycle-core-DAWYYqJl.js → lifecycle-core-oTVOKNSW.js} +5 -5
  98. package/dist/{login-CYfV0FRr.js → login-I5RlwiJn.js} +3 -3
  99. package/dist/{login-qr-DUSyrCPW.js → login-qr-CRjZn3ix.js} +6 -6
  100. package/dist/{logs-cli--IqfO6Fs.js → logs-cli-D2-73CiV.js} +9 -9
  101. package/dist/{manager-7hZXEYTj.js → manager-DWpiNvlg.js} +14 -14
  102. package/dist/{manifest-registry-Kbw8YPsZ.js → manifest-registry-CBF8Vfz8.js} +1 -1
  103. package/dist/{markdown-tables-BYHgyUjA.js → markdown-tables-DQlQMRGZ.js} +1 -1
  104. package/dist/{memory-cli-CuT-iG2F.js → memory-cli-BUrf60e_.js} +12 -12
  105. package/dist/{model-DmBmzJI6.js → model-DMZUvZJo.js} +2 -2
  106. package/dist/{model-catalog-D1X8r3WJ.js → model-catalog-DFi9HgWu.js} +3 -3
  107. package/dist/{model-picker-CrYHvOZH.js → model-picker-DFyoaAce.js} +4 -4
  108. package/dist/{models-BwUaRaeh.js → models-B-VHfTz-.js} +18 -18
  109. package/dist/{models-cli-DPvtAoJ-.js → models-cli-DQBbzn_p.js} +81 -81
  110. package/dist/{models-config-CmrBGsQs.js → models-config-AePb9RAo.js} +6 -6
  111. package/dist/{net-BXeYv7Iu.js → net-C75G4fup.js} +2 -2
  112. package/dist/{node-cli-Co4McDQy.js → node-cli-UnJ5obvj.js} +33 -33
  113. package/dist/{node-command-policy-D7hSN9B8.js → node-command-policy-DMwxqhrG.js} +1 -1
  114. package/dist/{node-service-CzRylWgI.js → node-service-83OYUi14.js} +1 -1
  115. package/dist/{nodes-cli-wABD1dZs.js → nodes-cli-U66EhW5E.js} +16 -16
  116. package/dist/{nodes-screen-DcxCMjOs.js → nodes-screen-BHwVUMr8.js} +7 -7
  117. package/dist/{npm-pack-install-BGN-e1vW.js → npm-pack-install-1gsZywqI.js} +18 -18
  118. package/dist/{npm-resolution-Dp9ywE7U.js → npm-resolution-ZwcMp-e1.js} +5 -5
  119. package/dist/{onboard-tlfs9gUN.js → onboard-1RaJpuJ4.js} +1 -1
  120. package/dist/{onboard-DfDL2v89.js → onboard-Ce_QcPvd.js} +6 -6
  121. package/dist/{onboard-channels-CjyJiI4i.js → onboard-channels-BLL6tVVk.js} +20 -20
  122. package/dist/{onboard-custom-WfZ3J4O7.js → onboard-custom-CltkNK3c.js} +3 -3
  123. package/dist/{onboard-custom.shared-D52ggtQF.js → onboard-custom.shared-CXzE62ZH.js} +2 -2
  124. package/dist/{onboard-helpers-CczYNQDJ.js → onboard-helpers-D8lLbK3A.js} +11 -11
  125. package/dist/{onboard-hooks-o0B0p8tR.js → onboard-hooks-DBif0Jq8.js} +4 -4
  126. package/dist/{onboard-remote-DTz_Z9Xl.js → onboard-remote-DpEjARZa.js} +3 -3
  127. package/dist/{onboard-skills-D70PenD-.js → onboard-skills-CL0tHf_N.js} +4 -4
  128. package/dist/{onboarding-H5cLNUFG.js → onboarding-Rub9MXWB.js} +1 -1
  129. package/dist/{onboarding-DNV-TKzA.js → onboarding-WDRpEgra.js} +13 -13
  130. package/dist/{onboarding.finalize-C6UdLnH3.js → onboarding.finalize-CWYrjSVx.js} +89 -89
  131. package/dist/{onboarding.finalize-DfZFzt37.js → onboarding.finalize-MTyP_Dr4.js} +3 -3
  132. package/dist/{onboarding.gateway-config-CnQR4xLI.js → onboarding.gateway-config-Ce8ndMkF.js} +18 -18
  133. package/dist/{openai-model-default-DqKKq57j.js → openai-model-default-XM-ZB1MD.js} +2 -2
  134. package/dist/{outbound-Dv-MM4iv.js → outbound-CHyBoNxD.js} +4 -4
  135. package/dist/{outbound-attachment-CXINK8df.js → outbound-attachment-DM-h2uQ1.js} +2 -2
  136. package/dist/{pairing-cli-BUHAN0R5.js → pairing-cli-DUMMuvWC.js} +9 -9
  137. package/dist/{pairing-labels-CFSUHOmk.js → pairing-labels-x4akYNb7.js} +1 -1
  138. package/dist/{pairing-store-BfzlN-z9.js → pairing-store-rFuiIoGM.js} +3 -3
  139. package/dist/{path-alias-guards-Cg9ZP1NN.js → path-alias-guards-laKq24fx.js} +3 -3
  140. package/dist/{path-safety-tZSbJG67.js → path-safety-BxYB92SS.js} +1 -1
  141. package/dist/{paths-BjoSX1aC.js → paths-B_L2Zoe-.js} +9 -9
  142. package/dist/{pi-embedded-xCcmCTnf.js → pi-embedded-CZAvX74y.js} +22 -22
  143. package/dist/{pi-embedded-helpers-C3sJPGXn.js → pi-embedded-helpers-BB2whkUz.js} +6 -6
  144. package/dist/{pi-embedded-helpers-Bmj18lhA.js → pi-embedded-helpers-DK1ft2pf.js} +3 -3
  145. package/dist/{pi-model-discovery-BZ2RCD_u.js → pi-model-discovery-RrejIg26.js} +1 -1
  146. package/dist/{pi-tools.policy-BH0D2kX0.js → pi-tools.policy-DRW8ya1z.js} +5 -5
  147. package/dist/{plugin-auto-enable-DER6qA6X.js → plugin-auto-enable-S_lBQAKI.js} +3 -3
  148. package/dist/{plugin-registry-CmucB2C0.js → plugin-registry-C2g1aLrK.js} +3 -3
  149. package/dist/{plugins-vsjS_m58.js → plugins-C4cYqW07.js} +2 -2
  150. package/dist/{plugins-cli-DJFtia9f.js → plugins-cli-Cdug93Mi.js} +86 -86
  151. package/dist/{ports-sCOQUaAP.js → ports-DRaxdQmm.js} +2 -2
  152. package/dist/{ports-zWusnrvP.js → ports-tfS1haOJ.js} +1 -1
  153. package/dist/{program-BkK1YIQS.js → program-L4hhvW67.js} +84 -84
  154. package/dist/{program-context-CFNQpYpG.js → program-context-BEPxCThZ.js} +7 -7
  155. package/dist/{prompt-select-styled-DlC5a1xd.js → prompt-select-styled-CYmsrkR3.js} +39 -39
  156. package/dist/{prompt-select-styled-DGdjezC8.js → prompt-select-styled-DTqU-r5T.js} +3 -3
  157. package/dist/{provider-auth-helpers-CJ2_W1oy.js → provider-auth-helpers-CNkIHUuF.js} +5 -5
  158. package/dist/{proxy-env-BQIJPH4j.js → proxy-env-BoopXu2J.js} +1 -1
  159. package/dist/{push-apns-BKjyYFyk.js → push-apns-DRX0c6-y.js} +5 -5
  160. package/dist/{pw-ai-pqeoAqm_.js → pw-ai-CMUrm_kS.js} +1 -1
  161. package/dist/{pw-ai-ITbRRqVN.js → pw-ai-DyGZ1pXu.js} +15 -15
  162. package/dist/{qmd-manager-BNohLpRA.js → qmd-manager-Bo22w5wm.js} +20 -20
  163. package/dist/{qr-cli-D-LqDNlm.js → qr-cli-EHSe4TmR.js} +1 -1
  164. package/dist/{query-expansion-BrM3X6-L.js → query-expansion-Ba9OpCm9.js} +12 -12
  165. package/dist/{redact-snapshot-D3QFNQl8.js → redact-snapshot-kY3aFpcF.js} +1 -1
  166. package/dist/{register.agent-C3K3DXul.js → register.agent-CaCz2lnX.js} +97 -97
  167. package/dist/register.configure-BHL2CNOY.js +174 -0
  168. package/dist/{register.init-ClMzXUKm.js → register.init-D4hlhvsq.js} +15 -15
  169. package/dist/{register.maintenance-Bb8amfJh.js → register.maintenance-DsxNo00b.js} +6 -6
  170. package/dist/{register.maintenance-zsZrRIaB.js → register.maintenance-MJR5bDWC.js} +99 -99
  171. package/dist/{register.message-CfRd6EM2.js → register.message-ChJGE4xV.js} +77 -77
  172. package/dist/{register.onboard-qFRFDsPK.js → register.onboard-4aB9FmjK.js} +2 -2
  173. package/dist/{register.onboard-BFM29BaY.js → register.onboard-CRCrMN8O.js} +18 -18
  174. package/dist/{register.setup-D0E9z_QW.js → register.setup-CCPeU8WO.js} +2 -2
  175. package/dist/{register.setup-Caqvvqmm.js → register.setup-DqRNRiXi.js} +21 -21
  176. package/dist/{register.start-CrwDVujg.js → register.start-D3IRihbV.js} +17 -17
  177. package/dist/{register.status-health-sessions-CWb4-Kgs.js → register.status-health-sessions-EhCB2a7v.js} +3 -3
  178. package/dist/{register.status-health-sessions-BBEF4th9.js → register.status-health-sessions-zD3z2YuT.js} +91 -91
  179. package/dist/{register.subclis-rB1Roe3w.js → register.subclis-D12iC4nF.js} +31 -31
  180. package/dist/{replies-Ckd7Lwt0.js → replies-BDnb0prE.js} +1 -1
  181. package/dist/{reply-prefix-DpXMFuAa.js → reply-prefix-H_GSyyzN.js} +1 -1
  182. package/dist/{resolve-route-Cnto8LMw.js → resolve-route-ByAwAiq5.js} +2 -2
  183. package/dist/{rpc-9G93KhBv.js → rpc-Bzb0JMJ_.js} +1 -1
  184. package/dist/{run-main-C02l3ZhV.js → run-main-C_fGUv-Y.js} +95 -95
  185. package/dist/{runtime-BI0xjrHi.js → runtime-Cx-7xFzl.js} +2 -2
  186. package/dist/{sandbox-CLIUxOtc.js → sandbox-BLqUWbp2.js} +18 -18
  187. package/dist/{sandbox-cli-MjHZjW2w.js → sandbox-cli-CEriRvUh.js} +26 -26
  188. package/dist/{secrets-cli-BFU9jh2A.js → secrets-cli-DG-NG8PH.js} +10 -10
  189. package/dist/{security-cli-DIfmEZrw.js → security-cli-C_Bc1U-7.js} +43 -43
  190. package/dist/{send-e1X1pfda.js → send-BCLu4NEE.js} +6 -6
  191. package/dist/{send-BpXRh0BM.js → send-BTswySBz.js} +11 -11
  192. package/dist/{send-CQJKPGw4.js → send-CZ2O-5pP.js} +6 -6
  193. package/dist/{send-sj8Hu26l.js → send-D0X-8aPh.js} +8 -8
  194. package/dist/{send-Cpaj_bKB.js → send-ZyB64ntO.js} +5 -5
  195. package/dist/{server-DbB5aXZq.js → server-CzDsmd9g.js} +19 -19
  196. package/dist/{server-context-DnPsW_Mg.js → server-context-DRq_OT33.js} +12 -12
  197. package/dist/{server-lifecycle-B2y6Fg7R.js → server-lifecycle-CcYnyYPQ.js} +2 -2
  198. package/dist/{server-middleware-CKSnhiM2.js → server-middleware-DHxnFjIL.js} +1 -1
  199. package/dist/{server-node-events-BwnXBzS2.js → server-node-events-B5xSV7Kq.js} +77 -77
  200. package/dist/{service-Wk285d-R.js → service-CZORJG4z.js} +15 -15
  201. package/dist/{session-meta-DF1WT4cr.js → session-meta-Cew1QAYN.js} +1 -1
  202. package/dist/{session-DNbfXbBi.js → session-nilNSQEL.js} +1 -1
  203. package/dist/{session-utils-BncMg1bn.js → session-utils-DxaIoRMp.js} +6 -6
  204. package/dist/{sessions-B2mnwD21.js → sessions-BXz4gdq6.js} +15 -15
  205. package/dist/{sessions-C2Xfck_9.js → sessions-DhD3eJDE.js} +4 -4
  206. package/dist/{shared-CJN2BLdi.js → shared-BZscafy-.js} +1 -1
  207. package/dist/{shared-BAdi_Ot7.js → shared-DvHQekWm.js} +3 -3
  208. package/dist/{skill-commands-CYucDd3C.js → skill-commands-Cpr3Poo2.js} +5 -5
  209. package/dist/{skill-scanner-BXOiOvI1.js → skill-scanner-0-AybMIe.js} +6 -6
  210. package/dist/{skills-BCgFAMj3.js → skills-D4S-gyVf.js} +3 -3
  211. package/dist/{skills-cli-CwbRKLum.js → skills-cli-B0jFsoo4.js} +5 -5
  212. package/dist/{skills-install-BQyeS7wB.js → skills-install-C6-Zzqoi.js} +6 -6
  213. package/dist/{skills-status-DG-bH5mO.js → skills-status-DQzBD0Y7.js} +1 -1
  214. package/dist/{status-B4v5QI5X.js → status-BfWqYNJf.js} +2 -2
  215. package/dist/{status-XGYDzhkW.js → status-Dw7ag8qn.js} +26 -26
  216. package/dist/{status.update-n2QPQr8w.js → status.update-B6whKviL.js} +2 -2
  217. package/dist/{status.update-DIamQqHr.js → status.update-C8qgou8r.js} +1 -1
  218. package/dist/{store-U8cs0QvT.js → store-TdzSHRPN.js} +5 -5
  219. package/dist/{subagent-registry-WD5F6cBf.js → subagent-registry-D6OfBLNb.js} +156 -156
  220. package/dist/{system-cli-C_5YHHhF.js → system-cli-BoamUpxz.js} +9 -9
  221. package/dist/{system-run-command-GKGzGztn.js → system-run-command-XHAlbx5q.js} +1 -1
  222. package/dist/{systemd-Dbwmb4TX.js → systemd-C4JtDaKk.js} +9 -9
  223. package/dist/{systemd-hints-VM2JkQxw.js → systemd-hints-ZHrBbXDd.js} +6 -6
  224. package/dist/{systemd-linger-DoeP9Z3f.js → systemd-linger-CD4viBmg.js} +1 -1
  225. package/dist/{tables-DVXe5x1J.js → tables-BOsRa7CS.js} +1 -1
  226. package/dist/{tailnet-C1XBcWue.js → tailnet-CfP3A6g2.js} +1 -1
  227. package/dist/{target-errors-C5LA-JI-.js → target-errors-DPJ9HFp9.js} +4 -4
  228. package/dist/{tool-images-CnpAosfi.js → tool-images-CmgHk8xk.js} +1 -1
  229. package/dist/{tui-kOoc7WBf.js → tui-GWJMI53u.js} +6 -6
  230. package/dist/{tui-cli-DeTfdnEG.js → tui-cli-CMrxH2Q_.js} +33 -33
  231. package/dist/{update-DFr19tQ1.js → update-CDWJ50iD.js} +3 -3
  232. package/dist/{update-cli-CUSnVFt4.js → update-cli-Dw_JHcRy.js} +22 -14
  233. package/dist/{update-cli-BlswPThb.js → update-cli-r3eyhSgp.js} +122 -114
  234. package/dist/{update-runner-CX6jOI_r.js → update-runner-CHxTFtW8.js} +34 -22
  235. package/dist/{update-runner-BA9B0S60.js → update-runner-CJua_LZ3.js} +19 -7
  236. package/dist/web-B4yuhy9a.js +125 -0
  237. package/dist/{web-CvYmNThc.js → web-De45Xhd1.js} +6 -6
  238. package/dist/{webhooks-cli-DLgCJq4n.js → webhooks-cli-B09BdLSk.js} +6 -6
  239. package/dist/{whatsapp-actions-B81EJMQI.js → whatsapp-actions-DUoWY7mE.js} +19 -19
  240. package/dist/{with-timeout-l0X_rwcb.js → with-timeout-B9qgOUui.js} +3 -3
  241. package/dist/{workspace-DWBFoy1G.js → workspace-A5CNJccm.js} +1 -1
  242. package/dist/{workspace-BHfqkuYN.js → workspace-DzeL98px.js} +23 -23
  243. package/dist/{workspace-dirs-BOgNOBjy.js → workspace-dirs-Bevk6X_8.js} +1 -1
  244. package/dist/{wsl-BDRu1-pk.js → wsl-DksyFTBT.js} +2 -2
  245. package/docs/install/index.md +12 -12
  246. package/docs/install/updating.md +32 -33
  247. package/docs/plans/2026-03-11-bitseek-update-package-design.md +25 -0
  248. package/package.json +1 -1
  249. package/dist/control-ui/assets/index-BlqD_sH7.js.map +0 -1
  250. package/dist/register.configure-aJItV_ZP.js +0 -174
  251. package/dist/web-DNL22pwf.js +0 -125
@@ -2,10 +2,10 @@ import { f as isRich, p as theme } from "./globals-B68W7uN8.js";
2
2
  import "./paths-BnKiOk2S.js";
3
3
  import { d as defaultRuntime } from "./subsystem-DjdBljTA.js";
4
4
  import "./boolean-DtWR5bt3.js";
5
- import "./auth-profiles-D_x1_5v_.js";
6
- import "./agent-scope-CJelRKYY.js";
5
+ import "./auth-profiles-CyG9VwU_.js";
6
+ import "./agent-scope-CY2-lUIY.js";
7
7
  import "./utils-DIzy5B5o.js";
8
- import "./workspace-BHfqkuYN.js";
8
+ import "./workspace-DzeL98px.js";
9
9
  import "./logger-BJMfryJd.js";
10
10
  import "./exec-CEAvKSx9.js";
11
11
  import "./github-copilot-token-CulJ9J5l.js";
@@ -13,26 +13,26 @@ import "./host-env-security-CJMD0__Z.js";
13
13
  import "./version-CGDNfh5C.js";
14
14
  import "./env-vars-Dw0EwyGP.js";
15
15
  import "./registry-7fg1BnMw.js";
16
- import "./manifest-registry-Kbw8YPsZ.js";
16
+ import "./manifest-registry-CBF8Vfz8.js";
17
17
  import "./message-channel-0J6eKf3g.js";
18
- import "./client-BvL3EdiZ.js";
19
- import "./call-CzoM7hPS.js";
18
+ import "./client-vUKV2o6h.js";
19
+ import "./call-CmAGfSJE.js";
20
20
  import "./pairing-token-DoBZxQnC.js";
21
- import "./net-BXeYv7Iu.js";
22
- import "./tailnet-C1XBcWue.js";
23
- import "./exec-approvals-allowlist-B4DS6FIn.js";
21
+ import "./net-C75G4fup.js";
22
+ import "./tailnet-CfP3A6g2.js";
23
+ import "./exec-approvals-allowlist-CFjPSbxI.js";
24
24
  import { n as formatTimeAgo } from "./format-relative-DlCMhQXD.js";
25
25
  import { c as readExecApprovalsSnapshot, p as saveExecApprovals } from "./exec-approvals-HRn5F9dF.js";
26
26
  import { t as formatDocsLink } from "./links-BDNlbZvM.js";
27
27
  import "./progress-CwQKn0ae.js";
28
- import { n as callGatewayFromCli } from "./gateway-rpc-BgV_ZJ92.js";
29
- import "./systemd-Dbwmb4TX.js";
30
- import "./service-Wk285d-R.js";
28
+ import { n as callGatewayFromCli } from "./gateway-rpc-DFqEAyI_.js";
29
+ import "./systemd-C4JtDaKk.js";
30
+ import "./service-CZORJG4z.js";
31
31
  import { t as renderTable } from "./table-BHL_2Py1.js";
32
- import { t as describeUnknownError } from "./shared-CJN2BLdi.js";
33
- import { a as resolveNodeId, r as nodesCallOpts } from "./rpc-9G93KhBv.js";
32
+ import { t as describeUnknownError } from "./shared-BZscafy-.js";
33
+ import { a as resolveNodeId, r as nodesCallOpts } from "./rpc-Bzb0JMJ_.js";
34
34
  import JSON5 from "json5";
35
- import fs from "node:fs/promises";
35
+ import fsPromises from "node:fs/promises";
36
36
 
37
37
  //#region src/cli/exec-approvals-cli.ts
38
38
  async function readStdin() {
@@ -329,7 +329,7 @@ function registerExecApprovalsCli(program) {
329
329
  if (!opts.file && !opts.stdin) exitWithError("Provide --file or --stdin.");
330
330
  if (opts.file && opts.stdin) exitWithError("Use either --file or --stdin (not both).");
331
331
  const { source, nodeId, targetLabel, baseHash } = await loadWritableSnapshotTarget(opts);
332
- const raw = opts.stdin ? await readStdin() : await fs.readFile(String(opts.file), "utf8");
332
+ const raw = opts.stdin ? await readStdin() : await fsPromises.readFile(String(opts.file), "utf8");
333
333
  let file;
334
334
  try {
335
335
  file = JSON5.parse(raw);
@@ -1,5 +1,5 @@
1
- import { Ut as listWritableExplicitTrustedSafeBinDirs, Vt as getTrustedSafeBinDirs, Wt as normalizeTrustedSafeBinDirs, _n as normalizeSafeBinProfileFixtures, vn as resolveSafeBinProfiles } from "./auth-profiles-D_x1_5v_.js";
2
- import { i as resolveSafeBins } from "./exec-approvals-allowlist-B4DS6FIn.js";
1
+ import { Ut as listWritableExplicitTrustedSafeBinDirs, Vt as getTrustedSafeBinDirs, Wt as normalizeTrustedSafeBinDirs, _n as normalizeSafeBinProfileFixtures, vn as resolveSafeBinProfiles } from "./auth-profiles-CyG9VwU_.js";
2
+ import { i as resolveSafeBins } from "./exec-approvals-allowlist-CFjPSbxI.js";
3
3
 
4
4
  //#region src/infra/exec-safe-bin-runtime-policy.ts
5
5
  const INTERPRETER_LIKE_SAFE_BINS = new Set([
@@ -10,13 +10,13 @@ import "./env-zky96nK6.js";
10
10
  import "./registry-BOq-EU8K.js";
11
11
  import "./dock-L5TLZmhV.js";
12
12
  import "./tokens-2c_yMaYC.js";
13
- import { P as resolveAgentTimeoutMs, t as runEmbeddedPiAgent } from "./pi-embedded-xCcmCTnf.js";
13
+ import { P as resolveAgentTimeoutMs, t as runEmbeddedPiAgent } from "./pi-embedded-CZAvX74y.js";
14
14
  import "./plugins-BuQyooWr.js";
15
15
  import "./accounts-DYfFud2l.js";
16
16
  import "./bindings-Cn3Pwuys.js";
17
17
  import "./send-paWifUry.js";
18
18
  import "./send-BpJIVMP0.js";
19
- import "./deliver-Dyh8ZsLI.js";
19
+ import "./deliver-Z7543EnP.js";
20
20
  import "./diagnostic-Co8pKHgV.js";
21
21
  import "./diagnostic-session-state-iIgQ4O9h.js";
22
22
  import "./accounts-BvAUwnNS.js";
@@ -24,8 +24,8 @@ import "./send-CIQavYDH.js";
24
24
  import "./image-ops-CSs8oYrR.js";
25
25
  import "./pi-model-discovery-DpYZ-y1X.js";
26
26
  import "./message-channel-B1_JjaQ_.js";
27
- import "./pi-embedded-helpers-Bmj18lhA.js";
28
- import "./chrome-CuMCXCQN.js";
27
+ import "./pi-embedded-helpers-DK1ft2pf.js";
28
+ import "./chrome-xatreDUO.js";
29
29
  import "./skills-Z-lrvzqS.js";
30
30
  import "./path-alias-guards-BaYeiedF.js";
31
31
  import "./redact-b4XSqAVh.js";
@@ -38,8 +38,8 @@ import "./accounts-B1Ev8y2Q.js";
38
38
  import { n as resolveSessionFilePath, s as resolveStorePath } from "./paths-BmEQm4ho.js";
39
39
  import "./tool-images-BOZsvFJ9.js";
40
40
  import "./thinking-kXAj2UX9.js";
41
- import "./image-DihIv8Eo.js";
42
- import "./audio-transcription-runner-DwWOJBSn.js";
41
+ import "./image-DQV2jl6F.js";
42
+ import "./audio-transcription-runner-CGsd7139.js";
43
43
  import "./fetch-BfCWv6tx.js";
44
44
  import "./fetch-guard-DfeA6yKv.js";
45
45
  import "./api-key-rotation-Bcht0XFN.js";
@@ -1,8 +1,8 @@
1
1
  import { k as resolvePreferredOpenClawTmpDir } from "./globals-B68W7uN8.js";
2
2
  import { g as resolveStateDir } from "./paths-BnKiOk2S.js";
3
- import { u as resolveAgentWorkspaceDir } from "./agent-scope-CJelRKYY.js";
4
- import { c as detectMime, l as extensionForMime } from "./image-ops-BGTBZMuE.js";
5
- import { n as withStrictGuardedFetchMode, t as fetchWithSsrFGuard } from "./fetch-guard-B62rgaSw.js";
3
+ import { u as resolveAgentWorkspaceDir } from "./agent-scope-CY2-lUIY.js";
4
+ import { c as detectMime, l as extensionForMime } from "./image-ops-B2L37gT8.js";
5
+ import { n as withStrictGuardedFetchMode, t as fetchWithSsrFGuard } from "./fetch-guard-Csbz9pui.js";
6
6
  import path from "node:path";
7
7
 
8
8
  //#region src/media/local-roots.ts
@@ -1,5 +1,5 @@
1
1
  import { i as logWarn } from "./logger-BJMfryJd.js";
2
- import { i as createPinnedDispatcher, n as SsrFBlockedError, r as closeDispatcher, s as resolvePinnedHostnameWithPolicy, t as hasProxyEnvConfigured } from "./proxy-env-BQIJPH4j.js";
2
+ import { i as createPinnedDispatcher, n as SsrFBlockedError, r as closeDispatcher, s as resolvePinnedHostnameWithPolicy, t as hasProxyEnvConfigured } from "./proxy-env-BoopXu2J.js";
3
3
  import { t as bindAbortRelay } from "./fetch-timeout-CZWuvzq4.js";
4
4
  import { EnvHttpProxyAgent } from "undici";
5
5
 
@@ -1,11 +1,11 @@
1
1
  import { _ as expandHomePrefix } from "./paths-BnKiOk2S.js";
2
- import { A as isNotFoundPathError, M as isSymlinkOpenError, T as sameFileIdentity, j as isPathInside, k as hasNodeErrorCode } from "./workspace-BHfqkuYN.js";
2
+ import { A as isNotFoundPathError, M as isSymlinkOpenError, T as sameFileIdentity, j as isPathInside, k as hasNodeErrorCode } from "./workspace-DzeL98px.js";
3
3
  import { i as logWarn } from "./logger-BJMfryJd.js";
4
- import { n as assertNoPathAliasEscape } from "./path-alias-guards-Cg9ZP1NN.js";
4
+ import { n as assertNoPathAliasEscape } from "./path-alias-guards-laKq24fx.js";
5
5
  import path from "node:path";
6
6
  import os from "node:os";
7
7
  import { constants } from "node:fs";
8
- import fs$1 from "node:fs/promises";
8
+ import fsPromises from "node:fs/promises";
9
9
  import { randomUUID } from "node:crypto";
10
10
  import { pipeline } from "node:stream/promises";
11
11
 
@@ -25,19 +25,19 @@ const ensureTrailingSep = (value) => value.endsWith(path.sep) ? value : value +
25
25
  async function expandRelativePathWithHome(relativePath) {
26
26
  let home = process.env.HOME || process.env.USERPROFILE || os.homedir();
27
27
  try {
28
- home = await fs$1.realpath(home);
28
+ home = await fsPromises.realpath(home);
29
29
  } catch {}
30
30
  return expandHomePrefix(relativePath, { home });
31
31
  }
32
32
  async function openVerifiedLocalFile(filePath, options) {
33
33
  try {
34
- if ((await fs$1.lstat(filePath)).isDirectory()) throw new SafeOpenError("not-file", "not a file");
34
+ if ((await fsPromises.lstat(filePath)).isDirectory()) throw new SafeOpenError("not-file", "not a file");
35
35
  } catch (err) {
36
36
  if (err instanceof SafeOpenError) throw err;
37
37
  }
38
38
  let handle;
39
39
  try {
40
- handle = await fs$1.open(filePath, OPEN_READ_FLAGS);
40
+ handle = await fsPromises.open(filePath, OPEN_READ_FLAGS);
41
41
  } catch (err) {
42
42
  if (isNotFoundPathError(err)) throw new SafeOpenError("not-found", "file not found");
43
43
  if (isSymlinkOpenError(err)) throw new SafeOpenError("symlink", "symlink open blocked", { cause: err });
@@ -45,13 +45,13 @@ async function openVerifiedLocalFile(filePath, options) {
45
45
  throw err;
46
46
  }
47
47
  try {
48
- const [stat, lstat] = await Promise.all([handle.stat(), fs$1.lstat(filePath)]);
48
+ const [stat, lstat] = await Promise.all([handle.stat(), fsPromises.lstat(filePath)]);
49
49
  if (lstat.isSymbolicLink()) throw new SafeOpenError("symlink", "symlink not allowed");
50
50
  if (!stat.isFile()) throw new SafeOpenError("not-file", "not a file");
51
51
  if (options?.rejectHardlinks && stat.nlink > 1) throw new SafeOpenError("invalid-path", "hardlinked path not allowed");
52
52
  if (!sameFileIdentity(stat, lstat)) throw new SafeOpenError("path-mismatch", "path changed during read");
53
- const realPath = await fs$1.realpath(filePath);
54
- const realStat = await fs$1.stat(realPath);
53
+ const realPath = await fsPromises.realpath(filePath);
54
+ const realStat = await fsPromises.stat(realPath);
55
55
  if (options?.rejectHardlinks && realStat.nlink > 1) throw new SafeOpenError("invalid-path", "hardlinked path not allowed");
56
56
  if (!sameFileIdentity(stat, realStat)) throw new SafeOpenError("path-mismatch", "path mismatch");
57
57
  return {
@@ -69,7 +69,7 @@ async function openVerifiedLocalFile(filePath, options) {
69
69
  async function resolvePathWithinRoot(params) {
70
70
  let rootReal;
71
71
  try {
72
- rootReal = await fs$1.realpath(params.rootDir);
72
+ rootReal = await fsPromises.realpath(params.rootDir);
73
73
  } catch (err) {
74
74
  if (isNotFoundPathError(err)) throw new SafeOpenError("not-found", "root dir not found");
75
75
  throw err;
@@ -170,7 +170,7 @@ function buildAtomicWriteTempPath(targetPath) {
170
170
  return path.join(dir, `.${base}.${process.pid}.${randomUUID()}.tmp`);
171
171
  }
172
172
  async function writeTempFileForAtomicReplace(params) {
173
- const tempHandle = await fs$1.open(params.tempPath, OPEN_WRITE_CREATE_FLAGS, params.mode);
173
+ const tempHandle = await fsPromises.open(params.tempPath, OPEN_WRITE_CREATE_FLAGS, params.mode);
174
174
  try {
175
175
  if (typeof params.data === "string") await tempHandle.writeFile(params.data, params.encoding ?? "utf8");
176
176
  else await tempHandle.writeFile(params.data);
@@ -180,7 +180,7 @@ async function writeTempFileForAtomicReplace(params) {
180
180
  }
181
181
  }
182
182
  async function verifyAtomicWriteResult(params) {
183
- const rootWithSep = ensureTrailingSep(await fs$1.realpath(params.rootDir));
183
+ const rootWithSep = ensureTrailingSep(await fsPromises.realpath(params.rootDir));
184
184
  const opened = await openVerifiedLocalFile(params.targetPath, { rejectHardlinks: true });
185
185
  try {
186
186
  if (!sameFileIdentity(opened.stat, params.expectedStat)) throw new SafeOpenError("path-mismatch", "path changed during write");
@@ -191,13 +191,13 @@ async function verifyAtomicWriteResult(params) {
191
191
  }
192
192
  async function resolveOpenedFileRealPathForHandle(handle, ioPath) {
193
193
  try {
194
- return await fs$1.realpath(ioPath);
194
+ return await fsPromises.realpath(ioPath);
195
195
  } catch (err) {
196
196
  if (!isNotFoundPathError(err)) throw err;
197
197
  }
198
198
  const fdCandidates = process.platform === "linux" ? [`/proc/self/fd/${handle.fd}`, `/dev/fd/${handle.fd}`] : process.platform === "win32" ? [] : [`/dev/fd/${handle.fd}`];
199
199
  for (const fdPath of fdCandidates) try {
200
- return await fs$1.realpath(fdPath);
200
+ return await fsPromises.realpath(fdPath);
201
201
  } catch {}
202
202
  throw new SafeOpenError("path-mismatch", "unable to resolve opened file path");
203
203
  }
@@ -212,10 +212,10 @@ async function openWritableFileWithinRoot(params) {
212
212
  } catch (err) {
213
213
  throw new SafeOpenError("invalid-path", "path alias escape blocked", { cause: err });
214
214
  }
215
- if (params.mkdir !== false) await fs$1.mkdir(path.dirname(resolved), { recursive: true });
215
+ if (params.mkdir !== false) await fsPromises.mkdir(path.dirname(resolved), { recursive: true });
216
216
  let ioPath = resolved;
217
217
  try {
218
- const resolvedRealPath = await fs$1.realpath(resolved);
218
+ const resolvedRealPath = await fsPromises.realpath(resolved);
219
219
  if (!isPathInside(rootWithSep, resolvedRealPath)) throw new SafeOpenError("outside-workspace", "file is outside workspace root");
220
220
  ioPath = resolvedRealPath;
221
221
  } catch (err) {
@@ -227,10 +227,10 @@ async function openWritableFileWithinRoot(params) {
227
227
  let createdForWrite = false;
228
228
  try {
229
229
  try {
230
- handle = await fs$1.open(ioPath, OPEN_WRITE_EXISTING_FLAGS, fileMode);
230
+ handle = await fsPromises.open(ioPath, OPEN_WRITE_EXISTING_FLAGS, fileMode);
231
231
  } catch (err) {
232
232
  if (!isNotFoundPathError(err)) throw err;
233
- handle = await fs$1.open(ioPath, OPEN_WRITE_CREATE_FLAGS, fileMode);
233
+ handle = await fsPromises.open(ioPath, OPEN_WRITE_CREATE_FLAGS, fileMode);
234
234
  createdForWrite = true;
235
235
  }
236
236
  } catch (err) {
@@ -244,7 +244,7 @@ async function openWritableFileWithinRoot(params) {
244
244
  if (!stat.isFile()) throw new SafeOpenError("invalid-path", "path is not a regular file under root");
245
245
  if (stat.nlink > 1) throw new SafeOpenError("invalid-path", "hardlinked path not allowed");
246
246
  try {
247
- const lstat = await fs$1.lstat(ioPath);
247
+ const lstat = await fsPromises.lstat(ioPath);
248
248
  if (lstat.isSymbolicLink() || !lstat.isFile()) throw new SafeOpenError("invalid-path", "path is not a regular file under root");
249
249
  if (!sameFileIdentity(stat, lstat)) throw new SafeOpenError("path-mismatch", "path changed during write");
250
250
  } catch (err) {
@@ -252,7 +252,7 @@ async function openWritableFileWithinRoot(params) {
252
252
  }
253
253
  const realPath = await resolveOpenedFileRealPathForHandle(handle, ioPath);
254
254
  openedRealPath = realPath;
255
- const realStat = await fs$1.stat(realPath);
255
+ const realStat = await fsPromises.stat(realPath);
256
256
  if (!sameFileIdentity(stat, realStat)) throw new SafeOpenError("path-mismatch", "path mismatch");
257
257
  if (realStat.nlink > 1) throw new SafeOpenError("invalid-path", "hardlinked path not allowed");
258
258
  if (!isPathInside(rootWithSep, realPath)) throw new SafeOpenError("outside-workspace", "file is outside workspace root");
@@ -267,7 +267,7 @@ async function openWritableFileWithinRoot(params) {
267
267
  const cleanupCreatedPath = createdForWrite && err instanceof SafeOpenError;
268
268
  const cleanupPath = openedRealPath ?? ioPath;
269
269
  await handle.close().catch(() => {});
270
- if (cleanupCreatedPath) await fs$1.rm(cleanupPath, { force: true }).catch(() => {});
270
+ if (cleanupCreatedPath) await fsPromises.rm(cleanupPath, { force: true }).catch(() => {});
271
271
  throw err;
272
272
  }
273
273
  }
@@ -290,7 +290,7 @@ async function writeFileWithinRoot(params) {
290
290
  encoding: params.encoding,
291
291
  mode: targetMode || 384
292
292
  });
293
- await fs$1.rename(tempPath, destinationPath);
293
+ await fsPromises.rename(tempPath, destinationPath);
294
294
  tempPath = null;
295
295
  try {
296
296
  await verifyAtomicWriteResult({
@@ -303,7 +303,7 @@ async function writeFileWithinRoot(params) {
303
303
  throw err;
304
304
  }
305
305
  } finally {
306
- if (tempPath) await fs$1.rm(tempPath, { force: true }).catch(() => {});
306
+ if (tempPath) await fsPromises.rm(tempPath, { force: true }).catch(() => {});
307
307
  }
308
308
  }
309
309
  async function copyFileWithinRoot(params) {
@@ -331,7 +331,7 @@ async function copyFileWithinRoot(params) {
331
331
  });
332
332
  await pipeline(sourceStream, targetStream);
333
333
  } catch (err) {
334
- if (target?.createdForWrite) await fs$1.rm(target.openedRealPath, { force: true }).catch(() => {});
334
+ if (target?.createdForWrite) await fsPromises.rm(target.openedRealPath, { force: true }).catch(() => {});
335
335
  throw err;
336
336
  } finally {
337
337
  if (!sourceClosedByStream) await source.handle.close().catch(() => {});