import logging
from pathlib import Path
from tempfile import TemporaryDirectory
from typing import Optional, Tuple

import docker
from docker.errors import DockerException
from pddl.core import Domain, Problem

from tp_lodge.task_planning.models.sas.sas_plan import SasPlan

logger = logging.getLogger(__name__)


class AIPlanner:

    def __init__(self):
        self.client = docker.from_env()

    def _is_docker_running(self) -> bool:
        try:
            self.client.ping()  # Sends a request to Docker to check if it's alive
            return True
        except DockerException:
            return False

    def _run_planner(
        self, docker_host_dir: Path, domain_file: str, problem_file: str
    ) -> Tuple[Optional[SasPlan], str]:
        """
        Run the Fast Downward planner in a Docker container.

        Args:
            docker_host_dir (Path): The directory on the host machine where the files are located.
            domain_file (str): The name of the domain file.
            problem_file (str): The name of the problem file.
            plan_file (str): The name of the output plan file.

        Returns:
            Tuple[Optional[str], str]: The the plan if one was found and the response from the planner
        """
        raise NotImplementedError("This method should be implemented in subclasses.")

    def plan(self, domain: Domain, problem: Problem) -> Tuple[str, bool, Optional[SasPlan]]:
        """
        Plan with the AI planner.
        Args:
            domain (Domain): The domain object.
            problem (Problem): The problem object.
        Returns:
            Tuple[str, bool, Optional[str]]: The plan if one was found and the response from the planner
        """
        logging.info("Plan with AI Planner...")

        with TemporaryDirectory() as docker_dir:
            docker_dir = Path(docker_dir)
            tmp_domain_file = "domain.pddl"
            tmp_problem_file = "problem.pddl"
            (docker_dir / tmp_domain_file).write_text(str(domain))
            (docker_dir / tmp_problem_file).write_text(str(problem))
            sas_plan, response = self._run_planner(
                docker_host_dir=docker_dir, domain_file=tmp_domain_file, problem_file=tmp_problem_file
            )

        success = sas_plan is not None

        return response, success, sas_plan
