from flask import Flask, request, jsonify
import requests
import os
import socket
import logging
from typing import Dict, Any
from dotenv import load_dotenv

# Load environment variables from .env file
load_dotenv()

app = Flask(__name__)

# Configure logging
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
)
logger = logging.getLogger(__name__)

# Configure the proxy server
PROXY_PORT = int(os.environ.get('LLM_PROXY_PORT', 5000))

@app.route('/llm_proxy', methods=['POST'])
def proxy_llm_request():
    """
    Proxy endpoint that forwards requests to the LLM API.
    Handles authentication and error cases.
    """
    try:
        # Get the request data
        data = request.json
        if not data:
            return jsonify({'error': 'No data provided'}), 400
            
        url = data.get('url')
        headers = data.get('headers', {})
        payload = data.get('payload', {})
        
        if not url:
            return jsonify({'error': 'No URL provided'}), 400
            
        # Make the actual API call
        logger.info(f"Making request to {url}")
        response = requests.post(
            url,
            headers=headers,
            json=payload,
            timeout=30
        )
        
        # Check if the response is successful
        response.raise_for_status()
        
        # Get the JSON response
        response_data = response.json()
        
        # Validate the response structure
        if 'choices' not in response_data:
            logger.error(f"Invalid response structure: {response_data}")
            return jsonify({'error': 'Invalid response structure from API'}), 500
            
        # Forward the response
        return jsonify(response_data)
        
    except requests.exceptions.Timeout:
        logger.error("Request timed out")
        return jsonify({'error': 'Request timed out'}), 504
    except requests.exceptions.RequestException as e:
        logger.error(f"Request failed: {str(e)}")
        return jsonify({'error': str(e)}), 500
    except Exception as e:
        logger.error(f"Unexpected error: {str(e)}")
        return jsonify({'error': str(e)}), 500

def get_server_info() -> Dict[str, str]:
    """Get server hostname and IP address."""
    hostname = socket.gethostname()
    ip_address = socket.gethostbyname(hostname)
    return {
        'hostname': hostname,
        'ip_address': ip_address,
        'port': PROXY_PORT
    }

if __name__ == '__main__':
    # Verify API key is set
    if not os.environ.get('OPENAI_API_KEY'):
        logger.error("OPENAI_API_KEY environment variable is not set!")
        exit(1)
        
    server_info = get_server_info()
    logger.info("Starting LLM proxy server with configuration:")
    logger.info(f"Hostname: {server_info['hostname']}")
    logger.info(f"IP Address: {server_info['ip_address']}")
    logger.info(f"Port: {server_info['port']}")
    
    app.run(host='0.0.0.0', port=PROXY_PORT)