September 12, 2017
BOINC is an open-source middleware system for volunteer computing, originally developed at UC Berkeley. BOINC is a meritocratic, consensus-based project. Anyone can join the BOINC community and contribute to the project in various ways. Those who consistently make positive contributions, as recognized by other contributors and users, can then become part of the decision-making process. This document describes the structures and processes governing these activities.
The general goal of the project is to maintain and develop BOINC in a way that:
- Reflects the needs and interests of its community.
- Is “sustainable”, i.e. does not depend on any one person, group, or funding source, and which allows and encourages volunteer participation.
Specific goals include:
- Distribute an “official” version of the BOINC source code, and a revision history with branches corresponding to public releases.
- Ensure that the BOINC software is modified as needed to work correctly with new versions of operating systems and virtualization software, new GPUs and other coprocessors, and new versions of server software such as Linux, PHP, Apache, and MySQL.
- Maintain a “public web site” (currently https://boinc.berkeley.edu) where volunteers can learn about volunteer computing, download the client software in installer form, and get support. The web site will also have instructions for people wanting to contribute to the project, and will describe the governance structure of the project, including the current version of this document.
- Ensure that the BOINC documentation is available online and is maintained.
- Maintain the process of internationalizing (translating) the BOINC software.
- Ensure that future development of BOINC proceeds coherently according to architectural plans agreed upon by the community.
In the following discussion, it is important to note that people may belong to one or more categories. For example, someone can be a committer and a PMC member. In another case, someone might only be a PMC member. In all cases, one person only gets one vote on issues even if they have multiple roles.
“Users” are people who use BOINC in some way. Examples include:
- “Volunteers” run the BOINC client software, contributing processing power and storage capacity to computing projects.
- “Project admins” operate BOINC-based computing projects (academic science projects, hobbyist projects, commercial projects). They run the project’s servers, maintain its web site, and develop and deploy its applications.
- “Add-on developers” create and operate systems that, although not part of BOINC, interact with it through its various APIs. Examples include: Account managers (such as BAM! And GridRepublic) Statistics web sites (such as BoincStats and BOINC All-Project Stats) GUIs such as BOINCTasks Branded versions of BOINC (such as HTC Power to Give, Samsung Power Sleep, and Intel Progress Thru Processors)
- Leaders of BOINC teams.
Anyone can be a user. The project asks its users to participate in the project and community as much as possible, for example by:
- Evangelizing about the project (e.g. by web links or word of mouth)
- Informing the community of strengths and weaknesses of BOINC’s products
- Users may contribute in other ways, as described below.
“Contributors” are people who contribute in concrete ways to BOINC, other than by computing for a BOINC-based project. Forms of contribution include:
- Programming
- Testing and bug reporting
- Writing and editing documentation
- Doing translations for a particular language
- Identifying and defining new software requirements
- Providing “customer support” by answering questions from volunteers and contributors
- Providing infrastructure (servers, hosting of email lists)
- Financial support, such as paying the salary of other contributors
In some forms of contribution, such as programming and documentation, contributors submit changes by developing code in branches and submitting them as pull requests for review by committers (see the next section). As contributors gain experience, their reputation within the community will increase. Contributors can nominate themselves or other people to the PMC as potential committers.
“Committers” are contributors who have shown, via a sequence of positive contributions, their value to the project. Committers facilitate the software development process both by contributing code themselves and also by mentoring contributors to help them become more effective contributors. Only committers can merge a pull request into the master branch and they should only do so through the process defined in Section 4. Committers have voting rights in the consensus process as it pertains to proposed design changes and to the reviews of pull requests. They contribute to discussion and approval of the software development process as documented in Section 4.
Each committer will be associated with one or more “areas” of the project:
- Software development and maintenance
- Translation system
- Testing and release management
- Documentation
- BOINC web site, including News items
- Support
- Infrastructure (e.g. setting up and maintaining email lists and Github repository; maintaining BOINC web server)
Depending on the committer’s area(s), they will be given specific privileges such as:
- Commit access to the source code repository
- Write access to the documentation Wikis
- Write access to the public web site
- Moderator status on project message boards
Committers are expected to:
- Read the communication channels relevant to their area(s)
- Subscribe to pull request notifications within github (https://help.github.com/categories/notifications/)
- Review bug reports and features and make sure that they are valid and contain sufficient detail to implement
- Review proposed solutions to bugs and feature requests
- Prioritize bug reports and features so that contributors and other developers know which issues are most important and in need of contribution
- Review pull requests and merge code when appropriate
- Identify contributors who would be helpful as committers; nominate these contributors to the PMC via the PMC email distribution list for consideration
The Project Management Committee (PMC) is a group of community members who have consistently and significantly contributed to the project, for example by
- Directly contributing in any of the ways listed in Section 2.2
- Operating a related system, such as an account manager, that is used by a significant number of volunteers
- Operating a BOINC project with a significant number of volunteers
- Contributing significant resources to the project, for example by paying the salary of a contributor
The functions of the PMC are:
- Decide on the strategic directions of the project
- Decide issues of intellectual property (copyright, licensing) and other legal issues
- Review and vote on nominated committers
- Decide on PMC membership
- Decide on the set of “approved” projects and account managers
- Modify the governance policies of the project as needed
PMC members are expected to actively participate in these processes, by
- Reading the PMC email lists (see below)
- Participating in votes (see below)
The “PMC Chair” is a member of the PMC, elected by the PMC to take this role. The chair has the following responsibilities:
- Ensure that votes are taken on issues that require votes
- Ensure that the activities of the BOINC community are in agreement with this document and established procedures
- Schedule monthly meetings of the PMC
The Chair remains in that role until they retire or the PMC votes to remove them. He or she has no additional authority beyond that of other PMC members.
The official list of committers and members of the PMC shall be maintained at http://boinc.berkeley.edu/trac/wiki/ProjectGovernance. This page shall also clearly list the email address of the PMC public email list with instructions on how someone can subscribe to the list.
The project will provide communication channels for various purposes:
- PMC public email list, used for:
- Requests to be a submitter
- Requests to be a PMC member
- Project-level discussion
- PMC private email list, used for sensitive issues, such as discussion of potential new committers, or legal matters that can’t be discussed in public. It is not used for project management or planning
- Issue tracking system, for bugs and development requests (https://github.com/BOINC/boinc/issues)
- Volunteer message boards, for support requests and responses
- Project admin email list, for announcements and discussion related to the BOINC server software and other issues related to BOINC-based computing projects
- Email lists for specific contribution areas, such as software development, testing, and translations
Except for the PMC private email list, all of these channels will be publicly readable and writable.
Anyone can contribute to BOINC. There are multiple ways to contribute to BOINC:
- Help other users by answering questions on the BOINC forums (https://boinc.berkeley.edu/dev/forum_index.php), project forums (see project list: https://boinc.berkeley.edu/projects.php) or on the BOINC mailing lists (https://boinc.berkeley.edu/trac/wiki/EmailLists)
- Add or maintain documentation to the BOINC wikis
- Add or maintaining translations of BOINC
- Participate in the Alpha testing of software releases (https://boinc.berkeley.edu/alpha/)
- Make a technical contribution
If you need help getting started, then please visit https://boinc.berkeley.edu/dev/forum_index.php and post in the "How to Contribute" forum.
The process of making technical or code contributions is the same for everyone, regardless of whether they are a contributor, committer or PMC member. You can contribute by doing the following:
- Read the BOINC developer information (https://boinc.berkeley.edu/trac/wiki/SoftwareDevelopment) to learn about the BOINC system
- Find something that needs to be implemented in BOINC:
- Review the Project (https://github.com/BOINC/boinc/projects) associated with the area of BOINC in which you want to contribute
- Issues that have been reviewed and are ready for implementation are listed under Longterm or TODO
- Issues with a higher priority for implementation are listed under TODO
- Follow the software development process that BOINC uses (See Development_Workflow.md)
If you are reporting a bug or requesting a feature, make sure you review the Development Workflow before you submit it.
Because one of the fundamental aspects of accomplishing things within the BOINC framework is doing so by consensus, it is necessary to determine whether consensus has been reached. This is done by voting.
There are a few types of items that require a vote:
- Whether or not to fix a bug or implement a feature request (documented and voted on as an issue on github)
- The design of a proposed feature or bug fix (documented and voted on within the relevant issue on github)
- A change in code or configuration to the system (documented and voted on as a pull request on github)
- General availability of stable releases (documented and voted on in the boinc_alpha mailing list)
- Procedural and other issues
- Other committer votes not otherwise identified above will be voted on in the boinc_dev mailing list
- Other PMC votes not otherwise identified above will be voted on in the boinc_adm or private boinc_pmc mailing lists as deemed appropriate by the PMC Chair.
Votes on design reviews, pull requests, and general availability of a stable release shall use the consensus voting process.
Procedural and other issues shall always follow the majority voting process.
Consensus voting consists of a 7 day review period. During this time anyone can review and discuss the item. At the end of the 7 day period, if there is at least one "Yes" vote for an item (apart from the vote of the person who created the item) and zero "No" votes, then the vote shall be deemed as having passed.
A vote of "No" shall not be valid unless it is accompanied by a detailed explanation of the objection to the item. It is preferable to suggest an alternative implementation if possible.
If discussion cannot remove the concerns that resulted in the "No" vote, then the vote shall be deemed as having failed.
If the vote fails, but the original proposer of the item still believes that the item is worth pursuing, they can appeal to the PMC. The PMC shall consider the appeal at their next regularly scheduled meeting and will use Majority Voting to determine the outcome.
Majority voting requires that at least 2/3rds of eligible voters cast a vote and, of those who cast a vote, a majority must approve the item.
Committers can vote on issues surrounding the technical infrastructure of the project and the code base itself. This includes voting to determine if a reported bug, feature request, proposed design, or pull request should be accepted. Committers are encouraged to review and participate in the discussion of any of these items, but they are also expected to know when it is advisable to get help from other committers who are stronger in the technology involved or have more experience in the area of application under consideration. Committers are expected to understand the Development Workflow and Client Release Process and their associated guidelines before voting to approve.
Committers are expected to subscribe to notifications from github in order to be aware of proposals under consideration. Committers should make a reasonable attempt to respond quickly if they are personally asked to review an item. Since most decisions that committers are involved in will use consensus voting, it is important for them to try to remain aware of proposed items.
Certain specific types of decisions by the PMC must be made by a special voting procedure (see below).
Decisions of the following types must be made by a special vote of the PMC:
- Intellectual property issues, e.g. those involving copyright and licensing of BOINC code
- Other legal and financial decisions
- PMC membership
- Selection of the PMC chair
- Changes to the project governance structure (i.e. changes to this document)
Votes can be called by any PMC member. The special voting process is:
- A vote is announced on the PMC public list, phrasing the issue as a yes/no decision
- Discussion of the issue (by the entire community) takes place on the PMC public list. Sensitive discussion among PMC members uses the PMC private list
- PMC members cast their votes publicly (by email on the PMC public list)
- Votes on these issues are decided by agreement of at least 75% of responding voters. The vote will be final when there is agreement of at least 75% of PMC members, or when 14 days have passed since the vote was called.
- If there is not agreement of at least 75% of responding voters, no action is taken on the issue
For all other types of decisions that require a PMC vote, the PMC will start decision making using the consensus voting with PMC members voting. If consensus voting fails to reach agreement, the chair or the person who called the vote can request that a majority vote occurs to determine the outcome.