Skip to content

Latest commit

 

History

History
139 lines (100 loc) · 6.56 KB

GOVERNANCE.md

File metadata and controls

139 lines (100 loc) · 6.56 KB

Harbor Governance

This document defines the project governance for Harbor.

Overview

Harbor, a Cloud Native Computing Foundation (CNCF) project, is committed to building an open, inclusive, productive and self-governing open source community focused on building a high-quality cloud native registry. The community is governed by this document with the goal of defining how community should work together to achieve this goal.

Code Repositories

The following code repositories are governed by Harbor community and maintained under the goharbor namespace.

  • harbor: Main Harbor codebase.
  • harbor-helm: Helm chart for easy deployment of Harbor
  • community: Used to store community-related material–e.g., proposals, presentation slides, governance documents, community meeting minutes, etc.

Community Roles

  • Users: Members that engage with the Harbor community via any medium (Slack, WeChat, GitHub, mailing lists, etc.).
  • Contributors: Regular contributions to projects (documentation, code reviews, responding to issues, participation in proposal discussions, contributing code, etc.). Two levels of maintainership are defined below.
  • Maintainers: Two levels of maintainership are defined in the Project Leadership section below.

Project Leadership

There are two roles that convey project leadership: maintainers and core maintainers.

  • Core Maintainers: Responsible for the overall health and direction of the project; final reviewers of PRs and responsible for releases.
  • Maintainers: Responsible for one or more components within a project, and are expected to contribute code and documentation, review PRs including ensuring quality of code, triage issues, proactively fix bugs, and perform maintenance tasks for these components.

Total Maintainership

Total maintainership is defined as the union of maintainers and core maintainers.

Maintainers

New maintainers must be nominated by an existing maintainer or core maintainer and must be elected by a supermajority of total maintainership. Likewise, maintainers can be removed by a supermajority of the total maintainership or can resign by notifying the core maintainers.

Core Maintainers

Nomination for core maintainership requires (a) a nomination by an existing core maintainer, and (b) election by a supermajority of the core maintainer group. Likewise, maintainers can be removed by a supermajority core maintainer vote or can resign by notifying the core maintainers.

Supermajority

A supermajority is defined as two-thirds of members in the group. A supermajority of Maintainers, Core Maintainers, or the union of both is required for certain decisions as outlined above.

Decision Making

Ideally, all project decisions are resolved by consensus. If impossible, any maintainer may call a vote. Unless otherwise specified in this document, any vote will be decided by a supermajority of the total maintainership, with a requirement of at least one core maintainer voting.

Votes by maintainers (either core or non-core) belonging to the same company will count as one vote; e.g., 4 maintainers employed by company ${x} will only have one combined vote. If voting members from a given company do not agree, the company's vote is determined by a supermajority of voters from that company. If no supermajority is achieved, the company is considered to have abstained.

Proposal Process

One of the most important aspects in any open source community is the concept of proposals. Large changes to the codebase and / or new features should be preceded by a proposal in our community repo. This process allows for all members of the community to weigh in on the concept (including the technical details), share their comments and ideas, and offer to help. It also ensures that members are not duplicating work or inadvertently stepping on toes by making large conflicting changes.

The project roadmap is defined by accepted proposals.

Proposals should cover the high-level objectives, use cases, and technical recommendations on how to implement. In general, the community member(s) interested in implementing the proposal should be either deeply engaged in the proposal process or be an author of the proposal.

The proposal should be documented as a separated markdown file pushed to the root of the proposals folder in the community repository via PR. The name of the file should follow the name pattern <short meaningful words joined by '-'>_proposal.md, e.g: clear-old-tags-with-policies_proposal.md.

Use the Proposal Template as a starting point.

Proposal Lifecycle

The proposal PR can be marked with different status labels to represent the status of the proposal:

  • New: Proposal is just created.
  • Reviewing: Proposal is under review and discussion.
  • Accepted: Proposal is reviewed and accepted (either by consensus or vote).
  • Rejected: Proposal is reviewed and rejected (either by consensus or vote).

Lazy Consensus

To maintain velocity in a project as busy as Harbor, the concept of Lazy Consensus is practiced. Ideas and / or proposals should be shared by maintainers (core or non-core) via GitHub with the appropriate maintainer groups (e.g., @goharbor/all-maintainers) tagged. Out of respect for other contributors, major changes should also be accompanied by a ping on Slack or a note on the Harbor dev mailing list as appropriate. Author(s) of proposal, Pull Requests, issues, etc. will give a time period of no less than five (5) working days for comment and remain cognizant of popular observed world holidays.

Other maintainers may chime in and request additional time for review, but should remain cognizant of blocking progress and abstain from delaying progress unless absolutely needed. The expectation is that blocking progress is accompanied by a guarantee to review and respond to the relevant action(s) (proposals, PRs, issues, etc.) in short order.

Lazy Consensus is practiced for all projects in the goharbor org, including the main project repository, community-driven sub-projects, and the community repo that includes proposals and governing documents.

Lazy consensus does not apply to the process of:

  • Removing core or non-core maintainers

Updating Governance

All substantive changes in Governance require a supermajority Total Maintainership vote.