147 lines
5.7 KiB
Python
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() |