$32 GRAYBYTE WORDPRESS FILE MANAGER $11

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 172.67.217.254 | ADMIN IP 216.73.216.157
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/python27/lib/python2.7/site-packages/pip/_internal/utils/

HOME
Current File : /opt/alt/python27/lib/python2.7/site-packages/pip/_internal/utils//filesystem.py
import errno
import fnmatch
import os
import os.path
import random
import shutil
import stat
import sys
from contextlib import contextmanager
from tempfile import NamedTemporaryFile

# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is
#       why we ignore the type on this import.
from pip._vendor.retrying import retry  # type: ignore
from pip._vendor.six import PY2

from pip._internal.utils.compat import get_path_uid
from pip._internal.utils.misc import format_size
from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast

if MYPY_CHECK_RUNNING:
    from typing import Any, BinaryIO, Iterator, List, Union

    class NamedTemporaryFileResult(BinaryIO):
        @property
        def file(self):
            # type: () -> BinaryIO
            pass


def check_path_owner(path):
    # type: (str) -> bool
    # If we don't have a way to check the effective uid of this process, then
    # we'll just assume that we own the directory.
    if sys.platform == "win32" or not hasattr(os, "geteuid"):
        return True

    assert os.path.isabs(path)

    previous = None
    while path != previous:
        if os.path.lexists(path):
            # Check if path is writable by current user.
            if os.geteuid() == 0:
                # Special handling for root user in order to handle properly
                # cases where users use sudo without -H flag.
                try:
                    path_uid = get_path_uid(path)
                except OSError:
                    return False
                return path_uid == 0
            else:
                return os.access(path, os.W_OK)
        else:
            previous, path = path, os.path.dirname(path)
    return False  # assume we don't own the path


def copy2_fixed(src, dest):
    # type: (str, str) -> None
    """Wrap shutil.copy2() but map errors copying socket files to
    SpecialFileError as expected.

    See also https://bugs.python.org/issue37700.
    """
    try:
        shutil.copy2(src, dest)
    except (OSError, IOError):
        for f in [src, dest]:
            try:
                is_socket_file = is_socket(f)
            except OSError:
                # An error has already occurred. Another error here is not
                # a problem and we can ignore it.
                pass
            else:
                if is_socket_file:
                    raise shutil.SpecialFileError(
                        "`{f}` is a socket".format(**locals()))

        raise


def is_socket(path):
    # type: (str) -> bool
    return stat.S_ISSOCK(os.lstat(path).st_mode)


@contextmanager
def adjacent_tmp_file(path, **kwargs):
    # type: (str, **Any) -> Iterator[NamedTemporaryFileResult]
    """Return a file-like object pointing to a tmp file next to path.

    The file is created securely and is ensured to be written to disk
    after the context reaches its end.

    kwargs will be passed to tempfile.NamedTemporaryFile to control
    the way the temporary file will be opened.
    """
    with NamedTemporaryFile(
        delete=False,
        dir=os.path.dirname(path),
        prefix=os.path.basename(path),
        suffix='.tmp',
        **kwargs
    ) as f:
        result = cast('NamedTemporaryFileResult', f)
        try:
            yield result
        finally:
            result.file.flush()
            os.fsync(result.file.fileno())


_replace_retry = retry(stop_max_delay=1000, wait_fixed=250)

if PY2:
    @_replace_retry
    def replace(src, dest):
        # type: (str, str) -> None
        try:
            os.rename(src, dest)
        except OSError:
            os.remove(dest)
            os.rename(src, dest)

else:
    replace = _replace_retry(os.replace)


# test_writable_dir and _test_writable_dir_win are copied from Flit,
# with the author's agreement to also place them under pip's license.
def test_writable_dir(path):
    # type: (str) -> bool
    """Check if a directory is writable.

    Uses os.access() on POSIX, tries creating files on Windows.
    """
    # If the directory doesn't exist, find the closest parent that does.
    while not os.path.isdir(path):
        parent = os.path.dirname(path)
        if parent == path:
            break  # Should never get here, but infinite loops are bad
        path = parent

    if os.name == 'posix':
        return os.access(path, os.W_OK)

    return _test_writable_dir_win(path)


