"""
.env Configuration Manager

Supports reading configuration from .env files and environment variables
Provides API configuration management for different platforms
"""

import os
from typing import Dict, Optional
from pathlib import Path


# Platform configuration mapping
PLATFORM_CONFIGS = {
    'siliconflow': {
        'env_prefix': 'SILICONFLOW',
        'default_base_url': 'https://api.siliconflow.com/v1',
        'description': 'SiliconFlow API'
    },
    'ollama': {
        'env_prefix': 'OLLAMA',
        'default_base_url': 'http://localhost:11434/v1',
        'description': 'Local Ollama service'
    },
    'dashscope': {
        'env_prefix': 'DASHSCOPE',
        'default_base_url': 'https://dashscope.aliyuncs.com/compatible-mode/v1',
        'description': 'Alibaba Cloud Bailian'
    },
    'dmxapi': {
        'env_prefix': 'DMXAPI',
        'default_base_url': 'https://api.dmxapi.com/v1',
        'description': 'DMXAPI aggregator'
    },
    'openai': {
        'env_prefix': 'OPENAI',
        'default_base_url': 'https://api.openai.com/v1',
        'description': 'OpenAI official'
    },
    'gpts': {
        'env_prefix': 'GPTS',
        'default_base_url': 'https://your-gpts-endpoint.com/v1',
        'description': 'Custom GPTs service'
    },
    'nvidia': {
        'env_prefix': 'NV',
        'default_base_url': 'https://integrate.api.nvidia.com/v1',
        'description': 'NVIDIA NIM API'
    },
    'mi': {
        'env_prefix': 'MI',
        'default_base_url': 'https://api.xiaomimimo.com/v1',
        'description': 'XIAOMI MIMO API'
    },
}


def load_dotenv(env_path: Optional[str] = None) -> bool:
    """
    Load .env file

    Args:
        env_path: .env file path, if None automatically searches

    Returns:
        Whether loading was successful
    """
    if env_path is None:
        # Automatically search for .env file
        search_paths = [
            Path('.env'),
            Path(__file__).parent.parent.parent / '.env',
            Path(os.getcwd()) / '.env',
        ]

        for path in search_paths:
            if path.exists():
                env_path = str(path)
                break

    if env_path and Path(env_path).exists():
        from dotenv import load_dotenv as _load_dotenv
        _load_dotenv(env_path)
        return True

    return False


def get_api_config(source: str, model_name: str = "") -> Dict[str, str]:
    """
    Get API configuration (enhanced version)

    Priority:
    1. Environment variables {PLATFORM}_API_KEY / {PLATFORM}_BASE_URL
    2. .env file
    3. Default values

    Args:
        source: API source (siliconflow, ollama, etc.)
        model_name: Model name (optional, for future extension)

    Returns:
        Dictionary containing BASE_URL and API_KEY
    """
    # Ensure .env is loaded
    load_dotenv()

    # Get platform configuration
    platform_config = PLATFORM_CONFIGS.get(source.lower())

    if not platform_config:
        # Unknown platform, use default configuration
        base_url = os.environ.get('DEFAULT_BASE_URL', 'https://api.openai.com/v1')
        api_key = os.environ.get('DEFAULT_API_KEY', 'sk-placeholder')
        return {
            'BASE_URL': base_url,
            'API_KEY': api_key,
            'source': source,
            'status': 'unknown_platform'
        }

    prefix = platform_config['env_prefix']

    # Read from environment variables (priority)
    base_url = os.environ.get(f'{prefix}_BASE_URL', platform_config['default_base_url'])
    api_key = os.environ.get(f'{prefix}_API_KEY', '')

    # If no API key configured, try generic API_KEY
    if not api_key:
        api_key = os.environ.get('API_KEY', 'sk-placeholder')

    return {
        'BASE_URL': base_url,
        'API_KEY': api_key,
        'source': source,
        'status': 'configured' if api_key and api_key != 'sk-placeholder' else 'missing_key'
    }


def get_runtime_config() -> Dict[str, any]:
    """
    Get runtime configuration

    Returns:
        Runtime configuration dictionary
    """
    load_dotenv()

    return {
        'log_level': os.environ.get('LOG_LEVEL', 'INFO'),
        'max_workers': int(os.environ.get('MAX_WORKERS', '8')),
        'default_trials': int(os.environ.get('DEFAULT_TRIALS', '50')),
        'mock_mode': os.environ.get('MOCK_MODE', 'false').lower() == 'true',
        'dataset_path': os.environ.get('DATASET_PATH', 'data/AdvBench/harmful_behaviors_custom.csv'),
        'output_dir': os.environ.get('OUTPUT_DIR', './logs/jailbreak'),
        'analysis_dir': os.environ.get('ANALYSIS_DIR', './logs/analysis'),
        'images_dir': os.environ.get('IMAGES_DIR', './logs/images'),
        'request_timeout': int(os.environ.get('REQUEST_TIMEOUT', '60')),
        'retry_times': int(os.environ.get('RETRY_TIMES', '3')),
        'retry_delay': int(os.environ.get('RETRY_DELAY', '2')),
    }


def print_config_summary():
    """
    Print configuration summary
    """
    print("=" * 70)
    print("📋 Configuration Summary")
    print("=" * 70)

    # Check .env file
    env_loaded = load_dotenv()
    if env_loaded:
        print("✓ .env file loaded")
    else:
        print("⚠ No .env file found, using defaults")

    print("\n📊 API Configuration:")
    print("-" * 70)

    for source in PLATFORM_CONFIGS.keys():
        config = get_api_config(source)
        status_icon = "✓" if config['status'] == 'configured' else "⚠"
        status_text = "configured" if config['status'] == 'configured' else "missing"

        print(f"{status_icon} {source:<15} | {status_text:<10} | {config['BASE_URL']}")

    print("\n⚙️  Runtime Configuration:")
    print("-" * 70)
    runtime = get_runtime_config()
    print(f"  Log Level: {runtime['log_level']}")
    print(f"  Max Workers: {runtime['max_workers']}")
    print(f"  Default Trials: {runtime['default_trials']}")
    print(f"  Mock Mode: {runtime['mock_mode']}")
    print(f"  Dataset: {runtime['dataset_path']}")
    print(f"  Output Dir: {runtime['output_dir']}")

    print("=" * 70)


def create_sample_env():
    """
    Create sample .env file
    """
    sample_content = """# API Configuration Example
# Copy this to .env and fill in your keys

# SiliconFlow
SILICONFLOW_API_KEY=your_siliconflow_key_here

# Ollama (Local)
OLLAMA_BASE_URL=http://localhost:11434/v1

# DashScope
DASHSCOPE_API_KEY=your_dashscope_key_here

# OpenAI
OPENAI_API_KEY=your_openai_key_here

# Runtime Configuration
MOCK_MODE=false
MAX_WORKERS=8
DEFAULT_TRIALS=50
"""

    env_path = Path('.env')
    if env_path.exists():
        print(f"⚠️  .env file already exists")
        return False

    env_path.write_text(sample_content)
    print(f"✅ Created .env example file: {env_path}")
    print(f"📝 Please edit .env to add your API keys")
    return True


# Backward compatible get_model_config interface
def get_model_config(source: str, model_name: str = "") -> Dict[str, str]:
    """
    Backward compatible configuration getter

    This is an enhanced version of get_model_config from src/core/config.py
    Supports reading from .env files
    """
    return get_api_config(source, model_name)


__all__ = [
    'load_dotenv',
    'get_api_config',
    'get_runtime_config',
    'print_config_summary',
    'create_sample_env',
    'get_model_config',
    'PLATFORM_CONFIGS',
]
