mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-30 04:16:25 +00:00
* fix(paths): respect OPENCLAW_HOME for all internal path resolution (#11995) Add home-dir module (src/infra/home-dir.ts) that centralizes home directory resolution with precedence: OPENCLAW_HOME > HOME > USERPROFILE > os.homedir(). Migrate all path-sensitive callsites: config IO, agent dirs, session transcripts, pairing store, cron store, doctor, CLI profiles. Add envHomedir() helper in config/paths.ts to reduce lambda noise. Document OPENCLAW_HOME in docs/help/environment.md. * fix(paths): handle OPENCLAW_HOME '~' fallback (#12091) (thanks @sebslight) * docs: mention OPENCLAW_HOME in install and getting started (#12091) (thanks @sebslight) * fix(status): show OPENCLAW_HOME in shortened paths (#12091) (thanks @sebslight) * docs(changelog): clarify OPENCLAW_HOME and HOME precedence (#12091) (thanks @sebslight)
72 lines
1.7 KiB
TypeScript
72 lines
1.7 KiB
TypeScript
import os from "node:os";
|
|
|
|
function normalize(value: string | undefined): string | undefined {
|
|
const trimmed = value?.trim();
|
|
return trimmed ? trimmed : undefined;
|
|
}
|
|
|
|
export function resolveEffectiveHomeDir(
|
|
env: NodeJS.ProcessEnv = process.env,
|
|
homedir: () => string = os.homedir,
|
|
): string | undefined {
|
|
const explicitHome = normalize(env.OPENCLAW_HOME);
|
|
if (explicitHome) {
|
|
if (explicitHome === "~" || explicitHome.startsWith("~/") || explicitHome.startsWith("~\\")) {
|
|
const fallbackHome =
|
|
normalize(env.HOME) ?? normalize(env.USERPROFILE) ?? normalizeSafe(homedir);
|
|
if (fallbackHome) {
|
|
return explicitHome.replace(/^~(?=$|[\\/])/, fallbackHome);
|
|
}
|
|
return undefined;
|
|
}
|
|
return explicitHome;
|
|
}
|
|
|
|
const envHome = normalize(env.HOME);
|
|
if (envHome) {
|
|
return envHome;
|
|
}
|
|
|
|
const userProfile = normalize(env.USERPROFILE);
|
|
if (userProfile) {
|
|
return userProfile;
|
|
}
|
|
|
|
return normalizeSafe(homedir);
|
|
}
|
|
|
|
function normalizeSafe(homedir: () => string): string | undefined {
|
|
try {
|
|
return normalize(homedir());
|
|
} catch {
|
|
return undefined;
|
|
}
|
|
}
|
|
|
|
export function resolveRequiredHomeDir(
|
|
env: NodeJS.ProcessEnv = process.env,
|
|
homedir: () => string = os.homedir,
|
|
): string {
|
|
return resolveEffectiveHomeDir(env, homedir) ?? process.cwd();
|
|
}
|
|
|
|
export function expandHomePrefix(
|
|
input: string,
|
|
opts?: {
|
|
home?: string;
|
|
env?: NodeJS.ProcessEnv;
|
|
homedir?: () => string;
|
|
},
|
|
): string {
|
|
if (!input.startsWith("~")) {
|
|
return input;
|
|
}
|
|
const home =
|
|
normalize(opts?.home) ??
|
|
resolveEffectiveHomeDir(opts?.env ?? process.env, opts?.homedir ?? os.homedir);
|
|
if (!home) {
|
|
return input;
|
|
}
|
|
return input.replace(/^~(?=$|[\\/])/, home);
|
|
}
|