@pixelzx/genesis 2026.6.4 → 2026.6.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.
- package/CHANGELOG.md +18 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-CcNxEsSq.js +201 -0
- package/dist/abort.runtime-DZJDSf0d.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-B7M6y8l8.js +107 -0
- package/dist/accounts-DddcYo7u.js +2 -0
- package/dist/accounts-v0Cqfnse.js +104 -0
- package/dist/acp-cli-D_2_Nim8.js +2193 -0
- package/dist/acp-spawn-BZPupfsZ.js +2 -0
- package/dist/acp-spawn-CWfIrbK7.js +1093 -0
- package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
- package/dist/action-agents-fjIM4rpc.js +67 -0
- package/dist/action-focus-cx1pm1ym.js +132 -0
- package/dist/action-help-DtyAnULB.js +7 -0
- package/dist/action-info-DF30-xZl.js +101 -0
- package/dist/action-kill-rsSdXzvX.js +33 -0
- package/dist/action-list-4VN835m2.js +21 -0
- package/dist/action-log-L032mq5B.js +30 -0
- package/dist/action-send-Dm62UP-n.js +39 -0
- package/dist/action-spawn-BuZHKlpL.js +47 -0
- package/dist/action-unfocus-CTIWf8WX.js +29 -0
- package/dist/actions.runtime-0ezEcm7K.js +18 -0
- package/dist/actions.runtime-DKsCTTnH.js +5 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-BTOBOCIw.js +2 -0
- package/dist/agent-command-C-_EFUUu.js +874 -0
- package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
- package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
- package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-D1LIGcNj.js +18 -0
- package/dist/agents-CME2O1l9.js +5 -0
- package/dist/agents-DsDQvAPy.js +954 -0
- package/dist/aliases-C807OidC.js +2 -0
- package/dist/aliases-jq1ap6Dz.js +96 -0
- package/dist/api-BbxKoRkD.js +3 -0
- package/dist/api-CwJPCW9U.js +139 -0
- package/dist/api-N5Kaaq64.js +5 -0
- package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
- package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
- package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
- package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
- package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
- package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
- package/dist/audit-DsDfRhB8.js +939 -0
- package/dist/audit.runtime-ComjcUGJ.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-BT_gqC-D.js +2 -0
- package/dist/auth-DeUz_8w8.js +383 -0
- package/dist/auth-order-DM7UkPDa.js +96 -0
- package/dist/auth-order-yS8hXrXh.js +2 -0
- package/dist/bash-tools-D0M9gBDu.js +3 -0
- package/dist/bash-tools-tnj1gSbO.js +2824 -0
- package/dist/binding-routing-C7atXiTD.js +85 -0
- package/dist/binding-targets-CCv7agx9.js +121 -0
- package/dist/bridge-server-C5O9rTJg.js +113 -0
- package/dist/browser-control-auth-GGN_kbqE.js +2 -0
- package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
- package/dist/browser-profiles-Dex2eaLH.js +2 -0
- package/dist/browser-runtime-BPocB6yO.js +387 -0
- package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
- package/dist/build-BqG7RkBz.js +550 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +2 -2
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/call-BI4JvjcR.js +3 -0
- package/dist/call-wY43fzOF.js +331 -0
- package/dist/call.runtime-Dh61oVeL.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-BHz-2Stx.js +1401 -0
- package/dist/catchup-Be7tHJwK.js +300 -0
- package/dist/channel-B-6VmF4-.js +840 -0
- package/dist/channel-BCJccV-O.js +226 -0
- package/dist/channel-BDZqLbod.js +1100 -0
- package/dist/channel-BQDNgTea.js +1174 -0
- package/dist/channel-BwjThGwK.js +453 -0
- package/dist/channel-CPoThmda.js +595 -0
- package/dist/channel-CUT8NJ-B.js +350 -0
- package/dist/channel-C_Y7lv8v.js +491 -0
- package/dist/channel-Ck7-C-lB.js +297 -0
- package/dist/channel-DOpVjq4i.js +1802 -0
- package/dist/channel-core-QV9-eAtb.js +5 -0
- package/dist/channel-inbound-D_tebgdx.js +31 -0
- package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
- package/dist/channel-runtime-D4ci0o4V.js +425 -0
- package/dist/channel-sAdF_zH-.js +1320 -0
- package/dist/channel.runtime-1swLIpNV.js +89 -0
- package/dist/channel.runtime-B9hljdNF.js +4 -0
- package/dist/channel.runtime-CSbR2pni.js +430 -0
- package/dist/channel.runtime-CdpqhnLO.js +2364 -0
- package/dist/channel.runtime-DOx6WROg.js +40130 -0
- package/dist/channel.runtime-H5Kb2LbC.js +109 -0
- package/dist/channel.runtime-V7boBc_e.js +576 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-BXyeNJ2_.js +10 -0
- package/dist/channels-KU7bwUUs.js +733 -0
- package/dist/channels-cli-CTX6_5z3.js +268 -0
- package/dist/chat-C_i6Wp50.js +2830 -0
- package/dist/clawbot-cli-CLGPtbt-.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-BhwHu1dK.js +72 -0
- package/dist/cli-CFsq8f2H.js +2 -0
- package/dist/cli-CNVlwurq.js +219 -0
- package/dist/cli-DLP8hKbi.js +2 -0
- package/dist/cli-runner-BbNBHV6v.js +286 -0
- package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
- package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli.runtime-3cD-pSyn.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-Bl0d_7ak.js +138 -0
- package/dist/client-ClJyHgmq.js +713 -0
- package/dist/command-auth-DO32coey.js +76 -0
- package/dist/command-config-resolution-CAsa4fGg.js +2 -0
- package/dist/command-config-resolution-D6YcwuRh.js +23 -0
- package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-registry-BJEQrMqR.js +4 -0
- package/dist/command-registry-DI9i95nj.js +9 -0
- package/dist/command-registry-core-BpF1mggD.js +106 -0
- package/dist/command-secret-gateway-DDNHxysD.js +528 -0
- package/dist/command-status.runtime-DqYUCcEA.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-C_zCJPvL.js +77 -0
- package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-BgZ64sA8.js +16 -0
- package/dist/commands-status.runtime-JI89gIEU.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
- package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-B7moUaCI.js +158 -0
- package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
- package/dist/commands.runtime-BjCVVqol.js +167 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-BNJH56SX.js +1118 -0
- package/dist/compact.runtime-CYI8Yi9d.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-Bb1Tk-vM.js +328 -0
- package/dist/config-DxkleHmo.js +252 -0
- package/dist/config-cli-CtaRB_f8.js +1078 -0
- package/dist/configure-Bp8WFryM.js +1252 -0
- package/dist/configure-DQ_X5zyT.js +2 -0
- package/dist/connect-options-BkWD0Wvv.js +699 -0
- package/dist/control-auth-Iqyldslx.js +125 -0
- package/dist/control-service-xIhkqyZE.js +156 -0
- package/dist/control-ui/assets/agents-Dh_TAFxm.js +1052 -0
- package/dist/control-ui/assets/canvas-BBkF0c_Z.js +269 -0
- package/dist/control-ui/assets/channel-config-extras-CNdHdere.js +2 -0
- package/dist/control-ui/assets/channels-DxBxgFLI.js +463 -0
- package/dist/control-ui/assets/cron-DI85RTUE.js +933 -0
- package/dist/control-ui/assets/de-ona0Q7Bc.js +2 -0
- package/dist/control-ui/assets/debug-DnDu2pj9.js +94 -0
- package/dist/control-ui/assets/es-Dn-oNRUH.js +2 -0
- package/dist/control-ui/assets/format-BvrOTETl.js +9 -0
- package/dist/control-ui/assets/fr-DXJ2RnNl.js +2 -0
- package/dist/control-ui/assets/i18n-BiXTtoQW.js +3 -0
- package/dist/control-ui/assets/id-BWsRmAR3.js +2 -0
- package/dist/control-ui/assets/index-YAwpI05T.js +6366 -0
- package/dist/control-ui/assets/instances-CRNiJVGJ.js +57 -0
- package/dist/control-ui/assets/ja-JP-BUkQN13S.js +2 -0
- package/dist/control-ui/assets/ko-Q_K13wyH.js +2 -0
- package/dist/control-ui/assets/logs-CzRlG5kP.js +74 -0
- package/dist/control-ui/assets/mcp-CAYQSRMs.js +373 -0
- package/dist/control-ui/assets/nodes-92SUclba.js +618 -0
- package/dist/control-ui/assets/pl-WlhlBCqd.js +2 -0
- package/dist/control-ui/assets/plugins-TwSBb6p5.js +273 -0
- package/dist/control-ui/assets/pt-BR-CVchspYo.js +2 -0
- package/dist/control-ui/assets/sessions-CHmx5D2H.js +306 -0
- package/dist/control-ui/assets/skills-C-34EOwN.js +323 -0
- package/dist/control-ui/assets/skills-shared-BbxW-wNm.js +11 -0
- package/dist/control-ui/assets/th-C4FUN3Mq.js +2 -0
- package/dist/control-ui/assets/tr-CoySBXqw.js +2 -0
- package/dist/control-ui/assets/uk-C-mkZs9j.js +2 -0
- package/dist/control-ui/assets/wallet-DjjoYuDY.js +285 -0
- package/dist/control-ui/assets/zh-CN-B7HXiLrY.js +2 -0
- package/dist/control-ui/assets/zh-TW-CKLRstBM.js +2 -0
- package/dist/control-ui/index.html +3 -3
- package/dist/conversation-id-BZtOqHIz.js +38 -0
- package/dist/conversation-id-D1Q9qPFH.js +235 -0
- package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
- package/dist/core-BdVAy0Wv.js +275 -0
- package/dist/cron-cli-BWM2kRKU.js +713 -0
- package/dist/daemon-cli-MRl5nyuF.js +12 -0
- package/dist/dashboard-BkdlJrnf.js +2 -0
- package/dist/dashboard-C9m86rHv.js +81 -0
- package/dist/delegate-BjUvKQlo.js +64 -0
- package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
- package/dist/devices-cli-B1n6tl9f.js +498 -0
- package/dist/diagnostics-DZxWkW3i.js +154 -0
- package/dist/direct-dm-qw-uk31C.js +64 -0
- package/dist/dispatch-D0xiJ6Up.js +1131 -0
- package/dist/dispatch-acp-DVN58m9G.js +981 -0
- package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
- package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
- package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
- package/dist/doctor-health-DKpg1bxM.js +59 -0
- package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
- package/dist/doctor-prompter-CLf5Uf10.js +56 -0
- package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
- package/dist/dreaming-Bk8dVfGi.js +1574 -0
- package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
- package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.js +2 -2
- package/dist/exec-approvals-cli-CnNETs_u.js +498 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/bluebubbles/api.js +3 -3
- package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
- package/dist/extensions/browser/browser-bridge.js +1 -1
- package/dist/extensions/browser/browser-config.js +4 -4
- package/dist/extensions/browser/browser-control-auth.js +2 -2
- package/dist/extensions/browser/browser-doctor.js +2 -2
- package/dist/extensions/browser/browser-maintenance.js +2 -2
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +10 -10
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +3 -3
- package/dist/extensions/browser/runtime-api.js +11 -11
- package/dist/extensions/browser/test-support.js +1 -1
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/index.js +3 -3
- package/dist/extensions/device-pair/notify.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/google-meet/index.js +2 -2
- package/dist/extensions/imessage/api.js +3 -3
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/runtime-api.js +3 -3
- package/dist/extensions/irc/api.js +2 -2
- package/dist/extensions/irc/channel-plugin-api.js +1 -1
- package/dist/extensions/line/api.js +2 -2
- package/dist/extensions/line/channel-plugin-api.js +1 -1
- package/dist/extensions/line/contract-api.js +1 -1
- package/dist/extensions/line/runtime-api.js +4 -4
- package/dist/extensions/line/setup-api.js +1 -1
- package/dist/extensions/llm-task/index.js +2 -2
- package/dist/extensions/lobster/index.js +3 -3
- package/dist/extensions/lobster/runtime-api.js +1 -1
- package/dist/extensions/mattermost/api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
- package/dist/extensions/mattermost/policy-api.js +1 -1
- package/dist/extensions/mattermost/runtime-api.js +4 -4
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +2 -2
- package/dist/extensions/memory-core/index.js +3 -3
- package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
- package/dist/extensions/msteams/api.js +1 -1
- package/dist/extensions/msteams/channel-plugin-api.js +1 -1
- package/dist/extensions/msteams/runtime-api.js +3 -3
- package/dist/extensions/msteams/test-api.js +1 -1
- package/dist/extensions/nextcloud-talk/api.js +1 -1
- package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
- package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
- package/dist/extensions/openshell/index.js +2 -2
- package/dist/extensions/signal/api.js +6 -6
- package/dist/extensions/signal/channel-plugin-api.js +1 -1
- package/dist/extensions/signal/reaction-runtime-api.js +1 -1
- package/dist/extensions/signal/runtime-api.js +7 -7
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.js +1 -1
- package/dist/extensions/synology-chat/api.js +1 -1
- package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/api.js +2 -2
- package/dist/extensions/tlon/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/runtime-api.js +1 -1
- package/dist/extensions/tlon/test-api.js +1 -1
- package/dist/extensions/twitch/api.js +1 -1
- package/dist/extensions/twitch/channel-plugin-api.js +1 -1
- package/dist/extensions/twitch/setup-plugin-api.js +1 -1
- package/dist/extensions/zalo/api.js +3 -3
- package/dist/extensions/zalo/channel-plugin-api.js +1 -1
- package/dist/extensions/zalo/runtime-api.js +2 -2
- package/dist/extensions/zalo/setup-api.js +2 -2
- package/dist/extensions/zalouser/api.js +3 -3
- package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
- package/dist/extensions/zalouser/runtime-api.js +6 -6
- package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
- package/dist/extensions/zalouser/test-api.js +1 -1
- package/dist/fallbacks-BwNexEVP.js +31 -0
- package/dist/fallbacks-GwVAaFt5.js +2 -0
- package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
- package/dist/gateway-BB4hdlYm.js +115 -0
- package/dist/gateway-cli-Bzz62NC8.js +1283 -0
- package/dist/gateway-rpc-dyJV2osv.js +14 -0
- package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-CqSQCYo0.js +15 -0
- package/dist/gateway-status-DdCiwrPt.js +584 -0
- package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
- package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/get-reply-qVmTjhwr.js +3897 -0
- package/dist/graph-users-kkSJYBNX.js +1337 -0
- package/dist/health-CFyVDYng.js +469 -0
- package/dist/health-Cl371mu8.js +3 -0
- package/dist/health-route-D0IspgUK.js +41 -0
- package/dist/health-route-D2tFKCLv.js +2 -0
- package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
- package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
- package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-cli-DYoG7Dz1.js +433 -0
- package/dist/image-fallbacks-5ckuJ46I.js +31 -0
- package/dist/image-fallbacks-DYnqzK01.js +2 -0
- package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
- package/dist/index.js +2 -2
- package/dist/infra-runtime-D08WIqN2.js +39 -0
- package/dist/init-BCgwiSZj.js +59 -0
- package/dist/library-CP9n_7AP.js +45 -0
- package/dist/lifecycle-BYam90xH.js +229 -0
- package/dist/lifecycle-DS58sNmu.js +571 -0
- package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-CASc4IWz.js +131 -0
- package/dist/list-CBPrBS2u.js +1212 -0
- package/dist/list-Cf7fcqQd.js +2 -0
- package/dist/list-Dqd2QyTH.js +2 -0
- package/dist/list.probe-BWcMSWDF.js +419 -0
- package/dist/llm-slug-generator-4LADFhXT.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-DI-LDL6p.js +35 -0
- package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/logs-cli-zoBIelUH.js +265 -0
- package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
- package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
- package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
- package/dist/manager-CfUcsSI9.js +2057 -0
- package/dist/manager-DmBBLCOg.js +2 -0
- package/dist/markdown-to-line-B0mPruD_.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-CLL9nfvE.js +725 -0
- package/dist/mcp-http-p7GbtbMx.js +529 -0
- package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
- package/dist/message-CRyNLXch.js +232 -0
- package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
- package/dist/message-action-runner-Dxv-GXkn.js +2 -0
- package/dist/message-actions-DtoR6Mr2.js +143 -0
- package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/models-auth-status-DsheCXaS.js +201 -0
- package/dist/models-cli-CQQG1U-p.js +219 -0
- package/dist/monitor-BRRSjPQY.js +1459 -0
- package/dist/monitor-Ch-cG7Si.js +1661 -0
- package/dist/monitor-ChBhfnC-.js +788 -0
- package/dist/monitor-CsvCTpjq.js +671 -0
- package/dist/monitor-DjemBuVh.js +1237 -0
- package/dist/monitor-LyGEO-KI.js +2 -0
- package/dist/monitor-auth-DVCdDwlp.js +207 -0
- package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
- package/dist/monitor.runtime-DLBFALbV.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-Dktr8JA-.js +180 -0
- package/dist/msteams-G5I2CO13.js +35 -0
- package/dist/native-hook-relay-B1ArNeG5.js +519 -0
- package/dist/nextcloud-talk-DimOAfaR.js +17 -0
- package/dist/node-cli-RIjV0id4.js +2276 -0
- package/dist/nodes-cli-Cke-B80I.js +1046 -0
- package/dist/nodes-utils-CsTqKwN9.js +84 -0
- package/dist/nodes.helpers-DYpGCFer.js +34 -0
- package/dist/notify-zBChwf0-.js +315 -0
- package/dist/onboard-D6UawRld.js +2 -0
- package/dist/onboard-DfoCtk3_.js +70 -0
- package/dist/onboard-helpers-BKQMe3RX.js +6 -0
- package/dist/onboard-helpers-BLBJlQ50.js +204 -0
- package/dist/onboard-interactive-GAbQD437.js +24 -0
- package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
- package/dist/onboard-remote-CNpTyVws.js +193 -0
- package/dist/onboard-remote-GFp2lT6Y.js +2 -0
- package/dist/onboard-skills-BQneolfo.js +2 -0
- package/dist/onboard-skills-BipqJ48b.js +134 -0
- package/dist/openai-http-CLDWjSKC.js +500 -0
- package/dist/openresponses-http-DNvXNiw_.js +1128 -0
- package/dist/operator-approvals-client-gaflvETF.js +68 -0
- package/dist/outbound.runtime-ByVsvEri.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-Dzkubc-8.js +44 -0
- package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
- package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
- package/dist/pi-embedded-C789hs31.js +4 -0
- package/dist/pi-embedded-CXLkrOwv.js +2905 -0
- package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
- package/dist/pi-tools-k60jrAVq.js +1057 -0
- package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
- package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
- package/dist/plugin-BfFuIgXQ.js +12195 -0
- package/dist/plugin-enabled-dXOUnZwX.js +140 -0
- package/dist/plugin-registration-CEAozQhV.js +23 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
- package/dist/plugin-sdk/agent-harness.js +6 -6
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
- package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
- package/dist/plugin-sdk/approval-runtime.js +1 -1
- package/dist/plugin-sdk/browser-node-runtime.js +4 -4
- package/dist/plugin-sdk/browser-setup-tools.js +3 -3
- package/dist/plugin-sdk/browser-support.js +7 -7
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/command-auth.js +1 -1
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
- package/dist/plugin-sdk/conversation-runtime.js +3 -3
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/direct-dm.js +1 -1
- package/dist/plugin-sdk/gateway-runtime.js +3 -3
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +2 -2
- package/dist/plugin-sdk/irc.js +2 -2
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
- package/dist/plugin-sdk/memory-core.js +2 -2
- package/dist/plugin-sdk/msteams.js +2 -2
- package/dist/plugin-sdk/nextcloud-talk.js +2 -2
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
- package/dist/plugin-sdk/runtime.js +2 -2
- package/dist/plugin-sdk/session-visibility.js +1 -1
- package/dist/plugin-sdk/testing.js +4 -4
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-BOpLQ8BU.js +2892 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-DiIlt2yW.js +328 -0
- package/dist/postinstall-inventory.json +445 -445
- package/dist/prepare.runtime-Bd8adOy3.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe-BOlTfbzG.js +2 -0
- package/dist/probe-BSRvsN95.js +2205 -0
- package/dist/probe-CDfjQSnz.js +74 -0
- package/dist/probe-D7gHyiZV.js +241 -0
- package/dist/probe-DTNKTWSs.js +2 -0
- package/dist/probe-DcryDdZh.js +45 -0
- package/dist/probe-nyesoHxj.js +1443 -0
- package/dist/program-BFGavenz.js +111 -0
- package/dist/prompt-select-styled-BhY1zahx.js +20 -0
- package/dist/protocol-DxLbSF2J.js +2477 -0
- package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
- package/dist/provider-dispatcher-ErSjESTP.js +2 -0
- package/dist/qr-cli-C1-oy_ho.js +349 -0
- package/dist/qr-cli-DmEs63Sb.js +2 -0
- package/dist/reaction-runtime-api-gua650a7.js +116 -0
- package/dist/reactions-R-rA7cXz.js +998 -0
- package/dist/register-service-commands-DkbqNKVB.js +71 -0
- package/dist/register.agent-C3nW9wDn.js +248 -0
- package/dist/register.configure-BzLHCu95.js +15 -0
- package/dist/register.maintenance-BHFQo4gr.js +363 -0
- package/dist/register.message-CsYRdfKi.js +329 -0
- package/dist/register.onboard-DltySQ6C.js +88 -0
- package/dist/register.runtime-6Sk1Njnp.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-CDvVQJuj.js +150 -0
- package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
- package/dist/register.subclis-BD4fuAci.js +3 -0
- package/dist/register.subclis-CbRd3F_m.js +29 -0
- package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
- package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
- package/dist/reply-runtime-2EGTfk-1.js +11 -0
- package/dist/reply.runtime-OaHntzIS.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/restart-health-BjmfJCUM.js +202 -0
- package/dist/restart-health-hw909zlD.js +2 -0
- package/dist/root-help-_hHiERsR.js +44 -0
- package/dist/routes-BxCk7Pue.js +3341 -0
- package/dist/routes-C1_6oFmZ.js +2 -0
- package/dist/rpc-zRbkEo6W.js +61 -0
- package/dist/rpc.runtime-BZSYNDPa.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-CJYYkV6H.js +567 -0
- package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-DHizeptL.js +135 -0
- package/dist/runtime-EtV_ChXX.js +9 -0
- package/dist/runtime-api-6H864Pmt.js +9 -0
- package/dist/runtime-api-CbZqRBZQ.js +14 -0
- package/dist/runtime-api-ZxEgu8cW.js +4 -0
- package/dist/runtime-api-j9A6jYUr.js +9 -0
- package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-hvRzTSAZ.js +973 -0
- package/dist/runtime-internal-C_KZYzFK.js +2 -0
- package/dist/runtime-options-BZEOCnMg.js +275 -0
- package/dist/runtime-schema-R7LWe58K.js +28576 -0
- package/dist/scan-BNDE3dSE.js +523 -0
- package/dist/scan-TG6lVEQ2.js +2 -0
- package/dist/secrets-cli-twD2FWoZ.js +2101 -0
- package/dist/security-cli-Cd1A5yhL.js +486 -0
- package/dist/selection-CqqmU0Hi.js +7764 -0
- package/dist/selection-CsM62vcz.js +2 -0
- package/dist/send-D-EgB64m.js +156 -0
- package/dist/send-DPk5hW1W.js +102 -0
- package/dist/send.runtime-3QDkKN71.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-C94r_Qff.js +77 -0
- package/dist/server-Ceiopn_v.js +13 -0
- package/dist/server-context-BFJlu5HY.js +2 -0
- package/dist/server-context-PNEqhnTM.js +847 -0
- package/dist/server-node-events-QOAWLsDC.js +481 -0
- package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
- package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
- package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
- package/dist/server.impl-CCoQpvB7.js +12864 -0
- package/dist/session-kill-http-oPi3ajEp.js +110 -0
- package/dist/session-reset-service-CzDd6PBK.js +497 -0
- package/dist/session-route-DUOQE8-f.js +93 -0
- package/dist/session-status.runtime-W5tlGbXw.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-DkeCaT-2.js +581 -0
- package/dist/session-visibility-B4CFjv43.js +147 -0
- package/dist/sessions-helpers-CDfOVWe3.js +305 -0
- package/dist/sessions-history-http-QXeTdxXM.js +383 -0
- package/dist/sessions-patch-xb4bXPwh.js +309 -0
- package/dist/sessions-resolve-BPlrW8C3.js +174 -0
- package/dist/sessions.runtime-yYJXudA9.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-0Im0LL1d.js +636 -0
- package/dist/setup-api-BxwfqXN-.js +29 -0
- package/dist/setup-core-BWwXgEuM.js +171 -0
- package/dist/setup-core-DzHNbQLG.js +176 -0
- package/dist/setup-surface-BVnqDsfU.js +286 -0
- package/dist/setup-surface-BajZWmKz2.js +403 -0
- package/dist/setup-surface-rDO3YjSb.js +219 -0
- package/dist/setup.finalize-BsnPbdwc.js +547 -0
- package/dist/setup.gateway-config-BFawSWHL.js +250 -0
- package/dist/shared-52tFSlVk.js +121 -0
- package/dist/shared-C8ENgtxM.js +198 -0
- package/dist/shared-DbXvU7JV.js +76 -0
- package/dist/slash-state-CMuPwgKt.js +1911 -0
- package/dist/src-IzaHgU6a.js +3974 -0
- package/dist/startup-context-xJS8ckSG.js +312 -0
- package/dist/status-BO4LMTER.js +2 -0
- package/dist/status-BwY1tASe.js +3 -0
- package/dist/status-BxG6n-ko.js +397 -0
- package/dist/status-Co_cq2vy.js +2 -0
- package/dist/status-DKNeRGzW.js +190 -0
- package/dist/status-DzlIHiTS.js +209 -0
- package/dist/status-all-DF7qaWjo.js +498 -0
- package/dist/status-json-CgCilobT.js +14 -0
- package/dist/status-json-command-DAa78z3e.js +84 -0
- package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
- package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BdbRrl1G.js +237 -0
- package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-CItmFIHS.js +292 -0
- package/dist/status.gather-qB6WOoH7.js +2 -0
- package/dist/status.runtime-ClZCgYx1.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-overview-B0b0Mvng.js +379 -0
- package/dist/status.scan-xY7nUi9N.js +65 -0
- package/dist/status.scan.fast-json-BANGHOys.js +132 -0
- package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
- package/dist/status.summary-B3PlFnWw.js +2 -0
- package/dist/status.summary-adB75FOM.js +214 -0
- package/dist/subagent-announce-B4w7Mcpr.js +351 -0
- package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
- package/dist/subagent-announce-output-sUPLcge-.js +364 -0
- package/dist/subagent-control-CxR0WRrx.js +506 -0
- package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
- package/dist/subagent-registry-CjMWjRCE.js +1753 -0
- package/dist/subagent-registry-H20VxEu0.js +3 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
- package/dist/system-cli-BJ5mMirj.js +59 -0
- package/dist/targets-CUnlEj96.js +67 -0
- package/dist/task-executor-DKnEwQ6v.js +360 -0
- package/dist/task-owner-access-CfypP1Yc.js +74 -0
- package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
- package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
- package/dist/task-registry-pQuAfAL9.js +2366 -0
- package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
- package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
- package/dist/telegram/token.js +1 -1
- package/dist/testing-C_mngO0u.js +575 -0
- package/dist/text-report-Ct6t3he6.js +587 -0
- package/dist/tool-resolution-C4KGgPH-.js +90 -0
- package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
- package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
- package/dist/trash-DhZow3jd.js +24 -0
- package/dist/tui-cli-BPdQPozP.js +4575 -0
- package/dist/update-cli-BRi3mVAU.js +1759 -0
- package/dist/upgrade-D9zejtCk.js +1226 -0
- package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
- package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
- package/dist/wizard-models-ysyV_WWR.js +334 -0
- package/package.json +1 -1
- package/dist/abort-DaihtnYj.js +0 -201
- package/dist/abort.runtime-BUT9L_5l.js +0 -2
- package/dist/accounts-BY5wsBnV.js +0 -104
- package/dist/accounts-DGth1vsM.js +0 -107
- package/dist/accounts-Do6Ir-q3.js +0 -2
- package/dist/acp-cli-BHgjn8rh.js +0 -2193
- package/dist/acp-spawn-BAM_Jrft.js +0 -2
- package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
- package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
- package/dist/action-agents-CzMSNQdc.js +0 -67
- package/dist/action-focus-CpjIrZFe.js +0 -132
- package/dist/action-help-BhE9UosK.js +0 -7
- package/dist/action-info-CH2j6dKT.js +0 -101
- package/dist/action-kill-CB4AnLIf.js +0 -33
- package/dist/action-list-CQ8LbzvR.js +0 -21
- package/dist/action-log-DZblh247.js +0 -30
- package/dist/action-send-DMe0B4FG.js +0 -39
- package/dist/action-spawn-CkKMESb5.js +0 -47
- package/dist/action-unfocus-DjQzPZwU.js +0 -29
- package/dist/actions.runtime-CUdRdpLB.js +0 -5
- package/dist/actions.runtime-CxRstWdN.js +0 -18
- package/dist/agent-command-Nh_kPL3z.js +0 -874
- package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
- package/dist/agent-q6U-cKJn.js +0 -2
- package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
- package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
- package/dist/agent-runtime-jSYYQd6f.js +0 -18
- package/dist/agents-BKOpsZXw.js +0 -5
- package/dist/agents-BY34ViPX.js +0 -954
- package/dist/aliases-CD5YlX7d.js +0 -2
- package/dist/aliases-Dq31zANx.js +0 -96
- package/dist/api-BhxN9fxJ.js +0 -139
- package/dist/api-DjL_3olO.js +0 -5
- package/dist/api-jIYND-S5.js +0 -3
- package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
- package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
- package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
- package/dist/approval-native-runtime-IrisOZrU.js +0 -729
- package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
- package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
- package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
- package/dist/audit-CVUpfDvE.js +0 -939
- package/dist/audit.runtime-CsuGXvud.js +0 -7
- package/dist/auth-CjcZyRUW.js +0 -383
- package/dist/auth-order-DIkyTpW4.js +0 -2
- package/dist/auth-order-Dpt1K1rT.js +0 -96
- package/dist/auth-sVuL2xeZ.js +0 -2
- package/dist/bash-tools-DDv0zQh9.js +0 -2824
- package/dist/bash-tools-s-QSvRmt.js +0 -3
- package/dist/binding-routing-Cz5R2kFK.js +0 -85
- package/dist/binding-targets-D4j2hdQh.js +0 -121
- package/dist/bridge-server-X8SdeAI3.js +0 -113
- package/dist/browser-control-auth-BrF3DZxC.js +0 -2
- package/dist/browser-node-runtime-BecPmKOx.js +0 -12
- package/dist/browser-profiles-BxAKEG3x.js +0 -2
- package/dist/browser-runtime-D9fTDscJ.js +0 -387
- package/dist/browser-setup-tools--AQGWGvl.js +0 -13
- package/dist/build-B0nbyXrw.js +0 -550
- package/dist/call-BvqN9kay.js +0 -3
- package/dist/call-Dk5rTl-p.js +0 -331
- package/dist/call.runtime-Bx1hKDwO.js +0 -2
- package/dist/capability-cli-286Z3Bq3.js +0 -1401
- package/dist/catchup-DyeQ6GNj.js +0 -300
- package/dist/channel-B5m01jSZ.js +0 -1802
- package/dist/channel-BE26v3WU.js +0 -840
- package/dist/channel-BS7r_Zt1.js +0 -226
- package/dist/channel-BUWCqkGh.js +0 -1320
- package/dist/channel-BhgKqvZn.js +0 -453
- package/dist/channel-Bx703sxQ.js +0 -297
- package/dist/channel-CDjlEQAM.js +0 -491
- package/dist/channel-ChrqAgRS.js +0 -595
- package/dist/channel-Crmp3BHh.js +0 -1100
- package/dist/channel-D7GdDfBl.js +0 -1174
- package/dist/channel-DqSzRIul.js +0 -350
- package/dist/channel-core-DIwclC34.js +0 -5
- package/dist/channel-inbound-DPW1gRUU.js +0 -31
- package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
- package/dist/channel-runtime-sV_Sg0EO.js +0 -425
- package/dist/channel.runtime-4BaNapRW.js +0 -89
- package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
- package/dist/channel.runtime-Bo5_2imz.js +0 -109
- package/dist/channel.runtime-CdYWlMyL.js +0 -40130
- package/dist/channel.runtime-CrYmCmSw.js +0 -4
- package/dist/channel.runtime-D3APPhVs.js +0 -430
- package/dist/channel.runtime-DjF1Gg6N.js +0 -576
- package/dist/channel.setup-BxXrmAYb.js +0 -10
- package/dist/channels-DHcJgMnw.js +0 -733
- package/dist/channels-cli-Dnq08u4r.js +0 -268
- package/dist/chat-BGU3UVKD.js +0 -2830
- package/dist/clawbot-cli-C-rqJUW-.js +0 -9
- package/dist/cli-BlnGJbLJ.js +0 -219
- package/dist/cli-D0RU1q0-.js +0 -2
- package/dist/cli-DBw79G2t.js +0 -72
- package/dist/cli-Dul37_xp.js +0 -2
- package/dist/cli-runner-DY8BKEmu.js +0 -286
- package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
- package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
- package/dist/cli.runtime-CGOUREQg.js +0 -1261
- package/dist/client-CCBN1ydB.js +0 -138
- package/dist/client-PHLyQ8il.js +0 -713
- package/dist/command-auth-79QKQZZ3.js +0 -76
- package/dist/command-config-resolution-BKAgMItc.js +0 -2
- package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
- package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
- package/dist/command-registry-C9axn0de.js +0 -4
- package/dist/command-registry-DkcFlIyM.js +0 -9
- package/dist/command-registry-core-DEDRtJmS.js +0 -106
- package/dist/command-secret-gateway-g0alGmKz.js +0 -528
- package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
- package/dist/commands-acp-De-XFc40.js +0 -77
- package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
- package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
- package/dist/commands-status-CION7GYY.js +0 -16
- package/dist/commands-status.runtime-FBwoHftv.js +0 -3
- package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
- package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
- package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
- package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
- package/dist/commands.runtime-CHSb1kYa.js +0 -167
- package/dist/compact-Dwchggv2.js +0 -1118
- package/dist/compact.runtime-jDUYMSjR.js +0 -12
- package/dist/completion-cli-DGiZcg4E.js +0 -328
- package/dist/config-Bnb9qa1S.js +0 -252
- package/dist/config-cli-BuZ5RUhD.js +0 -1078
- package/dist/configure-BLNGlWh0.js +0 -1252
- package/dist/configure-nPzsEeOb.js +0 -2
- package/dist/connect-options-C9cvS-bh.js +0 -699
- package/dist/control-auth-D2-P54fW.js +0 -125
- package/dist/control-service-CqUPgxlx.js +0 -156
- package/dist/control-ui/assets/agents-CA3uz9sP.js +0 -1052
- package/dist/control-ui/assets/canvas-D0sLy568.js +0 -269
- package/dist/control-ui/assets/channel-config-extras-CWzNTLS-.js +0 -2
- package/dist/control-ui/assets/channels-DXgjbWts.js +0 -463
- package/dist/control-ui/assets/cron-D-rffMH6.js +0 -933
- package/dist/control-ui/assets/de-l9FbKtxt.js +0 -2
- package/dist/control-ui/assets/debug-Vf_bLYLB.js +0 -94
- package/dist/control-ui/assets/es-CC-t9AUQ.js +0 -2
- package/dist/control-ui/assets/format-BL-FisEP.js +0 -9
- package/dist/control-ui/assets/fr-DZKceqST.js +0 -2
- package/dist/control-ui/assets/i18n-DFH8x0DD.js +0 -3
- package/dist/control-ui/assets/id-D93YKkrM.js +0 -2
- package/dist/control-ui/assets/index-lWAwAXYo.js +0 -6366
- package/dist/control-ui/assets/instances-BmzzTloa.js +0 -57
- package/dist/control-ui/assets/ja-JP-DoPdk5L_.js +0 -2
- package/dist/control-ui/assets/ko-8TeOGGHm.js +0 -2
- package/dist/control-ui/assets/logs-BjPSImvD.js +0 -74
- package/dist/control-ui/assets/mcp-CQGmuKdR.js +0 -281
- package/dist/control-ui/assets/nodes-CDhqPGsD.js +0 -618
- package/dist/control-ui/assets/pl-BSP1Y3tH.js +0 -2
- package/dist/control-ui/assets/plugins-D4fXQx07.js +0 -273
- package/dist/control-ui/assets/pt-BR-D4-81_zm.js +0 -2
- package/dist/control-ui/assets/sessions-DzjXl7P7.js +0 -306
- package/dist/control-ui/assets/skills-BTQrLVPj.js +0 -323
- package/dist/control-ui/assets/skills-shared-CX4mwYFK.js +0 -11
- package/dist/control-ui/assets/th-DrnubOIu.js +0 -2
- package/dist/control-ui/assets/tr-BMyrj0eZ.js +0 -2
- package/dist/control-ui/assets/uk-CZhU3bHK.js +0 -2
- package/dist/control-ui/assets/wallet-DPb6whuj.js +0 -285
- package/dist/control-ui/assets/zh-CN-CH12jxSw.js +0 -2
- package/dist/control-ui/assets/zh-TW-CaTySceX.js +0 -2
- package/dist/conversation-id-BAzJOKBB.js +0 -235
- package/dist/conversation-id-WJLKuyy9.js +0 -38
- package/dist/conversation-runtime-D8fK5aI0.js +0 -31
- package/dist/core-DywmHt1k.js +0 -275
- package/dist/cron-cli-CeEJRkfR.js +0 -713
- package/dist/daemon-cli-BZZOjJHx.js +0 -12
- package/dist/dashboard-C0NRxmP3.js +0 -81
- package/dist/dashboard-DqhPgQv-.js +0 -2
- package/dist/delegate-DwVbOeR5.js +0 -64
- package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
- package/dist/devices-cli-BKVbpwVc.js +0 -498
- package/dist/diagnostics-gh3UN_iV.js +0 -154
- package/dist/direct-dm-CwHHUkHV.js +0 -64
- package/dist/dispatch-B5af8_1v.js +0 -1131
- package/dist/dispatch-acp-DgOnUWBl.js +0 -981
- package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
- package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
- package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
- package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
- package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
- package/dist/doctor-health-BOhuy1vP.js +0 -59
- package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
- package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
- package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
- package/dist/dreaming-GOPEFPio.js +0 -1574
- package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
- package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
- package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
- package/dist/fallbacks-CdfWAgNP.js +0 -2
- package/dist/fallbacks-eXbQ8TBp.js +0 -31
- package/dist/fallbacks-shared-akcCu5CD.js +0 -111
- package/dist/gateway-D-dDKqwi.js +0 -115
- package/dist/gateway-cli-DBS06Da8.js +0 -1283
- package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
- package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
- package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
- package/dist/gateway-status-C_L_CdOg.js +0 -584
- package/dist/genesis-tools-rRJB3JXY.js +0 -9166
- package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
- package/dist/get-reply-BkiDsDVY.js +0 -3897
- package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
- package/dist/graph-users-BnXIYyC5.js +0 -1337
- package/dist/health-ZsJNENSY.js +0 -3
- package/dist/health-osa9LOJf.js +0 -469
- package/dist/health-route-8TdKOYLp.js +0 -2
- package/dist/health-route-BdLtX2Bg.js +0 -41
- package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
- package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
- package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
- package/dist/hooks-cli-C3ggAz0i.js +0 -433
- package/dist/image-fallbacks-CiSae-lb.js +0 -2
- package/dist/image-fallbacks-vI8KUh6N.js +0 -31
- package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
- package/dist/infra-runtime-CrHVeejV.js +0 -39
- package/dist/init-BKeEiV2q.js +0 -59
- package/dist/library-CHB7yTo5.js +0 -45
- package/dist/lifecycle-CUULToPr.js +0 -229
- package/dist/lifecycle-DCMpTRD2.js +0 -571
- package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
- package/dist/list-0zDFAWTF.js +0 -2
- package/dist/list-BaxVHTAN.js +0 -131
- package/dist/list-CMRMgrPs.js +0 -1212
- package/dist/list-DSrBtnKI.js +0 -2
- package/dist/list.probe-BJYSCsJY.js +0 -419
- package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
- package/dist/load-config-qC2BWt8E.js +0 -35
- package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
- package/dist/logs-cli-zK71r_PE.js +0 -265
- package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
- package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
- package/dist/managed-image-attachments-B6XXE4--.js +0 -635
- package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
- package/dist/manager-BCKuWA67.js +0 -2057
- package/dist/manager-rGwNUzMp.js +0 -2
- package/dist/markdown-to-line-DmPbXQA1.js +0 -790
- package/dist/mcp-cli-CYpPNMcE.js +0 -725
- package/dist/mcp-http-wiE81iKg.js +0 -529
- package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
- package/dist/message-CUDzVGD8.js +0 -232
- package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
- package/dist/message-action-runner-KkBFzZdg.js +0 -2
- package/dist/message-actions-Dcdb5aSR.js +0 -143
- package/dist/message.gateway.runtime-D86fFO99.js +0 -2
- package/dist/models-auth-status-DkiX4s0b.js +0 -201
- package/dist/models-cli-CSUot1R3.js +0 -219
- package/dist/monitor-BA8ByMKR.js +0 -2
- package/dist/monitor-Bv1GIHW5.js +0 -1661
- package/dist/monitor-DTFY0ruF.js +0 -788
- package/dist/monitor-DXH-vNGn.js +0 -1459
- package/dist/monitor-Df5k8NGk.js +0 -671
- package/dist/monitor-Dk2YRF26.js +0 -1237
- package/dist/monitor-auth-CZOW753A.js +0 -207
- package/dist/monitor-processing-Clta8N4C.js +0 -1974
- package/dist/monitor.runtime-3ORbPT0X.js +0 -2
- package/dist/monitor.webhook-CRyTxENk.js +0 -180
- package/dist/msteams-BE0VieXF.js +0 -35
- package/dist/native-hook-relay-DAwGGuEx.js +0 -519
- package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
- package/dist/node-cli-Bzyci_X_.js +0 -2276
- package/dist/nodes-cli-Er3OZkuk.js +0 -1046
- package/dist/nodes-utils-Cp8QZO8-.js +0 -84
- package/dist/nodes.helpers-CwKAAnRA.js +0 -34
- package/dist/notify-D_5n_vEJ.js +0 -315
- package/dist/onboard-BE82RudQ.js +0 -2
- package/dist/onboard-Bk4xL8X7.js +0 -70
- package/dist/onboard-helpers-D4WYa-6g.js +0 -204
- package/dist/onboard-helpers-MuFxPZg5.js +0 -6
- package/dist/onboard-interactive-0zmI-9ia.js +0 -24
- package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
- package/dist/onboard-remote-7qR1knbU.js +0 -2
- package/dist/onboard-remote-CLmoySkk.js +0 -193
- package/dist/onboard-skills-C_873OK_.js +0 -134
- package/dist/onboard-skills-DrlBYc0t.js +0 -2
- package/dist/openai-http-DzCBqW6b.js +0 -500
- package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
- package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
- package/dist/outbound.runtime--HS-MxM_.js +0 -2
- package/dist/pair-command-approve-CCTSQKJH.js +0 -44
- package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
- package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
- package/dist/pi-embedded-BSKL8IgF.js +0 -4
- package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
- package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
- package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
- package/dist/pi-tools-DD1YegeL.js +0 -1057
- package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
- package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
- package/dist/plugin-Cg3pHepG.js +0 -12195
- package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
- package/dist/plugin-registration-DLcLJgqz.js +0 -23
- package/dist/plugin-service-BogBl5qk.js +0 -2892
- package/dist/policy-Bkh8Xtnb.js +0 -328
- package/dist/prepare.runtime-Cd31ie7u.js +0 -815
- package/dist/probe-9IM22Rkf.js +0 -2
- package/dist/probe-ButCyV3d.js +0 -1443
- package/dist/probe-D7QBUio1.js +0 -45
- package/dist/probe-DV6CWm0r.js +0 -74
- package/dist/probe-DkfetvwA.js +0 -2
- package/dist/probe-Dxo-LQjn.js +0 -2205
- package/dist/probe-nil3qQAV.js +0 -241
- package/dist/program-AcjZFtZQ.js +0 -111
- package/dist/prompt-select-styled-BSf77q2T.js +0 -20
- package/dist/protocol-C4I0nfuT.js +0 -2477
- package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
- package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
- package/dist/qr-cli-BHY0TO2W.js +0 -2
- package/dist/qr-cli-BbjDJSKp.js +0 -349
- package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
- package/dist/reactions-CogkrjNr.js +0 -998
- package/dist/register-service-commands-IA3Nfza5.js +0 -71
- package/dist/register.agent-DD0aSYye.js +0 -248
- package/dist/register.configure-BOy4i7Ah.js +0 -15
- package/dist/register.maintenance-CUp6FEOF.js +0 -363
- package/dist/register.message-DezTIpNI.js +0 -329
- package/dist/register.onboard-Brpxl9p3.js +0 -88
- package/dist/register.runtime-BfH5rSb_.js +0 -81
- package/dist/register.setup-CIt4FVv0.js +0 -150
- package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
- package/dist/register.subclis-B1H4fYxP.js +0 -29
- package/dist/register.subclis-D-_xtNVs.js +0 -3
- package/dist/register.subclis-core-CkJelRU8.js +0 -249
- package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
- package/dist/reply-runtime-CgPzru94.js +0 -11
- package/dist/reply.runtime-sw14BA5F.js +0 -2
- package/dist/restart-health-1MNBua3p.js +0 -202
- package/dist/restart-health-BWGpwgPv.js +0 -2
- package/dist/root-help-B3zoC2OP.js +0 -44
- package/dist/routes-BM6fbday.js +0 -3341
- package/dist/routes-pVc_QLiP.js +0 -2
- package/dist/rpc-BGOWS7nj.js +0 -61
- package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
- package/dist/run-delivery.runtime-CabntI64.js +0 -530
- package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
- package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
- package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
- package/dist/run-main-kE0nFgvK.js +0 -567
- package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
- package/dist/run-wait-B2K_6JNL.js +0 -135
- package/dist/runtime-BZ296jTK.js +0 -9
- package/dist/runtime-DnZsw7MB.js +0 -973
- package/dist/runtime-api-BL9vpbvb.js +0 -14
- package/dist/runtime-api-BbsLJB4C.js +0 -9
- package/dist/runtime-api-ChwFrQRw.js +0 -9
- package/dist/runtime-api-_fH7M3Qh.js +0 -4
- package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
- package/dist/runtime-internal-DGwOFi_E.js +0 -2
- package/dist/runtime-options-CSPfxkb1.js +0 -275
- package/dist/runtime-schema-CMRvOPkk.js +0 -28576
- package/dist/scan-D6gkNpKl.js +0 -523
- package/dist/scan-_9J5-5L6.js +0 -2
- package/dist/secrets-cli-DlVSRQPM.js +0 -2101
- package/dist/security-cli-DtzNOYL2.js +0 -486
- package/dist/selection-CBJZE_FL.js +0 -7764
- package/dist/selection-XsoEF2p2.js +0 -2
- package/dist/send-BAaDBRfi.js +0 -156
- package/dist/send-BB-M1afy.js +0 -102
- package/dist/send.runtime-CI_75KUP.js +0 -2
- package/dist/server-B_BiVYFv.js +0 -13
- package/dist/server-D58E1Cua.js +0 -77
- package/dist/server-context-D5AnCc1E.js +0 -2
- package/dist/server-context-bt09wrJu.js +0 -847
- package/dist/server-node-events-CUx4-7FL.js +0 -481
- package/dist/server-plugin-bootstrap-CU5P500z.js +0 -12708
- package/dist/server-plugin-bootstrap-CXm9xWXR.js +0 -2
- package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
- package/dist/server.impl-BBBEDK9u.js +0 -12864
- package/dist/session-kill-http-9MoO6FXC.js +0 -110
- package/dist/session-reset-service-redPsOs-.js +0 -497
- package/dist/session-route-C8oB2UYs.js +0 -93
- package/dist/session-status.runtime-D3bYBPJe.js +0 -2
- package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
- package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
- package/dist/session-visibility-Dq88jJYB.js +0 -147
- package/dist/sessions-helpers-C8-IkqhO.js +0 -305
- package/dist/sessions-history-http-4Ftuwnes.js +0 -383
- package/dist/sessions-patch-BsyNHOaz.js +0 -309
- package/dist/sessions-resolve-gKLz2Bup.js +0 -174
- package/dist/sessions.runtime-C1W59rQY.js +0 -2
- package/dist/setup-DhvXyU_5.js +0 -636
- package/dist/setup-api-B9Y4qPgq.js +0 -29
- package/dist/setup-core-CdFQ6ZXC.js +0 -176
- package/dist/setup-core-kXUD3Kat.js +0 -171
- package/dist/setup-surface-BFL9WfBs.js +0 -219
- package/dist/setup-surface-Cxg_nSWc.js +0 -286
- package/dist/setup-surface-DbooMj782.js +0 -403
- package/dist/setup.finalize-CKxukDYi.js +0 -547
- package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
- package/dist/shared-BNVKrp5y.js +0 -76
- package/dist/shared-CM3mnx7z.js +0 -198
- package/dist/shared-CfrsSVhL.js +0 -121
- package/dist/slash-state-2Z-om57Q.js +0 -1911
- package/dist/src-DAoKvK_N.js +0 -3974
- package/dist/startup-context-CtYAdYwd.js +0 -312
- package/dist/status-B2M0Imij.js +0 -3
- package/dist/status-Bd-BNmiE.js +0 -2
- package/dist/status-D6nbpHFi.js +0 -397
- package/dist/status-MByUxUGu.js +0 -209
- package/dist/status-QUjO1tkz.js +0 -2
- package/dist/status-all-DPa-BiHk.js +0 -498
- package/dist/status-erNo8YmW.js +0 -190
- package/dist/status-json-command-C9rbAyj-.js +0 -84
- package/dist/status-json-tO3CQXIQ.js +0 -14
- package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
- package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
- package/dist/status-text-BCeYk0-q.js +0 -237
- package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
- package/dist/status.gather-B9a-CEev.js +0 -292
- package/dist/status.gather-ahBLFzk6.js +0 -2
- package/dist/status.runtime-BrErwtfc.js +0 -2
- package/dist/status.scan-D2mvM4II.js +0 -65
- package/dist/status.scan-overview-uOOaqp1t.js +0 -379
- package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
- package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
- package/dist/status.summary-Cf4p2BPK.js +0 -2
- package/dist/status.summary-DxfZCcNa.js +0 -214
- package/dist/subagent-announce-CyQZsAIm.js +0 -351
- package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
- package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
- package/dist/subagent-control-D-O6I8Mt.js +0 -506
- package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
- package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
- package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
- package/dist/subagent-registry-DodFw3pu.js +0 -3
- package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
- package/dist/system-cli-CSqO2Z4K.js +0 -59
- package/dist/targets-CMdwh9lR.js +0 -67
- package/dist/task-executor-DgZSfcBk.js +0 -360
- package/dist/task-owner-access-9c38idlo.js +0 -74
- package/dist/task-registry-Z-lBPkNj.js +0 -2366
- package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
- package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
- package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
- package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
- package/dist/testing-CFk04o9M.js +0 -575
- package/dist/text-report-QhVG354o.js +0 -587
- package/dist/tool-resolution-D6V4tg-G.js +0 -90
- package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
- package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
- package/dist/trash-rhbwNhfQ.js +0 -24
- package/dist/tui-cli-BfxeO4YM.js +0 -4575
- package/dist/update-cli-DaN9bvPV.js +0 -1759
- package/dist/upgrade-f5dlIxir.js +0 -1226
- package/dist/video-generation-task-status-yX54iO8n.js +0 -163
- package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
- package/dist/wizard-models-D_avLyHR.js +0 -334
|
@@ -1,1759 +0,0 @@
|
|
|
1
|
-
import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString } from "./string-coerce-DPP_aYVc.js";
|
|
2
|
-
import { t as resolveGenesisPackageRoot } from "./genesis-root-BREm_erB.js";
|
|
3
|
-
import { d as pathExists } from "./utils-CWrkFsp0.js";
|
|
4
|
-
import { n as defaultRuntime } from "./runtime-DDkDH9fa.js";
|
|
5
|
-
import { t as formatDocsLink } from "./links-C1-jbHJx.js";
|
|
6
|
-
import { r as theme } from "./theme-DD6pQv2_.js";
|
|
7
|
-
import { n as inheritOptionFromParent } from "./command-options-BAeBeFgJ.js";
|
|
8
|
-
import "./daemon-cli-BZZOjJHx.js";
|
|
9
|
-
import { n as resolveCliName, t as replaceCliName } from "./cli-name-Dx-I_gso.js";
|
|
10
|
-
import { t as formatCliCommand } from "./command-format-B3Q5KD9o.js";
|
|
11
|
-
import { n as DEFAULT_GATEWAY_PORT, u as resolveGatewayPort } from "./paths-Bv2rGpO9.js";
|
|
12
|
-
import { f as resolveGatewaySystemdServiceName, l as resolveGatewayLaunchAgentLabel, p as resolveGatewayWindowsTaskName } from "./constants-a99_SBoO.js";
|
|
13
|
-
import { o as resolveGatewayInstallEntrypoint } from "./daemon-install-plan.shared-sDw4anZ6.js";
|
|
14
|
-
import { a as parseSemver, i as nodeVersionSatisfiesEngine } from "./runtime-guard-B2AXF2AU.js";
|
|
15
|
-
import { r as runCommandWithTimeout } from "./exec-BbrLAvgI.js";
|
|
16
|
-
import { L as asResolvedSourceConfig, R as asRuntimeConfig, u as readConfigFileSnapshot } from "./io-B1sv_bx7.js";
|
|
17
|
-
import { a as shellEscapeRestartLogValue, i as resolveGatewayRestartLogPath, n as renderPosixRestartLogSetup, s as quoteCmdScriptArg, t as renderCmdRestartLogSetup } from "./restart-logs-B0OTqRo0.js";
|
|
18
|
-
import { r as resolveGatewayService } from "./service-DiHWY6iI.js";
|
|
19
|
-
import { t as runDaemonInstall } from "./install-DJ4pSeIP.js";
|
|
20
|
-
import { r as replaceConfigFile } from "./mutate-BW5qum-I.js";
|
|
21
|
-
import "./config-Cuf4dwjh.js";
|
|
22
|
-
import { t as runDaemonRestart } from "./lifecycle-CUULToPr.js";
|
|
23
|
-
import { n as formatConfigIssueLines } from "./issue-format-CvKVSqgv.js";
|
|
24
|
-
import { l as waitForGatewayHealthyRestart, o as renderRestartDiagnostics, s as terminateStaleGatewayPids } from "./restart-health-1MNBua3p.js";
|
|
25
|
-
import { u as trimLogTail } from "./restart-sentinel-BWLOu2lg.js";
|
|
26
|
-
import { r as formatDurationPrecise } from "./format-duration-FMBoWUPM.js";
|
|
27
|
-
import { n as stylePromptMessage } from "./prompt-style-q-APyeiS.js";
|
|
28
|
-
import { t as formatHelpExamples } from "./help-format-DziqFQ8a.js";
|
|
29
|
-
import { r as installCompletion } from "./completion-runtime-CUdMWalC.js";
|
|
30
|
-
import { n as renderTable, t as getTerminalTableWidth } from "./table-ree5Et8O.js";
|
|
31
|
-
import { n as updateNpmInstalledPlugins, t as syncPluginsForUpdateChannel } from "./update-BV0Q2ZHn.js";
|
|
32
|
-
import { n as doctorCommand, t as selectStyled } from "./prompt-select-styled-BSf77q2T.js";
|
|
33
|
-
import { d as formatUpdateChannelLabel, g as resolveUpdateChannelDisplay, h as resolveEffectiveUpdateChannel, i as fetchNpmTagVersion, m as normalizeUpdateChannel, n as compareSemverStrings, o as resolveNpmChannelTag, r as fetchNpmPackageTargetStatus, t as checkUpdateStatus, u as channelToNpmTag } from "./update-check-Cg09n-9K.js";
|
|
34
|
-
import { i as resolveUpdateAvailability, n as formatUpdateOneLiner, t as formatUpdateAvailableHint } from "./status.update-C3N7ujZu.js";
|
|
35
|
-
import { a as createGlobalInstallEnv, c as globalInstallArgs, d as resolveGlobalInstallSpec, f as resolveGlobalInstallTarget, h as readPackageVersion, i as collectInstalledGlobalPackageErrors, l as globalInstallFallbackArgs, m as readPackageName, n as canResolveRegistryVersionForPackageTarget, o as detectGlobalInstallManagerByPresence, p as normalizePackageTagInput, r as cleanupGlobalRenameDirs, s as detectGlobalInstallManagerForRoot, t as runGatewayUpdate, u as resolveExpectedInstalledVersionFromSpec } from "./update-runner-RF6RKOeQ.js";
|
|
36
|
-
import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-BWqy3j-A.js";
|
|
37
|
-
import path from "node:path";
|
|
38
|
-
import { spawn, spawnSync } from "node:child_process";
|
|
39
|
-
import os from "node:os";
|
|
40
|
-
import fs from "node:fs/promises";
|
|
41
|
-
import { confirm, isCancel, spinner } from "@clack/prompts";
|
|
42
|
-
//#region src/cli/update-cli/shared.ts
|
|
43
|
-
const INVALID_TIMEOUT_ERROR = "--timeout must be a positive integer (seconds)";
|
|
44
|
-
function parseTimeoutMsOrExit(timeout) {
|
|
45
|
-
const timeoutMs = timeout ? Number.parseInt(timeout, 10) * 1e3 : void 0;
|
|
46
|
-
if (timeoutMs !== void 0 && (Number.isNaN(timeoutMs) || timeoutMs <= 0)) {
|
|
47
|
-
defaultRuntime.error(INVALID_TIMEOUT_ERROR);
|
|
48
|
-
defaultRuntime.exit(1);
|
|
49
|
-
return null;
|
|
50
|
-
}
|
|
51
|
-
return timeoutMs;
|
|
52
|
-
}
|
|
53
|
-
const GENESIS_REPO_URL = "https://github.com/PIXELZX0/Genesis.git";
|
|
54
|
-
const MAX_LOG_CHARS = 8e3;
|
|
55
|
-
const DEFAULT_PACKAGE_NAME = "@pixelzx/genesis";
|
|
56
|
-
const LEGACY_PACKAGE_NAME = "genesis";
|
|
57
|
-
const CORE_PACKAGE_NAMES = new Set([DEFAULT_PACKAGE_NAME, LEGACY_PACKAGE_NAME]);
|
|
58
|
-
function normalizeTag(value) {
|
|
59
|
-
return normalizePackageTagInput(value, [DEFAULT_PACKAGE_NAME, LEGACY_PACKAGE_NAME]);
|
|
60
|
-
}
|
|
61
|
-
function normalizeVersionTag(tag) {
|
|
62
|
-
const trimmed = tag.trim();
|
|
63
|
-
if (!trimmed) return null;
|
|
64
|
-
const cleaned = trimmed.startsWith("v") ? trimmed.slice(1) : trimmed;
|
|
65
|
-
return parseSemver(cleaned) ? cleaned : null;
|
|
66
|
-
}
|
|
67
|
-
async function resolveTargetVersion(tag, timeoutMs, packageName = DEFAULT_PACKAGE_NAME) {
|
|
68
|
-
if (!canResolveRegistryVersionForPackageTarget(tag)) return null;
|
|
69
|
-
const direct = normalizeVersionTag(tag);
|
|
70
|
-
if (direct) return direct;
|
|
71
|
-
return (await fetchNpmTagVersion({
|
|
72
|
-
packageName,
|
|
73
|
-
tag,
|
|
74
|
-
timeoutMs
|
|
75
|
-
})).version ?? null;
|
|
76
|
-
}
|
|
77
|
-
async function isGitCheckout(root) {
|
|
78
|
-
try {
|
|
79
|
-
await fs.stat(path.join(root, ".git"));
|
|
80
|
-
return true;
|
|
81
|
-
} catch {
|
|
82
|
-
return false;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
async function isCorePackage(root) {
|
|
86
|
-
const name = await readPackageName(root);
|
|
87
|
-
return Boolean(name && CORE_PACKAGE_NAMES.has(name));
|
|
88
|
-
}
|
|
89
|
-
async function isEmptyDir(targetPath) {
|
|
90
|
-
try {
|
|
91
|
-
return (await fs.readdir(targetPath)).length === 0;
|
|
92
|
-
} catch {
|
|
93
|
-
return false;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
function resolveGitInstallDir() {
|
|
97
|
-
const override = process.env.GENESIS_GIT_DIR?.trim();
|
|
98
|
-
if (override) return path.resolve(override);
|
|
99
|
-
return resolveDefaultGitDir();
|
|
100
|
-
}
|
|
101
|
-
function resolveDefaultGitDir() {
|
|
102
|
-
const home = os.homedir();
|
|
103
|
-
if (home.startsWith("/")) return path.posix.join(home, "genesis");
|
|
104
|
-
return path.join(home, "genesis");
|
|
105
|
-
}
|
|
106
|
-
function resolveNodeRunner() {
|
|
107
|
-
const base = normalizeLowercaseStringOrEmpty(path.basename(process.execPath));
|
|
108
|
-
if (base === "node" || base === "node.exe") return process.execPath;
|
|
109
|
-
return "node";
|
|
110
|
-
}
|
|
111
|
-
async function resolveUpdateRoot() {
|
|
112
|
-
return await resolveGenesisPackageRoot({
|
|
113
|
-
moduleUrl: import.meta.url,
|
|
114
|
-
argv1: process.argv[1],
|
|
115
|
-
cwd: process.cwd()
|
|
116
|
-
}) ?? process.cwd();
|
|
117
|
-
}
|
|
118
|
-
async function runUpdateStep(params) {
|
|
119
|
-
const command = params.argv.join(" ");
|
|
120
|
-
params.progress?.onStepStart?.({
|
|
121
|
-
name: params.name,
|
|
122
|
-
command,
|
|
123
|
-
index: 0,
|
|
124
|
-
total: 0
|
|
125
|
-
});
|
|
126
|
-
const started = Date.now();
|
|
127
|
-
const res = await runCommandWithTimeout(params.argv, {
|
|
128
|
-
cwd: params.cwd,
|
|
129
|
-
env: params.env,
|
|
130
|
-
timeoutMs: params.timeoutMs
|
|
131
|
-
});
|
|
132
|
-
const durationMs = Date.now() - started;
|
|
133
|
-
const stderrTail = trimLogTail(res.stderr, MAX_LOG_CHARS);
|
|
134
|
-
params.progress?.onStepComplete?.({
|
|
135
|
-
name: params.name,
|
|
136
|
-
command,
|
|
137
|
-
index: 0,
|
|
138
|
-
total: 0,
|
|
139
|
-
durationMs,
|
|
140
|
-
exitCode: res.code,
|
|
141
|
-
stderrTail
|
|
142
|
-
});
|
|
143
|
-
return {
|
|
144
|
-
name: params.name,
|
|
145
|
-
command,
|
|
146
|
-
cwd: params.cwd ?? process.cwd(),
|
|
147
|
-
durationMs,
|
|
148
|
-
exitCode: res.code,
|
|
149
|
-
stdoutTail: trimLogTail(res.stdout, MAX_LOG_CHARS),
|
|
150
|
-
stderrTail
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
async function ensureGitCheckout(params) {
|
|
154
|
-
const gitEnv = params.env ?? await createGlobalInstallEnv();
|
|
155
|
-
if (!await pathExists(params.dir)) return await runUpdateStep({
|
|
156
|
-
name: "git clone",
|
|
157
|
-
argv: [
|
|
158
|
-
"git",
|
|
159
|
-
"clone",
|
|
160
|
-
GENESIS_REPO_URL,
|
|
161
|
-
params.dir
|
|
162
|
-
],
|
|
163
|
-
env: gitEnv,
|
|
164
|
-
timeoutMs: params.timeoutMs,
|
|
165
|
-
progress: params.progress
|
|
166
|
-
});
|
|
167
|
-
if (!await isGitCheckout(params.dir)) {
|
|
168
|
-
if (!await isEmptyDir(params.dir)) throw new Error(`GENESIS_GIT_DIR points at a non-git directory: ${params.dir}. Set GENESIS_GIT_DIR to an empty folder or an genesis checkout.`);
|
|
169
|
-
return await runUpdateStep({
|
|
170
|
-
name: "git clone",
|
|
171
|
-
argv: [
|
|
172
|
-
"git",
|
|
173
|
-
"clone",
|
|
174
|
-
GENESIS_REPO_URL,
|
|
175
|
-
params.dir
|
|
176
|
-
],
|
|
177
|
-
cwd: params.dir,
|
|
178
|
-
env: gitEnv,
|
|
179
|
-
timeoutMs: params.timeoutMs,
|
|
180
|
-
progress: params.progress
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
if (!await isCorePackage(params.dir)) throw new Error(`GENESIS_GIT_DIR does not look like a core checkout: ${params.dir}.`);
|
|
184
|
-
return null;
|
|
185
|
-
}
|
|
186
|
-
async function resolveGlobalManager(params) {
|
|
187
|
-
const runCommand = createGlobalCommandRunner();
|
|
188
|
-
if (params.installKind === "package") {
|
|
189
|
-
const detected = await detectGlobalInstallManagerForRoot(runCommand, params.root, params.timeoutMs);
|
|
190
|
-
if (detected) return detected;
|
|
191
|
-
}
|
|
192
|
-
return await detectGlobalInstallManagerByPresence(runCommand, params.timeoutMs) ?? "npm";
|
|
193
|
-
}
|
|
194
|
-
const COMPLETION_CACHE_WRITE_TIMEOUT_MS = 3e4;
|
|
195
|
-
async function tryWriteCompletionCache(root, jsonMode) {
|
|
196
|
-
const binPath = path.join(root, "genesis.mjs");
|
|
197
|
-
if (!await pathExists(binPath)) return;
|
|
198
|
-
const result = spawnSync(resolveNodeRunner(), [
|
|
199
|
-
binPath,
|
|
200
|
-
"completion",
|
|
201
|
-
"--write-state"
|
|
202
|
-
], {
|
|
203
|
-
cwd: root,
|
|
204
|
-
env: process.env,
|
|
205
|
-
encoding: "utf-8",
|
|
206
|
-
timeout: COMPLETION_CACHE_WRITE_TIMEOUT_MS
|
|
207
|
-
});
|
|
208
|
-
if (result.error) {
|
|
209
|
-
if (!jsonMode) defaultRuntime.log(theme.warn(`Completion cache update failed: ${String(result.error)}`));
|
|
210
|
-
return;
|
|
211
|
-
}
|
|
212
|
-
if (result.status !== 0 && !jsonMode) {
|
|
213
|
-
const stderr = (result.stderr ?? "").trim();
|
|
214
|
-
const detail = stderr ? ` (${stderr})` : "";
|
|
215
|
-
defaultRuntime.log(theme.warn(`Completion cache update failed${detail}.`));
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
function createGlobalCommandRunner() {
|
|
219
|
-
return async (argv, options) => {
|
|
220
|
-
const res = await runCommandWithTimeout(argv, options);
|
|
221
|
-
return {
|
|
222
|
-
stdout: res.stdout,
|
|
223
|
-
stderr: res.stderr,
|
|
224
|
-
code: res.code
|
|
225
|
-
};
|
|
226
|
-
};
|
|
227
|
-
}
|
|
228
|
-
//#endregion
|
|
229
|
-
//#region src/cli/update-cli/status.ts
|
|
230
|
-
function formatGitStatusLine(params) {
|
|
231
|
-
const shortSha = params.sha ? params.sha.slice(0, 8) : null;
|
|
232
|
-
const branch = params.branch && params.branch !== "HEAD" ? params.branch : null;
|
|
233
|
-
const tag = params.tag;
|
|
234
|
-
return [
|
|
235
|
-
branch ?? (tag ? "detached" : "git"),
|
|
236
|
-
tag ? `tag ${tag}` : null,
|
|
237
|
-
shortSha ? `@ ${shortSha}` : null
|
|
238
|
-
].filter(Boolean).join(" · ");
|
|
239
|
-
}
|
|
240
|
-
async function updateStatusCommand(opts) {
|
|
241
|
-
const timeoutMs = parseTimeoutMsOrExit(opts.timeout);
|
|
242
|
-
if (timeoutMs === null) return;
|
|
243
|
-
const root = await resolveUpdateRoot();
|
|
244
|
-
const configSnapshot = await readConfigFileSnapshot();
|
|
245
|
-
const configChannel = configSnapshot.valid ? normalizeUpdateChannel(configSnapshot.config.update?.channel) : null;
|
|
246
|
-
const update = await checkUpdateStatus({
|
|
247
|
-
root,
|
|
248
|
-
timeoutMs: timeoutMs ?? 3500,
|
|
249
|
-
fetchGit: true,
|
|
250
|
-
includeRegistry: true
|
|
251
|
-
});
|
|
252
|
-
const channelInfo = resolveUpdateChannelDisplay({
|
|
253
|
-
configChannel,
|
|
254
|
-
installKind: update.installKind,
|
|
255
|
-
gitTag: update.git?.tag ?? null,
|
|
256
|
-
gitBranch: update.git?.branch ?? null
|
|
257
|
-
});
|
|
258
|
-
const channelLabel = channelInfo.label;
|
|
259
|
-
const gitLabel = update.installKind === "git" ? formatGitStatusLine({
|
|
260
|
-
branch: update.git?.branch ?? null,
|
|
261
|
-
tag: update.git?.tag ?? null,
|
|
262
|
-
sha: update.git?.sha ?? null
|
|
263
|
-
}) : null;
|
|
264
|
-
const updateAvailability = resolveUpdateAvailability(update);
|
|
265
|
-
const updateLine = formatUpdateOneLiner(update).replace(/^Update:\s*/i, "");
|
|
266
|
-
if (opts.json) {
|
|
267
|
-
defaultRuntime.writeJson({
|
|
268
|
-
update,
|
|
269
|
-
channel: {
|
|
270
|
-
value: channelInfo.channel,
|
|
271
|
-
source: channelInfo.source,
|
|
272
|
-
label: channelLabel,
|
|
273
|
-
config: configChannel
|
|
274
|
-
},
|
|
275
|
-
availability: updateAvailability
|
|
276
|
-
});
|
|
277
|
-
return;
|
|
278
|
-
}
|
|
279
|
-
const tableWidth = getTerminalTableWidth();
|
|
280
|
-
const rows = [
|
|
281
|
-
{
|
|
282
|
-
Item: "Install",
|
|
283
|
-
Value: update.installKind === "git" ? `git (${update.root ?? "unknown"})` : update.installKind === "package" ? update.packageManager : "unknown"
|
|
284
|
-
},
|
|
285
|
-
{
|
|
286
|
-
Item: "Channel",
|
|
287
|
-
Value: channelLabel
|
|
288
|
-
},
|
|
289
|
-
...gitLabel ? [{
|
|
290
|
-
Item: "Git",
|
|
291
|
-
Value: gitLabel
|
|
292
|
-
}] : [],
|
|
293
|
-
{
|
|
294
|
-
Item: "Update",
|
|
295
|
-
Value: updateAvailability.available ? theme.warn(`available · ${updateLine}`) : updateLine
|
|
296
|
-
}
|
|
297
|
-
];
|
|
298
|
-
defaultRuntime.log(theme.heading("Genesis update status"));
|
|
299
|
-
defaultRuntime.log("");
|
|
300
|
-
defaultRuntime.log(renderTable({
|
|
301
|
-
width: tableWidth,
|
|
302
|
-
columns: [{
|
|
303
|
-
key: "Item",
|
|
304
|
-
header: "Item",
|
|
305
|
-
minWidth: 10
|
|
306
|
-
}, {
|
|
307
|
-
key: "Value",
|
|
308
|
-
header: "Value",
|
|
309
|
-
flex: true,
|
|
310
|
-
minWidth: 24
|
|
311
|
-
}],
|
|
312
|
-
rows
|
|
313
|
-
}).trimEnd());
|
|
314
|
-
defaultRuntime.log("");
|
|
315
|
-
const updateHint = formatUpdateAvailableHint(update);
|
|
316
|
-
if (updateHint) defaultRuntime.log(theme.warn(updateHint));
|
|
317
|
-
}
|
|
318
|
-
//#endregion
|
|
319
|
-
//#region src/cli/update-cli/progress.ts
|
|
320
|
-
const STEP_LABELS = {
|
|
321
|
-
"clean check": "Working directory is clean",
|
|
322
|
-
"upstream check": "Upstream branch exists",
|
|
323
|
-
"git fetch": "Fetching latest changes",
|
|
324
|
-
"git rebase": "Rebasing onto target commit",
|
|
325
|
-
"git rev-parse @{upstream}": "Resolving upstream commit",
|
|
326
|
-
"git rev-list": "Enumerating candidate commits",
|
|
327
|
-
"git clone": "Cloning git checkout",
|
|
328
|
-
"preflight worktree": "Preparing preflight worktree",
|
|
329
|
-
"preflight cleanup": "Cleaning preflight worktree",
|
|
330
|
-
"deps install": "Installing dependencies",
|
|
331
|
-
build: "Building",
|
|
332
|
-
"ui:build": "Building UI assets",
|
|
333
|
-
"ui:build (post-doctor repair)": "Restoring missing UI assets",
|
|
334
|
-
"ui assets verify": "Validating UI assets",
|
|
335
|
-
"genesis doctor entry": "Checking doctor entrypoint",
|
|
336
|
-
"genesis doctor": "Running doctor checks",
|
|
337
|
-
"git rev-parse HEAD (after)": "Verifying update",
|
|
338
|
-
"global update": "Updating via package manager",
|
|
339
|
-
"global update (omit optional)": "Retrying update without optional deps",
|
|
340
|
-
"global install": "Installing global package"
|
|
341
|
-
};
|
|
342
|
-
const GENESIS_NPM_PACKAGE_NAME = "@pixelzx/genesis";
|
|
343
|
-
function getStepLabel(step) {
|
|
344
|
-
return STEP_LABELS[step.name] ?? step.name;
|
|
345
|
-
}
|
|
346
|
-
function inferUpdateFailureHints(result) {
|
|
347
|
-
if (result.status !== "error") return [];
|
|
348
|
-
if (result.reason === "pnpm-corepack-missing") return ["This pnpm checkout could not auto-enable pnpm because corepack is missing.", "Install pnpm manually or install Node with corepack available, then rerun the update command."];
|
|
349
|
-
if (result.reason === "pnpm-corepack-enable-failed") return ["This pnpm checkout could not auto-enable pnpm via corepack.", "Run `corepack enable` manually or install pnpm manually, then rerun the update command."];
|
|
350
|
-
if (result.reason === "pnpm-npm-bootstrap-failed") return ["This pnpm checkout could not bootstrap pnpm from npm automatically.", "Install pnpm manually, then rerun the update command."];
|
|
351
|
-
if (result.reason === "preferred-manager-unavailable") return ["This checkout requires its declared package manager and the updater could not find it.", "Install the missing package manager manually, then rerun the update command."];
|
|
352
|
-
if (result.mode !== "npm") return [];
|
|
353
|
-
const failedStep = [...result.steps].toReversed().find((step) => step.exitCode !== 0);
|
|
354
|
-
if (!failedStep) return [];
|
|
355
|
-
const stderr = normalizeLowercaseStringOrEmpty(failedStep.stderrTail);
|
|
356
|
-
const hints = [];
|
|
357
|
-
if (failedStep.name.startsWith("global update") && stderr.includes("eacces")) {
|
|
358
|
-
hints.push("Detected permission failure (EACCES). Re-run with a writable global prefix or sudo (for system-managed Node installs).");
|
|
359
|
-
hints.push(`Example: npm config set prefix ~/.local && npm i -g ${GENESIS_NPM_PACKAGE_NAME}@latest`);
|
|
360
|
-
}
|
|
361
|
-
if (failedStep.name.startsWith("global update") && (stderr.includes("node-gyp") || stderr.includes("prebuild"))) {
|
|
362
|
-
hints.push("Detected native optional dependency build failure. The updater retries with --omit=optional automatically.");
|
|
363
|
-
hints.push(`If it still fails: npm i -g ${GENESIS_NPM_PACKAGE_NAME}@latest --omit=optional`);
|
|
364
|
-
}
|
|
365
|
-
return hints;
|
|
366
|
-
}
|
|
367
|
-
function createUpdateProgress(enabled) {
|
|
368
|
-
if (!enabled) return {
|
|
369
|
-
progress: {},
|
|
370
|
-
stop: () => {}
|
|
371
|
-
};
|
|
372
|
-
let currentSpinner = null;
|
|
373
|
-
return {
|
|
374
|
-
progress: {
|
|
375
|
-
onStepStart: (step) => {
|
|
376
|
-
currentSpinner = spinner();
|
|
377
|
-
currentSpinner.start(theme.accent(getStepLabel(step)));
|
|
378
|
-
},
|
|
379
|
-
onStepComplete: (step) => {
|
|
380
|
-
if (!currentSpinner) return;
|
|
381
|
-
const label = getStepLabel(step);
|
|
382
|
-
const duration = theme.muted(`(${formatDurationPrecise(step.durationMs)})`);
|
|
383
|
-
const icon = step.exitCode === 0 ? theme.success("✓") : theme.error("✗");
|
|
384
|
-
currentSpinner.stop(`${icon} ${label} ${duration}`);
|
|
385
|
-
currentSpinner = null;
|
|
386
|
-
if (step.exitCode !== 0 && step.stderrTail) {
|
|
387
|
-
const lines = step.stderrTail.split("\n").slice(-10);
|
|
388
|
-
for (const line of lines) if (line.trim()) defaultRuntime.log(` ${theme.error(line)}`);
|
|
389
|
-
}
|
|
390
|
-
}
|
|
391
|
-
},
|
|
392
|
-
stop: () => {
|
|
393
|
-
if (currentSpinner) {
|
|
394
|
-
currentSpinner.stop();
|
|
395
|
-
currentSpinner = null;
|
|
396
|
-
}
|
|
397
|
-
}
|
|
398
|
-
};
|
|
399
|
-
}
|
|
400
|
-
function formatStepStatus(exitCode) {
|
|
401
|
-
if (exitCode === 0) return theme.success("✓");
|
|
402
|
-
if (exitCode === null) return theme.warn("?");
|
|
403
|
-
return theme.error("✗");
|
|
404
|
-
}
|
|
405
|
-
function printResult(result, opts) {
|
|
406
|
-
if (opts.json) {
|
|
407
|
-
defaultRuntime.writeJson(result);
|
|
408
|
-
return;
|
|
409
|
-
}
|
|
410
|
-
const statusColor = result.status === "ok" ? theme.success : result.status === "skipped" ? theme.warn : theme.error;
|
|
411
|
-
defaultRuntime.log("");
|
|
412
|
-
defaultRuntime.log(`${theme.heading("Update Result:")} ${statusColor(result.status.toUpperCase())}`);
|
|
413
|
-
if (result.root) defaultRuntime.log(` Root: ${theme.muted(result.root)}`);
|
|
414
|
-
if (result.reason) defaultRuntime.log(` Reason: ${theme.muted(result.reason)}`);
|
|
415
|
-
if (result.before?.version || result.before?.sha) {
|
|
416
|
-
const before = result.before.version ?? result.before.sha?.slice(0, 8) ?? "";
|
|
417
|
-
defaultRuntime.log(` Before: ${theme.muted(before)}`);
|
|
418
|
-
}
|
|
419
|
-
if (result.after?.version || result.after?.sha) {
|
|
420
|
-
const after = result.after.version ?? result.after.sha?.slice(0, 8) ?? "";
|
|
421
|
-
defaultRuntime.log(` After: ${theme.muted(after)}`);
|
|
422
|
-
}
|
|
423
|
-
if (!opts.hideSteps && result.steps.length > 0) {
|
|
424
|
-
defaultRuntime.log("");
|
|
425
|
-
defaultRuntime.log(theme.heading("Steps:"));
|
|
426
|
-
for (const step of result.steps) {
|
|
427
|
-
const status = formatStepStatus(step.exitCode);
|
|
428
|
-
const duration = theme.muted(`(${formatDurationPrecise(step.durationMs)})`);
|
|
429
|
-
defaultRuntime.log(` ${status} ${step.name} ${duration}`);
|
|
430
|
-
if (step.exitCode !== 0 && step.stderrTail) {
|
|
431
|
-
const lines = step.stderrTail.split("\n").slice(0, 5);
|
|
432
|
-
for (const line of lines) if (line.trim()) defaultRuntime.log(` ${theme.error(line)}`);
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
}
|
|
436
|
-
const hints = inferUpdateFailureHints(result);
|
|
437
|
-
if (hints.length > 0) {
|
|
438
|
-
defaultRuntime.log("");
|
|
439
|
-
defaultRuntime.log(theme.heading("Recovery hints:"));
|
|
440
|
-
for (const hint of hints) defaultRuntime.log(` - ${theme.warn(hint)}`);
|
|
441
|
-
}
|
|
442
|
-
defaultRuntime.log("");
|
|
443
|
-
defaultRuntime.log(`Total time: ${theme.muted(formatDurationPrecise(result.durationMs))}`);
|
|
444
|
-
}
|
|
445
|
-
//#endregion
|
|
446
|
-
//#region src/cli/update-cli/restart-helper.ts
|
|
447
|
-
/**
|
|
448
|
-
* Shell-escape a string for embedding in single-quoted shell arguments.
|
|
449
|
-
* Replaces every `'` with `'\''` (end quote, escaped quote, resume quote).
|
|
450
|
-
* For batch scripts, validates against special characters instead.
|
|
451
|
-
*/
|
|
452
|
-
function shellEscape(value) {
|
|
453
|
-
return value.replace(/'/g, "'\\''");
|
|
454
|
-
}
|
|
455
|
-
/** Validates a string is safe for embedding in a batch (cmd.exe) script. */
|
|
456
|
-
function isBatchSafe(value) {
|
|
457
|
-
return /^[A-Za-z0-9 _\-().]+$/.test(value);
|
|
458
|
-
}
|
|
459
|
-
function resolveSystemdUnit(env) {
|
|
460
|
-
const override = normalizeOptionalString(env.GENESIS_SYSTEMD_UNIT);
|
|
461
|
-
if (override) return override.endsWith(".service") ? override : `${override}.service`;
|
|
462
|
-
return `${resolveGatewaySystemdServiceName(env.GENESIS_PROFILE)}.service`;
|
|
463
|
-
}
|
|
464
|
-
function resolveLaunchdLabel(env) {
|
|
465
|
-
const override = normalizeOptionalString(env.GENESIS_LAUNCHD_LABEL);
|
|
466
|
-
if (override) return override;
|
|
467
|
-
return resolveGatewayLaunchAgentLabel(env.GENESIS_PROFILE);
|
|
468
|
-
}
|
|
469
|
-
function resolveWindowsTaskName(env) {
|
|
470
|
-
const override = env.GENESIS_WINDOWS_TASK_NAME?.trim();
|
|
471
|
-
if (override) return override;
|
|
472
|
-
return resolveGatewayWindowsTaskName(env.GENESIS_PROFILE);
|
|
473
|
-
}
|
|
474
|
-
/**
|
|
475
|
-
* Prepares a standalone script to restart the gateway service.
|
|
476
|
-
* This script is written to a temporary directory and does not depend on
|
|
477
|
-
* the installed package files, ensuring restart capability even if the
|
|
478
|
-
* update process temporarily removes or corrupts installation files.
|
|
479
|
-
*/
|
|
480
|
-
async function prepareRestartScript(env = process.env, gatewayPort = DEFAULT_GATEWAY_PORT) {
|
|
481
|
-
const tmpDir = os.tmpdir();
|
|
482
|
-
const timestamp = Date.now();
|
|
483
|
-
const platform = process.platform;
|
|
484
|
-
let scriptContent = "";
|
|
485
|
-
let filename = "";
|
|
486
|
-
try {
|
|
487
|
-
if (platform === "linux") {
|
|
488
|
-
const escaped = shellEscape(resolveSystemdUnit(env));
|
|
489
|
-
const logSetup = renderPosixRestartLogSetup({
|
|
490
|
-
...process.env,
|
|
491
|
-
...env
|
|
492
|
-
});
|
|
493
|
-
filename = `genesis-restart-${timestamp}.sh`;
|
|
494
|
-
scriptContent = `#!/bin/sh
|
|
495
|
-
# Standalone restart script — survives parent process termination.
|
|
496
|
-
# Wait briefly to ensure file locks are released after update.
|
|
497
|
-
sleep 1
|
|
498
|
-
${logSetup}
|
|
499
|
-
printf '[%s] genesis restart attempt source=update target=%s\\n' "$(date -u +%FT%TZ)" '${escaped}' >&2
|
|
500
|
-
if systemctl --user restart '${escaped}'; then
|
|
501
|
-
status=0
|
|
502
|
-
printf '[%s] genesis restart done source=update\\n' "$(date -u +%FT%TZ)" >&2
|
|
503
|
-
else
|
|
504
|
-
status=$?
|
|
505
|
-
printf '[%s] genesis restart failed source=update status=%s\\n' "$(date -u +%FT%TZ)" "$status" >&2
|
|
506
|
-
fi
|
|
507
|
-
# Self-cleanup
|
|
508
|
-
rm -f "$0"
|
|
509
|
-
exit "$status"
|
|
510
|
-
`;
|
|
511
|
-
} else if (platform === "darwin") {
|
|
512
|
-
const label = resolveLaunchdLabel(env);
|
|
513
|
-
const escaped = shellEscape(label);
|
|
514
|
-
const uid = process.getuid ? process.getuid() : 501;
|
|
515
|
-
const home = normalizeOptionalString(env.HOME) || process.env.HOME || os.homedir();
|
|
516
|
-
const escapedPlistPath = shellEscape(path.join(home, "Library", "LaunchAgents", `${label}.plist`));
|
|
517
|
-
const logSetup = renderPosixRestartLogSetup({
|
|
518
|
-
...process.env,
|
|
519
|
-
...env
|
|
520
|
-
});
|
|
521
|
-
filename = `genesis-restart-${timestamp}.sh`;
|
|
522
|
-
scriptContent = `#!/bin/sh
|
|
523
|
-
# Standalone restart script — survives parent process termination.
|
|
524
|
-
# Wait briefly to ensure file locks are released after update.
|
|
525
|
-
sleep 1
|
|
526
|
-
# Capture launchctl output so bootstrap/kickstart failures leave a durable
|
|
527
|
-
# audit trail. Log setup is best-effort: restart must still run if the log path
|
|
528
|
-
# is temporarily unavailable.
|
|
529
|
-
${logSetup}
|
|
530
|
-
printf '[%s] genesis restart attempt source=update target=%s\\n' "$(date -u +%FT%TZ)" '${shellEscapeRestartLogValue(label)}' >&2
|
|
531
|
-
# Try kickstart first (works when the service is still registered).
|
|
532
|
-
# If it fails (e.g. after bootout), clear any persisted disabled state,
|
|
533
|
-
# then re-register via bootstrap and kickstart. The final status is captured
|
|
534
|
-
# before self-cleanup so a genuine failure remains observable.
|
|
535
|
-
status=0
|
|
536
|
-
if ! launchctl kickstart -k 'gui/${uid}/${escaped}'; then
|
|
537
|
-
launchctl enable 'gui/${uid}/${escaped}'
|
|
538
|
-
launchctl bootstrap 'gui/${uid}' '${escapedPlistPath}'
|
|
539
|
-
launchctl kickstart -k 'gui/${uid}/${escaped}'
|
|
540
|
-
status=$?
|
|
541
|
-
fi
|
|
542
|
-
if [ "$status" -eq 0 ]; then
|
|
543
|
-
printf '[%s] genesis restart done source=update\\n' "$(date -u +%FT%TZ)" >&2
|
|
544
|
-
else
|
|
545
|
-
printf '[%s] genesis restart failed source=update status=%s\\n' "$(date -u +%FT%TZ)" "$status" >&2
|
|
546
|
-
fi
|
|
547
|
-
# Self-cleanup (log is retained under the Genesis state logs directory).
|
|
548
|
-
rm -f "$0"
|
|
549
|
-
exit "$status"
|
|
550
|
-
`;
|
|
551
|
-
} else if (platform === "win32") {
|
|
552
|
-
const taskName = resolveWindowsTaskName(env);
|
|
553
|
-
if (!isBatchSafe(taskName)) return null;
|
|
554
|
-
const port = Number.isFinite(gatewayPort) && gatewayPort > 0 ? gatewayPort : DEFAULT_GATEWAY_PORT;
|
|
555
|
-
const restartLog = renderCmdRestartLogSetup({
|
|
556
|
-
...process.env,
|
|
557
|
-
...env
|
|
558
|
-
});
|
|
559
|
-
filename = `genesis-restart-${timestamp}.bat`;
|
|
560
|
-
scriptContent = `@echo off
|
|
561
|
-
REM Standalone restart script — survives parent process termination.
|
|
562
|
-
REM Wait briefly to ensure file locks are released after update.
|
|
563
|
-
timeout /t 2 /nobreak >nul
|
|
564
|
-
${restartLog.lines.join("\r\n")}
|
|
565
|
-
>> ${restartLog.quotedLogPath} 2>&1 echo [%DATE% %TIME%] genesis restart attempt source=update target=${taskName}
|
|
566
|
-
schtasks /End /TN "${taskName}" >> ${restartLog.quotedLogPath} 2>&1
|
|
567
|
-
REM Poll for gateway port release before rerun; force-kill listener if stuck.
|
|
568
|
-
set /a attempts=0
|
|
569
|
-
:wait_for_port_release
|
|
570
|
-
set /a attempts+=1
|
|
571
|
-
netstat -ano | findstr /R /C:":${port} .*LISTENING" >nul
|
|
572
|
-
if errorlevel 1 goto port_released
|
|
573
|
-
if %attempts% GEQ 10 goto force_kill_listener
|
|
574
|
-
timeout /t 1 /nobreak >nul
|
|
575
|
-
goto wait_for_port_release
|
|
576
|
-
:force_kill_listener
|
|
577
|
-
for /f "tokens=5" %%P in ('netstat -ano ^| findstr /R /C:":${port} .*LISTENING"') do (
|
|
578
|
-
taskkill /F /PID %%P >> ${restartLog.quotedLogPath} 2>&1
|
|
579
|
-
goto port_released
|
|
580
|
-
)
|
|
581
|
-
:port_released
|
|
582
|
-
schtasks /Run /TN "${taskName}" >> ${restartLog.quotedLogPath} 2>&1
|
|
583
|
-
set "status=%ERRORLEVEL%"
|
|
584
|
-
if not "%status%"=="0" (
|
|
585
|
-
>> ${restartLog.quotedLogPath} 2>&1 echo [%DATE% %TIME%] genesis restart failed source=update status=%status%
|
|
586
|
-
) else (
|
|
587
|
-
>> ${restartLog.quotedLogPath} 2>&1 echo [%DATE% %TIME%] genesis restart done source=update
|
|
588
|
-
)
|
|
589
|
-
REM Self-cleanup
|
|
590
|
-
del "%~f0"
|
|
591
|
-
exit /b %status%
|
|
592
|
-
`;
|
|
593
|
-
} else return null;
|
|
594
|
-
const scriptPath = path.join(tmpDir, filename);
|
|
595
|
-
await fs.writeFile(scriptPath, scriptContent, { mode: 493 });
|
|
596
|
-
return scriptPath;
|
|
597
|
-
} catch {
|
|
598
|
-
return null;
|
|
599
|
-
}
|
|
600
|
-
}
|
|
601
|
-
/**
|
|
602
|
-
* Executes the prepared restart script as a **detached** process.
|
|
603
|
-
*
|
|
604
|
-
* The script must outlive the CLI process because the CLI itself is part
|
|
605
|
-
* of the service being restarted — `systemctl restart` / `launchctl
|
|
606
|
-
* kickstart -k` will terminate the current process tree. Using
|
|
607
|
-
* `spawn({ detached: true })` + `unref()` ensures the script survives
|
|
608
|
-
* the parent's exit.
|
|
609
|
-
*
|
|
610
|
-
* Resolves immediately after spawning; the script runs independently.
|
|
611
|
-
*/
|
|
612
|
-
async function runRestartScript(scriptPath) {
|
|
613
|
-
const isWindows = process.platform === "win32";
|
|
614
|
-
spawn(isWindows ? "cmd.exe" : "/bin/sh", isWindows ? [
|
|
615
|
-
"/d",
|
|
616
|
-
"/s",
|
|
617
|
-
"/c",
|
|
618
|
-
quoteCmdScriptArg(scriptPath)
|
|
619
|
-
] : [scriptPath], {
|
|
620
|
-
detached: true,
|
|
621
|
-
stdio: "ignore",
|
|
622
|
-
windowsHide: true
|
|
623
|
-
}).unref();
|
|
624
|
-
}
|
|
625
|
-
//#endregion
|
|
626
|
-
//#region src/cli/update-cli/suppress-deprecations.ts
|
|
627
|
-
/**
|
|
628
|
-
* Suppress Node.js deprecation warnings.
|
|
629
|
-
*
|
|
630
|
-
* On Node.js v23+ `process.noDeprecation` may be a read-only property
|
|
631
|
-
* (defined via a getter on the prototype with no setter), so the
|
|
632
|
-
* assignment can throw. We fall back to the environment variable which
|
|
633
|
-
* achieves the same effect.
|
|
634
|
-
*/
|
|
635
|
-
function suppressDeprecations() {
|
|
636
|
-
try {
|
|
637
|
-
process.noDeprecation = true;
|
|
638
|
-
} catch {}
|
|
639
|
-
process.env.NODE_NO_WARNINGS = "1";
|
|
640
|
-
}
|
|
641
|
-
//#endregion
|
|
642
|
-
//#region src/cli/update-cli/update-command.ts
|
|
643
|
-
const CLI_NAME = resolveCliName();
|
|
644
|
-
const SERVICE_REFRESH_TIMEOUT_MS = 6e4;
|
|
645
|
-
const POST_CORE_UPDATE_ENV = "GENESIS_UPDATE_POST_CORE";
|
|
646
|
-
const POST_CORE_UPDATE_CHANNEL_ENV = "GENESIS_UPDATE_POST_CORE_CHANNEL";
|
|
647
|
-
const POST_CORE_UPDATE_RESULT_PATH_ENV = "GENESIS_UPDATE_POST_CORE_RESULT_PATH";
|
|
648
|
-
const SERVICE_REFRESH_PATH_ENV_KEYS = [
|
|
649
|
-
"GENESIS_HOME",
|
|
650
|
-
"GENESIS_STATE_DIR",
|
|
651
|
-
"GENESIS_CONFIG_PATH"
|
|
652
|
-
];
|
|
653
|
-
const UPDATE_QUIPS = [
|
|
654
|
-
"Leveled up! New skills unlocked. You're welcome.",
|
|
655
|
-
"Fresh code, same lobster. Miss me?",
|
|
656
|
-
"Back and better. Did you even notice I was gone?",
|
|
657
|
-
"Update complete. I learned some new tricks while I was out.",
|
|
658
|
-
"Upgraded! Now with 23% more sass.",
|
|
659
|
-
"I've evolved. Try to keep up.",
|
|
660
|
-
"New version, who dis? Oh right, still me but shinier.",
|
|
661
|
-
"Patched, polished, and ready to pinch. Let's go.",
|
|
662
|
-
"The lobster has molted. Harder shell, sharper claws.",
|
|
663
|
-
"Update done! Check the changelog or just trust me, it's good.",
|
|
664
|
-
"Reborn from the boiling waters of npm. Stronger now.",
|
|
665
|
-
"I went away and came back smarter. You should try it sometime.",
|
|
666
|
-
"Update complete. The bugs feared me, so they left.",
|
|
667
|
-
"New version installed. Old version sends its regards.",
|
|
668
|
-
"Firmware fresh. Brain wrinkles: increased.",
|
|
669
|
-
"I've seen things you wouldn't believe. Anyway, I'm updated.",
|
|
670
|
-
"Back online. The changelog is long but our friendship is longer.",
|
|
671
|
-
"Upgraded! Peter fixed stuff. Blame him if it breaks.",
|
|
672
|
-
"Molting complete. Please don't look at my soft shell phase.",
|
|
673
|
-
"Version bump! Same chaos energy, fewer crashes (probably)."
|
|
674
|
-
];
|
|
675
|
-
function pickUpdateQuip() {
|
|
676
|
-
return UPDATE_QUIPS[Math.floor(Math.random() * UPDATE_QUIPS.length)] ?? "Update complete.";
|
|
677
|
-
}
|
|
678
|
-
function isPackageManagerUpdateMode(mode) {
|
|
679
|
-
return mode === "npm" || mode === "pnpm" || mode === "bun";
|
|
680
|
-
}
|
|
681
|
-
function formatCommandFailure(stdout, stderr) {
|
|
682
|
-
const detail = (stderr || stdout).trim();
|
|
683
|
-
if (!detail) return "command returned a non-zero exit code";
|
|
684
|
-
return detail.split("\n").slice(-3).join("\n");
|
|
685
|
-
}
|
|
686
|
-
function tryResolveInvocationCwd() {
|
|
687
|
-
try {
|
|
688
|
-
return process.cwd();
|
|
689
|
-
} catch {
|
|
690
|
-
return;
|
|
691
|
-
}
|
|
692
|
-
}
|
|
693
|
-
async function resolvePackageRuntimePreflightError(params) {
|
|
694
|
-
if (!canResolveRegistryVersionForPackageTarget(params.tag)) return null;
|
|
695
|
-
const target = params.tag.trim();
|
|
696
|
-
if (!target) return null;
|
|
697
|
-
const status = await fetchNpmPackageTargetStatus({
|
|
698
|
-
packageName: params.packageName,
|
|
699
|
-
target,
|
|
700
|
-
timeoutMs: params.timeoutMs
|
|
701
|
-
});
|
|
702
|
-
if (status.error) return null;
|
|
703
|
-
if (nodeVersionSatisfiesEngine(process.versions.node ?? null, status.nodeEngine) !== false) return null;
|
|
704
|
-
const targetLabel = status.version ?? target;
|
|
705
|
-
return [
|
|
706
|
-
`Node ${process.versions.node ?? "unknown"} is too old for ${params.packageName}@${targetLabel}.`,
|
|
707
|
-
`The requested package requires ${status.nodeEngine}.`,
|
|
708
|
-
"Upgrade Node to 22.14+ or Node 24, then rerun `genesis update`.",
|
|
709
|
-
`Bare \`npm i -g ${params.packageName}\` can silently install an older compatible release.`,
|
|
710
|
-
`After upgrading Node, use \`npm i -g ${params.packageName}@latest\`.`
|
|
711
|
-
].join("\n");
|
|
712
|
-
}
|
|
713
|
-
function resolveServiceRefreshEnv(env, invocationCwd) {
|
|
714
|
-
const resolvedEnv = { ...env };
|
|
715
|
-
for (const key of SERVICE_REFRESH_PATH_ENV_KEYS) {
|
|
716
|
-
const rawValue = resolvedEnv[key]?.trim();
|
|
717
|
-
if (!rawValue) continue;
|
|
718
|
-
if (rawValue.startsWith("~") || path.isAbsolute(rawValue) || path.win32.isAbsolute(rawValue)) {
|
|
719
|
-
resolvedEnv[key] = rawValue;
|
|
720
|
-
continue;
|
|
721
|
-
}
|
|
722
|
-
if (!invocationCwd) {
|
|
723
|
-
resolvedEnv[key] = rawValue;
|
|
724
|
-
continue;
|
|
725
|
-
}
|
|
726
|
-
resolvedEnv[key] = path.resolve(invocationCwd, rawValue);
|
|
727
|
-
}
|
|
728
|
-
return resolvedEnv;
|
|
729
|
-
}
|
|
730
|
-
function printDryRunPreview(preview, jsonMode) {
|
|
731
|
-
if (jsonMode) {
|
|
732
|
-
defaultRuntime.writeJson(preview);
|
|
733
|
-
return;
|
|
734
|
-
}
|
|
735
|
-
defaultRuntime.log(theme.heading("Update dry-run"));
|
|
736
|
-
defaultRuntime.log(theme.muted("No changes were applied."));
|
|
737
|
-
defaultRuntime.log("");
|
|
738
|
-
defaultRuntime.log(` Root: ${theme.muted(preview.root)}`);
|
|
739
|
-
defaultRuntime.log(` Install kind: ${theme.muted(preview.installKind)}`);
|
|
740
|
-
defaultRuntime.log(` Mode: ${theme.muted(preview.mode)}`);
|
|
741
|
-
defaultRuntime.log(` Channel: ${theme.muted(preview.effectiveChannel)}`);
|
|
742
|
-
defaultRuntime.log(` Tag/spec: ${theme.muted(preview.tag)}`);
|
|
743
|
-
if (preview.currentVersion) defaultRuntime.log(` Current version: ${theme.muted(preview.currentVersion)}`);
|
|
744
|
-
if (preview.targetVersion) defaultRuntime.log(` Target version: ${theme.muted(preview.targetVersion)}`);
|
|
745
|
-
if (preview.downgradeRisk) defaultRuntime.log(theme.warn(" Downgrade confirmation would be required in a real run."));
|
|
746
|
-
defaultRuntime.log("");
|
|
747
|
-
defaultRuntime.log(theme.heading("Planned actions:"));
|
|
748
|
-
for (const action of preview.actions) defaultRuntime.log(` - ${action}`);
|
|
749
|
-
if (preview.notes.length > 0) {
|
|
750
|
-
defaultRuntime.log("");
|
|
751
|
-
defaultRuntime.log(theme.heading("Notes:"));
|
|
752
|
-
for (const note of preview.notes) defaultRuntime.log(` - ${theme.muted(note)}`);
|
|
753
|
-
}
|
|
754
|
-
}
|
|
755
|
-
async function refreshGatewayServiceEnv(params) {
|
|
756
|
-
const args = [
|
|
757
|
-
"gateway",
|
|
758
|
-
"install",
|
|
759
|
-
"--force"
|
|
760
|
-
];
|
|
761
|
-
if (params.jsonMode) args.push("--json");
|
|
762
|
-
const entrypoint = await resolveGatewayInstallEntrypoint(params.result.root);
|
|
763
|
-
if (entrypoint) {
|
|
764
|
-
const res = await runCommandWithTimeout([
|
|
765
|
-
resolveNodeRunner(),
|
|
766
|
-
entrypoint,
|
|
767
|
-
...args
|
|
768
|
-
], {
|
|
769
|
-
cwd: params.result.root,
|
|
770
|
-
env: resolveServiceRefreshEnv(process.env, params.invocationCwd),
|
|
771
|
-
timeoutMs: SERVICE_REFRESH_TIMEOUT_MS
|
|
772
|
-
});
|
|
773
|
-
if (res.code === 0) return;
|
|
774
|
-
throw new Error(`updated install refresh failed (${entrypoint}): ${formatCommandFailure(res.stdout, res.stderr)}`);
|
|
775
|
-
}
|
|
776
|
-
await runDaemonInstall({
|
|
777
|
-
force: true,
|
|
778
|
-
json: params.jsonMode || void 0
|
|
779
|
-
});
|
|
780
|
-
}
|
|
781
|
-
async function tryInstallShellCompletion(opts) {
|
|
782
|
-
if (opts.jsonMode || !process.stdin.isTTY) return;
|
|
783
|
-
const status = await checkShellCompletionStatus(CLI_NAME);
|
|
784
|
-
if (status.usesSlowPattern) {
|
|
785
|
-
defaultRuntime.log(theme.muted("Upgrading shell completion to cached version..."));
|
|
786
|
-
if (await ensureCompletionCacheExists(CLI_NAME)) await installCompletion(status.shell, true, CLI_NAME);
|
|
787
|
-
return;
|
|
788
|
-
}
|
|
789
|
-
if (status.profileInstalled && !status.cacheExists) {
|
|
790
|
-
defaultRuntime.log(theme.muted("Regenerating shell completion cache..."));
|
|
791
|
-
await ensureCompletionCacheExists(CLI_NAME);
|
|
792
|
-
return;
|
|
793
|
-
}
|
|
794
|
-
if (!status.profileInstalled) {
|
|
795
|
-
defaultRuntime.log("");
|
|
796
|
-
defaultRuntime.log(theme.heading("Shell completion"));
|
|
797
|
-
const shouldInstall = await confirm({
|
|
798
|
-
message: stylePromptMessage(`Enable ${status.shell} shell completion for ${CLI_NAME}?`),
|
|
799
|
-
initialValue: true
|
|
800
|
-
});
|
|
801
|
-
if (isCancel(shouldInstall) || !shouldInstall) {
|
|
802
|
-
if (!opts.skipPrompt) defaultRuntime.log(theme.muted(`Skipped. Run \`${replaceCliName(formatCliCommand("genesis completion --install"), CLI_NAME)}\` later to enable.`));
|
|
803
|
-
return;
|
|
804
|
-
}
|
|
805
|
-
if (!await ensureCompletionCacheExists(CLI_NAME)) {
|
|
806
|
-
defaultRuntime.log(theme.warn("Failed to generate completion cache."));
|
|
807
|
-
return;
|
|
808
|
-
}
|
|
809
|
-
await installCompletion(status.shell, opts.skipPrompt, CLI_NAME);
|
|
810
|
-
}
|
|
811
|
-
}
|
|
812
|
-
async function runPackageInstallUpdate(params) {
|
|
813
|
-
const manager = await resolveGlobalManager({
|
|
814
|
-
root: params.root,
|
|
815
|
-
installKind: params.installKind,
|
|
816
|
-
timeoutMs: params.timeoutMs
|
|
817
|
-
});
|
|
818
|
-
const installEnv = await createGlobalInstallEnv();
|
|
819
|
-
const runCommand = createGlobalCommandRunner();
|
|
820
|
-
const installTarget = await resolveGlobalInstallTarget({
|
|
821
|
-
manager,
|
|
822
|
-
runCommand,
|
|
823
|
-
timeoutMs: params.timeoutMs,
|
|
824
|
-
pkgRoot: params.root
|
|
825
|
-
});
|
|
826
|
-
const pkgRoot = installTarget.packageRoot;
|
|
827
|
-
const packageName = (pkgRoot ? await readPackageName(pkgRoot) : await readPackageName(params.root)) ?? "@pixelzx/genesis";
|
|
828
|
-
const installSpec = resolveGlobalInstallSpec({
|
|
829
|
-
packageName,
|
|
830
|
-
tag: params.tag,
|
|
831
|
-
env: installEnv
|
|
832
|
-
});
|
|
833
|
-
const beforeVersion = pkgRoot ? await readPackageVersion(pkgRoot) : null;
|
|
834
|
-
if (pkgRoot) await cleanupGlobalRenameDirs({
|
|
835
|
-
globalRoot: path.dirname(pkgRoot),
|
|
836
|
-
packageName
|
|
837
|
-
});
|
|
838
|
-
const updateStep = await runUpdateStep({
|
|
839
|
-
name: "global update",
|
|
840
|
-
argv: globalInstallArgs(installTarget, installSpec),
|
|
841
|
-
env: installEnv,
|
|
842
|
-
timeoutMs: params.timeoutMs,
|
|
843
|
-
progress: params.progress
|
|
844
|
-
});
|
|
845
|
-
const steps = [updateStep];
|
|
846
|
-
let finalInstallStep = updateStep;
|
|
847
|
-
if (updateStep.exitCode !== 0) {
|
|
848
|
-
const fallbackArgv = globalInstallFallbackArgs(installTarget, installSpec);
|
|
849
|
-
if (fallbackArgv) {
|
|
850
|
-
const fallbackStep = await runUpdateStep({
|
|
851
|
-
name: "global update (omit optional)",
|
|
852
|
-
argv: fallbackArgv,
|
|
853
|
-
env: installEnv,
|
|
854
|
-
timeoutMs: params.timeoutMs,
|
|
855
|
-
progress: params.progress
|
|
856
|
-
});
|
|
857
|
-
steps.push(fallbackStep);
|
|
858
|
-
finalInstallStep = fallbackStep;
|
|
859
|
-
}
|
|
860
|
-
}
|
|
861
|
-
let afterVersion = beforeVersion;
|
|
862
|
-
const verifiedPackageRoot = (await resolveGlobalInstallTarget({
|
|
863
|
-
manager: installTarget,
|
|
864
|
-
runCommand,
|
|
865
|
-
timeoutMs: params.timeoutMs,
|
|
866
|
-
pkgRoot
|
|
867
|
-
})).packageRoot ?? pkgRoot;
|
|
868
|
-
if (verifiedPackageRoot) {
|
|
869
|
-
afterVersion = await readPackageVersion(verifiedPackageRoot);
|
|
870
|
-
const verificationErrors = await collectInstalledGlobalPackageErrors({
|
|
871
|
-
packageRoot: verifiedPackageRoot,
|
|
872
|
-
expectedVersion: resolveExpectedInstalledVersionFromSpec(packageName, installSpec)
|
|
873
|
-
});
|
|
874
|
-
if (verificationErrors.length > 0) steps.push({
|
|
875
|
-
name: "global install verify",
|
|
876
|
-
command: `verify ${verifiedPackageRoot}`,
|
|
877
|
-
cwd: verifiedPackageRoot,
|
|
878
|
-
durationMs: 0,
|
|
879
|
-
exitCode: 1,
|
|
880
|
-
stderrTail: verificationErrors.join("\n"),
|
|
881
|
-
stdoutTail: null
|
|
882
|
-
});
|
|
883
|
-
const entryPath = await resolveGatewayInstallEntrypoint(verifiedPackageRoot);
|
|
884
|
-
if (entryPath) {
|
|
885
|
-
const doctorStep = await runUpdateStep({
|
|
886
|
-
name: `${CLI_NAME} doctor`,
|
|
887
|
-
argv: [
|
|
888
|
-
resolveNodeRunner(),
|
|
889
|
-
entryPath,
|
|
890
|
-
"doctor",
|
|
891
|
-
"--non-interactive"
|
|
892
|
-
],
|
|
893
|
-
env: {
|
|
894
|
-
...process.env,
|
|
895
|
-
GENESIS_UPDATE_IN_PROGRESS: "1"
|
|
896
|
-
},
|
|
897
|
-
timeoutMs: params.timeoutMs,
|
|
898
|
-
progress: params.progress
|
|
899
|
-
});
|
|
900
|
-
steps.push(doctorStep);
|
|
901
|
-
}
|
|
902
|
-
}
|
|
903
|
-
const failedStep = finalInstallStep.exitCode !== 0 ? finalInstallStep : steps.find((step) => step.name === "global install verify" && step.exitCode !== 0) ?? steps.find((step) => step.name === `${CLI_NAME} doctor` && step.exitCode !== 0);
|
|
904
|
-
return {
|
|
905
|
-
status: failedStep ? "error" : "ok",
|
|
906
|
-
mode: manager,
|
|
907
|
-
root: verifiedPackageRoot ?? params.root,
|
|
908
|
-
reason: failedStep ? failedStep.name : void 0,
|
|
909
|
-
before: { version: beforeVersion },
|
|
910
|
-
after: { version: afterVersion },
|
|
911
|
-
steps,
|
|
912
|
-
durationMs: Date.now() - params.startedAt
|
|
913
|
-
};
|
|
914
|
-
}
|
|
915
|
-
async function runGitUpdate(params) {
|
|
916
|
-
const updateRoot = params.switchToGit ? resolveGitInstallDir() : params.root;
|
|
917
|
-
const effectiveTimeout = params.timeoutMs ?? 20 * 6e4;
|
|
918
|
-
const installEnv = await createGlobalInstallEnv();
|
|
919
|
-
const cloneStep = params.switchToGit ? await ensureGitCheckout({
|
|
920
|
-
dir: updateRoot,
|
|
921
|
-
env: installEnv,
|
|
922
|
-
timeoutMs: effectiveTimeout,
|
|
923
|
-
progress: params.progress
|
|
924
|
-
}) : null;
|
|
925
|
-
if (cloneStep && cloneStep.exitCode !== 0) {
|
|
926
|
-
const result = {
|
|
927
|
-
status: "error",
|
|
928
|
-
mode: "git",
|
|
929
|
-
root: updateRoot,
|
|
930
|
-
reason: cloneStep.name,
|
|
931
|
-
steps: [cloneStep],
|
|
932
|
-
durationMs: Date.now() - params.startedAt
|
|
933
|
-
};
|
|
934
|
-
params.stop();
|
|
935
|
-
printResult(result, {
|
|
936
|
-
...params.opts,
|
|
937
|
-
hideSteps: params.showProgress
|
|
938
|
-
});
|
|
939
|
-
defaultRuntime.exit(1);
|
|
940
|
-
return result;
|
|
941
|
-
}
|
|
942
|
-
const updateResult = await runGatewayUpdate({
|
|
943
|
-
cwd: updateRoot,
|
|
944
|
-
argv1: params.switchToGit ? void 0 : process.argv[1],
|
|
945
|
-
timeoutMs: params.timeoutMs,
|
|
946
|
-
progress: params.progress,
|
|
947
|
-
channel: params.channel,
|
|
948
|
-
tag: params.tag,
|
|
949
|
-
devTargetRef: params.devTargetRef
|
|
950
|
-
});
|
|
951
|
-
const steps = [...cloneStep ? [cloneStep] : [], ...updateResult.steps];
|
|
952
|
-
if (params.switchToGit && updateResult.status === "ok") {
|
|
953
|
-
const installStep = await runUpdateStep({
|
|
954
|
-
name: "global install",
|
|
955
|
-
argv: globalInstallArgs(await resolveGlobalInstallTarget({
|
|
956
|
-
manager: await resolveGlobalManager({
|
|
957
|
-
root: params.root,
|
|
958
|
-
installKind: params.installKind,
|
|
959
|
-
timeoutMs: effectiveTimeout
|
|
960
|
-
}),
|
|
961
|
-
runCommand: createGlobalCommandRunner(),
|
|
962
|
-
timeoutMs: effectiveTimeout,
|
|
963
|
-
pkgRoot: params.root
|
|
964
|
-
}), updateRoot),
|
|
965
|
-
cwd: updateRoot,
|
|
966
|
-
env: installEnv,
|
|
967
|
-
timeoutMs: effectiveTimeout,
|
|
968
|
-
progress: params.progress
|
|
969
|
-
});
|
|
970
|
-
steps.push(installStep);
|
|
971
|
-
const failedStep = installStep.exitCode !== 0 ? installStep : null;
|
|
972
|
-
return {
|
|
973
|
-
...updateResult,
|
|
974
|
-
status: updateResult.status === "ok" && !failedStep ? "ok" : "error",
|
|
975
|
-
steps,
|
|
976
|
-
durationMs: Date.now() - params.startedAt
|
|
977
|
-
};
|
|
978
|
-
}
|
|
979
|
-
return {
|
|
980
|
-
...updateResult,
|
|
981
|
-
steps,
|
|
982
|
-
durationMs: Date.now() - params.startedAt
|
|
983
|
-
};
|
|
984
|
-
}
|
|
985
|
-
async function updatePluginsAfterCoreUpdate(params) {
|
|
986
|
-
if (!params.configSnapshot.valid) {
|
|
987
|
-
if (!params.opts.json) defaultRuntime.log(theme.warn("Skipping plugin updates: config is invalid."));
|
|
988
|
-
return {
|
|
989
|
-
status: "skipped",
|
|
990
|
-
reason: "invalid-config",
|
|
991
|
-
changed: false,
|
|
992
|
-
sync: {
|
|
993
|
-
changed: false,
|
|
994
|
-
switchedToBundled: [],
|
|
995
|
-
switchedToNpm: [],
|
|
996
|
-
warnings: [],
|
|
997
|
-
errors: []
|
|
998
|
-
},
|
|
999
|
-
npm: {
|
|
1000
|
-
changed: false,
|
|
1001
|
-
outcomes: []
|
|
1002
|
-
},
|
|
1003
|
-
integrityDrifts: []
|
|
1004
|
-
};
|
|
1005
|
-
}
|
|
1006
|
-
const pluginLogger = params.opts.json ? {} : {
|
|
1007
|
-
info: (msg) => defaultRuntime.log(msg),
|
|
1008
|
-
warn: (msg) => defaultRuntime.log(theme.warn(msg)),
|
|
1009
|
-
error: (msg) => defaultRuntime.log(theme.error(msg))
|
|
1010
|
-
};
|
|
1011
|
-
if (!params.opts.json) {
|
|
1012
|
-
defaultRuntime.log("");
|
|
1013
|
-
defaultRuntime.log(theme.heading("Updating plugins..."));
|
|
1014
|
-
}
|
|
1015
|
-
const syncResult = await syncPluginsForUpdateChannel({
|
|
1016
|
-
config: params.configSnapshot.sourceConfig,
|
|
1017
|
-
channel: params.channel,
|
|
1018
|
-
workspaceDir: params.root,
|
|
1019
|
-
logger: pluginLogger
|
|
1020
|
-
});
|
|
1021
|
-
let pluginConfig = syncResult.config;
|
|
1022
|
-
const integrityDrifts = [];
|
|
1023
|
-
const npmResult = await updateNpmInstalledPlugins({
|
|
1024
|
-
config: pluginConfig,
|
|
1025
|
-
skipIds: new Set(syncResult.summary.switchedToNpm),
|
|
1026
|
-
logger: pluginLogger,
|
|
1027
|
-
onIntegrityDrift: async (drift) => {
|
|
1028
|
-
integrityDrifts.push({
|
|
1029
|
-
pluginId: drift.pluginId,
|
|
1030
|
-
spec: drift.spec,
|
|
1031
|
-
expectedIntegrity: drift.expectedIntegrity,
|
|
1032
|
-
actualIntegrity: drift.actualIntegrity,
|
|
1033
|
-
...drift.resolvedSpec ? { resolvedSpec: drift.resolvedSpec } : {},
|
|
1034
|
-
...drift.resolvedVersion ? { resolvedVersion: drift.resolvedVersion } : {},
|
|
1035
|
-
action: "aborted"
|
|
1036
|
-
});
|
|
1037
|
-
if (!params.opts.json) {
|
|
1038
|
-
const specLabel = drift.resolvedSpec ?? drift.spec;
|
|
1039
|
-
defaultRuntime.log(theme.warn(`Integrity drift detected for "${drift.pluginId}" (${specLabel})\nExpected: ${drift.expectedIntegrity}\nActual: ${drift.actualIntegrity}
|
|
1040
|
-
Plugin update aborted. Reinstall the plugin only if you trust the new artifact.`));
|
|
1041
|
-
}
|
|
1042
|
-
return false;
|
|
1043
|
-
}
|
|
1044
|
-
});
|
|
1045
|
-
pluginConfig = npmResult.config;
|
|
1046
|
-
if (syncResult.changed || npmResult.changed) await replaceConfigFile({
|
|
1047
|
-
nextConfig: pluginConfig,
|
|
1048
|
-
baseHash: params.configSnapshot.hash
|
|
1049
|
-
});
|
|
1050
|
-
if (params.opts.json) return {
|
|
1051
|
-
status: syncResult.summary.errors.length > 0 || npmResult.outcomes.some((outcome) => outcome.status === "error") ? "error" : "ok",
|
|
1052
|
-
changed: syncResult.changed || npmResult.changed,
|
|
1053
|
-
sync: {
|
|
1054
|
-
changed: syncResult.changed,
|
|
1055
|
-
switchedToBundled: syncResult.summary.switchedToBundled,
|
|
1056
|
-
switchedToNpm: syncResult.summary.switchedToNpm,
|
|
1057
|
-
warnings: syncResult.summary.warnings,
|
|
1058
|
-
errors: syncResult.summary.errors
|
|
1059
|
-
},
|
|
1060
|
-
npm: {
|
|
1061
|
-
changed: npmResult.changed,
|
|
1062
|
-
outcomes: npmResult.outcomes
|
|
1063
|
-
},
|
|
1064
|
-
integrityDrifts
|
|
1065
|
-
};
|
|
1066
|
-
const summarizeList = (list) => {
|
|
1067
|
-
if (list.length <= 6) return list.join(", ");
|
|
1068
|
-
return `${list.slice(0, 6).join(", ")} +${list.length - 6} more`;
|
|
1069
|
-
};
|
|
1070
|
-
if (syncResult.summary.switchedToBundled.length > 0) defaultRuntime.log(theme.muted(`Switched to bundled plugins: ${summarizeList(syncResult.summary.switchedToBundled)}.`));
|
|
1071
|
-
if (syncResult.summary.switchedToNpm.length > 0) defaultRuntime.log(theme.muted(`Restored npm plugins: ${summarizeList(syncResult.summary.switchedToNpm)}.`));
|
|
1072
|
-
for (const warning of syncResult.summary.warnings) defaultRuntime.log(theme.warn(warning));
|
|
1073
|
-
for (const error of syncResult.summary.errors) defaultRuntime.log(theme.error(error));
|
|
1074
|
-
const updated = npmResult.outcomes.filter((entry) => entry.status === "updated").length;
|
|
1075
|
-
const unchanged = npmResult.outcomes.filter((entry) => entry.status === "unchanged").length;
|
|
1076
|
-
const failed = npmResult.outcomes.filter((entry) => entry.status === "error").length;
|
|
1077
|
-
const skipped = npmResult.outcomes.filter((entry) => entry.status === "skipped").length;
|
|
1078
|
-
if (npmResult.outcomes.length === 0) defaultRuntime.log(theme.muted("No plugin updates needed."));
|
|
1079
|
-
else {
|
|
1080
|
-
const parts = [`${updated} updated`, `${unchanged} unchanged`];
|
|
1081
|
-
if (failed > 0) parts.push(`${failed} failed`);
|
|
1082
|
-
if (skipped > 0) parts.push(`${skipped} skipped`);
|
|
1083
|
-
defaultRuntime.log(theme.muted(`npm plugins: ${parts.join(", ")}.`));
|
|
1084
|
-
}
|
|
1085
|
-
for (const outcome of npmResult.outcomes) {
|
|
1086
|
-
if (outcome.status !== "error") continue;
|
|
1087
|
-
defaultRuntime.log(theme.error(outcome.message));
|
|
1088
|
-
}
|
|
1089
|
-
return {
|
|
1090
|
-
status: syncResult.summary.errors.length > 0 || npmResult.outcomes.some((outcome) => outcome.status === "error") ? "error" : "ok",
|
|
1091
|
-
changed: syncResult.changed || npmResult.changed,
|
|
1092
|
-
sync: {
|
|
1093
|
-
changed: syncResult.changed,
|
|
1094
|
-
switchedToBundled: syncResult.summary.switchedToBundled,
|
|
1095
|
-
switchedToNpm: syncResult.summary.switchedToNpm,
|
|
1096
|
-
warnings: syncResult.summary.warnings,
|
|
1097
|
-
errors: syncResult.summary.errors
|
|
1098
|
-
},
|
|
1099
|
-
npm: {
|
|
1100
|
-
changed: npmResult.changed,
|
|
1101
|
-
outcomes: npmResult.outcomes
|
|
1102
|
-
},
|
|
1103
|
-
integrityDrifts
|
|
1104
|
-
};
|
|
1105
|
-
}
|
|
1106
|
-
async function maybeRestartService(params) {
|
|
1107
|
-
if (params.shouldRestart) {
|
|
1108
|
-
if (!params.opts.json) {
|
|
1109
|
-
defaultRuntime.log("");
|
|
1110
|
-
defaultRuntime.log(theme.heading("Restarting service..."));
|
|
1111
|
-
}
|
|
1112
|
-
try {
|
|
1113
|
-
let restarted = false;
|
|
1114
|
-
let restartInitiated = false;
|
|
1115
|
-
if (params.refreshServiceEnv) try {
|
|
1116
|
-
await refreshGatewayServiceEnv({
|
|
1117
|
-
result: params.result,
|
|
1118
|
-
jsonMode: Boolean(params.opts.json),
|
|
1119
|
-
invocationCwd: params.invocationCwd
|
|
1120
|
-
});
|
|
1121
|
-
} catch (err) {
|
|
1122
|
-
const message = `Failed to refresh gateway service environment from updated install: ${String(err)}`;
|
|
1123
|
-
if (params.opts.json) defaultRuntime.error(message);
|
|
1124
|
-
else defaultRuntime.log(theme.warn(message));
|
|
1125
|
-
}
|
|
1126
|
-
if (params.restartScriptPath) {
|
|
1127
|
-
await runRestartScript(params.restartScriptPath);
|
|
1128
|
-
restartInitiated = true;
|
|
1129
|
-
} else restarted = await runDaemonRestart();
|
|
1130
|
-
if (!params.opts.json && restarted) {
|
|
1131
|
-
defaultRuntime.log(theme.success("Daemon restarted successfully."));
|
|
1132
|
-
defaultRuntime.log("");
|
|
1133
|
-
process.env.GENESIS_UPDATE_IN_PROGRESS = "1";
|
|
1134
|
-
try {
|
|
1135
|
-
await doctorCommand(defaultRuntime, { nonInteractive: !(process.stdin.isTTY && !params.opts.json && params.opts.yes !== true) });
|
|
1136
|
-
} catch (err) {
|
|
1137
|
-
defaultRuntime.log(theme.warn(`Doctor failed: ${String(err)}`));
|
|
1138
|
-
} finally {
|
|
1139
|
-
delete process.env.GENESIS_UPDATE_IN_PROGRESS;
|
|
1140
|
-
}
|
|
1141
|
-
}
|
|
1142
|
-
if (!params.opts.json && restartInitiated) {
|
|
1143
|
-
const service = resolveGatewayService();
|
|
1144
|
-
let health = await waitForGatewayHealthyRestart({
|
|
1145
|
-
service,
|
|
1146
|
-
port: params.gatewayPort
|
|
1147
|
-
});
|
|
1148
|
-
if (!health.healthy && health.staleGatewayPids.length > 0) {
|
|
1149
|
-
if (!params.opts.json) defaultRuntime.log(theme.warn(`Found stale gateway process(es) after restart: ${health.staleGatewayPids.join(", ")}. Cleaning up...`));
|
|
1150
|
-
await terminateStaleGatewayPids(health.staleGatewayPids);
|
|
1151
|
-
await runDaemonRestart();
|
|
1152
|
-
health = await waitForGatewayHealthyRestart({
|
|
1153
|
-
service,
|
|
1154
|
-
port: params.gatewayPort
|
|
1155
|
-
});
|
|
1156
|
-
}
|
|
1157
|
-
if (health.healthy) defaultRuntime.log(theme.success("Daemon restart completed."));
|
|
1158
|
-
else {
|
|
1159
|
-
defaultRuntime.log(theme.warn("Gateway did not become healthy after restart."));
|
|
1160
|
-
for (const line of renderRestartDiagnostics(health)) defaultRuntime.log(theme.muted(line));
|
|
1161
|
-
defaultRuntime.log(theme.muted(`Restart log: ${resolveGatewayRestartLogPath(process.env)}`));
|
|
1162
|
-
defaultRuntime.log(theme.muted(`Run \`${replaceCliName(formatCliCommand("genesis gateway status --deep"), CLI_NAME)}\` for details.`));
|
|
1163
|
-
}
|
|
1164
|
-
defaultRuntime.log("");
|
|
1165
|
-
}
|
|
1166
|
-
} catch (err) {
|
|
1167
|
-
if (!params.opts.json) {
|
|
1168
|
-
defaultRuntime.log(theme.warn(`Daemon restart failed: ${String(err)}`));
|
|
1169
|
-
defaultRuntime.log(theme.muted(`You may need to restart the service manually: ${replaceCliName(formatCliCommand("genesis gateway restart"), CLI_NAME)}`));
|
|
1170
|
-
}
|
|
1171
|
-
}
|
|
1172
|
-
return;
|
|
1173
|
-
}
|
|
1174
|
-
if (!params.opts.json) {
|
|
1175
|
-
defaultRuntime.log("");
|
|
1176
|
-
if (params.result.mode === "npm" || params.result.mode === "pnpm") defaultRuntime.log(theme.muted(`Tip: Run \`${replaceCliName(formatCliCommand("genesis doctor"), CLI_NAME)}\`, then \`${replaceCliName(formatCliCommand("genesis gateway restart"), CLI_NAME)}\` to apply updates to a running gateway.`));
|
|
1177
|
-
else defaultRuntime.log(theme.muted(`Tip: Run \`${replaceCliName(formatCliCommand("genesis gateway restart"), CLI_NAME)}\` to apply updates to a running gateway.`));
|
|
1178
|
-
}
|
|
1179
|
-
}
|
|
1180
|
-
async function runPostCorePluginUpdate(params) {
|
|
1181
|
-
return await updatePluginsAfterCoreUpdate({
|
|
1182
|
-
root: params.root,
|
|
1183
|
-
channel: params.channel,
|
|
1184
|
-
configSnapshot: params.configSnapshot,
|
|
1185
|
-
opts: params.opts
|
|
1186
|
-
});
|
|
1187
|
-
}
|
|
1188
|
-
async function writePostCorePluginUpdateResultFile(filePath, result) {
|
|
1189
|
-
if (!filePath) return;
|
|
1190
|
-
await fs.writeFile(filePath, `${JSON.stringify(result)}\n`, "utf-8");
|
|
1191
|
-
}
|
|
1192
|
-
async function readPostCorePluginUpdateResultFile(filePath) {
|
|
1193
|
-
try {
|
|
1194
|
-
const raw = await fs.readFile(filePath, "utf-8");
|
|
1195
|
-
const parsed = JSON.parse(raw);
|
|
1196
|
-
if (parsed && typeof parsed === "object" && (parsed.status === "ok" || parsed.status === "skipped" || parsed.status === "error")) return parsed;
|
|
1197
|
-
} catch {
|
|
1198
|
-
return;
|
|
1199
|
-
}
|
|
1200
|
-
}
|
|
1201
|
-
async function continuePostCoreUpdateInFreshProcess(params) {
|
|
1202
|
-
const entryPath = path.join(params.root, "dist", "entry.js");
|
|
1203
|
-
if (!await pathExists(entryPath)) return { resumed: false };
|
|
1204
|
-
const argv = [entryPath, "update"];
|
|
1205
|
-
if (params.opts.json) argv.push("--json");
|
|
1206
|
-
if (params.opts.restart === false) argv.push("--no-restart");
|
|
1207
|
-
if (params.opts.yes) argv.push("--yes");
|
|
1208
|
-
const resultDir = params.opts.json === true ? await fs.mkdtemp(path.join(os.tmpdir(), "genesis-update-post-core-")) : null;
|
|
1209
|
-
const resultPath = resultDir ? path.join(resultDir, "plugins.json") : null;
|
|
1210
|
-
try {
|
|
1211
|
-
const child = spawn(resolveNodeRunner(), argv, {
|
|
1212
|
-
stdio: "inherit",
|
|
1213
|
-
env: {
|
|
1214
|
-
...process.env,
|
|
1215
|
-
[POST_CORE_UPDATE_ENV]: "1",
|
|
1216
|
-
[POST_CORE_UPDATE_CHANNEL_ENV]: params.channel,
|
|
1217
|
-
...resultPath ? { [POST_CORE_UPDATE_RESULT_PATH_ENV]: resultPath } : {}
|
|
1218
|
-
}
|
|
1219
|
-
});
|
|
1220
|
-
const exitCode = await new Promise((resolve, reject) => {
|
|
1221
|
-
child.once("error", reject);
|
|
1222
|
-
child.once("exit", (code, signal) => {
|
|
1223
|
-
if (signal) {
|
|
1224
|
-
reject(/* @__PURE__ */ new Error(`post-update process terminated by signal ${signal}`));
|
|
1225
|
-
return;
|
|
1226
|
-
}
|
|
1227
|
-
resolve(code ?? 1);
|
|
1228
|
-
});
|
|
1229
|
-
});
|
|
1230
|
-
if (exitCode !== 0) {
|
|
1231
|
-
defaultRuntime.exit(exitCode);
|
|
1232
|
-
throw new Error(`post-update process exited with code ${exitCode}`);
|
|
1233
|
-
}
|
|
1234
|
-
const pluginUpdate = resultPath ? await readPostCorePluginUpdateResultFile(resultPath) : void 0;
|
|
1235
|
-
return {
|
|
1236
|
-
resumed: true,
|
|
1237
|
-
...pluginUpdate ? { pluginUpdate } : {}
|
|
1238
|
-
};
|
|
1239
|
-
} finally {
|
|
1240
|
-
if (resultDir) await fs.rm(resultDir, {
|
|
1241
|
-
recursive: true,
|
|
1242
|
-
force: true
|
|
1243
|
-
}).catch(() => void 0);
|
|
1244
|
-
}
|
|
1245
|
-
}
|
|
1246
|
-
function shouldResumePostCoreUpdateInFreshProcess(params) {
|
|
1247
|
-
return isPackageManagerUpdateMode(params.result.mode) && !params.downgradeRisk;
|
|
1248
|
-
}
|
|
1249
|
-
async function updateCommand(opts) {
|
|
1250
|
-
suppressDeprecations();
|
|
1251
|
-
const invocationCwd = tryResolveInvocationCwd();
|
|
1252
|
-
const postCoreUpdateResume = process.env[POST_CORE_UPDATE_ENV] === "1";
|
|
1253
|
-
const postCoreUpdateChannel = process.env[POST_CORE_UPDATE_CHANNEL_ENV]?.trim();
|
|
1254
|
-
const timeoutMs = parseTimeoutMsOrExit(opts.timeout);
|
|
1255
|
-
const shouldRestart = opts.restart !== false;
|
|
1256
|
-
if (timeoutMs === null) return;
|
|
1257
|
-
const root = await resolveUpdateRoot();
|
|
1258
|
-
if (postCoreUpdateResume) {
|
|
1259
|
-
if (postCoreUpdateChannel !== "stable" && postCoreUpdateChannel !== "beta" && postCoreUpdateChannel !== "dev") {
|
|
1260
|
-
defaultRuntime.error("Missing post-core update channel context.");
|
|
1261
|
-
defaultRuntime.exit(1);
|
|
1262
|
-
return;
|
|
1263
|
-
}
|
|
1264
|
-
const pluginUpdate = await runPostCorePluginUpdate({
|
|
1265
|
-
root,
|
|
1266
|
-
channel: postCoreUpdateChannel,
|
|
1267
|
-
configSnapshot: await readConfigFileSnapshot(),
|
|
1268
|
-
opts
|
|
1269
|
-
});
|
|
1270
|
-
if (opts.json) {
|
|
1271
|
-
await writePostCorePluginUpdateResultFile(process.env[POST_CORE_UPDATE_RESULT_PATH_ENV], pluginUpdate);
|
|
1272
|
-
if (!process.env[POST_CORE_UPDATE_RESULT_PATH_ENV]) {
|
|
1273
|
-
const result = {
|
|
1274
|
-
status: pluginUpdate.status === "error" ? "error" : "ok",
|
|
1275
|
-
mode: "unknown",
|
|
1276
|
-
root,
|
|
1277
|
-
steps: [],
|
|
1278
|
-
durationMs: 0,
|
|
1279
|
-
postUpdate: { plugins: pluginUpdate }
|
|
1280
|
-
};
|
|
1281
|
-
defaultRuntime.writeJson(result);
|
|
1282
|
-
}
|
|
1283
|
-
}
|
|
1284
|
-
return;
|
|
1285
|
-
}
|
|
1286
|
-
const updateStatus = await checkUpdateStatus({
|
|
1287
|
-
root,
|
|
1288
|
-
timeoutMs: timeoutMs ?? 3500,
|
|
1289
|
-
fetchGit: false,
|
|
1290
|
-
includeRegistry: false
|
|
1291
|
-
});
|
|
1292
|
-
const configSnapshot = await readConfigFileSnapshot();
|
|
1293
|
-
const storedChannel = configSnapshot.valid ? normalizeUpdateChannel(configSnapshot.config.update?.channel) : null;
|
|
1294
|
-
const requestedChannel = normalizeUpdateChannel(opts.channel);
|
|
1295
|
-
if (opts.channel && !requestedChannel) {
|
|
1296
|
-
defaultRuntime.error(`--channel must be "stable", "beta", or "dev" (got "${opts.channel}")`);
|
|
1297
|
-
defaultRuntime.exit(1);
|
|
1298
|
-
return;
|
|
1299
|
-
}
|
|
1300
|
-
if (opts.channel && !configSnapshot.valid) {
|
|
1301
|
-
const issues = formatConfigIssueLines(configSnapshot.issues, "-");
|
|
1302
|
-
defaultRuntime.error(["Config is invalid; cannot set update channel.", ...issues].join("\n"));
|
|
1303
|
-
defaultRuntime.exit(1);
|
|
1304
|
-
return;
|
|
1305
|
-
}
|
|
1306
|
-
const installKind = updateStatus.installKind;
|
|
1307
|
-
const switchToGit = requestedChannel === "dev" && installKind !== "git";
|
|
1308
|
-
const switchToPackage = requestedChannel !== null && requestedChannel !== "dev" && installKind === "git";
|
|
1309
|
-
const updateInstallKind = switchToGit ? "git" : switchToPackage ? "package" : installKind;
|
|
1310
|
-
const inferredChannel = resolveEffectiveUpdateChannel({
|
|
1311
|
-
configChannel: storedChannel,
|
|
1312
|
-
installKind: updateInstallKind,
|
|
1313
|
-
git: updateStatus.git ? {
|
|
1314
|
-
tag: updateStatus.git.tag ?? null,
|
|
1315
|
-
branch: updateStatus.git.branch ?? null
|
|
1316
|
-
} : void 0
|
|
1317
|
-
});
|
|
1318
|
-
const channel = requestedChannel ?? inferredChannel.channel;
|
|
1319
|
-
const devTargetRef = channel === "dev" ? process.env.GENESIS_UPDATE_DEV_TARGET_REF?.trim() || void 0 : void 0;
|
|
1320
|
-
const explicitTag = normalizeTag(opts.tag);
|
|
1321
|
-
let tag = explicitTag ?? channelToNpmTag(channel);
|
|
1322
|
-
let currentVersion = null;
|
|
1323
|
-
let targetVersion = null;
|
|
1324
|
-
let downgradeRisk = false;
|
|
1325
|
-
let fallbackToLatest = false;
|
|
1326
|
-
let packageInstallSpec = null;
|
|
1327
|
-
let packageName = DEFAULT_PACKAGE_NAME;
|
|
1328
|
-
let packageAlreadyCurrent = false;
|
|
1329
|
-
if (updateInstallKind !== "git") {
|
|
1330
|
-
packageName = switchToPackage ? DEFAULT_PACKAGE_NAME : await readPackageName(root) ?? "@pixelzx/genesis";
|
|
1331
|
-
currentVersion = switchToPackage ? null : await readPackageVersion(root);
|
|
1332
|
-
if (explicitTag) targetVersion = await resolveTargetVersion(tag, timeoutMs, packageName);
|
|
1333
|
-
else targetVersion = await resolveNpmChannelTag({
|
|
1334
|
-
packageName,
|
|
1335
|
-
channel,
|
|
1336
|
-
timeoutMs
|
|
1337
|
-
}).then((resolved) => {
|
|
1338
|
-
tag = resolved.tag;
|
|
1339
|
-
fallbackToLatest = channel === "beta" && resolved.tag === "latest";
|
|
1340
|
-
return resolved.version;
|
|
1341
|
-
});
|
|
1342
|
-
const cmp = currentVersion && targetVersion ? compareSemverStrings(currentVersion, targetVersion) : null;
|
|
1343
|
-
packageAlreadyCurrent = updateInstallKind === "package" && !switchToPackage && currentVersion != null && targetVersion != null && currentVersion === targetVersion && (requestedChannel === null || requestedChannel === storedChannel);
|
|
1344
|
-
downgradeRisk = canResolveRegistryVersionForPackageTarget(tag) && !fallbackToLatest && currentVersion != null && (targetVersion == null || cmp != null && cmp > 0);
|
|
1345
|
-
packageInstallSpec = resolveGlobalInstallSpec({
|
|
1346
|
-
packageName,
|
|
1347
|
-
tag,
|
|
1348
|
-
env: process.env
|
|
1349
|
-
});
|
|
1350
|
-
}
|
|
1351
|
-
if (opts.dryRun) {
|
|
1352
|
-
let mode = "unknown";
|
|
1353
|
-
if (updateInstallKind === "git") mode = "git";
|
|
1354
|
-
else if (updateInstallKind === "package") mode = await resolveGlobalManager({
|
|
1355
|
-
root,
|
|
1356
|
-
installKind,
|
|
1357
|
-
timeoutMs: timeoutMs ?? 20 * 6e4
|
|
1358
|
-
});
|
|
1359
|
-
const actions = [];
|
|
1360
|
-
if (requestedChannel && requestedChannel !== storedChannel) actions.push(`Persist update.channel=${requestedChannel} in config`);
|
|
1361
|
-
if (switchToGit) actions.push("Switch install mode from package to git checkout (dev channel)");
|
|
1362
|
-
else if (switchToPackage) actions.push(`Switch install mode from git to package manager (${mode})`);
|
|
1363
|
-
else if (updateInstallKind === "git") actions.push(`Run git update flow on channel ${channel} (fetch/rebase/build/doctor)`);
|
|
1364
|
-
else if (packageAlreadyCurrent) actions.push(`Refresh package install with spec ${packageInstallSpec ?? tag}; current version already matches ${targetVersion}`);
|
|
1365
|
-
else actions.push(`Run global package manager update with spec ${packageInstallSpec ?? tag}`);
|
|
1366
|
-
actions.push("Run plugin update sync after core update");
|
|
1367
|
-
actions.push("Refresh shell completion cache (if needed)");
|
|
1368
|
-
actions.push(shouldRestart ? "Restart gateway service and run doctor checks" : "Skip restart (because --no-restart is set)");
|
|
1369
|
-
const notes = [];
|
|
1370
|
-
if (opts.tag && updateInstallKind === "git") notes.push("--tag applies to npm installs only; git updates ignore it.");
|
|
1371
|
-
if (fallbackToLatest) notes.push("Beta channel resolves to latest for this run (fallback).");
|
|
1372
|
-
if (explicitTag && !canResolveRegistryVersionForPackageTarget(tag)) notes.push("Non-registry package specs skip npm version lookup and downgrade previews.");
|
|
1373
|
-
printDryRunPreview({
|
|
1374
|
-
dryRun: true,
|
|
1375
|
-
root,
|
|
1376
|
-
installKind,
|
|
1377
|
-
mode,
|
|
1378
|
-
updateInstallKind,
|
|
1379
|
-
switchToGit,
|
|
1380
|
-
switchToPackage,
|
|
1381
|
-
restart: shouldRestart,
|
|
1382
|
-
requestedChannel,
|
|
1383
|
-
storedChannel,
|
|
1384
|
-
effectiveChannel: channel,
|
|
1385
|
-
tag: packageInstallSpec ?? tag,
|
|
1386
|
-
currentVersion,
|
|
1387
|
-
targetVersion,
|
|
1388
|
-
downgradeRisk,
|
|
1389
|
-
actions,
|
|
1390
|
-
notes
|
|
1391
|
-
}, Boolean(opts.json));
|
|
1392
|
-
return;
|
|
1393
|
-
}
|
|
1394
|
-
if (downgradeRisk && !opts.yes) {
|
|
1395
|
-
if (!process.stdin.isTTY || opts.json) {
|
|
1396
|
-
defaultRuntime.error(["Downgrade confirmation required.", "Downgrading can break configuration. Re-run in a TTY to confirm."].join("\n"));
|
|
1397
|
-
defaultRuntime.exit(1);
|
|
1398
|
-
return;
|
|
1399
|
-
}
|
|
1400
|
-
const targetLabel = targetVersion ?? `${tag} (unknown)`;
|
|
1401
|
-
const ok = await confirm({
|
|
1402
|
-
message: stylePromptMessage(`Downgrading from ${currentVersion} to ${targetLabel} can break configuration. Continue?`),
|
|
1403
|
-
initialValue: false
|
|
1404
|
-
});
|
|
1405
|
-
if (isCancel(ok) || !ok) {
|
|
1406
|
-
if (!opts.json) defaultRuntime.log(theme.muted("Update cancelled."));
|
|
1407
|
-
defaultRuntime.exit(0);
|
|
1408
|
-
return;
|
|
1409
|
-
}
|
|
1410
|
-
}
|
|
1411
|
-
if (updateInstallKind === "git" && opts.tag && !opts.json) defaultRuntime.log(theme.muted("Note: --tag applies to npm installs only; git updates ignore it."));
|
|
1412
|
-
if (updateInstallKind === "package") {
|
|
1413
|
-
const runtimePreflightError = await resolvePackageRuntimePreflightError({
|
|
1414
|
-
packageName,
|
|
1415
|
-
tag,
|
|
1416
|
-
timeoutMs
|
|
1417
|
-
});
|
|
1418
|
-
if (runtimePreflightError) {
|
|
1419
|
-
defaultRuntime.error(runtimePreflightError);
|
|
1420
|
-
defaultRuntime.exit(1);
|
|
1421
|
-
return;
|
|
1422
|
-
}
|
|
1423
|
-
}
|
|
1424
|
-
const showProgress = !opts.json && process.stdout.isTTY;
|
|
1425
|
-
if (!opts.json) {
|
|
1426
|
-
defaultRuntime.log(theme.heading("Updating Genesis..."));
|
|
1427
|
-
defaultRuntime.log("");
|
|
1428
|
-
}
|
|
1429
|
-
const { progress, stop } = createUpdateProgress(showProgress);
|
|
1430
|
-
const startedAt = Date.now();
|
|
1431
|
-
const result = updateInstallKind === "package" ? await runPackageInstallUpdate({
|
|
1432
|
-
root,
|
|
1433
|
-
installKind,
|
|
1434
|
-
tag,
|
|
1435
|
-
timeoutMs: timeoutMs ?? 20 * 6e4,
|
|
1436
|
-
startedAt,
|
|
1437
|
-
progress
|
|
1438
|
-
}) : await runGitUpdate({
|
|
1439
|
-
root,
|
|
1440
|
-
switchToGit,
|
|
1441
|
-
installKind,
|
|
1442
|
-
timeoutMs,
|
|
1443
|
-
startedAt,
|
|
1444
|
-
progress,
|
|
1445
|
-
channel,
|
|
1446
|
-
tag,
|
|
1447
|
-
showProgress,
|
|
1448
|
-
opts,
|
|
1449
|
-
stop,
|
|
1450
|
-
devTargetRef
|
|
1451
|
-
});
|
|
1452
|
-
stop();
|
|
1453
|
-
if (!opts.json || result.status !== "ok") printResult(result, {
|
|
1454
|
-
...opts,
|
|
1455
|
-
hideSteps: showProgress
|
|
1456
|
-
});
|
|
1457
|
-
if (result.status === "error") {
|
|
1458
|
-
defaultRuntime.exit(1);
|
|
1459
|
-
return;
|
|
1460
|
-
}
|
|
1461
|
-
if (result.status === "skipped") {
|
|
1462
|
-
if (result.reason === "dirty") {
|
|
1463
|
-
defaultRuntime.error(theme.error("Update blocked: local files are edited in this checkout."));
|
|
1464
|
-
defaultRuntime.log(theme.warn("Git-based updates need a clean working tree before they can switch commits, fetch, or rebase."));
|
|
1465
|
-
defaultRuntime.log(theme.muted("Commit, stash, or discard the local changes, then rerun `genesis update`."));
|
|
1466
|
-
}
|
|
1467
|
-
if (result.reason === "not-git-install") {
|
|
1468
|
-
defaultRuntime.log(theme.warn(`Skipped: this Genesis install isn't a git checkout, and the package manager couldn't be detected. Update via your package manager, then run \`${replaceCliName(formatCliCommand("genesis doctor"), CLI_NAME)}\` and \`${replaceCliName(formatCliCommand("genesis gateway restart"), CLI_NAME)}\`.`));
|
|
1469
|
-
defaultRuntime.log(theme.muted(`Examples: \`${replaceCliName(`npm i -g ${DEFAULT_PACKAGE_NAME}@latest`, CLI_NAME)}\` or \`${replaceCliName(`pnpm add -g ${DEFAULT_PACKAGE_NAME}@latest`, CLI_NAME)}\``));
|
|
1470
|
-
}
|
|
1471
|
-
defaultRuntime.exit(0);
|
|
1472
|
-
return;
|
|
1473
|
-
}
|
|
1474
|
-
if (switchToGit && result.status === "ok" && result.mode === "git") {
|
|
1475
|
-
if (!opts.json) defaultRuntime.log(theme.muted("Switched from a package install to a git checkout. Skipping remaining post-update work in the old CLI process; rerun follow-up commands from the new git install if needed."));
|
|
1476
|
-
else defaultRuntime.writeJson(result);
|
|
1477
|
-
defaultRuntime.exit(0);
|
|
1478
|
-
return;
|
|
1479
|
-
}
|
|
1480
|
-
let postUpdateConfigSnapshot = configSnapshot;
|
|
1481
|
-
if (requestedChannel && configSnapshot.valid && requestedChannel !== storedChannel) if (switchToGit) {
|
|
1482
|
-
if (!opts.json) defaultRuntime.log(theme.muted(`Skipped persisting update.channel=${requestedChannel} in the pre-update CLI process after switching to a git install.`));
|
|
1483
|
-
} else {
|
|
1484
|
-
const next = {
|
|
1485
|
-
...configSnapshot.sourceConfig,
|
|
1486
|
-
update: {
|
|
1487
|
-
...configSnapshot.sourceConfig.update,
|
|
1488
|
-
channel: requestedChannel
|
|
1489
|
-
}
|
|
1490
|
-
};
|
|
1491
|
-
await replaceConfigFile({
|
|
1492
|
-
nextConfig: next,
|
|
1493
|
-
baseHash: configSnapshot.hash
|
|
1494
|
-
});
|
|
1495
|
-
postUpdateConfigSnapshot = {
|
|
1496
|
-
...configSnapshot,
|
|
1497
|
-
hash: void 0,
|
|
1498
|
-
parsed: next,
|
|
1499
|
-
sourceConfig: asResolvedSourceConfig(next),
|
|
1500
|
-
resolved: asResolvedSourceConfig(next),
|
|
1501
|
-
runtimeConfig: asRuntimeConfig(next),
|
|
1502
|
-
config: asRuntimeConfig(next)
|
|
1503
|
-
};
|
|
1504
|
-
if (!opts.json) defaultRuntime.log(theme.muted(`Update channel set to ${requestedChannel}.`));
|
|
1505
|
-
}
|
|
1506
|
-
const postUpdateRoot = result.root ?? root;
|
|
1507
|
-
let postCorePluginUpdate;
|
|
1508
|
-
let pluginsUpdatedInFreshProcess = false;
|
|
1509
|
-
if (shouldResumePostCoreUpdateInFreshProcess({
|
|
1510
|
-
result,
|
|
1511
|
-
downgradeRisk
|
|
1512
|
-
})) {
|
|
1513
|
-
const freshProcessResult = await continuePostCoreUpdateInFreshProcess({
|
|
1514
|
-
root: postUpdateRoot,
|
|
1515
|
-
channel,
|
|
1516
|
-
opts
|
|
1517
|
-
});
|
|
1518
|
-
pluginsUpdatedInFreshProcess = freshProcessResult.resumed;
|
|
1519
|
-
postCorePluginUpdate = freshProcessResult.pluginUpdate;
|
|
1520
|
-
}
|
|
1521
|
-
const deferOldProcessPostUpdateWork = switchToGit && result.mode === "git";
|
|
1522
|
-
if (deferOldProcessPostUpdateWork) {
|
|
1523
|
-
if (!opts.json) defaultRuntime.log(theme.muted("Skipped plugin update sync in the pre-update CLI process after switching to a git install."));
|
|
1524
|
-
} else if (!pluginsUpdatedInFreshProcess) postCorePluginUpdate = await runPostCorePluginUpdate({
|
|
1525
|
-
root: postUpdateRoot,
|
|
1526
|
-
channel,
|
|
1527
|
-
configSnapshot: postUpdateConfigSnapshot,
|
|
1528
|
-
opts
|
|
1529
|
-
});
|
|
1530
|
-
let restartScriptPath = null;
|
|
1531
|
-
let refreshGatewayServiceEnv = false;
|
|
1532
|
-
const gatewayPort = resolveGatewayPort(postUpdateConfigSnapshot.valid ? postUpdateConfigSnapshot.config : void 0, process.env);
|
|
1533
|
-
if (shouldRestart) try {
|
|
1534
|
-
if (await resolveGatewayService().isLoaded({ env: process.env })) {
|
|
1535
|
-
restartScriptPath = await prepareRestartScript(process.env, gatewayPort);
|
|
1536
|
-
refreshGatewayServiceEnv = true;
|
|
1537
|
-
}
|
|
1538
|
-
} catch {}
|
|
1539
|
-
if (deferOldProcessPostUpdateWork) {
|
|
1540
|
-
if (!opts.json) defaultRuntime.log(theme.muted("Skipped completion/restart follow-ups in the pre-update CLI process after switching to a git install."));
|
|
1541
|
-
} else {
|
|
1542
|
-
await tryWriteCompletionCache(postUpdateRoot, Boolean(opts.json));
|
|
1543
|
-
await tryInstallShellCompletion({
|
|
1544
|
-
jsonMode: Boolean(opts.json),
|
|
1545
|
-
skipPrompt: Boolean(opts.yes)
|
|
1546
|
-
});
|
|
1547
|
-
await maybeRestartService({
|
|
1548
|
-
shouldRestart,
|
|
1549
|
-
result,
|
|
1550
|
-
opts,
|
|
1551
|
-
refreshServiceEnv: refreshGatewayServiceEnv,
|
|
1552
|
-
gatewayPort,
|
|
1553
|
-
restartScriptPath,
|
|
1554
|
-
invocationCwd
|
|
1555
|
-
});
|
|
1556
|
-
}
|
|
1557
|
-
if (!opts.json) defaultRuntime.log(theme.muted(pickUpdateQuip()));
|
|
1558
|
-
else defaultRuntime.writeJson({
|
|
1559
|
-
...result,
|
|
1560
|
-
...postCorePluginUpdate ? { postUpdate: { plugins: postCorePluginUpdate } } : {}
|
|
1561
|
-
});
|
|
1562
|
-
}
|
|
1563
|
-
//#endregion
|
|
1564
|
-
//#region src/cli/update-cli/wizard.ts
|
|
1565
|
-
async function updateWizardCommand(opts = {}) {
|
|
1566
|
-
if (!process.stdin.isTTY) {
|
|
1567
|
-
defaultRuntime.error("Update wizard requires a TTY. Use `genesis update --channel <stable|beta|dev>` instead.");
|
|
1568
|
-
defaultRuntime.exit(1);
|
|
1569
|
-
return;
|
|
1570
|
-
}
|
|
1571
|
-
const timeoutMs = parseTimeoutMsOrExit(opts.timeout);
|
|
1572
|
-
if (timeoutMs === null) return;
|
|
1573
|
-
const root = await resolveUpdateRoot();
|
|
1574
|
-
const [updateStatus, configSnapshot] = await Promise.all([checkUpdateStatus({
|
|
1575
|
-
root,
|
|
1576
|
-
timeoutMs: timeoutMs ?? 3500,
|
|
1577
|
-
fetchGit: false,
|
|
1578
|
-
includeRegistry: false
|
|
1579
|
-
}), readConfigFileSnapshot()]);
|
|
1580
|
-
const channelInfo = resolveEffectiveUpdateChannel({
|
|
1581
|
-
configChannel: configSnapshot.valid ? normalizeUpdateChannel(configSnapshot.config.update?.channel) : null,
|
|
1582
|
-
installKind: updateStatus.installKind,
|
|
1583
|
-
git: updateStatus.git ? {
|
|
1584
|
-
tag: updateStatus.git.tag,
|
|
1585
|
-
branch: updateStatus.git.branch
|
|
1586
|
-
} : void 0
|
|
1587
|
-
});
|
|
1588
|
-
const channelLabel = formatUpdateChannelLabel({
|
|
1589
|
-
channel: channelInfo.channel,
|
|
1590
|
-
source: channelInfo.source,
|
|
1591
|
-
gitTag: updateStatus.git?.tag ?? null,
|
|
1592
|
-
gitBranch: updateStatus.git?.branch ?? null
|
|
1593
|
-
});
|
|
1594
|
-
const pickedChannel = await selectStyled({
|
|
1595
|
-
message: "Update channel",
|
|
1596
|
-
options: [
|
|
1597
|
-
{
|
|
1598
|
-
value: "keep",
|
|
1599
|
-
label: `Keep current (${channelInfo.channel})`,
|
|
1600
|
-
hint: channelLabel
|
|
1601
|
-
},
|
|
1602
|
-
{
|
|
1603
|
-
value: "stable",
|
|
1604
|
-
label: "Stable",
|
|
1605
|
-
hint: "Tagged releases (npm latest)"
|
|
1606
|
-
},
|
|
1607
|
-
{
|
|
1608
|
-
value: "beta",
|
|
1609
|
-
label: "Beta",
|
|
1610
|
-
hint: "Prereleases (npm beta)"
|
|
1611
|
-
},
|
|
1612
|
-
{
|
|
1613
|
-
value: "dev",
|
|
1614
|
-
label: "Dev",
|
|
1615
|
-
hint: "Git main"
|
|
1616
|
-
}
|
|
1617
|
-
],
|
|
1618
|
-
initialValue: "keep"
|
|
1619
|
-
});
|
|
1620
|
-
if (isCancel(pickedChannel)) {
|
|
1621
|
-
defaultRuntime.log(theme.muted("Update cancelled."));
|
|
1622
|
-
defaultRuntime.exit(0);
|
|
1623
|
-
return;
|
|
1624
|
-
}
|
|
1625
|
-
const requestedChannel = pickedChannel === "keep" ? null : pickedChannel;
|
|
1626
|
-
if (requestedChannel === "dev" && updateStatus.installKind !== "git") {
|
|
1627
|
-
const gitDir = resolveGitInstallDir();
|
|
1628
|
-
if (!await isGitCheckout(gitDir)) {
|
|
1629
|
-
if (await pathExists(gitDir)) {
|
|
1630
|
-
if (!await isEmptyDir(gitDir)) {
|
|
1631
|
-
defaultRuntime.error(`GENESIS_GIT_DIR points at a non-git directory: ${gitDir}. Set GENESIS_GIT_DIR to an empty folder or an genesis checkout.`);
|
|
1632
|
-
defaultRuntime.exit(1);
|
|
1633
|
-
return;
|
|
1634
|
-
}
|
|
1635
|
-
}
|
|
1636
|
-
const ok = await confirm({
|
|
1637
|
-
message: stylePromptMessage(`Create a git checkout at ${gitDir}? (override via GENESIS_GIT_DIR)`),
|
|
1638
|
-
initialValue: true
|
|
1639
|
-
});
|
|
1640
|
-
if (isCancel(ok) || !ok) {
|
|
1641
|
-
defaultRuntime.log(theme.muted("Update cancelled."));
|
|
1642
|
-
defaultRuntime.exit(0);
|
|
1643
|
-
return;
|
|
1644
|
-
}
|
|
1645
|
-
}
|
|
1646
|
-
}
|
|
1647
|
-
const restart = await confirm({
|
|
1648
|
-
message: stylePromptMessage("Restart the gateway service after update?"),
|
|
1649
|
-
initialValue: true
|
|
1650
|
-
});
|
|
1651
|
-
if (isCancel(restart)) {
|
|
1652
|
-
defaultRuntime.log(theme.muted("Update cancelled."));
|
|
1653
|
-
defaultRuntime.exit(0);
|
|
1654
|
-
return;
|
|
1655
|
-
}
|
|
1656
|
-
try {
|
|
1657
|
-
await updateCommand({
|
|
1658
|
-
channel: requestedChannel ?? void 0,
|
|
1659
|
-
restart,
|
|
1660
|
-
timeout: opts.timeout
|
|
1661
|
-
});
|
|
1662
|
-
} catch (err) {
|
|
1663
|
-
defaultRuntime.error(String(err));
|
|
1664
|
-
defaultRuntime.exit(1);
|
|
1665
|
-
}
|
|
1666
|
-
}
|
|
1667
|
-
//#endregion
|
|
1668
|
-
//#region src/cli/update-cli.ts
|
|
1669
|
-
function inheritedUpdateJson(command) {
|
|
1670
|
-
return Boolean(inheritOptionFromParent(command, "json"));
|
|
1671
|
-
}
|
|
1672
|
-
function inheritedUpdateTimeout(opts, command) {
|
|
1673
|
-
const timeout = opts.timeout;
|
|
1674
|
-
if (timeout) return timeout;
|
|
1675
|
-
return inheritOptionFromParent(command, "timeout");
|
|
1676
|
-
}
|
|
1677
|
-
function registerUpdateCli(program) {
|
|
1678
|
-
program.enablePositionalOptions();
|
|
1679
|
-
const update = program.command("update").description("Update Genesis and inspect update channel status").option("--json", "Output result as JSON", false).option("--no-restart", "Skip restarting the gateway service after a successful update").option("--dry-run", "Preview update actions without making changes", false).option("--channel <stable|beta|dev>", "Persist update channel (git + npm)").option("--tag <dist-tag|version|spec>", "Override the package target for this update (dist-tag, version, or package spec)").option("--timeout <seconds>", "Timeout for each update step in seconds (default: 1200)").option("--yes", "Skip confirmation prompts (non-interactive)", false).addHelpText("after", () => {
|
|
1680
|
-
const fmtExamples = [
|
|
1681
|
-
["genesis update", "Update a source checkout (git)"],
|
|
1682
|
-
["genesis update --channel beta", "Switch to beta channel (git + npm)"],
|
|
1683
|
-
["genesis update --channel dev", "Switch to dev channel (git + npm)"],
|
|
1684
|
-
["genesis update --tag beta", "One-off update to a dist-tag or version"],
|
|
1685
|
-
["genesis update --tag main", "One-off package install from GitHub main"],
|
|
1686
|
-
["genesis update --dry-run", "Preview actions without changing anything"],
|
|
1687
|
-
["genesis update --no-restart", "Update without restarting the service"],
|
|
1688
|
-
["genesis update --json", "Output result as JSON"],
|
|
1689
|
-
["genesis update --yes", "Non-interactive (accept downgrade prompts)"],
|
|
1690
|
-
["genesis update wizard", "Interactive update wizard"],
|
|
1691
|
-
["genesis --update", "Shorthand for genesis update"]
|
|
1692
|
-
].map(([cmd, desc]) => ` ${theme.command(cmd)} ${theme.muted(`# ${desc}`)}`).join("\n");
|
|
1693
|
-
return `
|
|
1694
|
-
${theme.heading("What this does:")}
|
|
1695
|
-
- Git checkouts: fetches, rebases, installs deps, builds, and runs doctor
|
|
1696
|
-
- npm installs: updates via detected package manager
|
|
1697
|
-
|
|
1698
|
-
${theme.heading("Switch channels:")}
|
|
1699
|
-
- Use --channel stable|beta|dev to persist the update channel in config
|
|
1700
|
-
- Run genesis update status to see the active channel and source
|
|
1701
|
-
- Use --tag <dist-tag|version|spec> for a one-off package update without persisting
|
|
1702
|
-
|
|
1703
|
-
${theme.heading("Non-interactive:")}
|
|
1704
|
-
- Use --yes to accept downgrade prompts
|
|
1705
|
-
- Combine with --channel/--tag/--restart/--json/--timeout as needed
|
|
1706
|
-
- Use --dry-run to preview actions without writing config/installing/restarting
|
|
1707
|
-
|
|
1708
|
-
${theme.heading("Examples:")}
|
|
1709
|
-
${fmtExamples}
|
|
1710
|
-
|
|
1711
|
-
${theme.heading("Notes:")}
|
|
1712
|
-
- Switch channels with --channel stable|beta|dev
|
|
1713
|
-
- For global installs: auto-updates via detected package manager when possible (see docs/install/updating.md)
|
|
1714
|
-
- Downgrades require confirmation (can break configuration)
|
|
1715
|
-
- Skips update if the working directory has uncommitted changes
|
|
1716
|
-
|
|
1717
|
-
${theme.muted("Docs:")} ${formatDocsLink("/cli/update", "genesis.pixelzx.com/docs/cli/update")}`;
|
|
1718
|
-
}).action(async (opts) => {
|
|
1719
|
-
try {
|
|
1720
|
-
await updateCommand({
|
|
1721
|
-
json: Boolean(opts.json),
|
|
1722
|
-
restart: Boolean(opts.restart),
|
|
1723
|
-
dryRun: Boolean(opts.dryRun),
|
|
1724
|
-
channel: opts.channel,
|
|
1725
|
-
tag: opts.tag,
|
|
1726
|
-
timeout: opts.timeout,
|
|
1727
|
-
yes: Boolean(opts.yes)
|
|
1728
|
-
});
|
|
1729
|
-
} catch (err) {
|
|
1730
|
-
defaultRuntime.error(String(err));
|
|
1731
|
-
defaultRuntime.exit(1);
|
|
1732
|
-
}
|
|
1733
|
-
});
|
|
1734
|
-
update.command("wizard").description("Interactive update wizard").option("--timeout <seconds>", "Timeout for each update step in seconds (default: 1200)").addHelpText("after", `\n${theme.muted("Docs:")} ${formatDocsLink("/cli/update", "genesis.pixelzx.com/docs/cli/update")}\n`).action(async (opts, command) => {
|
|
1735
|
-
try {
|
|
1736
|
-
await updateWizardCommand({ timeout: inheritedUpdateTimeout(opts, command) });
|
|
1737
|
-
} catch (err) {
|
|
1738
|
-
defaultRuntime.error(String(err));
|
|
1739
|
-
defaultRuntime.exit(1);
|
|
1740
|
-
}
|
|
1741
|
-
});
|
|
1742
|
-
update.command("status").description("Show update channel and version status").option("--json", "Output result as JSON", false).option("--timeout <seconds>", "Timeout for update checks in seconds (default: 3)").addHelpText("after", () => `\n${theme.heading("Examples:")}\n${formatHelpExamples([
|
|
1743
|
-
["genesis update status", "Show channel + version status."],
|
|
1744
|
-
["genesis update status --json", "JSON output."],
|
|
1745
|
-
["genesis update status --timeout 10", "Custom timeout."]
|
|
1746
|
-
])}\n\n${theme.heading("Notes:")}\n${theme.muted("- Shows current update channel (stable/beta/dev) and source")}\n${theme.muted("- Includes git tag/branch/SHA for source checkouts")}\n\n${theme.muted("Docs:")} ${formatDocsLink("/cli/update", "genesis.pixelzx.com/docs/cli/update")}`).action(async (opts, command) => {
|
|
1747
|
-
try {
|
|
1748
|
-
await updateStatusCommand({
|
|
1749
|
-
json: Boolean(opts.json) || inheritedUpdateJson(command),
|
|
1750
|
-
timeout: inheritedUpdateTimeout(opts, command)
|
|
1751
|
-
});
|
|
1752
|
-
} catch (err) {
|
|
1753
|
-
defaultRuntime.error(String(err));
|
|
1754
|
-
defaultRuntime.exit(1);
|
|
1755
|
-
}
|
|
1756
|
-
});
|
|
1757
|
-
}
|
|
1758
|
-
//#endregion
|
|
1759
|
-
export { registerUpdateCli, updateCommand, updateStatusCommand, updateWizardCommand };
|