Mondays at 15:00-15:30 UTC / 4:00-4:30 pm BST / 7:00-7:30 am PST
๐ Zoom: https://protocol.zoom.us/j/568955431
๐ Notes from past calls can be found here.
๐ฌ Video recordings of past calls can be found in our YouTube playlist.
This repo is used for two purposes:
- To organize overall documentation work across the IPFS project
- To host the documentation website for IPFS, available at https://docs.ipfs.io/
Based on feedback from the community via social media, forums, this repo, IPFS Camp 2019, and a variety of other sources, we're placing increased emphasis on improvements to our overall documentation strategy (and its tactical implementation!) in Q3 2019.
IPFS documentation currently has a number of acute problems:
- There is no clear introduction to the overall idea of what IPFS does, how it works or why it's useful -- starting with "civilian" dweb basics and allowing users to dig deeper as they wish.
- IPFS has lots of new concepts that are just very different from the web technologies people know today; even if you're well versed in some of technologies central to IPFS, chances are good that you don't know them all, or understand right off the bat how they need to work together.
- Developer docs are inconsistently located and spread across a number of repos users have to hunt through.
- Clear, standard API docs are not always available.
- People are motivated to use IPFS for a variety of reasons, but our docs don't yet offer clear goal-based pathways for installing or learning more.
- In our open-source world, how to use IPFS is not always clearly differentiated from how to contribute to IPFS; we need to offer materials targeted for both users and contributors of varying degrees of expertise as IPFS expands in scale, scope and maturity.
We already have some substantiative research, including user interviews, that help us quantify the problems outlined above. In Q3 2019, we plan to use this body of knowledge, as well as additional work mentioned below, to formulate and begin execution upon an overall IPFS documentation approach that will benefit users in both the short and long term.
You can also view our progress against these in the IPFS-wide OKR (Objectives and Key Results) tracking document, or filter this repo's issues for ones with the OKR
label.
- Evaluate existing IPFS documentation content and presentation platform and make decisions for future-proof improvement and alignment
- Complete a content audit of existing ipfs.io material and use to prioritize next steps
- Create prioritized features list for a best-in-breed IPFS docs platform based on competitive-landscape and analogous product/service research, as well as community feedback
- Determine best-fit tech stack/framework for the IPFS docs site
- Better understand our users and their needs, and use this knowledge to prioritize improvements
- Complete the creation of ranked, goal-based personae for key IPFS user segments
- Ensure appropriate resourcing in order to execute upon results of content audit, features list, user suggestion, or other asks
- Improve existing docs content in the short term, with emphasis on collecting metrics
- Implement hotfixes for either content or metrics collection as they emerge from content audit, features list, or user suggestion
- Add interactive "so you'd like to ..." content on the front of ipfs.io (including analytics) with appropriate guidance for users' next steps
- ProtoSchool-specific enhancements related to improved analytics and user feedback collection
While we're making every effort to create a comprehensive plan for our overall documentation strategy in Q3 2019, that doesn't mean any pause in overall work in IPFS docs -- and to that end, we would love โค๏ธ your help with any of the types of content currently on the IPFS docs site:
-
Introductory overview. This lives in
content/introduction
. If you spot any problems, or have ideas for improvements, please post an issue or PR. We're also in the midst of a complete rework of the overall IPFS explainer, so please check its progress! -
Examples and tutorials. At present, most examples currently live in other repos, like js-ipfs examples. We're working on how to better integrate these, but if you have thoughts on how to best address this, please file an issue here. If you have feedback on an existing example, please file an issue or PR in that example's relevant repo. However, if you have ideas for new guides or tutorials, please file an issue in this repo!
-
Concept guides. Concept guides (which live in the
content/guides/concepts
folder) are intended to present brief overviews of IPFS-related concepts that might be new to the average user. To see which concepts still need guides, please visit this list. All concept guides should focus on the following key points:- What is this concept?
- How does it relate to the rest of IPFS?
- How can (or should?) you use it?
- Where do you go to learn more?
- What is the current state of work on this concept?
-
Reference/API Documentation. Please see the open issues in this repo for current activity around reference and API documentation.
-
Community. The Community section of docs.ipfs.io is a work in progress, and we welcome ideas for how best to structure this information going forward! Please file an issue in this repo with your thoughts.
-
Any other issue in this repo with a "help wanted" label!
If you are able to contribute to any of the categories above, we thank you -- your work directly improves the future of IPFS for the global community! Before posting a PR with your changes, please be sure to check our documentation style guide and the overall IPFS contributor guidelines so we can ensure that docs are clear, consistent, and simple to read. Finally, please make sure to follow the IPFS code of conduct.
-
Install AEgir
npm install -g aegir
-
Download dependencies and IPFS libraries (e.g. go-ipfs, js-ipfs) and generate their documentation:
make install
This installs dependencies and generates source files from other projects (e.g. API documentation; theme resources from the
ipfs-css
, etc).When dependencies or external packages (like
go-ipfs
) have new releases, you should regenerate files based on them by runningmake resources
.
- In the root directory, run
make dev
- Load http://localhost:1313 in your web browser
- Edit and add things!
To create a production build, run make build
instead. Youโll find the final static site in the public
directory.
We believe in hosting IPFSโs documentation on IPFS, and thatโs much easier when the content is static.
All software code is copyright (c) Protocol Labs, Inc. under the MIT license.
Other written documentation and content is copyright (c) Protocol Labs, Inc. under the Creative Commons Attribution-Share-Alike License.
See LICENSE file for details.