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 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__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. |
"""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