add github page

This commit is contained in:
Eduardo Silva
2026-03-18 22:17:13 -03:00
parent 35fa484972
commit 30074e5bd6
64 changed files with 705 additions and 10 deletions

View File

@@ -0,0 +1,11 @@
<!doctype html><html lang=pt-BR><head><meta charset=UTF-8><meta name=viewport content="width=device-width,initial-scale=1"><title>Categories · wireguard_webadmin</title><meta name=description content="Self-hosted VPN management and Zero Trust access control."><link rel=alternate hreflang=en-us href=https://wireguard-webadmin.com/categories/><link rel=alternate hreflang=pt-BR href=https://wireguard-webadmin.com/pt-br/categories/><link rel=alternate hreflang=es href=https://wireguard-webadmin.com/es/categories/><link rel=alternate hreflang=fr href=https://wireguard-webadmin.com/fr/categories/><link rel=alternate hreflang=de href=https://wireguard-webadmin.com/de/categories/><link rel=alternate hreflang=x-default href=https://wireguard-webadmin.com/><meta property="og:type" content="website"><meta property="og:url" content="https://wireguard-webadmin.com/pt-br/categories/"><meta property="og:title" content="Categories · wireguard_webadmin"><meta property="og:description" content="Self-hosted VPN management and Zero Trust access control."><meta property="og:image" content="https://wireguard-webadmin.com/og-image.png"><meta property="og:image:width" content="1280"><meta property="og:image:height" content="800"><meta name=twitter:card content="summary_large_image"><meta name=twitter:title content="Categories · wireguard_webadmin"><meta name=twitter:description content="Self-hosted VPN management and Zero Trust access control."><meta name=twitter:image content="https://wireguard-webadmin.com/og-image.png"><link rel=icon type=image/svg+xml href=/favicon.svg><link rel=preconnect href=https://fonts.googleapis.com><link rel=preconnect href=https://fonts.gstatic.com crossorigin><link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap" rel=stylesheet><link rel=stylesheet href=/css/main.min.css></head><body><header class=site-header><div class=container><nav class=nav-inner><a href=/pt-br/ class=nav-logo>wireguard_<span>webadmin</span></a>
<button class=hamburger aria-label="Toggle menu" aria-expanded=false>
<span></span><span></span><span></span></button><ul class=nav-links><li><a href=/pt-br/>Início</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Instalação</a></li><li><a href=/pt-br/get-involved/>Contribua</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener class=nav-github><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 0C5.374.0.0 5.373.0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931.0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176.0.0 1.008-.322 3.301 1.23A11.509 11.509.0 0112 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221.0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z"/></svg>
GitHub</a></li><li class=nav-lang-sep></li><li class=lang-dropdown><button class=lang-btn aria-expanded=false>
🇧🇷 PT
<svg width="10" height="10" viewBox="0 0 10 10" fill="currentColor"><path d="M2 3.5l3 3 3-3" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" fill="none"/></svg></button><ul class=lang-menu><li><a href=/categories/ hreflang=en><span class=lang-flag>🇬🇧</span>
<span>English</span></a></li><li><a href=/pt-br/categories/ hreflang=pt-br class=lang-active><span class=lang-flag>🇧🇷</span>
<span>Português</span></a></li><li><a href=/es/categories/ hreflang=es><span class=lang-flag>🇪🇸</span>
<span>Español</span></a></li><li><a href=/fr/categories/ hreflang=fr><span class=lang-flag>🇫🇷</span>
<span>Français</span></a></li><li><a href=/de/categories/ hreflang=de><span class=lang-flag>🇩🇪</span>
<span>Deutsch</span></a></li></ul></li></ul></nav></div></header><main><div class=container style="padding:4rem 0"><h1>Categories</h1></div></main><footer class=site-footer><div class=container><div class=footer-inner><div class=footer-logo>wireguard_<span>webadmin</span></div><ul class=footer-links><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener>GitHub</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin/discussions target=_blank rel=noopener>Discussions</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Deployment</a></li><li><a href=/pt-br/get-involved/>Get Involved</a></li></ul><div class=footer-built>desenvolvido por <a href=https://github.com/eduardogsilva target=_blank rel=noopener>@eduardogsilva</a></div></div></div></footer><script>document.querySelectorAll(".tab-btn").forEach(e=>{e.addEventListener("click",()=>{const t=e.closest(".tab-group");t.querySelectorAll(".tab-btn").forEach(e=>e.classList.remove("active")),t.querySelectorAll(".tab-panel").forEach(e=>e.classList.remove("active")),e.classList.add("active"),t.querySelector("#"+e.dataset.tab).classList.add("active")})});const hamburger=document.querySelector(".hamburger"),navLinks=document.querySelector(".nav-links");hamburger&&(hamburger.addEventListener("click",e=>{e.stopPropagation();const t=navLinks.classList.toggle("open");hamburger.classList.toggle("open",t),hamburger.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{!navLinks.contains(e.target)&&!hamburger.contains(e.target)&&(navLinks.classList.remove("open"),hamburger.classList.remove("open"),hamburger.setAttribute("aria-expanded",!1))}));const langBtn=document.querySelector(".lang-btn"),langDropdown=document.querySelector(".lang-dropdown");if(langBtn&&(langBtn.addEventListener("click",e=>{e.stopPropagation();const t=langDropdown.classList.toggle("open");langBtn.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{langDropdown.contains(e.target)||(langDropdown.classList.remove("open"),langBtn.setAttribute("aria-expanded",!1))}),langDropdown.querySelectorAll(".lang-menu a").forEach(e=>{e.addEventListener("click",()=>localStorage.setItem("lang-manual","1"))})),location.pathname==="/"&&!localStorage.getItem("lang-manual")){const t=(navigator.language||navigator.userLanguage||"en").toLowerCase(),n=[{prefix:"pt",url:"/pt-br/"},{prefix:"es",url:"/es/"},{prefix:"fr",url:"/fr/"},{prefix:"de",url:"/de/"}],e=n.find(e=>t.startsWith(e.prefix));e&&location.replace(e.url)}</script></body></html>

