https://github.com/larads/api-solid-nodejs
Aplicação para check-ins em academias. alguns conceitos ide SOLID, Design Patterns, Docker para iniciar o Banco de Dados, JWT e Refresh Token, RBAC e outros conceitos.
https://github.com/larads/api-solid-nodejs
jwt nodejs prisma vitest zod
Last synced: about 2 months ago
JSON representation
Aplicação para check-ins em academias. alguns conceitos ide SOLID, Design Patterns, Docker para iniciar o Banco de Dados, JWT e Refresh Token, RBAC e outros conceitos.
- Host: GitHub
- URL: https://github.com/larads/api-solid-nodejs
- Owner: larads
- Created: 2024-08-27T19:27:55.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-08-29T19:47:21.000Z (almost 2 years ago)
- Last Synced: 2025-05-21T18:35:16.243Z (about 1 year ago)
- Topics: jwt, nodejs, prisma, vitest, zod
- Language: TypeScript
- Homepage:
- Size: 441 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: Readme.md
Awesome Lists containing this project
README
# App
GymPass style app.
## RFs (Requisitos funcionais)
- [x] Deve ser possível se cadastrar;
- [x] Deve ser possível se autenticar;
- [x] Deve ser possível obter o perfil de um usuário logado;
- [x] Deve ser possível obter o número de check-ins realizados pelo usuário logado;
- [x] Deve ser possível o usuário obter o seu histórico de check-ins;
- [x] Deve ser possível o usuário buscar academias próximas;
- [x] Deve ser possível o usuário buscar academias pelo nome;
- [x] Deve ser possível o usuário realizar check-in em uma academia;
- [x] Deve ser possível validar o check-in de um usuário;
- [x] Deve ser possível cadastrar uma academia;
## RNs (Regras de negócio)
- [x] O usuário não deve poder se cadastrar com um e-mail duplicado;
- [x] O usuário não pode fazer 2 check-ins no mesmo dia;
- [x] O usuário não pode fazer check-in se não estiver perto (100m) da academia;
- [x] O check-in só pode ser validado até 20 minutos após ser criado;
- [x] O check-in só pode ser validado por administradores;
- [x] A academia só pode ser cadastrada por administradores;
## RNFs (Requisitos não-funcionais)
- [x] A senha do usuário precisa estar criptografada;
- [x] Os dados da aplicação precisam estar persistidos em um banco PostgreSQL;
- [x] Todas listas de dados precisam estar paginadas com 20 itens por página;
- [x] O usuário deve ser identificado por um JWT (JSON Web Token);