Programação Orientada a Serviços

Prof. Diego Cirilo

Aula 16: Serviços REST

Desenvolvendo Serviços

  • Client/Server ou sistemas monolíticos?
  • APIs/Serviços
  • Por que criar APIs?
  • SaaS - Software as a service
  • Múltiplos clientes: web/mobile/terceiros.

RESTful APIs

  • Uma API deve ser útil para programadores.
  • O uso da API deve ser padronizado.
  • Padrão REST/JSON.
  • Documentação!

Boas práticas em RESTful APIs

  • Endpoints claros: recursos.
  • Métodos HTTP: ações.
  • Serialização: JSON.
  • Códigos de status HTTP: erros.
  • Permita filtragem/paginação/ordenação.
  • Backward Compatibility/Compatibilidade reversa.
  • Versionamento

Django REST Framework

  • Django vs. Flask?
  • Django Rest Framework
  • Suporte "nativo" a página de documentação, ORM, autenticação, etc.
  • Pode ser adicionado a um projeto já existente.
  • Serializers

Django REST Framework

  • Instale o djangorestframework com o pip
  • Adicione o rest_framework no INSTALLED_APPS do arquivo settings.py.
  • Adicione os serializers em serializers.py.
  • Adeque as views.
  • Só?

Exemplo

Tarefa

  • Implemente o serviço do Tutorial do slide anterior
  • Implemente um API Wrapper para o serviço em JS.
  • Utilizando o API Wrapper, implemente um cliente com JS (React ou Vanilla) para o serviço em questão.
  • O cliente deve ser capaz de utilizar todas as funcionalidades do serviço.

Projeto Final

  • Crie uma API parecida com a JSON Placeholder.
  • Sua API deve permitir o CRUD de User, ToDo, Posts e Comments, Albums e Photos, seguindo o esquema da API original.
  • Não é necessário Autenticação.
  • Crie também um cliente web (com React ou Vanilla) que acesse sua API. O cliente deve ter front-end com estilos.
  • O cliente deve ser capaz de utilizar todos os recursos da API, visualizando, editando e criando recursos.
  • O projeto é em dupla(no máximo!), e terá uma nota para o Cliente e outra para o Serviço.

Referências

Dúvidas? 🤔