View File

@@ -0,0 +1 @@
<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Categories on wireguard_webadmin</title><link>https://wireguard-webadmin.com/pt-br/categories/</link><description>Recent content in Categories on wireguard_webadmin</description><generator>Hugo</generator><language>pt-BR</language><atom:link href="https://wireguard-webadmin.com/pt-br/categories/index.xml" rel="self" type="application/rss+xml"/></channel></rss>

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,11 @@
<!doctype html><html lang=pt-BR><head><meta charset=UTF-8><meta name=viewport content="width=device-width,initial-scale=1"><title>Participe · wireguard_webadmin</title><meta name=description content="Formas de contribuir com o wireguard_webadmin: reportar bugs, escrever código ou simplesmente divulgar o projeto."><link rel=alternate hreflang=en-us href=https://wireguard-webadmin.com/get-involved/><link rel=alternate hreflang=pt-BR href=https://wireguard-webadmin.com/pt-br/get-involved/><link rel=alternate hreflang=es href=https://wireguard-webadmin.com/es/get-involved/><link rel=alternate hreflang=fr href=https://wireguard-webadmin.com/fr/get-involved/><link rel=alternate hreflang=de href=https://wireguard-webadmin.com/de/get-involved/><link rel=alternate hreflang=x-default href=https://wireguard-webadmin.com/><meta property="og:type" content="website"><meta property="og:url" content="https://wireguard-webadmin.com/pt-br/get-involved/"><meta property="og:title" content="Participe · wireguard_webadmin"><meta property="og:description" content="Formas de contribuir com o wireguard_webadmin: reportar bugs, escrever código ou simplesmente divulgar o projeto."><meta property="og:image" content="https://wireguard-webadmin.com/og-image.png"><meta property="og:image:width" content="1280"><meta property="og:image:height" content="800"><meta name=twitter:card content="summary_large_image"><meta name=twitter:title content="Participe · wireguard_webadmin"><meta name=twitter:description content="Formas de contribuir com o wireguard_webadmin: reportar bugs, escrever código ou simplesmente divulgar o projeto."><meta name=twitter:image content="https://wireguard-webadmin.com/og-image.png"><link rel=icon type=image/svg+xml href=/favicon.svg><link rel=preconnect href=https://fonts.googleapis.com><link rel=preconnect href=https://fonts.gstatic.com crossorigin><link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap" rel=stylesheet><link rel=stylesheet href=/css/main.min.css></head><body><header class=site-header><div class=container><nav class=nav-inner><a href=/pt-br/ class=nav-logo>wireguard_<span>webadmin</span></a>
<button class=hamburger aria-label="Toggle menu" aria-expanded=false>
<span></span><span></span><span></span></button><ul class=nav-links><li><a href=/pt-br/>Início</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Instalação</a></li><li><a href=/pt-br/get-involved/ aria-current=page>Contribua</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener class=nav-github><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 0C5.374.0.0 5.373.0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931.0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176.0.0 1.008-.322 3.301 1.23A11.509 11.509.0 0112 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221.0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z"/></svg>
GitHub</a></li><li class=nav-lang-sep></li><li class=lang-dropdown><button class=lang-btn aria-expanded=false>
🇧🇷 PT
<svg width="10" height="10" viewBox="0 0 10 10" fill="currentColor"><path d="M2 3.5l3 3 3-3" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" fill="none"/></svg></button><ul class=lang-menu><li><a href=/get-involved/ hreflang=en><span class=lang-flag>🇬🇧</span>
<span>English</span></a></li><li><a href=/pt-br/get-involved/ hreflang=pt-br class=lang-active><span class=lang-flag>🇧🇷</span>
<span>Português</span></a></li><li><a href=/es/get-involved/ hreflang=es><span class=lang-flag>🇪🇸</span>
<span>Español</span></a></li><li><a href=/fr/get-involved/ hreflang=fr><span class=lang-flag>🇫🇷</span>
<span>Français</span></a></li><li><a href=/de/get-involved/ hreflang=de><span class=lang-flag>🇩🇪</span>
<span>Deutsch</span></a></li></ul></li></ul></nav></div></header><main><section class=page-hero><div class=container><div class=section-label>Open Source</div><h1>Participe</h1><p class=section-sub style=margin-top:1rem>wireguard_webadmin é desenvolvido de forma aberta. Toda contribuição ajuda, independentemente do tamanho.</p></div></section><div class=page-content><div class=container><div class=involve-grid><div class="involve-card involve-card--highlight"><div class=involve-card-icon></div><h3>Dê uma estrela ao repositório</h3><p>É a coisa mais simples que você pode fazer. Isso ajuda o projeto a ser descoberto por outros sysadmins que estão procurando exatamente algo assim.</p><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener class="btn btn-primary">Dar estrela no GitHub</a></div><div class=involve-card><div class=involve-card-icon>🐛</div><h3>Reporte bugs</h3><p>Encontrou algo quebrado? Abra uma issue no GitHub. Não precisa de template: basta descrever o que você viu e como reproduzir.</p><a href=https://github.com/eduardogsilva/wireguard_webadmin/issues target=_blank rel=noopener class="btn btn-outline">Abrir uma issue</a></div><div class=involve-card><div class=involve-card-icon>🔧</div><h3>Contribua com código</h3><p>Pull requests são bem-vindos. Para qualquer coisa que não seja trivial, abra uma issue antes para alinharmos o caminho antes de você investir tempo escrevendo código. Bons pontos de partida: issues marcadas com <code>good first issue</code>, correções com um caso de reprodução claro e cobertura de testes.</p><a href=https://github.com/eduardogsilva/wireguard_webadmin/pulls target=_blank rel=noopener class="btn btn-outline">Ver PRs abertas</a></div><div class=involve-card><div class=involve-card-icon>💬</div><h3>Entre na discussão</h3><p>Está rodando uma configuração interessante? Encontrou um caso de borda? O GitHub Discussions é o lugar certo para perguntas, ideias e cenários de uso que não se encaixam bem em uma issue.</p><a href=https://github.com/eduardogsilva/wireguard_webadmin/discussions target=_blank rel=noopener class="btn btn-outline">Ir para Discussions</a></div></div><div class=involve-footer><h4>Espalhe a ideia</h4><p>Escreva um post. Compartilhe com o seu time. Mencione o projeto quando alguém perguntar como gerenciar WireGuard. Esse alcance orgânico vale mais do que qualquer campanha publicitária.</p></div></div></div></main><footer class=site-footer><div class=container><div class=footer-inner><div class=footer-logo>wireguard_<span>webadmin</span></div><ul class=footer-links><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener>GitHub</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin/discussions target=_blank rel=noopener>Discussions</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Deployment</a></li><li><a href=/pt-br/get-involved/>Get Involved</a></li></ul><div class=footer-built>desenvolvido por <a href=https://github.com/eduardogsilva target=_blank rel=noopener>@eduardogsilva</a></div></div></div></footer><script>document.querySelectorAll(".tab-btn").forEach(e=>{e.addEventListener("click",()=>{const t=e.closest(".tab-group");t.querySelectorAll(".tab-btn").forEach(e=>e.classList.remove("active")),t.querySelectorAll(".tab-panel").forEach(e=>e.classList.remove("active")),e.classList.add("active"),t.querySelector("#"+e.dataset.tab).classList.add("active")})});const hamburger=document.querySelector(".hamburger"),navLinks=document.querySelector(".nav-links");hamburger&&(hamburger.addEventListener("click",e=>{e.stopPropagation();const t=navLinks.classList.toggle("open");hamburger.classList.toggle("open",t),hamburger.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{!navLinks.contains(e.target)&&!hamburger.contains(e.target)&&(navLinks.classList.remove("open"),hamburger.classList.remove("open"),hamburger.setAttribute("aria-expanded",!1))}));const langBtn=document.querySelector(".lang-btn"),langDropdown=document.querySelector(".lang-dropdown");if(langBtn&&(langBtn.addEventListener("click",e=>{e.stopPropagation();const t=langDropdown.classList.toggle("open");langBtn.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{langDropdown.contains(e.target)||(langDropdown.classList.remove("open"),langBtn.setAttribute("aria-expanded",!1))}),langDropdown.querySelectorAll(".lang-menu a").forEach(e=>{e.addEventListener("click",()=>localStorage.setItem("lang-manual","1"))})),location.pathname==="/"&&!localStorage.getItem("lang-manual")){const t=(navigator.language||navigator.userLanguage||"en").toLowerCase(),n=[{prefix:"pt",url:"/pt-br/"},{prefix:"es",url:"/es/"},{prefix:"fr",url:"/fr/"},{prefix:"de",url:"/de/"}],e=n.find(e=>t.startsWith(e.prefix));e&&location.replace(e.url)}</script></body></html>