def _test_writable_dir_win(path):
    # type: (str) -> bool
    # os.access doesn't work on Windows: http://bugs.python.org/issue2528
    # and we can't use tempfile: http://bugs.python.org/issue22107
    basename = 'accesstest_deleteme_fishfingers_custard_'
    alphabet = 'abcdefghijklmnopqrstuvwxyz0123456789'
    for _ in range(10):
        name = basename + ''.join(random.choice(alphabet) for _ in range(6))
        file = os.path.join(path, name)
        try:
            fd = os.open(file, os.O_RDWR | os.O_CREAT | os.O_EXCL)
        # Python 2 doesn't support FileExistsError and PermissionError.
        except OSError as e:
            # exception FileExistsError
            if e.errno == errno.EEXIST:
                continue
            # exception PermissionError
            if e.errno == errno.EPERM or e.errno == errno.EACCES:
                # This could be because there's a directory with the same name.
                # But it's highly unlikely there's a directory called that,
                # so we'll assume it's because the parent dir is not writable.
                # This could as well be because the parent dir is not readable,
                # due to non-privileged user access.
                return False
            raise
        else:
            os.close(fd)
            os.unlink(file)
            return True

    # This should never be reached
    raise EnvironmentError(
        'Unexpected condition testing for writable directory'
    )


def find_files(path, pattern):
    # type: (str, str) -> List[str]
    """Returns a list of absolute paths of files beneath path, recursively,
    with filenames which match the UNIX-style shell glob pattern."""
    result = []  # type: List[str]
    for root, _, files in os.walk(path):
        matches = fnmatch.filter(files, pattern)
        result.extend(os.path.join(root, f) for f in matches)
    return result


def file_size(path):
    # type: (str) -> Union[int, float]
    # If it's a symlink, return 0.
    if os.path.islink(path):
        return 0
    return os.path.getsize(path)


def format_file_size(path):
    # type: (str) -> str
    return format_size(file_size(path))


def directory_size(path):
    # type: (str) -> Union[int, float]
    size = 0.0
    for root, _dirs, files in os.walk(path):
        for filename in files:
            file_path = os.path.join(root, filename)
            size += file_size(file_path)
    return size


def format_directory_size(path):
    # type: (str) -> str
    return format_size(directory_size(path))


Current_dir [ NOT WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
3 Mar 2024 10.49 PM
root / linksafe
0755
__init__.py
0 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
__init__.pyc
0.221 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
appdirs.py
1.317 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
appdirs.pyc
2.016 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
compat.py
9.267 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
compat.pyc
9.653 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
compatibility_tags.py
5.312 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
compatibility_tags.pyc
4.909 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
datetime.py
0.288 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
datetime.pyc
0.731 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
deprecation.py
3.24 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
deprecation.pyc
3.805 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
direct_url_helpers.py
4.257 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
direct_url_helpers.pyc
3.61 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
distutils_args.py
1.318 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
distutils_args.pyc
1.726 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
encoding.py
1.254 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
encoding.pyc
1.731 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
entrypoints.py
1.19 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
entrypoints.pyc
1.589 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
filesystem.py
6.78 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
filesystem.pyc
8.431 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
filetypes.py
0.558 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
filetypes.pyc
0.834 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
glibc.py
3.22 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
glibc.pyc
2.493 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
hashes.py
4.568 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
hashes.pyc
6.646 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
inject_securetransport.py
0.791 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
inject_securetransport.pyc
1.189 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
logging.py
12.786 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
logging.pyc
13.289 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
misc.py
27.667 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
misc.pyc
37.103 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
models.py
1.173 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
models.pyc
3.218 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
packaging.py
2.964 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
packaging.pyc
3.572 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
parallel.py
3.324 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
parallel.pyc
3.921 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
pkg_resources.py
1.225 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
pkg_resources.pyc
2.939 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
setuptools_build.py
4.939 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
setuptools_build.pyc
4.254 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
subprocess.py
9.691 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
subprocess.pyc
7.313 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
temp_dir.py
8.182 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
temp_dir.pyc
9.96 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
typing.py
1.368 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
typing.pyc
1.644 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
unpacking.py
9.266 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
unpacking.pyc
8.435 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
urls.py
1.491 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
urls.pyc
2.187 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
virtualenv.py
3.619 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
virtualenv.pyc
4.597 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
wheel.py
7.132 KB
13 Nov 2023 9.11 PM
root / linksafe
0644
wheel.pyc
7.997 KB
13 Nov 2023 9.11 PM
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF