Current Path: > > opt > alt > python27 > 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 | January 08 2025 10:43:30. | |
__init__.pyc | File | 678 bytes | January 08 2025 10:43:30. | |
__init__.pyo | File | 678 bytes | January 08 2025 10:43:30. | |
bdist.py | File | 5596 bytes | January 08 2025 10:43:30. | |
bdist.pyc | File | 5247 bytes | January 08 2025 10:43:30. | |
bdist.pyo | File | 5247 bytes | January 08 2025 10:43:30. | |
bdist_dumb.py | File | 5196 bytes | January 08 2025 10:43:30. | |
bdist_dumb.pyc | File | 5048 bytes | January 08 2025 10:43:30. | |
bdist_dumb.pyo | File | 5048 bytes | January 08 2025 10:43:30. | |
bdist_msi.py | File | 35193 bytes | January 08 2025 10:43:30. | |
bdist_msi.pyc | File | 24182 bytes | January 08 2025 10:43:29. | |
bdist_msi.pyo | File | 24075 bytes | January 08 2025 10:43:30. | |
bdist_rpm.py | File | 21049 bytes | January 08 2025 10:43:30. | |
bdist_rpm.pyc | File | 17725 bytes | January 08 2025 10:43:29. | |
bdist_rpm.pyo | File | 17641 bytes | January 08 2025 10:43:30. | |
bdist_wininst.py | File | 14999 bytes | January 08 2025 10:43:30. | |
bdist_wininst.pyc | File | 10855 bytes | January 08 2025 10:43:30. | |
bdist_wininst.pyo | File | 10776 bytes | January 08 2025 10:43:30. | |
build.py | File | 5456 bytes | January 08 2025 10:43:30. | |
build.pyc | File | 5276 bytes | January 08 2025 10:43:30. | |
build.pyo | File | 5276 bytes | January 08 2025 10:43:30. | |
build_clib.py | File | 8131 bytes | January 08 2025 10:43:29. | |
build_clib.pyc | File | 6477 bytes | January 08 2025 10:43:30. | |
build_clib.pyo | File | 6477 bytes | January 08 2025 10:43:30. | |
build_ext.py | File | 32502 bytes | January 08 2025 10:43:29. | |
build_ext.py.debug-build | File | 32270 bytes | January 08 2025 10:43:30. | |
build_ext.pyc | File | 19591 bytes | January 08 2025 10:43:30. | |
build_ext.pyo | File | 19591 bytes | January 08 2025 10:43:30. | |
build_py.py | File | 16338 bytes | January 08 2025 10:43:30. | |
build_py.pyc | File | 11766 bytes | January 08 2025 10:43:29. | |
build_py.pyo | File | 11694 bytes | January 08 2025 10:43:30. | |
build_scripts.py | File | 4598 bytes | January 08 2025 10:43:29. | |
build_scripts.pyc | File | 4568 bytes | January 08 2025 10:43:30. | |
build_scripts.pyo | File | 4568 bytes | January 08 2025 10:43:30. | |
check.py | File | 5672 bytes | January 08 2025 10:43:30. | |
check.pyc | File | 6418 bytes | January 08 2025 10:43:30. | |
check.pyo | File | 6418 bytes | January 08 2025 10:43:30. | |
clean.py | File | 2814 bytes | January 08 2025 10:43:30. | |
clean.pyc | File | 3134 bytes | January 08 2025 10:43:30. | |
clean.pyo | File | 3134 bytes | January 08 2025 10:43:30. | |
command_template | File | 719 bytes | January 08 2025 10:43:30. | |
config.py | File | 13130 bytes | January 08 2025 10:43:30. | |
config.pyc | File | 12945 bytes | January 08 2025 10:43:29. | |
config.pyo | File | 12945 bytes | January 08 2025 10:43:29. | |
install.py | File | 26264 bytes | January 08 2025 10:43:30. | |
install.pyc | File | 17130 bytes | January 08 2025 10:43:30. | |
install.pyo | File | 17130 bytes | January 08 2025 10:43:30. | |
install_data.py | File | 2845 bytes | January 08 2025 10:43:30. | |
install_data.pyc | File | 3209 bytes | January 08 2025 10:43:29. | |
install_data.pyo | File | 3209 bytes | January 08 2025 10:43:29. | |
install_egg_info.py | File | 2587 bytes | January 08 2025 10:43:30. | |
install_egg_info.pyc | File | 3861 bytes | January 08 2025 10:43:30. | |
install_egg_info.pyo | File | 3861 bytes | January 08 2025 10:43:30. | |
install_headers.py | File | 1346 bytes | January 08 2025 10:43:30. | |
install_headers.pyc | File | 2346 bytes | January 08 2025 10:43:30. | |
install_headers.pyo | File | 2346 bytes | January 08 2025 10:43:30. | |
install_lib.py | File | 8338 bytes | January 08 2025 10:43:30. | |
install_lib.pyc | File | 6837 bytes | January 08 2025 10:43:30. | |
install_lib.pyo | File | 6837 bytes | January 08 2025 10:43:30. | |
install_scripts.py | File | 2068 bytes | January 08 2025 10:43:29. | |
install_scripts.pyc | File | 3019 bytes | January 08 2025 10:43:29. | |
install_scripts.pyo | File | 3019 bytes | January 08 2025 10:43:29. | |
register.py | File | 11839 bytes | January 08 2025 10:43:30. | |
register.pyc | File | 10377 bytes | January 08 2025 10:43:30. | |
register.pyo | File | 10377 bytes | January 08 2025 10:43:30. | |
sdist.py | File | 18557 bytes | January 08 2025 10:43:30. | |
sdist.pyc | File | 16930 bytes | January 08 2025 10:43:30. | |
sdist.pyo | File | 16930 bytes | January 08 2025 10:43:30. | |
upload.py | File | 7000 bytes | January 08 2025 10:43:30. | |
upload.pyc | File | 6386 bytes | January 08 2025 10:43:30. | |
upload.pyo | File | 6386 bytes | January 08 2025 10:43:30. | |
wininst-6.0.exe | File | 61440 bytes | January 08 2025 10:43:29. | |
wininst-7.1.exe | File | 65536 bytes | January 08 2025 10:43:30. | |
wininst-8.0.exe | File | 61440 bytes | January 08 2025 10:43:30. | |
wininst-9.0-amd64.exe | File | 223744 bytes | January 08 2025 10:43:29. | |
wininst-9.0.exe | File | 196096 bytes | January 08 2025 10:43:30. |
"""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