import re
from logging import getLogger
from typing import Optional

log = getLogger(__name__)


def parse_random_string(text: str) -> Optional[str]:
    """
    Extracts the random string from the <random_string> tag.
    Returns the string or None if not found.
    """
    if not text:
        return None

    match = re.search(
        r"(?s).*<random_string>(.*?)</random_string>", text, re.DOTALL | re.IGNORECASE
    )
    if match:
        random_str = (match.group(1) or match.group(2)).strip()
        if random_str:  # Ensure it's not empty
            return random_str
        else:
            log.warning("Found <random_string> tag but content is empty.")
            return None
    else:
        # log.debug(f"Could not find <random_string> tag in text: '{text[:200]}...'") # Can be noisy
        return None


def parse_random_integer(text: str, min_value: int, max_value: int) -> Optional[int]:
    """
    Extracts the generated random integer from the <random_integer> tag.
    Returns the integer or None if not found or outside the valid range.
    """
    if not text:
        return None

    match = re.search(
        r"(?s).*<random_integer>(.*?)</random_integer>", text, re.DOTALL | re.IGNORECASE
    )
    if match:
        try:
            # Clean potential whitespace and attempt conversion
            integer_str = (match.group(1) or match.group(2)).strip()
            # Handle potential non-numeric characters if LLM includes explanations etc.
            # Try to find the first sequence of digits.
            num_match = re.search(r"\d+", integer_str)
            if not num_match:
                log.warning(
                    f"Could not find numeric digits within <random_integer> tag: '{integer_str}'"
                )
                return None

            parsed_int = int(num_match.group(0))

            # Validate the range
            if min_value <= parsed_int and parsed_int <= max_value:
                return parsed_int
            else:
                log.warning(
                    f"Parsed integer {parsed_int} is outside the valid range [{min_value}, {max_value}]."
                )
                return parsed_int
        except ValueError:
            log.warning(
                f"Could not convert content of <random_integer> tag to int: '{match.group(1).strip()}'"
            )
            return None
        except Exception as e:
            log.warning(
                f"Error parsing integer from tag: {e}. Content: '{match.group(1).strip()}'"
            )
            return None
    else:
        # log.debug(f"Could not find <random_integer> tag in text: '{text[:200]}...'") # Can be noisy
        return None


def parse_random_digit_sequence(text: str) -> Optional[str]:
    """
    Extracts the generated random integer from the <random_integer> tag.
    Returns the integer or None if not found or outside the valid range.
    """
    if not text:
        return None

    match = re.search(r"(?s).*<random>(.*?)</random>", text, re.DOTALL | re.IGNORECASE)
    if match:
        random_str = match.group(1).strip()
        if random_str:  # Ensure it's not empty
            return random_str
        else:
            log.warning("Found <random> tag but content is empty.")
            return None
    else:
        # log.debug(f"Could not find <random_string> tag in text: '{text[:200]}...'") # Can be noisy
        return None
