../projeto

GymPass

API Back-end para uma aplicação para check-ins em academias, estilo gympass, aplicando conceitos do SOLID, Design Patterns, Docker para iniciar o banco de dados, JWT e Refresh Token, RBAC e diversos outros conceitos. A aplicação está bem completa com todas as funcinalidades de um gympass e com validações de dados utilizando o ZOD, testes unitários e e2e, além de utilizar o github actions para um CI/CD.

Node.jsFastifyTypescriptPrismaZodDockerVitest
Voltar para projetos

GymPass

API Back-end para uma aplicação para check-ins em academias, estilo gympass, aplicando conceitos do SOLID, Design Patterns, Docker para iniciar o banco de dados, JWT e Refresh Token, RBAC e diversos outros conceitos. A aplicação está bem completa com todas as funcinalidades de um gympass e com validações de dados utilizando o ZOD, testes unitários e e2e, além de utilizar o github actions para um CI/CD.

RFs (Requisitos funcionais)

  • Deve ser possível se cadastrar;
  • Deve ser possível se autenticar;
  • 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;
  • 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 (até 10km);
  • Deve ser possível o usuário buscar academais 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;

RNs (Regras de negócio)

  • 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 ser criado;
  • O check-in só pode ser validado por administradores;
  • A academia só pode ser cadastrada por administradores;

RNFs (Requisitos não funcionais)

  • A senha do usuário precisa estar criptografada;
  • Os dados da aplicação precisam estar persistidos em um banco PostgreeSQL;
  • Todas listas de dados precisam estar paginadas com 20 itens por página;
  • O usuário deve ser indentificado por um JWT (JSON Web Token);

⚙ Clonando Projeto

# Faça o clone do repotório
git clone git@github.com/Victtor-777/Gympass-Node.git

# Instalar as dependências do projeto
npm install

# Rodar as migrations do projeto para criar o banco de dados
npx prisma migrate dev

# Executando o projeto no ambiente de desenvolvimento
npm run dev

🚀 Tecnologias

  • Node.js
  • TypeScript
  • Fastify
  • Prisma
  • Docker
  • Zod
  • Vitest
  • MySQL

Gympass

imagem da sessão Gympass