You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 32 Next »

Tasks to be completed

  • Determine The Current Status of all Projects/Tools/Libraries
  • Examine the current process used for documentation
  • Create Standards / Best Practices for Community
  • Create Documentation Best Practice badging system.

List of deliverables or work products

  • Survey For Maintainers and Community
  • Report on Current Documentation processes used.
  • Create Recommendations for community
  • Create Badging process
  • Create templates and guides for achieving badge.

Time to complete

6 months (End 8/28/22)

Leader

Ben W

Initial participant list

Ben W
Bobbi M
John C

Chat Channel

https://discord.com/channels/905194001349627914/943951538345377832

References

TASK FORCE NAME: Documentation Standards

Creation Date
2/28/22

To Do:

Complete survey

Alert Dev newsletter

Decide on the date to present to TSC

Recommendations

TASK FORCE RECOMENDATIONS:

GAPS AND OPPORTUNITIES

IDEAS:
       Scorecard: make 
sure each project is advancing and implemented guidelines across projects: example of scorecard https://github.com/ossf/scorecard
       Badging: one time badging with yearly review

TASKS



This Review focuses on a variety of documentation for the HyperLedger Fabric project, as a case study indicative of how other pages might be standardized. This initial commit is a fact finding mission with generalized conclusions. These conclusions should be discussed, edited and converted into direct action items. This is not an exhaustive review, but an initial fact finding summary. It is mean to foster open discussion and create a place for new ideas on the betterment of Hyperledger project documentation. 

Main Recommendations

  • Current / Future Hyperledger Projects should utilize the documentation pattern found on the Fabric documentation sources. 
  • The Fabric documentation pattern is as follows: ReadtheDocs exists as the main source of non-code truth, GitHub for all code truth, and a Hyperledger Wiki page for Community related items and badging. 
  • All Projects can leverage Discord: include or “pin” documentation relevant posts. (currently all are not pinned) 
  • Re-factor all documentation content to adhere to the various sources of truth in the Fabric documentation pattern. 
  • Standardize graphics across all documentation, especially in the ReadtheDocs
  • Harmonize the Read the Docs- especially in the glossary section for concept lookups and graphical standardization. 
  • Graphics are present in the Read the Docs page, but not present in the glossary- would be a “nice to have” to complete the glossary section. 

Hyperledger Fabric Documentation 

HyperLedger Fabric  documentation can be found in a variety of sources, depending on your use case. Here are the main documentation standards: 

  1. HyperLedger Fabric Read the Docs: https://hyperledger-fabric.readthedocs.io/
    • Designed for Multiple Audiences: Developers and Business Professionals
    • Generally follows topical organization with bullet points 
    • Has code, helpful imagery, written explanations 
    • Sorts concepts into tutorials, very comprehensive spread of information 
    • Doesn’t include source code files, at times will link to GitHub files for more detail
    • Some areas are informative, rich knowledge base
    • Use Cases area could be more informative (Recommend re-fresh / re-formatting of both pages, especially wiki page. currently just links to hyperledger wiki) 
  2. HyperLedger Fabric Main GitHub page: https://github.com/hyperledger/fabric
    • Designed for developers: whether smart contract, application or enterprise blockchain developers 
    • Has a Readme file for general information, versioning, installation 
    • Links back to the HyperLedger Fabric Wiki 
  3. HyperLedger Fabric Wiki: https://wiki.hyperledger.org/display/fabric
  4. HyperLedger Fabric Discord Documentation Channel: https://discord.com/channels/905194001349627914/945038395825070141
    • The Discord channel is designed for asking and answering questions, fostering discussion regarding HyperLedger Fabric Documentation 
    • Not a single source of truth for any audience, however helpful for business, developer or community members 
    • Lots of useful links, but nothing is pinned for quick access
    • As Discord becomes bigger, “pinning” will be eminently helpful 
  5. HyperLedger Fabric LandScape Page: https://landscape.hyperledger.org/projects?selected=hyperledger-fabric 
    • The LandScape Page holds notable metrics, badging, links and an aggregate of the Fabric Twitter Page
    • Metrics include the programming languages used, and the number of recent commits.
    • The links include a comprehensive list of the various Fabric GitHub repositories 
    • The Twitter aggregate section includes the latest 3 tweets from the Hyperledger Foundation

Some Key Conclusions:

