This document describes a proposed governance model for the Python Packaging Authority (PyPA). The model is closely based on existing informal practices, "status-quo", with the intent of providing clarity into the functioning of the PyPA and formalizing transparent processes for the PyPA.
Anyone with the triage bit or commit bit, on at least one project in the PyPA organization.
Anyone with the commit bit on at least one project in the PyPA organization, which should correspond to everyone on the PyPA-Committers mailing list.
Note that all PyPA committers are PyPA members.
Essentially anyone who is interested in PyPA activity and wants to follow along or make proposals.
As described in the Packaging-WG Wiki page.
The Python Packaging Authority (PyPA) is a collaborative community that maintains many of the relevant projects in Python packaging. The software and standards developed through the PyPA are used to package, share, and install Python software and to interact with indexes of downloadable Python software such as PyPI, the Python Package Index.
These goals are the primary motivation for the existence of the PyPA. These goals are largely already being carried out, even though most have not been explicitly defined.
In the event that a given project needs additional support, or no longer has active maintainers, the PyPA will ensure that the given project will continue to be supported for users to the extent necessary.
The PyPA should, as much as possible, strive for standardization and coordination across PyPA projects, primarily though the governance process outlined below. PyPA projects are expected to abide by applicable specifications maintained by the PyPA.
The PyPA community (especially PyPA members) should be expected to provide opinions, insight and experience when ecosystem-wide changes are being proposed.
For example: accepting new projects from the community, organically creating projects within the PyPA, etc.
Generally this means leading by example, but occasionally it may mean more explicit moderation.
These are specific items that are explicitly not goals of the PyPA.
This is for members of individual projects to decide, as they add new members to their projects. Maintainership of a project that is under the PyPA organization automatically transfers membership in the PyPA.
As long as the project is adhering to the Code of Conduct, the PyPA should only concerned with large, ecosystem-wide changes.
These are new goals which the governance model seeks to make possible.
Provide a transparent process for decisions taken, regarding project membership in the PyPA.
Formally document how the PyPA uses Python Enhancement Proposals (PEPs), for maintaining interoperability specifications defined by the PyPA.
The processes for PyPA's functioning are outlined below:
PEPs will be used for defining, and making changes to, the interoperability specifications maintained by the PyPA. Thus, the Python Steering Council has the final say in the acceptance of these interoperability specifications.
It is expected (and not required) that the Python Steering Council would delegate the authority to approve (or reject) PEPs, to individuals within the PyPA community. At the time of writing (Sept 2019), the Python Steering Council has standing delegations for currently active packaging interoperability specifications.
The details of the process of proposing and updating the interoperability specifications are described at https://www.pypa.io/en/latest/specifications.
A PyPA member can put forward a proposal and call for a vote on a public PyPA communication channel. A PyPA committer vote is triggered when a PyPA committer (not the proposer) seconds the proposal.
The proposal will be put to a vote on the PyPA-Committers mailing list, over a 7 day period. Each PyPA committer can vote once, and can choose one of +1
and -1
. If at least two thirds of voters vote +1
, then the vote succeeds.
PyPA committer votes are required for, and limited to, the following kinds of proposals:
Proposing the acceptance of a project into the PyPA organization. This proposal must not be opposed by the existing maintainers of the project.
Proposing the creation of a new tools / project in the PyPA organization.
Proposing the removal of a project in the PyPA organization.
Proposing changes to how the PyPA operates, including but not limited to changes to its specification and governance processes.
A project that is a part of the PyPA organization, can request to leave PyPA.
Such requests can made by a committer of the project, on the PyPA-Committers mailing list and must clearly state the GitHub user/organization to transfer the repository to.
If the request is not opposed by another committer of the same project over a 7 day period, the project would leave the PyPA and be transferred out of the PyPA organization as per the request.
Guido assigned BDFL-delegate responsibility to myself and @dstufft (interop and warehouse respectively) in the past. Is this statement intended to suggest that we ask the SC to ratify and/or modify those delegations, or are we expecting to simply assume they carry on unless the SC chooses to request a change? It's probably worth being explicit here (and I doubt there's any harm in requesting ratification, at least).