14
docs/pt-br/index.html Normal file

File diff suppressed because one or more lines are too long

49
docs/pt-br/index.xml Normal file
View File

@@ -0,0 +1,49 @@
<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>wireguard_webadmin</title><link>https://wireguard-webadmin.com/pt-br/</link><description>Recent content on wireguard_webadmin</description><generator>Hugo</generator><language>pt-BR</language><atom:link href="https://wireguard-webadmin.com/pt-br/index.xml" rel="self" type="application/rss+xml"/><item><title>Gateway de Aplicações Zero Trust</title><link>https://wireguard-webadmin.com/pt-br/zero-trust/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://wireguard-webadmin.com/pt-br/zero-trust/</guid><description>&lt;h2 id="o-que-significa-zero-trust-aqui"&gt;O que significa Zero Trust aqui?&lt;/h2&gt;
&lt;p&gt;A segurança de rede tradicional assume que tudo o que está dentro da sua rede pode ser confiável.
Zero Trust inverte esse modelo: &lt;strong&gt;nenhuma requisição é confiável por padrão&lt;/strong&gt;, mesmo que venha de dentro da VPN.&lt;/p&gt;
&lt;p&gt;No wireguard_webadmin, o gateway de aplicações Zero Trust fica na frente dos seus serviços internos.
Toda requisição precisa se autenticar antes de chegar à aplicação, e o serviço em si nunca precisa ser exposto diretamente.&lt;/p&gt;</description></item><item><title>Guia de Deploy</title><link>https://wireguard-webadmin.com/pt-br/deployment/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://wireguard-webadmin.com/pt-br/deployment/</guid><description>&lt;h2 id="pré-requisitos"&gt;Pré-requisitos&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;Um servidor Linux acessível a partir de onde você vai administrá-lo&lt;/li&gt;
&lt;li&gt;&lt;a href="https://docs.docker.com/engine/install/"&gt;Docker&lt;/a&gt; e &lt;a href="https://docs.docker.com/compose/install/"&gt;Docker Compose&lt;/a&gt; instalados&lt;/li&gt;
&lt;li&gt;Um nome de domínio apontando para o IP do seu servidor&lt;/li&gt;
&lt;li&gt;Portas &lt;strong&gt;80&lt;/strong&gt; e &lt;strong&gt;443&lt;/strong&gt; abertas para o Caddy, além da porta UDP do WireGuard aberta (padrão &lt;strong&gt;51820&lt;/strong&gt;)&lt;/li&gt;
&lt;/ul&gt;
&lt;div class="callout"&gt;
&lt;p&gt;&lt;strong&gt;O Caddy precisa de um nome DNS válido&lt;/strong&gt;, interno ou público, apontando para o seu servidor para conseguir obter e renovar certificados SSL automaticamente.&lt;/p&gt;
&lt;/div&gt;
&lt;hr&gt;
&lt;h2 id="deploy"&gt;Deploy&lt;/h2&gt;
&lt;div class="tab-group"&gt;
&lt;div class="tabs"&gt;
&lt;button class="tab-btn active" data-tab="dep-step-1"&gt;1. Criar diretório&lt;/button&gt;
&lt;button class="tab-btn" data-tab="dep-step-2"&gt;2. Baixar arquivo compose&lt;/button&gt;
&lt;button class="tab-btn" data-tab="dep-step-3"&gt;3. Configurar .env&lt;/button&gt;
&lt;button class="tab-btn" data-tab="dep-step-4"&gt;4. Executar&lt;/button&gt;
&lt;/div&gt;
&lt;div class="tab-wrap"&gt;
&lt;div class="tab-panel active" id="dep-step-1"&gt;
&lt;pre&gt;&lt;code&gt;mkdir wireguard_webadmin &amp;&amp; cd wireguard_webadmin&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;
&lt;div class="tab-panel" id="dep-step-2"&gt;
&lt;pre&gt;&lt;code&gt;wget -O docker-compose.yml \
https://raw.githubusercontent.com/eduardogsilva/wireguard_webadmin/main/docker-compose-caddy.yml&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;
&lt;div class="tab-panel" id="dep-step-3"&gt;
&lt;p&gt;Crie um arquivo &lt;code&gt;.env&lt;/code&gt; no mesmo diretório. Defina &lt;code&gt;SERVER_ADDRESS&lt;/code&gt; com o seu domínio:&lt;/p&gt;</description></item><item><title>Participe</title><link>https://wireguard-webadmin.com/pt-br/get-involved/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://wireguard-webadmin.com/pt-br/get-involved/</guid><description>&lt;div class="involve-grid"&gt;
&lt;div class="involve-card involve-card--highlight"&gt;
&lt;div class="involve-card-icon"&gt;&lt;/div&gt;
&lt;h3&gt;Dê uma estrela ao repositório&lt;/h3&gt;
&lt;p&gt;É a coisa mais simples que você pode fazer. Isso ajuda o projeto a ser descoberto por outros sysadmins que estão procurando exatamente algo assim.&lt;/p&gt;
&lt;a href="https://github.com/eduardogsilva/wireguard_webadmin" target="_blank" rel="noopener" class="btn btn-primary"&gt;Dar estrela no GitHub&lt;/a&gt;
&lt;/div&gt;
&lt;div class="involve-card"&gt;
&lt;div class="involve-card-icon"&gt;🐛&lt;/div&gt;
&lt;h3&gt;Reporte bugs&lt;/h3&gt;
&lt;p&gt;Encontrou algo quebrado? Abra uma issue no GitHub. Não precisa de template: basta descrever o que você viu e como reproduzir.&lt;/p&gt;
&lt;a href="https://github.com/eduardogsilva/wireguard_webadmin/issues" target="_blank" rel="noopener" class="btn btn-outline"&gt;Abrir uma issue&lt;/a&gt;
&lt;/div&gt;
&lt;div class="involve-card"&gt;
&lt;div class="involve-card-icon"&gt;🔧&lt;/div&gt;
&lt;h3&gt;Contribua com código&lt;/h3&gt;
&lt;p&gt;Pull requests são bem-vindos. Para qualquer coisa que não seja trivial, abra uma issue antes para alinharmos o caminho antes de você investir tempo escrevendo código. Bons pontos de partida: issues marcadas com &lt;code&gt;good first issue&lt;/code&gt;, correções com um caso de reprodução claro e cobertura de testes.&lt;/p&gt;</description></item></channel></rss>