Most current Fabric links point to the Read the Docs page as the source of truth. Thus it should be considered the de facto standard in a general sense. Fabric uses Read the Docs as the main source of truth for descriptions, GitHub as the source of truth for Code, and the HyperLedger Wiki page as the source of Truth for community related items. Projects should be customized as required. But some information in Fabric is spread out over multiple pages.  Thus, it would be more efficient to be grouped by audience for easier readability. For example, some details are on the wiki page that aren’t on Read the Docs- and vice versa. Use of graphics on the Read the Docs is sometimes inconsistent. The TaskForce could hone in on any existing inconsistencies in style, graphics, tables, bullet points, readability, links, and content usefulness for all projects to better serve future and current HyperLedger projects. 


Comparison of Fabric Vs. Besu Documentation


This comparison is an initial analysis of the level of standardization between the Hyperledger Fabric Vs. Besu ReadTheDocs. ReadtheDocs was chosen because the ReadTheDocs is main source of documentation truth, and most deep in knowledge / helpfulness. 

Key Takeaways: 

    • Besu introduces itself as a product first, whereas Fabric introduces blockchain before a product introduction. 
    • Should we standardize this? Should we introduce the product or concept? 
    • Recommendation: Plenty of space in the ReadtheDocs for conceptual resources, let’s introduce the product first. (technical documentation typically assumes the developer knows the fundamentals)
    • FAQ style Vs. Concept style. Besu uses FAQ, Fabric conceptual. 
    • Practical Vs. Theory: Besu very quickly is practical. Fabric documentation puts you through lots of theory before set-up steps. 
    • Main structure: Fabric is structured much differently from Besu. 
    • Audience: Even though the Besu documentation is deep and thorough, it is noticeably simpler in structure for a first-time user. 
    • Social Media: Besu main page is lacking social media links, and Fabric displays them- particularly the Discord is important for community engagement. 

Comparison of Fabric Vs. SawTooth Documentation

This comparison is an initial analysis of the level of standardization between the Hyperledger Fabric Vs. SawTooth ReadTheDocs.  

The terminology used between the two varies: while both begin with a key concepts / key terms introduction. Fabric emphasizes the idea of a Blockchain, while Sawtooth emphasizes the idea of a distributed ledger. While every blockchain uses a distributed ledger system, not all distributed ledgers conform to the characteristics of a blockchain. Therefore greater clarity may be gained if all documentation emphasized blockchain as the standard starting point, which utilizes practices related to distributed ledgers. 

Key Takeaways: 

  • No standard navigation style or layout exists between Fabric and Sawtooth. Each project has a different look and feel to their ReadtheDocs
  • Layout and conceptual navigation is different between the projects: this could lead to slower development and adoption
  • Both Fabric and Sawtooth emphasize concepts first, instead of a QuickStart or rapid development deployment project example
  • Fabric has a much deeper conceptual dive into blockchain concepts, while Sawtooth has an initial conceptual dive. 
  • Code formatting looks cleaner and more legible on Fabric Documentation. 
  • Sawtooth begins with a Glossary, Fabric ends with a Glossary. (Should be consistent between the two.) 
  • The Sawtooth documentation may be outdated and require an update to conform to the latest release (per Hardik) 

Comparison of Fabric Vs. Cosmos Documentation

This comparison is an initial analysis between the Hyperledger Fabric documentation and the Cosmos Blockchain documentation.  

Both Cosmos and Fabric begin with a key concepts / key terms introduction. Fabric emphasizes the idea of an Enterprise level Blockchain, while Cosmos emphasizes the idea of application-specific blockchains.  

Key Takeaways: 


  • Cosmos has an updated / web3 look and feel to the UI. 
  • Landing page comparison: Cosmos provides a direct and immediate choice between conceptual and Quickstart / Developer Tutorials.
  • Introduction comparison: similar themes addressed: history, backgrounder, orientation to product
  • Key Concepts: both start with Key Concepts: blockchain, smart contracts, etc. Fabric is more comprehensive from a conceptual standpoint. 
  • Cosmos documentation assumes the audience knows blockchain basics, whereas Fabric is more newcomer friendly. 
  • Tutorials comparison: Fabric are built-in, while the Cosmos tutorials takes me to an entirely new page, new UI, new layout. (not user-friendly) 
  • Cosmos Tutorials means data is duplicated, developer has to start from scratch. 



Review of ReadtheDocs Syntax, Sphinx, and reStructured Syntax

This section highlights some of the syntax, capabilities and limitations of the ReadtheDocs structure. This is salient because the documentation of various Hyperledger projects relies on the ReadtheDocs platform. 

