104 lines
4.6 KiB
Python
104 lines
4.6 KiB
Python
# ================================================================
|
|
# TENANT SERVICE CONFIGURATION
|
|
# services/tenant/app/core/config.py
|
|
# ================================================================
|
|
|
|
"""
|
|
Tenant service configuration
|
|
Multi-tenant management and subscription handling
|
|
"""
|
|
|
|
from shared.config.base import BaseServiceSettings
|
|
import os
|
|
|
|
class TenantSettings(BaseServiceSettings):
|
|
"""Tenant service specific settings"""
|
|
|
|
# Service Identity
|
|
APP_NAME: str = "Tenant Service"
|
|
SERVICE_NAME: str = "tenant-service"
|
|
DESCRIPTION: str = "Multi-tenant management and subscription service"
|
|
|
|
# Database configuration (secure approach - build from components)
|
|
@property
|
|
def DATABASE_URL(self) -> str:
|
|
"""Build database URL from secure components"""
|
|
# Try complete URL first (for backward compatibility)
|
|
complete_url = os.getenv("TENANT_DATABASE_URL")
|
|
if complete_url:
|
|
return complete_url
|
|
|
|
# Build from components (secure approach)
|
|
user = os.getenv("TENANT_DB_USER", "tenant_user")
|
|
password = os.getenv("TENANT_DB_PASSWORD", "tenant_pass123")
|
|
host = os.getenv("TENANT_DB_HOST", "localhost")
|
|
port = os.getenv("TENANT_DB_PORT", "5432")
|
|
name = os.getenv("TENANT_DB_NAME", "tenant_db")
|
|
|
|
return f"postgresql+asyncpg://{user}:{password}@{host}:{port}/{name}"
|
|
|
|
# Redis Database (dedicated for tenant data)
|
|
REDIS_DB: int = 4
|
|
|
|
# Service URLs for usage tracking
|
|
RECIPES_SERVICE_URL: str = os.getenv("RECIPES_SERVICE_URL", "http://recipes-service:8004")
|
|
SUPPLIERS_SERVICE_URL: str = os.getenv("SUPPLIERS_SERVICE_URL", "http://suppliers-service:8005")
|
|
|
|
# Subscription Plans
|
|
DEFAULT_PLAN: str = os.getenv("DEFAULT_PLAN", "basic")
|
|
TRIAL_PERIOD_DAYS: int = int(os.getenv("TRIAL_PERIOD_DAYS", "14"))
|
|
|
|
# Plan Limits
|
|
BASIC_PLAN_LOCATIONS: int = int(os.getenv("BASIC_PLAN_LOCATIONS", "1"))
|
|
BASIC_PLAN_PREDICTIONS_PER_DAY: int = int(os.getenv("BASIC_PLAN_PREDICTIONS_PER_DAY", "100"))
|
|
BASIC_PLAN_DATA_RETENTION_DAYS: int = int(os.getenv("BASIC_PLAN_DATA_RETENTION_DAYS", "90"))
|
|
|
|
PREMIUM_PLAN_LOCATIONS: int = int(os.getenv("PREMIUM_PLAN_LOCATIONS", "5"))
|
|
PREMIUM_PLAN_PREDICTIONS_PER_DAY: int = int(os.getenv("PREMIUM_PLAN_PREDICTIONS_PER_DAY", "1000"))
|
|
PREMIUM_PLAN_DATA_RETENTION_DAYS: int = int(os.getenv("PREMIUM_PLAN_DATA_RETENTION_DAYS", "365"))
|
|
|
|
ENTERPRISE_PLAN_LOCATIONS: int = int(os.getenv("ENTERPRISE_PLAN_LOCATIONS", "50"))
|
|
ENTERPRISE_PLAN_PREDICTIONS_PER_DAY: int = int(os.getenv("ENTERPRISE_PLAN_PREDICTIONS_PER_DAY", "10000"))
|
|
ENTERPRISE_PLAN_DATA_RETENTION_DAYS: int = int(os.getenv("ENTERPRISE_PLAN_DATA_RETENTION_DAYS", "1095"))
|
|
|
|
# Billing Configuration
|
|
BILLING_ENABLED: bool = os.getenv("BILLING_ENABLED", "false").lower() == "true"
|
|
BILLING_CURRENCY: str = os.getenv("BILLING_CURRENCY", "EUR")
|
|
BILLING_CYCLE_DAYS: int = int(os.getenv("BILLING_CYCLE_DAYS", "30"))
|
|
|
|
# Resource Limits
|
|
MAX_API_CALLS_PER_MINUTE: int = int(os.getenv("MAX_API_CALLS_PER_MINUTE", "100"))
|
|
MAX_STORAGE_MB: int = int(os.getenv("MAX_STORAGE_MB", "1024"))
|
|
MAX_CONCURRENT_REQUESTS: int = int(os.getenv("MAX_CONCURRENT_REQUESTS", "10"))
|
|
|
|
# Spanish Business Configuration
|
|
SPANISH_TAX_RATE: float = float(os.getenv("SPANISH_TAX_RATE", "0.21")) # IVA 21%
|
|
INVOICE_LANGUAGE: str = os.getenv("INVOICE_LANGUAGE", "es")
|
|
SUPPORT_EMAIL: str = os.getenv("SUPPORT_EMAIL", "soporte@bakeryforecast.es")
|
|
|
|
# Onboarding
|
|
ONBOARDING_ENABLED: bool = os.getenv("ONBOARDING_ENABLED", "true").lower() == "true"
|
|
DEMO_DATA_ENABLED: bool = os.getenv("DEMO_DATA_ENABLED", "true").lower() == "true"
|
|
|
|
# Compliance
|
|
GDPR_COMPLIANCE_ENABLED: bool = True
|
|
DATA_EXPORT_ENABLED: bool = True
|
|
DATA_DELETION_ENABLED: bool = True
|
|
|
|
# Stripe Payment Configuration
|
|
STRIPE_PUBLISHABLE_KEY: str = os.getenv("STRIPE_PUBLISHABLE_KEY", "")
|
|
STRIPE_SECRET_KEY: str = os.getenv("STRIPE_SECRET_KEY", "")
|
|
STRIPE_WEBHOOK_SECRET: str = os.getenv("STRIPE_WEBHOOK_SECRET", "")
|
|
|
|
# ============================================================
|
|
# SCHEDULER CONFIGURATION
|
|
# ============================================================
|
|
|
|
# Usage tracking scheduler
|
|
USAGE_TRACKING_ENABLED: bool = os.getenv("USAGE_TRACKING_ENABLED", "true").lower() == "true"
|
|
USAGE_TRACKING_HOUR: int = int(os.getenv("USAGE_TRACKING_HOUR", "2"))
|
|
USAGE_TRACKING_MINUTE: int = int(os.getenv("USAGE_TRACKING_MINUTE", "0"))
|
|
USAGE_TRACKING_TIMEZONE: str = os.getenv("USAGE_TRACKING_TIMEZONE", "UTC")
|
|
|
|
settings = TenantSettings()
|