Gateway
Konfiguracja — narzędzia i niestandardowi dostawcy
tools.* klucze konfiguracji oraz niestandardowa konfiguracja dostawcy / bazowego adresu URL. Informacje o agentach, kanałach i innych kluczach konfiguracji najwyższego poziomu znajdziesz w referencji konfiguracji.
Narzędzia
Profile narzędzi
tools.profile ustawia bazową listę dozwolonych narzędzi przed tools.allow/tools.deny:
| Profil | Obejmuje |
|---|---|
minimal |
tylko session_status |
coding |
group:fs, group:runtime, group:web, group:sessions, group:memory, cron, image, image_generate, video_generate |
messaging |
group:messaging, sessions_list, sessions_history, sessions_send, session_status |
full |
Brak ograniczeń (tak samo jak brak ustawienia) |
Grupy narzędzi
| Grupa | Narzędzia |
|---|---|
group:runtime |
exec, process, code_execution (bash jest akceptowany jako alias dla exec) |
group:fs |
read, write, edit, apply_patch |
group:sessions |
sessions_list, sessions_history, sessions_send, sessions_spawn, sessions_yield, subagents, session_status |
group:memory |
memory_search, memory_get |
group:web |
web_search, x_search, web_fetch |
group:ui |
browser, canvas |
group:automation |
heartbeat_respond, cron, gateway |
group:messaging |
message |
group:nodes |
nodes |
group:agents |
agents_list, update_plan |
group:media |
image, image_generate, music_generate, video_generate, tts |
group:openclaw |
Wszystkie wbudowane narzędzia (z wyłączeniem Pluginów dostawców) |
tools.allow / tools.deny
Globalna polityka zezwalania/odmawiania narzędzi (odmowa ma pierwszeństwo). Nie rozróżnia wielkości liter, obsługuje symbole wieloznaczne *. Stosowana nawet wtedy, gdy sandbox Docker jest wyłączony.
{
tools: { deny: ["browser", "canvas"] },
}
write i apply_patch to oddzielne identyfikatory narzędzi. allow: ["write"] włącza też apply_patch dla zgodnych modeli, ale deny: ["write"] nie blokuje apply_patch. Aby zablokować wszystkie mutacje plików, odmów group:fs albo jawnie wymień każde narzędzie modyfikujące:
{
tools: { deny: ["write", "edit", "apply_patch"] },
}
tools.byProvider
Dodatkowo ogranicza narzędzia dla konkretnych dostawców lub modeli. Kolejność: profil bazowy → profil dostawcy → zezwalanie/odmawianie.
{
tools: {
profile: "coding",
byProvider: {
"google-antigravity": { profile: "minimal" },
"openai/gpt-5.4": { allow: ["group:fs", "sessions_list"] },
},
},
}
tools.elevated
Kontroluje podwyższony dostęp exec poza sandboxem:
{
tools: {
elevated: {
enabled: true,
allowFrom: {
whatsapp: ["+15555550123"],
discord: ["1234567890123", "987654321098765432"],
},
},
},
}
- Nadpisanie dla agenta (
agents.list[].tools.elevated) może tylko dodatkowo ograniczać. /elevated on|off|ask|fullzapisuje stan dla sesji; dyrektywy w treści dotyczą pojedynczej wiadomości.- Podwyższony
execomija sandboxing i używa skonfigurowanej ścieżki wyjścia (gatewaydomyślnie albonode, gdy celexectonode).
tools.exec
{
tools: {
exec: {
backgroundMs: 10000,
timeoutSec: 1800,
cleanupMs: 1800000,
notifyOnExit: true,
notifyOnExitEmptySuccess: false,
applyPatch: {
enabled: false,
allowModels: ["gpt-5.5"],
},
},
},
}
tools.loopDetection
Kontrole bezpieczeństwa pętli narzędzi są domyślnie wyłączone. Ustaw enabled: true, aby aktywować wykrywanie. Ustawienia można definiować globalnie w tools.loopDetection i nadpisywać dla agenta w agents.list[].tools.loopDetection.
{
tools: {
loopDetection: {
enabled: true,
historySize: 30,
warningThreshold: 10,
criticalThreshold: 20,
globalCircuitBreakerThreshold: 30,
detectors: {
genericRepeat: true,
knownPollNoProgress: true,
pingPong: true,
},
},
},
}
historySizenumberMaksymalna historia wywołań narzędzi zachowywana do analizy pętli.
warningThresholdnumberPróg powtarzającego się wzorca bez postępu dla ostrzeżeń.
criticalThresholdnumberWyższy próg powtórzeń do blokowania krytycznych pętli.
globalCircuitBreakerThresholdnumberPróg twardego zatrzymania dla dowolnego przebiegu bez postępu.
detectors.genericRepeatbooleanOstrzegaj o powtarzanych wywołaniach tego samego narzędzia z tymi samymi argumentami.
detectors.knownPollNoProgressbooleanOstrzegaj/blokuj dla znanych narzędzi odpytywania (process.poll, command_status itd.).
detectors.pingPongbooleanOstrzegaj/blokuj dla naprzemiennych wzorców par bez postępu.
tools.web
{
tools: {
web: {
search: {
enabled: true,
apiKey: "brave_api_key", // or BRAVE_API_KEY env
maxResults: 5,
timeoutSeconds: 30,
cacheTtlMinutes: 15,
},
fetch: {
enabled: true,
provider: "firecrawl", // optional; omit for auto-detect
maxChars: 50000,
maxCharsCap: 50000,
maxResponseBytes: 2000000,
timeoutSeconds: 30,
cacheTtlMinutes: 15,
maxRedirects: 3,
readability: true,
userAgent: "custom-ua",
},
},
},
}
tools.media
Konfiguruje rozumienie przychodzących multimediów (obraz/audio/wideo):
{
tools: {
media: {
concurrency: 2,
asyncCompletion: {
directSend: false, // deprecated: completions stay agent-mediated
},
audio: {
enabled: true,
maxBytes: 20971520,
scope: {
default: "deny",
rules: [{ action: "allow", match: { chatType: "direct" } }],
},
models: [
{ provider: "openai", model: "gpt-4o-mini-transcribe" },
{ type: "cli", command: "whisper", args: ["--model", "base", "{{MediaPath}}"] },
],
},
image: {
enabled: true,
timeoutSeconds: 180,
models: [{ provider: "ollama", model: "gemma4:26b", timeoutSeconds: 300 }],
},
video: {
enabled: true,
maxBytes: 52428800,
models: [{ provider: "google", model: "gemini-3-flash-preview" }],
},
},
},
}
Pola wpisu modelu multimediów
Wpis dostawcy (type: "provider" albo pominięte):
provider: identyfikator dostawcy API (openai,anthropic,google/gemini,groqitd.)model: nadpisanie identyfikatora modeluprofile/preferredProfile: wybór profiluauth-profiles.json
Wpis CLI (type: "cli"):
command: plik wykonywalny do uruchomieniaargs: argumenty szablonowe (obsługuje{{MediaPath}},{{Prompt}},{{MaxChars}}itd.;openclaw doctor --fixmigruje przestarzałe placeholdery{input}do{{MediaPath}})
Pola wspólne:
capabilities: opcjonalna lista (image,audio,video). Domyślnie:openai/anthropic/minimax→ obraz,google→ obraz+audio+wideo,groq→ audio.prompt,maxChars,maxBytes,timeoutSeconds,language: nadpisania dla pojedynczego wpisu.tools.media.image.timeoutSecondsoraz pasujące wpisytimeoutSecondsmodelu obrazu mają też zastosowanie, gdy agent wywołuje jawne narzędzieimage.- Niepowodzenia powodują przejście do następnego wpisu.
Uwierzytelnianie dostawcy stosuje standardową kolejność: auth-profiles.json → zmienne środowiskowe → models.providers.*.apiKey.
Pola ukończenia asynchronicznego:
asyncCompletion.directSend: przestarzała flaga zgodności. Ukończone asynchroniczne zadania multimedialne pozostają pośredniczone przez sesję żądającego, aby agent otrzymał wynik, zdecydował, jak przekazać go użytkownikowi, i użył narzędzia wiadomości, gdy wymaga tego dostarczenie ze źródła.
tools.agentToAgent
{
tools: {
agentToAgent: {
enabled: false,
allow: ["home", "work"],
},
},
}
tools.sessions
Kontroluje, które sesje mogą być celem narzędzi sesji (sessions_list, sessions_history, sessions_send).
Domyślnie: tree (bieżąca sesja + sesje przez nią utworzone, takie jak subagenci).
{
tools: {
sessions: {
// "self" | "tree" | "agent" | "all"
visibility: "tree",
},
},
}
Zakresy widoczności
self: tylko klucz bieżącej sesji.tree: bieżąca sesja + sesje utworzone przez bieżącą sesję (subagenci).agent: dowolna sesja należąca do bieżącego identyfikatora agenta (może obejmować innych użytkowników, jeśli uruchamiasz sesje dla poszczególnych nadawców pod tym samym identyfikatorem agenta).all: dowolna sesja. Kierowanie między agentami nadal wymagatools.agentToAgent.- Ograniczenie piaskownicy: gdy bieżąca sesja działa w piaskownicy i
agents.defaults.sandbox.sessionToolsVisibility="spawned", widoczność jest wymuszana natree, nawet jeślitools.sessions.visibility="all".
tools.sessions_spawn
Kontroluje obsługę załączników inline dla sessions_spawn.
{
tools: {
sessions_spawn: {
attachments: {
enabled: false, // opt-in: set true to allow inline file attachments
maxTotalBytes: 5242880, // 5 MB total across all files
maxFiles: 50,
maxFileBytes: 1048576, // 1 MB per file
retainOnSessionKeep: false, // keep attachments when cleanup="keep"
},
},
},
}
Uwagi dotyczące załączników
- Załączniki są obsługiwane tylko dla
runtime: "subagent". Środowisko uruchomieniowe ACP je odrzuca. - Pliki są materializowane w podrzędnym obszarze roboczym w
.openclaw/attachments/<uuid>/z plikiem.manifest.json. - Zawartość załączników jest automatycznie redagowana przy utrwalaniu transkrypcji.
- Dane wejściowe Base64 są weryfikowane za pomocą rygorystycznych kontroli alfabetu/dopełnienia oraz zabezpieczenia rozmiaru przed dekodowaniem.
- Uprawnienia plików to
0700dla katalogów i0600dla plików. - Czyszczenie jest zgodne z polityką
cleanup:deletezawsze usuwa załączniki;keepzachowuje je tylko wtedy, gdyretainOnSessionKeep: true.
tools.experimental
Eksperymentalne flagi wbudowanych narzędzi. Domyślnie wyłączone, chyba że ma zastosowanie reguła automatycznego włączania strict-agentic dla GPT-5.
{
tools: {
experimental: {
planTool: true, // enable experimental update_plan
},
},
}
planTool: włącza strukturalne narzędzieupdate_plando śledzenia nietrywialnej pracy wieloetapowej.- Domyślnie:
false, chyba żeagents.defaults.embeddedPi.executionContract(lub nadpisanie dla konkretnego agenta) ma wartość"strict-agentic"dla uruchomienia z rodziny OpenAI lub OpenAI Codex GPT-5. Ustawtrue, aby wymusić włączenie narzędzia poza tym zakresem, albofalse, aby pozostawić je wyłączone nawet dla uruchomień strict-agentic GPT-5. - Po włączeniu prompt systemowy dodaje także wskazówki użycia, aby model korzystał z niego tylko przy większej pracy i utrzymywał najwyżej jeden krok
in_progress.
agents.defaults.subagents
{
agents: {
defaults: {
subagents: {
allowAgents: ["research"],
model: "minimax/MiniMax-M2.7",
maxConcurrent: 8,
runTimeoutSeconds: 900,
archiveAfterMinutes: 60,
},
},
},
}
model: domyślny model dla uruchamianych subagentów. Jeśli pominięty, subagenci dziedziczą model wywołującego.allowAgents: domyślna lista dozwolonych identyfikatorów agentów docelowych dlasessions_spawn, gdy agent żądający nie ustawia własnegosubagents.allowAgents(["*"]= dowolny; domyślnie: tylko ten sam agent).runTimeoutSeconds: domyślny limit czasu (w sekundach) dlasessions_spawn, gdy wywołanie narzędzia pomijarunTimeoutSeconds.0oznacza brak limitu czasu.- Polityka narzędzi dla subagenta:
tools.subagents.tools.allow/tools.subagents.tools.deny.
Niestandardowi dostawcy i bazowe adresy URL
OpenClaw używa wbudowanego katalogu modeli. Dodaj niestandardowych dostawców przez models.providers w konfiguracji albo ~/.openclaw/agents/<agentId>/agent/models.json.
{
models: {
mode: "merge", // merge (default) | replace
providers: {
"custom-proxy": {
baseUrl: "http://localhost:4000/v1",
apiKey: "LITELLM_KEY",
api: "openai-completions", // openai-completions | openai-responses | anthropic-messages | google-generative-ai
models: [
{
id: "llama-3.1-8b",
name: "Llama 3.1 8B",
reasoning: false,
input: ["text"],
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
contextWindow: 128000,
contextTokens: 96000,
maxTokens: 32000,
},
],
},
},
},
}
Uwierzytelnianie i pierwszeństwo scalania
- Użyj
authHeader: true+headersw przypadku niestandardowych potrzeb uwierzytelniania. - Nadpisz katalog główny konfiguracji agenta za pomocą
OPENCLAW_AGENT_DIR(alboPI_CODING_AGENT_DIR, starszego aliasu zmiennej środowiskowej). - Pierwszeństwo scalania dla pasujących identyfikatorów dostawców:
- Niepuste wartości
baseUrlwmodels.jsonagenta wygrywają. - Niepuste wartości
apiKeyagenta wygrywają tylko wtedy, gdy ten dostawca nie jest zarządzany przez SecretRef w bieżącym kontekście konfiguracji/profilu uwierzytelniania. - Wartości
apiKeydostawcy zarządzane przez SecretRef są odświeżane ze znaczników źródłowych (ENV_VAR_NAMEdla odwołań do zmiennych środowiskowych,secretref-manageddla odwołań do plików/wykonań), zamiast utrwalać rozwiązane sekrety. - Wartości nagłówków dostawcy zarządzane przez SecretRef są odświeżane ze znaczników źródłowych (
secretref-env:ENV_VAR_NAMEdla odwołań do zmiennych środowiskowych,secretref-manageddla odwołań do plików/wykonań). - Puste lub brakujące
apiKey/baseUrlagenta korzystają z wartości zastępczych zmodels.providersw konfiguracji. - Pasujące
contextWindow/maxTokensmodelu używają wyższej wartości między jawną konfiguracją a niejawnymi wartościami katalogu. - Pasujące
contextTokensmodelu zachowuje jawny limit środowiska uruchomieniowego, gdy jest obecny; użyj go, aby ograniczyć efektywny kontekst bez zmiany natywnych metadanych modelu. - Użyj
models.mode: "replace", gdy chcesz, aby konfiguracja w pełni przepisałamodels.json. - Utrwalanie znaczników jest autorytatywne względem źródła: znaczniki są zapisywane z aktywnej migawki konfiguracji źródłowej (przed rozwiązaniem), a nie z rozwiązanych wartości sekretów środowiska uruchomieniowego.
- Niepuste wartości
Szczegóły pól dostawcy
Katalog najwyższego poziomu
models.mode: zachowanie katalogu dostawców (mergealboreplace).models.providers: mapa niestandardowych dostawców indeksowana identyfikatorem dostawcy.- Bezpieczne edycje: użyj
openclaw config set models.providers.<id> '<json>' --strict-json --mergealboopenclaw config set models.providers.<id>.models '<json-array>' --strict-json --mergedo aktualizacji addytywnych.config setodmawia destrukcyjnych zastąpień, chyba że przekażesz--replace.
- Bezpieczne edycje: użyj
Połączenie z dostawcą i uwierzytelnianie
models.providers.*.api: adapter żądań (openai-completions,openai-responses,anthropic-messages,google-generative-aiitd.). Dla samodzielnie hostowanych backendów/v1/chat/completions, takich jak MLX, vLLM, SGLang i większość lokalnych serwerów zgodnych z OpenAI, użyjopenai-completions. Niestandardowy dostawca zbaseUrl, ale bezapi, domyślnie używaopenai-completions; ustawopenai-responsestylko wtedy, gdy backend obsługuje/v1/responses.models.providers.*.apiKey: dane uwierzytelniające dostawcy (preferuj SecretRef/podstawienie ze zmiennych środowiskowych).models.providers.*.auth: strategia uwierzytelniania (api-key,token,oauth,aws-sdk).models.providers.*.contextWindow: domyślne natywne okno kontekstu dla modeli u tego dostawcy, gdy wpis modelu nie ustawiacontextWindow.models.providers.*.contextTokens: domyślny efektywny limit kontekstu środowiska uruchomieniowego dla modeli u tego dostawcy, gdy wpis modelu nie ustawiacontextTokens.models.providers.*.maxTokens: domyślny limit tokenów wyjściowych dla modeli u tego dostawcy, gdy wpis modelu nie ustawiamaxTokens.models.providers.*.timeoutSeconds: opcjonalny limit czasu żądania HTTP modelu dla konkretnego dostawcy, w sekundach, obejmujący połączenie, nagłówki, treść i całkowitą obsługę przerwania żądania.models.providers.*.injectNumCtxForOpenAICompat: dla Ollama +openai-completionswstrzykujeoptions.num_ctxdo żądań (domyślnie:true).models.providers.*.authHeader: wymusza transport danych uwierzytelniających w nagłówkuAuthorization, gdy jest wymagany.models.providers.*.baseUrl: bazowy adres URL upstream API.models.providers.*.headers: dodatkowe statyczne nagłówki do trasowania proxy/dzierżawcy.
Nadpisania transportu żądań
models.providers.*.request: nadpisania transportu dla żądań HTTP dostawcy modeli.
request.headers: dodatkowe nagłówki (scalane z wartościami domyślnymi dostawcy). Wartości akceptują SecretRef.request.auth: nadpisanie strategii uwierzytelniania. Tryby:"provider-default"(użyj wbudowanego uwierzytelniania dostawcy),"authorization-bearer"(ztoken),"header"(zheaderName,value, opcjonalnymprefix).request.proxy: nadpisanie proxy HTTP. Tryby:"env-proxy"(użyj zmiennych środowiskowychHTTP_PROXY/HTTPS_PROXY),"explicit-proxy"(zurl). Oba tryby akceptują opcjonalny podobiekttls.request.tls: nadpisanie TLS dla połączeń bezpośrednich. Pola:ca,cert,key,passphrase(wszystkie akceptują SecretRef),serverName,insecureSkipVerify.request.allowPrivateNetwork: gdytrue, zezwala na HTTPS dobaseUrl, gdy DNS rozwiązuje się do zakresów prywatnych, CGNAT lub podobnych, przez zabezpieczenie fetch HTTP dostawcy (operatorska zgoda dla zaufanych, samodzielnie hostowanych endpointów zgodnych z OpenAI). Adresy URL strumieni dostawcy modeli w local loopback, takie jaklocalhost,127.0.0.1i[::1], są dozwolone automatycznie, chyba że jawnie ustawiono to nafalse; hosty LAN, tailnet i prywatne hosty DNS nadal wymagają zgody. WebSocket używa tego samegorequestdla nagłówków/TLS, ale nie tej bramki SSRF fetch. Domyślniefalse.
Wpisy katalogu modeli
models.providers.*.models: jawne wpisy katalogu modeli dostawcy.models.providers.*.models.*.input: modalności wejściowe modelu. Użyj["text"]dla modeli wyłącznie tekstowych i["text", "image"]dla natywnych modeli obrazu/wizji. Załączniki obrazów są wstrzykiwane do tur agenta tylko wtedy, gdy wybrany model jest oznaczony jako obsługujący obrazy.models.providers.*.models.*.contextWindow: metadane natywnego okna kontekstu modelu. To nadpisujecontextWindowna poziomie dostawcy dla tego modelu.models.providers.*.models.*.contextTokens: opcjonalny limit kontekstu środowiska uruchomieniowego. To nadpisujecontextTokensna poziomie dostawcy; użyj tego, gdy chcesz mniejszego efektywnego budżetu kontekstu niż natywnecontextWindowmodelu;openclaw models listpokazuje obie wartości, gdy się różnią.models.providers.*.models.*.compat.supportsDeveloperRole: opcjonalna wskazówka zgodności. Dlaapi: "openai-completions"z niepustym nienatywnymbaseUrl(host inny niżapi.openai.com) OpenClaw wymusza w środowisku uruchomieniowym wartośćfalse. Puste/pominiętebaseUrlzachowuje domyślne zachowanie OpenAI.models.providers.*.models.*.compat.requiresStringContent: opcjonalna wskazówka zgodności dla wyłącznie tekstowych endpointów czatu zgodnych z OpenAI. Gdytrue, OpenClaw spłaszcza czysto tekstowe tablicemessages[].contentdo zwykłych ciągów znaków przed wysłaniem żądania.
Wykrywanie Amazon Bedrock
plugins.entries.amazon-bedrock.config.discovery: katalog główny ustawień automatycznego wykrywania Bedrock.plugins.entries.amazon-bedrock.config.discovery.enabled: włączanie/wyłączanie niejawnego wykrywania.plugins.entries.amazon-bedrock.config.discovery.region: region AWS do wykrywania.plugins.entries.amazon-bedrock.config.discovery.providerFilter: opcjonalny filtr identyfikatora dostawcy do ukierunkowanego wykrywania.plugins.entries.amazon-bedrock.config.discovery.refreshInterval: interwał odpytywania do odświeżania wykrywania.plugins.entries.amazon-bedrock.config.discovery.defaultContextWindow: zastępcze okno kontekstu dla wykrytych modeli.plugins.entries.amazon-bedrock.config.discovery.defaultMaxTokens: zastępczy maksymalny limit tokenów wyjściowych dla wykrytych modeli.
Interaktywne wdrażanie niestandardowego dostawcy wnioskuje wejście obrazowe dla typowych identyfikatorów modeli wizyjnych, takich jak GPT-4o, Claude, Gemini, Qwen-VL, LLaVA, Pixtral, InternVL, Mllama, MiniCPM-V i GLM-4V, oraz pomija dodatkowe pytanie dla znanych rodzin wyłącznie tekstowych. Nieznane identyfikatory modeli nadal pytają o obsługę obrazów. Nieinteraktywne wdrażanie używa tego samego wnioskowania; przekaż --custom-image-input, aby wymusić metadane obsługujące obrazy, albo --custom-text-input, aby wymusić metadane wyłącznie tekstowe.
Przykłady dostawców
Cerebras (GLM 4.7 / GPT OSS)
Dołączony Plugin dostawcy cerebras może skonfigurować to przez openclaw onboard --auth-choice cerebras-api-key. Używaj jawnej konfiguracji dostawcy tylko podczas nadpisywania wartości domyślnych.
{
env: { CEREBRAS_API_KEY: "sk-..." },
agents: {
defaults: {
model: {
primary: "cerebras/zai-glm-4.7",
fallbacks: ["cerebras/gpt-oss-120b"],
},
models: {
"cerebras/zai-glm-4.7": { alias: "GLM 4.7 (Cerebras)" },
"cerebras/gpt-oss-120b": { alias: "GPT OSS 120B (Cerebras)" },
},
},
},
models: {
mode: "merge",
providers: {
cerebras: {
baseUrl: "https://api.cerebras.ai/v1",
apiKey: "${CEREBRAS_API_KEY}",
api: "openai-completions",
models: [
{ id: "zai-glm-4.7", name: "GLM 4.7 (Cerebras)" },
{ id: "gpt-oss-120b", name: "GPT OSS 120B (Cerebras)" },
],
},
},
},
}
Użyj cerebras/zai-glm-4.7 dla Cerebras; zai/glm-4.7 dla bezpośredniego Z.AI.
Kimi Coding
{
env: { KIMI_API_KEY: "sk-..." },
agents: {
defaults: {
model: { primary: "kimi/kimi-code" },
models: { "kimi/kimi-code": { alias: "Kimi Code" } },
},
},
}
Wbudowany Provider zgodny z Anthropic. Skrót: openclaw onboard --auth-choice kimi-code-api-key.
Local models (LM Studio)
Zobacz Modele lokalne. W skrócie: uruchom duży model lokalny przez LM Studio Responses API na wydajnym sprzęcie; zachowaj scalone modele hostowane jako fallback.
MiniMax M2.7 (direct)
{
agents: {
defaults: {
model: { primary: "minimax/MiniMax-M2.7" },
models: {
"minimax/MiniMax-M2.7": { alias: "Minimax" },
},
},
},
models: {
mode: "merge",
providers: {
minimax: {
baseUrl: "https://api.minimax.io/anthropic",
apiKey: "${MINIMAX_API_KEY}",
api: "anthropic-messages",
models: [
{
id: "MiniMax-M2.7",
name: "MiniMax M2.7",
reasoning: true,
input: ["text"],
cost: { input: 0.3, output: 1.2, cacheRead: 0.06, cacheWrite: 0.375 },
contextWindow: 204800,
maxTokens: 131072,
},
],
},
},
},
}
Ustaw MINIMAX_API_KEY. Skróty: openclaw onboard --auth-choice minimax-global-api lub openclaw onboard --auth-choice minimax-cn-api. Katalog modeli domyślnie zawiera tylko M2.7. Na ścieżce streamingu zgodnej z Anthropic OpenClaw domyślnie wyłącza myślenie MiniMax, chyba że jawnie ustawisz thinking samodzielnie. /fast on lub params.fastMode: true przepisuje MiniMax-M2.7 na MiniMax-M2.7-highspeed.
Moonshot AI (Kimi)
{
env: { MOONSHOT_API_KEY: "sk-..." },
agents: {
defaults: {
model: { primary: "moonshot/kimi-k2.6" },
models: { "moonshot/kimi-k2.6": { alias: "Kimi K2.6" } },
},
},
models: {
mode: "merge",
providers: {
moonshot: {
baseUrl: "https://api.moonshot.ai/v1",
apiKey: "${MOONSHOT_API_KEY}",
api: "openai-completions",
models: [
{
id: "kimi-k2.6",
name: "Kimi K2.6",
reasoning: false,
input: ["text", "image"],
cost: { input: 0.95, output: 4, cacheRead: 0.16, cacheWrite: 0 },
contextWindow: 262144,
maxTokens: 262144,
},
],
},
},
},
}
Dla punktu końcowego w Chinach: baseUrl: "https://api.moonshot.cn/v1" lub openclaw onboard --auth-choice moonshot-api-key-cn.
Natywne punkty końcowe Moonshot deklarują zgodność użycia streamingu na współdzielonym transporcie openai-completions, a OpenClaw opiera to na możliwościach punktu końcowego, nie tylko na identyfikatorze wbudowanego dostawcy.
OpenCode
{
agents: {
defaults: {
model: { primary: "opencode/claude-opus-4-6" },
models: { "opencode/claude-opus-4-6": { alias: "Opus" } },
},
},
}
Ustaw OPENCODE_API_KEY (lub OPENCODE_ZEN_API_KEY). Użyj odwołań opencode/... dla katalogu Zen albo odwołań opencode-go/... dla katalogu Go. Skrót: openclaw onboard --auth-choice opencode-zen lub openclaw onboard --auth-choice opencode-go.
Synthetic (Anthropic-compatible)
{
env: { SYNTHETIC_API_KEY: "sk-..." },
agents: {
defaults: {
model: { primary: "synthetic/hf:MiniMaxAI/MiniMax-M2.5" },
models: { "synthetic/hf:MiniMaxAI/MiniMax-M2.5": { alias: "MiniMax M2.5" } },
},
},
models: {
mode: "merge",
providers: {
synthetic: {
baseUrl: "https://api.synthetic.new/anthropic",
apiKey: "${SYNTHETIC_API_KEY}",
api: "anthropic-messages",
models: [
{
id: "hf:MiniMaxAI/MiniMax-M2.5",
name: "MiniMax M2.5",
reasoning: true,
input: ["text"],
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
contextWindow: 192000,
maxTokens: 65536,
},
],
},
},
},
}
Bazowy URL powinien pomijać /v1 (klient Anthropic dodaje go). Skrót: openclaw onboard --auth-choice synthetic-api-key.
Z.AI (GLM-4.7)
{
agents: {
defaults: {
model: { primary: "zai/glm-4.7" },
models: { "zai/glm-4.7": {} },
},
},
}
Ustaw ZAI_API_KEY. z.ai/* i z-ai/* są akceptowanymi aliasami. Skrót: openclaw onboard --auth-choice zai-api-key.
- Ogólny punkt końcowy:
https://api.z.ai/api/paas/v4 - Punkt końcowy do kodowania (domyślny):
https://api.z.ai/api/coding/paas/v4 - Dla ogólnego punktu końcowego zdefiniuj niestandardowego providera z nadpisaniem bazowego URL.
Powiązane
- Konfiguracja — agenci
- Konfiguracja — kanały
- Odwołanie do konfiguracji — inne klucze najwyższego poziomu
- Narzędzia i pluginy