ReadtheDocs Highlights: 

  • Hyperledger documentation on ReadtheDocs is populated by files from the various Hyperledger project GitHub pages
  • Those GitHub pages are synced with the ReadtheDocs platform and Pull Requests sync up to an index.rst file
  • The index.rst file, as the extension might imply, is built upon Sphinx and reStructured syntax. (RST stands for reStructured) 
  • Sphinx and reStructured have their own syntax, formatting and are designed specifically for formatting documentation 

ReStructured Text: 

  • reStructured is not a full fledged markdown language, but does allow for some customization 
    • Myriad options for text formatting is available 
    • images and images with hyperlinks are available 
    • various themes are available
    • backgrounds for code snippets like dark mode are available 
    • Tables, References / Bibliographic citations and a Table of Contents are available 

What is an RST file? Here is an RST Example from Hyperledger Fabric: 


Sphinx 

Sphinx allows for customization of themes, they can be found here. Should they be standard for all projects? 


Proof of Concept for ReadMe: 

A POC was performed for ReadtheDocs using the tutorial found here. Was to ensure that certain features that are in the web3 community may be applicable to Hyperledger projects. It was found that features are available but ReadtheDocs relies on third-party plug ins and that deeper / more web3-style layouts would require customization work. 

POC Key Takeaways: 

A Proof of Concept / Tutorial Page to dive into the customization options and reStructured Syntax for a ReadTheDocs page.

  • A GitHub Repo was created for a POC of ReadtheDocs functionality
  • Linked up Github with ReadtheDocs so that a Pull Request syncs to the documentation page
  • ReStructured Text Syntax was utilized to test image-based button linking 


Image: pull requests sync easily to the Sphinx platform. 


POC Next Steps / Future Work: Custom CSS and JS 


We can change, or add a common theme to all pages. Currently some pages use standard themes (Ex: Fabric) while others use custom themes (Ex: Besu). 

Apparently, Sphinx can also support custom CSS and JS- thus further customization could be performed. However, the caveat being that this customization would need to be synced up between projects. If different projects used different layouts, functionality it defeats the purpose of standardization. 



Questionnaire For Hyperledger Documentation 

This questionnaire is meant to promote discussion regarding layout, accessibility, features and use-cases around Hyperledger documentation. 


Questionnaire: Hyperledger project documentation 

What features are most relevant to your project documentation page? 

  1. Quick Start / Example Projects 
  2. Key product features and functionality 
  3. The ability for the user to spin up an instance 
  4. All of the above 


What visual layout or aesthetic style is the best choice for your Hyperledger documentation page? 

  1. Simple, plain visual layout 
  2. A current / modern look and feel 
  3. Visually stunning layout with more color options 
  4. Visual Layout is not relevant to my documentation page


Are there any features you would like to add to your project documentation page? 

  1. Buttons to allow for ease of use 
  2. Tables, graphs, charts or explanatory design documents 
  3. Styling, aesthetic or layout features 
  4. Social Media links / Hyperledger community links 
  5. None of the above
  6. All of the above 


How important are unique style elements to your project for documentation usage? 

  1. Uniqueness is very important for product adoption
  2. Medium amount of importance 
  3. Not very important, end users don't need unique style for documentation usage


Are there any features you would like to remove from  your project documentation page? 

  1. Yes, I would remove some features 
  2. No, the documentation has no extraneous data 


What content do you think is most important on a documentation page? 

  1. Introduction to the actual product itself 
  2. A Quick Start / Example Project 
  3. Key Concepts (section / paragraph style explanations) 
  4. Glossary of  Key Terms 
  5. Code Snippets / Code Examples 
  6. All of the above 


Where you like your project documentation to be stored? 

  1. Readthedocs (current platform) 
  2. Another documentation platform 
  3. I don’t have a preference 


What layout do you prefer for your documentation landing page? 

  1. Small concepts that link to details 
  2. Many concepts that comprehensively reflect the project
  3. No preference as to layout 


From an end-user experience, do you think your page  is visited by mostly one or more of the following? 

  1. Business-facing users / General purpose users
  2. Developers / Technical Users 


How much customization do you prefer for your documentation? 

  1. Plain, not much customization
  2. A bit, but generic themes are ok 
  3. I want in depth personalization and customization 


How important are charts, graphs, and other visual documentation components? 

  1. Very important for product adoption
  2. Medium amount of importance 
  3. Not very important 


Does your documentation page include Provide alt text or descriptions for non-text content (images)? 

  1. Yes our page is fully accessible to persons with disabilities 
  2. No, upgrades or additions can be made to img tags with alt text
  • No labels