SILENT KILLERPanel

Current Path: > > usr > lib64 > python2.7 > distutils > command >


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/lib64/python2.7/distutils/command/

NameTypeSizeLast ModifiedActions
__init__.py File 822 bytes April 10 2024 04:58:35.
__init__.pyc File 665 bytes April 10 2024 04:58:46.
__init__.pyo File 665 bytes April 10 2024 04:58:46.
bdist.py File 5596 bytes April 10 2024 04:58:35.
bdist.pyc File 5169 bytes April 10 2024 04:58:46.
bdist.pyo File 5169 bytes April 10 2024 04:58:46.
bdist_dumb.py File 5196 bytes April 10 2024 04:58:35.
bdist_dumb.pyc File 4983 bytes April 10 2024 04:58:46.
bdist_dumb.pyo File 4983 bytes April 10 2024 04:58:46.
bdist_msi.py File 35193 bytes April 10 2024 04:58:35.
bdist_msi.pyc File 23961 bytes April 10 2024 04:58:46.
bdist_msi.pyo File 23854 bytes April 10 2024 04:58:43.
bdist_rpm.py File 21049 bytes April 10 2024 04:58:35.
bdist_rpm.pyc File 17608 bytes April 10 2024 04:58:46.
bdist_rpm.pyo File 17524 bytes April 10 2024 04:58:43.
bdist_wininst.py File 14999 bytes April 10 2024 04:58:35.
bdist_wininst.pyc File 10725 bytes April 10 2024 04:58:46.
bdist_wininst.pyo File 10646 bytes April 10 2024 04:58:43.
build.py File 5456 bytes April 10 2024 04:58:35.
build.pyc File 5146 bytes April 10 2024 04:58:46.
build.pyo File 5146 bytes April 10 2024 04:58:46.
build_clib.py File 8131 bytes April 10 2024 04:58:35.
build_clib.pyc File 6347 bytes April 10 2024 04:58:46.
build_clib.pyo File 6347 bytes April 10 2024 04:58:46.
build_ext.py File 32511 bytes April 10 2024 04:58:35.
build_ext.py.debug-build File 32270 bytes April 10 2024 04:58:35.
build_ext.pyc File 19344 bytes April 10 2024 04:58:46.
build_ext.pyo File 19344 bytes April 10 2024 04:58:46.
build_py.py File 16338 bytes April 10 2024 04:58:35.
build_py.pyc File 11493 bytes April 10 2024 04:58:46.
build_py.pyo File 11421 bytes April 10 2024 04:58:43.
build_scripts.py File 4598 bytes April 10 2024 04:58:35.
build_scripts.pyc File 4477 bytes April 10 2024 04:58:46.
build_scripts.pyo File 4477 bytes April 10 2024 04:58:46.
check.py File 5672 bytes April 10 2024 04:58:35.
check.pyc File 6262 bytes April 10 2024 04:58:46.
check.pyo File 6262 bytes April 10 2024 04:58:46.
clean.py File 2814 bytes April 10 2024 04:58:35.
clean.pyc File 3069 bytes April 10 2024 04:58:46.
clean.pyo File 3069 bytes April 10 2024 04:58:46.
command_template File 719 bytes April 10 2024 04:58:35.
config.py File 13130 bytes April 10 2024 04:58:35.
config.pyc File 12685 bytes April 10 2024 04:58:46.
config.pyo File 12685 bytes April 10 2024 04:58:46.
install.py File 26264 bytes April 10 2024 04:58:35.
install.pyc File 16818 bytes April 10 2024 04:58:46.
install.pyo File 16818 bytes April 10 2024 04:58:46.
install_data.py File 2845 bytes April 10 2024 04:58:35.
install_data.pyc File 3118 bytes April 10 2024 04:58:46.
install_data.pyo File 3118 bytes April 10 2024 04:58:46.
install_egg_info.py File 2587 bytes April 10 2024 04:58:35.
install_egg_info.pyc File 3744 bytes April 10 2024 04:58:46.
install_egg_info.pyo File 3744 bytes April 10 2024 04:58:46.
install_headers.py File 1346 bytes April 10 2024 04:58:35.
install_headers.pyc File 2255 bytes April 10 2024 04:58:46.
install_headers.pyo File 2255 bytes April 10 2024 04:58:46.
install_lib.py File 8338 bytes April 10 2024 04:58:35.
install_lib.pyc File 6681 bytes April 10 2024 04:58:46.
install_lib.pyo File 6681 bytes April 10 2024 04:58:46.
install_scripts.py File 2068 bytes April 10 2024 04:58:35.
install_scripts.pyc File 2928 bytes April 10 2024 04:58:46.
install_scripts.pyo File 2928 bytes April 10 2024 04:58:46.
register.py File 11839 bytes April 10 2024 04:58:35.
register.pyc File 10208 bytes April 10 2024 04:58:46.
register.pyo File 10208 bytes April 10 2024 04:58:46.
sdist.py File 18557 bytes April 10 2024 04:58:35.
sdist.pyc File 16696 bytes April 10 2024 04:58:46.
sdist.pyo File 16696 bytes April 10 2024 04:58:46.
upload.py File 7000 bytes April 10 2024 04:58:35.
upload.pyc File 6308 bytes April 10 2024 04:58:46.
upload.pyo File 6308 bytes April 10 2024 04:58:46.

Reading File: //usr/lib64/python2.7/distutils/command//upload.py

"""distutils.command.upload

Implements the Distutils 'upload' subcommand (upload package to PyPI)."""
import os
import socket
import platform
from urllib2 import urlopen, Request, HTTPError
from base64 import standard_b64encode
import urlparse
import cStringIO as StringIO
from hashlib import md5

