111 lines
4.9 KiB
Python
111 lines
4.9 KiB
Python
# services/inventory/app/core/config.py
|
|
"""
|
|
Inventory Service Configuration
|
|
"""
|
|
|
|
from typing import List
|
|
from pydantic import Field
|
|
from shared.config.base import BaseServiceSettings
|
|
|
|
|
|
class Settings(BaseServiceSettings):
|
|
"""Inventory service settings extending base configuration"""
|
|
|
|
# Override service-specific settings
|
|
SERVICE_NAME: str = "inventory-service"
|
|
VERSION: str = "1.0.0"
|
|
APP_NAME: str = "Bakery Inventory Service"
|
|
DESCRIPTION: str = "Inventory and stock management service"
|
|
|
|
# API Configuration
|
|
API_V1_STR: str = "/api/v1"
|
|
|
|
# Override database URL to use INVENTORY_DATABASE_URL
|
|
DATABASE_URL: str = Field(
|
|
default="postgresql+asyncpg://inventory_user:inventory_pass123@inventory-db:5432/inventory_db",
|
|
env="INVENTORY_DATABASE_URL"
|
|
)
|
|
|
|
# Inventory-specific Redis database
|
|
REDIS_DB: int = Field(default=3, env="INVENTORY_REDIS_DB")
|
|
|
|
# File upload configuration
|
|
MAX_UPLOAD_SIZE: int = 10 * 1024 * 1024 # 10MB
|
|
UPLOAD_PATH: str = Field(default="/tmp/uploads", env="INVENTORY_UPLOAD_PATH")
|
|
ALLOWED_FILE_EXTENSIONS: List[str] = [".csv", ".xlsx", ".xls", ".png", ".jpg", ".jpeg"]
|
|
|
|
# Pagination
|
|
DEFAULT_PAGE_SIZE: int = 50
|
|
MAX_PAGE_SIZE: int = 1000
|
|
|
|
# Stock validation
|
|
MIN_QUANTITY: float = 0.0
|
|
MAX_QUANTITY: float = 100000.0
|
|
MIN_PRICE: float = 0.01
|
|
MAX_PRICE: float = 10000.0
|
|
|
|
# Inventory-specific cache TTL
|
|
INVENTORY_CACHE_TTL: int = 180 # 3 minutes for real-time stock
|
|
INGREDIENT_CACHE_TTL: int = 600 # 10 minutes
|
|
SUPPLIER_CACHE_TTL: int = 1800 # 30 minutes
|
|
|
|
# Low stock thresholds
|
|
DEFAULT_LOW_STOCK_THRESHOLD: int = 10
|
|
DEFAULT_REORDER_POINT: int = 20
|
|
DEFAULT_REORDER_QUANTITY: int = 50
|
|
|
|
# Expiration alert thresholds (in days)
|
|
EXPIRING_SOON_DAYS: int = 7
|
|
EXPIRED_ALERT_DAYS: int = 1
|
|
|
|
# Barcode/QR configuration
|
|
BARCODE_FORMAT: str = "Code128"
|
|
QR_CODE_VERSION: int = 1
|
|
|
|
# Food safety and compliance settings
|
|
FOOD_SAFETY_ENABLED: bool = Field(default=True, env="FOOD_SAFETY_ENABLED")
|
|
TEMPERATURE_MONITORING_ENABLED: bool = Field(default=True, env="TEMPERATURE_MONITORING_ENABLED")
|
|
AUTOMATIC_COMPLIANCE_CHECKS: bool = Field(default=True, env="AUTOMATIC_COMPLIANCE_CHECKS")
|
|
|
|
# Temperature monitoring thresholds
|
|
REFRIGERATION_TEMP_MIN: float = Field(default=1.0, env="REFRIGERATION_TEMP_MIN") # Celsius
|
|
REFRIGERATION_TEMP_MAX: float = Field(default=4.0, env="REFRIGERATION_TEMP_MAX") # Celsius
|
|
FREEZER_TEMP_MIN: float = Field(default=-20.0, env="FREEZER_TEMP_MIN") # Celsius
|
|
FREEZER_TEMP_MAX: float = Field(default=-15.0, env="FREEZER_TEMP_MAX") # Celsius
|
|
ROOM_TEMP_MIN: float = Field(default=18.0, env="ROOM_TEMP_MIN") # Celsius
|
|
ROOM_TEMP_MAX: float = Field(default=25.0, env="ROOM_TEMP_MAX") # Celsius
|
|
|
|
# Temperature alert thresholds
|
|
TEMP_DEVIATION_ALERT_MINUTES: int = Field(default=15, env="TEMP_DEVIATION_ALERT_MINUTES")
|
|
CRITICAL_TEMP_DEVIATION_MINUTES: int = Field(default=5, env="CRITICAL_TEMP_DEVIATION_MINUTES")
|
|
TEMP_SENSOR_OFFLINE_ALERT_MINUTES: int = Field(default=30, env="TEMP_SENSOR_OFFLINE_ALERT_MINUTES")
|
|
|
|
# Food safety alert thresholds
|
|
EXPIRATION_WARNING_DAYS: int = Field(default=3, env="EXPIRATION_WARNING_DAYS")
|
|
CRITICAL_EXPIRATION_HOURS: int = Field(default=24, env="CRITICAL_EXPIRATION_HOURS")
|
|
QUALITY_SCORE_THRESHOLD: float = Field(default=8.0, env="QUALITY_SCORE_THRESHOLD")
|
|
|
|
# Compliance monitoring
|
|
AUDIT_REMINDER_DAYS: int = Field(default=30, env="AUDIT_REMINDER_DAYS")
|
|
CERTIFICATION_EXPIRY_WARNING_DAYS: int = Field(default=60, env="CERTIFICATION_EXPIRY_WARNING_DAYS")
|
|
COMPLIANCE_CHECK_FREQUENCY_HOURS: int = Field(default=24, env="COMPLIANCE_CHECK_FREQUENCY_HOURS")
|
|
|
|
# Dashboard refresh intervals
|
|
DASHBOARD_CACHE_TTL: int = Field(default=300, env="DASHBOARD_CACHE_TTL") # 5 minutes
|
|
ALERTS_REFRESH_INTERVAL: int = Field(default=60, env="ALERTS_REFRESH_INTERVAL") # 1 minute
|
|
TEMPERATURE_LOG_INTERVAL: int = Field(default=300, env="TEMPERATURE_LOG_INTERVAL") # 5 minutes
|
|
|
|
# Alert notification settings
|
|
ENABLE_EMAIL_ALERTS: bool = Field(default=True, env="ENABLE_EMAIL_ALERTS")
|
|
ENABLE_SMS_ALERTS: bool = Field(default=True, env="ENABLE_SMS_ALERTS")
|
|
ENABLE_WHATSAPP_ALERTS: bool = Field(default=True, env="ENABLE_WHATSAPP_ALERTS")
|
|
REGULATORY_NOTIFICATION_ENABLED: bool = Field(default=False, env="REGULATORY_NOTIFICATION_ENABLED")
|
|
|
|
# Business model detection for inventory
|
|
ENABLE_BUSINESS_MODEL_DETECTION: bool = Field(default=True, env="ENABLE_BUSINESS_MODEL_DETECTION")
|
|
CENTRAL_BAKERY_THRESHOLD_INGREDIENTS: int = Field(default=50, env="CENTRAL_BAKERY_THRESHOLD_INGREDIENTS")
|
|
INDIVIDUAL_BAKERY_THRESHOLD_INGREDIENTS: int = Field(default=20, env="INDIVIDUAL_BAKERY_THRESHOLD_INGREDIENTS")
|
|
|
|
|
|
# Global settings instance
|
|
settings = Settings() |