Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/devkayos/03-api-solid

API Rest que simula um Gympass, com autentificacao por meio de token JWT, RBAC para fazer a distincao de cargos como Admin e membros comuns, criada usando os principios do SOLID, TDD e testes na aplicacao toda testando use cases e testes e2e que testam varias camadas da aplicacao.
https://github.com/devkayos/03-api-solid

docker fastify jwt-authentication nodejs solid typescript vitest

Last synced: 11 days ago
JSON representation

API Rest que simula um Gympass, com autentificacao por meio de token JWT, RBAC para fazer a distincao de cargos como Admin e membros comuns, criada usando os principios do SOLID, TDD e testes na aplicacao toda testando use cases e testes e2e que testam varias camadas da aplicacao.

Awesome Lists containing this project

README

        

# App

Gympass style app.

# 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 seu histórico de check-ins;
- [X] Deve ser possível o usuário buscar academias próximas (até 10km);
- [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;

# 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 valido até 20 minutos após criado;
- [X] O check-in só pode ser validado por administradores;
- [X] A academia só pode ser cadastrada por administradores

# 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 PostgresSQL
- [X] Todas as 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);

TODO