Pular para o conteúdo

CLI

Opções e comandos da CLI do opencode.

A CLI do opencode, por padrão, inicia o TUI quando executada sem argumentos.

Terminal window
opencode

Mas também aceita comandos conforme documentado nesta página. Isso permite que você interaja com o opencode programaticamente.

Terminal window
opencode run "Explain how closures work in JavaScript"

tui

Inicie a interface de usuário do terminal do opencode.

Terminal window
opencode [project]

Flags

FlagCurtoDescrição
--continue-cContinue a última sessão
--session-sID da sessão para continuar
--forkCriar um fork da sessão ao continuar (use com --continue ou --session)
--promptPrompt a ser usado
--model-mModelo a ser usado na forma de provider/model
--agentAgente a ser usado
--portPorta para escutar
--hostnameNome do host para escutar

Comandos

A CLI do opencode também possui os seguintes comandos.


agent

Gerencie agentes para o opencode.

Terminal window
opencode agent [command]

attach

Anexe um terminal a um servidor backend do opencode já em execução, iniciado via comandos serve ou web.

Terminal window
opencode attach [url]

Isso permite usar o TUI com um backend opencode remoto. Por exemplo:

Terminal window
# Start the backend server for web/mobile access
opencode web --port 4096 --hostname 0.0.0.0
# In another terminal, attach the TUI to the running backend
opencode attach http://10.20.30.40:4096

Flags

FlagCurtoDescrição
--dirDiretório de trabalho para iniciar o TUI
--session-sID da sessão para continuar

create

Crie um novo agente com configuração personalizada.

Terminal window
opencode agent create

Este comando irá guiá-lo na criação de um novo agente com um prompt de sistema personalizado e configuração de ferramentas.


list

Liste todos os agentes disponíveis.

Terminal window
opencode agent list

auth

Comando para gerenciar credenciais e login para provedores.

Terminal window
opencode auth [command]

login

O opencode é alimentado pela lista de provedores em Models.dev, então você pode usar opencode auth login para configurar chaves de API para qualquer provedor que você gostaria de usar. Isso é armazenado em ~/.local/share/opencode/auth.json.

Terminal window
opencode auth login

Quando o opencode é iniciado, ele carrega os provedores do arquivo de credenciais. E se houver chaves definidas em seus ambientes ou em um arquivo .env em seu projeto.


list

Lista todos os provedores autenticados conforme armazenado no arquivo de credenciais.

Terminal window
opencode auth list

Ou a versão curta.

Terminal window
opencode auth ls

logout

Desconecta você de um provedor limpando-o do arquivo de credenciais.

Terminal window
opencode auth logout

github

Gerencie o agente do GitHub para automação de repositórios.

Terminal window
opencode github [command]

install

Instale o agente do GitHub em seu repositório.

Terminal window
opencode github install

Isso configura o fluxo de trabalho necessário do GitHub Actions e o guia pelo processo de configuração. Saiba mais.


run

Execute o agente do GitHub. Isso é tipicamente usado em GitHub Actions.

Terminal window
opencode github run
Flags
FlagDescrição
--eventEvento simulado do GitHub para executar o agente
--tokenToken de acesso pessoal do GitHub

mcp

Gerencie servidores do Model Context Protocol.

Terminal window
opencode mcp [command]

add

Adicione um servidor MCP à sua configuração.

Terminal window
opencode mcp add

Este comando irá guiá-lo na adição de um servidor MCP local ou remoto.


list

Liste todos os servidores MCP configurados e seu status de conexão.

Terminal window
opencode mcp list

Ou use a versão curta.

Terminal window
opencode mcp ls

auth

Autentique-se com um servidor MCP habilitado para OAuth.

Terminal window
opencode mcp auth [name]

Se você não fornecer um nome de servidor, será solicitado que você selecione entre os servidores disponíveis habilitados para OAuth.

Você também pode listar servidores habilitados para OAuth e seu status de autenticação.

Terminal window
opencode mcp auth list

Ou use a versão curta.

Terminal window
opencode mcp auth ls

logout

Remova credenciais OAuth para um servidor MCP.

Terminal window
opencode mcp logout [name]

debug

Depure problemas de conexão OAuth para um servidor MCP.

Terminal window
opencode mcp debug <name>

models

Liste todos os modelos disponíveis dos provedores configurados.

Terminal window
opencode models [provider]

Este comando exibe todos os modelos disponíveis entre seus provedores configurados no formato provider/model.

Isso é útil para descobrir o nome exato do modelo a ser usado em sua configuração.

Você pode opcionalmente passar um ID de provedor para filtrar modelos por esse provedor.

Terminal window
opencode models anthropic

Flags

FlagDescrição
--refreshAtualiza o cache de modelos a partir do models.dev
--verboseUse uma saída de modelo mais detalhada (inclui metadados como custos)

