Este guia percorre a criação de um Plugin de provedor que adiciona um provedor de modelo (LLM) ao OpenClaw. Ao final, você terá um provedor com um catálogo de modelos, autenticação por chave de API e resolução dinâmica de modelos.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Se você ainda não criou nenhum Plugin do OpenClaw, leia
Primeiros passos primeiro para entender a estrutura básica do pacote
e a configuração do manifesto.
Passo a passo
Pacote e manifesto
Etapa 1: Pacote e manifesto
providerAuthEnvVars para que o OpenClaw consiga detectar
credenciais sem carregar o runtime do seu Plugin. Adicione providerAuthAliases
quando uma variante de provedor deve reutilizar a autenticação do ID de outro provedor. modelSupport
é opcional e permite que o OpenClaw carregue automaticamente seu Plugin de provedor a partir de
IDs de modelo abreviados como acme-large antes que existam hooks de runtime. Se você publicar o
provedor no ClawHub, esses campos openclaw.compat e openclaw.build
serão obrigatórios em package.json.Registre o provedor
Um provedor de texto mínimo precisa de
id, label, auth e catalog.
catalog é o hook de runtime/configuração pertencente ao provedor; ele pode chamar APIs
de fornecedores ao vivo e retorna entradas models.providers.index.ts
registerModelCatalogProvider é a superfície de catálogo de plano de controle mais recente
para IU de lista/ajuda/seletor. Use-a para linhas de texto, geração de imagem,
geração de vídeo e geração de música. Mantenha as chamadas aos endpoints do fornecedor e o
mapeamento de respostas no Plugin; o OpenClaw controla o formato compartilhado das linhas, os rótulos
de origem e a renderização de ajuda.Isso é um provedor funcional. Os usuários agora podem executar
openclaw onboard --acme-ai-api-key <key> e selecionar
acme-ai/acme-large como modelo.Se o provedor upstream usar tokens de controle diferentes dos do OpenClaw, adicione uma
pequena transformação bidirecional de texto em vez de substituir o caminho de stream:input reescreve o prompt de sistema final e o conteúdo das mensagens de texto antes
do transporte. output reescreve deltas de texto do assistente e o texto final antes que
o OpenClaw analise seus próprios marcadores de controle ou a entrega pelo canal.Para provedores incluídos que registram apenas um provedor de texto com autenticação por chave de API
mais um único runtime respaldado por catálogo, prefira o helper mais restrito
defineSingleProviderPluginEntry(...):buildProvider é o caminho de catálogo ao vivo usado quando o OpenClaw consegue resolver a
autenticação real do provedor. Ele pode executar descoberta específica do provedor. Use
buildStaticProvider apenas para linhas offline que sejam seguras para exibir antes que a autenticação
seja configurada; ele não deve exigir credenciais nem fazer solicitações de rede.
A exibição models list --all do OpenClaw atualmente executa catálogos estáticos
apenas para Plugins de provedor incluídos, com configuração vazia, env vazio e nenhum
caminho de agente/workspace.Se seu fluxo de autenticação também precisar corrigir models.providers.*, aliases e
o modelo padrão do agente durante o onboarding, use os helpers de preset de
openclaw/plugin-sdk/provider-onboard. Os helpers mais restritos são
createDefaultModelPresetAppliers(...),
createDefaultModelsPresetAppliers(...) e
createModelCatalogPresetAppliers(...).Quando o endpoint nativo de um provedor oferecer suporte a blocos de uso transmitidos por stream no
transporte normal openai-completions, prefira os helpers de catálogo compartilhados em
openclaw/plugin-sdk/provider-catalog-shared em vez de codificar verificações
de IDs de provedor. supportsNativeStreamingUsageCompat(...) e
applyProviderNativeStreamingUsageCompat(...) detectam suporte a partir do
mapa de capacidades do endpoint, então endpoints nativos no estilo Moonshot/DashScope ainda
optam por participar mesmo quando um Plugin está usando um ID de provedor personalizado.Adicione resolução dinâmica de modelos
Se seu provedor aceitar IDs de modelo arbitrários (como um proxy ou roteador),
adicione Se a resolução exigir uma chamada de rede, use
resolveDynamicModel:prepareDynamicModel para aquecimento assíncronoresolveDynamicModelexecuta novamente depois que ela é concluída.
Adicione hooks de runtime (conforme necessário)
A maioria dos provedores precisa apenas de Famílias de replay disponíveis hoje:
Famílias de fluxo disponíveis hoje:
catalog + resolveDynamicModel. Adicione hooks
incrementalmente conforme seu provedor precisar deles.Os builders de helpers compartilhados agora cobrem as famílias mais comuns de replay/compatibilidade
de ferramentas, então os Plugins geralmente não precisam conectar manualmente cada hook, um por um:| Família | O que ela conecta | Exemplos incluídos |
|---|---|---|
openai-compatible | Política compartilhada de repetição no estilo OpenAI para transportes compatíveis com OpenAI, incluindo sanitização de ids de chamadas de ferramenta, correções de ordenação com assistente primeiro e validação genérica de turnos do Gemini quando o transporte precisa disso | moonshot, ollama, xai, zai |
anthropic-by-model | Política de repetição ciente do Claude escolhida por modelId, para que transportes de mensagens da Anthropic recebam limpeza de blocos de pensamento específica do Claude somente quando o modelo resolvido for de fato um id do Claude | amazon-bedrock, anthropic-vertex |
google-gemini | Política de repetição nativa do Gemini mais sanitização de repetição de bootstrap e modo de saída de raciocínio marcada | google, google-gemini-cli |
passthrough-gemini | Sanitização de assinatura de pensamento do Gemini para modelos Gemini executados por transportes proxy compatíveis com OpenAI; não habilita validação de repetição nativa do Gemini nem reescritas de bootstrap | openrouter, kilocode, opencode, opencode-go |
hybrid-anthropic-openai | Política híbrida para provedores que misturam superfícies de modelo de mensagens da Anthropic e compatíveis com OpenAI em um Plugin; a remoção opcional de blocos de pensamento apenas do Claude permanece limitada ao lado Anthropic | minimax |
| Família | O que ela conecta | Exemplos incluídos |
|---|---|---|
google-thinking | Normalização de payload de pensamento do Gemini no caminho de fluxo compartilhado | google, google-gemini-cli |
kilocode-thinking | Wrapper de raciocínio do Kilo no caminho de fluxo proxy compartilhado, com kilo/auto e ids de raciocínio proxy sem suporte ignorando pensamento injetado | kilocode |
moonshot-thinking | Mapeamento de payload de pensamento nativo binário do Moonshot a partir da configuração + nível /think | moonshot |
minimax-fast-mode | Reescrita de modelo de modo rápido MiniMax no caminho de fluxo compartilhado | minimax, minimax-portal |
openai-responses-defaults | Wrappers compartilhados nativos de Responses da OpenAI/Codex: cabeçalhos de atribuição, /fast/serviceTier, verbosidade de texto, pesquisa web nativa do Codex, formatação de payload de compatibilidade de raciocínio e gerenciamento de contexto de Responses | openai, openai-codex |
openrouter-thinking | Wrapper de raciocínio do OpenRouter para rotas proxy, com ignoros de modelo sem suporte/auto tratados centralmente | openrouter |
tool-stream-default-on | Wrapper tool_stream ativado por padrão para provedores como Z.AI que querem streaming de ferramenta salvo quando explicitamente desabilitado | zai |
Interfaces SDK que alimentam os construtores de família
Interfaces SDK que alimentam os construtores de família
Cada construtor de família é composto a partir de auxiliares públicos de nível mais baixo exportados pelo mesmo pacote, que você pode usar quando um provedor precisa sair do padrão comum:
openclaw/plugin-sdk/provider-model-shared-ProviderReplayFamily,buildProviderReplayFamilyHooks(...)e os construtores brutos de repetição (buildOpenAICompatibleReplayPolicy,buildAnthropicReplayPolicyForModel,buildGoogleGeminiReplayPolicy,buildHybridAnthropicOrOpenAIReplayPolicy). Também exporta auxiliares de repetição do Gemini (sanitizeGoogleGeminiReplayHistory,resolveTaggedReasoningOutputMode) e auxiliares de endpoint/modelo (resolveProviderEndpoint,normalizeProviderId,normalizeGooglePreviewModelId).openclaw/plugin-sdk/provider-stream-ProviderStreamFamily,buildProviderStreamFamilyHooks(...),composeProviderStreamWrappers(...), mais os wrappers compartilhados da OpenAI/Codex (createOpenAIAttributionHeadersWrapper,createOpenAIFastModeWrapper,createOpenAIServiceTierWrapper,createOpenAIResponsesContextManagementWrapper,createCodexNativeWebSearchWrapper), wrapper compatível com OpenAI do DeepSeek V4 (createDeepSeekV4OpenAICompatibleThinkingWrapper), limpeza de preenchimento antecipado de pensamento de Anthropic Messages (createAnthropicThinkingPrefillPayloadWrapper) e wrappers compartilhados de proxy/provedor (createOpenRouterWrapper,createToolStreamWrapper,createMinimaxFastModeWrapper).openclaw/plugin-sdk/provider-tools-ProviderToolCompatFamily,buildProviderToolCompatFamilyHooks("gemini")e auxiliares subjacentes de schema do Gemini (normalizeGeminiToolSchemas,inspectGeminiToolSchemas).
@openclaw/anthropic-provider mantém wrapAnthropicProviderStream, resolveAnthropicBetas, resolveAnthropicFastMode, resolveAnthropicServiceTier e os construtores de wrapper Anthropic de nível mais baixo em sua própria interface pública api.ts / contract-api.ts porque eles codificam o tratamento beta de OAuth do Claude e o controle de context1m. O Plugin xAI, de modo semelhante, mantém a formatação nativa de Responses xAI em seu próprio wrapStreamFn (aliases de /fast, tool_stream padrão, limpeza de ferramenta estrita sem suporte, remoção de payload de raciocínio específica da xAI).O mesmo padrão de raiz de pacote também sustenta @openclaw/openai-provider (construtores de provedor, auxiliares de modelo padrão, construtores de provedor em tempo real) e @openclaw/openrouter-provider (construtor de provedor mais auxiliares de integração/configuração).- Troca de token
- Cabeçalhos personalizados
- Identidade nativa do transporte
- Uso e cobrança
Para provedores que precisam de uma troca de token antes de cada chamada de inferência:
Todos os ganchos de provedor disponíveis
Todos os ganchos de provedor disponíveis
OpenClaw chama os ganchos nesta ordem. A maioria dos provedores usa apenas 2-3:
Campos de provedor somente para compatibilidade que o OpenClaw não chama mais, como
Observações sobre fallback de runtime:
ProviderPlugin.capabilities e suppressBuiltInModel, não estão listados
aqui.| # | Gancho | Quando usar |
|---|---|---|
| 1 | catalog | Catálogo de modelos ou padrões de URL base |
| 2 | applyConfigDefaults | Padrões globais pertencentes ao provedor durante a materialização da configuração |
| 3 | normalizeModelId | Limpeza de aliases legados/de pré-visualização de id de modelo antes da busca |
| 4 | normalizeTransport | Limpeza de api / baseUrl de família de provedor antes da montagem genérica do modelo |
| 5 | normalizeConfig | Normalizar configuração models.providers.<id> |
| 6 | applyNativeStreamingUsageCompat | Reescritas de compatibilidade de uso de streaming nativo para provedores de configuração |
| 7 | resolveConfigApiKey | Resolução de autenticação por marcador de env pertencente ao provedor |
| 8 | resolveSyntheticAuth | Autenticação sintética local/auto-hospedada ou apoiada por configuração |
| 9 | shouldDeferSyntheticProfileAuth | Rebaixar placeholders sintéticos de perfil armazenado atrás de autenticação por env/configuração |
| 10 | resolveDynamicModel | Aceitar ids arbitrários de modelos upstream |
| 11 | prepareDynamicModel | Busca assíncrona de metadados antes da resolução |
| 12 | normalizeResolvedModel | Reescritas de transporte antes do executor |
| 13 | contributeResolvedModelCompat | Flags de compatibilidade para modelos de fornecedor por trás de outro transporte compatível |
| 14 | normalizeToolSchemas | Limpeza de schema de ferramentas pertencente ao provedor antes do registro |
| 15 | inspectToolSchemas | Diagnósticos de schema de ferramentas pertencentes ao provedor |
| 16 | resolveReasoningOutputMode | Contrato de saída de raciocínio marcada vs nativa |
| 17 | prepareExtraParams | Parâmetros de requisição padrão |
| 18 | createStreamFn | Transporte StreamFn totalmente personalizado |
| 19 | wrapStreamFn | Wrappers personalizados de cabeçalhos/corpo no caminho de fluxo normal |
| 20 | resolveTransportTurnState | Cabeçalhos/metadados nativos por turno |
| 21 | resolveWebSocketSessionPolicy | Cabeçalhos/cool-down nativos de sessão WS |
| 22 | formatApiKey | Formato personalizado de token de runtime |
| 23 | refreshOAuth | Atualização OAuth personalizada |
| 24 | buildAuthDoctorHint | Orientação de reparo de autenticação |
| 25 | matchesContextOverflowError | Detecção de estouro pertencente ao provedor |
| 26 | classifyFailoverReason | Classificação de limite de taxa/sobrecarga pertencente ao provedor |
| 27 | isCacheTtlEligible | Controle de elegibilidade de TTL do cache de prompt |
| 28 | buildMissingAuthMessage | Dica personalizada de autenticação ausente |
| 29 | augmentModelCatalog | Linhas sintéticas de compatibilidade futura |
| 30 | resolveThinkingProfile | Conjunto de opções /think específico do modelo |
| 31 | isBinaryThinking | Compatibilidade de pensamento binário ligado/desligado |
| 32 | supportsXHighThinking | Compatibilidade com suporte de raciocínio xhigh |
| 33 | resolveDefaultThinkingLevel | Compatibilidade da política padrão de /think |
| 34 | isModernModelRef | Correspondência de modelo live/smoke |
| 35 | prepareRuntimeAuth | Troca de token antes da inferência |
| 36 | resolveUsageAuth | Análise personalizada de credenciais de uso |
| 37 | fetchUsageSnapshot | Endpoint de uso personalizado |
| 38 | createEmbeddingProvider | Adaptador de embeddings pertencente ao provedor para memória/pesquisa |
| 39 | buildReplayPolicy | Política personalizada de repetição/compaction de transcrição |
| 40 | sanitizeReplayHistory | Reescritas de repetição específicas do provedor após a limpeza genérica |
| 41 | validateReplayTurns | Validação estrita de turnos de repetição antes do executor incorporado |
| 42 | onModelSelected | Callback pós-seleção (por exemplo, telemetria) |
normalizeConfigverifica primeiro o provedor correspondente, depois outros Plugins de provedor capazes de usar ganchos até que um realmente altere a configuração. Se nenhum gancho de provedor reescrever uma entrada de configuração da família Google compatível, o normalizador de configuração Google incluído ainda se aplica.resolveConfigApiKeyusa o gancho do provedor quando exposto. O caminhoamazon-bedrockincluído também tem aqui um resolvedor integrado de marcador de env AWS, embora a autenticação de runtime do Bedrock em si ainda use a cadeia padrão do AWS SDK.resolveSystemPromptContributionpermite que um provedor injete orientação de prompt de sistema ciente de cache para uma família de modelos. Prefira-o abefore_prompt_buildquando o comportamento pertence a uma família de provedor/modelo e deve preservar a divisão estável/dinâmica do cache.
Adicionar capacidades extras (opcional)
Etapa 5: Adicionar capacidades extras
Um Plugin de provedor pode registrar fala, transcrição em tempo real, voz em tempo real, compreensão de mídia, geração de imagens, geração de vídeo, busca de páginas web e pesquisa na web junto com inferência de texto. O OpenClaw classifica isso como um Plugin de capacidade híbrida - o padrão recomendado para Plugins de empresa (um Plugin por fornecedor). Veja Internos: propriedade de capacidade.Registre cada capacidade dentro deregister(api) junto com sua chamada existente
api.registerProvider(...). Escolha apenas as abas necessárias:- Fala (TTS)
- Transcrição em tempo real
- Voz em tempo real
- Compreensão de mídia
- Geração de imagens e vídeo
- Busca de páginas web e pesquisa
assertOkOrThrowProviderError(...) para falhas HTTP do provedor, para que
os Plugins compartilhem leituras limitadas do corpo de erro, análise de erros JSON e
sufixos de ID de solicitação.Testar
Etapa 6: Testar
src/provider.test.ts
Publicar no ClawHub
Plugins de provedor são publicados da mesma forma que qualquer outro Plugin de código externo:clawhub package publish.
Estrutura de arquivos
Referência de ordem do catálogo
catalog.order controla quando seu catálogo é mesclado em relação aos provedores
integrados:
| Ordem | Quando | Caso de uso |
|---|---|---|
simple | Primeiro passo | Provedores simples com chave de API |
profile | Após simple | Provedores condicionados a perfis de autenticação |
paired | Após profile | Sintetizar várias entradas relacionadas |
late | Último passo | Substituir provedores existentes (vence em colisão) |
Próximas etapas
- Plugins de canal - se seu Plugin também fornece um canal
- Runtime do SDK - helpers
api.runtime(TTS, pesquisa, subagente) - Visão geral do SDK - referência completa de importação por subcaminho
- Internos de Plugin - detalhes de hooks e exemplos integrados