1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00
🐍 Ocean Protocol's official documentation https://docs.oceanprotocol.com
Go to file
2018-11-20 15:49:41 +01:00
content update test doc, document repositories.yml links usage 2018-11-20 15:49:41 +01:00
data Moved 'Engineering Principles' under CONTRIBUTE 2018-11-18 09:33:45 +01:00
external switch to master of dev-ocean 2018-11-16 17:53:42 +01:00
scripts new beta url 2018-11-16 17:39:13 +01:00
src output additional links on all repos 2018-11-20 15:39:53 +01:00
static more plugins 2018-11-09 22:59:22 +01:00
.editorconfig setup markdownlint 2018-11-12 12:45:55 +01:00
.env.sample copy updates 2018-11-11 04:02:34 +01:00
.eslintrc drop da base 🍾 2018-11-07 12:33:32 +01:00
.gitignore .env tweaks 2018-11-10 19:49:44 +01:00
.gitmodules spacing 2018-11-16 17:56:29 +01:00
.markdownlint.json lint & format 2018-11-12 12:52:39 +01:00
.prettierignore ignore external docs for linting 2018-11-14 15:46:30 +01:00
.prettierrc drop da base 🍾 2018-11-07 12:33:32 +01:00
.stylelintrc add stylelint, lint & format tasks 2018-11-10 15:05:35 +01:00
.travis.yml install awscli on Travis 2018-11-16 11:19:43 +01:00
config.js make edit link work for external repo contents 2018-11-15 23:51:12 +01:00
docker-compose.yml add Docker 2018-11-10 14:47:09 +01:00
Dockerfile add Docker 2018-11-10 14:47:09 +01:00
gatsby-browser.js switch syntax theme 2018-11-09 22:14:20 +01:00
gatsby-config.js fix for retina screenshots 2018-11-16 18:17:29 +01:00
gatsby-node.js make it clear we query whole dev-ocean repo 2018-11-16 14:52:42 +01:00
LICENSE Initial commit 2018-11-07 11:01:48 +01:00
package.json setup deployment 2018-11-16 11:12:28 +01:00
README.md update test doc, document repositories.yml links usage 2018-11-20 15:49:41 +01:00

banner

docs

🐍 Ocean Protocol's official documentation.

Build Status js oceanprotocol css bigchaindb code style: prettier Greenkeeper badge


These docs are meant to be viewed on docs.oceanprotocol.com. You can still browse them here but links or images might not work in some places.

If you want to contribute to these docs, then keep reading.


Content

The documentation is split in multiple sections whose content lives in this repo:

  • Core concepts: high-level explanation of concepts, assumptions, and components
  • Setup: getting started for various stakeholders and use cases
  • Tutorials: detailed tutorials

Those sections are defined in the /data/sections.yml file.

Content Files

Some content files live in the /content & /data folders, and is written using Markdown and YAML.

That content is organized into subfolders corresponding to the sections mentioned above. The subfolder names, along with the filenames, define the final URL of a given piece of content.

The final navigational organization of the content is driven through the sidebar files under /data/sidebars.

Some global values used throughout the site can be set in config.js.

External Content Files

Additionally, some content files live in other repositories and are maintained there. They are pulled into the site at build time.

At the moment, this is setup for the following repositories:

For including a document from any of the above repositories, 4 values are required in a document's YAML frontmatter. If found, a page will be generated automatically, accessible under the defined slug.

This will NOT include this page in the doc's sidebar navigation, this needs to be done manually in the docs repo in one of the sidebar files. This is so you can check out everything before exposing it to visitors, and to ensure editorial workflow of the categorization.

TODO: In a later stage, we will include more documentation in this site, e.g.:

  • API references
  • Component docs
  • Maybe more

Markdown File Requirements

All Markdown files should use GitHub Flavored Markdown and must satisfy some extra requirements:

  1. The file must begin with a section called YAML frontmatter that looks like this:

    ---
    title: This is the Title in Title Case
    description: A short description of the page.
    ---
    
    Markdown content begins here.
    

    For external documents in other repos, defining the slug and section is required:

    ---
    title: This is the Title in Title Case
    description: A short description of the page.
    slug: /concepts/architecture/
    section: concepts
    ---
    
    Markdown content begins here.
    

    Note: The description value will be rendered on-page below the title, and it will also be used for description tags in the HTML head.

  2. Don't include the page title or description in the Markdown section. That is, don't begin the Markdown content with # This is the Title in Title Case. Just write as if that were already there.

  3. start your heading levels with h2, so ## My heading

  4. Internal links to other docs pages should be:

    • to a absolute URL without the host, that looks like /concepts/terminology/ with slashes on the beginning and end, and with no .md or .html at the end (before the last slash).
    • when linking from external repos, to the full absolute URL, such as https://docs.oceanprotocol.com/hello/you-are-awesome/
  5. no TOC please, this will be generated automatically from all headings

  6. for images and media, you can keep them in the original repo. Images will be automatically grabbed by the docs site on querying. When doing that, docs site will generate all sorts of image sizes to handle proper responsive images, so no need to keep an eye on image dimensions or file sizes

