No primeiro módulo tivemos uma introdução sobre o que é uma API REST, foi mostrado os métodos mais utilizados do HTTP (get, post, put, delete) foi visto na prática como desenvolver um CRUD (create, read, update, delete) e de como interagir com ele. O Diego explicou como usar middlewares globais e locais, ele também mostrou como debugar o código com o auxílio das ferramentas do VS Code em vez de usar o console.log rsrsrs...
Com o que foi mostrado no primeiro módulo e com o conhecimento que tenho finalizei o 1 desafio.
Crie uma aplicação para armazenar projetos e suas tarefas do zero utilizando Express.
-
POST /projects
: A rota deve receberid
etitle
dentro do corpo e cadastrar um novo projeto dentro de um array no seguinte formato:{ id: "1", title: 'Novo projeto', tasks: [] }
; Certifique-se de enviar tanto o ID quanto o título do projeto no formato string com aspas duplas. -
GET /projects
: Rota que lista todos projetos e suas tarefas; -
PUT /projects/:id
: A rota deve alterar apenas o título do projeto com oid
presente nos parâmetros da rota; -
DELETE /projects/:id
: A rota deve deletar o projeto com oid
presente nos parâmetros da rota; -
POST /projects/:id/tasks
: A rota deve receber um campotitle
e armazenar uma nova tarefa no array de tarefas de um projeto específico escolhido através doid
presente nos parâmetros da rota;
Se eu chamar a rota POST /projects
repassando { id: 1, title: 'Novo projeto' }
e a rota POST /projects/1/tasks
com { title: 'Nova tarefa' }
, meu array de projetos deve ficar assim:
[
{
id: "1",
title: "Novo projeto",
tasks: ["Nova tarefa"]
}
];
-
Crie um middleware que será utilizado em todas rotas que recebem o ID do projeto nos parâmetros da URL que verifica se o projeto com aquele ID existe. Se não existir retorne um erro, caso contrário permita a requisição continuar normalmente;
-
Crie um middleware global chamado em todas requisições que imprime (
console.log
) uma contagem de quantas requisições foram feitas na aplicação até então;
# instalar as dependências necessarias para que o app funcione
yarn install
# Iniciar o servidor na porta 3333
yarn dev
# Parar o servidor
crtl+c
Para ter acesso as todas as rotas import o insomnia.json em uplicativo que permita isso, Insominia ou Postman
Esse projeto está sob a licença MIT. Veja o arquivo LICENSE para mais detalhes.
Rocketseat 👋 Entre na nossa comunidade!