Introdução
Já faz um bom tempo que a plataforma heroku anunciou mudanças no plano gratuito (mais detalhes). Quando soube nem liguei muito, mas agora que resolvi retomar com as atividades do blog percebi que teria que dar um jeito, pois era lá que estava hospedado o antigo CMS deste blog.
Um pouco da história da criação do blog
Lembro que na época o objetivo era criar algo para poder compartilhar experiências pessoais e documentar meu aprendizado, então pensei: vou criar um blog! Com o blog eu poderia colocar em prática o que estava estudando e também ajudar alguém que esteja querendo aprender algo comigo.
Escolhi fazer o blog utilizando Next.js e para a gestão de conteúdo o strapi um headless CMS. O processo de desenvolvimento foi bem legal e aprendi muita coisa, porém depois que terminei fiquei pensando “será que precisava de toda essa arquitetura apenas para um blog simples?”.
Claro que para um ambiente de testes e projeto pessoal era super válido, mas não sei se recomendaria criar toda essa estrutura, pelo menos não de início.
Estrutura antes da atualização
Na antiga estrutura, o servidor do CMS ficava hospedado dentro do heroku com o banco de dados postgreSQL e o frontend em Next.js hospedado na vercel.
Utilizando os recursos de geração estática do Next.js através das funções getStaticProps e getStaticPaths o frontend buscava os dados da api dos posts e dados que eram dinâmicos das páginas e gerava no build toda a parte estática necessária para poder ser indexado pelos buscadores.
O mais legal é que se o conteúdo muda o Next faz o fetch novamente para gerar as páginas conforme os novos dados e caso contrário ele os mantém como estavam.
E o que me deixou impressionado é que quando o serviço de banco de dados foi desligado do heroku e a api do strapi parou de funcionar, o blog continuou com as páginas normalmente sem quebrar por falta do conteúdo.
Gostei de trabalhar com essas ferramentas e inclusive já apliquei essa stack em projetos onde trabalho. Porém, analisando essa arquitetura e o "problema" que eu queria resolver (um blog simples onde somente eu faço manutenção e escrevo o conteúdo) vi que era exagero demais. Esse é um dos casos onde vale lembrar do padrão de design KISS "Keep it Simple, Stupid" traduzindo de forma livre, mantenha isso estupidamente simples.
Modificações e atualizações
A primeira e a mais importante modificação: precisava trocar o CMS. Pesquisei e vi algumas alternativas, até que conheci o Netlify CMS pelo blog do Willian Justen neste post aqui - inclusive recomendo muito o conteúdo desse cara - gostei bastante de como ele funciona e iria suprir minhas necessidades.
Netlify CMS e a estrutura nova
Para quem não conhece o Netlify é um CMS que usa o git para gerenciar o conteúdo e esse conteúdo fica todo dentro do projeto, então não tem a necessidade um banco de dados ou servidor separado.
Configuração Vercel/Next.js
A configuração dentro do next é bem simples. Seguindo a documentação basta criar uma pasta onde ficará o cms dentro do diretório /public e configurar dois arquivos index.html e config.yml.
Dentro do arquivo config.yml é bem tranquilo configurar suas coleções de dados e seus respectivos campos, qual a pasta onde ele vai usar para colocar o conteúdo e mídias. Segue minha configuração:
1backend: 2 name: github 3 repo: GustavoGcdo/personal-blog 4 branch: master 5 squash_merges: true ## Estrategia de juntar todos commits em um quando publicar 6 base_url: https://www.gustavooliveira.dev/ 7 auth_endpoint: api/auth/ ## Endpoint para autenticação com git 8 9media_folder: "public/images" 10public_folder: "/images" 11publish_mode: editorial_workflow ## Habilitar modo workflow 12slug: 13 encoding: 'ascii' 14 clean_accents: true 15 16collections: 17 - name: posts 18 label: posts 19 folder: posts 20 create: true 21 slug: '{{slug}}' 22 fields: 23 - { label: 'Layout', name: 'layout', widget: 'hidden', default: 'post' } 24 - { label: 'Date', name: 'publishedAt', widget: 'datetime', format: 'YYYY-MM-DD hh:mm:ss' } 25 - { label: 'Post Image', name: 'image', widget: 'image', required: true } 26 - { label: 'Title', name: 'title', widget: 'string' } 27 - { label: 'Description', name: 'description', widget: 'string' } 28 - { label: 'Body', name: 'body', widget: 'markdown' }
Para autenticar usando a vercel/next seguir os seguintes passos:
-
Certificar que na config.yml o auth_endpoint está configurado para api/auth (confira linha 7 do arquivo acima).
-
Instalação do pacote @openlab/vercel-netlify-cms-github e configuração dos arquivos api/auth.ts e api/callback.ts.
1// src/pages/api/auth.ts 2export { auth as default } from '@openlab/vercel-netlify-cms-github'
1// src/pages/api/callback.ts 2export { callback as default } from '@openlab/vercel-netlify-cms-github'
-
Configurar um “new OAuth App” para permitir autenticação dentro do github (https://github.com/settings/developers)
-
Copiar as keys geradas no github
-
Configurar as keys do git como OAUTH_CLIENT_ID e OAUTH_CLIENT_SECRET nas variáveis de ambiente da Vercel.
Com isso configurado, é só entrar com github e já terá acesso ao CMS.
Workflow
Ainda nas configurações, o netlify também nos permite habilitar o editorial_workflow, um modo de publicação que utiliza pull requests para gerenciar em qual estágio está o seu conteúdo, no meu caso os posts.
Dessa forma é possível gerenciar visualmente o que está sendo feito e quando o conteúdo está pronto é só clicar em publicar que a branch do post é mergeada com a branch principal e estará disponível para deploy.
Bônus: Atualmente publicando o projeto na Vercel ainda é possível ver uma versão com essas branchs antes de serem publicadas, conseguindo avaliar como ficaria em produção e também criar comentários.
Next.js 13
A segunda atualização foi mais para experimentar algumas coisas da nova versão do Next.js 13, vi que tinha bastante coisa legal e que poderia ser aplicada.
A primeira coisa que fiz foi atualizar a versão do React.js para a 18 e logo em seguida atualizei a versão do Next.js para a última versão estável.
Sei que não é novidade, mas ainda não tinha atualizado o projeto para usar o diretório "src" então também já aproveitei e fiz. Achei que ficou bem mais organizado.
Das novas funcionalidades do Next.js as que apliquei no projeto foram:
- Next/font: Utilização de um novo sistema de carregamento de fontes auto-hospedadas para melhorar o desempenho e evitar o layout shift (Aquela piscada na tela onde pode se perceber a troca de fonte quando há um certo delay na rede)
- Next/image: A nova versão trouxe diversas otimizações de desempenho e facilidades de configuração.
Existem outras funcionalidades que ainda não apliquei aqui, mas pretendo utilizar como o novo diretório app e também os ServerComponents que estão bastante interessantes.
Caso queiram conhecer todas as novidades confira aqui
Conclusão
Experimentar e aprender novas tecnologias é sempre muito empolgante, eu particularmente gostei muito do resultado e com certeza me animou para crescer ainda mais. Espero que tenham gostado do conteúdo e ter motivado vocês a continuarem um projeto ou até mesmo iniciar um novo.