Skip to main content

devpi-server: reliable private and pypi.org caching server

Project description

devpi-server: server for private package indexes and PyPI caching

PyPI cache

You can point pip or easy_install to the root/pypi/+simple/ index, serving as a transparent cache for pypi-hosted packages.

User specific indexes

Each user (which can represent a person, project or team) can have multiple indexes and upload packages and docs via standard twine or setup.py invocations. Users and indexes can be manipulated through devpi-client and a RESTful HTTP API.

Index inheritance

Each index can be configured to merge in other indexes so that it serves both its uploads and all releases from other index(es). For example, an index using root/pypi as a parent is a good place to test out a release candidate before you push it to PyPI.

Good defaults and easy deployment

Get started easily and create a permanent devpi-server deployment including pre-configured templates for nginx and process managers.

Separate tool for Packaging/Testing activities

The complementary devpi-client tool helps to manage users, indexes, logins and typical setup.py-based upload and installation workflows.

See https://doc.devpi.net on how to get started and further documentation.

Support

If you find a bug, use the issue tracker at Github.

For general questions use the #devpi IRC channel on freenode.net or the devpi-dev@python.org mailing list.

For support contracts and paid help contact merlinux.eu.

Changelog

6.0.0 (2021-05-16)

Deprecations and Removals

  • Remove deprecated command line options which were replaced by separate scripts.

  • Dropped support for Python 2.7, 3.4 and 3.5. Python 3.x versions will be supported until their EOL (see https://devguide.python.org/#status-of-python-branches). After that, any release might break support for EOLed versions.

  • Removed deprecated --start, --stop and --status options.

Features

  • fix #140: support force flag for deletion on non-volatile indexes.

  • fix #725: new option mirror_whitelist_inheritance for indexes. The union setting is the old behaviour and used for existing indexes to not break existing installations. With it the whitelist of each index in the inheritance order is merged into the current whitelist. This could lead to unexpected whitelisting. The new intersection setting is used for all new indexes and it intersects the whitelist at each step in the inheritance order which is more secure and never causes unexpected whitelisting.

  • fix #792: support data-yanked attribute from PEP 592 for mirror indexes.

  • fix #827: add --listen option corresponding to listen kwarg of waitress server.

  • Replicas download files asynchronously from the metadata and will do so with multiple parallel requests. This means the metadata will be in sync faster and downloads will process quicker. Missing files will be downloaded on demand if they haven’t been fetched yet. The new --file-replication-threads option allows controlling the amount of parallel downloads. Event processing waits until files for that serial are available. Since newest files are downloaded first, event processing might wait until all files are downloaded.

  • Add devpi-gen-secret script to generate a file with a random secret and proper permissions.

  • Installers will get simple results directly instead of a redirect when an index is used without /+simple or without a trailing slash.

  • Much faster mirror project names parsing. For PyPI the speedup can be about 30x.

  • Do some validity and security checks on the secret provided by --secretfile.

  • The server secret for token signing is now derived via argon2 from the data provided by --secretfile. Existing login tokens are invalidated by this.

  • Add --trusted-proxy, --trusted-proxy-count and --trusted-proxy-headers to support proxy headers with waitress.

  • The user creation and modification time is now stored. Adding or removing an index doesn’t count as a modification.

Bug Fixes

  • fix #210: the original fix was incomplete and the test for it was subtly wrong.

  • fix #451: packages not on mirror_whitelist no longer query the mirror

  • fix #680: indexes with multiple mirror bases now work correctly with default secure whitelist settings.

  • Handle cases where the Content-Type header from a mirror can be an empty string.

Other Changes

  • The X-Outside-URL header now takes precedence over the --outside-url option. This allows the option to be the fallback when there is no proxy in front, instead of overwriting the header.

  • Warning! Once you used 6.0.0 with a replica you have to check that all files have been downloaded with devpi-fsck before attempting to downgrade to 5.x.y, as those older versions have no mechanism to re-download those.

  • Add new devpiserver_auth_request hook and deprecate devpiserver_auth_user hook.

  • Require pyramid>=2.

  • Use secrets.token_bytes instead of os.urandom for salts and server secrets.

  • Replicas need to use the same secret as the master for the --secretfile option to be able to authenticate with the master.

  • Replicas will no longer proxy to the master to determine the authentication status now that the secret must be shared between master and replicas.

  • When using --restrict-modify those users can’t delete their own user object to prevent lockout.

  • The secret file must be user accessible only, devpi-server will not start if it is not.

5.5.1 (2021-03-01)

Bug Fixes

  • Pin to pyramid<2.

5.5.0 (2020-05-04)

Features

  • Proxy requests from replica to master are now streamed if possible. This improves reliability of large uploads through replicas and reduces RAM usage on the replica.

5.4.1 (2020-03-26)

Bug Fixes

  • Import won’t abort anymore when a base index was removed. The bases setting will be imported as is.

5.4.0 (2020-01-31)

Features

  • The requires_python metadata is now included in version data on mirror indexes.

  • Downloaded files from mirrors can be included in exports with the --include-mirrored-files option.

  • On import files for mirror indexes are now imported when they were included in the dump (see --include-mirrored-files).

Bug Fixes

  • Fix --no-root-pypi option when importing devpi data.

  • Fix pushing from mirror to an index when the file was removed and mirror_use_external_urls is active.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

devpi-server-6.0.0.tar.gz (229.3 kB view details)

Uploaded Source

Built Distribution

devpi_server-6.0.0-py3-none-any.whl (235.8 kB view details)

Uploaded Python 3

File details

Details for the file devpi-server-6.0.0.tar.gz.

File metadata

  • Download URL: devpi-server-6.0.0.tar.gz
  • Upload date:
  • Size: 229.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: devpi-server/5.5.0 (py3.7.3; linux)

File hashes

Hashes for devpi-server-6.0.0.tar.gz
Algorithm Hash digest
SHA256 fbd3700168f02d77c11ea0e5d3749f1d49d3b7ddcf7e961e10820b8934f6701a
MD5 bf1a3c502a88c83a7aec1a8d156d83d7
BLAKE2b-256 5ac022636f5398783a72177f60a8744e72a8c9c4198b460cbaf73492b0443d6d

See more details on using hashes here.

File details

Details for the file devpi_server-6.0.0-py3-none-any.whl.

File metadata

  • Download URL: devpi_server-6.0.0-py3-none-any.whl
  • Upload date:
  • Size: 235.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: devpi-server/5.5.0 (py3.7.3; linux)

File hashes

Hashes for devpi_server-6.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d73c9fe3a2d483d515f2c069dafa5c9aa19382b72ed371e1b53002ed30bc330a
MD5 b578f6c3b79c7366a1bf5d5ac767c7d8
BLAKE2b-256 49047588995aeaa01cd1c14ce1d4b70205a1b9cd4484bdd109272339ddd96e49

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