Source code for reemote.facts.sftp.isdir

# Copyright (c) 2025 Kim Jarvis TPF Software Services S.A. kim.jarvis@tpfsystems.com 
# This software is licensed under the MIT License. See the LICENSE file for details.
#
import asyncssh
from reemote.command import Command
from reemote.result import Result


[docs] class Isdir: """ A class to encapsulate the functionality of checking if a path refers to a directory using SFTP isdir in Unix-like operating systems. Attributes: path: The remote path to check (can be PurePath, str, or bytes). **Examples:** .. code:: python yield Isdir(path="/path/to/directory") Usage: This class is designed to be used in a generator-based workflow where commands are yielded for execution. The boolean result for each host will be returned in the operation result. Notes: The operation will execute on all hosts in the current execution context. The path must be a valid remote path accessible via SFTP. """ def __init__(self, path=None): self.path = path def __repr__(self): return f"Isdir(path={self.path!r})" @staticmethod async def _isdir_callback(host_info, global_info, command, cp, caller): """Static callback method for checking if a path is a directory""" async with asyncssh.connect(**host_info) as conn: async with conn.start_sftp_client() as sftp: # Check if the path refers to a directory if caller.path: is_dir = await sftp.isdir(caller.path) return is_dir else: raise ValueError("Path must be provided for isdir operation") def execute(self): r = yield Command(f"{self}", local=True, callback=self._isdir_callback, caller=self) r.executed = True r.changed = False return r