mirror of
https://github.com/openclaw/openclaw.git
synced 2026-04-02 21:01:51 +00:00
* Models: gate custom provider keys by usable secret semantics * Config: project runtime writes onto source snapshot * Models: prevent stale apiKey preservation for marker-managed providers * Runner: strip SecretRef marker headers from resolved models * Secrets: scan active agent models.json path in audit * Config: guard runtime-source projection for unrelated configs * Extensions: fix onboarding type errors in CI * Tests: align setup helper account-enabled expectation * Secrets audit: harden models.json file reads * fix: harden SecretRef custom/provider secret persistence (#42554) (thanks @joshavant)
57 lines
2.0 KiB
TypeScript
57 lines
2.0 KiB
TypeScript
import { ensureAuthProfileStore, listProfilesForProvider } from "../agents/auth-profiles.js";
|
|
import { hasUsableCustomProviderApiKey, resolveEnvApiKey } from "../agents/model-auth.js";
|
|
import { loadModelCatalog } from "../agents/model-catalog.js";
|
|
import { resolveDefaultModelForAgent } from "../agents/model-selection.js";
|
|
import type { OpenClawConfig } from "../config/config.js";
|
|
import type { WizardPrompter } from "../wizard/prompts.js";
|
|
import { OPENAI_CODEX_DEFAULT_MODEL } from "./openai-codex-model-default.js";
|
|
|
|
export async function warnIfModelConfigLooksOff(
|
|
config: OpenClawConfig,
|
|
prompter: WizardPrompter,
|
|
options?: { agentId?: string; agentDir?: string },
|
|
) {
|
|
const ref = resolveDefaultModelForAgent({
|
|
cfg: config,
|
|
agentId: options?.agentId,
|
|
});
|
|
const warnings: string[] = [];
|
|
const catalog = await loadModelCatalog({
|
|
config,
|
|
useCache: false,
|
|
});
|
|
if (catalog.length > 0) {
|
|
const known = catalog.some(
|
|
(entry) => entry.provider === ref.provider && entry.id === ref.model,
|
|
);
|
|
if (!known) {
|
|
warnings.push(
|
|
`Model not found: ${ref.provider}/${ref.model}. Update agents.defaults.model or run /models list.`,
|
|
);
|
|
}
|
|
}
|
|
|
|
const store = ensureAuthProfileStore(options?.agentDir);
|
|
const hasProfile = listProfilesForProvider(store, ref.provider).length > 0;
|
|
const envKey = resolveEnvApiKey(ref.provider);
|
|
const hasCustomKey = hasUsableCustomProviderApiKey(config, ref.provider);
|
|
if (!hasProfile && !envKey && !hasCustomKey) {
|
|
warnings.push(
|
|
`No auth configured for provider "${ref.provider}". The agent may fail until credentials are added.`,
|
|
);
|
|
}
|
|
|
|
if (ref.provider === "openai") {
|
|
const hasCodex = listProfilesForProvider(store, "openai-codex").length > 0;
|
|
if (hasCodex) {
|
|
warnings.push(
|
|
`Detected OpenAI Codex OAuth. Consider setting agents.defaults.model to ${OPENAI_CODEX_DEFAULT_MODEL}.`,
|
|
);
|
|
}
|
|
}
|
|
|
|
if (warnings.length > 0) {
|
|
await prompter.note(warnings.join("\n"), "Model check");
|
|
}
|
|
}
|