1
docs/pt-br/sitemap.xml Normal file
View File

@@ -0,0 +1 @@
<?xml version="1.0" encoding="utf-8" standalone="yes"?><urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:xhtml="http://www.w3.org/1999/xhtml"><url><loc>https://wireguard-webadmin.com/pt-br/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/"/></url><url><loc>https://wireguard-webadmin.com/pt-br/categories/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/categories/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/categories/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/categories/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/categories/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/categories/"/></url><url><loc>https://wireguard-webadmin.com/pt-br/zero-trust/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/zero-trust/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/zero-trust/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/zero-trust/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/zero-trust/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/zero-trust/"/></url><url><loc>https://wireguard-webadmin.com/pt-br/deployment/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/deployment/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/deployment/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/deployment/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/deployment/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/deployment/"/></url><url><loc>https://wireguard-webadmin.com/pt-br/get-involved/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/get-involved/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/get-involved/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/get-involved/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/get-involved/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/get-involved/"/></url><url><loc>https://wireguard-webadmin.com/pt-br/tags/</loc><xhtml:link rel="alternate" hreflang="en-us" href="https://wireguard-webadmin.com/tags/"/><xhtml:link rel="alternate" hreflang="es" href="https://wireguard-webadmin.com/es/tags/"/><xhtml:link rel="alternate" hreflang="fr" href="https://wireguard-webadmin.com/fr/tags/"/><xhtml:link rel="alternate" hreflang="de" href="https://wireguard-webadmin.com/de/tags/"/><xhtml:link rel="alternate" hreflang="pt-BR" href="https://wireguard-webadmin.com/pt-br/tags/"/></url></urlset>

