Giter Site home page Giter Site logo

mateuschaves / gym-nodejs Goto Github PK

View Code? Open in Web Editor NEW
0.0 2.0 0.0 702 KB

🏋️‍♀️💪 Api feita usando fastify e prisma para gerenciar check-ins de academia

Home Page: https://gym-nodejs-production.up.railway.app

JavaScript 0.17% TypeScript 99.83%
backend fastify jest-tests prisma typescript nodejs

gym-nodejs's Introduction

Gym NodeJS

🏋️‍♀️ 💪 Api feita usando fastify e prisma para gerenciar check-ins de academia

Requisitos

Node.js (versão 16.x ou superior)

TypeScript (versão 5 ou superior)

Docker

Instalação

  1. Clone o repositório: git clone https://github.com/mateuschaves/gym-nodejs.git
  2. Instale as dependências: npm install
  3. Crie um arquivo .env usando o modelo de exemplo .env.example
  4. Execute as migrations usando o comando: npx prisma migrate deploy

Ao executar as migrations, uma seed popula o banco com um usuário ADMIN com as seguintes credenciais:

{
   "email": "[email protected]",
   "password": "123456"
}
   

Obs: A senha é gerada usando o secret gym nas configurações do JWT

Uso

Inicie o banco de dados utilizando o docker compose:

    docker-compose up --build

Para iniciar o servidor, utilize o seguinte comando:

    npm run start:dev

Tests unitários

Execute os testes unitários utilizando o seguinte comando:

 npm run test

Tests e2e

Execute os testes e2e utilizando o seguinte comando:

 npm run test:e2e

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 o 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 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;

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 PostgreSQL;
  • 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);

Contribuição

  1. Faça o fork do projeto
  2. Crie sua feature branch (git checkout -b feature/nome-da-feature)
  3. Commit suas mudanças (git commit -am 'Adicionando nova feature')
  4. Faça o push para o branch (git push origin feature/nome-da-feature)
  5. Crie um novo Pull Request

gym-nodejs's People

Contributors

mateuschaves avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.