Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matheusfd3/gobarber-api
API construida com NodeJS para gobarber-web.
https://github.com/matheusfd3/gobarber-api
2021 api express nodejs
Last synced: about 2 months ago
JSON representation
API construida com NodeJS para gobarber-web.
- Host: GitHub
- URL: https://github.com/matheusfd3/gobarber-api
- Owner: matheusfd3
- License: mit
- Created: 2020-11-18T18:32:51.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-03-23T17:38:49.000Z (almost 4 years ago)
- Last Synced: 2024-04-29T02:38:10.516Z (9 months ago)
- Topics: 2021, api, express, nodejs
- Language: TypeScript
- Homepage:
- Size: 405 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Recuperação de senha
**Requisitos Funcionais**
- O usuário deve poder recuperar sua senha informando o seu e-mail;
- O usuário deve receber um e-mail com instruções de recuperação de senha;
- O usuário deve poder resetar sua senha;**Requisitos Não Funcionais**
- 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);**Regras de Negócios**
- O link enviado por e-mail para resetar a senha, deve expirar em 2h;
- O usuário precisa confirmar a nova senha ao resetar sua senha;# Atualização do perfil
**Requisitos Funcionais**
- O usuário deve poder atualizar seu nome, e-mail e senha;
**Regras de Negócios**
- O usuário não pode alterar seu e-mail para um e-mail 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
**Requisitos Funcionais**
- 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;**Requisitos Não Funcionais**
- Os agendamentos do prestador no dia devem ser armazenados em cache;
- As notificações do prestador devem ser armazanadas no MongoDB;
- As notificações do prestador devem ser enviadas em tempo-real utilizando Socket.io;**Regras de Negócios**
- A notificação deve ter um status de lida e não-lida para que o prestador possa controlar;
# Agendamento de serviços
**Requisitos Funcionais**
- O usuário deve poder listar todos os prestadores de serviços cadastrados;
- O usuário deve poder listar os dias de um mês com pelo menos um horário disponível de um prestador;
- O usuário deve poder listar horários disponíveis de um prestador;
- O usuário deve poder realizar um novo agendamento com um prestador;**Requisitos Não Funcionais**
- A listagem de prestadores devem ser armazenadas em cache;
**Regras de Negócios**
- 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;