TRILHA 2

⚡ Deploy Moderno

Colocar projetos no ar de verdade: Vercel para deploy em um clique, banco de dados sem dor com o Supabase, APIs conectando servicos e variaveis de ambiente para guardar seus segredos com seguranca.

4
Modulos
24
Topicos
~3h
Duracao
Basico
Nivel
SEU CODIGO no GitHub VERCEL deploy em 1 clique SUPABASE banco de dados APIs GET / POST VARIAVEIS .env secreto ⚡ APP no ar de verdade

Mapa da trilha

Conteudo detalhado

2.1 ~45 min

⚡ Vercel

A forma mais rapida de colocar um site no ar: voce conecta o GitHub e, a cada push, a Vercel publica seu projeto sozinha. Deploy em um clique.

O que e:

Deploy e o ato de pegar seu projeto e coloca-lo num servidor publico, com um endereco que qualquer pessoa acessa. A Vercel e uma plataforma que faz isso de forma quase automatica.

Por que aprender:

Codigo no seu computador so voce ve. Deploy e o que transforma o projeto em algo real e compartilhavel. A Vercel torna esse passo simples e gratuito.

Conceitos-chave:

A Vercel e ideal para sites e apps modernos (React, Next.js, HTML). Ela observa seu repositorio e refaz o deploy a cada mudanca, sem comando manual.

O que e:

O cadastro na Vercel usando sua conta do GitHub e a autorizacao para a Vercel enxergar seus repositorios.

Por que aprender:

E a ponte que liga onde seu codigo vive (GitHub) a onde ele sera publicado (Vercel). Sem essa conexao, nao ha deploy automatico.

Conceitos-chave:

Use "Sign up with GitHub" para criar a conta ja conectada. Autorize so os repositorios que voce quer publicar. O plano gratuito (Hobby) basta para comecar.

O que e:

O passo de importar um repositorio na Vercel e clicar em "Deploy". Em segundos, seu projeto ganha um endereco publico funcionando.

Por que aprender:

E o momento "no ar" da Trilha 2: ver seu site rodando num link real prova que o ciclo de deploy funciona de ponta a ponta.

Conceitos-chave:

A Vercel detecta o tipo do projeto sozinha. Voce recebe um endereco projeto.vercel.app. A partir dai, cada git push refaz o deploy.

O que e:

A cada branch ou pull request, a Vercel cria um deploy de "preview": uma copia do site com endereco proprio, separada da versao de producao.

Por que aprender:

Permite testar uma mudanca num link real antes de mexer no site principal. Voce mostra a novidade para alguem sem riscos para a versao no ar.

Conceitos-chave:

A branch main vira producao; as outras viram previews. Cada preview tem URL unica e some quando a branch e removida.

O que e:

O painel de configuracoes da Vercel: comando de build, pasta raiz do projeto, dominios e o botao de refazer (redeploy) um deploy.

Por que aprender:

Projetos crescem e precisam de ajustes. Saber onde mexer evita aquele "funciona no meu PC, mas quebra no deploy".

Conceitos-chave:

Na maioria dos casos os padroes ja servem. Mude o "Root Directory" se o projeto esta numa subpasta. O "Redeploy" repete o ultimo deploy.

O que e:

Trocar o endereco padrao projeto.vercel.app por um dominio proprio que voce comprou, como seusite.com.

Por que aprender:

Um dominio proprio passa profissionalismo e e mais facil de divulgar. A Vercel cuida do HTTPS automaticamente, de graca.

Conceitos-chave:

Adicione o dominio em "Domains" e aponte o DNS conforme a Vercel indicar. O certificado HTTPS (cadeado) e gerado sozinho.

Ver Completo
2.2 ~45 min

🗃️ Supabase

Banco de dados sem dor: o Supabase te entrega um banco pronto, com API automatica e login de usuarios, tudo pela tela do navegador.

O que e:

Um banco de dados e um lugar organizado para guardar informacao de forma permanente: usuarios, pedidos, mensagens. Pense numa planilha gigante e confiavel que muitos programas podem ler e escrever ao mesmo tempo.

Por que aprender:

Quase todo app de verdade precisa lembrar de algo entre uma visita e outra. Sem banco, tudo se perde quando a pagina fecha.

Conceitos-chave:

Os dados ficam em tabelas (linhas e colunas). O Supabase usa PostgreSQL, um banco poderoso e gratuito, por baixo dos panos.

O que e:

