Skip to content
This repository has been archived by the owner on Apr 29, 2020. It is now read-only.

RFC 0002: IPFS governance structure (wip) #2

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

flyingzumwalt
Copy link

Proposes a governance structure with protocols for creating & dissolving working groups, using RFCs, etc.

@flyingzumwalt flyingzumwalt force-pushed the 0002-ipfs-governance branch 3 times, most recently from 479a8d8 to 39abbab Compare March 9, 2018 02:27
@flyingzumwalt flyingzumwalt force-pushed the 0002-ipfs-governance branch from 39abbab to b767bc3 Compare March 9, 2018 02:30
@flyingzumwalt
Copy link
Author

flyingzumwalt commented Mar 9, 2018

In the latest commit I've renamed Product Working Groups to Teams. Please comment if you disagree.

Background: In previous iterations, we called everything a Working Group but distinguished between Product Working Groups (PWG) and Functional Working Groups (FWG). That language was really clunky. To make the language clearer, in the current version of the RFC I renamed Product Working Groups to Teams and renamed Functional Working Groups to just "Working Groups".

Some of Drawbacks of calling everything a WG:

  1. We are literally designing PWGs to force people to work as (small) teams. They’re teams, not WGs.
  2. Creating an explosion of WGs will make the org and its communications sound very bureaucratic, and forcing people to understand & follow important distinctions between two nearly identical acronyms- PWG and FWG - will be both confusing and frustrating (and classic bureaucratic BS).
  3. It will make it harder for people to understand the guidelines. “Commit to one team. Join as many WGs as you want.” Is easier to remember and apply than “Commit to one Product Working Group. Join as many Functional Working Groups as you want.” — especially since people will say things like “Infrastructure is Functional, not a Product”
  4. Some Product Working Groups produce Services, so they’re Services Groups, not Product Groups, so then we're stuck with three acronyms instead of two, and the distinction between two of them is just linguistic, not procedural (In our org there's no structural difference between Teams who produce/maintain products and Teams who product/maintain services)

@flyingzumwalt
Copy link
Author

FYI, there's a sketch of the existing and proposed WGs in the Working Groups Lifecycle Management document. That sheet uses the PWG/FWG distinction that I'm proposing to replace with "Teams" and "Working Groups"

@dignifiedquire
Copy link

Something I really enjoy and is helpful for keeping up with the work going on in different places is a newsletter like working groups in the rust world do, e.g: https://internals.rust-lang.org/t/the-embedded-working-group-newsletter-1/7053

Copy link
Member

@hsanjuan hsanjuan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My general feedback is that it would seem that teams come with obligations (in terms of project and product management) but with little rights or support.

I understand that teams can run their backyard pretty much how they like, organize their time, their sprints, adopt methodologies as they need, and, in practice, significantly steer project's direction (withing limits, but still), but this is not expressed.

In my wishlist, is also that if a Team is created, a project-manager should be allocated to it from a PM team. This PM should help the team focus, help write and curate their OKRs and help aligning with other teams. Teams should also be able to get access to other cross-team resources like Designers, Event managers or HR. This happens in practice, so it should probably be stated (with a safe-guard about being a best-effort thing and depending on available resources).

In general I think this is OK for as starting point statutes. I don't have fundamental issues (no-gos) with it.

- Working Groups occasionally define OKRs, but they don't have to define OKRs every quarter.
- Working Groups don’t necessarily subdivide when they get bigger. Unlike Teams, which are encouraged to form a tree of sub-teams when they grow bigger than ~5 people, Working Groups are able to convene larger groups of stakeholders.

### The Core Working Group
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suggest to change this to something else than Core, as Core has different meaning in Protocol Labs and this may lead to confusion.

Coordination working group, Steering commitee/WG etc. would be clearer

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

+1 (this was confusing for me as well)

2. Keep the Working Group lifecycle running smoothly
3. Keep the RFC process running smoothly, delegating the decision making to Working Groups whenever possible

### The Core Working Group is Responsible for
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This section is essentially a dup from the three bullet points right above.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also, I prefer the three bullet points because there is less to read.

- Core team can assign/delegate ownership of a product, library, spec, problem domain to a Team or WG, So that those groups can operate with clear mandates and healthy amounts of autonomy.
- In case of process failure or broken protocols among the teams, the Core Working Group is responsible for addressing the situation.
- They have the authority to institute short-term measures to address pressing problems/disputes
- They have the authority to fast-track RFCs that amend broken processes or protocols.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we can get a short list of what the Core working group cannot do, or things which are not among their prerogatives.

# Motivation
[motivation]: #motivation

## Size and Maturity of the Projects
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If all the text accompanying each of the motivation entries disappeared, and the Motivation section was just a list with 4 bullet points I wouldn't mind.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To clarify, there are 3 parts in this document:

  • A part to set a context and try to convince readers why it's good to do this
  • A part to explain concepts
  • A part to set rules

I think the first part (motivation) belongs more to the discussion than to the document itself. The document could have a pointer to it though.


