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.
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
Diagrama Entidade-Relacionamento
- Java 17
- Spring
- Spring Data JPA
- Hibernate
- Spring Security
- JWT
- Junit
- Mockito
- Log4J2
- Spring Mail
- Efí Bank SDK
- Spring Retry
- H2 Database
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 |
Siga as etapas abaixo para configurar e executar o projeto Java com Spring localmente:
-
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.
-
Clone o repositório do projeto:
git clone https://github.com/rogeriobgregorio/ecommerce-manager
- Acesse o diretório do projeto:
cd ecommerce-manager
- 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.
- Linkedin: linkedin.com/in/rogeriogregorio
- Email: [email protected]