SILENT KILLERPanel

Current Path: > > usr > > lib > python2.7 > site-packages > pip > utils


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr//lib/python2.7/site-packages/pip/utils

NameTypeSizeLast ModifiedActions
__init__.py File 27187 bytes April 21 2022 18:08:21.
__init__.pyc File 27725 bytes April 21 2022 18:08:35.
__init__.pyo File 27666 bytes April 21 2022 18:08:36.
appdirs.py File 8811 bytes April 21 2022 18:08:21.
appdirs.pyc File 8607 bytes April 21 2022 18:08:35.
appdirs.pyo File 8607 bytes April 21 2022 18:08:35.
build.py File 1312 bytes April 21 2022 18:08:21.
build.pyc File 1719 bytes April 21 2022 18:08:35.
build.pyo File 1719 bytes April 21 2022 18:08:35.
deprecation.py File 2232 bytes April 21 2022 18:08:21.
deprecation.pyc File 2317 bytes April 21 2022 18:08:35.
deprecation.pyo File 2317 bytes April 21 2022 18:08:35.
encoding.py File 971 bytes April 21 2022 18:08:21.
encoding.pyc File 1282 bytes April 21 2022 18:08:35.
encoding.pyo File 1282 bytes April 21 2022 18:08:35.
filesystem.py File 899 bytes April 21 2022 18:08:21.
filesystem.pyc File 780 bytes April 21 2022 18:08:35.
filesystem.pyo File 780 bytes April 21 2022 18:08:35.
glibc.py File 2939 bytes April 21 2022 18:08:21.
glibc.pyc File 1826 bytes April 21 2022 18:08:35.
glibc.pyo File 1826 bytes April 21 2022 18:08:35.
hashes.py File 2866 bytes April 21 2022 18:08:21.
hashes.pyc File 3961 bytes April 21 2022 18:08:35.
hashes.pyo File 3961 bytes April 21 2022 18:08:35.
logging.py File 3327 bytes April 21 2022 18:08:21.
logging.pyc File 4842 bytes April 21 2022 18:08:35.
logging.pyo File 4842 bytes April 21 2022 18:08:35.
outdated.py File 5989 bytes April 21 2022 18:08:21.
outdated.pyc File 5680 bytes April 21 2022 18:08:35.
outdated.pyo File 5680 bytes April 21 2022 18:08:35.
packaging.py File 2080 bytes April 21 2022 18:08:21.
packaging.pyc File 2461 bytes April 21 2022 18:08:35.
packaging.pyo File 2461 bytes April 21 2022 18:08:35.
setuptools_build.py File 278 bytes April 21 2022 18:08:21.
setuptools_build.pyc File 347 bytes April 21 2022 18:08:35.
setuptools_build.pyo File 347 bytes April 21 2022 18:08:35.
ui.py File 11597 bytes April 21 2022 18:08:21.
ui.pyc File 11683 bytes April 21 2022 18:08:35.
ui.pyo File 11613 bytes April 21 2022 18:08:36.

Reading File: //usr//lib/python2.7/site-packages/pip/utils/hashes.py

from __future__ import absolute_import

import hashlib

from pip.exceptions import HashMismatch, HashMissing, InstallationError
from pip.utils import read_chunks
from pip._vendor.six import iteritems, iterkeys, itervalues


# The recommended hash algo of the moment. Change this whenever the state of
# the art changes; it won't hurt backward compatibility.
FAVORITE_HASH = 'sha256'


# Names of hashlib algorithms allowed by the --hash option and ``pip hash``
# Currently, those are the ones at least as collision-resistant as sha256.
STRONG_HASHES = ['sha256', 'sha384', 'sha512']


class Hashes(object):
    """A wrapper that builds multiple hashes at once and checks them against
    known-good values

    """
    def __init__(self, hashes=None):
        """
        :param hashes: A dict of algorithm names pointing to lists of allowed
            hex digests
        """
        self._allowed = {} if hashes is None else hashes

    def check_against_chunks(self, chunks):
        """Check good hashes against ones built from iterable of chunks of
        data.

        Raise HashMismatch if none match.

        """
        gots = {}
        for hash_name in iterkeys(self._allowed):
            try:
                gots[hash_name] = hashlib.new(hash_name)
            except (ValueError, TypeError):
                raise InstallationError('Unknown hash name: %s' % hash_name)

        for chunk in chunks:
            for hash in itervalues(gots):
                hash.update(chunk)

        for hash_name, got in iteritems(gots):
            if got.hexdigest() in self._allowed[hash_name]:
                return
        self._raise(gots)

    def _raise(self, gots):
        raise HashMismatch(self._allowed, gots)

    def check_against_file(self, file):
        """Check good hashes against a file-like object

        Raise HashMismatch if none match.

        """
        return self.check_against_chunks(read_chunks(file))

    def check_against_path(self, path):
        with open(path, 'rb') as file:
            return self.check_against_file(file)

    def __nonzero__(self):
        """Return whether I know any known-good hashes."""
        return bool(self._allowed)

    def __bool__(self):
        return self.__nonzero__()


class MissingHashes(Hashes):
    """A workalike for Hashes used when we're missing a hash for a requirement

    It computes the actual hash of the requirement and raises a HashMissing
    exception showing it to the user.

    """
    def __init__(self):
        """Don't offer the ``hashes`` kwarg."""
        # Pass our favorite hash in to generate a "gotten hash". With the
        # empty list, it will never match, so an error will always raise.
        super(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []})

    def _raise(self, gots):
        raise HashMissing(gots[FAVORITE_HASH].hexdigest())

SILENT KILLER Tool