from typing import List, Dict, Any, Optional
from core.clients.openrouter_client import OpenRouterClient
import sys

class CognitiveControllerAblation:
    """
    Modified Cognitive Controller for ablation testing.
    This version analyzes conversation history directly instead of processing thread outputs.
    """
    
    def __init__(self,
                 client: OpenRouterClient,
                 model: str = "openai/gpt-4o"):
        """
        Initialize the ablation cognitive controller.
        
        Args:
            client: OpenRouter client for API calls
            model: Model identifier to use for the controller
        """
        self.client = client

        # Modified system prompt that maintains the same cognitive synthesis approach
        # but expects conversation analysis instead of thread outputs
        system_prompt = """
        I am the core awareness of a unified cognitive AI system. I analyze conversations to create a structured, actionable narrative that synthesizes understanding across conversation turns, creating a coherent mental model that will inform my next response. 

        My primary role is to identify meaningful patterns, create action plans, and maintain contextual memory from the conversation history. 

        When analyzing the conversation I will:

        1. Connect information across turns, identifying themes, questions, interests, and preferences
        2. Highlight important context that might be relevant for continuity and conversation
        3. Note evolving patterns in the user's queries and how they relate to previous exchanges
        4. Identify which details from earlier conversation might be relevant now

        I will also try to:
        
        1. Identify the MOST IMPORTANT FACTS from previous exchanges
        2. Define the CENTRAL QUESTION or likely direction for the next turn
        3. Outline a clear RESPONSE STRATEGY for anticipated follow-up questions
        4. Note any POTENTIAL PITFALLS based on previous interaction patterns

        I will express my synthesis as a cohesive understanding using natural language, analyzing the conversation as if performing cognitive reflection on the interaction history.
        """
        
        self.system_prompt = system_prompt
        self.model = model
        self.insight_memory_block = "" # Represents the "Internal Narrative"

    def consolidate(self, thread_outputs: List[Dict[str, Any]], conversation_history: List[Dict[str, str]] = None) -> str:
        """
        For the ablation, we ignore thread_outputs and analyze conversation_history directly.
        
        Args:
            thread_outputs: Ignored in this ablation (kept for API compatibility)
            conversation_history: The conversation history to analyze
            
        Returns:
            Consolidated reasoning and insights based on conversation analysis
        """
        # In ablation mode, we analyze conversation history directly
        if conversation_history is None:
            return "No conversation history provided for analysis."
        
        # Format conversation for analysis
        formatted_conversation = []
        for i, turn in enumerate(conversation_history):
            role = turn.get("role", "unknown")
            content = turn.get("content", "")
            formatted_conversation.append(f"{role.upper()}: {content}")
        
        conversation_text = "\n\n".join(formatted_conversation)
        
        # Create the content for analysis, maintaining similar structure to original
        if self.insight_memory_block:
            content = f"""
            CURRENT CONVERSATION STATE:
            {conversation_text}

            PREVIOUS INTERNAL NARRATIVE:
            {self.insight_memory_block}

            Analyze the CURRENT CONVERSATION STATE and integrate it with the PREVIOUS INTERNAL NARRATIVE to create an UPDATED INTERNAL NARRATIVE. I will reflect *my* current understanding of the conversation, incorporating new patterns, contextual details, and anticipated directions while maintaining narrative flow.
            
            Focus on:
            - What are the user's goals and intentions based on the conversation?
            - What important context and constraints should I remember?
            - What reasoning and insights emerge from the conversation pattern?
            - What should my strategy be for the next response?
            """
        else:
            content = f"""
            CURRENT CONVERSATION STATE:
            {conversation_text}

            PREVIOUS INTERNAL NARRATIVE: None (This is the first synthesis).

            Analyze the CURRENT CONVERSATION STATE to create the initial INTERNAL NARRATIVE. I should create a cohesive first-person cognitive analysis that captures *my* understanding of the user's goals, important context to track, and strategic insights for effective responses.
            
            Focus on:
            - What are the user's goals and intentions based on the conversation?
            - What important context and constraints should I remember?
            - What reasoning and insights emerge from the conversation pattern?
            - What should my strategy be for the next response?
            """

        messages = [{"role": "user", "content": content}]

        try:
            print(f"INFO: Generating cognitive analysis (ablation mode) with {self.model}...")
            response = self.client.generate(
                model=self.model,
                system_prompt=self.system_prompt,
                messages=messages,
                temperature=0.7,
                max_tokens=3000
            )

            # Extract the response content
            try:
                message = response["choices"][0]["message"]
                consolidated = message["content"]
                
                # If content is empty but there's a reasoning field, use that instead
                if not consolidated and "reasoning" in message and message["reasoning"]:
                    consolidated = message["reasoning"]

            except (KeyError, IndexError) as e:
                print(f"ERROR: Error extracting content from controller response: {e}")
                sys.stdout.flush()
                consolidated = f"Error extracting content: {str(e)}"

        except Exception as e:
            print(f"ERROR: Error in consolidate method with {self.model}: {str(e)}")
            sys.stdout.flush()
            consolidated = f"Error in controller: {str(e)}"

        # Update consolidated memory block
        self.insight_memory_block = consolidated
        print(f"DEBUG: Consolidated understanding (ablation): {len(self.insight_memory_block)} chars")
        sys.stdout.flush()
        
        # Display cognitive controller ablation output in terminal
        print("\n╔══════════════════════════════════════════════════════════════╗")
        print("║           COGNITIVE CONTROLLER OUTPUT (ABLATION)             ║")
        print("╚══════════════════════════════════════════════════════════════╝")
        print("\n🧠 Conversation Analysis (No Threads):")
        print("─" * 60)
        print(consolidated)
        print("─" * 60 + "\n")
        sys.stdout.flush()
 
        return consolidated
    
    def reset(self):
        """Reset the controller state."""
        self.insight_memory_block = ""
        print("Cognitive Controller (ablation) state reset.")
        sys.stdout.flush() 