# 1. modules/database/database_init.py import os import logging from azure.cosmos import CosmosClient from pymongo import MongoClient import certifi logging.basicConfig(level=logging.DEBUG) logger = logging.getLogger(__name__) # Variables globales para Cosmos DB SQL API cosmos_client = None user_database = None user_container = None application_requests_container = None user_feedback_container = None user_sessions_container = None # Variables globales para Cosmos DB MongoDB API mongo_client = None mongo_db = None def verify_container_partition_key(container, expected_path): """Verifica la configuración de partition key de un contenedor""" try: container_props = container.read() partition_key_paths = container_props['partitionKey']['paths'] logger.info(f"Container: {container.id}, Partition Key Paths: {partition_key_paths}") return expected_path in partition_key_paths except Exception as e: logger.error(f"Error verificando partition key en {container.id}: {str(e)}") return False def get_container(container_name): """Obtiene un contenedor específico""" global containers container_config = { "users": "/id", "application_requests": "/email", "user_feedback": "/username", "users_sessions": "/username" } if container_name not in container_config: logger.error(f"Contenedor no válido: {container_name}") return None # Si el contenedor ya está en caché, devolverlo if container_name in containers and containers[container_name] is not None: return containers[container_name] # Si no está en caché, intentar inicializar la conexión if not initialize_cosmos_sql_connection(): logger.error("No se pudo inicializar la conexión") return None return containers.get(container_name) def initialize_cosmos_sql_connection(): """Inicializa y verifica la conexión a Cosmos DB SQL API""" global cosmos_client, user_database, containers try: # Si ya está inicializado, retornar True if cosmos_client and user_database and containers: return True cosmos_endpoint = os.environ.get("COSMOS_ENDPOINT") cosmos_key = os.environ.get("COSMOS_KEY") if not cosmos_endpoint or not cosmos_key: raise ValueError("COSMOS_ENDPOINT and COSMOS_KEY environment variables must be set") cosmos_client = CosmosClient(cosmos_endpoint, cosmos_key) user_database = cosmos_client.get_database_client("user_database") # Configuración de contenedores container_config = { "users": "/id", "application_requests": "/email", "user_feedback": "/username", "users_sessions": "/username" } # Inicializar contenedores for container_id, partition_path in container_config.items(): try: container = user_database.get_container_client(container_id) if not verify_container_partition_key(container, partition_path): logger.error(f"Verificación de partition key falló para {container_id}") return False containers[container_id] = container logger.info(f"Contenedor {container_id} inicializado correctamente") except Exception as e: logger.error(f"Error inicializando contenedor {container_id}: {str(e)}") return False logger.info("Conexión a Cosmos DB SQL API exitosa") return True except Exception as e: logger.error(f"Error al conectar con Cosmos DB SQL API: {str(e)}") return False def initialize_mongodb_connection(): """Inicializa la conexión a Cosmos DB MongoDB API""" global mongo_client, mongo_db try: cosmos_mongodb_connection_string = os.getenv("MONGODB_CONNECTION_STRING") if not cosmos_mongodb_connection_string: raise ValueError("MONGODB_CONNECTION_STRING environment variable is not set") mongo_client = MongoClient( cosmos_mongodb_connection_string, tls=True, tlsCAFile=certifi.where(), retryWrites=False, serverSelectionTimeoutMS=5000, connectTimeoutMS=10000, socketTimeoutMS=10000 ) mongo_client.admin.command('ping') mongo_db = mongo_client['aideatext_db'] logger.info("Conexión a Cosmos DB MongoDB API exitosa") return True except Exception as e: logger.error(f"Error al conectar con Cosmos DB MongoDB API: {str(e)}") return False def initialize_database_connections(): """Inicializa todas las conexiones a bases de datos""" return initialize_cosmos_sql_connection() and initialize_mongodb_connection() def get_mongodb(): """Obtiene la conexión MongoDB""" if mongo_db is None: initialize_mongodb_connection() return mongo_db