Files
bakery-ia/services/suppliers/app/core/config.py

147 lines
5.7 KiB
Python

# services/suppliers/app/core/config.py
"""
Supplier & Procurement Service Configuration
"""
import os
from typing import List
from pydantic import Field
from shared.config.base import BaseServiceSettings
class Settings(BaseServiceSettings):
"""Supplier service settings extending base configuration"""
# Override service-specific settings
SERVICE_NAME: str = "suppliers-service"
VERSION: str = "1.0.0"
APP_NAME: str = "Bakery Supplier Service"
DESCRIPTION: str = "Supplier and procurement management service"
# API Configuration
API_V1_STR: str = "/api/v1"
# 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("SUPPLIERS_DATABASE_URL")
if complete_url:
return complete_url
# Build from components (secure approach)
user = os.getenv("SUPPLIERS_DB_USER", "suppliers_user")
password = os.getenv("SUPPLIERS_DB_PASSWORD", "suppliers_pass123")
host = os.getenv("SUPPLIERS_DB_HOST", "localhost")
port = os.getenv("SUPPLIERS_DB_PORT", "5432")
name = os.getenv("SUPPLIERS_DB_NAME", "suppliers_db")
return f"postgresql+asyncpg://{user}:{password}@{host}:{port}/{name}"
# Suppliers-specific Redis database
REDIS_DB: int = Field(default=4, env="SUPPLIERS_REDIS_DB")
# File upload configuration
MAX_UPLOAD_SIZE: int = 10 * 1024 * 1024 # 10MB
UPLOAD_PATH: str = Field(default="/tmp/uploads", env="SUPPLIERS_UPLOAD_PATH")
ALLOWED_FILE_EXTENSIONS: List[str] = [".csv", ".xlsx", ".xls", ".pdf", ".png", ".jpg", ".jpeg"]
# Pagination
DEFAULT_PAGE_SIZE: int = 50
MAX_PAGE_SIZE: int = 500
# Price validation
MIN_UNIT_PRICE: float = 0.01
MAX_UNIT_PRICE: float = 10000.0
MIN_ORDER_AMOUNT: float = 1.0
MAX_ORDER_AMOUNT: float = 100000.0
# Supplier-specific cache TTL
SUPPLIERS_CACHE_TTL: int = 900 # 15 minutes
PURCHASE_ORDERS_CACHE_TTL: int = 300 # 5 minutes
DELIVERIES_CACHE_TTL: int = 180 # 3 minutes
PRICE_LIST_CACHE_TTL: int = 1800 # 30 minutes
# Purchase order settings
DEFAULT_PAYMENT_TERMS_DAYS: int = 30
MAX_PAYMENT_TERMS_DAYS: int = 90
DEFAULT_DELIVERY_DAYS: int = 3
MAX_DELIVERY_DAYS: int = 30
# Quality and rating settings
MIN_QUALITY_RATING: float = 1.0
MAX_QUALITY_RATING: float = 5.0
MIN_DELIVERY_RATING: float = 1.0
MAX_DELIVERY_RATING: float = 5.0
# Lead time settings (in days)
DEFAULT_LEAD_TIME: int = 3
MAX_LEAD_TIME: int = 30
# Order approval thresholds
AUTO_APPROVE_THRESHOLD: float = 500.0 # Amounts below this auto-approve
MANAGER_APPROVAL_THRESHOLD: float = 2000.0 # Manager approval required
# Communication settings
ORDER_CONFIRMATION_EMAIL: bool = True
DELIVERY_NOTIFICATION_EMAIL: bool = True
QUALITY_ISSUE_EMAIL: bool = True
# Business hours for supplier contact (24h format)
BUSINESS_HOURS_START: int = 8
BUSINESS_HOURS_END: int = 18
# Performance Tracking Settings
PERFORMANCE_TRACKING_ENABLED: bool = Field(default=True, env="PERFORMANCE_TRACKING_ENABLED")
PERFORMANCE_CALCULATION_INTERVAL_MINUTES: int = Field(default=60, env="PERFORMANCE_CALCULATION_INTERVAL")
PERFORMANCE_CACHE_TTL: int = Field(default=300, env="PERFORMANCE_CACHE_TTL") # 5 minutes
# Performance Thresholds
EXCELLENT_DELIVERY_RATE: float = 95.0
GOOD_DELIVERY_RATE: float = 90.0
ACCEPTABLE_DELIVERY_RATE: float = 85.0
POOR_DELIVERY_RATE: float = 80.0
EXCELLENT_QUALITY_RATE: float = 98.0
GOOD_QUALITY_RATE: float = 95.0
ACCEPTABLE_QUALITY_RATE: float = 90.0
POOR_QUALITY_RATE: float = 85.0
# Alert Settings
ALERTS_ENABLED: bool = Field(default=True, env="SUPPLIERS_ALERTS_ENABLED")
ALERT_EVALUATION_INTERVAL_MINUTES: int = Field(default=15, env="ALERT_EVALUATION_INTERVAL")
ALERT_RETENTION_DAYS: int = Field(default=365, env="ALERT_RETENTION_DAYS")
# Critical alert thresholds
CRITICAL_DELIVERY_DELAY_HOURS: int = 24
CRITICAL_QUALITY_REJECTION_RATE: float = 10.0
HIGH_COST_VARIANCE_PERCENTAGE: float = 15.0
# Dashboard Settings
DASHBOARD_CACHE_TTL: int = Field(default=180, env="SUPPLIERS_DASHBOARD_CACHE_TTL") # 3 minutes
DASHBOARD_REFRESH_INTERVAL: int = Field(default=300, env="DASHBOARD_REFRESH_INTERVAL") # 5 minutes
# Performance Analytics
DEFAULT_ANALYTICS_PERIOD_DAYS: int = 30
MAX_ANALYTICS_PERIOD_DAYS: int = 365
SCORECARD_GENERATION_DAY: int = 1 # Day of month to generate scorecards
# Notification Settings
NOTIFICATION_EMAIL_ENABLED: bool = Field(default=True, env="NOTIFICATION_EMAIL_ENABLED")
NOTIFICATION_WEBHOOK_ENABLED: bool = Field(default=False, env="NOTIFICATION_WEBHOOK_ENABLED")
NOTIFICATION_WEBHOOK_URL: str = Field(default="", env="NOTIFICATION_WEBHOOK_URL")
# Business Model Detection
ENABLE_BUSINESS_MODEL_DETECTION: bool = Field(default=True, env="ENABLE_BUSINESS_MODEL_DETECTION")
CENTRAL_BAKERY_THRESHOLD_SUPPLIERS: int = Field(default=20, env="CENTRAL_BAKERY_THRESHOLD_SUPPLIERS")
INDIVIDUAL_BAKERY_THRESHOLD_SUPPLIERS: int = Field(default=10, env="INDIVIDUAL_BAKERY_THRESHOLD_SUPPLIERS")
# Performance Report Settings
AUTO_GENERATE_MONTHLY_REPORTS: bool = Field(default=True, env="AUTO_GENERATE_MONTHLY_REPORTS")
AUTO_GENERATE_QUARTERLY_REPORTS: bool = Field(default=True, env="AUTO_GENERATE_QUARTERLY_REPORTS")
REPORT_EXPORT_FORMATS: List[str] = ["pdf", "excel", "csv"]
# Global settings instance
settings = Settings()