e3ef47b87923d055cba04eaf2695f34c9992f32a
Clear auth store when exiting demo session to prevent unauthorized page redirect. ## Problem When users clicked "Salir" (Exit) from the demo session, they were redirected to the unauthorized page (`/unauthorized`) instead of the demo landing page (`/demo`). ## Root Cause The `handleExpiration()` function in DemoBanner.tsx was clearing localStorage and navigating to `/demo`, but was NOT clearing the auth store. This created an inconsistent state: - `isDemoMode = false` (localStorage cleared) - `demoSessionId = null` (localStorage cleared) - `isAuthenticated = true` (auth store NOT cleared - still has demo user) The `useHasAccess()` hook checks: ```typescript return isAuthenticated || (isDemoMode && !!demoSessionId); ``` After clearing localStorage but not auth: - `isAuthenticated = true` but the demo session is invalid - `isDemoMode = false` and `demoSessionId = null` - Result: `useHasAccess()` returns `false` When navigating to `/demo`, the ProtectedRoute checked access and found it was `false`, redirecting to `/unauthorized`. ## Solution Call `logout()` on the auth store before navigating to clear the demo user session completely. This ensures: - Auth store is cleared (`isAuthenticated = false`) - User is properly logged out from demo session - Navigation to `/demo` succeeds without authentication check ## Additional Improvements - Also clear `virtual_tenant_id` and `subscription_tier` from localStorage - Updated comment to clarify navigation intent ## Files Changed - frontend/src/components/layout/DemoBanner/DemoBanner.tsx:73-74 - Added auth store logout before navigation - Added clearing of virtual_tenant_id and subscription_tier - Updated comment for clarity 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
🍞 BakeWise - Multi-Service Architecture
Welcome to BakeWise, an advanced AI-powered platform for bakery management and optimization. This project implements a microservices architecture with multiple interconnected services to provide comprehensive bakery management solutions.
🚀 Quick Start
Prerequisites
- Docker Desktop with Kubernetes enabled
- Docker Compose
- Node.js (for frontend development)
Running the Application
-
Clone the repository:
git clone <repository-url> cd bakery-ia -
Set up environment variables:
cp .env.example .env # Edit .env with your specific configuration -
Run with Docker Compose:
docker-compose up --build -
Or run with Kubernetes (Docker Desktop):
# Enable Kubernetes in Docker Desktop # Run the setup script ./scripts/setup-kubernetes-dev.sh
🏗️ Architecture Overview
The project follows a microservices architecture with the following main components:
- Frontend: React-based dashboard for user interaction
- Gateway: API gateway handling authentication and routing
- Services: Multiple microservices handling different business domains
- Infrastructure: Redis, RabbitMQ, PostgreSQL databases
🐳 Kubernetes Infrastructure
🛠️ Services
The project includes multiple services:
- Auth Service: Authentication and authorization
- Tenant Service: Multi-tenancy management
- Sales Service: Sales processing
- External Service: Integration with external systems
- Training Service: AI model training
- Forecasting Service: Demand forecasting
- Notification Service: Notifications and alerts
- Inventory Service: Inventory management
- Recipes Service: Recipe management
- Suppliers Service: Supplier management
- POS Service: Point of sale
- Orders Service: Order management
- Production Service: Production planning
- Alert Processor: Background alert processing
📊 Monitoring
The system includes comprehensive monitoring with:
- Prometheus for metrics collection
- Grafana for visualization
- ELK stack for logging (planned)
🚀 Production Deployment
For production deployment on clouding.io with Kubernetes:
- Set up your clouding.io Kubernetes cluster
- Update image references to your container registry
- Configure production-specific values
- Deploy using the production kustomization:
kubectl apply -k infrastructure/kubernetes/environments/production/
🤝 Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Submit a pull request
📄 License
This project is licensed under the MIT License.
Description
Languages
Python
56.3%
TypeScript
39.6%
Shell
2.9%
CSS
0.4%
Starlark
0.3%
Other
0.3%