https://github.com/danicunhac/gobarber-server
Backend do projeto principal desenvolvido durante o bootcamp GoStack da Rocketseat 🚀 para gerenciamento de agendamentos em barbearias 🪒🧔💈. NodeJS, Typescript, Express, TypeORM, JWT
https://github.com/danicunhac/gobarber-server
express jwt nodejs typeorm typescript
Last synced: about 2 months ago
JSON representation
Backend do projeto principal desenvolvido durante o bootcamp GoStack da Rocketseat 🚀 para gerenciamento de agendamentos em barbearias 🪒🧔💈. NodeJS, Typescript, Express, TypeORM, JWT
- Host: GitHub
- URL: https://github.com/danicunhac/gobarber-server
- Owner: danicunhac
- Created: 2020-11-26T12:34:08.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2021-02-19T00:35:58.000Z (over 5 years ago)
- Last Synced: 2025-03-17T05:45:50.616Z (over 1 year ago)
- Topics: express, jwt, nodejs, typeorm, typescript
- Language: TypeScript
- Homepage:
- Size: 1020 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README

# GoBarber Server
Backend do projeto **principal** desenvolvido durante o bootcamp GoStack da Rocketseat 🚀 para gerenciamento de agendamentos em barbearias 🪒🧔💈. NodeJS, Typescript, Express, TypeORM, JWT
## Recuperação de senha
**RF**
- O usuário deve poder recuperar sua senha informando o seu email;
- O usuário deve receber um e-mail com instruções de recuperação de senha;
- O usuário deve poder resetar sua senha;
**RNF**
- Utilizar Mailtrap para testar envios em ambiente de desenvolvimento;
- Utilizar Amazon SES para envios em produção;
- O envio de e-mails deve acontecer em segundo plano (background job);
**RN**
- O link enviado por email para resetar senha, deve expirar em 2h;
- O usuário precisa confirmar a nova senha ao resetá-la;
## Atualização do perfil
**RF**
- O usuário deve poder atualizar seu nome, email e senha;
**RN**
- O usuário não pode alterar seu email para um email já utilizado;
- Para atualizar sua senha, o usuário deve informar a senha antiga;
- Para atualizar sua senha, o usuário precisa confirmar a nova senha;
## Painel do prestador
**RF**
- O usuário deve poder listar seus agendamentos de um dia específico;
- O prestador deve receber uma notificação sempre que houver um novo agendamento;
- O prestador deve poder visualizar as notificações não lidas;
**RNF**
- Os agendamentos do prestador no dia devem ser armazenados em cache;
- As notificações do prestador devem ser armazenadas no MongoDB;
- As notificações do prestador devem ser enviadas em tempo-real utilizando Socket.io;
**RN**
- A notificação deve ter um status de lida ou não-lida para que o prestador possa controlar;
## Agendamento de serviços
**RF**
- O usuário deve poder listar todos os prestadores de serviço cadastrados;
- O usuário deve poder listar os dias de um mês com pelo menos horário disponível de um prestador;
- O usuário deve poder listar os horários disponíveis em um dia específico de um prestador;
- O usuário deve poder realizar um novo agendamento com um prestador;
**RNF**
- A listagem de prestadores deve ser armazenada em cache;
**RN**
- Cada agendamento deve durar 1h exatamente;
- Os agendamentos devem estar disponíveis entre 8h às 18h (Primeiro às 8h, último às 17h);
- O usuário não pode agendar em um horário já ocupado;
- O usuário não pode agendar em um horário que já passou;
- O usuário não pode agendar serviços consigo mesmo;