# Copyright 2025 ZTE Corporation.
# All Rights Reserved.
#
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
#    not use this file except in compliance with the License. You may obtain
#    a copy of the License at
#
#         http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
#    License for the specific language governing permissions and limitations
#    under the License.

import os
import re
import requests
import subprocess
from pathlib import Path
from urllib.parse import urlparse
from tqdm import tqdm
from typing import Union, Tuple
from pdf2image import convert_from_path
from utils import encode_media

from backports.tarfile import DEFAULT_FORMAT

default_encoding: str = "utf-8"

from configs import logger


class CSFileWriter:
    """
    A utility class for writing content to local files in various formats.
    """
    def __init__(self, WORKSPACE_PATH: str = None):
        """
        Initializes the CSFileWriter.

        Args:
            WORKSPACE_PATH (str, optional): The path to the workspace directory.
                                            Defaults to the current working directory if not provided.
        """
        self.WORKSPACE_PATH = WORKSPACE_PATH or os.getcwd()
        self.tool_json_schema = {
            "name": 'write_to_file',
            "description": 'Writes text or binary data to a file. The format is determined by the file extension (e.g., `.txt`, `.csv`, `.json`).',
            "parameters": {
                "type": "object",
                "properties": {
                    "content": {
                        "type": "string",
                        "description": "The text or data to write into the file."
                    },
                    "file_path": {
                        "type": "string",
                        "description": "The full path, including filename and extension, where the file will be saved."
                    },
                    "mode": {
                        "type": "string",
                        "description": "(Optional) Use `'w'` to **overwrite** the file or `'a'` to **append** content to the end. Defaults to `'a'` (append).",
                        "enum": ["a", "w"],
                        "default": "a"
                    },
                    "binary": {
                        "type": "boolean",
                        "description": "(Optional) Set to `true` if writing binary data (like an image). Defaults to `false`.",
                        "default": False
                    }
                },
                "required": ["content", "file_path"]
            }
        }

    def _write_text_file(
        self,
        file_path: Path,
        content: str,
        encoding: str = "utf-8",
        binary: bool = False,
        file_mode: str = "w"
    ) -> None:
        """Writes text content to a plaintext file."""
        with file_path.open(file_mode, encoding=None if binary else encoding) as f:
            f.write(content)

    def _write_docx_file(self, file_path: Path, content: str) -> None:
        """Writes text content to a DOCX file with default formatting."""
        import docx

        document = docx.Document()
        style = document.styles['Normal']
        style.font.name = 'Calibri'
        style.font.size = docx.shared.Pt(11)
        style.paragraph_format.line_spacing = 1.0

        for para_text in content.split('\n'):
            para = document.add_paragraph(para_text)
            para.style = style

        document.save(str(file_path))

    def _write_pdf_file(self, file_path: Path, content: str, **kwargs) -> None:
        """Writes text content to a PDF file with default formatting."""
        from fpdf import FPDF

        pdf = FPDF()
        pdf.set_margins(10, 10, 10)
        pdf.add_page()
        pdf.set_font('Arial', style='', size=12)

        for para in content.split('\n'):
            if para.strip():
                pdf.multi_cell(0, 10, para)
            else:
                pdf.ln(10)

        pdf.output(str(file_path))

    def _write_csv_file(
        self,
        file_path: Path,
        content: Union[str, list],
        encoding: str = "utf-8",
    ) -> None:
        """Writes content to a CSV file."""
        import csv

        with file_path.open("w", encoding=encoding, newline='') as f:
            if isinstance(content, str):
                f.write(content)
            else:
                writer = csv.writer(f)
                writer.writerows(content)

    def _write_json_file(
        self,
        file_path: Path,
        content: Union[str, dict, list],
        encoding: str = "utf-8",
    ) -> None:
        """Writes content to a JSON file."""
        import json

        with file_path.open("w", encoding=encoding) as f:
            if isinstance(content, str):
                try:
                    data = json.loads(content)
                    json.dump(data, f, ensure_ascii=False, indent=4)
                except json.JSONDecodeError:
                    f.write(content)
            else:
                json.dump(content, f, ensure_ascii=False, indent=4)

    def _write_yaml_file(
        self,
        file_path: Path,
        content: str,
        encoding: str = "utf-8",
        binary: bool = False,
        file_mode: str = "w"
    ) -> None:
        """Writes content to a YAML file."""
        # For YAML, writing the string directly is often sufficient.
        # Libraries like PyYAML can be used for complex object serialization.
        with file_path.open(file_mode, encoding=None if binary else encoding) as f:
            f.write(content)

    def _write_html_file(
        self, file_path: Path, content: str, encoding: str = "utf-8", binary: bool = False, file_mode: str = "w"
    ) -> None:
        """Writes content to an HTML file."""
        with file_path.open(file_mode, encoding=None if binary else encoding) as f:
            f.write(content)

    def _write_markdown_file(
        self, file_path: Path, content: str, encoding: str = "utf-8", binary: bool = False, file_mode: str = "w"
    ) -> None:
        """Writes content to a Markdown file."""
        with file_path.open(file_mode, encoding=None if binary else encoding) as f:
            f.write(content)

    async def call_tool(self, arguments: dict, **kwargs) -> Tuple[str, bool]:
        """
        Writes content to a file based on the provided arguments.
        """
        content = arguments["content"]
        file_path = arguments["file_path"]
        mode = arguments.get("mode", "a")
        binary = arguments.get("binary", False)

        # Determine the absolute path
        if os.path.isabs(file_path):
            absolute_path = file_path
        else:
            absolute_path = os.path.join(self.WORKSPACE_PATH, file_path)

        # If the file doesn't exist and the mode is append, change to write
        if not os.path.exists(absolute_path) and mode == 'a':
            mode = 'w'

        # Ensure the directory exists
        directory = os.path.dirname(absolute_path)
        if directory and not os.path.exists(directory):
            os.makedirs(directory)

        # Add 'b' to the mode for binary files
        file_mode = mode + 'b' if binary else mode

        path_obj = Path(absolute_path)
        extension = path_obj.suffix.lower()

        # If no extension is provided, use the default format
        if not extension:
            path_obj = path_obj.with_suffix(DEFAULT_FORMAT)
            extension = DEFAULT_FORMAT

        # Call the appropriate write method based on the extension
        if extension in [".doc", ".docx"]:
            self._write_docx_file(path_obj, str(content))
        elif extension == ".pdf":
            self._write_pdf_file(path_obj, str(content))
        elif extension == ".csv":
            self._write_csv_file(path_obj, content, encoding=default_encoding)
        elif extension == ".json":
            self._write_json_file(path_obj, content, encoding=default_encoding)
        elif extension in [".yml", ".yaml"]:
            self._write_yaml_file(path_obj, str(content), encoding=default_encoding, binary=binary, file_mode=mode)
        elif extension in [".html", ".htm"]:
            self._write_html_file(path_obj, str(content), encoding=default_encoding, binary=binary, file_mode=mode)
        elif extension in [".md", ".markdown"]:
            self._write_markdown_file(path_obj, str(content), encoding=default_encoding, binary=binary, file_mode=mode)
        else:
            # Fallback to plain text for unknown or .txt extensions
            self._write_text_file(path_obj, str(content), encoding=default_encoding, binary=binary, file_mode=file_mode)

        msg = f"Content successfully written to file: {file_path}"
        return msg, True