O passo de criar uma conta, abrir um novo projeto e deixar o Supabase provisionar um banco PostgreSQL pronto para uso.

Por que aprender:

Montar um banco do zero costumava ser complicado. O Supabase entrega isso em poucos cliques, sem voce instalar nada.

Conceitos-chave:

Escolha uma regiao perto de voce e guarde a senha do banco com cuidado. O plano gratuito ja serve para aprender e prototipar.

O que e:

A organizacao do banco: cada tabela guarda um tipo de coisa (ex.: "usuarios"), as colunas sao os campos (nome, email) e o tipo define o que cabe em cada coluna (texto, numero, data).

Por que aprender:

Uma boa estrutura evita bagunca e erros. Definir tabelas e tipos certos no inicio poupa muita dor de cabeca depois.

Conceitos-chave:

Crie tabelas pelo "Table Editor" visual. Tipos comuns: text, int, bool, timestamp. Toda linha tem um id unico.

O que e:

As duas acoes mais comuns num banco: inserir (gravar uma nova linha) e consultar (buscar linhas que atendem a um criterio). E o "escrever e ler" do banco.

Por que aprender:

Todo app vive disso: salva o que o usuario digita e mostra de volta o que ja foi salvo. Sem inserir e consultar, o banco fica parado.

Conceitos-chave:

Voce pode inserir pela tela ou por codigo. A linguagem por tras e o SQL (insert, select), mas o Supabase deixa fazer tudo de forma visual tambem.

O que e:

Assim que voce cria uma tabela, o Supabase gera sozinho uma API: enderecos prontos para o seu site ler e gravar dados no banco pela internet.

Por que aprender:

Normalmente seria preciso programar um servidor inteiro para isso. Ter a API de graca conecta seu frontend ao banco em minutos.

Conceitos-chave:

Cada projeto tem uma URL e uma chave (anon key). A biblioteca supabase-js facilita as chamadas. Esse e o gancho para o modulo de APIs.

O que e:

O sistema pronto do Supabase para cadastro e login de usuarios: email e senha, ou entrar com Google e GitHub, sem voce programar isso do zero.

Por que aprender:

Login seguro e dificil de fazer certo. Usar uma solucao pronta evita falhas graves e te deixa focar no resto do app.

Conceitos-chave:

O Supabase gerencia senhas e sessoes. Com regras de acesso (RLS), cada usuario so enxerga os proprios dados. Ative os provedores na aba Authentication.

Ver Completo
2.3 ~45 min

🔌 APIs

APIs sao a forma como os servicos conversam entre si pela internet. Aprenda a pedir e enviar dados, testar e tratar erros com seguranca.

O que e:

API e um conjunto de enderecos por onde um programa pede informacao a outro. Pense num garcom: voce faz um pedido, ele leva a cozinha e traz o prato; voce nao precisa saber como a cozinha funciona.

Por que aprender:

Tudo na web moderna conversa por API: clima, mapas, pagamentos, seu banco no Supabase. Entender API e entender como apps se conectam.

Conceitos-chave:

Voce envia uma requisicao a uma URL e recebe uma resposta, quase sempre em formato JSON. A maioria das APIs web fala por HTTP.

O que e:

Os quatro verbos basicos de uma API: GET le, POST cria, PUT atualiza e DELETE apaga. Cada um descreve a intencao do pedido.

Por que aprender:

Usar o verbo certo deixa a API previsivel e organizada. E o vocabulario padrao que todo servico web entende.

Conceitos-chave:

Lembre pelo CRUD: Create=POST, Read=GET, Update=PUT, Delete=DELETE. GET nunca deve mudar dados; POST e PUT enviam um corpo com a informacao.

O que e:

Duas formas de testar uma API sem escrever um app: o curl faz a chamada pelo terminal; o Thunder Client e uma extensao do VS Code com tela visual para isso.

Por que aprender:

Antes de ligar a API ao seu site, e essencial conferir se ela responde como esperado. Testar primeiro economiza horas de depuracao.

Conceitos-chave:

curl -X GET url faz a chamada mais simples. O Thunder Client guarda suas requisicoes e mostra a resposta formatada. Veja sempre o codigo de status.

O que e:

Usar o JavaScript do seu site para chamar uma API e mostrar o resultado na tela. A ferramenta padrao do navegador para isso e o fetch.

Por que aprender:

E o que torna um site "vivo": ele busca dados na hora e atualiza a pagina sem recarregar. Esse e o coracao de qualquer app dinamico.

Conceitos-chave:

