openclaw 2026.4.27-beta.1 → 2026.4.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/dist/build-info.json +3 -3
  2. package/dist/cli/run-main.js +5 -5
  3. package/dist/cli-startup-metadata.json +2 -2
  4. package/dist/{command-registry-CMWio-tP.js → command-registry-BXwjip4t.js} +2 -2
  5. package/dist/{command-registry-BjoQo_JH.js → command-registry-CXfgUc3g.js} +2 -2
  6. package/dist/{command-registry-core-DKo5GqFR.js → command-registry-core-CSyNl-BO.js} +3 -3
  7. package/dist/{completion-cli-BmOHMHeQ.js → completion-cli-DYMtC8G6.js} +2 -2
  8. package/dist/{config-cli-zS-Lu2lA.js → config-cli-CFLlqP4o.js} +1 -1
  9. package/dist/crestodian/crestodian.js +1 -1
  10. package/dist/crestodian/rescue-message.js +1 -1
  11. package/dist/{crestodian-DskOuHY3.js → crestodian-DG6faf2a.js} +3 -3
  12. package/dist/{dialogue-C9Rd8vz5.js → dialogue-BzHx5-LG.js} +1 -1
  13. package/dist/{gateway-cli-pj6tWKTk.js → gateway-cli-eSJgcA31.js} +1 -1
  14. package/dist/{operations-BpSveX17.js → operations-Dv7j-NpF.js} +2 -2
  15. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  16. package/dist/postinstall-inventory.json +24 -24
  17. package/dist/{program-BpI9kTzJ.js → program-CEtzLOw3.js} +1 -1
  18. package/dist/{register.crestodian-y8Ymvezu.js → register.crestodian-o_jW-snG.js} +1 -1
  19. package/dist/register.subclis-CXOkRHl6.js +3 -0
  20. package/dist/{register.subclis-BZI2W2li.js → register.subclis-DLLl37PA.js} +2 -2
  21. package/dist/{register.subclis-core-OKdixKpO.js → register.subclis-core-y3H-e26t.js} +2 -2
  22. package/dist/{route-BynaE0pb.js → route-xP22X2bZ.js} +1 -1
  23. package/dist/{run-B7mVeLtf.js → run-BDvpbL6X.js} +1 -1
  24. package/dist/{run-CHwkqs_l.js → run-CRwamKav.js} +1 -1
  25. package/dist/{runtime-schema-CNIdSEd4.js → runtime-schema-CjQQFitv.js} +1 -1
  26. package/dist/{server-Cntni6l8.js → server-OZWXuHXI.js} +1 -1
  27. package/dist/{server-methods-D2vht_QR.js → server-methods-CBx73Ug-.js} +1 -1
  28. package/dist/{server-plugin-bootstrap-CEfHwkno.js → server-plugin-bootstrap-ZA5D65nV.js} +1 -1
  29. package/dist/{server-plugin-bootstrap-DWvZ-HCI.js → server-plugin-bootstrap-vl1ejzkD.js} +1 -1
  30. package/dist/{server.impl-DR_SqBmD.js → server.impl-BoLlD_Zm.js} +3 -3
  31. package/dist/{tui-backend-5SVT148v.js → tui-backend-BFU3M2gp.js} +2 -2
  32. package/package.json +1 -1
  33. package/dist/register.subclis-CtaRYKyA.js +0 -3
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "2026.4.27-beta.1",
3
- "commit": "15901513a3e29e54bd0be58158db2af4051646ca",
4
- "builtAt": "2026-04-29T21:28:03.015Z"
2
+ "version": "2026.4.27",
3
+ "commit": "cbc2ba0931468259f26a7c547131a06e03ca6c6c",
4
+ "builtAt": "2026-04-29T22:23:39.827Z"
5
5
  }
