mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-07 23:41:24 +00:00
* initial commit * removes assesment from docs * resolves automated review comments * resolves lint , type , tests , refactors , and submits * solves : why do we have to lint the tests xD * adds greptile fixes * solves a type error * solves a ci error * refactors auths * solves a failing test after i pulled from main lol * solves a failing test after i pulled from main lol * resolves token naming issue to comply with better practices when using hf / huggingface * fixes curly lints ! * fixes failing tests for google api from main * solve merge conflicts * solve failing tests with a defensive check 'undefined' openrouterapi key * fix: preserve Hugging Face auth-choice intent and token behavior (#13472) (thanks @Josephrp) * test: resolve auth-choice cherry-pick conflict cleanup (#13472) --------- Co-authored-by: Cursor <cursoragent@cursor.com> Co-authored-by: Peter Steinberger <steipete@gmail.com>
143 lines
4.1 KiB
TypeScript
143 lines
4.1 KiB
TypeScript
import type { OpenClawConfig } from "../config/config.js";
|
|
import {
|
|
buildCloudflareAiGatewayModelDefinition,
|
|
resolveCloudflareAiGatewayBaseUrl,
|
|
} from "../agents/cloudflare-ai-gateway.js";
|
|
import {
|
|
CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF,
|
|
VERCEL_AI_GATEWAY_DEFAULT_MODEL_REF,
|
|
} from "./onboard-auth.credentials.js";
|
|
|
|
export function applyVercelAiGatewayProviderConfig(cfg: OpenClawConfig): OpenClawConfig {
|
|
const models = { ...cfg.agents?.defaults?.models };
|
|
models[VERCEL_AI_GATEWAY_DEFAULT_MODEL_REF] = {
|
|
...models[VERCEL_AI_GATEWAY_DEFAULT_MODEL_REF],
|
|
alias: models[VERCEL_AI_GATEWAY_DEFAULT_MODEL_REF]?.alias ?? "Vercel AI Gateway",
|
|
};
|
|
|
|
return {
|
|
...cfg,
|
|
agents: {
|
|
...cfg.agents,
|
|
defaults: {
|
|
...cfg.agents?.defaults,
|
|
models,
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
export function applyCloudflareAiGatewayProviderConfig(
|
|
cfg: OpenClawConfig,
|
|
params?: { accountId?: string; gatewayId?: string },
|
|
): OpenClawConfig {
|
|
const models = { ...cfg.agents?.defaults?.models };
|
|
models[CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF] = {
|
|
...models[CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF],
|
|
alias: models[CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF]?.alias ?? "Cloudflare AI Gateway",
|
|
};
|
|
|
|
const providers = { ...cfg.models?.providers };
|
|
const existingProvider = providers["cloudflare-ai-gateway"];
|
|
const existingModels = Array.isArray(existingProvider?.models) ? existingProvider.models : [];
|
|
const defaultModel = buildCloudflareAiGatewayModelDefinition();
|
|
const hasDefaultModel = existingModels.some((model) => model.id === defaultModel.id);
|
|
const mergedModels = hasDefaultModel ? existingModels : [...existingModels, defaultModel];
|
|
const baseUrl =
|
|
params?.accountId && params?.gatewayId
|
|
? resolveCloudflareAiGatewayBaseUrl({
|
|
accountId: params.accountId,
|
|
gatewayId: params.gatewayId,
|
|
})
|
|
: existingProvider?.baseUrl;
|
|
|
|
if (!baseUrl) {
|
|
return {
|
|
...cfg,
|
|
agents: {
|
|
...cfg.agents,
|
|
defaults: {
|
|
...cfg.agents?.defaults,
|
|
models,
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
const { apiKey: existingApiKey, ...existingProviderRest } = (existingProvider ?? {}) as Record<
|
|
string,
|
|
unknown
|
|
> as { apiKey?: string };
|
|
const resolvedApiKey = typeof existingApiKey === "string" ? existingApiKey : undefined;
|
|
const normalizedApiKey = resolvedApiKey?.trim();
|
|
providers["cloudflare-ai-gateway"] = {
|
|
...existingProviderRest,
|
|
baseUrl,
|
|
api: "anthropic-messages",
|
|
...(normalizedApiKey ? { apiKey: normalizedApiKey } : {}),
|
|
models: mergedModels.length > 0 ? mergedModels : [defaultModel],
|
|
};
|
|
|
|
return {
|
|
...cfg,
|
|
agents: {
|
|
...cfg.agents,
|
|
defaults: {
|
|
...cfg.agents?.defaults,
|
|
models,
|
|
},
|
|
},
|
|
models: {
|
|
mode: cfg.models?.mode ?? "merge",
|
|
providers,
|
|
},
|
|
};
|
|
}
|
|
|
|
export function applyVercelAiGatewayConfig(cfg: OpenClawConfig): OpenClawConfig {
|
|
const next = applyVercelAiGatewayProviderConfig(cfg);
|
|
const existingModel = next.agents?.defaults?.model;
|
|
return {
|
|
...next,
|
|
agents: {
|
|
...next.agents,
|
|
defaults: {
|
|
...next.agents?.defaults,
|
|
model: {
|
|
...(existingModel && "fallbacks" in (existingModel as Record<string, unknown>)
|
|
? {
|
|
fallbacks: (existingModel as { fallbacks?: string[] }).fallbacks,
|
|
}
|
|
: undefined),
|
|
primary: VERCEL_AI_GATEWAY_DEFAULT_MODEL_REF,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
export function applyCloudflareAiGatewayConfig(
|
|
cfg: OpenClawConfig,
|
|
params?: { accountId?: string; gatewayId?: string },
|
|
): OpenClawConfig {
|
|
const next = applyCloudflareAiGatewayProviderConfig(cfg, params);
|
|
const existingModel = next.agents?.defaults?.model;
|
|
return {
|
|
...next,
|
|
agents: {
|
|
...next.agents,
|
|
defaults: {
|
|
...next.agents?.defaults,
|
|
model: {
|
|
...(existingModel && "fallbacks" in (existingModel as Record<string, unknown>)
|
|
? {
|
|
fallbacks: (existingModel as { fallbacks?: string[] }).fallbacks,
|
|
}
|
|
: undefined),
|
|
primary: CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
}
|