From Fedora Project Wiki

Revision as of 14:27, 26 February 2015 by Mstuchli (talk | contribs)

This document details realization of User Level Package Management for the Python use case.

DevPi

DevPi is a PyPI compatible server that we can use to mirror a restricted set of packages and their versions from the root PyPI server. A DevPI server can have multiple indexes -- repositories for metadata and files.

Indexes and packages

The Fedora Python DevPI server will contain several indexes, in the form of fedora/21, fedora/22, etc. for each supported Fedora release. Each index will include PyPI packages that are packaged in the relevant Fedora branch. These packages will be rebuilt as wheel with Python runtime that is used as system Python in the relevant Fedora branch.

The set of packages and their versions that are to be mirrored will be determined by a whitelist file that will be generated by scanning all the Fedora packages in the relevant Fedora branch and determining if they come from PyPI.

Since not all packages that use PyPI are named python-* and since not all python-* packages use PyPI, this would probably be best done by inspecting the Source field in spec file.

This whitelist will then be passed to DevPI using the feature described in [1].

Package versions

The Fedora indexes will mirror all version that are equal or higher compared to version of the respective package in Fedora. Indexes covering non-Fedora products can have different permissivity, e.g. RSHSCL indexes could mirror only the specific version that is included in the product.

Patches

Should the fedora patches be included in the mirrored package? If they are, what happens when they can't be applied to a newer version?

Issue reporting

Since we will mirror package version that are not part of Fedora and may have issues, e.g. got relicensed under a lincese that in not OK for Fedora, we will have a way of reporting these issues. This could be at least partially automatized with a tool like licorice [2].