README.pt-BR.md
June 2, 2026 · View on GitHub
⚡ OxideTerm
Um workspace SSH local-first para quem vive no terminal.
Conecte-se uma vez a uma máquina remota e trabalhe com shell, arquivos, portas, transferências, editor leve e BYOK AI em um só lugar.
App Tauri nativo · SSH puro em Rust · sem conta para os workflows SSH principais
Zero Electron. Zero OpenSSL. Zero telemetria. Zero assinatura. BYOK-first. SSH puro em Rust.
🌐 oxideterm.app — Documentation & website
English | 简体中文 | 繁體中文 | 日本語 | 한국어 | Français | Deutsch | Español | Italiano | Português | Tiếng Việt
O que você pode fazer
- Gerenciar lado a lado terminais SSH, SFTP, port forwards, transferências no terminal e shells locais
- Continuar trabalhando durante instabilidades de rede com Grace Period reconnect
- Usar seu próprio provedor de IA para inspecionar sessões ativas e executar ações aprovadas
Por que OxideTerm?
| Se você se importa com... | OxideTerm oferece... |
|---|---|
| Um nó remoto, muitas ferramentas | Terminal, SFTP, port forwarding, trzsz, mini IDE, monitoramento e contexto de IA ficam no mesmo workspace SSH |
| Workflows SSH local-first | SSH, SFTP, forwarding, shell local e configuração funcionam sem cadastro; sincronização cloud é opcional via plugin oficial |
| BYOK AI em vez de créditos de plataforma | OxideSens usa seu endpoint OpenAI/Ollama/DeepSeek/OpenAI-compatible com suporte a MCP e RAG |
| Reconexão estável | Grace Period sonda a conexão antiga por 30 s antes de substituí-la, para vim/htop/yazi sobreviverem a quedas curtas |
| App nativo em Rust puro | App Tauri 2.0 nativo, russh 0.59 compilado com ring, sem Electron e sem OpenSSL/libssh2 |
| Segurança de credenciais | Senhas e chaves de API ficam no keychain do OS, metadados são selados localmente e .oxide usa ChaCha20-Poly1305 + Argon2id |
O que é / o que não é
OxideTerm foca em workflows SSH local-first. Ele é feito para usuários que querem manter terminal, arquivos, portas, transferências, edição leve e contexto de IA ao redor de suas próprias máquinas e nós remotos.
Não tenta ser uma plataforma cloud de agentes nem um projeto centrado apenas em benchmarks de renderização de terminal. A direção é mais estreita: fazer o trabalho remoto parecer um workspace local, sem conta OxideTerm.
Capturas de tela
Terminal SSH + OxideSens AI![]() |
Gerenciador de arquivos SFTP![]() |
IDE integrado (CodeMirror 6)![]() |
Encaminhamento de portas inteligente![]() |
Download
Baixe a versão mais recente em GitHub Releases.
Visão geral das funcionalidades
| Categoria | Funcionalidades |
|---|---|
| Terminal | PTY local (zsh/bash/fish/pwsh/WSL2), SSH remoto, terminais seriais locais, painéis divididos, broadcast de entrada, gravação/reprodução de sessões (asciicast v2), renderização WebGL, 30+ temas + editor personalizado, paleta de comandos (⌘K), modo zen, transferência de arquivos trzsz integrada |
| SSH e autenticação | Pool de conexões e multiplexação, ProxyJump (saltos ilimitados) com grafo topológico, reconexão automática com período de carência, Encaminhamento de agente. Auth: senha, chave SSH (RSA/Ed25519/ECDSA), SSH Agent, certificados, 2FA interativo por teclado, Known Hosts TOFU |
| SFTP | Navegador de painel duplo, arrastar e soltar, pré-visualização inteligente (imagens/vídeo/áudio/código/PDF/hex/fontes), fila de transferência com progresso e ETA, favoritos, extração de arquivos |
| Modo IDE | CodeMirror 6 com 30+ linguagens, árvore de arquivos + status Git, multi-abas, resolução de conflitos, terminal integrado. Agente remoto opcional para Linux (9 arquiteturas adicionais) |
| Encaminhamento de portas | Local (-L), remoto (-R), SOCKS5 dinâmico (-D), I/O por passagem de mensagens sem lock, restauração automática na reconexão, relatório de falhas, timeout de inatividade |
| IA (OxideSens) | Assistente orientado a alvos para conexões salvas, sessões SSH ativas, buffers de terminal, caminhos SFTP, configurações e entradas da base de conhecimento; pode diagnosticar saída remota, executar comandos aprovados, inspecionar arquivos e explicar falhas sem uma conta OxideTerm |
| Plugins | Carregamento ESM em runtime, 18 namespaces de API, 24 componentes UI Kit, API congelada + ACL Proxy, circuit breaker, desativação automática em caso de erros |
| CLI | Companion oxt: JSON-RPC 2.0 via Unix Socket / Named Pipe, status/health/list/forward/config/connect/focus/attach/SFTP/import/AI, saída legível + JSON |
| Segurança | Exportação .oxide criptografada (ChaCha20-Poly1305 + Argon2id 256 MB), configuração local criptografada em repouso, chaveiro do SO, Touch ID (macOS), cofre de chaves criptografado portátil, TOFU de chave do host, limpeza de memória zeroize |
| i18n | 11 idiomas: EN, 简体中文, 繁體中文, 日本語, 한국어, FR, DE, ES, IT, PT-BR, VI |
Nos Bastidores
OxideTerm mantém a superfície do produto local-first, mas por dentro é construído para workflows SSH intensivos. Os detalhes completos de implementação ficam preservados abaixo.
Arquitetura, internals SSH, reconexão, IA, forwarding, plugins e mais
Arquitetura — Comunicação de plano duplo
OxideTerm separa dados do terminal dos comandos de controle em dois planos independentes:
┌─────────────────────────────────────┐
│ Frontend (React 19) │
│ xterm.js 6 (WebGL) + 19 stores │
└──────────┬──────────────┬───────────┘
│ Tauri IPC │ WebSocket (binário)
│ (JSON) │ porta por sessão
┌──────────▼──────────────▼───────────┐
│ Backend (Rust) │
│ NodeRouter → SshConnectionRegistry │
│ Wire Protocol v1 │
│ [Type:1][Length:4][Payload:n] │
└─────────────────────────────────────┘
- Plano de dados (WebSocket): cada sessão SSH obtém sua própria porta WebSocket. Os bytes do terminal fluem como frames binários com cabeçalho Type-Length-Payload — sem serialização JSON, sem codificação Base64, zero overhead no caminho crítico.
- Plano de controle (Tauri IPC): gerenciamento de conexões, operações SFTP, encaminhamentos, configuração — JSON estruturado, mas fora do caminho crítico.
- Endereçamento por nó: o frontend nunca toca
sessionIdnemconnectionId. Tudo é endereçado pornodeId, resolvido atomicamente no servidor peloNodeRouter. A reconexão SSH altera oconnectionIdsubjacente — mas SFTP, IDE e encaminhamentos não são afetados de forma alguma.
🔩 SSH puro em Rust — russh 0.59
Toda a pilha SSH é russh 0.59 compilada com o backend criptográfico ring:
- Zero dependências C/OpenSSL — toda a pilha criptográfica é Rust. Sem mais debug de "qual versão do OpenSSL?".
- Protocolo SSH2 completo: troca de chaves, canais, subsistema SFTP, encaminhamento de portas
- Suítes de cifragem ChaCha20-Poly1305 e AES-GCM, chaves Ed25519/RSA/ECDSA
AgentSignerpersonalizado: encapsula o SSH Agent do sistema e implementa o traitSignerdo russh, resolvendo problemas de boundsSendRPITIT ao clonar&AgentIdentitypara um valor owned antes de cruzar.await
pub struct AgentSigner { /* wraps system SSH Agent */ }
impl Signer for AgentSigner { /* challenge-response via Agent IPC */ }
- Suporte de plataforma: Unix (
SSH_AUTH_SOCK), Windows (\\.\pipe\openssh-ssh-agent) - Cadeias proxy: cada salto usa autenticação Agent de forma independente
- Reconexão:
AuthMethod::Agentreproduzido automaticamente
🔄 Reconexão inteligente com período de carência
A maioria dos clientes SSH destrói tudo na desconexão e recomeça do zero. O orquestrador de reconexão do OxideTerm adota uma abordagem fundamentalmente diferente:
- Detecção do timeout de heartbeat WebSocket (300 s, calibrado para macOS App Nap e throttling de timers JS)
- Snapshot do estado completo: painéis do terminal, transferências SFTP em andamento, encaminhamentos de portas ativos, arquivos IDE abertos
- Sondagem inteligente: eventos
visibilitychange+onlinedisparam keepalive SSH proativo (~2 s de detecção contra 15–30 s de timeout passivo) - Período de carência (30 s): sonda a conexão SSH antiga via keepalive — se ela se recuperar (ex.: troca de ponto de acesso WiFi), seus apps TUI (vim, htop, yazi) sobrevivem completamente intactos
- Se a recuperação falhar → nova conexão SSH → restauração automática dos encaminhamentos → retomada das transferências SFTP → reabertura dos arquivos IDE
Pipeline: queued → snapshot → grace-period → ssh-connect → await-terminal → restore-forwards → resume-transfers → restore-ide → verify → done
Toda a lógica passa por um ReconnectOrchestratorStore dedicado — zero código de reconexão espalhado em hooks ou componentes.
🛡️ Pool de conexões SSH
SshConnectionRegistry com contagem de referências respaldado por DashMap para acesso concorrente sem lock:
- Uma conexão, muitos consumidores: terminal, SFTP, encaminhamentos de portas e IDE compartilham uma única conexão SSH física — sem handshakes TCP redundantes
- Máquina de estados por conexão:
connecting → active → idle → link_down → reconnecting - Gerenciamento de ciclo de vida: timeout de inatividade configurável (5 min / 15 min / 30 min / 1 h / nunca), intervalo keepalive de 15 s, detecção de falhas de heartbeat
- Heartbeat WsBridge: intervalo de 30 s, timeout de 5 min — tolera macOS App Nap e throttling JS do navegador
- Propagação em cascata: falha do host de salto → todos os nós downstream automaticamente marcados como
link_downcom sincronização de status - Desconexão por inatividade: emite
connection_status_changedpara o frontend (não apenasnode:stateinterno), prevenindo dessincronização da interface
🤖 OxideSens AI
Assistente IA focado em privacidade com dois modos de interação:
- Painel inline (
⌘I): comandos rápidos de terminal, saída injetada via bracketed paste - Chat lateral: conversas persistentes com histórico completo
- Contexto de workspace orientado a alvos: vê conexões salvas, sessões SSH ativas, buffers de terminal, caminhos SFTP, configurações e entradas da base de conhecimento como alvos do workspace
- Ações aprovadas: pode diagnosticar saída remota, executar comandos aprovados, inspecionar arquivos e explicar falhas sem exigir uma conta OxideTerm
- Suporte MCP: conexão a servidores Model Context Protocol externos (stdio & SSE) para integração de ferramentas de terceiros
- Base de conhecimento RAG (v0.20): importe documentos Markdown/TXT em coleções com escopo (global ou por conexão). A busca híbrida funde índice de palavras-chave BM25 + similaridade cosseno vetorial via Reciprocal Rank Fusion. Chunking com reconhecimento de Markdown que preserva a hierarquia de cabeçalhos. Tokenizer de bigramas CJK para chinês/japonês/coreano.
- Provedores: OpenAI, Ollama, DeepSeek, OneAPI, ou qualquer endpoint
/v1/chat/completions - Segurança: chaves API armazenadas no chaveiro do SO; no macOS, a leitura de chaves é protegida por Touch ID via
LAContext— sem entitlements ou assinatura de código necessários, em cache após a primeira autenticação por sessão
Encaminhamento de portas — I/O sem lock
Encaminhamento local (-L), remoto (-R) e SOCKS5 dinâmico (-D) completo:
- Arquitetura por passagem de mensagens: o canal SSH é de propriedade de uma única task
ssh_io— semArc<Mutex<Channel>>, eliminando a contenção mutex completamente - Relatório de falhas: as tasks de encaminhamento reportam ativamente o motivo de saída (desconexão SSH, fechamento de porta remota, timeout) para diagnósticos claros
- Restauração automática: encaminhamentos
Suspendedretomados automaticamente na reconexão sem intervenção do usuário - Timeout de inatividade:
FORWARD_IDLE_TIMEOUT(300 s) previne o acúmulo de conexões zumbi
📦 trzsz — Transferência de Arquivos Integrada
Faça upload e download de arquivos diretamente pela sessão SSH — sem conexão SFTP:
- Protocolo integrado: os arquivos trafegam como frames Base64 dentro do fluxo terminal existente — funciona de forma transparente através de cadeias ProxyJump e tmux sem portas ou agentes adicionais
- Bidirecional: o servidor executa
tsz <arquivo>para enviar arquivos ao cliente;trzinicia o upload do cliente; suporte a arrastar e soltar - Suporte a diretórios: transferências recursivas via
trz -d/tsz -d - Limites de transferência: limites configuráveis por sessão para tamanho do bloco, contagem de arquivos e total de bytes
- I/O nativo Tauri: leituras e escritas de arquivos usam diálogos nativos do Tauri e Rust I/O — sem restrições de memória do navegador
- Notificações em tempo real: notificações Toast para início, conclusão, cancelamento e erros — incluindo uma dica quando o trzsz é detectado mas a funcionalidade está desabilitada
- Ativar em Configurações → Terminal → Transferência Integrada
🔌 Sistema de plugins em runtime
Carregamento ESM dinâmico com superfície API congelada e reforçada em segurança:
- API PluginContext: 18 namespaces — terminal, ui, commands, settings, lifecycle, events, storage, system
- 24 componentes UI Kit: componentes React pré-construídos (botões, campos de entrada, diálogos, tabelas…) injetados em sandboxes de plugins via
window.__OXIDE__ - Membrana de segurança:
Object.freezeem todos os objetos de contexto, ACL baseada em Proxy, whitelist IPC, circuit breaker com desativação automática após erros repetidos - Módulos compartilhados: React, ReactDOM, zustand, lucide-react expostos para uso dos plugins sem duplicação de bundles
⚡ Renderização adaptativa
Agendador de renderização de três níveis que substitui o batching fixo de requestAnimationFrame:
| Nível | Gatilho | Frequência | Benefício |
|---|---|---|---|
| Boost | Dados de frame ≥ 4 KB | 120 Hz+ (ProMotion nativo) | Elimina lag de rolagem em cat largefile.log |
| Normal | Digitação padrão | 60 Hz (RAF) | Base fluida |
| Inativo | 3 s sem I/O / aba oculta | 1–15 Hz (decaimento exponencial) | Carga GPU quase nula, economia de bateria |
As transições são completamente automáticas — impulsionadas pelo volume de dados, entrada do usuário e API Page Visibility. Abas em segundo plano continuam esvaziando dados via timer de inatividade sem despertar RAF.
🔐 Exportação criptografada .oxide
Backup de conexão portátil e à prova de adulteração:
- Criptografia autenticada ChaCha20-Poly1305 AEAD
- KDF Argon2id: custo de memória de 256 MB, 4 iterações — resistente a brute-force GPU
- Checksum de integridade SHA-256
- Incorporação opcional de chaves: chaves privadas codificadas em base64 no payload criptografado
- Análise prévia: detalhamento dos tipos de autenticação, detecção de chaves ausentes antes da exportação
📡 ProxyJump — Multi-salto com consciência topológica
- Profundidade de cadeia ilimitada:
Cliente → Salto A → Salto B → … → Destino - Parsing automático de
~/.ssh/config, construção do grafo topológico, pathfinding Dijkstra para a rota ótima - Nós de salto reutilizáveis como sessões independentes
- Propagação de falhas em cascata: host de salto down → todos os nós downstream automaticamente marcados como
link_down
⚙️ Terminal local — PTY thread-safe
Shell local multiplataforma via portable-pty 0.8, protegido pelo feature gate local-terminal:
MasterPtyenvolvido emstd::sync::Mutex— threads de I/O dedicados mantêm as leituras PTY bloqueantes fora do event loop do Tokio- Detecção automática de shell:
zsh,bash,fish,pwsh, Git Bash, WSL2 cargo build --no-default-featuresremove PTY para builds mobile/leves
🪟 Otimização Windows
- ConPTY nativo: invoca diretamente a API Windows Pseudo Console — suporte completo TrueColor e ANSI, sem WinPTY legado
- Scanner de shells: detecta automaticamente PowerShell 7, Git Bash, WSL2, CMD via Registro e PATH
E muito mais
- Modo IDE: CodeMirror 6 via SFTP, 24 linguagens, árvore de arquivos com status Git, multi-abas, resolução de conflitos — agente remoto opcional (~1 MB) para recursos avançados no Linux
- Profiler de recursos: CPU/memória/rede em tempo real via canal SSH persistente lendo
/proc/stat, cálculo baseado em deltas, degradação automática para RTT-only em sistemas não-Linux - Motor de temas personalizado: 30+ temas integrados, editor visual com pré-visualização ao vivo, 20 campos xterm.js + 24 variáveis de cor UI, derivação automática de cores da UI a partir da paleta do terminal
- Gravação de sessões: formato asciicast v2, gravação e reprodução completas
- Broadcast de entrada: digite uma vez, envie para todos os painéis divididos — operações de servidor em lote
- Galeria de fundos: imagens de fundo por aba, 16 tipos de abas, controle de opacidade/desfoque/ajuste
- Companion CLI (
oxt): binário de ~1 MB, JSON-RPC 2.0 via Unix Socket / Named Pipe, status/health/list/forward/config/connect/focus/attach/SFTP/import/AI com saída legível ou--json - WSL Graphics ⚠️ experimental: visualizador VNC integrado — 9 ambientes desktop + modo de aplicação única, detecção WSLg, Xtigervnc + noVNC
Plugins oficiais
| Plugin | Descrição | Repositório |
|---|---|---|
| Cloud Sync | Sincronização auto-hospedada criptografada — faça upload e importe snapshots .oxide via WebDAV, HTTP JSON, Dropbox, Git ou S3 | oxideterm.cloud-sync |
| Telnet Client | Cliente Telnet nativo para roteadores, switches e dispositivos legados — sem necessidade de binário externo | oxideterm.telnet |
📸 11 idiomas em ação
![]() English |
![]() 简体中文 |
![]() 繁體中文 |
![]() 日本語 |
![]() 한국어 |
![]() Français |
![]() Deutsch |
![]() Español |
![]() Italiano |
![]() Português |
![]() Tiếng Việt |
Requisitos de runtime
O OxideTerm usa o runtime WebView nativo fornecido pelo sistema operacional. A maioria dos usuários já o tem instalado; instale manualmente apenas se o app não iniciar ou se o ambiente estiver isolado.
| Plataforma | Dependência de runtime |
|---|---|
| Windows | WebView2 Runtime — pré-instalado no Windows 10 (1803+) e Windows 11. Para ambientes isolados / intranet, use o instalador independente Evergreen (offline, ~170 MB) ou implante o runtime de versão fixa via política de grupo. |
| macOS | Nenhuma (usa WebKit nativo) |
| Linux | libwebkit2gtk-4.1 (geralmente pré-instalado em desktops modernos) |
Modo portátil
O OxideTerm suporta um modo portátil totalmente autônomo — todos os dados (conexões, segredos, configurações) são armazenados ao lado do binário do aplicativo, ideal para pen drives USB ou ambientes offline.
Ativação
Opção A — Arquivo marcador (mais simples): crie um arquivo vazio chamado portable (sem extensão) ao lado do aplicativo.
| Plataforma | Onde colocar o arquivo portable |
|---|---|
| macOS | Ao lado de OxideTerm.app (mesmo diretório) |
| Windows | Ao lado de OxideTerm.exe |
| Linux (AppImage) | Ao lado do arquivo .AppImage |
/my-usb/
├── OxideTerm.app (or .exe / .AppImage)
├── portable ← arquivo vazio criado por você
└── data/ ← criado automaticamente na primeira execução
Opção B — portable.json (diretório de dados personalizado): coloque um arquivo portable.json no mesmo local:
{
"enabled": true,
"dataDir": "my-data"
}
enabledétruepor padrão quando omitidodataDirdeve ser um caminho relativo (..não permitido); padrão édata
Como funciona
- Primeira execução — A tela de bootstrap solicita que você crie uma senha portátil. Essa senha criptografa o cofre de chaves local (ChaCha20-Poly1305 + Argon2id) e protege todos os segredos salvos.
- Execuções posteriores — Digite a senha para desbloquear. No macOS com Touch ID, você pode ativar o desbloqueio biométrico em Settings → General → Portable Runtime.
- Bloqueio de instância — Apenas uma instância do OxideTerm pode usar o diretório portátil por vez (
data/.portable.lock). - Gerenciamento — Altere a senha portátil ou ative o desbloqueio biométrico em Settings → General → Portable Runtime.
- Portabilidade — Copie a pasta inteira (aplicativo + marcador
portable+data/) para outra máquina. A senha acompanha o cofre de chaves.
Tip
As atualizações automáticas são desativadas no modo portátil. Para atualizar, substitua o binário do aplicativo mantendo o diretório data/.
Início rápido
Pré-requisitos
- Rust 1.85+
- Node.js 18+ (pnpm recomendado)
- Ferramentas de plataforma:
- macOS: Xcode Command Line Tools
- Windows: Visual Studio C++ Build Tools
- Linux:
build-essential,libwebkit2gtk-4.1-dev,libssl-dev
Desenvolvimento
git clone https://github.com/AnalyseDeCircuit/oxideterm.git
cd oxideterm && pnpm install
# Compilar o CLI companion (necessário para recursos CLI)
pnpm cli:build
# App completa (frontend + backend Rust com hot reload)
pnpm run tauri dev
# Apenas frontend (Vite na porta 1420)
pnpm dev
# Build de produção
pnpm run tauri build
Stack tecnológico
| Camada | Tecnologia | Detalhes |
|---|---|---|
| Framework | Tauri 2.0 | Binário nativo, 25–40 MB |
| Runtime | Tokio + DashMap 6 | Totalmente assíncrono, mapas concorrentes sem lock |
| SSH | russh 0.59 (ring) | Puro Rust, zero dependências C, SSH Agent |
| PTY local | portable-pty 0.8 | Feature-gated, ConPTY no Windows |
| Frontend | React 19.1 + TypeScript 5.8 | Vite 7, Tailwind CSS 4 |
| Estado | Zustand 5 | 19 stores especializados |
| Terminal | xterm.js 6 + WebGL | Acelerado por GPU, 60 fps+ |
| Editor | CodeMirror 6 | 30+ modos de linguagem |
| Criptografia | ChaCha20-Poly1305 + Argon2id | AEAD + KDF com alto consumo de memória (256 MB) |
| Armazenamento | redb 2.1 | Store KV embarcado |
| i18n | i18next 25 | 11 idiomas × 22 namespaces |
| Plugins | ESM Runtime | PluginContext congelado + 24 UI Kit |
| CLI | JSON-RPC 2.0 | Unix Socket / Named Pipe |
Tamanho do projeto
Medido com tokei, excluindo dependências e artefatos de build.
| Métrica | Tamanho atual |
|---|---|
| Código total | 286K+ |
| TypeScript / TSX | 130K+ |
| Rust | 100K+ |
| Código de testes frontend | 24K+ |
| Arquivos de testes frontend | 128 |
Arquivos fonte (src + src-tauri/src) | 664 |
Segurança
| Aspecto | Implementação |
|---|---|
| Senhas | Chaveiro do SO (macOS Keychain / Windows Credential Manager / libsecret) |
| Cofre de chaves portátil | Cofre criptografado com ChaCha20-Poly1305 ao lado do aplicativo, vinculação biométrica opcional via chaveiro do SO |
| Chaves API IA | Chaveiro do SO + autenticação biométrica Touch ID no macOS |
| Exportação | .oxide: ChaCha20-Poly1305 + Argon2id (256 MB de memória, 4 iterações) |
| Memória | Segurança de memória do Rust + zeroize para limpeza de dados sensíveis |
| Chaves do host | TOFU com ~/.ssh/known_hosts, rejeita alterações (prevenção MITM) |
| Plugins | Object.freeze + ACL Proxy, circuit breaker, whitelist IPC |
| WebSocket | Tokens de uso único com limites de tempo |
Roteiro
- Encaminhamento de agente SSH
- Suporte completo a ProxyCommand
- Registro de auditoria
- Melhorias no Agent
- Busca de sessões e troca rápida
- Migração nativa para Rust via GPUI — [em andamento]
Suporte e manutenção
O OxideTerm é mantido por um desenvolvedor independente com base no melhor esforço. Relatos de bugs e regressões reproduzíveis têm prioridade; solicitações de funcionalidades são bem-vindas, mas nem sempre serão implementadas.
Se o OxideTerm ajuda seu fluxo de trabalho, uma estrela no GitHub, uma reprodução de issue, uma correção de tradução, um plugin ou um pull request ajudam o projeto a continuar avançando.
Licença
GPL-3.0 — este software é software livre licenciado sob a Licença Pública Geral GNU v3.0.
Você é livre para usar, modificar e distribuir este software sob os termos da GPL-3.0. Qualquer trabalho derivado também deve ser distribuído sob a mesma licença.
O OxideTerm mudou de PolyForm Noncommercial 1.0.0 para GPL-3.0 a partir da v1.0.0. A mudança foi deliberada: nada de cosplay "open source" com armadilhas não comerciais ou cláusulas de não concorrência, apenas liberdade copyleft clara para usuários, forks, redistribuidores e operadores comerciais.
Código público não é automaticamente open source. Se um projeto exibe uma licença conhecida de código aberto, mas adiciona cláusulas como "sem redistribuição", "sem reempacotamento", "sem produtos concorrentes" ou "sem plataformas de distribuição não autorizadas", isso se parece mais com marketing source-available do que com a liberdade que usuários esperam do open source. O OxideTerm não adiciona cláusulas de não concorrência ou anti-redistribuição: os termos da GPL-3.0 são todos os termos.
Texto completo: Licença Pública Geral GNU v3.0
Agradecimentos
russh · portable-pty · Tauri · xterm.js · CodeMirror · Radix UI
271.000+ linhas de Rust e TypeScript — construído com ⚡ e ☕














