Desafio Cake ERP
Go to file
Augusto Gunsch b905a812b9
Adicionar limit e offset na query (GET /trainer)
2021-10-18 09:51:50 -03:00
api Adicionar limit e offset na query (GET /trainer) 2021-10-18 09:51:50 -03:00
.gitignore Commit inicial 2021-10-14 16:02:23 -03:00
Makefile Usar ORM ao invés de SQL bruto 2021-10-17 18:59:27 -03:00
README.md Arrumar checkboxes 2021-10-17 21:22:25 -03:00
create_db.py Usar ORM ao invés de SQL bruto 2021-10-17 18:59:27 -03:00
requirements.txt Atualizar requirements.txt 2021-10-17 21:16:15 -03:00

README.md

Rodando

As dependências (Python) do projeto estão listadas em requirements.txt.

Crie o banco de dados: python3 create_db.py

Depois, no diretório api: flask run

Por padrão o servidor tem sua interface em http://localhost:5000.

Desenvolvimento

  • Comecei a desenvolver o projeto em Rust, mas sofri muito com a linguagem, perdendo uma tarde inteira lutando com o borrow checker e o framework Rocket. Concluí que preciso aprender melhor as mecânicas de ownership do Rust, e decidi fazer em Python (framework Flask) ao invés.
  • Pensei em fazer em C# ou C++, mas seria obrigado a usar um sistema de build como cmake, que demoraria bastante tempo pra organizar. Isso porque uso Linux, e não posso garantir a portabilidade das Makefiles pra outras plataformas.
  • Comecei fazendo com SQL bruto, mas aprendi como funciona a biblioteca de ORM SQLAlchemy, e passei a usá-la.

Endpoints

Os endpoints que já estão funcionando marcados:

  • GET /trainer
  • POST /trainer
  • POST /trainer/authenticate
  • GET /trainer/{trainerId}
  • GET /trainer/{trainerId}/pokemon
  • POST /trainer/{trainerId}/pokemon
  • GET /trainer/{trainerId}/pokemon/{pokemonId}
  • DELETE /trainer/{trainerId}/pokemon/{pokemonId}