Plugins
Pacotes de Plugin
OpenClaw pode instalar plugins de três ecossistemas externos: Codex, Claude, e Cursor. Eles são chamados de pacotes — pacotes de conteúdo e metadados que o OpenClaw mapeia para recursos nativos como Skills, hooks e ferramentas MCP.
Por que os pacotes existem
Muitos plugins úteis são publicados no formato Codex, Claude ou Cursor. Em vez de exigir que autores os reescrevam como plugins nativos do OpenClaw, o OpenClaw detecta esses formatos e mapeia o conteúdo compatível para o conjunto de recursos nativo. Isso significa que você pode instalar um pacote de comandos Claude ou um pacote de Skills do Codex e usá-lo imediatamente.
Instalar um pacote
Instalar de um diretório, arquivo ou marketplace
# Local directory
openclaw plugins install ./my-bundle
# Archive
openclaw plugins install ./my-bundle.tgz
# Claude marketplace
openclaw plugins marketplace list <marketplace-name>
openclaw plugins install <plugin-name>@<marketplace-name>
Verificar detecção
openclaw plugins list
openclaw plugins inspect <id>
Pacotes aparecem como Format: bundle com um subtipo codex, claude ou cursor.
Reiniciar e usar
openclaw gateway restart
Recursos mapeados (Skills, hooks, ferramentas MCP, padrões LSP) ficam disponíveis na próxima sessão.
O que o OpenClaw mapeia de pacotes
Nem todos os recursos de pacote rodam no OpenClaw hoje. Veja o que funciona e o que é detectado, mas ainda não está conectado.
Com suporte agora
| Recurso | Como é mapeado | Aplica-se a |
|---|---|---|
| Conteúdo de Skill | Raízes de Skills do pacote carregam como Skills normais do OpenClaw | Todos os formatos |
| Comandos | commands/ e .cursor/commands/ tratados como raízes de Skills |
Claude, Cursor |
| Pacotes de hooks | Layouts no estilo OpenClaw com HOOK.md + handler.ts |
Codex |
| Ferramentas MCP | Configuração MCP do pacote mesclada nas configurações embarcadas do Pi; servidores stdio e HTTP compatíveis carregados | Todos os formatos |
| Servidores LSP | .lsp.json do Claude e lspServers declarados no manifesto mesclados aos padrões LSP embarcados do Pi |
Claude |
| Configurações | settings.json do Claude importado como padrões embarcados do Pi |
Claude |
Conteúdo de Skill
- raízes de Skills do pacote carregam como raízes de Skills normais do OpenClaw
- raízes
commandsdo Claude são tratadas como raízes de Skills adicionais - raízes
.cursor/commandsdo Cursor são tratadas como raízes de Skills adicionais
Isso significa que arquivos de comando Markdown do Claude funcionam pelo carregador normal de Skills do OpenClaw. Markdown de comandos do Cursor funciona pelo mesmo caminho.
Pacotes de hooks
- raízes de hooks de pacote funcionam somente quando usam o layout normal de pacote de hooks
do OpenClaw. Hoje, esse é principalmente o caso compatível com Codex:
HOOK.mdhandler.tsouhandler.js
MCP para Pi
- pacotes habilitados podem contribuir configuração de servidor MCP
- o OpenClaw mescla a configuração MCP do pacote nas configurações embarcadas efetivas do Pi como
mcpServers - o OpenClaw expõe ferramentas MCP de pacote compatíveis durante turnos do agente Pi embarcado ao iniciar servidores stdio ou conectar a servidores HTTP
- os perfis de ferramenta
codingemessagingincluem ferramentas MCP de pacote por padrão; usetools.deny: ["bundle-mcp"]para optar por não usar em um agente ou Gateway - configurações locais de projeto do Pi ainda se aplicam depois dos padrões do pacote, então as configurações do workspace podem substituir entradas MCP do pacote quando necessário
- catálogos de ferramentas MCP de pacote são ordenados deterministamente antes do registro, para que
alterações na ordem upstream de
listTools()não agitem blocos de ferramentas do cache de prompt
Transportes
Servidores MCP podem usar transporte stdio ou HTTP:
Stdio inicia um processo filho:
{
"mcp": {
"servers": {
"my-server": {
"command": "node",
"args": ["server.js"],
"env": { "PORT": "3000" }
}
}
}
}
HTTP conecta a um servidor MCP em execução por sse por padrão, ou streamable-http quando solicitado:
{
"mcp": {
"servers": {
"my-server": {
"url": "http://localhost:3100/mcp",
"transport": "streamable-http",
"headers": {
"Authorization": "Bearer ${MY_SECRET_TOKEN}"
},
"connectionTimeoutMs": 30000
}
}
}
}
transportpode ser definido como"streamable-http"ou"sse"; quando omitido, o OpenClaw usassetype: "http"é um formato downstream nativo da CLI; usetransport: "streamable-http"na configuração do OpenClaw.openclaw mcp seteopenclaw doctor --fixnormalizam o alias comum.- somente esquemas de URL
http:ehttps:são permitidos - valores de
headersaceitam interpolação${ENV_VAR} - uma entrada de servidor com
commandeurlé rejeitada - credenciais de URL (userinfo e parâmetros de consulta) são redigidas de descrições de ferramentas e logs
connectionTimeoutMssubstitui o tempo limite de conexão padrão de 30 segundos para transportes stdio e HTTP
Nomeação de ferramentas
O OpenClaw registra ferramentas MCP de pacote com nomes seguros para provedores no formato
serverName__toolName. Por exemplo, um servidor com chave "vigil-harbor" que expõe uma ferramenta
memory_search é registrado como vigil-harbor__memory_search.
- caracteres fora de
A-Za-z0-9_-são substituídos por- - prefixos de servidor são limitados a 30 caracteres
- nomes completos de ferramentas são limitados a 64 caracteres
- nomes de servidor vazios usam
mcpcomo fallback - nomes sanitizados conflitantes são desambiguados com sufixos numéricos
- a ordem final de ferramentas expostas é determinística por nome seguro para manter turnos repetidos do Pi estáveis em cache
- a filtragem de perfis trata todas as ferramentas de um servidor MCP de pacote como pertencentes ao plugin
bundle-mcp, então listas de permissão e negação de perfil podem incluir tanto nomes individuais de ferramentas expostas quanto a chave de pluginbundle-mcp
Configurações embarcadas do Pi
settings.jsondo Claude é importado como configurações embarcadas padrão do Pi quando o pacote está habilitado- o OpenClaw sanitiza chaves de substituição de shell antes de aplicá-las
Chaves sanitizadas:
shellPathshellCommandPrefix
LSP embarcado do Pi
- pacotes Claude habilitados podem contribuir configuração de servidor LSP
- o OpenClaw carrega
.lsp.jsonmais quaisquer caminhoslspServersdeclarados no manifesto - a configuração LSP do pacote é mesclada aos padrões LSP embarcados efetivos do Pi
- somente servidores LSP com suporte baseados em stdio podem ser executados hoje; transportes
sem suporte ainda aparecem em
openclaw plugins inspect <id>
Detectado, mas não executado
Estes são reconhecidos e exibidos em diagnósticos, mas o OpenClaw não os executa:
agents, automaçãohooks.json,outputStylesdo Claude.cursor/agents,.cursor/hooks.json,.cursor/rulesdo Cursor- metadados inline/de app do Codex além do relatório de capacidades
Formatos de pacote
Pacotes Codex
Marcadores: .codex-plugin/plugin.json
Conteúdo opcional: skills/, hooks/, .mcp.json, .app.json
Pacotes Codex se encaixam melhor no OpenClaw quando usam raízes de Skills e diretórios
de pacote de hooks no estilo OpenClaw (HOOK.md + handler.ts).
Pacotes Claude
Dois modos de detecção:
- Baseado em manifesto:
.claude-plugin/plugin.json - Sem manifesto: layout padrão do Claude (
skills/,commands/,agents/,hooks/,.mcp.json,.lsp.json,settings.json)
Comportamento específico do Claude:
commands/é tratado como conteúdo de Skillsettings.jsoné importado para as configurações embarcadas do Pi (chaves de substituição de shell são sanitizadas).mcp.jsonexpõe ferramentas stdio compatíveis ao Pi embarcado.lsp.jsonmais caminhoslspServersdeclarados no manifesto carregam nos padrões LSP embarcados do Pihooks/hooks.jsoné detectado, mas não executado- caminhos de componentes personalizados no manifesto são aditivos (estendem os padrões, não os substituem)
Pacotes Cursor
Marcadores: .cursor-plugin/plugin.json
Conteúdo opcional: skills/, .cursor/commands/, .cursor/agents/, .cursor/rules/, .cursor/hooks.json, .mcp.json
.cursor/commands/é tratado como conteúdo de Skill.cursor/rules/,.cursor/agents/e.cursor/hooks.jsonsão somente detecção
Precedência de detecção
O OpenClaw verifica primeiro o formato de plugin nativo:
openclaw.plugin.jsonoupackage.jsonválido comopenclaw.extensions— tratado como plugin nativo- Marcadores de pacote (
.codex-plugin/,.claude-plugin/ou layout padrão do Claude/Cursor) — tratados como pacote
Se um diretório contiver ambos, o OpenClaw usa o caminho nativo. Isso evita que pacotes de formato duplo sejam parcialmente instalados como pacotes.
Dependências de runtime e limpeza
- Pacotes compatíveis de terceiros não recebem reparo de
npm installna inicialização. Eles devem ser instalados por meio deopenclaw plugins installe incluir tudo de que precisam no diretório de plugin instalado. - Plugins empacotados pertencentes ao OpenClaw são enviados de forma leve no núcleo ou baixáveis pelo instalador de plugins. A inicialização do Gateway nunca executa um gerenciador de pacotes para eles.
openclaw doctor --fixremove diretórios legados de dependências preparadas e pode recuperar plugins baixáveis ausentes do índice local de plugins quando a configuração os referencia.
Segurança
Pacotes têm um limite de confiança mais restrito que plugins nativos:
- o OpenClaw não carrega módulos arbitrários de runtime de pacote no processo
- caminhos de Skills e de pacotes de hooks devem permanecer dentro da raiz do plugin (com verificação de limite)
- arquivos de configuração são lidos com as mesmas verificações de limite
- servidores MCP stdio compatíveis podem ser iniciados como subprocessos
Isso torna pacotes mais seguros por padrão, mas você ainda deve tratar pacotes de terceiros como conteúdo confiável para os recursos que eles expõem.
Solução de problemas
O pacote é detectado, mas as capacidades não rodam
Execute openclaw plugins inspect <id>. Se uma capacidade estiver listada, mas marcada como
não conectada, isso é um limite do produto — não uma instalação quebrada.
Arquivos de comando Claude não aparecem
Verifique se o pacote está habilitado e se os arquivos Markdown estão dentro de uma raiz
commands/ ou skills/ detectada.
Configurações do Claude não se aplicam
Somente configurações embarcadas do Pi de settings.json têm suporte. O OpenClaw não
trata configurações de pacote como patches de configuração bruta.
Hooks do Claude não executam
hooks/hooks.json é somente detecção. Se você precisa de hooks executáveis, use o
layout de pacote de hooks do OpenClaw ou envie um plugin nativo.
Relacionado
- Instalar e configurar plugins
- Criar plugins — crie um plugin nativo
- Manifesto de Plugin — esquema de manifesto nativo