from langchain_core.tools import tool

# Terminal input version for script mode execution of causal_discovery_llm
@tool(response_format="content_and_artifact")
def human_in_the_loop(question: str) -> str:
    """
    This function allows for user interaction. Use this to: query for additional knowledge, clarifications, to validate hypotheses or possible causal relationships. 
    Args:
        question (str): The question or prompt to present to the user for input.
    Returns:
        user_input: A string containing the user's input if provided.
    """
    # Use terminal input for user input
    user_input = input(f"{question} ")

    # If the user input is not empty, return it as a string
    # To make it compatible with the rest of the code, we also return an "artifact", i.e. a dictionary with token expenditure for this tool (which are 0 in this case since it)
    if user_input:
        return str(user_input), {"input_token_count": 0, "output_token_count": 0}

    # If the user input is empty, return None
    return None, {"input_token_count": 0, "output_token_count": 0}