Skip to content

Latest commit

 

History

History
176 lines (151 loc) · 15.2 KB

README.md

File metadata and controls

176 lines (151 loc) · 15.2 KB

E-Commerce Manager

Status

O E-Commerce Manager é uma API REST robusta para gestão de E-Commerce. Construída em Java e Ecossistema Spring, prioriza código limpo e implementação de princípios SOLID, além de Design Patterns para criar um software flexível, escalável e de fácil manutenção. Utiliza tecnologias como JPA, Hibernate, JWT, JUnit, Mockito e log4j2 para garantir a qualidade e eficiência do sistema.

Problema a ser solucionado:

Este software visa resolver desafios relacionados à gestão de e-commerce, fornecendo funcionalidades essenciais para gerenciamento de:

Cadastro de Usuários e Administradores:

  • Cadastro de clientes
  • Autenticação com token jwt
  • Cadastro de administradores
  • Autorizações diferentes para administradores e clientes

Gestão de Produtos e Inventário:

  • Cadastro de produtos
  • Cadastro dos itens de inventário
  • Cadastro de categorias para os produtos

Gestão de Pedidos e Pagamentos:

  • Pedidos
  • Itens de pedido
  • Pagamento por PIX consumindo a API do Banco EfíBank

Gestão de Promoções e Descontos:

  • Desconto em produtos
  • Cupons de desconto para pedidos

Gestão de Entrega e Estoque:

  • Cadastro dos endereços de entrega
  • Movimentações de entrada e saída do estoque

Comunicação e Review:

  • Review dos clientes acerca dos produtos
  • Notificações de anúncios dos administradores
  • Envio de emails para entrega de recibo de compra e redefinição de senha

Modelo Conceitual

Diagrama Entidade-Relacionamento der-ecommerce-manager

Stack utilizada

  • Java 17
  • Spring
  • Spring Data JPA
  • Hibernate
  • Spring Security
  • JWT
  • Junit
  • Mockito
  • Log4J2
  • Spring Mail
  • Efí Bank SDK
  • Spring Retry
  • H2 Database

Funcionalidades e Rotas