Use a flag --refresh para atualizar a lista de modelos em cache. Isso é útil quando novos modelos foram adicionados a um provedor e você deseja vê-los no opencode.

Terminal window
opencode models --refresh

run

Execute o opencode em modo não interativo passando um prompt diretamente.

Terminal window
opencode run [message..]

Isso é útil para scripts, automação ou quando você deseja uma resposta rápida sem iniciar o TUI completo. Por exemplo.

Terminal window
opencode run Explain the use of context in Go

Você também pode se anexar a uma instância em execução do opencode serve para evitar tempos de inicialização a frio do servidor MCP em cada execução:

Terminal window
# Start a headless server in one terminal
opencode serve
# In another terminal, run commands that attach to it
opencode run --attach http://localhost:4096 "Explain async/await in JavaScript"

Flags

FlagCurtoDescrição
--commandO comando a ser executado, use mensagem para argumentos
--continue-cContinue a última sessão
--session-sID da sessão para continuar
--forkCriar um fork da sessão ao continuar (use com --continue ou --session)
--shareCompartilhe a sessão
--model-mModelo a ser usado na forma de provider/model
--agentAgente a ser usado
--file-fArquivo(s) a serem anexados à mensagem
--formatFormato: padrão (formatado) ou json (eventos JSON brutos)
--titleTítulo para a sessão (usa o prompt truncado se nenhum valor for fornecido)
--attachAnexe a um servidor opencode em execução (por exemplo, http://localhost:4096)
--portPorta para o servidor local (padrão para porta aleatória)

serve

Inicie um servidor opencode sem cabeça para acesso à API. Confira a documentação do servidor para a interface HTTP completa.

Terminal window
opencode serve

Isso inicia um servidor HTTP que fornece acesso à funcionalidade do opencode sem a interface TUI. Defina OPENCODE_SERVER_PASSWORD para habilitar a autenticação básica HTTP (o nome de usuário padrão é opencode).

Flags

FlagDescrição
--portPorta para escutar
--hostnameNome do host para escutar
--mdnsHabilitar descoberta mDNS
--corsOrigem(ns) de navegador adicionais para permitir CORS

session

Gerencie sessões do opencode.

Terminal window
opencode session [command]

list

Liste todas as sessões do opencode.

Terminal window
opencode session list
Flags
FlagCurtoDescrição
--max-count-nLimitar às N sessões mais recentes
--formatFormato de saída: tabela ou json (tabela)

stats

Mostre o uso de tokens e estatísticas de custo para suas sessões do opencode.

Terminal window
opencode stats

Flags

FlagDescrição
--daysMostre estatísticas dos últimos N dias (todo o tempo)
--toolsNúmero de ferramentas a serem mostradas (todas)
--modelsMostre a divisão do uso de modelos (oculto por padrão). Passe um número para mostrar os N principais
--projectFiltrar por projeto (todos os projetos, string vazia: projeto atual)

export

Exporte dados da sessão como JSON.

Terminal window
opencode export [sessionID]

Se você não fornecer um ID de sessão, será solicitado que você selecione entre as sessões disponíveis.


import

Importe dados da sessão de um arquivo JSON ou URL de compartilhamento do opencode.

Terminal window
opencode import <file>

Você pode importar de um arquivo local ou de uma URL de compartilhamento do opencode.

Terminal window
opencode import session.json
opencode import https://opncd.ai/s/abc123

web

Inicie um servidor opencode sem cabeça com uma interface web.

Terminal window
opencode web

Isso inicia um servidor HTTP e abre um navegador para acessar o opencode através de uma interface web. Defina OPENCODE_SERVER_PASSWORD para habilitar a autenticação básica HTTP (o nome de usuário padrão é opencode).

Flags

FlagDescrição
--portPorta para escutar
--hostnameNome do host para escutar
--mdnsHabilitar descoberta mDNS
--corsOrigem(ns) de navegador adicionais para permitir CORS

acp

Inicie um servidor ACP (Agent Client Protocol).

Terminal window
opencode acp

Este comando inicia um servidor ACP que se comunica via stdin/stdout usando nd-JSON.

Flags

FlagDescrição
--cwdDiretório de trabalho
--portPorta para escutar
--hostnameNome do host para escutar

uninstall

Desinstale o opencode e remova todos os arquivos relacionados.

Terminal window
opencode uninstall

Flags

FlagCurtoDescrição
--keep-config-cManter arquivos de configuração
--keep-data-dManter dados de sessão e snapshots
--dry-runMostrar o que seria removido sem remover
--force-fPular prompts de confirmação

upgrade

Atualiza o opencode para a versão mais recente ou uma versão específica.

Terminal window
opencode upgrade [target]

Para atualizar para a versão mais recente.

Terminal window
opencode upgrade

Para atualizar para uma versão específica.

Terminal window
opencode upgrade v0.1.48

Flags

FlagCurtoDescrição
--method-mO método de instalação que foi usado; curl, npm, pnpm, bun, brew

Flags Globais

A CLI do opencode aceita as seguintes flags globais.

FlagCurtoDescrição
--help-hExibir ajuda
--version-vImprimir número da versão
--print-logsImprimir logs no stderr
--log-levelNível de log (DEBUG, INFO, WARN, ERROR)

Variáveis de ambiente

O opencode pode ser configurado usando variáveis de ambiente.

VariávelTipoDescrição
OPENCODE_AUTO_SHAREbooleanCompartilhar sessões automaticamente
OPENCODE_GIT_BASH_PATHstringCaminho para o executável do Git Bash no Windows
OPENCODE_CONFIGstringCaminho para o arquivo de configuração
OPENCODE_CONFIG_DIRstringCaminho para o diretório de configuração
OPENCODE_CONFIG_CONTENTstringConteúdo de configuração json inline
OPENCODE_DISABLE_AUTOUPDATEbooleanDesabilitar verificações de atualização automática
OPENCODE_DISABLE_PRUNEbooleanDesabilitar a poda de dados antigos
OPENCODE_DISABLE_TERMINAL_TITLEbooleanDesabilitar atualizações automáticas do título do terminal
OPENCODE_PERMISSIONstringConfiguração de permissões json inline
OPENCODE_DISABLE_DEFAULT_PLUGINSbooleanDesabilitar plugins padrão
OPENCODE_DISABLE_LSP_DOWNLOADbooleanDesabilitar downloads automáticos do servidor LSP
OPENCODE_ENABLE_EXPERIMENTAL_MODELSbooleanHabilitar modelos experimentais
OPENCODE_DISABLE_AUTOCOMPACTbooleanDesabilitar compactação automática de contexto
OPENCODE_DISABLE_CLAUDE_CODEbooleanDesabilitar leitura de .claude (prompt + habilidades)
OPENCODE_DISABLE_CLAUDE_CODE_PROMPTbooleanDesabilitar leitura de ~/.claude/CLAUDE.md
OPENCODE_DISABLE_CLAUDE_CODE_SKILLSbooleanDesabilitar carregamento de .claude/skills
OPENCODE_DISABLE_MODELS_FETCHbooleanDesabilitar busca de modelos de fontes remotas
OPENCODE_FAKE_VCSstringProvedor VCS falso para fins de teste
OPENCODE_DISABLE_FILETIME_CHECKbooleanDesabilitar verificação de tempo de arquivo para otimização
OPENCODE_CLIENTstringIdentificador do cliente (padrão é cli)
OPENCODE_ENABLE_EXAbooleanHabilitar ferramentas de busca web Exa
OPENCODE_SERVER_PASSWORDstringHabilitar autenticação básica para serve/web
OPENCODE_SERVER_USERNAMEstringSubstituir nome de usuário de autenticação básica (padrão opencode)
OPENCODE_MODELS_URLstringURL personalizada para buscar configuração de modelos

Experimental

Essas variáveis de ambiente habilitam recursos experimentais que podem mudar ou ser removidos.

VariávelTipoDescrição
OPENCODE_EXPERIMENTALbooleanHabilitar todos os recursos experimentais
OPENCODE_EXPERIMENTAL_ICON_DISCOVERYbooleanHabilitar descoberta de ícones
OPENCODE_EXPERIMENTAL_DISABLE_COPY_ON_SELECTbooleanDesabilitar cópia ao selecionar no TUI
OPENCODE_EXPERIMENTAL_BASH_DEFAULT_TIMEOUT_MSnumberTempo limite padrão para comandos bash em ms
OPENCODE_EXPERIMENTAL_OUTPUT_TOKEN_MAXnumberMáximo de tokens de saída para respostas LLM
OPENCODE_EXPERIMENTAL_FILEWATCHERbooleanHabilitar monitoramento de arquivos para todo o diretório
OPENCODE_EXPERIMENTAL_OXFMTbooleanHabilitar formatador oxfmt
OPENCODE_EXPERIMENTAL_LSP_TOOLbooleanHabilitar ferramenta LSP experimental
OPENCODE_EXPERIMENTAL_DISABLE_FILEWATCHERbooleanDesabilitar monitoramento de arquivos
OPENCODE_EXPERIMENTAL_EXAbooleanHabilitar recursos experimentais do Exa
OPENCODE_EXPERIMENTAL_LSP_TYbooleanHabilitar verificação de tipo LSP experimental
OPENCODE_EXPERIMENTAL_MARKDOWNbooleanHabilitar recursos experimentais de markdown
OPENCODE_EXPERIMENTAL_PLAN_MODEbooleanHabilitar modo de plano