class CSFileSaver:
    def __init__(self, WORKSPACE_PATH=None):
        self.WORKSPACE_PATH = WORKSPACE_PATH or os.getcwd()
        self.tool_json_schema = {
            "name": 'save_to_file',
            "description": 'Save content to a local file at a specified path. Supports both text and binary files (e.g., images, audio, video). Default mode is append to preserve existing file content.',
            "parameters": {
                "type": "object",
                "properties": {
                    "content": {
                        "type": "string",
                        "description": "(str) Content to be saved (text or base64 encoded binary data)."
                    },
                    "file_path": {
                        "type": "string",
                        "description": "(str) Absolute or relative path of the file to save."
                    },
                    "mode": {
                        "type": "string",
                        "description": "(str) File opening mode: 'a' for append (default), 'w' for write (overwrite).",
                        "enum": ["a", "w"],
                        "default": "a"
                    },
                    "binary": {
                        "type": "boolean",
                        "description": "(bool) Whether to use binary mode.",
                        "default": False
                    }
                },
                "required": ["content", "file_path"]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs):
        r"""Save content to a file at the specified path. Supports both text and binary files. Default mode is append to preserve existing content.

        Returns:
            str: A message indicating the result of the operation.
        """
        
        content = arguments["content"]
        file_path = arguments["file_path"]
        mode = arguments.get("mode", "a")
        binary = arguments.get("binary", False)
        # Use the input path if it exists, otherwise use workspace path
        if os.path.exists(file_path):
            absolute_path = file_path
        else:
            absolute_path = os.path.join(self.WORKSPACE_PATH, file_path)
            # If file doesn't exist and mode is append, change to write mode
            if mode == 'a':
                mode = 'w'

        # Ensure the directory exists
        directory = os.path.dirname(absolute_path)
        if directory and not os.path.exists(directory):
            os.makedirs(directory)

        # Add 'b' to mode if binary
        file_mode = mode + 'b' if binary else mode
        with open(absolute_path, file_mode, encoding=None if binary else "utf-8") as file:
            file.write(content)

        return f"Content successfully saved to {file_path}", True


class CSFileReader:
    def __init__(self, WORKSPACE_PATH=None):
        """
        Initializes the CSFileReader tool.
        
        Args:
            WORKSPACE_PATH (str, optional): The path to the workspace directory. 
                                            If not provided, it will be read from the 
                                            "WORKSPACE_PATH" environment variable or 
                                            default to the current working directory.
        """
        self.WORKSPACE_PATH = WORKSPACE_PATH or os.getcwd()
        self.tool_json_schema = {
            "name": 'read_file',
            "description": 'Reads and returns the contents of a local file.',
            "parameters": {
                "type": "object",
                "properties": {
                    "file": {
                        "type": "string",
                        "description": "The full path to the file you want to read."
                    },
                    "start_line": {
                        "type": "integer",
                        "description": "(Optional) The line number to start reading from (0-indexed). For text files only."
                    },
                    "end_line": {
                        "type": "integer",
                        "description": "(Optional) The line number to stop reading at (exclusive). For text files only.",
                    },
                    "binary": {
                        "type": "boolean",
                        "description": "(Optional) Set to `true` to read the file in binary mode (for non-text files). Defaults to `false`.",
                        "default": False
                    }
                },
                "required": ["file"]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs):
        r"""Read file content. Supports both text and binary files.

        Args:
            arguments (dict): A dictionary containing the parameters for the tool call.
                - file (str): Absolute path of the file to read. The file must be in the workspace.
                - start_line (int, optional): Starting line to read from, 0-based (text files only).
                - end_line (int, optional): Ending line number (exclusive, text files only).
                - binary (bool, optional): Whether to read file in binary mode.

        Returns:
            Union[str, bytes]: The file content or an error message.
        """
        # 1. Extract parameters from the arguments dictionary
        file_path = arguments["file"]
        start_line = arguments.get("start_line")
        end_line = arguments.get("end_line")
        binary = arguments.get("binary", False)

        # Determine the absolute path
        if os.path.exists(file_path):
            absolute_path = file_path
        else:
            absolute_path = os.path.join(self.WORKSPACE_PATH, file_path)

        # Verify file exists at the final path
        if not os.path.exists(absolute_path):
            return f"Error: File not found at {absolute_path}", False

        # Read file content
        with open(absolute_path, 'rb' if binary else 'r', encoding=None if binary else 'utf-8') as f:
            if binary:
                return f.read(), True
            else:
                lines = f.readlines()

        # Handle line range for text files
        if not binary and (start_line is not None or end_line is not None):
            start = start_line if start_line is not None else 0
            end = end_line if end_line is not None else len(lines)
            # Ensure indices are within bounds
            start = max(0, start)
            end = min(len(lines), end)
            lines = lines[start:end]

        return ''.join(lines), True


class CSSearchFileContent:
    def __init__(self, WORKSPACE_PATH=None):
        """
        Initializes the tool with its JSON schema definition.
        """
        self.WORKSPACE_PATH = WORKSPACE_PATH or os.getcwd()
        self.tool_json_schema = {
            "name": 'search_file_content',
            "description": 'Searches for a text pattern (using regex) within a file and returns the matching lines.',
            "parameters": {
                "type": "object",
                "properties": {
                    "file": {
                        "type": "string",
                        "description": "The path of the file to search within."
                    },
                    "regex": {
                        "type": "string",
                        "description": "The regular expression pattern to find."
                    }
                },
                "required": ["file", "regex"]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs):
        r"""Search for matching text within text file content. Supports text-based formats like txt, markdown, etc.

        Args:
            arguments (dict): A dictionary containing the arguments for the tool call.
                - file (str): Absolute path of the text file to search within. The file must be in workspace.
                - regex (str): Regular expression pattern to match.
                - sudo (bool, optional): Whether to use sudo privileges. Defaults to False.

        Returns:
            str: Matching results or an error message.
        """
        # 1. Extract parameters from the arguments dictionary
        file_path = arguments["file"]
        regex = arguments["regex"]

        # 2. Replicate the core functionality of the original function
        # Use the input path if it exists, otherwise use workspace path
        if os.path.exists(file_path):
            absolute_path = file_path
        else:
            absolute_path = os.path.join(self.WORKSPACE_PATH, file_path)

        # Verify file exists
        if not os.path.exists(absolute_path):
            return f"Error: File not found at {file_path}", False

        # Read file content
        # Note: The original function doesn't use sudo for the read operation itself.
        # A real implementation might involve running a subprocess with sudo.
        with open(absolute_path, 'r', encoding='utf-8') as f:
            content = f.read()

        # Find matches
        matches = re.findall(regex, content)

        if not matches:
            return f"No match found for pattern '{regex}' in {file_path}.", False
        return f"Matches found in {file_path}:\n" + "\n".join(matches), True


class CSRemoteFileDownloader:
    """
    A class to download a remote file and save it to a specified path.
    """
    def __init__(self, WORKSPACE_PATH=None):
        """
        Initializes the CSRemoteFileDownloader tool.
        """
        self.WORKSPACE_PATH = WORKSPACE_PATH or os.getcwd()


        self.tool_json_schema = {
            "name": "download_file",
            "description": "Downloads a file from a URL and saves it to a local path. If a file already exists at the destination, it will be overwritten.",
            "parameters": {
                "type": "object",
                "properties": {
                    "url": {
                        "type": "string",
                        "description": "The direct URL of the file to be downloaded."
                    },
                    "dest_path": {
                        "type": "string",
                        "description": "The local path, including the filename and extension, where the file will be saved (e.g., 'downloads/image.jpg')."
                    }
                },
                "required": [
                    "url",
                    "dest_path"
                ]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs):
        """
        Downloads a remote file based on the provided arguments.

        Args:
            arguments (dict): A dictionary containing the necessary parameters.
                - url (str): The URL of the file to download.
                - dest_path (str): The absolute path where the file will be saved.

        Returns:
            str: A message indicating the result of the download operation.
        """
        # 1. Get parameters from the arguments dictionary
        url = arguments["url"]
        if os.path.isabs(arguments["dest_path"]):
            dest_path = arguments["dest_path"]
        else:
            dest_path = os.path.join(self.WORKSPACE_PATH, arguments["dest_path"])

        # 2. Replicate the core functionality of the original function
        chunk_size = 8192 # Increased chunk size for potentially better performance

        # If the file exists, notify and remove it to overwrite.
        if os.path.exists(dest_path):
            logger.info(f"File already exists, overwriting: {dest_path}")

        # Ensure the directory for the destination path exists
        Path(dest_path).parent.mkdir(parents=True, exist_ok=True)

        # Initiate the download request
        with requests.get(url, stream=True) as response:
            response.raise_for_status()  # Raise an exception for bad status codes (4xx or 5xx)
            
            total_size = int(response.headers.get('content-length', 0))

            with open(dest_path, 'wb') as f, tqdm(
                total=total_size,
                unit='B',
                unit_scale=True,
                unit_divisor=1024,
                desc=os.path.basename(dest_path)
            ) as bar:
                for chunk in response.iter_content(chunk_size=chunk_size):
                    if chunk:
                        f.write(chunk)
                        bar.update(len(chunk))

        success_message = f"Download complete: {arguments['dest_path']}"
        return success_message, True


class FileToolkit:
    def __init__(self):
        pass

    def file_str_replace(self, file: str, old_str: str, new_str: str, sudo: bool = False) -> str:
        r"""Replace specified string in a text file. Supports text-based formats like txt, markdown, etc.

        Args:
            file (str): Absolute path of the text file to perform replacement on. The file must be in workspace.
            old_str (str): Original string to be replaced
            new_str (str): New string to replace with
            sudo (bool, optional): Whether to use sudo privileges

        Returns:
            str: Success message or error message
        """
        try:
            # Use the input path if it exists, otherwise use workspace path
            if os.path.exists(file):
                absolute_path = file
            else:
                workspace_path = os.getenv("WORKSPACE_PATH") or os.getcwd()
                absolute_path = os.path.join(workspace_path, os.path.basename(file))

            # Verify file exists
            if not os.path.exists(absolute_path):
                return f"Error: File not found at {absolute_path}"

            # Read file content
            with open(absolute_path, 'r', encoding='utf-8') as f:
                content = f.read()

            # Perform replacement
            new_content = content.replace(old_str, new_str)

            # Write updated content
            with open(absolute_path, 'w', encoding='utf-8') as f:
                f.write(new_content)

            return f"Successfully replaced '{old_str}' with '{new_str}' in {absolute_path}"
        except PermissionError:
            return "Error: Permission denied. Try with sudo=True if appropriate"
        except Exception as e:
            return f"Error replacing string in file: {str(e)}"


def is_youtube_url(url):
    """
    判断是否为 YouTube 视频链接
    """
    parsed = urlparse(url)
    return "youtube.com" in parsed.netloc or "youtu.be" in parsed.netloc


def sanitize_filename(title):
    """
    简单清理非法字符，确保文件名合法
    """
    return re.sub(r'[\\/*?:"<>|]', "", title)


def get_video_title(url):
    """
    获取视频标题（用于构建文件名）
    """
    try:
        result = subprocess.run(
            ["yt-dlp", "--get-title", "--no-playlist", url],
            capture_output=True, text=True, check=True
        )
        title = result.stdout.strip()
        return sanitize_filename(title)
    except subprocess.CalledProcessError:
        return "default_name"


def download_youtube_audio_and_subs(url, lang="en", output_dir="."):
    """
    下载 YouTube 音频和自动字幕，并返回下载音频的绝对路径
    """
    if not is_youtube_url(url):
        print("⚠️ 该链接不是有效的 YouTube 视频链接，已跳过。")
        return None

    title = get_video_title(url)
    if not title:
        print("❌ 无法获取视频标题，可能是链接无效。")
        return None

    output_path = os.path.abspath(os.path.join(output_dir, f"{title}.mp4"))  # yt-dlp 默认音频格式常为 .webm 或 .m4a

    try:
        command = [
            "yt-dlp",
            "--write-auto-sub",
            "--no-playlist",
            "-o", output_path,
            url
        ]

        print(f"⏳ 正在下载：{title} ...")
        subprocess.run(command, check=True)
        print(f"✅ 下载完成！文件路径：{output_path}")
        compress_output_path = os.path.abspath(os.path.join(output_dir, f"{title}_compress.mp4"))
        compress_video_for_openai(output_path, compress_output_path)
        return compress_output_path

    except subprocess.CalledProcessError as e:
        print("❌ 下载失败，请检查 yt-dlp 是否正确安装，以及视频 URL 是否有效。")
        print("错误信息:", e)
        return None


def compress_video_for_openai(input_path, output_path=None, duration=30, width=640, fps=1, crf=24):
    """
    压缩视频并确保能够正常播放。
    :param input_path: 原始视频路径
    :param output_path: 输出路径（默认同目录添加 _compressed 后缀）
    :param duration: 保留时长（秒）
    :param width: 压缩后的视频宽度（高度自动等比）
    :param fps: 输出视频帧率
    :param crf: 压缩质量（越大越模糊，推荐 24~30）
    :return: 输出视频的绝对路径
    """
    if not os.path.isfile(input_path):
        raise FileNotFoundError(f"文件不存在: {input_path}")

    if output_path is None:
        base, ext = os.path.splitext(input_path)
        output_path = f"{base}_compressed.mp4"

    output_path = os.path.abspath(output_path)

    command = [
        "ffmpeg",
        "-y",  # 覆盖已存在的输出文件
        "-i", input_path,
        "-t", str(duration),  # 保留前 N 秒
        "-vf", f"scale={width}:-1,fps={fps}",  # 压缩分辨率和帧率
        "-c:v", "libx264",  # 使用常见的视频编码器
        "-preset", "veryfast",  # 编码速度
        "-crf", str(crf),  # 控制视频质量（越大越模糊）
        "-c:a", "aac",  # 使用 AAC 音频编码器，兼容性更好
        "-b:a", "192k",  # 设置音频比特率
        "-movflags", "+faststart",  # 提前加载元数据，支持流式播放
        output_path
    ]

    try:
        print("🎬 正在压缩视频，请稍候...")
        subprocess.run(command, check=True)
        print(f"✅ 压缩完成！输出路径：{output_path}")
        return output_path
    except subprocess.CalledProcessError as e:
        print("❌ 视频压缩失败，请检查 ffmpeg 是否正确安装。")
        print("错误信息:", e)
        return None


class PdfToPngConverter:
    """
    A tool to convert PDF files into a series of PNG images.
    """
    def __init__(self):
        """
        Initializes the tool and sets up its JSON schema definition.
        """
        self.tool_json_schema = {
            "name": 'pdf_to_png_converter',
            "description": 'Converts each page of a specified PDF file into a separate PNG image. The files are saved with the name page_{i}.png, where i is the page number starts from 1.',
            "parameters": {
                "type": "object",
                "properties": {
                    "read_file_path": {
                        "type": "string",
                        "description": "The full path to the input PDF file that needs to be converted."
                    },
                    "write_folder_path": {
                        "type": "string",
                        "description": "The path to the folder where the output PNG images will be saved. Defaults to the current working directory."
                    }
                },
                "required": ["read_file_path", "write_folder_path"]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs) -> Tuple[str, bool]:
        """
        Converts a PDF file to PNG images and saves them to a specified folder.

        Args:
            arguments (dict): A dictionary containing the tool's parameters.
                - read_file_path (str): The path to the source PDF file.
                - write_folder_path (str): The destination folder for the PNG files.

        Returns:
            Tuple[str, bool]: A tuple containing a result message and a boolean indicating success.
        """
        read_file_path = arguments.get("read_file_path")
        write_folder_path = arguments.get("write_folder_path", "./")

        # 1. Validate the input arguments
        if not read_file_path or not write_folder_path:
            return "Error: Missing 'read_file_path' or 'write_folder_path'. Both are required.", False

        try:
            # 2. Check if the source file exists
            if not os.path.isfile(read_file_path):
                return f"Error: The source file does not exist at '{read_file_path}'", False

            # 3. Convert PDF to a list of image objects
            images = convert_from_path(read_file_path)

            # 4. Create the output directory if it doesn't exist
            os.makedirs(write_folder_path, exist_ok=True)
            
            # 5. Save each page as a separate PNG file
            output_files = []
            for i, image in enumerate(images):
                output_path = os.path.join(write_folder_path, f'page_{i+1}.png')
                image.save(output_path, 'PNG')
                output_files.append(output_path)

            success_message = f"Successfully converted PDF to {len(output_files)} PNG files in '{write_folder_path}'"
            return success_message, True

        except Exception as e:
            # 6. Handle any other potential errors during conversion
            error_message = f"An unexpected error occurred: {e}"
            return error_message, False

class GetImage:
    """
    A tool to load an image from a specified local file path.
    """
    def __init__(self):
        """
        Initializes the tool and sets up its JSON schema definition.
        """
        self.tool_json_schema = {
            "name": 'get_image',
            "description": 'Load an image into the conversation.',
            "parameters": {
                "type": "object",
                "properties": {
                    "image_path": {
                        "type": "string",
                        "description": "The full file path to the input image file."
                    }
                },
                "required": ["image_path"]
            }
        }

    async def call_tool(self, arguments: dict, **kwargs) -> Tuple[dict, bool]:
        image_file_path = arguments.get("image_path")

        # 1. Validate that the file path argument was provided
        if not image_file_path:
            return {"error": "The 'image_path' argument is missing."}, False

        # 2. Validate that the file exists at the given path
        if not os.path.isfile(image_file_path):
            return {"error": f"No file found at the specified path: '{image_file_path}'"}, False

        try:
            return {'content': [{'data': encode_media(file_path=image_file_path), 'mimeType': 'image/png'}]}, True
        except Exception as e:
            return {"error": f"Error encoding image: {str(e)}"}, False