Have a look at docs.oceanprotocol.com/test/ to see what content elements can be used in all markdown files included in docs site.

Adding Docs

  1. Add new Markdown file under one of the folders under /content
  2. Add new path to one of the sidebars in /data/sidebars
  3. ...

Editing Docs

Every article on docs.oceanprotocol.com ends with an Edit this page on GitHub link. Clicking that will put you to the right place in the repository from where you can hit the Edit pencil icon on GitHub.

GitHub will automatically fork the repository if you are not part of the oceanprotocol organisation on GitHub. Members can simply push to a new branch on the original repo.

The editing workflow is as follows:

  1. Make your changes
  2. Push your changes to a new branch in the repo, or in your fork
  3. Open a pull request against master, automatically asking for review
  4. Wait for review, possibly make requested changes
  5. Wait for all checks to pass
  6. Merge!

Repositories

The repositories list is currently sourced from the /data/repositories.yml file, defining the grouping, the display order, and which repos to include.

Including a repo requires only the name key and value, and it needs to be exactly the same as the repo name on GitHub:

- name: pleuston

Additional information about a repo will then be fetched automatically via GitHub's GraphQL API on build time, and re-fetched every 5 minutes on client side. You can also add a private repo to prepare for a release, it will show up as soon as it is made public on GitHub.

The above example will result in:

screen shot 2018-11-10 at 22 43 41

This repository component can also be used within any Markdown content like so:

<repo name="pleuston"></repo>

Additionally, you can attach multiple links to a repo. The GitHub link is automatically added for every repository and will always be displayed. Add more links like so:

- name: keeper-contracts
  links:
    - name: Documentation
      url: https://github.com/oceanprotocol/keeper-contracts/tree/develop/doc

in /data/repositories.yml. The links defined in this file will also be used to enhance the display of the repository component on all other pages.

Development

The site is a React app built with Gatsby.

This Git repo has Git submodules. They are the subdirectories of external/. Each one is basically another Git repo, i.e. an external Git repo that just looks like it's part of this Git repo. It's very easy to get Git into a confusing state when there are submodules. If you follow the following tips, you should probably be okay:

  1. Clone this repo using:

    git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
    
  2. Don't edit anything in the submodules (i.e. in external/). Instead, edit it over in the other Git repository and merge your changes over there.

  3. Get all the submodules up-to-date using:

    git submodule update --remote --recursive
    

    That will get each submodule up-to-date with the HEAD commit of some branch in a remote repository. Which branch? That's set in the .gitmodules file. You can check the current commit hashes of all the submodules using git submodule status

  4. Before doing any git checkout ... or other normal Git operations, do this:

    git config --global submodule.recurse true
    

    That's like adding the --recurse-submodules option to all those Git commands (except for git clone) so you don't have to.

Using npm

As a prerequisite, you'll need the following on your machine:

Clone this repo, install all dependencies, and start the development server:

git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
cd docs/

# add GITHUB_TOKEN
cp .env.sample .env
vi .env

npm i
npm start

This will start a hot-reloading local server exposed under localhost:8000.

Using Docker

Alternatively, you can use Docker for which you need to have installed on your machine:

Then use Docker Compose to bring everything up:

git clone --recurse-submodules git@github.com:oceanprotocol/docs.git
cd docs/

# add GITHUB_TOKEN
cp .env.sample .env
vi .env

docker-compose up

This will expose a hot-reloading server under localhost:8000.

Linting & Formatting

To enforce a consistent code style, linting is setup for pretty much every file. Linting is part of the test suite, meaning builds on Travis will fail in case of linting errors.

In this repo the following tools are setup for that:

# only run linting checks
npm run lint

# auto-formatting of all js, css, md, yml files
npm run format

Editor Setup: VS Code

If you use VS Code as your editor, you can install those extensions to get linting as you type, and auto-formatting as you save:

GitHub GraphQL API

The GitHub GraphQL API integration is done through gatsby-source-graphql and requires authorization.

An environment variable GITHUB_TOKEN needs to present, filled with a personal access token with the scope public_repo.

For local development, you can simply create a personal access token and use it in your local .env file:

cp .env.sample .env
vi .env
# GITHUB_TOKEN=add_your_token_here

When running the site locally, you can use the GraphiQL client running under localhost:8000/___graphql to explore the whole GraphQL layer of the site (not just the GitHub infos).

screen shot 2018-11-10 at 18 41 45

This query should get you started to explore what information you can get from GitHub:

query {
  github {
    organization(login: "oceanprotocol") {
      repositories(first: 100) {
        edges {
          node {
            name
            description
            url
          }
        }
      }
    }
  }
}

Deployment

Automatic deployments are triggered upon successful tests & builds on Travis:

The deploy command simply calls the scripts/deploy.sh script, syncing the contents of the public/ folder to S3:

npm run deploy

Requires authorization against AWS with one of the various ways, on Travis this is done with those environment variables:

  • AWS_ACCESS_KEY_ID
  • AWS_SECRET_ACCESS_KEY
  • AWS_DEFAULT_REGION

Authors

License

Copyright 2018 Ocean Protocol Foundation Ltd.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.