{"id":27816984,"url":"https://github.com/clubedojava/clube-do-java-frontend","last_synced_at":"2025-05-01T14:28:10.535Z","repository":{"id":290195463,"uuid":"973656154","full_name":"ClubeDoJava/Clube-do-java-frontend","owner":"ClubeDoJava","description":null,"archived":false,"fork":false,"pushed_at":"2025-04-27T13:20:20.000Z","size":498,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-04-27T14:25:59.813Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ClubeDoJava.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-04-27T13:11:43.000Z","updated_at":"2025-04-27T13:20:23.000Z","dependencies_parsed_at":"2025-04-27T14:36:29.503Z","dependency_job_id":null,"html_url":"https://github.com/ClubeDoJava/Clube-do-java-frontend","commit_stats":null,"previous_names":["clubedojava/clube-do-java-frontend"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ClubeDoJava%2FClube-do-java-frontend","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ClubeDoJava%2FClube-do-java-frontend/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ClubeDoJava%2FClube-do-java-frontend/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ClubeDoJava%2FClube-do-java-frontend/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ClubeDoJava","download_url":"https://codeload.github.com/ClubeDoJava/Clube-do-java-frontend/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":251889518,"owners_count":21660333,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-05-01T14:28:09.967Z","updated_at":"2025-05-01T14:28:10.524Z","avatar_url":"https://github.com/ClubeDoJava.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"#  🧼 Clube do Java - E-commerce\n\n![](https://img.shields.io/badge/Java-17-orange)\n![](https://img.shields.io/badge/Angular-darkred)\n![](https://img.shields.io/badge/Spring%20Boot-3.x-green)\n![](https://img.shields.io/badge/Project%20Loom-Virtual%20Threads-blue)\n![](https://img.shields.io/badge/Status-Production%20Ready-brightgreen)\n\nUma loja virtual especializada em produtos para desenvolvedores, como camisetas, canecas, adesivos e jaquetas. Projeto desenvolvido com Java 17 (Azul Zulu), Project Loom e Quasar, com recursos para concorrência e alta performance.\n\n\u003c!-- \u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://via.placeholder.com/800x400?text=Clube+do+Java\" alt=\"Clube do Java Banner\" width=\"600\"\u003e\n\u003c/p\u003e\n--\u003e\n\n\n## ✨ Funcionalidades\n\n- 🛍️ **Catálogo de Produtos**: Listagem, filtros e buscas avançadas\n- 🛒 **Carrinho de Compras**: Adição, remoção e atualização de itens\n- 👤 **Autenticação e Autorização**: Registro, login e controle de acesso\n- 💳 **Checkout**: Finalização de compras com seleção de frete e pagamento\n- 💰 **Pagamento**: Integração com Asaas para PIX e boleto\n- 📦 **Gestão de Pedidos**: Acompanhamento de status e histórico\n- 🚚 **Cálculo de Frete**: Integração com Correios, Jadlog e Braspress\n- 🔐 **Área do Usuário**: Gerenciamento de perfil, endereços e pedidos\n\n## 🛠️ Tecnologias Utilizadas\n\n### Backend\n- ☕ **Java 17 (Azul Zulu)**: Implementação do JDK com suporte LTS\n- 🧵 **Project Loom**: Uso de Virtual Threads para alta concorrência\n- 🌟 **Quasar**: Programação orientada a fibras para processos assíncronos\n- 🍃 **Spring Boot 3**: Framework para desenvolvimento rápido de aplicações\n- 🔒 **Spring Security**: Autenticação e autorização com JWT\n- 🗃️ **Spring Data JPA**: Persistência de dados simplificada\n- 🐘 **PostgreSQL**: Banco de dados relacional\n- ⚡ **Redis**: Cache distribuído\n- 🔑 **BouncyCastle**: Biblioteca para criptografia avançada\n- 🔄 **Flyway**: Migrations e versionamento do banco de dados\n\n### Integrações\n- 💸 **Asaas**: Gateway de pagamentos (PIX e boleto)\n- 📮 **Correios**: Cálculo de frete e rastreamento\n- 🚛 **Jadlog**: Opção adicional de transportadora\n- 🚚 **Braspress**: Opção adicional de transportadora\n\n### DevOps\n- 🐋 **Docker \u0026 Docker Compose**: Containerização da aplicação\n- 📊 **Prometheus \u0026 Grafana**: Monitoramento e métricas\n- 🔄 **Nginx**: Proxy reverso e balanceamento de carga\n\n## 🏗️ Arquitetura\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://via.placeholder.com/800x500?text=Arquitetura+do+Sistema\" alt=\"Arquitetura do Sistema\" width=\"600\"\u003e\n\u003c/p\u003e\n\nO sistema utiliza uma arquitetura de microserviços com os seguintes componentes:\n\n- 🌐 **API RESTful**: Interface para comunicação com o frontend\n- ⚡ **Serviços Assíncronos**: Processamento de pedidos e pagamentos usando Virtual Threads\n- 🚀 **Cache Distribuído**: Otimização de performance e redução de carga no banco de dados\n- 🔐 **Segurança**: Implementação de JWT com BouncyCastle para criptografia avançada\n\n## 📋 Pré-requisitos\n\n- ☕ Java 17 (preferencialmente Azul Zulu)\n- 🔨 Maven 3.8+\n- 🐋 Docker e Docker Compose\n- 🐘 PostgreSQL 13+\n- ⚡ Redis 6+\n\n## ⚙️ Configuração\n\n### Variáveis de Ambiente\n\nConfigure as seguintes variáveis de ambiente ou ajuste o arquivo `application.yml`:\n\n```properties\n# Banco de Dados\nDB_HOST=localhost\nDB_PORT=5432\nDB_NAME=clubedojava\nDB_USERNAME=postgres\nDB_PASSWORD=postgres\n\n# Redis\nREDIS_HOST=localhost\nREDIS_PORT=6379\n\n# JWT\nJWT_SECRET=your_jwt_secret_key\n\n# Asaas (Gateway de Pagamentos)\nASAAS_API_URL=https://sandbox.asaas.com/api/v3\nASAAS_API_KEY=your_asaas_api_key\nASAAS_WEBHOOK_SECRET=your_webhook_secret\n\n# Transportadoras\nORIGIN_ZIPCODE=01001000\nORIGIN_CITY=São Paulo\nORIGIN_STATE=SP\nCORREIOS_API_URL=https://api.correios.com.br\nCORREIOS_API_KEY=your_correios_api_key\nJADLOG_API_URL=https://api.jadlog.com.br\nJADLOG_API_KEY=your_jadlog_api_key\nBRASPRESS_API_URL=https://api.braspress.com\nBRASPRESS_API_KEY=your_braspress_api_key\n```\n\n## 🚀 Executando a Aplicação\n\n### Usando Maven\n\n```bash\n# Compilar o projeto\nmvn clean install\n\n# Executar a aplicação\nmvn spring-boot:run\n```\n\n### Usando Docker Compose\n\n```bash\n# Iniciar todos os serviços\ndocker-compose up -d\n\n# Verificar os logs\ndocker-compose logs -f app\n\n# Parar todos os serviços\ndocker-compose down\n```\n\n## 🔄 Endpoints da API\n\n### Autenticação e Usuários\n\n- `POST /api/auth/register` - Registro de novo usuário\n- `POST /api/auth/login` - Login do usuário\n- `GET /api/users/me` - Informações do usuário atual\n- `PUT /api/users/{id}` - Atualizar dados do usuário\n- `GET /api/users/{id}/addresses` - Listar endereços do usuário\n- `POST /api/users/{id}/addresses` - Adicionar novo endereço\n- `PUT /api/users/{userId}/addresses/{addressId}` - Atualizar endereço\n- `DELETE /api/users/{userId}/addresses/{addressId}` - Remover endereço\n\n### Produtos e Categorias\n\n- `GET /api/products` - Listar produtos\n- `GET /api/products/{id}` - Detalhes do produto\n- `GET /api/products/featured` - Produtos em destaque\n- `GET /api/products/category/{categoryId}` - Produtos por categoria\n- `GET /api/categories` - Listar categorias\n\n### Carrinho de Compras\n\n- `GET /api/cart` - Recuperar carrinho atual\n- `POST /api/cart/items` - Adicionar item ao carrinho\n- `PUT /api/cart/items/{itemId}` - Atualizar quantidade do item\n- `DELETE /api/cart/items/{itemId}` - Remover item do carrinho\n- `DELETE /api/cart` - Limpar carrinho\n\n### Pedidos\n\n- `GET /api/orders` - Listar pedidos do usuário\n- `GET /api/orders/{id}` - Detalhes do pedido\n- `POST /api/orders` - Criar novo pedido\n- `PATCH /api/orders/{id}/cancel` - Cancelar pedido\n- `GET /api/orders/tracking/{trackingNumber}` - Rastrear pedido\n\n### Cálculo de Frete\n\n- `POST /api/shipping/calculate` - Calcular opções de frete\n- `GET /api/shipping/tracking/{trackingNumber}` - Rastrear entrega\n\n## ⚡ Recursos Especiais de Project Loom e Quasar\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://via.placeholder.com/800x300?text=Virtual+Threads+Performance\" alt=\"Performance com Virtual Threads\" width=\"600\"\u003e\n\u003c/p\u003e\n\nA aplicação faz uso intensivo de Virtual Threads (Project Loom) e Quasar Fibers para alta concorrência:\n\n- 🚀 Processamento assíncrono de pedidos\n- ⚡ Cálculo paralelo de fretes de múltiplas transportadoras\n- 💸 Verificação de pagamentos em background\n- 🔄 Comunicação assíncrona com integrações externas\n\nEsses recursos permitem que a aplicação escale facilmente para lidar com milhares de requisições simultâneas com baixo consumo de recursos.\n\n## 🔒 Segurança\n\nA aplicação implementa diversas medidas de segurança:\n\n- 🔐 Autenticação JWT com BouncyCastle para criptografia avançada\n- 🔑 Senhas armazenadas com BCrypt\n- 🛡️ Proteção contra ataques CSRF e XSS\n- ✅ Validação de entrada em todos os endpoints\n- 🔒 HTTPS obrigatório em produção\n- 🔐 Comunicação segura com APIs de pagamento\n\n## 📊 Monitoramento\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://via.placeholder.com/800x400?text=Grafana+Dashboard\" alt=\"Dashboard de Monitoramento\" width=\"600\"\u003e\n\u003c/p\u003e\n\nO projeto incluí uma configuração pronta para monitoramento com:\n\n- 📈 Prometheus para coleta de métricas\n- 📊 Grafana para visualização e dashboards\n- ✅ Health checks para todos os serviços\n- 📝 Logs estruturados para fácil análise\n\n## 🤝 Contribuindo\n\n1. 🍴 Fork o repositório\n2. 🔄 Crie uma branch para sua feature (`git checkout -b feature/nome-da-feature`)\n3. ✅ Commit suas mudanças (`git commit -m 'Adiciona nova feature'`)\n4. ⬆️ Push para a branch (`git push origin feature/nome-da-feature`)\n5. 🔍 Abra um Pull Request\n\n## 📝 Licença\n\nEste projeto está licenciado sob a licença MIT - veja o arquivo LICENSE para detalhes.\n\n## 📞 Contato\n\nPara questões ou sugestões, entre em contato através do email: contato@clubedojava.com.br\n\n---\n\n\u003cp align=\"center\"\u003e\n  Feito com ☕ e 💙 pelo clube do Java para a comunidade Java!\n\u003c/p\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fclubedojava%2Fclube-do-java-frontend","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fclubedojava%2Fclube-do-java-frontend","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fclubedojava%2Fclube-do-java-frontend/lists"}