Skip to content

Latest commit

 

History

History
316 lines (234 loc) · 12.3 KB

File metadata and controls

316 lines (234 loc) · 12.3 KB

GoStack 10.0 || Desafio 03

1. Conceitos abordados

  1. utilizar multipart form data via Multer / Criar o Avatar do usuário.
  2. Vincular arquivos a tabelas na DB (Avatar a usuário).
  3. formatação e cálculo de datas via biblioteca 'date-fns'.
  4. Aplicar paginação.
  5. Criar notificações usando uma DB não-relacional (MongoDB).
  6. Envios de e-mails usando uma DB não-relacional e filas (Nodemailer e redis).

2. Descrição do projeto

Finalização do back-end do aplicativo Fastfeet.

O Fastfeet é um aplicativo de entregas de produtos quaisquer, similar a ifood, Rappi e UberEats. Pelo website, o usuário administrador lista, cadastra, edita e exclui: encomendas, entregadores, destinatários e problemas nas entregas.

3. Iniciando o projeto

  1. Iniciar Dbs:

    1. DB SQL para GET / POST / PUT / DELETE de dados.

      1. Instalar Docker: https://docs.docker.com/install/
      2. Para conferir se está instalado: docker -v
      3. Para conferir os comandos: docker help
      4. Para criar um serviço do docker em Postgres: https://hub.docker.com/_/postgres
      5. Acessar terminal e colocar:
        1. 5433 - porta do computador - 5432 chama a porta no container onde o postgres está rodando
          docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -p 5433:5432 -d postgres
          
        2. trocar some-postgres e mysecretpassword
        3. Containers em execução: docker ps
        4. Todos os containers: docker ps -a
      6. Para conferir se o banco está rodando, baixar postbird: https://electronjs.org/apps/postbird
      7. configurar a porta no arquivo: src/config/database.js
        1. Usar como padrão: DB_HOST=localhost DB_USER=postgres DB_PASS=docker DB_NAME=postgres
      8. Terminal: yarn sequelize db:migrate
    2. DB Mongo para notificações de delivery.

      1. Run docker mongo. Ex:
      docker run --name mongogdash -p 27017:27017 -d -t mongo
      
    3. DB redis para gerenciar a fila de e-mail.

      1. Run docker redis. Ex:
      docker run --name redisbarber -p 6379:6379 -d -t redis:alpine
      
    4. Iniciar os containers:

      docker start database3 (port: 5434)
      docker start mongofastfeet
      docker start redisfastfeet
      
  2. Iniciar o projeto:

    1. Instalar bibliotecas yarn ou npm install

    2. Script para iniciar o server:

    yarn dev
    
  3. Insomnia

    1. Página do Insomnia: https://insomnia.rest/download/

      Import/Export -> Import Data -> From File -> Insomnia_2020-03-31.json

  4. Acesso de administrador

    1. email: admin@fastfeet.com
    2. senha: 123123

4. Enunciado do Projeto

Fastfeet

Desafio 3: FastFeet, continuando a aplicação

⚠️ Etapa 2/4 do Desafio Final ⚠️

Esse desafio faz parte do Desafio Final, que é uma aplicação completa (Back-end, Front-end e Mobile) que é avaliada para emissão do Certificado do Bootcamp GoStack, por isso é fundamental que ele seja feito com muito empenho!

“Faça seu melhor, mas sempre com prazo de entrega”!

GitHub language count Made by Rocketseat License Stargazers

Sobre o desafio   |    Entrega   |    Licença

🚀 Sobre o desafio

Durante esse desafio vamos aprimorar a aplicação FastFeet que demos início no desafio anterior implementando funcionalidades que aprendemos durante as aulas até agora.

Funcionalidades do administrador

Abaixo estão descritas as funcionalidades que você deve adicionar em sua aplicação para administradores.

1. Gestão de entregadores

Permita que o administrador possa cadastrar entregadores para a plataforma, o entregador deve possuir os seguintes campos:

  • id (id do entregador)
  • name (nome do entregador);
  • avatar_id (foto do entregador);
  • email (email do entregador)
  • created_at;
  • updated_at;

Crie rotas para listagem/cadastro/atualização/remoção de entregadores;

Obs.: Essa funcionalidade é para administradores autenticados na aplicação.

2. Gestão de encomendas

Apesar do entregador estar cadastrado, ele não é independente dentro da plataforma, e você deve cadastrar encomendas para os entregadores.

Nessa funcionalidade criaremos um cadastro de encomendas por entregador, a encomenda possui os campos:

  • id (id da entrega)
  • recipient_id (referência ao destinatário);
  • deliveryman_id (referência ao entregador);
  • signature_id (referência à uma assinatura do destinatário, que será uma imagem);
  • product (nome do produto a ser entregue);
  • canceled_at (data de cancelamento, se cancelada);
  • start_date (data de retirada do produto);
  • end_date (data final da entrega);
  • created_at;
  • updated_at;

data de início deve ser cadastrada assim que for feita a retirada do produto pelo entregador, e as retiradas só podem ser feitas entre as 08:00 e 18:00h.

data de término da entrega deve ser cadastrada quando o entregador finalizar a entrega:

Os campos recipient_id e deliveryman_id devem ser cadastrados no momento que for cadastrada a encomenda.

Quando a encomenda é cadastrada para um entregador, o entregador recebe um e-mail com detalhes da encomenda, com nome do produto e uma mensagem informando-o que o produto já está disponível para a retirada.

Crie rotas para listagem/cadastro/atualização/remoção de encomendas;

Obs.: Essa funcionalidade é para administradores autenticados na aplicação.

