O site gerado por esse repositório está disponível em: fastapidozero.dunossauro.com.
O objetivo final desse curso é que ele também seja disponibilizado em vídeo quando a escrita do material terminar. Nos vemos no youtube em breve!
O objetivo desse projeto é ensinar FastAPI para pessoas que queiram ter o seu primeiro contato com o mesmo. A ideia padrão é construir uma aplicação pequena e simples, mas executando todos os passos até o deploy.
As Aulas estão dividas em:
- Apresentação do curso
- Configurando o Ambiente de Desenvolvimento
- Introdução ao desenvolvimento WEB
- Estruturando seu Projeto e Criando Rotas CRUD
- Configurando Banco de Dados e Gerenciando Migrações com Alembic
- Integrando Banco de Dados a API
- Autenticação e Autorização
- Refatorando a Estrutura do Projeto
- Tornando o sistema de autenticação robusto
- Criando Rotas CRUD para Tarefas
- Dockerizando a aplicação
- Automatizando os testes com integração contínua
- Fazendo o deploy no fly.io
- Despedida
Todo esse projeto é gerenciado pelo Poetry, a versão usada durante o momento da escrita é 2.0.0
:
pipx install poetry==2.0.0
pipx inject poetry poetry-plugin-shell
A versão usada do python é a versão 3.13.0:
pyenv local 3.13.0
para configurar todo o ambiente basta executar:
poetry install
para ativar o ambiente virtual:
poetry shell
Os comandos para executar funções como deploy, servidor local, geração de slides, etc. Estão todas sendo feitas pelo taskipy
:
task --list
serve Executa o servidor local do mkdocs
deploy Faz o deploy da página em produção
slides Gera os slides em pdf
slides_html Gera os slides em html (formato usado nas aulas)
pdf Cria um pdf único de todo o curso (não otimizado ainda)
Para executar qualquer comando, basta usar: task <comando>
, como por exemplo task serve
.
Todos os slides foram feitos usando marp. Versão do marp usada: 4.0.3
. O tema rose-pine
está dentro da pasta dos slides brutos.