@@ -149,7 +149,7 @@ async function tryRunGatewayRunFastPath(argv, startupTrace) {
149
149
  if (!isGatewayRunFastPathArgv(argv)) return false;
150
150
  const [{ Command }, { addGatewayRunCommand }, { VERSION }, { emitCliBanner }, { resolveCliStartupPolicy }] = await startupTrace.measure("gateway-run-imports", () => Promise.all([
151
151
  import("commander"),
152
- import("../run-CHwkqs_l.js"),
152
+ import("../run-CRwamKav.js"),
153
153
  import("../version-CFYXGG_n.js"),
154
154
  import("../banner-DPNP7UqW.js"),
155
155
  import("../command-startup-policy-DmUClLUn.js")
@@ -337,7 +337,7 @@ async function runCli(argv = process$1.argv) {
337
337
  if (!bootstrapProxyBeforeFastPath && await tryRunGatewayRunFastPath(normalizedArgv, startupTrace)) return;
338
338
  await bootstrapCliProxyCaptureAndDispatcher(startupTrace);
339
339
  if (bootstrapProxyBeforeFastPath && await tryRunGatewayRunFastPath(normalizedArgv, startupTrace)) return;
340
- const { tryRouteCli } = await startupTrace.measure("route-import", () => import("../route-BynaE0pb.js"));
340
+ const { tryRouteCli } = await startupTrace.measure("route-import", () => import("../route-xP22X2bZ.js"));
341
341
  if (await startupTrace.measure("route", () => tryRouteCli(normalizedArgv))) return;
342
342
  const { createCliProgress } = await import("../progress-DpplB4QN.js");
343
343
  const startupProgress = createCliProgress({
@@ -356,7 +356,7 @@ async function runCli(argv = process$1.argv) {
356
356
  const { enableConsoleCapture } = await import("../logging-Db9UZRE_.js");
357
357
  enableConsoleCapture();
358
358
  const [{ buildProgram }, { formatUncaughtError }, { runFatalErrorHooks }, { installUnhandledRejectionHandler, isBenignUncaughtExceptionError, isUncaughtExceptionHandled }, { restoreTerminalState }] = await startupTrace.measure("core-imports", () => Promise.all([
359
- import("../program-BpI9kTzJ.js"),
359
+ import("../program-CEtzLOw3.js"),
360
360
  import("../infra/errors.js"),
361
361
  import("../fatal-error-hooks-DxqbkWSf.js"),
362
362
  import("../unhandled-rejections-CRZGfjcO.js"),
@@ -384,10 +384,10 @@ async function runCli(argv = process$1.argv) {
384
384
  const { getProgramContext } = await import("../program-context-DAqUYR9Q.js");
385
385
  const ctx = getProgramContext(program);
386
386
  if (ctx) {
387
- const { registerCoreCliByName } = await import("../command-registry-BjoQo_JH.js");
387
+ const { registerCoreCliByName } = await import("../command-registry-CXfgUc3g.js");
388
388
  await registerCoreCliByName(program, ctx, primary, parseArgv);
389
389
  }
390
- const { registerSubCliByName } = await import("../register.subclis-CtaRYKyA.js");
390
+ const { registerSubCliByName } = await import("../register.subclis-CXOkRHl6.js");
391
391
  await registerSubCliByName(program, primary, parseArgv);
392
392
  });
393
393
  if (!shouldSkipPluginCommandRegistration({
@@ -28,6 +28,6 @@
28
28
  "channelCatalogSignature": "e315e8d61dcdfb410a961ea637238cd70f2df740",
29
29
  "rootHelpBundleSignature": "44c467816221667e745a45a51a6f169839d56ad7",
30
30
  "browserHelpSourceSignature": "a0875c8cd47ffcfe5ba9abe123d31a831c8f5ab5",
31
- "browserHelpText": "\n🦞 OpenClaw 2026.4.27-beta.1 (1590151) — iMessage green bubble energy, but for everyone.\n\nUsage: openclaw browser [options] [command]\n\nManage OpenClaw's dedicated browser (Chrome/Chromium)\n\nOptions:\n --browser-profile <name> Browser profile name (default from config)\n --expect-final Wait for final response (agent) (default: false)\n -h, --help Display help for command\n --json Output machine-readable JSON (default: false)\n --timeout <ms> Timeout in ms (default: \"30000\")\n --token <token> Gateway token (if required)\n --url <url> Gateway WebSocket URL (defaults to\n gateway.remote.url when configured)\n\nCommands:\n click Click an element by ref from snapshot\n click-coords Click viewport coordinates\n close Close a tab (target id optional)\n console Get recent console messages\n cookies Read/write cookies\n create-profile Create a new browser profile\n delete-profile Delete a browser profile\n dialog Arm the next modal dialog (alert/confirm/prompt)\n doctor Check browser plugin readiness\n download Click a ref and save the resulting download\n drag Drag from one ref to another\n errors Get recent page errors\n evaluate Evaluate a function against the page or a ref\n fill Fill a form with JSON field descriptors\n focus Focus a tab by target id, tab id, label, or unique\n target id prefix\n highlight Highlight an element by ref\n hover Hover an element by ai ref\n navigate Navigate the current tab to a URL\n open Open a URL in a new tab\n pdf Save page as PDF\n press Press a key\n profiles List all browser profiles\n requests Get recent network requests (best-effort)\n reset-profile Reset browser profile (moves it to Trash)\n resize Resize the viewport\n responsebody Wait for a network response and return its body\n screenshot Capture a screenshot (MEDIA:<path>)\n scrollintoview Scroll an element into view by ref from snapshot\n select Select option(s) in a select element\n set Browser environment settings\n snapshot Capture a snapshot (default: ai; aria is the\n accessibility tree)\n start Start the browser (no-op if already running)\n status Show browser status\n stop Stop the browser (best-effort)\n storage Read/write localStorage/sessionStorage\n tab Tab shortcuts (index-based)\n tabs List open tabs\n trace Record a Playwright trace\n type Type into an element by ref from snapshot\n upload Arm file upload for the next file chooser\n wait Wait for time, selector, URL, load state, or JS\n conditions\n waitfordownload Wait for the next download (and save it)\n\nExamples:\n openclaw browser status\n openclaw browser start\n openclaw browser start --headless\n openclaw browser stop\n openclaw browser tabs\n openclaw browser open https://example.com\n openclaw browser focus abcd1234\n openclaw browser close abcd1234\n openclaw browser screenshot\n openclaw browser screenshot --full-page\n openclaw browser screenshot --ref 12\n openclaw browser snapshot\n openclaw browser snapshot --format aria --limit 200\n openclaw browser snapshot --efficient\n openclaw browser snapshot --labels\n openclaw browser navigate https://example.com\n openclaw browser resize 1280 720\n openclaw browser click 12 --double\n openclaw browser click-coords 120 340\n openclaw browser type 23 \"hello\" --submit\n openclaw browser press Enter\n openclaw browser hover 44\n openclaw browser drag 10 11\n openclaw browser select 9 OptionA OptionB\n openclaw browser upload /tmp/openclaw/uploads/file.pdf\n openclaw browser fill --fields '[{\"ref\":\"1\",\"value\":\"Ada\"}]'\n openclaw browser dialog --accept\n openclaw browser wait --text \"Done\"\n openclaw browser evaluate --fn '(el) => el.textContent' --ref 7\n openclaw browser console --level error\n openclaw browser pdf\n\nDocs: https://docs.openclaw.ai/cli/browser\n\n",
32
- "rootHelpText": "\n🦞 OpenClaw 2026.4.27-beta.1 (1590151) — iMessage green bubble energy, but for everyone.\n\nUsage: openclaw [options] [command]\n\nOptions:\n --container <name> Run the CLI inside a running Podman/Docker container\n named <name> (default: env OPENCLAW_CONTAINER)\n --dev Dev profile: isolate state under ~/.openclaw-dev, default\n gateway port 19001, and shift derived ports\n (browser/canvas)\n -h, --help Display help for command\n --log-level <level> Global log level override for file + console\n (silent|fatal|error|warn|info|debug|trace)\n --no-color Disable ANSI colors\n --profile <name> Use a named profile (isolates\n OPENCLAW_STATE_DIR/OPENCLAW_CONFIG_PATH under\n ~/.openclaw-<name>)\n -V, --version output the version number\n\nCommands:\n Hint: commands suffixed with * have subcommands. Run <command> --help for details.\n acp * Agent Control Protocol tools\n agent Run one agent turn via the Gateway\n agents * Manage isolated agents (workspaces, auth, routing)\n approvals * Manage exec approvals (gateway or node host)\n backup * Create and verify local backup archives for OpenClaw\n state\n capability * Run provider-backed inference commands (fallback alias:\n infer)\n channels * Manage connected chat channels (Telegram, Discord, etc.)\n chat Open a local terminal UI (alias for tui --local)\n clawbot * Legacy clawbot command aliases\n completion Generate shell completion script\n config * Non-interactive config helpers\n (get/set/unset/file/validate). Default: starts guided\n setup.\n configure Interactive configuration for credentials, channels,\n gateway, and agent defaults\n crestodian Open the ring-zero setup and repair helper\n cron * Manage cron jobs via the Gateway scheduler\n daemon * Gateway service (legacy alias)\n dashboard Open the Control UI with your current token\n devices * Device pairing + token management\n directory * Lookup contact and group IDs (self, peers, groups) for\n supported chat channels\n dns * DNS helpers for wide-area discovery (Tailscale + CoreDNS)\n docs Search the live OpenClaw docs\n doctor Health checks + quick fixes for the gateway and channels\n exec-policy * Show or synchronize requested exec policy with host\n approvals\n gateway * Run, inspect, and query the WebSocket Gateway\n health Fetch health from the running gateway\n help Display help for command\n hooks * Manage internal agent hooks\n infer * Run provider-backed inference commands\n logs Tail gateway file logs via RPC\n mcp * Manage OpenClaw MCP config and channel bridge\n memory Search, inspect, and reindex memory files\n message * Send, read, and manage messages\n migrate * Import state from another agent system\n models * Discover, scan, and configure models\n node * Run and manage the headless node host service\n nodes * Manage gateway-owned node pairing and node commands\n onboard Interactive onboarding for gateway, workspace, and skills\n pairing * Secure DM pairing (approve inbound requests)\n plugins * Manage OpenClaw plugins\n proxy * Run the OpenClaw debug proxy and inspect captured traffic\n qr Generate mobile pairing QR/setup code\n reset Reset local config/state (keeps the CLI installed)\n sandbox * Manage sandbox containers for agent isolation\n secrets * Secrets runtime reload controls\n security * Security tools and local config audits\n sessions * List stored conversation sessions\n setup Initialize local config and agent workspace\n skills * List and inspect available skills\n status Show channel health and recent session recipients\n system * System events, heartbeat, and presence\n tasks * Inspect durable background task state\n terminal Open a local terminal UI (alias for tui --local)\n tui Open a terminal UI connected to the Gateway\n uninstall Uninstall the gateway service + local data (CLI remains)\n update * Update OpenClaw and inspect update channel status\n webhooks * Webhook helpers and integrations\n\nExamples:\n openclaw models --help\n Show detailed help for the models command.\n openclaw channels login --verbose\n Link personal WhatsApp Web and show QR + connection logs.\n openclaw message send --target +15555550123 --message \"Hi\" --json\n Send via your web session and print JSON result.\n openclaw gateway --port 18789\n Run the WebSocket Gateway locally.\n openclaw --dev gateway\n Run a dev Gateway (isolated state/config) on ws://127.0.0.1:19001.\n openclaw gateway --force\n Kill anything bound to the default gateway port, then start it.\n openclaw gateway ...\n Gateway control via WebSocket.\n openclaw agent --to +15555550123 --message \"Run summary\" --deliver\n Talk directly to the agent using the Gateway; optionally send the WhatsApp reply.\n openclaw message send --channel telegram --target @mychat --message \"Hi\"\n Send via your Telegram bot.\n\nDocs: https://docs.openclaw.ai/cli\n\n"
31
+ "browserHelpText": "\n🦞 OpenClaw 2026.4.27 (cbc2ba0) — I keep secrets like a vault... unless you print them in debug logs again.\n\nUsage: openclaw browser [options] [command]\n\nManage OpenClaw's dedicated browser (Chrome/Chromium)\n\nOptions:\n --browser-profile <name> Browser profile name (default from config)\n --expect-final Wait for final response (agent) (default: false)\n -h, --help Display help for command\n --json Output machine-readable JSON (default: false)\n --timeout <ms> Timeout in ms (default: \"30000\")\n --token <token> Gateway token (if required)\n --url <url> Gateway WebSocket URL (defaults to\n gateway.remote.url when configured)\n\nCommands:\n click Click an element by ref from snapshot\n click-coords Click viewport coordinates\n close Close a tab (target id optional)\n console Get recent console messages\n cookies Read/write cookies\n create-profile Create a new browser profile\n delete-profile Delete a browser profile\n dialog Arm the next modal dialog (alert/confirm/prompt)\n doctor Check browser plugin readiness\n download Click a ref and save the resulting download\n drag Drag from one ref to another\n errors Get recent page errors\n evaluate Evaluate a function against the page or a ref\n fill Fill a form with JSON field descriptors\n focus Focus a tab by target id, tab id, label, or unique\n target id prefix\n highlight Highlight an element by ref\n hover Hover an element by ai ref\n navigate Navigate the current tab to a URL\n open Open a URL in a new tab\n pdf Save page as PDF\n press Press a key\n profiles List all browser profiles\n requests Get recent network requests (best-effort)\n reset-profile Reset browser profile (moves it to Trash)\n resize Resize the viewport\n responsebody Wait for a network response and return its body\n screenshot Capture a screenshot (MEDIA:<path>)\n scrollintoview Scroll an element into view by ref from snapshot\n select Select option(s) in a select element\n set Browser environment settings\n snapshot Capture a snapshot (default: ai; aria is the\n accessibility tree)\n start Start the browser (no-op if already running)\n status Show browser status\n stop Stop the browser (best-effort)\n storage Read/write localStorage/sessionStorage\n tab Tab shortcuts (index-based)\n tabs List open tabs\n trace Record a Playwright trace\n type Type into an element by ref from snapshot\n upload Arm file upload for the next file chooser\n wait Wait for time, selector, URL, load state, or JS\n conditions\n waitfordownload Wait for the next download (and save it)\n\nExamples:\n openclaw browser status\n openclaw browser start\n openclaw browser start --headless\n openclaw browser stop\n openclaw browser tabs\n openclaw browser open https://example.com\n openclaw browser focus abcd1234\n openclaw browser close abcd1234\n openclaw browser screenshot\n openclaw browser screenshot --full-page\n openclaw browser screenshot --ref 12\n openclaw browser snapshot\n openclaw browser snapshot --format aria --limit 200\n openclaw browser snapshot --efficient\n openclaw browser snapshot --labels\n openclaw browser navigate https://example.com\n openclaw browser resize 1280 720\n openclaw browser click 12 --double\n openclaw browser click-coords 120 340\n openclaw browser type 23 \"hello\" --submit\n openclaw browser press Enter\n openclaw browser hover 44\n openclaw browser drag 10 11\n openclaw browser select 9 OptionA OptionB\n openclaw browser upload /tmp/openclaw/uploads/file.pdf\n openclaw browser fill --fields '[{\"ref\":\"1\",\"value\":\"Ada\"}]'\n openclaw browser dialog --accept\n openclaw browser wait --text \"Done\"\n openclaw browser evaluate --fn '(el) => el.textContent' --ref 7\n openclaw browser console --level error\n openclaw browser pdf\n\nDocs: https://docs.openclaw.ai/cli/browser\n\n",
32
+ "rootHelpText": "\n🦞 OpenClaw 2026.4.27 (cbc2ba0) — iMessage green bubble energy, but for everyone.\n\nUsage: openclaw [options] [command]\n\nOptions:\n --container <name> Run the CLI inside a running Podman/Docker container\n named <name> (default: env OPENCLAW_CONTAINER)\n --dev Dev profile: isolate state under ~/.openclaw-dev, default\n gateway port 19001, and shift derived ports\n (browser/canvas)\n -h, --help Display help for command\n --log-level <level> Global log level override for file + console\n (silent|fatal|error|warn|info|debug|trace)\n --no-color Disable ANSI colors\n --profile <name> Use a named profile (isolates\n OPENCLAW_STATE_DIR/OPENCLAW_CONFIG_PATH under\n ~/.openclaw-<name>)\n -V, --version output the version number\n\nCommands:\n Hint: commands suffixed with * have subcommands. Run <command> --help for details.\n acp * Agent Control Protocol tools\n agent Run one agent turn via the Gateway\n agents * Manage isolated agents (workspaces, auth, routing)\n approvals * Manage exec approvals (gateway or node host)\n backup * Create and verify local backup archives for OpenClaw\n state\n capability * Run provider-backed inference commands (fallback alias:\n infer)\n channels * Manage connected chat channels (Telegram, Discord, etc.)\n chat Open a local terminal UI (alias for tui --local)\n clawbot * Legacy clawbot command aliases\n completion Generate shell completion script\n config * Non-interactive config helpers\n (get/set/unset/file/validate). Default: starts guided\n setup.\n configure Interactive configuration for credentials, channels,\n gateway, and agent defaults\n crestodian Open the ring-zero setup and repair helper\n cron * Manage cron jobs via the Gateway scheduler\n daemon * Gateway service (legacy alias)\n dashboard Open the Control UI with your current token\n devices * Device pairing + token management\n directory * Lookup contact and group IDs (self, peers, groups) for\n supported chat channels\n dns * DNS helpers for wide-area discovery (Tailscale + CoreDNS)\n docs Search the live OpenClaw docs\n doctor Health checks + quick fixes for the gateway and channels\n exec-policy * Show or synchronize requested exec policy with host\n approvals\n gateway * Run, inspect, and query the WebSocket Gateway\n health Fetch health from the running gateway\n help Display help for command\n hooks * Manage internal agent hooks\n infer * Run provider-backed inference commands\n logs Tail gateway file logs via RPC\n mcp * Manage OpenClaw MCP config and channel bridge\n memory Search, inspect, and reindex memory files\n message * Send, read, and manage messages\n migrate * Import state from another agent system\n models * Discover, scan, and configure models\n node * Run and manage the headless node host service\n nodes * Manage gateway-owned node pairing and node commands\n onboard Interactive onboarding for gateway, workspace, and skills\n pairing * Secure DM pairing (approve inbound requests)\n plugins * Manage OpenClaw plugins\n proxy * Run the OpenClaw debug proxy and inspect captured traffic\n qr Generate mobile pairing QR/setup code\n reset Reset local config/state (keeps the CLI installed)\n sandbox * Manage sandbox containers for agent isolation\n secrets * Secrets runtime reload controls\n security * Security tools and local config audits\n sessions * List stored conversation sessions\n setup Initialize local config and agent workspace\n skills * List and inspect available skills\n status Show channel health and recent session recipients\n system * System events, heartbeat, and presence\n tasks * Inspect durable background task state\n terminal Open a local terminal UI (alias for tui --local)\n tui Open a terminal UI connected to the Gateway\n uninstall Uninstall the gateway service + local data (CLI remains)\n update * Update OpenClaw and inspect update channel status\n webhooks * Webhook helpers and integrations\n\nExamples:\n openclaw models --help\n Show detailed help for the models command.\n openclaw channels login --verbose\n Link personal WhatsApp Web and show QR + connection logs.\n openclaw message send --target +15555550123 --message \"Hi\" --json\n Send via your web session and print JSON result.\n openclaw gateway --port 18789\n Run the WebSocket Gateway locally.\n openclaw --dev gateway\n Run a dev Gateway (isolated state/config) on ws://127.0.0.1:19001.\n openclaw gateway --force\n Kill anything bound to the default gateway port, then start it.\n openclaw gateway ...\n Gateway control via WebSocket.\n openclaw agent --to +15555550123 --message \"Run summary\" --deliver\n Talk directly to the agent using the Gateway; optionally send the WhatsApp reply.\n openclaw message send --channel telegram --target @mychat --message \"Hi\"\n Send via your Telegram bot.\n\nDocs: https://docs.openclaw.ai/cli\n\n"
33
33
  }
@@ -1,5 +1,5 @@
1
- import { r as registerCoreCliCommands } from "./command-registry-core-DKo5GqFR.js";
2
- import { n as registerSubCliCommands } from "./register.subclis-BZI2W2li.js";
1
+ import { r as registerCoreCliCommands } from "./command-registry-core-CSyNl-BO.js";
2
+ import { n as registerSubCliCommands } from "./register.subclis-DLLl37PA.js";
3
3
  //#region src/cli/program/command-registry.ts
4
4
  function registerProgramCommands(program, ctx, argv = process.argv) {
5
5
  registerCoreCliCommands(program, ctx, argv);
@@ -1,4 +1,4 @@
1
1
  import "./argv-Bh2LLxMT.js";
2
- import { n as registerCoreCliByName } from "./command-registry-core-DKo5GqFR.js";
3
- import "./command-registry-CMWio-tP.js";
2
+ import { n as registerCoreCliByName } from "./command-registry-core-CSyNl-BO.js";
3
+ import "./command-registry-BXwjip4t.js";
4
4
  export { registerCoreCliByName };
@@ -2,7 +2,7 @@ import { _ as getCoreCliCommandDescriptors, v as getCoreCliCommandNames$1 } from
2
2
  import { t as resolveCliArgvInvocation } from "./argv-invocation-C0QUafZn.js";
3
3
  import { n as shouldRegisterPrimaryCommandOnly } from "./command-registration-policy-C0qLofS8.js";
4
4
  import { i as registerCommandGroups, r as registerCommandGroupByName } from "./register-command-groups-C8J96v2h.js";
5
- import { a as defineImportedCommandGroupSpec, i as buildCommandGroupEntries, o as defineImportedProgramCommandGroupSpecs } from "./register.subclis-core-OKdixKpO.js";
5
+ import { a as defineImportedCommandGroupSpec, i as buildCommandGroupEntries, o as defineImportedProgramCommandGroupSpecs } from "./register.subclis-core-y3H-e26t.js";
6
6
  //#region src/cli/program/command-registry-core.ts
7
7
  function withProgramOnlySpecs(specs) {
8
8
  return specs.map((spec) => ({
@@ -16,7 +16,7 @@ const coreEntrySpecs = [
16
16
  ...withProgramOnlySpecs(defineImportedProgramCommandGroupSpecs([
17
17
  {
18
18
  commandNames: ["crestodian"],
19
- loadModule: () => import("./register.crestodian-y8Ymvezu.js"),
19
+ loadModule: () => import("./register.crestodian-o_jW-snG.js"),
20
20
  exportName: "registerCrestodianCommand"
21
21
  },
22
22
  {
@@ -36,7 +36,7 @@ const coreEntrySpecs = [
36
36
  },
37
37
  {
38
38
  commandNames: ["config"],
39
- loadModule: () => import("./config-cli-zS-Lu2lA.js"),
39
+ loadModule: () => import("./config-cli-CFLlqP4o.js"),
40
40
  exportName: "registerConfigCli"
41
41
  },
42
42
  {
@@ -2,8 +2,8 @@ import { t as formatDocsLink } from "./links-BszRQhGa.js";
2
2
  import { r as theme } from "./theme-B128avno.js";
3
3
  import { a as routeLogsToStderr } from "./console-DnTGmMkY.js";
4
4
  import { c as resolveShellFromEnv, i as installCompletion, o as isCompletionShell, s as resolveCompletionCachePath, t as COMPLETION_SHELLS } from "./completion-runtime-CAaolkxV.js";
5
- import { n as registerSubCliByName, t as getSubCliEntries } from "./register.subclis-core-OKdixKpO.js";
6
- import { n as registerCoreCliByName, t as getCoreCliCommandNames } from "./command-registry-core-DKo5GqFR.js";
5
+ import { n as registerSubCliByName, t as getSubCliEntries } from "./register.subclis-core-y3H-e26t.js";
6
+ import { n as registerCoreCliByName, t as getCoreCliCommandNames } from "./command-registry-core-CSyNl-BO.js";
7
7
  import { t as getProgramContext } from "./program-context-BPz01Sb4.js";
8
8
  import path from "node:path";
9
9
  import fs from "node:fs/promises";
@@ -17,7 +17,7 @@ import { r as replaceConfigFile } from "./mutate-Bnr0cx3h.js";
17
17
  import "./config-CopVFMnG.js";
18
18
  import { a as normalizeConfigIssues, n as formatConfigIssueLines } from "./issue-format-DPCYJ_FB.js";
19
19
  import { n as redactConfigObject } from "./redact-snapshot-BccX3f-_.js";
20
- import { n as readBestEffortRuntimeConfigSchema } from "./runtime-schema-CNIdSEd4.js";
20
+ import { n as readBestEffortRuntimeConfigSchema } from "./runtime-schema-CjQQFitv.js";
21
21
  import { n as setCommandJsonMode } from "./json-mode-CEP1Xm_u.js";
22
22
  import fs from "node:fs";
23
23
  import JSON5 from "json5";
@@ -1,2 +1,2 @@
1
- import { t as runCrestodian } from "../crestodian-DskOuHY3.js";
1
+ import { t as runCrestodian } from "../crestodian-DG6faf2a.js";
2
2
  export { runCrestodian };
@@ -1,6 +1,6 @@
1
1
  import { _ as resolveStateDir } from "../paths-B2cMK-wd.js";
2
2
  import { c as normalizeAgentId } from "../session-key-C6F-NnIG.js";
3
- import { a as parseCrestodianOperation, i as isPersistentCrestodianOperation, n as executeCrestodianOperation, r as formatCrestodianPersistentPlan } from "../operations-BpSveX17.js";
3
+ import { a as parseCrestodianOperation, i as isPersistentCrestodianOperation, n as executeCrestodianOperation, r as formatCrestodianPersistentPlan } from "../operations-Dv7j-NpF.js";
4
4
  import path from "node:path";
5
5
  import fs from "node:fs/promises";
6
6
  import { createHash, randomUUID } from "node:crypto";
@@ -1,8 +1,8 @@
1
1
  import { n as defaultRuntime, r as writeRuntimeJson } from "./runtime-CIJX7ulQ.js";
2
2
  import { n as withProgress } from "./progress-DEutg9EU.js";
3
- import { i as isPersistentCrestodianOperation, n as executeCrestodianOperation } from "./operations-BpSveX17.js";
3
+ import { i as isPersistentCrestodianOperation, n as executeCrestodianOperation } from "./operations-Dv7j-NpF.js";
4
4
  import { r as loadCrestodianOverview, t as formatCrestodianOverview } from "./overview-BsMEIOL7.js";
5
- import { r as resolveCrestodianOperation } from "./dialogue-C9Rd8vz5.js";
5
+ import { r as resolveCrestodianOperation } from "./dialogue-BzHx5-LG.js";
6
6
  import { stdin, stdout } from "node:process";
7
7
  //#region src/crestodian/crestodian.ts
8
8
  function crestodianCommandDepsFromOptions(opts) {
@@ -46,7 +46,7 @@ async function runCrestodian(opts = {}, runtime = defaultRuntime) {
46
46
  runtime.error("Crestodian needs an interactive TTY. Use --message for one command.");
47
47
  return;
48
48
  }
49
- const runInteractiveTui = opts.runInteractiveTui ?? (await import("./tui-backend-5SVT148v.js")).runCrestodianTui;
49
+ const runInteractiveTui = opts.runInteractiveTui ?? (await import("./tui-backend-BFU3M2gp.js")).runCrestodianTui;
50
50
  opts.onReady?.();
51
51
  await runInteractiveTui(opts, runtime);
52
52
  }
@@ -1,4 +1,4 @@
1
- import { a as parseCrestodianOperation, t as describeCrestodianPersistentOperation } from "./operations-BpSveX17.js";
1
+ import { a as parseCrestodianOperation, t as describeCrestodianPersistentOperation } from "./operations-Dv7j-NpF.js";
2
2
  import { r as loadCrestodianOverview } from "./overview-BsMEIOL7.js";
3
3
  //#region src/crestodian/dialogue.ts
4
4
  function approvalQuestion(operation) {
@@ -11,7 +11,7 @@ import { n as withProgress } from "./progress-DEutg9EU.js";
11
11
  import { n as runCommandWithRuntime } from "./cli-utils-BE3eZBkQ.js";
12
12
  import { t as formatHelpExamples } from "./help-format-CmO6sKiH.js";
13
13
  import { n as buildGatewayDiscoveryTarget } from "./gateway-discovery-targets-CE3SJS1o.js";
14
- import { n as addGatewayRunCommand } from "./run-B7mVeLtf.js";
14
+ import { n as addGatewayRunCommand } from "./run-BDvpbL6X.js";
15
15
  //#region src/cli/gateway-cli/call.ts
16
16
  const gatewayCallOpts = (cmd) => cmd.option("--url <url>", "Gateway WebSocket URL (defaults to gateway.remote.url when configured)").option("--token <token>", "Gateway token (if required)").option("--password <password>", "Gateway password (password auth)").option("--timeout <ms>", "Timeout in ms", "10000").option("--expect-final", "Wait for final response (agent)", false).option("--json", "Output JSON", false);
17
17
  const callGatewayCli = async (method, opts, params) => withProgress({
@@ -387,7 +387,7 @@ async function executeCrestodianOperation(operation, runtime, opts = {}) {
387
387
  const { readConfigFileSnapshot } = await import("./config/config.js");
388
388
  const before = await readConfigFileSnapshot();
389
389
  await (opts.deps?.runConfigSet ?? (async (setOpts) => {
390
- const { runConfigSet: importedRunConfigSet } = await import("./config-cli-zS-Lu2lA.js");
390
+ const { runConfigSet: importedRunConfigSet } = await import("./config-cli-CFLlqP4o.js");
391
391
  await importedRunConfigSet({
392
392
  ...setOpts,
393
393
  runtime: createNoExitRuntime(runtime)
@@ -425,7 +425,7 @@ async function executeCrestodianOperation(operation, runtime, opts = {}) {
425
425
  const { readConfigFileSnapshot } = await import("./config/config.js");
426
426
  const before = await readConfigFileSnapshot();
427
427
  await (opts.deps?.runConfigSet ?? (async (setOpts) => {
428
- const { runConfigSet: importedRunConfigSet } = await import("./config-cli-zS-Lu2lA.js");
428
+ const { runConfigSet: importedRunConfigSet } = await import("./config-cli-CFLlqP4o.js");
429
429
  await importedRunConfigSet({
430
430
  ...setOpts,
431
431
  runtime: createNoExitRuntime(runtime)
@@ -1 +1 @@
1
- 2026-04-29T21:28:02.572Z
1
+ 2026-04-29T22:23:39.383Z
@@ -508,9 +508,9 @@
508
508
  "dist/command-queue-CKVxpmTJ.js",
509
509
  "dist/command-registration-L3hFwlvE.js",
510
510
  "dist/command-registration-policy-C0qLofS8.js",
511
- "dist/command-registry-BjoQo_JH.js",
512
- "dist/command-registry-CMWio-tP.js",
513
- "dist/command-registry-core-DKo5GqFR.js",
511
+ "dist/command-registry-BXwjip4t.js",
512
+ "dist/command-registry-core-CSyNl-BO.js",
513
+ "dist/command-registry-CXfgUc3g.js",
514
514
  "dist/command-secret-gateway-Ia71bRAm.js",
515
515
  "dist/command-secret-targets-Cld2ckCB.js",
516
516
  "dist/command-secret-targets-CQsa2CXb.js",
@@ -561,7 +561,7 @@
561
561
  "dist/compaction-Dgl_FCSL.js",
562
562
  "dist/compaction-runtime-context-BA4kwTPh.js",
563
563
  "dist/compaction-successor-transcript-BwDunTlM.js",
564
- "dist/completion-cli-BmOHMHeQ.js",
564
+ "dist/completion-cli-DYMtC8G6.js",
565
565
  "dist/completion-runtime-CAaolkxV.js",
566
566
  "dist/config-api-68140Qo1.js",
567
567
  "dist/config-api-D7VNaJ5k.js",
@@ -572,7 +572,7 @@
572
572
  "dist/config-BRhMsjHq.js",
573
573
  "dist/config-CfVyXSXt.js",
574
574
  "dist/config-Cjtlhl2S.js",
575
- "dist/config-cli-zS-Lu2lA.js",
575
+ "dist/config-cli-CFLlqP4o.js",
576
576
  "dist/config-compat-C_gh1oGT.js",
577
577
  "dist/config-compat-D2gSMAan.js",
578
578
  "dist/config-compat-DwtqhDey.js",
@@ -696,7 +696,7 @@
696
696
  "dist/credential-planner-Cm-IPlWf.js",
697
697
  "dist/credentials-B-149jP7.js",
698
698
  "dist/credentials-secret-inputs-DulDir6k.js",
699
- "dist/crestodian-DskOuHY3.js",
699
+ "dist/crestodian-DG6faf2a.js",
700
700
  "dist/crestodian/crestodian.js",
701
701
  "dist/crestodian/rescue-message.js",
702
702
  "dist/cron-cli-CPbXyakq.js",
@@ -782,7 +782,7 @@
782
782
  "dist/diagnostics-CpRHwhnq.js",
783
783
  "dist/diagnostics-D8CvnbdN.js",
784
784
  "dist/diagnostics-qdhCYEH2.js",
785
- "dist/dialogue-C9Rd8vz5.js",
785
+ "dist/dialogue-BzHx5-LG.js",
786
786
  "dist/direct-dm-9_FMy_7P.js",
787
787
  "dist/direct-dm-access-BP-VyFqY.js",
788
788
  "dist/direct-dm-guard-policy-CF26aycp.js",
@@ -2665,7 +2665,7 @@
2665
2665
  "dist/gateway-bindings-3HZnDntG.js",
2666
2666
  "dist/gateway-BtDnd2On.js",
2667
2667
  "dist/gateway-ChoMsZEr.js",
2668
- "dist/gateway-cli-pj6tWKTk.js",
2668
+ "dist/gateway-cli-eSJgcA31.js",
2669
2669
  "dist/gateway-control-ui-origins-Cv0Yit_i.js",
2670
2670
  "dist/gateway-discovery-targets-CE3SJS1o.js",
2671
2671
  "dist/gateway-install-token-DmMKqYDr.js",
@@ -3283,7 +3283,7 @@
3283
3283
  "dist/openclaw.plugin-DW9TMPE7.js",
3284
3284
  "dist/openclaw.plugin-QSPYzYWx.js",
3285
3285
  "dist/openresponses-http-DEwaG2UX.js",
3286
- "dist/operations-BpSveX17.js",
3286
+ "dist/operations-Dv7j-NpF.js",
3287
3287
  "dist/operator-approvals-client-kPeM-ghG.js",
3288
3288
  "dist/operator-scopes-B0wNyvBW.js",
3289
3289
  "dist/order-C6fBUbU3.js",
@@ -7443,7 +7443,7 @@
7443
7443
  "dist/profile-list-DRJDaM7Y.js",
7444
7444
  "dist/profile-utils-7b3ZHGpe.js",
7445
7445
  "dist/profiles-JhylvYqI.js",
7446
- "dist/program-BpI9kTzJ.js",
7446
+ "dist/program-CEtzLOw3.js",
7447
7447
  "dist/program-context-BPz01Sb4.js",
7448
7448
  "dist/program-context-DAqUYR9Q.js",
7449
7449
  "dist/progress-DEutg9EU.js",
@@ -7654,16 +7654,16 @@
7654
7654
  "dist/register.agent-hi5DBiRB.js",
7655
7655
  "dist/register.backup-BpBm654g.js",
7656
7656
  "dist/register.configure-BB8gW2Cw.js",
7657
- "dist/register.crestodian-y8Ymvezu.js",
7657
+ "dist/register.crestodian-o_jW-snG.js",
7658
7658
  "dist/register.maintenance-CK3bjvhh.js",
7659
7659
  "dist/register.message-CKdlyKEs.js",
7660
7660
  "dist/register.migrate-u0ymn5qq.js",
7661
7661
  "dist/register.onboard-DfI4Lfvm.js",
7662
7662
  "dist/register.setup-DSMBEXhI.js",
7663
7663
  "dist/register.status-health-sessions-BWogum6u.js",
7664
- "dist/register.subclis-BZI2W2li.js",
7665
- "dist/register.subclis-core-OKdixKpO.js",
7666
- "dist/register.subclis-CtaRYKyA.js",
7664
+ "dist/register.subclis-core-y3H-e26t.js",
7665
+ "dist/register.subclis-CXOkRHl6.js",
7666
+ "dist/register.subclis-DLLl37PA.js",
7667
7667
  "dist/registry-C85w3UMa.js",
7668
7668
  "dist/registry-D6R60lhW.js",
7669
7669
  "dist/registry-DBMOajJS.js",
@@ -7731,10 +7731,10 @@
7731
7731
  "dist/root-help-X_sUYrsl.js",
7732
7732
  "dist/root-memory-files-YefKNHwl.js",
7733
7733
  "dist/route-auth-K9vk7d03.js",
7734
- "dist/route-BynaE0pb.js",
7735
7734
  "dist/route-reply-BM0cEgcN.js",
7736
7735
  "dist/route-reply.runtime-CkhhO1vX.js",
7737
7736
  "dist/route-reply.runtime.js",
7737
+ "dist/route-xP22X2bZ.js",
7738
7738
  "dist/routes-CrlJYldF.js",
7739
7739
  "dist/routes-fb1zZLp8.js",
7740
7740
  "dist/routing-TLYJLD5I.js",
@@ -7744,11 +7744,11 @@
7744
7744
  "dist/rpc.runtime.js",
7745
7745
  "dist/run-auth-profile.runtime-D52pGWS-.js",
7746
7746
  "dist/run-auth-profile.runtime.js",
7747
- "dist/run-B7mVeLtf.js",
7748
- "dist/run-CHwkqs_l.js",
7747
+ "dist/run-BDvpbL6X.js",
7749
7748
  "dist/run-command-CT6r9duW.js",
7750
7749
  "dist/run-context.runtime-CQrQKujy.js",
7751
7750
  "dist/run-context.runtime.js",
7751
+ "dist/run-CRwamKav.js",
7752
7752
  "dist/run-delivery.runtime-CLVFzUsE.js",
7753
7753
  "dist/run-delivery.runtime.js",
7754
7754
  "dist/run-embedded.runtime-DV93n6m_.js",
@@ -7844,7 +7844,7 @@
7844
7844
  "dist/runtime-registry-loader-BXI479Q8.js",
7845
7845
  "dist/runtime-registry-loader-CRw7Q92-.js",
7846
7846
  "dist/runtime-rFFV7jqk.js",
7847
- "dist/runtime-schema-CNIdSEd4.js",
7847
+ "dist/runtime-schema-CjQQFitv.js",
7848
7848
  "dist/runtime-shared-ClUz2kEK.js",
7849
7849
  "dist/runtime-shared-Cp4Kj9uq.js",
7850
7850
  "dist/runtime-sidecar-paths-x_1yh4vX.js",
@@ -7926,17 +7926,17 @@
7926
7926
  "dist/server-chat-BHbejvgn.js",
7927
7927
  "dist/server-Cl-5cBFY.js",
7928
7928
  "dist/server-close-BJJy21On.js",
7929
- "dist/server-Cntni6l8.js",
7930
7929
  "dist/server-constants-Be14enJ0.js",
7931
7930
  "dist/server-context-C4wklOCJ.js",
7932
7931
  "dist/server-context-D4ZXIeAZ.js",
7933
7932
  "dist/server-json-CLBM-p_d.js",
7934
- "dist/server-methods-D2vht_QR.js",
7933
+ "dist/server-methods-CBx73Ug-.js",
7935
7934
  "dist/server-middleware-DRn7LEQk.js",
7936
7935
  "dist/server-model-catalog-xhiB9tgW.js",
7937
7936
  "dist/server-node-events-kmuHFq9j.js",
7938
- "dist/server-plugin-bootstrap-CEfHwkno.js",
7939
- "dist/server-plugin-bootstrap-DWvZ-HCI.js",
7937
+ "dist/server-OZWXuHXI.js",
7938
+ "dist/server-plugin-bootstrap-vl1ejzkD.js",
7939
+ "dist/server-plugin-bootstrap-ZA5D65nV.js",
7940
7940
  "dist/server-reload-handlers-B3gDl2fL.js",
7941
7941
  "dist/server-restart-sentinel-B4zLDOil.js",
7942
7942
  "dist/server-restart-sentinel-CrdAyt4a.js",
@@ -7944,7 +7944,7 @@
7944
7944
  "dist/server-startup-log-CaUcn1jh.js",
7945
7945
  "dist/server-startup-memory-Dzw_rhUs.js",
7946
7946
  "dist/server-tailscale-CF3CY3YJ.js",
7947
- "dist/server.impl-DR_SqBmD.js",
7947
+ "dist/server.impl-BoLlD_Zm.js",
7948
7948
  "dist/service-audit-B7H59cr9.js",
7949
7949
  "dist/service-audit-Crqizo10.js",
7950
7950
  "dist/service-BwerdKfA.js",
@@ -8412,7 +8412,7 @@
8412
8412
  "dist/tts.runtime-Bp6MnFUb.js",
8413
8413
  "dist/tts.runtime-XmvYZt5k.js",
8414
8414
  "dist/tts.runtime.js",
8415
- "dist/tui-backend-5SVT148v.js",
8415
+ "dist/tui-backend-BFU3M2gp.js",
8416
8416
  "dist/tui-BsmD4OWl.js",
8417
8417
  "dist/tui-cli-Dt6DOakR.js",
8418
8418
  "dist/tui-DMn8dYl5.js",
@@ -10,7 +10,7 @@ import { n as setProgramContext } from "./program-context-BPz01Sb4.js";
10
10
  import { t as isCommandJsonOutputMode } from "./json-mode-CEP1Xm_u.js";
11
11
  import { n as resolvePluginInstallPreactionRequest, t as resolvePluginInstallInvalidConfigPolicy } from "./plugin-install-config-policy-9u9i0qwM.js";
12
12
  import { t as forceFreePort } from "./ports-C-alElw5.js";
13
- import { t as registerProgramCommands } from "./command-registry-CMWio-tP.js";
13
+ import { t as registerProgramCommands } from "./command-registry-BXwjip4t.js";
14
14
  import { t as configureProgramHelp } from "./help-drsYiZEo.js";
15
15
  import { n as ensureCliExecutionBootstrap, r as resolveCliExecutionStartupContext, t as applyCliExecutionStartupPresentation } from "./command-execution-startup-CyzpU1vC.js";
16
16
  import process$1 from "node:process";
@@ -1,6 +1,6 @@
1
1
  import { r as theme } from "./theme-B128avno.js";
2
2
  import { n as defaultRuntime } from "./runtime-CIJX7ulQ.js";
3
- import { t as runCrestodian } from "./crestodian-DskOuHY3.js";
3
+ import { t as runCrestodian } from "./crestodian-DG6faf2a.js";
4
4
  import { n as runCommandWithRuntime } from "./cli-utils-BE3eZBkQ.js";
5
5
  import { t as formatHelpExamples } from "./help-format-CmO6sKiH.js";
6
6
  //#region src/cli/program/register.crestodian.ts
@@ -0,0 +1,3 @@
1
+ import "./argv-Bh2LLxMT.js";
2
+ import { t as registerSubCliByName } from "./register.subclis-DLLl37PA.js";
3
+ export { registerSubCliByName };
@@ -2,11 +2,11 @@ import { h as getSubCliEntries } from "./argv-Bh2LLxMT.js";
2
2
  import { t as resolveCliArgvInvocation } from "./argv-invocation-C0QUafZn.js";
3
3
  import { r as shouldRegisterPrimarySubcommandOnly, t as shouldEagerRegisterSubcommands } from "./command-registration-policy-C0qLofS8.js";
4
4
  import { i as registerCommandGroups, r as registerCommandGroupByName } from "./register-command-groups-C8J96v2h.js";
5
- import { i as buildCommandGroupEntries, n as registerSubCliByName$1, o as defineImportedProgramCommandGroupSpecs, r as registerSubCliCommands$1 } from "./register.subclis-core-OKdixKpO.js";
5
+ import { i as buildCommandGroupEntries, n as registerSubCliByName$1, o as defineImportedProgramCommandGroupSpecs, r as registerSubCliCommands$1 } from "./register.subclis-core-y3H-e26t.js";
6
6
  //#region src/cli/program/register.subclis.ts
7
7
  const entrySpecs = [...defineImportedProgramCommandGroupSpecs([{
8
8
  commandNames: ["completion"],
9
- loadModule: () => import("./completion-cli-BmOHMHeQ.js"),
9
+ loadModule: () => import("./completion-cli-DYMtC8G6.js"),
10
10
  exportName: "registerCompletionCli"
11
11
  }])];
12
12
  function resolveSubCliCommandGroups() {
@@ -52,7 +52,7 @@ function shouldRegisterGatewayRunOnly(name, argv) {
52
52
  return invocation.commandPath.length === 1 || invocation.commandPath[1] === "run";
53
53
  }
54
54
  async function registerGatewayRunOnly(program) {
55
- const { addGatewayRunCommand } = await import("./run-CHwkqs_l.js");
55
+ const { addGatewayRunCommand } = await import("./run-CRwamKav.js");
56
56
  removeCommandByName(program, "gateway");
57
57
  addGatewayRunCommand(addGatewayRunCommand(program.command("gateway").description("Run, inspect, and query the WebSocket Gateway")).command("run").description("Run the WebSocket Gateway (foreground)"));
58
58
  }
@@ -73,7 +73,7 @@ const entrySpecs = [
73
73
  },
74
74
  {
75
75
  commandNames: ["gateway"],
76
- loadModule: () => import("./gateway-cli-pj6tWKTk.js"),
76
+ loadModule: () => import("./gateway-cli-eSJgcA31.js"),
77
77
  exportName: "registerGatewayCli"
78
78
  },
79
79
  {
@@ -232,7 +232,7 @@ let configCliPromise;
232
232
  let modelsListCommandPromise;
233
233
  let modelsStatusCommandPromise;
234
234
  function loadConfigCli() {
235
- configCliPromise ??= import("./config-cli-zS-Lu2lA.js");
235
+ configCliPromise ??= import("./config-cli-CFLlqP4o.js");
236
236
  return configCliPromise;
237
237
  }
238
238
  function loadModelsListCommand() {
@@ -652,7 +652,7 @@ async function runGatewayCommand(opts) {
652
652
  const { startGatewayServer } = await startupTrace.measure("cli.server-import", () => withProgress({
653
653
  label: "Loading gateway modules…",
654
654
  indeterminate: true
655
- }, async () => import("./server-Cntni6l8.js")));
655
+ }, async () => import("./server-OZWXuHXI.js")));
656
656
  setConsoleTimestampPrefix(true);
657
657
  if (devMode) {
658
658
  const { ensureDevGatewayConfig } = await import("./dev-BNvXFn0o.js");
@@ -1,2 +1,2 @@
1
- import { n as addGatewayRunCommand, t as __testing } from "./run-B7mVeLtf.js";
1
+ import { n as addGatewayRunCommand, t as __testing } from "./run-BDvpbL6X.js";
2
2
  export { __testing, addGatewayRunCommand };
@@ -26555,7 +26555,7 @@ const GENERATED_BASE_CONFIG_SCHEMA = {
26555
26555
  ] },
26556
26556
  "mcp.servers.*.url": { tags: ["advanced", "url-secret"] }
26557
26557
  },
26558
- version: "2026.4.27-beta.1",
26558
+ version: "2026.4.27",
26559
26559
  generatedAt: "2026-03-22T21:17:33.302Z"
26560
26560
  };
26561
26561
  //#endregion
@@ -8,7 +8,7 @@ async function loadServerImpl() {
8
8
  const startupStartedAt = performance.now();
9
9
  const before = performance.now();
10
10
  try {
11
- return await import("./server.impl-DR_SqBmD.js");
11
+ return await import("./server.impl-BoLlD_Zm.js");
12
12
  } finally {
13
13
  const now = performance.now();
14
14
  emitStartupTrace("gateway.server-impl-import", now - before, now - startupStartedAt);
@@ -162,7 +162,7 @@ import { n as buildAuthHealthSummary, r as formatRemainingShort } from "./auth-h
162
162
  import { a as performGatewaySessionReset } from "./session-reset-service-BuH-2Afi.js";
163
163
  import { t as buildChannelUiCatalog } from "./catalog-Cd8W7MpD.js";
164
164
  import { a as removeBackfillDiaryEntries, c as writeBackfillDiaryEntries, n as dedupeDreamDiaryEntries, o as removeGroundedShortTermCandidates, r as previewGroundedRemMarkdown, s as repairDreamingArtifacts } from "./memory-core-bundled-runtime-Dc6W1BMH.js";
165
- import { r as lookupConfigSchema, t as loadGatewayRuntimeConfigSchema } from "./runtime-schema-CNIdSEd4.js";
165
+ import { r as lookupConfigSchema, t as loadGatewayRuntimeConfigSchema } from "./runtime-schema-CjQQFitv.js";
166
166
  import { t as readConfiguredLogTail } from "./log-tail-DxdMZUpS.js";
167
167
  import { n as purgeAgentSessionStoreEntries } from "./agents.command-shared-uTTCDkFP.js";
168
168
  import { o as pruneAgentConfig, r as findAgentEntryIndex, t as applyAgentConfig } from "./agents.config-D05DHieO.js";
@@ -1,2 +1,2 @@
1
- import { r as reloadDeferredGatewayPlugins } from "./server-plugin-bootstrap-DWvZ-HCI.js";
1
+ import { r as reloadDeferredGatewayPlugins } from "./server-plugin-bootstrap-vl1ejzkD.js";
2
2
  export { reloadDeferredGatewayPlugins };
@@ -293,7 +293,7 @@ async function dispatchGatewayMethod(method, params, options) {
293
293
  const isWebchatConnect = scope?.isWebchatConnect ?? (() => false);
294
294
  if (!context) throw new Error(`Plugin subagent dispatch requires a gateway request scope (method: ${method}). No scope set and no fallback context available.`);
295
295
  let result;
296
- const { handleGatewayRequest } = await import("./server-methods-D2vht_QR.js");
296
+ const { handleGatewayRequest } = await import("./server-methods-CBx73Ug-.js");
297
297
  const pluginRuntimeOwnerId = typeof options?.pluginRuntimeOwnerId === "string" && options.pluginRuntimeOwnerId.trim() ? options.pluginRuntimeOwnerId.trim() : void 0;
298
298
  const syntheticClient = createSyntheticOperatorClient({
299
299
  allowModelOverride: options?.allowSyntheticModelOverride === true,
@@ -120,7 +120,7 @@ import { C as pruneStaleControlPlaneBuckets, b as parseGatewayRole, f as loadVoi
120
120
  import { i as buildGatewayReloadPlan, t as diffConfigPaths } from "./config-reload-B8Hbe_dn.js";
121
121
  import { a as resolveApnsAuthConfigFromEnv, c as sendApnsExecApprovalAlert, d as resolveApnsRelayConfigFromEnv, l as sendApnsExecApprovalResolvedWake, n as loadApnsRegistration, t as clearApnsRegistrationIfCurrent, u as shouldClearStoredApnsRegistration } from "./push-apns-Cja9LD1a.js";
122
122
  import { i as normalizeCanvasScopedUrl, n as buildCanvasScopedHostUrl, r as mintCanvasCapabilityToken, t as CANVAS_CAPABILITY_TTL_MS } from "./canvas-capability-DUKLM-Um.js";
123
- import { a as loadPluginLookUpTable, i as setFallbackGatewayContextResolver, o as mergeActivationSectionsIntoRuntimeConfig, t as loadGatewayStartupPlugins } from "./server-plugin-bootstrap-DWvZ-HCI.js";
123
+ import { a as loadPluginLookUpTable, i as setFallbackGatewayContextResolver, o as mergeActivationSectionsIntoRuntimeConfig, t as loadGatewayStartupPlugins } from "./server-plugin-bootstrap-vl1ejzkD.js";
124
124
  import { a as getRequiredSharedGatewaySessionGeneration, d as DEFAULT_CHANNEL_CONNECT_GRACE_MS, f as DEFAULT_CHANNEL_STALE_EVENT_THRESHOLD_MS, g as enqueueConfigRecoveryNotice, h as buildGatewayCronService, i as enforceSharedGatewaySessionGenerationForConfigWrite, m as applyGatewayLaneConcurrency, n as disconnectAllSharedGatewayAuthClients, o as setCurrentSharedGatewaySessionGeneration, p as evaluateChannelHealth, r as disconnectStaleSharedGatewayAuthClients, s as activateGatewayScheduledServices, t as resolveHookClientIpConfig, u as startGatewayRuntimeServices } from "./hook-client-ip-config-B6ymtVEi.js";
125
125
  import { a as resolvePluginRoutePathContext, i as isProtectedPluginRoutePathFromContext, n as shouldEnforceGatewayAuthForPluginPath } from "./route-auth-K9vk7d03.js";
126
126
  import "./paths-Cev8MaZh.js";
@@ -7162,7 +7162,7 @@ function attachGatewayWsMessageHandler(params) {
7162
7162
  });
7163
7163
  };
7164
7164
  (async () => {
7165
- const { handleGatewayRequest } = await import("./server-methods-D2vht_QR.js");
7165
+ const { handleGatewayRequest } = await import("./server-methods-CBx73Ug-.js");
7166
7166
  await handleGatewayRequest({
7167
7167
  req,
7168
7168
  respond,
@@ -8095,7 +8095,7 @@ async function startGatewayServer(port = 18789, opts = {}) {
8095
8095
  } : () => {};
8096
8096
  if (!minimalTestGateway) {
8097
8097
  if (deferredConfiguredChannelPluginIds.length > 0) {
8098
- const { reloadDeferredGatewayPlugins } = await import("./server-plugin-bootstrap-CEfHwkno.js");
8098
+ const { reloadDeferredGatewayPlugins } = await import("./server-plugin-bootstrap-ZA5D65nV.js");
8099
8099
  ({pluginRegistry, gatewayMethods: baseGatewayMethods} = reloadDeferredGatewayPlugins({
8100
8100
  cfg: gatewayPluginConfigAtStart,
8101
8101
  activationSourceConfig: startupActivationSourceConfig,
@@ -1,7 +1,7 @@
1
1
  import { r as buildAgentMainSessionKey } from "./session-key-C6F-NnIG.js";
2
- import { i as isPersistentCrestodianOperation, n as executeCrestodianOperation } from "./operations-BpSveX17.js";
2
+ import { i as isPersistentCrestodianOperation, n as executeCrestodianOperation } from "./operations-Dv7j-NpF.js";
3
3
  import { n as formatCrestodianStartupMessage, r as loadCrestodianOverview } from "./overview-BsMEIOL7.js";
4
- import { n as isYes, r as resolveCrestodianOperation, t as approvalQuestion } from "./dialogue-C9Rd8vz5.js";
4
+ import { n as isYes, r as resolveCrestodianOperation, t as approvalQuestion } from "./dialogue-BzHx5-LG.js";
5
5
  import { f as runTui } from "./tui-DMn8dYl5.js";
6
6
  import { randomUUID } from "node:crypto";
7
7
  //#region src/crestodian/tui-backend.ts
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "openclaw",
3
- "version": "2026.4.27-beta.1",
3
+ "version": "2026.4.27",
4
4
  "description": "Multi-channel AI gateway with extensible messaging integrations",
5
5
  "keywords": [],
6
6
  "homepage": "https://github.com/openclaw/openclaw#readme",
@@ -1,3 +0,0 @@
1
- import "./argv-Bh2LLxMT.js";
2
- import { t as registerSubCliByName } from "./register.subclis-BZI2W2li.js";
3
- export { registerSubCliByName };