UNPKG

@gguf/claw

Version:

Multi-channel AI gateway with extensible messaging integrations

207 lines (204 loc) 7.67 kB
import "./paths-B4BZAPZh.js"; import { B as theme, S as shortenHomePath } from "./utils-CP9YLh6M.js"; import "./thinking-EAliFiVK.js"; import "./reply-BylFHBd4.js"; import "./registry-B-j4DRfe.js"; import { f as defaultRuntime } from "./subsystem-BCQGGxdd.js"; import "./exec-DYqRzFbo.js"; import { C as ensureAgentWorkspace, m as DEFAULT_AGENT_WORKSPACE_DIR } from "./agent-scope-BnZW9Gh2.js"; import "./model-selection-CqaTAlhy.js"; import "./github-copilot-token-D2zp6kMZ.js"; import "./boolean-BsqeuxE6.js"; import "./env-VriqyjXT.js"; import "./message-channel-Bena1Tzd.js"; import "./send-CsyONLnQ.js"; import { l as writeConfigFile, r as createConfigIO } from "./config-PQiujvsf.js"; import "./manifest-registry-4k4vkhPS.js"; import "./runner-U04aiHHC.js"; import "./image-DxEpBZim.js"; import "./models-config-B459BnCS.js"; import "./pi-model-discovery-4uUnLc3n.js"; import "./pi-embedded-helpers-BdscQhyS.js"; import "./sandbox-UAzvS0V6.js"; import "./image-ops-CI1VknD1.js"; import "./common-a25M2Kvi.js"; import "./chrome-Dd5zBIFu.js"; import "./tailscale-C3JsBEiY.js"; import "./auth-DZSWPd8D.js"; import "./server-context-DAWsUNUs.js"; import "./frontmatter-6HZ0_y2V.js"; import "./skills-CLmzWt48.js"; import "./routes-DIQa_0pt.js"; import "./redact-B7Mjvk0c.js"; import "./errors-kfGqPQ4b.js"; import "./fs-safe-_OpKPuZA.js"; import "./paths-D1WZUYry.js"; import "./ssrf-6f5m2MMA.js"; import "./store-DSGYY-H9.js"; import "./ports-DwDxX6cS.js"; import "./trash-DLzIf__E.js"; import "./sessions-Z1BZU3xh.js"; import "./dock-7F-MiPtF.js"; import "./normalize-Ci8UyR3Z.js"; import "./accounts-Bj1dJ-fd.js"; import "./accounts-DOl1Wkxo.js"; import "./accounts-t6R5_PzC.js"; import "./bindings-Dja1z-h8.js"; import "./logging-xYH6GmRT.js"; import "./send-uu2Jc-Js.js"; import "./plugins-CKbXkuXd.js"; import { o as resolveSessionTranscriptsDir } from "./paths-C2NfoGZE.js"; import "./tool-display-Bx4M6uNT.js"; import "./fetch-guard-C1sYsWgl.js"; import "./api-key-rotation-CpGefdGL.js"; import "./local-roots-DiDvXIIo.js"; import "./sqlite-JcMMx8Z5.js"; import "./model-catalog-CIixTnGt.js"; import "./tokens-D4lZk7-h.js"; import "./with-timeout-DijiQjw6.js"; import "./deliver-DgvS3uCz.js"; import "./diagnostic-UUwku4RV.js"; import "./diagnostic-session-state-ByqoIyGn.js"; import "./send-DbwyyQAv.js"; import "./model-VbWjwqaW.js"; import "./reply-prefix-DAK7-zK4.js"; import "./memory-cli-DxmtLhh_.js"; import "./manager-C0teWocQ.js"; import "./retry-rUEdE6zT.js"; import "./chunk-CMylpCPi.js"; import "./markdown-tables-B9VGUdDc.js"; import "./ir-24qCLTKH.js"; import "./render-CXDO_kgw.js"; import "./commands-registry-bb_U-3FM.js"; import "./client-BdSkEtCd.js"; import "./call-BCz_8mqq.js"; import "./pairing-token-B-_eiWlR.js"; import "./channel-activity-DynIQUB_.js"; import "./fetch-Bu5zBCce.js"; import "./tables-C70h_80U.js"; import "./send-CAfFUUkm.js"; import "./pairing-store-T5DpOfoL.js"; import "./proxy-BiOWrea2.js"; import { t as formatDocsLink } from "./links-BVCMOGeE.js"; import { n as runCommandWithRuntime } from "./cli-utils-CX1oQ81G.js"; import "./help-format-dbk2xW0E.js"; import "./progress-CaVMHLaE.js"; import "./resolve-route-2TU_aaLs.js"; import "./replies-NhrZJ3yf.js"; import "./skill-commands-N8Sho46-.js"; import "./workspace-dirs-CE3CxabZ.js"; import "./pi-tools.policy-DTy1DnPK.js"; import "./outbound-attachment-CntoLTI_.js"; import "./delivery-queue-CxDDEWQg.js"; import "./session-cost-usage-BlUDaylg.js"; import "./send-4LoRaltQ.js"; import "./onboard-helpers-DbjfBSMX.js"; import "./prompt-style-VqCNjBi8.js"; import "./pairing-labels-DaESq9ML.js"; import "./exec-approvals-q0C8VDMT.js"; import "./nodes-screen-5fMfTT2n.js"; import "./control-service-BoO2TGOx.js"; import "./stagger-B6VQyn1F.js"; import "./channel-selection-DuDSoVSC.js"; import "./runtime-guard-DlT3NecY.js"; import { t as hasExplicitOptions } from "./command-options-ByE5SNIE.js"; import "./note-C-OTWf0F.js"; import "./clack-prompter-C8qX15zH.js"; import "./daemon-runtime-CZuP7tS4.js"; import "./systemd-B6S4ND7H.js"; import "./service-Bw9h81em.js"; import "./health-Bt3xmMjK.js"; import "./onboarding-DeU1kIgp.js"; import "./shared-B-zggieW.js"; import "./auth-token-CliHE70g.js"; import { n as logConfigUpdated, t as formatConfigPath } from "./logging-Cl6-FWdR.js"; import "./openai-model-default-8jds2v9m.js"; import "./vllm-setup-G6R-Hqd8.js"; import "./systemd-linger-C3Tnphf9.js"; import "./model-picker-C9zrudfS.js"; import "./onboard-custom-DQu1PmgP.js"; import { t as onboardCommand } from "./onboard-cNHf-thX.js"; import JSON5 from "json5"; import fs from "node:fs/promises"; //#region src/commands/setup.ts async function readConfigFileRaw(configPath) { try { const raw = await fs.readFile(configPath, "utf-8"); const parsed = JSON5.parse(raw); if (parsed && typeof parsed === "object") return { exists: true, parsed }; return { exists: true, parsed: {} }; } catch { return { exists: false, parsed: {} }; } } async function setupCommand(opts, runtime = defaultRuntime) { const desiredWorkspace = typeof opts?.workspace === "string" && opts.workspace.trim() ? opts.workspace.trim() : void 0; const configPath = createConfigIO().configPath; const existingRaw = await readConfigFileRaw(configPath); const cfg = existingRaw.parsed; const defaults = cfg.agents?.defaults ?? {}; const workspace = desiredWorkspace ?? defaults.workspace ?? DEFAULT_AGENT_WORKSPACE_DIR; const next = { ...cfg, agents: { ...cfg.agents, defaults: { ...defaults, workspace } } }; if (!existingRaw.exists || defaults.workspace !== workspace) { await writeConfigFile(next); if (!existingRaw.exists) runtime.log(`Wrote ${formatConfigPath(configPath)}`); else logConfigUpdated(runtime, { path: configPath, suffix: "(set agents.defaults.workspace)" }); } else runtime.log(`Config OK: ${formatConfigPath(configPath)}`); const ws = await ensureAgentWorkspace({ dir: workspace, ensureBootstrapFiles: !next.agents?.defaults?.skipBootstrap }); runtime.log(`Workspace OK: ${shortenHomePath(ws.dir)}`); const sessionsDir = resolveSessionTranscriptsDir(); await fs.mkdir(sessionsDir, { recursive: true }); runtime.log(`Sessions OK: ${shortenHomePath(sessionsDir)}`); } //#endregion //#region src/cli/program/register.setup.ts function registerSetupCommand(program) { program.command("setup").description("Initialize ~/.openclaw/openclaw.json and the agent workspace").addHelpText("after", () => `\n${theme.muted("Docs:")} ${formatDocsLink("/cli/setup", "docs.openclaw.ai/cli/setup")}\n`).option("--workspace <dir>", "Agent workspace directory (default: ~/.openclaw/workspace; stored as agents.defaults.workspace)").option("--wizard", "Run the interactive onboarding wizard", false).option("--non-interactive", "Run the wizard without prompts", false).option("--mode <mode>", "Wizard mode: local|remote").option("--remote-url <url>", "Remote Gateway WebSocket URL").option("--remote-token <token>", "Remote Gateway token (optional)").action(async (opts, command) => { await runCommandWithRuntime(defaultRuntime, async () => { const hasWizardFlags = hasExplicitOptions(command, [ "wizard", "nonInteractive", "mode", "remoteUrl", "remoteToken" ]); if (opts.wizard || hasWizardFlags) { await onboardCommand({ workspace: opts.workspace, nonInteractive: Boolean(opts.nonInteractive), mode: opts.mode, remoteUrl: opts.remoteUrl, remoteToken: opts.remoteToken }, defaultRuntime); return; } await setupCommand({ workspace: opts.workspace }, defaultRuntime); }); }); } //#endregion export { registerSetupCommand };