https://github.com/odeassis/tasks-with-node.js
Aplicação para armazenar projetos e suas tarefas utilizando Express.
https://github.com/odeassis/tasks-with-node.js
Last synced: 2 months ago
JSON representation
Aplicação para armazenar projetos e suas tarefas utilizando Express.
- Host: GitHub
- URL: https://github.com/odeassis/tasks-with-node.js
- Owner: odeassis
- Created: 2020-02-21T03:46:24.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-12T02:23:31.000Z (over 3 years ago)
- Last Synced: 2025-03-20T09:30:07.275Z (over 1 year ago)
- Language: JavaScript
- Size: 171 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Desafio 1: Conceitos do NodeJS
“Se você quiser fazer uma torta de maçã do nada, primeiro tem que inventar o universo”!


## :pushpin: Sobre o desafio
Crie uma aplicação para armazenar projetos e suas tarefas do zero utilizando [Express](https://expressjs.com/pt-br/).
### Rotas
- [x] `POST /projects`: A rota deve receber `id` e `title` 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.
```js
server.post('/projects', (req, res) => {
const { id , title } = req.body;
const project = {
id,
title,
tasks:[]
};
projects.push(project);
return res.json(projects);
});
```
- [x] `GET /projects`: Rota que lista todos projetos e suas tarefas;
```js
server.get('/projects', (req, res) => {
return res.json(projects);
});
```
- [x] `PUT /projects/:id`: A rota deve alterar apenas o título do projeto com o `id` presente nos parâmetros da rota;
```js
server.put('/projects/:id', checkIdExist, (req, res) => {
const { id } = req.params;
const { title } = req.body;
const project = projects.find(proj => proj.id == id);
project.title = title;
return res.json(project);
});
```
- [x] `DELETE /projects/:id`: A rota deve deletar o projeto com o `id` presente nos parâmetros da rota;
```js
server.delete('/projects/:id', checkIdExist, (req, res) => {
const { id } = req.params;
const projectIndex = projects.findIndex(proj => proj.id == id);
projects.slice(projectIndex , 1);
return res.send( 'Projeto removido!');
});
```
- [x] `POST /projects/:id/tasks`: A rota deve receber um campo `title` e armazenar uma nova tarefa no array de tarefas de um projeto específico escolhido através do `id` presente nos parâmetros da rota;
```js
server.post('/projects/:id/tasks', checkIdExist, (req, res) => {
const { id } = req.params;
const { title } = req.body;
const project = projects.find(proj => proj.id == id);
project.tasks.push(title);
return res.json(project);
});
```
### Exemplo
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:
```js
[
{
id: "1",
title: "Novo projeto",
tasks: ["Nova tarefa"]
}
];
```
### Middlewares
- [x] 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;
```js
function checkIdExist(req, res, next) {
if (!projects[projects.findIndex(proj => proj.id == req.params.id)])
return res.status(400).json({error: "Projeto nao existe!"})
return next();
}
```
- [x] 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;
```js
function countReq(req, res, next){
console.count('quantidade de requisicoes' );
return next();
}
server.use(countReq);
```
## :memo: Licença
Esse projeto está sob a licença MIT.
---