Giter Site home page Giter Site logo

richardwlaub / docs Goto Github PK

View Code? Open in Web Editor NEW

This project forked from pulumi/docs

0.0 3.0 0.0 26.19 MB

Documentation for all things Pulumi!

Home Page: https://pulumi.io

HTML 12.10% Dockerfile 0.15% Ruby 1.35% Makefile 1.32% CSS 48.95% TypeScript 4.79% JavaScript 7.90% Shell 5.82% Go 17.63%

docs's Introduction

Pulumi Documentation Site

"Because knowing is half the battle."

Staging Production
Build Status Build Status

Contributing

Before adding new content, read CONTRIBUTING.md.

Toolchain

The website is statically built using Jekyll. So we have basic templating for generating HTML and the ability to write most files in Markdown.

TypeScript documentation is generated directly from source using TYPEDOC. We just check the resulting files directly into the repo under ./packages/.

Development

Prerequisites

  • Install a recent version of Ruby
  • Install the necessary Ruby Gems: gem install jekyll bundler
  • Install a recent version of Go
  • Install mustache: go get -u github.com/cbroglie/mustache

Run make configure to get the required Gem dependencies. (Assuming you have a recent Ruby installation on your system.

make build will generate the website (published to _site).

make serve will build the website and serve it to http://localhost:4000.

make docker will run build and serve in a docker container with all prerequisites installed.

make test runs a broken link checker tool against http://localhost:4000.

make generate will regenerate the TypeScript documentation if needed, as well as the CLI documentation in references/cli. The generated API documentation is placed in the packages folder. This is extremely hacky.

The following repos must be peers of docs, should be checked out to an appropriate branch, and should be built before running make generate:

  • pulumi
  • pulumi-aws
  • pulumi-azure
  • pulumi-cloud
  • pulumi-gcp
  • pulumi-kubernetes

Generating a change log

To generate a change log from closed pull requests, run the script /scripts/generate_changelog.sh. It generates a file using the rules documented here: Planning, Work Items, and Changelog.

  1. Run ./scripts/update_repos.sh to pull down the latest tags for the repos pulumi, pulumi-cloud, pulumi-aws, pulumi-terraform, and pulumi-azure

  2. Set the environment variable GITHUB_TOKEN to a token that has "repo" scope.

  3. [Will be improved] Clone the repo at https://github.com/pulumi/github-pr-changelog and run npm i -g to globally install the command gh-changelog.

  4. Generate a change log with the following command:

    ./scripts/generate_changelog.sh <from-git-tag> <to-git-tag> > output.file
    

    You can also use the optional flags --all-prs to print out all PRs (not just ones with the relevant labels) and --tab-output to print in a format that can be pasted to a Google Sheet.

Deploying updates

When changes are merged into master our staging website (https://staging.pulumi.io/) is automatically deployed. You can use the Travis UI to check on the status of the deployment. Once it has been deployed, browse around the staging website and ensure the changes you expected were made and render correctly. Then, open a Pull Request to merge master into production.

Design Reference

Web design is hard. Documentation is hard. Good web design for documentation is harder.

Examples of other sites and their docs as inspiration:

Creating shortlinks

Shortlinks can be created as a permanent reference to documentation that may move around in the repo. This is particularly useful for troubleshooting links that are produced by CLI tools.

To create a shortlink, create a file under /shortlinks in the following format:

---
redirect_to: <link-to-current-docs-page>
permalink: <unique-6-character-shortlink>/
---

You can use the scripts/create_short_url.sh script to generate a new random shortlink:

./scripts/create_short_url.sh /reference/troubleshooting#ingress-status-loadbalancer ingress-status-loadbalancer

Created shortlink definition at <filepath>/ingress-status-loadbalancer.md
https://pulumi.io/xdv72s --> https://pulumi.io/reference/troubleshooting#ingress-status-loadbalancer

or you can choose a shortlink:

./scripts/create_short_url.sh /reference/troubleshooting#ingress-status-loadbalancer ingress-status-loadbalancer help/ingress-lbstaus


Created shortlink definition at <filepath>/ingress-status-loadbalancer.md
https://pulumi.io/help/ingress-lbstatus --> https://pulumi.io/reference/troubleshooting#ingress-status-loadbalancer

Here is a concrete example:

---
redirect_to: /reference/troubleshooting.html#ingress-status-loadbalancer
permalink: xdv72s/
---

With the above file in place, a redirect will be created from https://pulumi.io/xdv72s to https://pulumi.io/reference/troubleshooting.html#ingress-status-loadbalancer

Note that the trailing / on the permalink is required!

docs's People

Contributors

joeduffy avatar lindydonna avatar chrsmith avatar lukehoban avatar ellismg avatar justinvp avatar hausdorff avatar swgillespie avatar mehzer avatar cyrusnajmabadi avatar lblackstone avatar pgavlin avatar ericrudder avatar frassle avatar tirke avatar cnunciato avatar praneetloke avatar scty-tpaoletti avatar octocruise avatar clstokes avatar wilsonmar avatar swasifali avatar shanemcd avatar robertbullen avatar houqp avatar pbzdyl avatar jonparker avatar twpol avatar jen20 avatar efleming18 avatar

Watchers

James Cloos avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.