from distutils.errors import DistutilsError, DistutilsOptionError
from distutils.core import PyPIRCCommand
from distutils.spawn import spawn
from distutils import log

class upload(PyPIRCCommand):

    description = "upload binary package to PyPI"

    user_options = PyPIRCCommand.user_options + [
        ('sign', 's',
         'sign files to upload using gpg'),
        ('identity=', 'i', 'GPG identity used to sign files'),
        ]

    boolean_options = PyPIRCCommand.boolean_options + ['sign']

    def initialize_options(self):
        PyPIRCCommand.initialize_options(self)
        self.username = ''
        self.password = ''
        self.show_response = 0
        self.sign = False
        self.identity = None

    def finalize_options(self):
        PyPIRCCommand.finalize_options(self)
        if self.identity and not self.sign:
            raise DistutilsOptionError(
                "Must use --sign for --identity to have meaning"
            )
        config = self._read_pypirc()
        if config != {}:
            self.username = config['username']
            self.password = config['password']
            self.repository = config['repository']
            self.realm = config['realm']

        # getting the password from the distribution
        # if previously set by the register command
        if not self.password and self.distribution.password:
            self.password = self.distribution.password

    def run(self):
        if not self.distribution.dist_files:
            msg = ("Must create and upload files in one command "
                   "(e.g. setup.py sdist upload)")
            raise DistutilsOptionError(msg)
        for command, pyversion, filename in self.distribution.dist_files:
            self.upload_file(command, pyversion, filename)

    def upload_file(self, command, pyversion, filename):
        # Makes sure the repository URL is compliant
        schema, netloc, url, params, query, fragments = \
            urlparse.urlparse(self.repository)
        if params or query or fragments:
            raise AssertionError("Incompatible url %s" % self.repository)

        if schema not in ('http', 'https'):
            raise AssertionError("unsupported schema " + schema)

        # Sign if requested
        if self.sign:
            gpg_args = ["gpg", "--detach-sign", "-a", filename]
            if self.identity:
                gpg_args[2:2] = ["--local-user", self.identity]
            spawn(gpg_args,
                  dry_run=self.dry_run)

        # Fill in the data - send all the meta-data in case we need to
        # register a new release
        f = open(filename,'rb')
        try:
            content = f.read()
        finally:
            f.close()
        meta = self.distribution.metadata
        data = {
            # action
            ':action': 'file_upload',
            'protcol_version': '1',

            # identify release
            'name': meta.get_name(),
            'version': meta.get_version(),

            # file content
            'content': (os.path.basename(filename),content),
            'filetype': command,
            'pyversion': pyversion,
            'md5_digest': md5(content).hexdigest(),

            # additional meta-data
            'metadata_version' : '1.0',
            'summary': meta.get_description(),
            'home_page': meta.get_url(),
            'author': meta.get_contact(),
            'author_email': meta.get_contact_email(),
            'license': meta.get_licence(),
            'description': meta.get_long_description(),
            'keywords': meta.get_keywords(),
            'platform': meta.get_platforms(),
            'classifiers': meta.get_classifiers(),
            'download_url': meta.get_download_url(),
            # PEP 314
            'provides': meta.get_provides(),
            'requires': meta.get_requires(),
            'obsoletes': meta.get_obsoletes(),
            }
        comment = ''
        if command == 'bdist_rpm':
            dist, version, id = platform.dist()
            if dist:
                comment = 'built for %s %s' % (dist, version)
        elif command == 'bdist_dumb':
            comment = 'built for %s' % platform.platform(terse=1)
        data['comment'] = comment

        if self.sign:
            data['gpg_signature'] = (os.path.basename(filename) + ".asc",
                                     open(filename+".asc").read())

        # set up the authentication
        auth = "Basic " + standard_b64encode(self.username + ":" +
                                             self.password)

        # Build up the MIME payload for the POST data
        boundary = '--------------GHSKFJDLGDS7543FJKLFHRE75642756743254'
        sep_boundary = '\r\n--' + boundary
        end_boundary = sep_boundary + '--\r\n'
        body = StringIO.StringIO()
        for key, value in data.items():
            # handle multiple entries for the same name
            if not isinstance(value, list):
                value = [value]
            for value in value:
                if isinstance(value, tuple):
                    fn = ';filename="%s"' % value[0]
                    value = value[1]
                else:
                    fn = ""

                body.write(sep_boundary)
                body.write('\r\nContent-Disposition: form-data; name="%s"' % key)
                body.write(fn)
                body.write("\r\n\r\n")
                body.write(value)
        body.write(end_boundary)
        body = body.getvalue()

        self.announce("Submitting %s to %s" % (filename, self.repository), log.INFO)

        # build the Request
        headers = {'Content-type':
                        'multipart/form-data; boundary=%s' % boundary,
                   'Content-length': str(len(body)),
                   'Authorization': auth}

        request = Request(self.repository, data=body,
                          headers=headers)
        # send the data
        try:
            result = urlopen(request)
            status = result.getcode()
            reason = result.msg
            if self.show_response:
                msg = '\n'.join(('-' * 75, result.read(), '-' * 75))
                self.announce(msg, log.INFO)
        except socket.error, e:
            self.announce(str(e), log.ERROR)
            raise
        except HTTPError, e:
            status = e.code
            reason = e.msg

        if status == 200:
            self.announce('Server response (%s): %s' % (status, reason),
                          log.INFO)
        else:
            msg = 'Upload failed (%s): %s' % (status, reason)
            self.announce(msg, log.ERROR)
            raise DistutilsError(msg)

SILENT KILLER Tool