Skip to main content

Upload source distributions to your PyPI server.

Project description

https://secure.travis-ci.org/ignacysokolowski/pypi-uploader.png https://coveralls.io/repos/ignacysokolowski/pypi-uploader/badge.png https://pypip.in/v/pypi-uploader/badge.png https://pypip.in/d/pypi-uploader/badge.png

Upload source distributions of your requirements to your PyPI server.

The problem

If you are using a custom PyPI server as a proxy and want to upload some packages there, it’s not easy. For each package, you need to download its source and upload it using setup.py script:

# Uploading requests==2.0.0
$ git clone https://github.com/kennethreitz/requests
$ cd requests
$ git checkout v2.0.0
# Assuming you have 'internal' index-server configured in your '~/.pypirc'.
$ python setup.py sdist upload -r internal
# Uploading coverage==3.5
$ cd ..
$ git clone https://github.com/nedbat/coveragepy
$ cd coveragepy
$ git checkout coverage-3.5
$ python setup.py sdist upload -r internal

You could also download the packages directly into the PyPI’s index directory.

$ ssh pypi-mirror.yourdomain.com
$ pip install requests==2.0.0 coverage==3.5 -d ~/.packages

If there’s more than one package, you could use a requirements file.

$ scp requirements.txt pypi-mirror.yourdomain.com:.
$ ssh pypi-mirror.yourdomain.com
$ pip install -r requirements.txt -d ~/.packages

But it’s still too much. You should be able to do it with one command. And what if you don’t have SSH access to the PyPI server host?

The solution

One command for download and upload.

Upload packages by name

$ pypiupload packages mock==1.0.1 requests==2.2.1 -i internal

Upload packages from requirements file

$ pypiupload requirements requirements.txt -i internal

Upload source distribution files

$ pypiupload files packages/mock-1.0.1.tar.gz \
  packages/requests-2.2.1-py2.py3-none-any.whl -i internal

More options

$ pypiupload --help
$ pypiupload <command> --help

Supported PyPI servers

Tested only on pypiserver.

Installation

Install from PyPI:

$ pip install pypi-uploader

Or go to the root directory with setup.py script and install it:

$ python setup.py install

Documentation

Documentation is available at https://pypi-uploader.readthedocs.org

Source

Source is available at https://github.com/ignacysokolowski/pypi-uploader

License

PyPI Uploader is licensed under the MIT license.

Changelog

Version 1.1.0

  • Adapt to newer versions of pip: use pip download instead of pip install for downloading packages, and --no-binary :all: instead of --no-use-wheel to not use wheel archives.

Version 1.0.0

  • Added --no-use-wheel option

Version 0.1.0

First release

Issues and contributing

Please report any issues on GitHub at https://github.com/ignacysokolowski/pypi-uploader/issues

Or contribute by submitting a pull request with your changes following these rules:

  • Follow PEP 8 rules

  • Follow PEP 257 rules

  • Follow The Zen of Python

  • Test your commits

  • Write meaningful commit messages

  • Keep the documentation up-to-date

To run tests and build the docs, you have to install additional packages:

$ python setup.py develop
$ pip install -r requirements_dev.txt

Running tests:

$ tox

Building documentation:

$ cd docs
$ make html

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pypi-uploader-1.1.0.tar.gz (19.4 kB view details)

Uploaded Source

File details

Details for the file pypi-uploader-1.1.0.tar.gz.

File metadata

File hashes

Hashes for pypi-uploader-1.1.0.tar.gz
Algorithm Hash digest
SHA256 c011671afe815d1f9cf914ab498c005a143841b8adb6cbd8903896e1b4ef5a8c
MD5 e027c3d7ef4a51324ad832df4c29c443
BLAKE2b-256 7097bb14d2b7f3dd11e863a3b82bcb2e6d64c90135b443373cc9a8f7e6abeef6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page