README.pt-BR.md

June 2, 2026 · View on GitHub

OxideTerm

⚡ 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.

Versão Plataforma Licença Rust Tauri Total de downloads

Baixar última versão Baixar última beta

🌐 oxideterm.app — Documentation & website

English | 简体中文 | 繁體中文 | 日本語 | 한국어 | Français | Deutsch | Español | Italiano | Português | Tiếng Việt

OxideTerm AI opening a terminal demo

Veja o OxideSens seguir uma solicitação do usuário e abrir um terminal dentro do OxideTerm.


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 ferramentasTerminal, SFTP, port forwarding, trzsz, mini IDE, monitoramento e contexto de IA ficam no mesmo workspace SSH
Workflows SSH local-firstSSH, 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 plataformaOxideSens usa seu endpoint OpenAI/Ollama/DeepSeek/OpenAI-compatible com suporte a MCP e RAG
Reconexão estávelGrace 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 puroApp Tauri 2.0 nativo, russh 0.59 compilado com ring, sem Electron e sem OpenSSL/libssh2
Segurança de credenciaisSenhas 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

Terminal SSH com barra lateral OxideSens AI
Gerenciador de arquivos SFTP

Gerenciador de arquivos SFTP de painel duplo com fila de transferência
IDE integrado (CodeMirror 6)

Modo IDE integrado com editor CodeMirror 6
Encaminhamento de portas inteligente

Encaminhamento de portas inteligente com detecção automática

Download

Baixe a versão mais recente em GitHub Releases.


Visão geral das funcionalidades

CategoriaFuncionalidades
TerminalPTY 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çãoPool 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
SFTPNavegador 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 IDECodeMirror 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 portasLocal (-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
PluginsCarregamento 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
CLICompanion 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çaExportaçã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
i18n11 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 sessionId nem connectionId. Tudo é endereçado por nodeId, resolvido atomicamente no servidor pelo NodeRouter. A reconexão SSH altera o connectionId subjacente — 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
  • AgentSigner personalizado: encapsula o SSH Agent do sistema e implementa o trait Signer do russh, resolvendo problemas de bounds Send RPITIT ao clonar &AgentIdentity para 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::Agent reproduzido 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:

  1. Detecção do timeout de heartbeat WebSocket (300 s, calibrado para macOS App Nap e throttling de timers JS)
  2. Snapshot do estado completo: painéis do terminal, transferências SFTP em andamento, encaminhamentos de portas ativos, arquivos IDE abertos
  3. Sondagem inteligente: eventos visibilitychange + online disparam keepalive SSH proativo (~2 s de detecção contra 15–30 s de timeout passivo)
  4. 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
  5. 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_down com sincronização de status
  • Desconexão por inatividade: emite connection_status_changed para o frontend (não apenas node:state interno), 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 — sem Arc<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 Suspended retomados 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; trz inicia 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.freeze em 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ívelGatilhoFrequênciaBenefício
BoostDados de frame ≥ 4 KB120 Hz+ (ProMotion nativo)Elimina lag de rolagem em cat largefile.log
NormalDigitação padrão60 Hz (RAF)Base fluida
Inativo3 s sem I/O / aba oculta1–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:

  • MasterPty envolvido em std::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-features remove 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

PluginDescriçãoRepositório
Cloud SyncSincronização auto-hospedada criptografada — faça upload e importe snapshots .oxide via WebDAV, HTTP JSON, Dropbox, Git ou S3oxideterm.cloud-sync
Telnet ClientCliente Telnet nativo para roteadores, switches e dispositivos legados — sem necessidade de binário externooxideterm.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.

PlataformaDependência de runtime
WindowsWebView2 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.
macOSNenhuma (usa WebKit nativo)
Linuxlibwebkit2gtk-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.

PlataformaOnde colocar o arquivo portable
macOSAo lado de OxideTerm.app (mesmo diretório)
WindowsAo 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 é true por padrão quando omitido
  • dataDir deve ser um caminho relativo (.. não permitido); padrão é data

Como funciona

  1. 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.
  2. 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.
  3. Bloqueio de instância — Apenas uma instância do OxideTerm pode usar o diretório portátil por vez (data/.portable.lock).
  4. Gerenciamento — Altere a senha portátil ou ative o desbloqueio biométrico em Settings → General → Portable Runtime.
  5. 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

CamadaTecnologiaDetalhes
FrameworkTauri 2.0Binário nativo, 25–40 MB
RuntimeTokio + DashMap 6Totalmente assíncrono, mapas concorrentes sem lock
SSHrussh 0.59 (ring)Puro Rust, zero dependências C, SSH Agent
PTY localportable-pty 0.8Feature-gated, ConPTY no Windows
FrontendReact 19.1 + TypeScript 5.8Vite 7, Tailwind CSS 4
EstadoZustand 519 stores especializados
Terminalxterm.js 6 + WebGLAcelerado por GPU, 60 fps+
EditorCodeMirror 630+ modos de linguagem
CriptografiaChaCha20-Poly1305 + Argon2idAEAD + KDF com alto consumo de memória (256 MB)
Armazenamentoredb 2.1Store KV embarcado
i18ni18next 2511 idiomas × 22 namespaces
PluginsESM RuntimePluginContext congelado + 24 UI Kit
CLIJSON-RPC 2.0Unix Socket / Named Pipe

Tamanho do projeto

Medido com tokei, excluindo dependências e artefatos de build.

MétricaTamanho atual
Código total286K+
TypeScript / TSX130K+
Rust100K+
Código de testes frontend24K+
Arquivos de testes frontend128
Arquivos fonte (src + src-tauri/src)664

Segurança

AspectoImplementação
SenhasChaveiro do SO (macOS Keychain / Windows Credential Manager / libsecret)
Cofre de chaves portátilCofre criptografado com ChaCha20-Poly1305 ao lado do aplicativo, vinculação biométrica opcional via chaveiro do SO
Chaves API IAChaveiro 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óriaSegurança de memória do Rust + zeroize para limpeza de dados sensíveis
Chaves do hostTOFU com ~/.ssh/known_hosts, rejeita alterações (prevenção MITM)
PluginsObject.freeze + ACL Proxy, circuit breaker, whitelist IPC
WebSocketTokens 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 ☕

Star History

Star History Chart