HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-157-generic #167-Ubuntu SMP Wed Sep 17 21:35:53 UTC 2025 x86_64
User: sport3497 (1034)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //usr/local/CyberCP/lib64/python3.10/site-packages/paramiko/__pycache__/sftp_handle.cpython-310.pyc
o

�h�@sHdZddlZddlmZmZddlmZGdd�de�Zddlm	Z	dS)z7
Abstraction of an SFTP file handle (for server mode).
�N)�SFTP_OP_UNSUPPORTED�SFTP_OK)�ClosingContextManagerc@sbeZdZdZddd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�Zdd�Z
dS)�
SFTPHandlea�
    Abstract object representing a handle to an open file (or folder) in an
    SFTP server implementation.  Each handle has a string representation used
    by the client to refer to the underlying file.

    Server implementations can (and should) subclass SFTPHandle to implement
    features of a file handle, like `stat` or `chattr`.

    Instances of this class may be used as context managers.
    rcCs||_d|_i|_d|_dS)a"
        Create a new file handle representing a local file being served over
        SFTP.  If ``flags`` is passed in, it's used to determine if the file
        is open in append mode.

        :param int flags: optional flags as passed to
            `.SFTPServerInterface.open`
        N)�_SFTPHandle__flags�_SFTPHandle__name�_SFTPHandle__files�_SFTPHandle__tell)�self�flags�r�G/usr/local/CyberCP/lib/python3.10/site-packages/paramiko/sftp_handle.py�__init__(s	
zSFTPHandle.__init__cCs@t|dd�}|dur|��t|dd�}|dur|��dSdS)a
        When a client closes a file, this method is called on the handle.
        Normally you would use this method to close the underlying OS level
        file object(s).

        The default implementation checks for attributes on ``self`` named
        ``readfile`` and/or ``writefile``, and if either or both are present,
        their ``close()`` methods are called.  This means that if you are
        using the default implementations of `read` and `write`, this
        method's default implementation should be fine also.
        �readfileN�	writefile)�getattr�close)r
rrrrr
r7s�zSFTPHandle.closec
Cs�t|dd�}|durtSz|jdur|��|_||jkr$|�|�||_|�|�}WntyE}zd|_t�|j	�WYd}~Sd}~ww|jt
|�7_|S)a5
        Read up to ``length`` bytes from this file, starting at position
        ``offset``.  The offset may be a Python long, since SFTP allows it
        to be 64 bits.

        If the end of the file has been reached, this method may return an
        empty string to signify EOF, or it may also return ``SFTP_EOF``.

        The default implementation checks for an attribute on ``self`` named
        ``readfile``, and if present, performs the read operation on the Python
        file-like object found there.  (This is meant as a time saver for the
        common case where you are wrapping a Python file object.)

        :param offset: position in the file to start reading from.
        :param int length: number of bytes to attempt to read.
        :return: the `bytes` read, or an error code `int`.
        rN)rrr	�tell�seek�read�IOError�
SFTPServer�
convert_errno�errno�len)r
�offset�lengthr�data�errr
rJs"



��zSFTPHandle.readc
Cs�t|dd�}|durtSz*|jtj@dkr,|jdur|��|_||jkr,|�|�||_|�|�|�	�Wnt
yQ}zd|_t�|j
�WYd}~Sd}~ww|jdur`|jt|�7_tS)am
        Write ``data`` into this file at position ``offset``.  Extending the
        file past its original end is expected.  Unlike Python's normal
        ``write()`` methods, this method cannot do a partial write: it must
        write all of ``data`` or else return an error.

        The default implementation checks for an attribute on ``self`` named
        ``writefile``, and if present, performs the write operation on the
        Python file-like object found there.  The attribute is named
        differently from ``readfile`` to make it easy to implement read-only
        (or write-only) files, but if both attributes are present, they should
        refer to the same file.

        :param offset: position in the file to start reading from.
        :param bytes data: data to write into the file.
        :return: an SFTP error code like ``SFTP_OK``.
        rNr)rrr�os�O_APPENDr	rr�write�flushrrrrrr)r
rrrrrrr
r!ls(




��
zSFTPHandle.writecC�tS)a�
        Return an `.SFTPAttributes` object referring to this open file, or an
        error code.  This is equivalent to `.SFTPServerInterface.stat`, except
        it's called on an open file instead of a path.

        :return:
            an attributes object for the given file, or an SFTP error code
            (like ``SFTP_PERMISSION_DENIED``).
        :rtype: `.SFTPAttributes` or error code
        �r�r
rrr
�stat�szSFTPHandle.statcCr#)af
        Change the attributes of this file.  The ``attr`` object will contain
        only those fields provided by the client in its request, so you should
        check for the presence of fields before using them.

        :param .SFTPAttributes attr: the attributes to change on this file.
        :return: an `int` error code like ``SFTP_OK``.
        r$)r
�attrrrr
�chattr�s	zSFTPHandle.chattrcCs
||_dS)z�
        Used by the SFTP server code to cache a directory listing.  (In
        the SFTP protocol, listing a directory is a multi-stage process
        requiring a temporary handle.)
        N�r)r
�filesrrr
�
_set_files�s
zSFTPHandle._set_filescCs"|jdd�}|jdd�|_|S)z^
        Used by the SFTP server code to retrieve a cached directory
        listing.
        N�r))r
�fnlistrrr
�_get_next_files�szSFTPHandle._get_next_filescCs|jS�N�rr%rrr
�	_get_name�szSFTPHandle._get_namecCs
||_dSr/r0)r
�namerrr
�	_set_name�s
zSFTPHandle._set_nameN)r)�__name__�
__module__�__qualname__�__doc__rrrr!r&r(r+r.r1r3rrrr
rs
"&

	r)r)
r7r�
paramiko.sftprr�
paramiko.utilrr�paramiko.sftp_serverrrrrr
�<module>s)