fetch(url) retorna uma promessa; use await e .json() para ler a resposta. Chamadas sao assincronas: o codigo espera a resposta chegar.

O que e:

APIs abertas que qualquer um pode usar para buscar dados prontos: previsao do tempo, endereco a partir do CEP (ViaCEP), cotacao de moedas e muito mais.

Por que aprender:

Sao a forma mais facil de praticar: voce ja recebe dados reais sem montar um servidor. Da para enriquecer seu app com pouco esforco.

Conceitos-chave:

Algumas pedem uma chave (API key) gratuita; outras, como a ViaCEP, sao abertas. Leia a documentacao para saber a URL e o formato da resposta.

O que e:

A pratica de prever que a API pode falhar (internet caiu, dado nao existe, servico fora do ar) e mostrar uma mensagem clara em vez de quebrar o app.

Por que aprender:

No mundo real, requisicoes falham. Um app que trata erros bem parece profissional; um que trava na primeira falha frustra o usuario.

Conceitos-chave:

Status 200 e sucesso; 404 nao encontrado; 500 erro do servidor. Use try/catch e cheque response.ok antes de usar os dados.

Ver Completo
2.4 ~45 min

🔑 Variaveis de Ambiente

Segredos seguros: senhas e chaves nunca devem ficar no codigo. As variaveis de ambiente guardam esses segredos fora do projeto, com seguranca.

O que e:

Variaveis de ambiente sao valores guardados fora do codigo, como uma chave de API ou senha do banco. O programa as le na hora de rodar, sem que elas estejam escritas no projeto.

Por que aprender:

Permitem separar o "como o app funciona" (codigo) do "com quais segredos ele funciona" (configuracao). Trocar um segredo nao exige mexer no codigo.

Conceitos-chave:

Sao pares NOME=valor. O mesmo codigo roda diferente em cada ambiente (seu PC, producao) so trocando as variaveis.

O que e:

Um arquivo chamado .env na raiz do projeto onde voce escreve suas variaveis, uma por linha, para usar enquanto desenvolve no seu computador.

Por que aprender:

E a forma padrao de guardar segredos durante o desenvolvimento, sem escrever a chave direto no codigo que vai para o GitHub.

Conceitos-chave:

Formato CHAVE=valor, sem espacos. O .env precisa ir no .gitignore (visto na Trilha 1) para nunca subir.

O que e:

O painel da Vercel onde voce cadastra as mesmas variaveis do .env, mas para o site que esta no ar. Como o .env nao sobe, a Vercel precisa receber os segredos por aqui.

Por que aprender:

Sem isso, seu site publicado nao consegue acessar o banco ou as APIs. E o passo que liga o deploy aos seus segredos com seguranca.

Conceitos-chave:

Adicione em "Settings → Environment Variables". Da para separar por ambiente (Production, Preview). Apos mudar, refaca o deploy.

O que e:

O GitHub Actions roda tarefas automaticas (testes, deploy) a cada push. Os "Secrets" sao onde voce guarda chaves para essas tarefas usarem com seguranca.

Por que aprender:

Automacoes tambem precisam de segredos, mas nunca devem te-los escritos no arquivo de configuracao. Os Secrets resolvem isso.

Conceitos-chave:

Cadastre em "Settings → Secrets and variables → Actions". No fluxo, voce os acessa por ${{ secrets.NOME }}. Eles aparecem mascarados nos logs.

O que e:

A regra de ouro: senhas, chaves de API, tokens e o proprio .env nunca devem ir para o GitHub. Uma vez no historico, ficam la para sempre.

Por que aprender:

Vazar um segredo num repositorio publico e um dos erros mais comuns e perigosos: bots varrem o GitHub atras de chaves para usar indevidamente.

Conceitos-chave:

Sempre coloque .env no .gitignore. Confira com git status antes do commit. Se vazou, considere a chave comprometida e troque-a.

O que e:

Rotacao e o ato de gerar uma chave nova e descartar a antiga, periodicamente ou quando ha suspeita de vazamento. E como trocar a fechadura por seguranca.

Por que aprender:

Chaves antigas que ja circularam sao um risco. Rotacionar limita o estrago: mesmo que uma chave vaze, ela logo deixa de funcionar.

Conceitos-chave:

Gere a nova chave no servico, atualize em todos os lugares (.env, Vercel, Actions) e so depois revogue a antiga, para nao quebrar o app no meio.

Ver Completo
← Voltar para o inicio Proxima Trilha →