View File

@@ -0,0 +1,11 @@
<!doctype html><html lang=pt-BR><head><meta charset=UTF-8><meta name=viewport content="width=device-width,initial-scale=1"><title>Tags · wireguard_webadmin</title><meta name=description content="Self-hosted VPN management and Zero Trust access control."><link rel=alternate hreflang=en-us href=https://wireguard-webadmin.com/tags/><link rel=alternate hreflang=pt-BR href=https://wireguard-webadmin.com/pt-br/tags/><link rel=alternate hreflang=es href=https://wireguard-webadmin.com/es/tags/><link rel=alternate hreflang=fr href=https://wireguard-webadmin.com/fr/tags/><link rel=alternate hreflang=de href=https://wireguard-webadmin.com/de/tags/><link rel=alternate hreflang=x-default href=https://wireguard-webadmin.com/><meta property="og:type" content="website"><meta property="og:url" content="https://wireguard-webadmin.com/pt-br/tags/"><meta property="og:title" content="Tags · wireguard_webadmin"><meta property="og:description" content="Self-hosted VPN management and Zero Trust access control."><meta property="og:image" content="https://wireguard-webadmin.com/og-image.png"><meta property="og:image:width" content="1280"><meta property="og:image:height" content="800"><meta name=twitter:card content="summary_large_image"><meta name=twitter:title content="Tags · wireguard_webadmin"><meta name=twitter:description content="Self-hosted VPN management and Zero Trust access control."><meta name=twitter:image content="https://wireguard-webadmin.com/og-image.png"><link rel=icon type=image/svg+xml href=/favicon.svg><link rel=preconnect href=https://fonts.googleapis.com><link rel=preconnect href=https://fonts.gstatic.com crossorigin><link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap" rel=stylesheet><link rel=stylesheet href=/css/main.min.css></head><body><header class=site-header><div class=container><nav class=nav-inner><a href=/pt-br/ class=nav-logo>wireguard_<span>webadmin</span></a>
<button class=hamburger aria-label="Toggle menu" aria-expanded=false>
<span></span><span></span><span></span></button><ul class=nav-links><li><a href=/pt-br/>Início</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Instalação</a></li><li><a href=/pt-br/get-involved/>Contribua</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener class=nav-github><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 0C5.374.0.0 5.373.0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931.0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176.0.0 1.008-.322 3.301 1.23A11.509 11.509.0 0112 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221.0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z"/></svg>
GitHub</a></li><li class=nav-lang-sep></li><li class=lang-dropdown><button class=lang-btn aria-expanded=false>
🇧🇷 PT
<svg width="10" height="10" viewBox="0 0 10 10" fill="currentColor"><path d="M2 3.5l3 3 3-3" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" fill="none"/></svg></button><ul class=lang-menu><li><a href=/tags/ hreflang=en><span class=lang-flag>🇬🇧</span>
<span>English</span></a></li><li><a href=/pt-br/tags/ hreflang=pt-br class=lang-active><span class=lang-flag>🇧🇷</span>
<span>Português</span></a></li><li><a href=/es/tags/ hreflang=es><span class=lang-flag>🇪🇸</span>
<span>Español</span></a></li><li><a href=/fr/tags/ hreflang=fr><span class=lang-flag>🇫🇷</span>
<span>Français</span></a></li><li><a href=/de/tags/ hreflang=de><span class=lang-flag>🇩🇪</span>
<span>Deutsch</span></a></li></ul></li></ul></nav></div></header><main><div class=container style="padding:4rem 0"><h1>Tags</h1></div></main><footer class=site-footer><div class=container><div class=footer-inner><div class=footer-logo>wireguard_<span>webadmin</span></div><ul class=footer-links><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener>GitHub</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin/discussions target=_blank rel=noopener>Discussions</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Deployment</a></li><li><a href=/pt-br/get-involved/>Get Involved</a></li></ul><div class=footer-built>desenvolvido por <a href=https://github.com/eduardogsilva target=_blank rel=noopener>@eduardogsilva</a></div></div></div></footer><script>document.querySelectorAll(".tab-btn").forEach(e=>{e.addEventListener("click",()=>{const t=e.closest(".tab-group");t.querySelectorAll(".tab-btn").forEach(e=>e.classList.remove("active")),t.querySelectorAll(".tab-panel").forEach(e=>e.classList.remove("active")),e.classList.add("active"),t.querySelector("#"+e.dataset.tab).classList.add("active")})});const hamburger=document.querySelector(".hamburger"),navLinks=document.querySelector(".nav-links");hamburger&&(hamburger.addEventListener("click",e=>{e.stopPropagation();const t=navLinks.classList.toggle("open");hamburger.classList.toggle("open",t),hamburger.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{!navLinks.contains(e.target)&&!hamburger.contains(e.target)&&(navLinks.classList.remove("open"),hamburger.classList.remove("open"),hamburger.setAttribute("aria-expanded",!1))}));const langBtn=document.querySelector(".lang-btn"),langDropdown=document.querySelector(".lang-dropdown");if(langBtn&&(langBtn.addEventListener("click",e=>{e.stopPropagation();const t=langDropdown.classList.toggle("open");langBtn.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{langDropdown.contains(e.target)||(langDropdown.classList.remove("open"),langBtn.setAttribute("aria-expanded",!1))}),langDropdown.querySelectorAll(".lang-menu a").forEach(e=>{e.addEventListener("click",()=>localStorage.setItem("lang-manual","1"))})),location.pathname==="/"&&!localStorage.getItem("lang-manual")){const t=(navigator.language||navigator.userLanguage||"en").toLowerCase(),n=[{prefix:"pt",url:"/pt-br/"},{prefix:"es",url:"/es/"},{prefix:"fr",url:"/fr/"},{prefix:"de",url:"/de/"}],e=n.find(e=>t.startsWith(e.prefix));e&&location.replace(e.url)}</script></body></html>