Descrição Método HTTP Endpoint Autorizações
Registro de usuário POST /api/v1/register Não Requer Autorização
Login de autenticação POST /api/v1/authenticate Não Requer Autorização
Listar endereços GET /api/v1/addresses ADMIN, MANAGER
Adicionar endereço POST /api/v1/addresses ADMIN, MANAGER, CLIENT
Atualizar endereço PUT /api/v1/addresses/{id} ADMIN, MANAGER, CLIENT
Excluir endereço DELETE /api/v1/addresses/{id} ADMIN, MANAGER, CLIENT
Detalhes de um endereço específico GET /api/v1/addresses/{id} ADMIN, MANAGER, CLIENT
Listar categorias GET /api/v1/categories ADMIN, MANAGER, CLIENT
Adicionar categoria POST /api/v1/categories ADMIN, MANAGER
Atualizar categoria PUT /api/v1/categories/{id} ADMIN, MANAGER
Excluir categoria DELETE /api/v1/categories/{id} ADMIN
Detalhes de uma categoria específica GET /api/v1/categories/{id} ADMIN, MANAGER, CLIENT
Pesquisar categoria por nome GET /api/v1/categories/search ADMIN, MANAGER, CLIENT
Listar itens de inventário GET /api/v1/inventory-items ADMIN, MANAGER
Adicionar item de inventário POST /api/v1/inventory-items ADMIN, MANAGER
Atualizar item de inventário PUT /api/v1/inventory-items/{id} ADMIN, MANAGER
Excluir item de inventário DELETE /api/v1/inventory-items/{id} ADMIN
Detalhes de um item de inventário GET /api/v1/inventory-items/{id} ADMIN, MANAGER
Listar pedidos GET /api/v1/orders ADMIN, MANAGER
Adicionar pedido POST /api/v1/orders ADMIN, MANAGER, CLIENT
Atualizar pedido PUT /api/v1/orders/{id} ADMIN, MANAGER, CLIENT
Atualizar apenas status do pedido PATCH /api/v1/orders/status/{id} ADMIN, MANAGER
Excluir pedido DELETE /api/v1/orders/{id} ADMIN, MANAGER, CLIENT
Detalhes de um pedido específico GET /api/v1/orders/{id} ADMIN, MANAGER
Listar pedidos de um client GET /api/v1/orders/client/{id} ADMIN, MANAGER, CLIENT
Listar itens de pedido GET /api/v1/order-items ADMIN, MANAGER, CLIENT
Adicionar item de pedido POST /api/v1/order-items ADMIN, MANAGER, CLIENT
Atualizar item de pedido PUT /api/v1/order-items ADMIN, MANAGER, CLIENT
Excluir item de pedido DELETE /api/v1/order-items/{orderId}/{itemId} ADMIN, MANAGER, CLIENT
Detalhes de um item de pedido específico GET /api/v1/order-items/{orderId}/{itemId} ADMIN, MANAGER, CLIENT
Listar pagamentos GET /api/v1/payments ADMIN, MANAGER
Realizar pagamento POST /api/v1/payments ADMIN, MANAGER, CLIENT
Excluir pagamento DELETE /api/v1/payments/{id} ADMIN
Detalhes de um pagamento específico GET /api/v1/payments/{id} ADMIN, MANAGER
Listar produtos GET /api/v1/products ADMIN, MANAGER, CLIENT
Adicionar produto POST /api/v1/products ADMIN, MANAGER
Atualizar produto PUT /api/v1/products/{id} ADMIN, MANAGER
Excluir produto DELETE /api/v1/products/{id} ADMIN
Detalhes de um produto específico GET /api/v1/products/{id} ADMIN, MANAGER, CLIENT
Pesquisar produto por nome GET /api/v1/products/search ADMIN, MANAGER, CLIENT
Listar movimentações de estoque GET /api/v1/stock-movements ADMIN, MANAGER
Adicionar movimentação de estoque POST /api/v1/stock-movements ADMIN, MANAGER
Atualizar movimentação de estoque PUT /api/v1/stock-movements/{id} ADMIN, MANAGER
Excluir movimentação de estoque DELETE /api/v1/stock-movements/{id} ADMIN
Detalhes de uma movimentação de estoque GET /api/v1/stock-movements/{id} ADMIN, MANAGER
Listar usuários GET /api/v1/users ADMIN, MANAGER
Adicionar usuário POST /api/v1/users ADMIN, MANAGER, CLIENT
Atualizar usuário PUT /api/v1/users/{id} ADMIN, MANAGER, CLIENT
Excluir usuário DELETE /api/v1/users/{id} ADMIN, MANAGER, CLIENT
Detalhes de um usuário específico GET /api/v1/users/{id} ADMIN, MANAGER, CLIENT
Pesquisar usuário por nome GET /api/v1/users/search ADMIN, MANAGER
Adicionar função de usuário PATCH /api/v1/users/roles/{id} ADMIN
Listar cupons de desconto GET /api/v1/discount-coupons ADMIN, MANAGER, CLIENT
Criar cupom de desconto POST /api/v1/discount-coupons ADMIN, MANAGER
Detalhes de um cupom de desconto específico GET /api/v1/discount-coupons/{id} ADMIN, MANAGER, CLIENT
Atualizar cupom de desconto PUT /api/v1/discount-coupons/{id} ADMIN, MANAGER
Excluir cupom de desconto DELETE /api/v1/discount-coupons/{id} ADMIN, MANAGER
Listar notificações GET /api/v1/notifications ADMIN, MANAGER, CLIENT
Adicionar notificação POST /api/v1/notifications ADMIN, MANAGER,
Atualizar notificação PUT /api/v1/notifications/{id} ADMIN, MANAGER,
Excluir notificação DELETE /api/v1/notifications/{id} ADMIN, MANAGER,
Detalhes de uma notificação específica GET /api/v1/notifications/{id} ADMIN, MANAGER, CLIENT
Listar descontos de produtos GET /api/v1/product-discounts ADMIN, MANAGER
Adicionar desconto de produto POST /api/v1/product-discounts ADMIN, MANAGER,
Atualizar desconto de produto PUT /api/v1/product-discounts/{id} ADMIN, MANAGER,
Excluir desconto de produto DELETE /api/v1/product-discounts/{id} ADMIN, MANAGER,
Detalhes de um desconto de produto específico GET /api/v1/product-discounts/{id} ADMIN, MANAGER
Listar reviews dos produtos GET /api/v1/product-reviews ADMIN, MANAGER
Adicionar review do produto POST /api/v1/product-reviews ADMIN, MANAGER, CLIENT
Atualizar review do produto PUT /api/v1/product-reviews ADMIN, MANAGER, CLIENT
Excluir review do produto DELETE /api/v1/product-reviews/{productId}/{userId} ADMIN, MANAGER
Detalhes de um review do produto específico GET /api/v1/product-reviews/{productId/{userId} ADMIN, MANAGER, CLIENT
Validar o email do usuário GET /api/v1/email/validate/search ADMIN, MANAGER, CLIENT
Solicitar redefinição da senha POST /api/v1/email/password-reset Não Requer Autorização
Validar a redefinição da senha PUT /api/v1/email/password-reset ADMIN, MANAGER, CLIENT
Listar pix pagas GET /api/v1/pix/charges/search ADMIN, MANAGER, CLIENT
Receber da API banco atualizações de pagamento das cobranças GET /api/v1/webhook/pix certificado de autenticação
Receber da API do banco teste de conexão GET /api/v1/webhook certificado de autenticação

Rodando localmente

Siga as etapas abaixo para configurar e executar o projeto Java com Spring localmente:

  1. Certifique-se de ter o Java 17 JDK instalado. Caso não tenha, faça o download e a instalação a partir do site oficial da Oracle.

  2. Clone o repositório do projeto:

  git clone /~https://github.com/rogeriobgregorio/ecommerce-manager
  1. Acesse o diretório do projeto:
  cd ecommerce-manager
  1. Execute o projeto:
  ./mvnw spring-boot:run

Caso prefira, abra o projeto em uma IDE, como IntelliJ por exemplo, e execute o projeto.

Após concluir essas etapas, o seu servidor Spring estará em execução localmente na porta 8080.

Autor

Rogério Bernardo Gregório