Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/natanaelvich/gympass-api-ignite-rocketseat-23
Uma aplicação de exemplo que simula funcionalidades básicas de um app de academia.
https://github.com/natanaelvich/gympass-api-ignite-rocketseat-23
eslint fastify postgresql prisma typescript zod
Last synced: 19 days ago
JSON representation
Uma aplicação de exemplo que simula funcionalidades básicas de um app de academia.
- Host: GitHub
- URL: https://github.com/natanaelvich/gympass-api-ignite-rocketseat-23
- Owner: Natanaelvich
- License: mit
- Created: 2023-03-21T01:40:37.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-04-07T02:20:11.000Z (over 1 year ago)
- Last Synced: 2024-04-17T22:09:24.289Z (8 months ago)
- Topics: eslint, fastify, postgresql, prisma, typescript, zod
- Language: TypeScript
- Homepage:
- Size: 316 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: license
Awesome Lists containing this project
README
# GymPass style app
Uma aplicação de exemplo que simula funcionalidades básicas de um app de academia.
## Requisitos Funcionais (RFs)
- [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;
- [ ] 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;
- [ ] Deve ser possível o usuário buscar academias próximas;
- [ ] Deve ser possível o usuário busca academias pelo nome;
- [ ] Deve ser possível o usuário realizar check-in em uma academia;
- [ ] Deve ser possível validar o check-in de um usuário;
- [ ] Deve ser possível cadastrar uma academia.## Regras de Negócio (RNs)
- [x] O usuário não deve poder se cadastrar com um e-mail duplicado;
- [ ] O usuário não pode fazer 2 check-ins no mesmo dia;
- [ ] O usuário não pode fazer check-in se não estiver perto (100m) da academia;
- [ ] O check-in só pode ser validado até 20 minutos após criado;
- [ ] O check-in só pode ser validado por administradores;
- [ ] A academia só pode ser cadastrada por administradores.## Requisitos Não Funcionais (RNFs)
- [x] A senha do usuário precisa estar criptografada;
- [ ] 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;
- [ ] O usuário deve ser identificado por um JWT (JSON Web Token).## Scripts
- `dev`: Roda a aplicação em modo de desenvolvimento.
- `start`: Roda a aplicação em produção, após ser compilada.
- `build`: Compila a aplicação.## Como usar
1. Clone o repositório: `git clone https://github.com/natanaelvich/03-api-solid.git`
2. Instale as dependências: `npm install`
3. Inicie o servidor: `npm run dev`
4. Acesse `http://localhost:3000` para testar a API.