/delivery_back

Repositório Ruby On Rails de uma aplicação de delivery com autenticação, threads, docker, testes. Back-end e interface :admin e developer.

Primary LanguageHTML

Java Projects Logo Aplicação de Delivery Java Projects Logo

🌐 Idiomas

Português Español English Русский 中文 العربية

Este repositório representa o backend em Rails para uma aplicação de delivery, incluindo uma interface de gerenciamento de dados para usuários com as roles admin e developer.

Ilustração de uso da interface do admin


🔗 Repositórios Relacionados

📚 Conceitos e Gems Utilizadas

🔍 Clique para expandir os detalhes das Gems e Conceitos
  • Processos em Background: Utilização do Sidekiq para o processamento assíncrono de tarefas. O Redis é utilizado como fila de armazenamento para essas tarefas.

  • Paginação: Implementação de paginação para listagem de recursos utilizando a gem Kaminari.

  • Testes com RSpec e Shoulda Matchers: Utilização de RSpec para escrever testes de unidade, integração e funcionalidade.

  • Cobertura de Testes com SimpleCov: Integração com a gem SimpleCov para realizar análises de cobertura de código.

  • Soft Delete com Discard: Implementação de exclusão suave (soft delete) com a gem Discard.

  • Bullet para Detecção de N+1 Queries: A gem Bullet é utilizada para detectar e prevenir problemas de desempenho como N+1 queries.

  • Anonimização de Dados: Aplicação de técnicas para anonimizar dados sensíveis, garantindo a conformidade com normas de privacidade e segurança, como a LGPD.

  • API RESTful: Desenvolvimento de uma API RESTful que segue os princípios de arquiteturas de software para permitir uma comunicação eficiente entre o backend e o frontend.

  • Swagger: Documentação automática da API utilizando a gem Rswag (baseada no Swagger).

  • Docker: Opção de containerização utilizando Docker para facilitar o desenvolvimento, teste e deployment.

  • Manipulação de Imagens: Utilização da gem ImageProcessing para manipulação de imagens, como redimensionamento e compressão.

  • WebSockets e SSE: Implementação de comunicação em tempo real usando WebSockets.

  • Cálculo de Distância: Utilização da gem Geocoder para implementar o cálculo de distância entre o cliente e o estabelecimento comercial.

  • Threads: Uso de threads para melhorar a concorrência e o desempenho da aplicação em operações paralelas.

  • Gerenciamento de Sessão e Autenticação: Implementação de autenticação de usuários com Devise e autenticação via JWT.

  • Controle de CORS: Utilização da gem rack-cors para gerenciar as permissões de CORS.

  • Máquinas de Estado com State Machines: Utilização da gem state_machines-activerecord para implementação de máquinas de estado nos modelos ActiveRecord.

  • Faraday para Consumo de APIs Externas: Integração com serviços externos utilizando a gem Faraday.

  • Automação de Tarefas e DevOps: A estrutura DevOps é suportada por ferramentas como Sidekiq e Docker.


⚙️ Setup do Projeto

🛠️ Com Docker

Pré-requisitos

  • Certifique-se de ter o Docker e o Docker Compose instalados em sua máquina.
  • Docker
  • Docker Compose

Configuração

  1. Clone os repositórios relacionados:

    git clone https://github.com/SamuelRocha91/consumy.git
    git clone https://github.com/SamuelRocha91/seller_application.git
    git clone https://github.com/SamuelRocha91/paymenty.git
    git clone https://github.com/SamuelRocha91/delivery_back.git
    
  2. Baixe o arquivo docker-compose.yml:

  3. Na raiz do projeto, execute o seguinte comando:

    docker-compose up --build
  4. Clique em "RUN PENDING MIGRATES" na aplicação back-end.

  5. Entre no container do back-end e rode as seeds:

    docker exec -it nomeDoContainerBackEnd /bin/sh 
    rails db:seed
  6. Configure as variáveis de ambiente:

    JWT_SECRET_KEY=xxxxxxxxxxxxxxxxxxxxx
  7. Reinicie os containers para as variáveis serem carregadas.

🛠️ Sem Docker

Pré-requisitos

  • Certifique-se de ter o Redis e o Sidekiq configurados e rodando localmente.

  • Instale as dependências do R:

    install.packages("FactoMineR")
    install.packages("ggplot2")
    install.packages("reshape2")

Instalação das Dependências

bundle install

Configurar o Banco de Dados

Crie o banco de dados e execute as migrações:

rails db:create
rails db:migrate

Iniciar o Servidor Local

rails server

Executar Testes

bundle exec rspec

Iniciar Redis e Sidekiq

redis-server
bundle exec sidekiq

📝 Outros projetos