mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-10 07:22:44 +00:00
Co-authored-by: jaden-clovervnd <91520439+jaden-clovervnd@users.noreply.github.com> Co-authored-by: Sid <201593046+Sid-Qin@users.noreply.github.com> Co-authored-by: Marcus Widing <245375637+widingmarcus-cyber@users.noreply.github.com>
97 lines
3.7 KiB
TypeScript
97 lines
3.7 KiB
TypeScript
import { formatCliCommand } from "../cli/command-format.js";
|
|
import { readConfigFileSnapshot } from "../config/config.js";
|
|
import { assertSupportedRuntime } from "../infra/runtime-guard.js";
|
|
import type { RuntimeEnv } from "../runtime.js";
|
|
import { defaultRuntime } from "../runtime.js";
|
|
import { resolveUserPath } from "../utils.js";
|
|
import { isDeprecatedAuthChoice, normalizeLegacyOnboardAuthChoice } from "./auth-choice-legacy.js";
|
|
import { DEFAULT_WORKSPACE, handleReset } from "./onboard-helpers.js";
|
|
import { runInteractiveOnboarding } from "./onboard-interactive.js";
|
|
import { runNonInteractiveOnboarding } from "./onboard-non-interactive.js";
|
|
import type { OnboardOptions, ResetScope } from "./onboard-types.js";
|
|
|
|
const VALID_RESET_SCOPES = new Set<ResetScope>(["config", "config+creds+sessions", "full"]);
|
|
|
|
export async function onboardCommand(opts: OnboardOptions, runtime: RuntimeEnv = defaultRuntime) {
|
|
assertSupportedRuntime(runtime);
|
|
const originalAuthChoice = opts.authChoice;
|
|
const normalizedAuthChoice = normalizeLegacyOnboardAuthChoice(originalAuthChoice);
|
|
if (opts.nonInteractive && isDeprecatedAuthChoice(originalAuthChoice)) {
|
|
runtime.error(
|
|
[
|
|
`Auth choice "${String(originalAuthChoice)}" is deprecated.`,
|
|
'Use "--auth-choice token" (Anthropic setup-token) or "--auth-choice openai-codex".',
|
|
].join("\n"),
|
|
);
|
|
runtime.exit(1);
|
|
return;
|
|
}
|
|
if (originalAuthChoice === "claude-cli") {
|
|
runtime.log('Auth choice "claude-cli" is deprecated; using setup-token flow instead.');
|
|
}
|
|
if (originalAuthChoice === "codex-cli") {
|
|
runtime.log('Auth choice "codex-cli" is deprecated; using OpenAI Codex OAuth instead.');
|
|
}
|
|
const flow = opts.flow === "manual" ? ("advanced" as const) : opts.flow;
|
|
const normalizedOpts =
|
|
normalizedAuthChoice === opts.authChoice && flow === opts.flow
|
|
? opts
|
|
: { ...opts, authChoice: normalizedAuthChoice, flow };
|
|
if (
|
|
normalizedOpts.secretInputMode &&
|
|
normalizedOpts.secretInputMode !== "plaintext" &&
|
|
normalizedOpts.secretInputMode !== "ref"
|
|
) {
|
|
runtime.error('Invalid --secret-input-mode. Use "plaintext" or "ref".');
|
|
runtime.exit(1);
|
|
return;
|
|
}
|
|
|
|
if (normalizedOpts.resetScope && !VALID_RESET_SCOPES.has(normalizedOpts.resetScope)) {
|
|
runtime.error('Invalid --reset-scope. Use "config", "config+creds+sessions", or "full".');
|
|
runtime.exit(1);
|
|
return;
|
|
}
|
|
|
|
if (normalizedOpts.nonInteractive && normalizedOpts.acceptRisk !== true) {
|
|
runtime.error(
|
|
[
|
|
"Non-interactive onboarding requires explicit risk acknowledgement.",
|
|
"Read: https://docs.openclaw.ai/security",
|
|
`Re-run with: ${formatCliCommand("openclaw onboard --non-interactive --accept-risk ...")}`,
|
|
].join("\n"),
|
|
);
|
|
runtime.exit(1);
|
|
return;
|
|
}
|
|
|
|
if (normalizedOpts.reset) {
|
|
const snapshot = await readConfigFileSnapshot();
|
|
const baseConfig = snapshot.valid ? snapshot.config : {};
|
|
const workspaceDefault =
|
|
normalizedOpts.workspace ?? baseConfig.agents?.defaults?.workspace ?? DEFAULT_WORKSPACE;
|
|
const resetScope: ResetScope = normalizedOpts.resetScope ?? "config+creds+sessions";
|
|
await handleReset(resetScope, resolveUserPath(workspaceDefault), runtime);
|
|
}
|
|
|
|
if (process.platform === "win32") {
|
|
runtime.log(
|
|
[
|
|
"Windows detected — OpenClaw runs great on WSL2!",
|
|
"Native Windows might be trickier.",
|
|
"Quick setup: wsl --install (one command, one reboot)",
|
|
"Guide: https://docs.openclaw.ai/windows",
|
|
].join("\n"),
|
|
);
|
|
}
|
|
|
|
if (normalizedOpts.nonInteractive) {
|
|
await runNonInteractiveOnboarding(normalizedOpts, runtime);
|
|
return;
|
|
}
|
|
|
|
await runInteractiveOnboarding(normalizedOpts, runtime);
|
|
}
|
|
|
|
export type { OnboardOptions } from "./onboard-types.js";
|