Se você quer um workspace SSH local-first sem Electron, telemetria ou assinaturas, dê uma estrela ao OxideTerm para que mais usuários de SSH o encontrem.
Workspace SSH local-first: shell, SFTP, encaminhamento de portas, trzsz, edição leve e IA BYOK ao redor de um nó remoto.
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
ai-terminal-demo.mp4
🤖 OxideSens AI — controle terminais ativos e ferramentas do workspace a partir de um único assistente.
| Problema | A resposta do OxideTerm |
|---|---|
| Workspace SSH, não apenas shell | Workspace de nó remoto: terminais, SFTP, encaminhamento de portas, trzsz, IDE leve, monitoramento e contexto de IA ficam sob o mesmo nó |
| Você também quer um shell local | Shell local integrado: zsh/bash/fish/pwsh/WSL2 lado a lado com sessões SSH, para tarefas locais e remotas na mesma UI |
| Reconexão = perder tudo | Reconexão com período de carência: sonda a conexão antiga por 30 s antes de encerrá-la — seus vim/htop/yazi sobrevivem |
| Você não quer instalar uma IDE remota pesada | Edição leve integrada: CodeMirror 6 sobre SFTP, com agente Linux opcional (~1 MB) apenas quando operações de arquivo mais rápidas forem necessárias |
| Sem reutilização de conexão SSH | Multiplexação: terminal, SFTP, encaminhamentos, IDE compartilham uma única conexão SSH via pool com contagem de referências |
| Bibliotecas SSH dependem do OpenSSL | russh 0.59: SSH puro em Rust compilado com ring — zero dependências C |
| Você não quer Electron | Tauri 2.0: backend Rust nativo, binário de 25–40 MB |
| Você não quer telemetria ou assinatura do app | Zero rastreamento, zero assinatura para os workflows SSH centrais: SSH/SFTP/encaminhamento de portas/shell local não exigem conta ou assinatura; os dados ficam no seu dispositivo por padrão; sincronização em nuvem é opcional via plugin oficial |
| Você quer IA sem conta da plataforma | OxideSens BYOK-first: use sua própria chave OpenAI/Ollama/DeepSeek/compatível; o OxideTerm não vende créditos de IA nem planos de nuvem |
| Credenciais em arquivos de configuração em texto simples | Criptografado em repouso: senhas e chaves de API permanecem no chaveiro do sistema, os metadados das conexões salvas são selados localmente e os arquivos .oxide usam ChaCha20-Poly1305 + Argon2id |
OxideTerm é um workspace SSH local-first: abra um nó remoto uma vez e trabalhe no mesmo lugar com shell, arquivos, portas, transferências integradas, edição leve e contexto de IA.
OxideTerm não é uma plataforma de IA em nuvem, um serviço de Agent hospedado, uma caixa de ferramentas para todo protocolo remoto, nem um projeto cujo objetivo principal seja benchmark de renderização de terminal. Muitos terminais modernos evoluem em torno de shells locais, painéis de IA ou plataformas de Agent em nuvem; o OxideTerm se concentra no workspace SSH local-first.
Terminal SSH + OxideSens AI![]() |
Gerenciador de arquivos SFTP![]() |
IDE integrado (CodeMirror 6)![]() |
Encaminhamento de portas inteligente![]() |
Baixe a versão mais recente em GitHub Releases.
| Categoria | Funcionalidades |
|---|---|
| Terminal | PTY local (zsh/bash/fish/pwsh/WSL2), SSH remoto, 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 |
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.
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
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.
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
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 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
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
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
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.
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
- 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
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
- 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
- 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
| 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 |
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) |
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.
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
- 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/.
- 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
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| 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 |
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 |
| 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 |
- 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]
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.
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
russh · portable-pty · Tauri · xterm.js · CodeMirror · Radix UI
271.000+ linhas de Rust e TypeScript — construído com ⚡ e ☕