View File

@@ -0,0 +1 @@
<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Tags on wireguard_webadmin</title><link>https://wireguard-webadmin.com/pt-br/tags/</link><description>Recent content in Tags on wireguard_webadmin</description><generator>Hugo</generator><language>pt-BR</language><atom:link href="https://wireguard-webadmin.com/pt-br/tags/index.xml" rel="self" type="application/rss+xml"/></channel></rss>

View File

@@ -0,0 +1,16 @@
<!doctype html><html lang=pt-BR><head><meta charset=UTF-8><meta name=viewport content="width=device-width,initial-scale=1"><title>Gateway de Aplicações Zero Trust · wireguard_webadmin</title><meta name=description content="Entenda como o wireguard_webadmin implementa controle de acesso Zero Trust para publicar com segurança aplicações internas como Grafana, Proxmox e outras."><link rel=alternate hreflang=en-us href=https://wireguard-webadmin.com/zero-trust/><link rel=alternate hreflang=pt-BR href=https://wireguard-webadmin.com/pt-br/zero-trust/><link rel=alternate hreflang=es href=https://wireguard-webadmin.com/es/zero-trust/><link rel=alternate hreflang=fr href=https://wireguard-webadmin.com/fr/zero-trust/><link rel=alternate hreflang=de href=https://wireguard-webadmin.com/de/zero-trust/><link rel=alternate hreflang=x-default href=https://wireguard-webadmin.com/><meta property="og:type" content="website"><meta property="og:url" content="https://wireguard-webadmin.com/pt-br/zero-trust/"><meta property="og:title" content="Gateway de Aplicações Zero Trust · wireguard_webadmin"><meta property="og:description" content="Entenda como o wireguard_webadmin implementa controle de acesso Zero Trust para publicar com segurança aplicações internas como Grafana, Proxmox e outras."><meta property="og:image" content="https://wireguard-webadmin.com/og-image.png"><meta property="og:image:width" content="1280"><meta property="og:image:height" content="800"><meta name=twitter:card content="summary_large_image"><meta name=twitter:title content="Gateway de Aplicações Zero Trust · wireguard_webadmin"><meta name=twitter:description content="Entenda como o wireguard_webadmin implementa controle de acesso Zero Trust para publicar com segurança aplicações internas como Grafana, Proxmox e outras."><meta name=twitter:image content="https://wireguard-webadmin.com/og-image.png"><link rel=icon type=image/svg+xml href=/favicon.svg><link rel=preconnect href=https://fonts.googleapis.com><link rel=preconnect href=https://fonts.gstatic.com crossorigin><link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap" rel=stylesheet><link rel=stylesheet href=/css/main.min.css></head><body><header class=site-header><div class=container><nav class=nav-inner><a href=/pt-br/ class=nav-logo>wireguard_<span>webadmin</span></a>
<button class=hamburger aria-label="Toggle menu" aria-expanded=false>
<span></span><span></span><span></span></button><ul class=nav-links><li><a href=/pt-br/>Início</a></li><li><a href=/pt-br/zero-trust/ aria-current=page>Zero Trust</a></li><li><a href=/pt-br/deployment/>Instalação</a></li><li><a href=/pt-br/get-involved/>Contribua</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener class=nav-github><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 0C5.374.0.0 5.373.0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931.0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176.0.0 1.008-.322 3.301 1.23A11.509 11.509.0 0112 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221.0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z"/></svg>
GitHub</a></li><li class=nav-lang-sep></li><li class=lang-dropdown><button class=lang-btn aria-expanded=false>
🇧🇷 PT
<svg width="10" height="10" viewBox="0 0 10 10" fill="currentColor"><path d="M2 3.5l3 3 3-3" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" fill="none"/></svg></button><ul class=lang-menu><li><a href=/zero-trust/ hreflang=en><span class=lang-flag>🇬🇧</span>
<span>English</span></a></li><li><a href=/pt-br/zero-trust/ hreflang=pt-br class=lang-active><span class=lang-flag>🇧🇷</span>
<span>Português</span></a></li><li><a href=/es/zero-trust/ hreflang=es><span class=lang-flag>🇪🇸</span>
<span>Español</span></a></li><li><a href=/fr/zero-trust/ hreflang=fr><span class=lang-flag>🇫🇷</span>
<span>Français</span></a></li><li><a href=/de/zero-trust/ hreflang=de><span class=lang-flag>🇩🇪</span>
<span>Deutsch</span></a></li></ul></li></ul></nav></div></header><main><section class=page-hero><div class=container><div class=section-label>Zero Trust</div><h1>Gateway de Aplicações Zero Trust</h1><p class=section-sub style=margin-top:1rem>Publique serviços internos com segurança, sem expô-los diretamente à internet.</p></div></section><div class=page-content><div class=container><h2 id=o-que-significa-zero-trust-aqui>O que significa Zero Trust aqui?</h2><p>A segurança de rede tradicional assume que tudo o que está dentro da sua rede pode ser confiável.
Zero Trust inverte esse modelo: <strong>nenhuma requisição é confiável por padrão</strong>, mesmo que venha de dentro da VPN.</p><p>No wireguard_webadmin, o gateway de aplicações Zero Trust fica na frente dos seus serviços internos.
Toda requisição precisa se autenticar antes de chegar à aplicação, e o serviço em si nunca precisa ser exposto diretamente.</p><hr><h2 id=como-uma-requisição-flui>Como uma requisição flui</h2><div class=flow-cards><div class=flow-card><div class=flow-card-header><span class=flow-card-num>1</span> <strong>O cliente chega ao gateway</strong></div><p>O endpoint público recebe a requisição no lugar do serviço interno.</p></div><div class=flow-card><div class=flow-card-header><span class=flow-card-num>2</span> <strong>Validação do navegador</strong></div><p>O proof-of-work do Altcha pode desafiar abusos automatizados antes mesmo do login começar.</p></div><div class=flow-card><div class=flow-card-header><span class=flow-card-num>3</span> <strong>Verificações de identidade</strong></div><p>Credenciais, TOTP e a política de IP de origem são avaliados.</p></div><div class=flow-card><div class=flow-card-header><span class=flow-card-num>4</span> <strong>Encaminhamento para o upstream</strong></div><p>Apenas requisições aprovadas são encaminhadas para Grafana, Proxmox ou outra aplicação interna.</p></div></div><hr><h2 id=métodos-de-autenticação>Métodos de autenticação</h2><div class=auth-list><div class=auth-row><div class=auth-row-name>TOTP / 2FA</div><div class=auth-row-desc>Senhas temporárias baseadas em tempo. Funciona com qualquer app TOTP, como Google Authenticator, Aegis e Authy.</div></div><div class=auth-row><div class=auth-row-name>Credenciais locais</div><div class=auth-row-desc>Nome de usuário e senha gerenciados dentro do wireguard_webadmin. Nenhum IdP externo é necessário.</div></div><div class=auth-row><div class=auth-row-name>ACL por IP</div><div class=auth-row-desc>Permita IPs ou sub-redes específicas em uma lista de confiança. Peers da VPN podem ser automaticamente confiáveis pelo endereço do túnel.</div></div><div class=auth-row><div class=auth-row-name>OIDC <span class=auth-coming>em breve</span></div><div class=auth-row-desc>Delegue a autenticação para Keycloak, Authentik, Google Workspace ou qualquer provedor compatível com OIDC.</div></div></div><hr><h2 id=anti-brute-force-proof-of-work-do-altcha>Anti brute force: proof-of-work do Altcha</h2><p>Antes mesmo de qualquer formulário de login ser exibido, o navegador precisa resolver um desafio computacional leve
(<a href=https://altcha.org/ target=_blank rel=noopener>Altcha</a>).</p><p>Isso não gera atrito para usuários reais, já que o hardware moderno resolve o desafio em milissegundos,
mas torna ataques automatizados de credential stuffing computacionalmente caros em larga escala.</p><div class=callout><p><strong>Proteção em camadas:</strong> O rate limiting já está em vigor. O proof-of-work complementa essa camada: enquanto o rate limiting limita o volume de requisições por IP, o Altcha adiciona um custo computacional por requisição que encarece ataques distribuídos, independentemente de quantos IPs de origem estejam envolvidos.</p></div><hr><h2 id=casos-de-uso>Casos de uso</h2><ul><li>Exponha o <strong>Grafana</strong> para o seu time sem abrir a porta 3000 para a internet</li><li>Publique um console web do <strong>Proxmox</strong> atrás de TOTP, acessível apenas pela sua VPN</li><li>Compartilhe uma <strong>aplicação self-hosted</strong> com um cliente usando credenciais temporárias</li><li>Proteja qualquer <strong>serviço HTTP interno</strong> sem mexer na configuração dele</li></ul><div class="callout green"><p><strong>Nenhuma mudança na aplicação é necessária.</strong> O gatekeeper faz o proxy da requisição de forma transparente.
Seu serviço interno não precisa implementar autenticação: o gateway cuida disso.</p></div><hr><p>O gerenciamento da VPN e o gateway de aplicações rodam como uma única stack self-hosted. Sem conta em serviço de terceiros, sem dependência de túnel de saída e sem tráfego deixando a sua infraestrutura.</p></div></div></main><footer class=site-footer><div class=container><div class=footer-inner><div class=footer-logo>wireguard_<span>webadmin</span></div><ul class=footer-links><li><a href=https://github.com/eduardogsilva/wireguard_webadmin target=_blank rel=noopener>GitHub</a></li><li><a href=https://github.com/eduardogsilva/wireguard_webadmin/discussions target=_blank rel=noopener>Discussions</a></li><li><a href=/pt-br/zero-trust/>Zero Trust</a></li><li><a href=/pt-br/deployment/>Deployment</a></li><li><a href=/pt-br/get-involved/>Get Involved</a></li></ul><div class=footer-built>desenvolvido por <a href=https://github.com/eduardogsilva target=_blank rel=noopener>@eduardogsilva</a></div></div></div></footer><script>document.querySelectorAll(".tab-btn").forEach(e=>{e.addEventListener("click",()=>{const t=e.closest(".tab-group");t.querySelectorAll(".tab-btn").forEach(e=>e.classList.remove("active")),t.querySelectorAll(".tab-panel").forEach(e=>e.classList.remove("active")),e.classList.add("active"),t.querySelector("#"+e.dataset.tab).classList.add("active")})});const hamburger=document.querySelector(".hamburger"),navLinks=document.querySelector(".nav-links");hamburger&&(hamburger.addEventListener("click",e=>{e.stopPropagation();const t=navLinks.classList.toggle("open");hamburger.classList.toggle("open",t),hamburger.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{!navLinks.contains(e.target)&&!hamburger.contains(e.target)&&(navLinks.classList.remove("open"),hamburger.classList.remove("open"),hamburger.setAttribute("aria-expanded",!1))}));const langBtn=document.querySelector(".lang-btn"),langDropdown=document.querySelector(".lang-dropdown");if(langBtn&&(langBtn.addEventListener("click",e=>{e.stopPropagation();const t=langDropdown.classList.toggle("open");langBtn.setAttribute("aria-expanded",t)}),document.addEventListener("click",e=>{langDropdown.contains(e.target)||(langDropdown.classList.remove("open"),langBtn.setAttribute("aria-expanded",!1))}),langDropdown.querySelectorAll(".lang-menu a").forEach(e=>{e.addEventListener("click",()=>localStorage.setItem("lang-manual","1"))})),location.pathname==="/"&&!localStorage.getItem("lang-manual")){const t=(navigator.language||navigator.userLanguage||"en").toLowerCase(),n=[{prefix:"pt",url:"/pt-br/"},{prefix:"es",url:"/es/"},{prefix:"fr",url:"/fr/"},{prefix:"de",url:"/de/"}],e=n.find(e=>t.startsWith(e.prefix));e&&location.replace(e.url)}</script></body></html>