Funcionalidades do entregador

Abaixo estão descritas as funcionalidades que você deve adicionar em sua aplicação para os entregadores.

1. Visualizar encomendas

Para que o entregador possa visualizar suas encomendas, ele deverá informar apenas seu ID de cadastro (ID do entregador no banco de dados). Essa funcionalidade deve retornar as encomendas atribuidas a ele, que não estejam entregues ou canceladas;

Permita também que ele liste apenas as encomendas que já foram entregues por ele, com base em seu ID de cadastro;

Exemplo de requisição: GET https://fastfeet.com/deliveryman/1/deliveries

2. Alterar status de encomendas

Você deve permitir que o entregador tenha rotas para incluir uma data de retirada (start_date) e data de entrega (end_date) para as encomendas. O entregador só pode fazer 5 retiradas por dia.

Obs.: Para a funcionalidade de finalizar a entrega, você deverá permitir o envio de uma imagem que irá preencher o campo signature_id da tabela de encomendas.

3. Cadastrar problemas nas entregas

O entregador nem sempre conseguirá entregar as encomendas com sucesso, algumas vezes o destinatário pode estar ausente, ou o próprio entregador poderá ter algum problema com seu veículo na hora de entregar.

A tabela delivery_problems deve conter os seguintes campos:

  • delivery_id (referência da encomenda);
  • description (descrição do problema que o entregador teve);
  • created_at;
  • updated_at;

Crie uma rota para a distribuidora listar todas as entregas com algum problema;

Crie uma rota para listar todos os problemas de uma encomenda baseado no ID da encomenda.

Exemplo de requisição: GET https://fastfeet.com/delivery/2/problems

Crie uma rota para o entregador cadastrar problemas na entrega apenas informando seu ID de cadastro (ID da encomenda no banco de dados);

Exemplo de requisição: POST https://fastfeet.com/delivery/3/problems

Crie uma rota para a distribuidora cancelar uma entrega baseado no ID do problema. Esse cancelamento pode acontecer devido a gravidade do problema da entrega, por exemplo, em caso de perda da encomenda.

Exemplo de requisição: DELETE https://fastfeet.com/problem/1/cancel-delivery

Quando uma encomenda for cancelada, o entregador deve receber um e-mail informando-o sobre o cancelamento.

📅 Entrega

Esse desafio não precisa ser entregue e não receberá correção. Além disso, o código fonte não está disponível por fazer parte do desafio final, que será corrigido para certificação do bootcamp. Após concluir o desafio, adicionar esse código ao seu Github é uma boa forma de demonstrar seus conhecimentos para oportunidades futuras.

📝 Licença

Esse projeto está sob a licença MIT. Veja o arquivo LICENSE para mais detalhes.


Feito com ♥ by Rocketseat 👋 Entre na nossa comunidade!

5. Criando o projeto

  1. Configurando o Multer

    1. (multipart form data, multer conversa com esse formato e formato json).
      1. Usado para fazer upload de imagens de avatar (deliveryman).
      yarn add multer
      
      1. Criar config/multr.js
    2. Criar pasta tmp/uploads (onde vao ficar os arquivos de imagens)
    3. Adicionar a routes.js
    const upload = multer(multerConfig);
    
    1. Insomnia:
      1. Criar Files/POST
  2. Avatar.

    1. Criar FileController.js
    2. Migration de files { id, type, name, path, created_at, updated_at }:
    yarn sequelize migration:create --name=create-files
    yarn sequelize db:migrate
    
    1. Criar models/File.js, update database/index.js
    2. Incluir nova coluna a tabela "user" para vincular a tabela "files.
    yarn sequelize migration:create --name=add-avatar-field-to-deliverymans
    yarn sequelize db:migrate
    
    1. Vincular Deliveryman a File, Deliveryman.js
    static associate(models) {
     this.belongsTo(models.File, { foreignKey: 'avatar_id' });
    }
    1. Insomnia:
      1. Files/Post (Create): Multipart: file, Bearer.
  3. Listagem de Deliverymen ("Deliverymans" para se enquadrar na DB).

    1. Criar DeliverymanController.js
    2. adicionar rota a routes.js $$$$$$$$$$$$$$$$ completar com o restante de upload de arquivo....
  4. Migration e Model de entrega (Delivery).

    1. Migration de deliveries { id, recipient_id, deliveryman_id, product, canceled_at, start_date, end_date, created_at, updated_at, signature_id }
    yarn sequelize migration:create --name=create-deliveries
    
    1. Criar model Delivery.js
  5. Agendamento de delivery

    1. Criar DeliveryController.js
    2. Adicionar rota a routes.js
    3. Insomnia:
      1. Deliveries/Post (Create): { recipient_id, deliveryman_id, product }
  6. Validação de Delivery:

    1. Biblioteca para lidar com datas: date-fns
    yarn add date-fns@next (next: versão atual).
    
    1. Checks:
      1. DeliveryController.js create: isRecipient, isDeliveryman, checkAvailability
      2. DeliveryController.js update:
        1. isBefore openingTime,
        2. isAfter closingTime,
        3. Delivery already: started / ended / canceled.
        4. Deliveryman is making a delivery already.
      3. DeliveryController.js delete:
        1. Delivery already: ended / canceled.
  7. Listando deliveries:

    1. DeliveryController.js: obs. importante ter o attributo 'path'.
    2. Adicionar rota a routes.js
    3. Insomnia:
      1. Deliveries: Get (list): Bearer
  8. Aplicando paginação:

    1. Insomnia:
      1. Appointments/Get List, Query: page = 1.
      2. atualizar DeliveryController.js