Improve base config
This commit is contained in:
@@ -1,37 +1,68 @@
|
||||
"""Data service configuration"""
|
||||
# ================================================================
|
||||
# DATA SERVICE CONFIGURATION
|
||||
# services/data/app/core/config.py
|
||||
# ================================================================
|
||||
|
||||
from pydantic_settings import BaseSettings
|
||||
from typing import List
|
||||
"""
|
||||
Data service configuration
|
||||
External data integration and management
|
||||
"""
|
||||
|
||||
class Settings(BaseSettings):
|
||||
# Database
|
||||
DATABASE_URL: str = "postgresql+asyncpg://data_user:data_pass123@data-db:5432/data_db"
|
||||
from shared.config.base import BaseServiceSettings
|
||||
import os
|
||||
|
||||
class DataSettings(BaseServiceSettings):
|
||||
"""Data service specific settings"""
|
||||
|
||||
# Redis
|
||||
REDIS_URL: str = "redis://redis:6379/3"
|
||||
|
||||
# RabbitMQ
|
||||
RABBITMQ_URL: str = "amqp://bakery:forecast123@rabbitmq:5672/"
|
||||
|
||||
# External APIs
|
||||
AEMET_API_KEY: str = "your-aemet-api-key-here"
|
||||
MADRID_OPENDATA_API_KEY: str = "your-madrid-opendata-key-here"
|
||||
|
||||
# Service settings
|
||||
# Service Identity
|
||||
APP_NAME: str = "Data Service"
|
||||
SERVICE_NAME: str = "data-service"
|
||||
SERVICE_VERSION: str = "1.0.0"
|
||||
DESCRIPTION: str = "External data integration and management service"
|
||||
|
||||
# Auth
|
||||
AUTH_SERVICE_URL: str = "http://auth-service:8000"
|
||||
# Database Configuration
|
||||
DATABASE_URL: str = os.getenv("DATA_DATABASE_URL",
|
||||
"postgresql+asyncpg://data_user:data_pass123@data-db:5432/data_db")
|
||||
|
||||
# CORS
|
||||
CORS_ORIGINS: List[str] = ["http://localhost:3000", "http://localhost:3001"]
|
||||
# Redis Database (dedicated for external data cache)
|
||||
REDIS_DB: int = 3
|
||||
|
||||
# Monitoring
|
||||
LOG_LEVEL: str = "INFO"
|
||||
ENABLE_METRICS: bool = True
|
||||
# External API Configuration
|
||||
AEMET_API_KEY: str = os.getenv("AEMET_API_KEY", "")
|
||||
AEMET_BASE_URL: str = "https://opendata.aemet.es/opendata"
|
||||
AEMET_TIMEOUT: int = int(os.getenv("AEMET_TIMEOUT", "30"))
|
||||
AEMET_RETRY_ATTEMPTS: int = int(os.getenv("AEMET_RETRY_ATTEMPTS", "3"))
|
||||
|
||||
class Config:
|
||||
env_file = ".env"
|
||||
MADRID_OPENDATA_API_KEY: str = os.getenv("MADRID_OPENDATA_API_KEY", "")
|
||||
MADRID_OPENDATA_BASE_URL: str = "https://datos.madrid.es"
|
||||
MADRID_OPENDATA_TIMEOUT: int = int(os.getenv("MADRID_OPENDATA_TIMEOUT", "30"))
|
||||
|
||||
# Data Collection Configuration
|
||||
WEATHER_COLLECTION_INTERVAL_HOURS: int = int(os.getenv("WEATHER_COLLECTION_INTERVAL_HOURS", "1"))
|
||||
TRAFFIC_COLLECTION_INTERVAL_HOURS: int = int(os.getenv("TRAFFIC_COLLECTION_INTERVAL_HOURS", "1"))
|
||||
EVENTS_COLLECTION_INTERVAL_HOURS: int = int(os.getenv("EVENTS_COLLECTION_INTERVAL_HOURS", "6"))
|
||||
|
||||
# Cache TTL Configuration
|
||||
WEATHER_CACHE_TTL_HOURS: int = int(os.getenv("WEATHER_CACHE_TTL_HOURS", "1"))
|
||||
TRAFFIC_CACHE_TTL_HOURS: int = int(os.getenv("TRAFFIC_CACHE_TTL_HOURS", "1"))
|
||||
EVENTS_CACHE_TTL_HOURS: int = int(os.getenv("EVENTS_CACHE_TTL_HOURS", "6"))
|
||||
|
||||
# Data Quality Configuration
|
||||
DATA_VALIDATION_ENABLED: bool = os.getenv("DATA_VALIDATION_ENABLED", "true").lower() == "true"
|
||||
OUTLIER_DETECTION_ENABLED: bool = os.getenv("OUTLIER_DETECTION_ENABLED", "true").lower() == "true"
|
||||
DATA_COMPLETENESS_THRESHOLD: float = float(os.getenv("DATA_COMPLETENESS_THRESHOLD", "0.8"))
|
||||
|
||||
# Geolocation Settings (Madrid focus)
|
||||
DEFAULT_LATITUDE: float = float(os.getenv("DEFAULT_LATITUDE", "40.4168")) # Madrid
|
||||
DEFAULT_LONGITUDE: float = float(os.getenv("DEFAULT_LONGITUDE", "-3.7038")) # Madrid
|
||||
LOCATION_RADIUS_KM: float = float(os.getenv("LOCATION_RADIUS_KM", "50.0"))
|
||||
|
||||
# Data Retention
|
||||
RAW_DATA_RETENTION_DAYS: int = int(os.getenv("RAW_DATA_RETENTION_DAYS", "90"))
|
||||
PROCESSED_DATA_RETENTION_DAYS: int = int(os.getenv("PROCESSED_DATA_RETENTION_DAYS", "365"))
|
||||
|
||||
# Batch Processing
|
||||
BATCH_PROCESSING_ENABLED: bool = os.getenv("BATCH_PROCESSING_ENABLED", "true").lower() == "true"
|
||||
BATCH_SIZE: int = int(os.getenv("BATCH_SIZE", "1000"))
|
||||
PARALLEL_PROCESSING_WORKERS: int = int(os.getenv("PARALLEL_PROCESSING_WORKERS", "4"))
|
||||
|
||||
settings = Settings()
|
||||
settings = DataSettings()
|
||||
Reference in New Issue
Block a user