- Description
- Existing Working Groups
- Development and Maintenance:
- Community
- Efforts to Support Specific Uses:
- Existing Research Groups
The IPFS Project is developed by multiple teams from multiple organizations and both intermittent and continuous invidividual contributors. A structure was developed (and continues to evolve) around Working & Research Groups, OKRs, and PM best practices that were designed to support the already large and growing group of people to coordinate among each other at a global scale.
This document captures the Team Structures that emerged and that led to the many of the sucesses within the IPFS project, namely: Working Groups & Research Groups. At the end of this document, you will find pointers to Teams and Projects that have grown to become their own entities, namely: IPLD, libp2p and Multiformats.
- Working Group - A cohesive team with measurable goals for each quarter. A Working Group needs to have a Captain, a set of people commited to it, and entry point repo and Objectives & Key Results defined per Quarter.
- Research Group - A set of people focused on exploring a specific vertical and output possible research surveys, tools, experiments, and other types of knowledge that can inform and help the work done by the Working Groups or spark the creation of new Working Groups all together.
Working Groups
Working Groups are teams of people that are appointed to research, develop, and deploy work under the working groups' scope. This structure is designed to provide clarity and direction to the project, enabling individual contributors to focus their time and energy on the areas they are most interested.
Each Working Group is free to experiment with setting their own pace, tracking work, and defining priorities. The only requirements are that the Working Group exposes its focus through OKRs to the rest of the org (common interface), that it assigns a Captain, creates an entry point repo and has at least 2 full time contributors dedicated to it.
Each contributor shouldn't carry responsibilities accross multiple working groups. This is not forbidden by any means but it is greatly discouraged as it will prevent the contributor from achieving full focus.
Research Groups
A set of people focused on exploring a specific vertical and output possible research surveys, tools, experiments, and other types of knowledge that can inform and help the work done by the Working Groups or spark the creation of new Working Groups all together.
Some great examples from this structure are: research-pubsub which led to the implementation of PubSub by the IPFS/libp2p teams; and research-crdt which lead to the creation of the Dynamic Data & Capabilities Working Group which todays tackles many of the challenges of building DApps on the distributed web.
A Research Group doesn't require a Captain or OKRs to be formed and having individuals that subscribe to multiple Research Groups isn't considered harmful.
A byproduct of both of these team structures achieves another important goal: making it easier for new users and contributors to subscribe to updates and get ramped up quickly to the current project focus.
- Coordination: https://github.com/ipfs/project
- Captain: David Dias
The IPFS Project Working Group Community serves as the point of coordination for the IPFS Organization.
Responsibilities include:
- Maintain the IPFS Project Roadmap and Vision.
- Provide coaching to Working Groups to develop their own planning and goal-setting.
- Facilitate communication and alignment accross the organization.
- Research, develop and build new ways to help async teams coordinate at scale.
- Recognize needs of the project and develop solutions to meet them.
- Coordination: https://github.com/ipfs/pm/blob/master/JS_CORE_DEV_MGMT.md
- Captain: David Dias
Develop js-ipfs.
Responsibilities include:
- Create the browser implementation of the IPFS Protocol.
- Coordination: https://github.com/ipfs/pm/blob/master/GOLANG_CORE_DEV_MGMT.md
- Captain: Jeromy Johnson
Develop go-ipfs.
Responsibilities include:
- Create the server and reference implementation of the IPFS Protocol.
- Coordination: https://github.com/ipfs/ipfs-gui
- Captain: Oli Evans
Making IPFS GUIs simple, accessible, reusable, and beautiful.
Responsibilities include:
- Fight complexity at every step.
- IPFS must be usable and comprehensible for everyone.
- Publish and promote this work. Make doing the right thing the easiest thing.
- Demonstrate the nature of the system with effortless, coherent, and compelling interfaces.
- Coordination: https://github.com/ipfs/ipfs-cluster
- Captain: Hector Sanjuan
The IPFS Cluster Working Group is the team implementing IPFS Cluster.
Responsibilities include:
- Design and implement IPFS Cluster.
- Provide knowledge and APIs that organizations with large data sets can use.
- Coordination: http://github.com/ipfs/infrastructure
- Captain: Erin Fahy
Tools and systems for the IPFS community.
Responsibilities include:
- Manage and maintain the IPFS HTTP Gateway.
- Manage and maintain the IPFS Bootstrapper nodes.
- Manage and maintain the IPFS pinning service, pinbot.
- Monitor services and hosts used by the IPFS dev teams.
- Provide wisdom to other users that want to host IPFS nodes.
- Coordination: https://github.com/ipfs/testing
- Captain: Victor Bjelkholm
The QA, Testing and Dev Team Enablement Working Group focuses on building developer tools, CI, and automated maintenance tasks to improve the developer experience of the many IPFS (and related) projects.
Responsibilities include:
- Enable developers to develop faster by reducing friction from dev.
- Upgrade and build dev tools (i.e AEgir and gx).
- Create a sound testing infrastructure for all the IPFS projects.
- Set the guidelines for writing, maintaining and managing codebases, test suites, and contributions.
- Define process and help achieve high quality sustainable open source modules.
- Automating tasks for things such as: release cycle, ensuring code quality, activity reports.
- Coordination: https://github.com/ipfs/community
- Captain: Mikeal Rogers
Community outreach working group. Coordinates the communities around events, blog posts documentation, automation and education.
- Evangelism (Events, Social Media)
- Editorial (Blogs, Documentation)
- Education (ProtoSchool, Demos)
- Automation (Probots, etc)
Responsibilities include:
- Help community members organize meetups for their own communities.
- Respond to requests for IPFS presence in conferences.
- Managing the official social media channels.
- Publish regular updates to the community (blog posts and newsletters).
- Create Tutorials and Workshops to teach concepts about IPFS and the Distributed Web in ProtoSchool.
- Ensure that public forums (discuss.ipfs.io, irc, github, etc) have adequate moderation and responsive support.
- Ensure that the code of conduct is followed and provide appropriate support or response when violations occur.
- Author and improve documention.
- Coordination: https://github.com/ipfs/in-web-browsers
- Captain: Marcin Rataj
The Integration with Web Browsers Working Group designs and implements browser integrations, web extensions, service workers and any other strategy that contributes to IPFS being integrated with the web today.
Responsibilities include:
- Browser integrations (Firefox, Chrome, Brave and others).
- IPFS Web Extension.
- IPFS Service Worker.
- IPFS Web Worker.
- Collaborate with with browser vendors.
- Identify blockers and design constraints of each integration, figuring out new ways to go around those limitations.
- Increase the adoption of the distributed web by making it easy for users to access it.
- Define specifications for address schemes and advocate for those schemes to be adopted.
- Coordination: http://github.com/ipfs/dynamic-data-and-capabilities
- Captain: Pedro Teixeira
Research and development of building blocks that enable collaborative applications, providing solutions for security, identity, access control, concurrency, synchronization, offline, and near-real-time collaboration. This WG was born out of the results created by the CRDT Research Group.
Responsibilities include:
- Research and implement CRDTs on top of IPFS, creating building blocks that can be used by other applications.
- Research Cryptographic ACLs (Capabilities Systems) and create building blocks to implement them.
- Apply this research and implementation to products like PeerPad, validating the solutions and defining new problems to be solved.
- Coordination: https://github.com/ipfs/decentralized-data-stewardship
- Captain: Michelle Hertzfeld
User research, collaborations, and products that support holding data together on decentralized networks.
Responsibilities include:
- Participate in groups such as Data Together
- Conduct user research around managing large volumes of data on IPFS
- Support collaborations between IPFS and community members who need to manage large volumes of data
- Research and prototype policy layers for just and inclusive data stewardship on decentralized networks
The list of existing research groups is: