Uma lib MVC simples da Hero com banco de dados em memória.
Project description
Exemplos de APIs com banco de dados
- 01_app_without_design_patterns: exemplo de código que salva um item no banco de dados sem padrão.
- 02_app_without_dto: exemplo de código que salva um item no banco de dados, que utiliza o padrão DTO.
- 03_app_mvc: exemplo de código que salva um item no banco de dados, usando o padrão MVC.
- 04_app_mvc_relation: exemplo de código que salva um item com relacionamento no banco de dados, usando o padrão MVC.
Explicando o código 03_APP_MVC
API de exemplo para gerenciar Heróis usando FastAPI, SQLModel (SQLAlchemy + Pydantic), e o padrão MVC com Repository:
- Controller (Router) → recebe HTTP
- Service → regras de negócio
- Repository → acesso ao banco
- Model (SQLModel) → entidades e DTOs
- Database → criação do engine e sessão
✨ Principais recursos
- Estrutura limpa em camadas (Controller → Service → Repository → DB)
- SQLModel (tipagem forte + ORM)
- Injeção de dependência com
Depends - Tratamento de erros HTTP padronizado
- Pronto para trocar SQLite por PostgreSQL
📂 Estrutura do projeto
├─ app/
│ ├─ main.py # inicialização da app e rotas
│ ├─ database.py # engine, sessão e inicialização do schema
│ ├─ models.py # SQLModel: entidades e schemas (Create/Update/Public)
│ ├─ controllers/
│ │ └─ heroes.py # Controller (Router) da feature "heroes"
│ ├─ services/
│ │ └─ hero_service.py # Regras de negócio
│ └─ repositories/
│ └─ hero_repository.py # Acesso ao banco (CRUD)
└─ requirements.txt
🧰 Stack & Requisitos
- Python 3.10+
- FastAPI
- SQLModel
- Uvicorn
requirements.txt:
fastapi==0.114.2
uvicorn[standard]==0.30.6
SQLModel==0.0.22
Para PostgreSQL, adicione também:
psycopg[binary]==3.*
⚙️ Configuração & Execução
- Crie o ambiente e instale dependências:
python -m venv .venv
source .venv/bin/activate # Windows: .venv\Scripts\activate
pip install -r requirements.txt
- (Opcional) Defina o banco via variável de ambiente:
-
SQLite (padrão) – já funciona sem configurar nada.
-
PostgreSQL:
export DATABASE_URL="postgresql+psycopg://app:app@localhost:5432/appdb"
- Rode a aplicação:
uvicorn app.main:app --reload
- Acesse:
- Healthcheck: http://127.0.0.1:8000/
- Docs (Swagger): http://127.0.0.1:8000/docs
- ReDoc: http://127.0.0.1:8000/redoc
🧱 Modelos (resumo)
Hero(tabela):id,name,secret_name?,age?HeroCreate(entrada POST)HeroUpdate(entrada PATCH, campos opcionais)HeroPublic(saída nas respostas)
🔌 Endpoints (Heroes)
Base path: /heroes
| Método | Rota | Body | Resposta | Descrição |
|---|---|---|---|---|
| POST | / |
HeroCreate |
HeroPublic |
Cria um herói |
| GET | / |
— | List[HeroPublic] |
Lista heróis (offset/limit) |
| GET | /{hero_id} |
— | HeroPublic |
Busca por ID |
| PATCH | /{hero_id} |
HeroUpdate |
HeroPublic |
Atualiza campos parciais |
| DELETE | /{hero_id} |
— | 204 No Content |
Remove herói |
🧪 Exemplos (cURL)
Criar:
curl -X POST http://127.0.0.1:8000/heroes/ \
-H "Content-Type: application/json" \
-d '{"name":"Ada","secret_name":"The Enchantress","age":28}'
Listar:
curl "http://127.0.0.1:8000/heroes/?offset=0&limit=100"
Buscar por ID:
curl http://127.0.0.1:8000/heroes/1
Atualizar (parcial):
curl -X PATCH http://127.0.0.1:8000/heroes/1 \
-H "Content-Type: application/json" \
-d '{"name":"Ada Lovelace"}'
Remover:
curl -X DELETE http://127.0.0.1:8000/heroes/1 -i
🧠 Como as camadas se conectam
HTTP (FastAPI)
↓
Controller (app/controllers/heroes.py)
↓
Service (app/services/hero_service.py)
↓
Repository (app/repositories/hero_repository.py)
↓
DB Session (app/database.py) + SQLModel (app/models.py)
- Controller: lida com requisições/respostas e validações de query/path; injeta dependências com
Depends. - Service: regras de negócio (ex.: checar nome duplicado).
- Repository: SQL puro via SQLModel/SQLAlchemy (CRUD).
- Database: engine, sessão e criação de schema.
Reference:
Documento Fast API : Documentação do FAST API.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lib_hero_mvc_ps-0.1.4.tar.gz.
File metadata
- Download URL: lib_hero_mvc_ps-0.1.4.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
15a852f01647f991424c2c6ad099f938c9c857207f8c46b70896608feae86481
|
|
| MD5 |
66334dd2280ede7c091634bfd3c5b43f
|
|
| BLAKE2b-256 |
891cae83b16982fe22c6b9ed33967a676a6e368136a22cd264182f4b85b549e4
|
File details
Details for the file lib_hero_mvc_ps-0.1.4-py3-none-any.whl.
File metadata
- Download URL: lib_hero_mvc_ps-0.1.4-py3-none-any.whl
- Upload date:
- Size: 11.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
63ec77d0aea85383254203c129b9850bed1b45adf249b9e2047e86a5964eb5e6
|
|
| MD5 |
df9d58bc685369d3c027763614386b68
|
|
| BLAKE2b-256 |
af71a30b6e9e9520f8f786a456626c7d1ff5b344f65447c68e95901dd3ea38cf
|