We want Teams and Working Groups to emerge, function, and dissolve in response to community needs. To accommodate this, Teams and Working Groups are created using the RFC process -- people who want to form a Team or Working Group must propose it in an RFC and get that RFC merged. That open-ended invitation to create Teams and Working Groups is matched by clear protocols describing when and how working groups should be dissolved.

# Reference-level explanation
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The content in this section seems more like statutes, rather than an "explanation". It's basicly rules, so I'd adapt the title accordingly.


Another important goal of these changes is to create welcoming entry points for the community to subscribe to bodies of work and research. These entry points are curated by the Teams and Working Groups themselves. These Teams and Working Groups should serve the purpose of encouraging new users, engaging with them and enabling contribution as simply as possible.

# Guide-level explanation
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't fully understand what guide-level explanation means as a term at first sight. High-level overview? or simply Overview?

@hsanjuan
Copy link
Member

Ops, I looked into this without having seen #1 and realizing this is following an RFC template. It's weird because the "proposal to get governance structure" contains the implementation of it in the same document.

I guess the final Governance document should be separate from the RFC. In any case, take my comments in this light.

- What does success look like? If this Team or WG achieves its goals, what will the results be?
- Which other Teams and WGs will this group primarily interact with? Why? Have they expressed a need for it to exist?

### 2. Proposal (RFC)
Copy link

@ghost ghost May 11, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@flyingzumwalt I want to propose a libp2p Team, initially consisting of myself and Cole Brown. I also want to propose a libp2p Working Group consisting of the team as well as others who are part-time involved in libp2p development (like @vyzo or @Stebalien or @whyrusleeping or @diasdavid).

A couple problems I see:

  1. It seems weird that the libp2p team and WG's RFCs would be under the IPFS org, since we want libp2p to be an independent project at the same level as IPFS.
  2. There are not technically two Teams requesting a libp2p Working Group. I'm bending the definitions a little to allow libp2p to have a "Team" (in the sense of this RFC) and an "Extended Team" (a concept not addressed in this document but referring to a broader group of people with involvement in libp2p.

Thoughts on how I should approach this? Maybe libp2p is exceptional because it is trying to become its own project at the same level as IPFS. But I wonder how exceptional that really is.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are not technically two Teams requesting a libp2p Working Group

It would not be difficult to extract a request for a libp2p WG from go-ipfs Team, Cluster team, libp2p team, js-ipfs team and maybe some other, if you ask nicely :)

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i think that's just premature; i don't think it's wise having two newbies in the project running on their own.
Let bigs get acquainted with the codebase first.

In order to complete the formation of the Team/WG, in addition to getting members to sign on and allocate time, you must also:

1. Create a landing page for the group that lists its purpose, audiences, members, responsibilities, products and services. (This is often a landing page on a github repository dedicated to the group or its main product/service)
2. Add the group to the **[TODO] Full list of Teams and WGs**, grouped according to primary funnel
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[TODO] Full list of Teams and WGs

Where will this doc be located?

- Teams write higher-level OKRs that condense and summarize their OKRs so they can be
to percolated upwards
- Define how membership of Core WG will be updated over time
- One leading approach is for the captains of all top-level Teams to be automatically on the Core Working Group, but this runs a risk of the group getting too big when we form more Teams and Working Groups.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It should be fine as long we limit it to one person per WG (and ignore Teams).

- Note: In Rust, the leader of a WG must be part of the core team
- [ ] Define: How do OKRs percolate up from sub-teams?
- Some options:
- The objectives percolate up, becoming KRs in their parent group's OKRs list
Copy link

@lidel lidel May 14, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suspect it will be quite tricky to convert every child's Objective into a parent's KR. In my mind these are fundamentally different things and requirement for such systemic translation may introduce duplication and unnecessary overhead to the entire process. Not saying it can't be done, but the process will be lossy and fuzzy with unknown value added.

Personally I'd go with a rule of thumb stating there should be no "OKR translation"
(a Team writes OKRs that could be copied&pasted to WG sheet as-is).

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My understanding of OKRs was that they are defined top-down, see https://rework.withgoogle.com/guides/set-goals-with-okrs/steps/develop-team-OKRs/ also contains a discussion regarding the below bullet point on OKRs at leaves.

[drawbacks]: #drawbacks

Why should we *not* do this?
- If we don't set the right protocols for creation & dissolution of working groups, we will end up with a lot of confusion about who is responsible for what, meaning balls will get dropped, people will get frustrated, and productive time will be wasted.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I may be reading this wrong, but this just seems like another reason why we should do this?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"Why shouldnt you jump off this cliff?"
"If you don't jump off this cliff, you won't experience the amazing feeling of freefall!"

### 1. Design

Anyone can propose creating a Team or Working Group. In order to be considered, it must satisfy a number of basic conditions:
- A _Team_ **must have at least 2 people** whose **Full Time** efforts are primarily focused on that Team's work.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this the third time this is stated in this document? It would be great if this whole thing was much smaller and got to the point sooner.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants