mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 05:30:42 +00:00
* feat(nvidia): add NVIDIA provider with onboarding flow Add the NVIDIA build.nvidia.com API as a bundled provider. Default model is nvidia/nvidia/nemotron-3-super-120b-a12b: first segment is the provider id, remaining "nvidia/nemotron-3-super-120b-a12b" is the literal upstream model id (which happens to start with "nvidia/" because NVIDIA is also the model maker). Supporting core change: introduce a provider capability flag nativeIdsIncludeProviderPrefix so providers whose native catalog ids intentionally include their provider prefix (OpenRouter) opt into self-prefix dedupe in modelKey, without hardcoding provider names in core. Providers whose ids merely happen to start with their own name (NVIDIA) leave the flag unset and get the full <provider>/<model-id> concatenation. - extensions/nvidia/*: new plugin, catalog, onboarding, tests, docs - extensions/openrouter/index.ts: declare nativeIdsIncludeProviderPrefix - src/plugins/types.ts: add field to ProviderPlugin - src/plugins/registry.ts: populate self-prefix set on registration - src/agents/provider-self-prefix.ts: sync accessor used by modelKey - src/agents/model-ref-shared.ts: modelKey consults the flag - test updates for affected surfaces Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com> * refactor(model-picker): simplify literal-prefix display to label-only * fix(model-picker): pass workspaceDir/env to allowlist literal-prefix resolution * chore: untrack generated baseline JSON artifacts (gitignored) * fix(nvidia): show literal model ref in picker and onboarding notes * fix(nvidia): show hint whenever display label differs from stored config * fix(nvidia): drop redundant hint from Keep current label * fix(nvidia): restore literal double-prefix display labels * fix(picker): handle literal-prefix fast path * fix(picker): show literal keep label * fix(docs): update nvidia provider docs * fix(nvidia): update test helper imports * fix(changelog): add nvidia provider entry --------- Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
65 lines
1.8 KiB
TypeScript
65 lines
1.8 KiB
TypeScript
import { defineSingleProviderPluginEntry } from "openclaw/plugin-sdk/provider-entry";
|
|
import { applyNvidiaConfig, NVIDIA_DEFAULT_MODEL_REF } from "./onboard.js";
|
|
import { buildNvidiaProvider } from "./provider-catalog.js";
|
|
|
|
const PROVIDER_ID = "nvidia";
|
|
|
|
function buildNvidiaCatalogModels() {
|
|
return buildNvidiaProvider().models.map((model) => ({
|
|
provider: PROVIDER_ID,
|
|
id: model.id,
|
|
name: model.name ?? model.id,
|
|
contextWindow: model.contextWindow,
|
|
reasoning: model.reasoning,
|
|
input: model.input,
|
|
}));
|
|
}
|
|
|
|
export default defineSingleProviderPluginEntry({
|
|
id: PROVIDER_ID,
|
|
name: "NVIDIA Provider",
|
|
description: "Bundled NVIDIA provider plugin",
|
|
provider: {
|
|
label: "NVIDIA",
|
|
docsPath: "/providers/nvidia",
|
|
envVars: ["NVIDIA_API_KEY"],
|
|
preserveLiteralProviderPrefix: true,
|
|
auth: [
|
|
{
|
|
methodId: "api-key",
|
|
label: "NVIDIA API key",
|
|
hint: "Direct API key",
|
|
optionKey: "nvidiaApiKey",
|
|
flagName: "--nvidia-api-key",
|
|
envVar: "NVIDIA_API_KEY",
|
|
promptMessage: "Enter NVIDIA API key",
|
|
defaultModel: NVIDIA_DEFAULT_MODEL_REF,
|
|
applyConfig: applyNvidiaConfig,
|
|
},
|
|
],
|
|
catalog: {
|
|
buildProvider: buildNvidiaProvider,
|
|
},
|
|
augmentModelCatalog: buildNvidiaCatalogModels,
|
|
wizard: {
|
|
setup: {
|
|
choiceId: "nvidia-api-key",
|
|
choiceLabel: "NVIDIA API key",
|
|
groupId: "nvidia",
|
|
groupLabel: "NVIDIA",
|
|
groupHint: "Direct API key",
|
|
methodId: "api-key",
|
|
modelSelection: {
|
|
promptWhenAuthChoiceProvided: true,
|
|
allowKeepCurrent: false,
|
|
},
|
|
},
|
|
modelPicker: {
|
|
label: "NVIDIA (custom)",
|
|
hint: "Use NVIDIA-hosted open models",
|
|
methodId: "api-key",
|
|
},
|
|
},
|
|
},
|
|
});
|