Source code for julee.api.services.system_initialization

"""
System Initialization Service for the julee CEAP system.

This module provides the service layer for system initialization,
orchestrating the use cases needed to ensure required system data
exists on application startup.

The service acts as a facade between the API layer and domain use cases,
handling application-level concerns while delegating business logic
to the appropriate use cases.
"""

import logging
from typing import Any

from julee.domain.use_cases.initialize_system_data import (
    InitializeSystemDataUseCase,
)

[docs] logger = logging.getLogger(__name__)
[docs] class SystemInitializationService: """ Service for orchestrating system initialization on application startup. This service coordinates the execution of use cases needed to initialize required system data, such as knowledge service configurations and other essential data needed for the application to function properly. The service provides error handling, logging, and coordination between multiple initialization tasks while keeping the business logic in the domain use cases. """ def __init__( self, initialize_system_data_use_case: InitializeSystemDataUseCase, ) -> None: """Initialize the service with required use cases. Args: initialize_system_data_use_case: Use case for initializing system data """
[docs] self.initialize_system_data_use_case = initialize_system_data_use_case
[docs] self.logger = logging.getLogger("SystemInitializationService")
[docs] async def initialize(self) -> dict[str, Any]: """ Initialize all required system data and configuration. This method orchestrates all initialization tasks needed for the application to start successfully. It coordinates multiple use cases and provides comprehensive error handling and logging. Returns: Dict containing initialization results and metadata Raises: Exception: If any critical initialization step fails """ self.logger.info("Starting system initialization") initialization_results: dict[str, Any] = { "status": "in_progress", "tasks_completed": [], "tasks_failed": [], "metadata": {}, } try: # Execute system data initialization await self._execute_system_data_initialization(initialization_results) # Future initialization tasks can be added here # await self._execute_additional_initialization_tasks( # initialization_results # ) # Mark initialization as successful initialization_results["status"] = "completed" self.logger.info( "System initialization completed successfully", extra={ "tasks_completed": initialization_results["tasks_completed"], "total_tasks": len(initialization_results["tasks_completed"]), }, ) return initialization_results except Exception as e: initialization_results["status"] = "failed" initialization_results["error"] = { "type": type(e).__name__, "message": str(e), } self.logger.error( "System initialization failed", exc_info=True, extra={ "tasks_completed": initialization_results["tasks_completed"], "tasks_failed": initialization_results["tasks_failed"], "error_type": type(e).__name__, "error_message": str(e), }, ) raise
async def _execute_system_data_initialization( self, results: dict[str, Any] ) -> None: """ Execute system data initialization use case. Args: results: Dictionary to track initialization results Raises: Exception: If system data initialization fails """ task_name = "system_data_initialization" try: self.logger.debug("Starting task: %s", task_name) await self.initialize_system_data_use_case.execute() results["tasks_completed"].append(task_name) results["metadata"][task_name] = { "status": "completed", "description": "System data initialization completed", } self.logger.debug("Completed task: %s", task_name) except Exception as e: results["tasks_failed"].append( { "task": task_name, "error": str(e), "error_type": type(e).__name__, } ) self.logger.error( f"Failed task: {task_name}", exc_info=True, extra={ "task_name": task_name, "error_type": type(e).__name__, "error_message": str(e), }, ) raise
[docs] async def get_initialization_status(self) -> dict[str, Any]: """ Get the current initialization status. This method can be used to check if the system has been properly initialized, useful for health checks or debugging. Returns: Dict containing current initialization status and metadata """ # This is a simple implementation - in a more complex system, # you might want to persist initialization status return { "system_initialized": True, "last_initialization": None, # Could track timestamps "required_components": [ "knowledge_service_configs", ], "status": "ready", }
[docs] async def reinitialize(self) -> dict[str, Any]: """ Reinitialize system data. This method can be used to force reinitalization of system data, useful for development, testing, or recovery scenarios. Returns: Dict containing reinitialization results Raises: Exception: If reinitialization fails """ self.logger.info("Starting system reinitialization") try: results = await self.initialize() results["reinitialization"] = True self.logger.info("System reinitialization completed successfully") return results except Exception as e: self.logger.error( "System reinitialization failed", exc_info=True, extra={ "error_type": type(e).__name__, "error_message": str(e), }, ) raise