We encourage contributions from the community.
Create a GitHub issue for any changes beyond typos and small fixes.
If you do create a pull request (PR), please follow our style guidance.
We review GitHub issues and PRs on a regular schedule.
To ensure that each change is relevant and properly peer reviewed, please adhere to best practices for open-source contributions. This means that if you are outside the Temporal organization, you must fork the repository and create PRs from branches on your own fork. The README in GitHub's first-contributions repo provides an example.
The Temporal documentation site uses Docusaurus 2, which is a static website generator.
You can make changes locally without previewing them in the browser. However, if you want to build the site and preview changes in the browser, do the following:
-
Install version 16 or later of Node.js. (On a Mac, use the command
brew install node@16
.) -
Download the repository and install dependencies with
yarn
:git clone https://github.com/temporalio/documentation.git cd documentation/ yarn
-
Now you can build and view the site locally:
yarn start
This command starts a local development server and opens a browser window to localhost:3000.
In the documentation files, snipsync snippets appear like this:
<!--SNIPSTART typescript-hello-client -->
<!--SNIPEND-->
To preview snipsync snippets, run yarn snipsync
, which inserts the snippet contents (in this case, from samples-typescript
) between the SNIPSTART
and SNIPEND
tags.
Before committing, run yarn snipsync --clear
to remove the snippets.
Before submitting a PR, use Prettier to reformat.
To install:
yarn install
To reformat:
yarn format
To reformat incremental changes:
yarn prettier --write .prettierrc.json
If you inspect the /docs
directory, you might notice that many of the files contain the following comment:
<!-- THIS FILE IS GENERATED. DO NOT EDIT THIS FILE DIRECTLY -->
These generated files are actually put together from many individual files, which we call Information Nodes.
Most of these Information Nodes now live in the docs-src
directory.
The reasons for modularizing our information are many, but one of them is that it provides a fun use case for combining our pre-build processes, usually a set of independent scripts, into a Temporal Workflow.
The assembly
directory is dedicated to the documentation site's Assembly Workflow.
In the directory are the defined Workflows, Activities, Worker, guide configurations, and an application configuration file.
Each JSON configuration file in assembly/guide-configs represents a user-facing narrative that pieces together the Information Nodes. The Docs full assembly Workflow uses these configuration files to generate the guides, such as Concepts and Application development.
The Assembly Workflow can be run using a local Cluster (such as Temporalite) or Temporal Cloud.
If you are running this for the first time, you need to run yarn
directly in the assembly
directory.
TIP: Make your changes in the source files that are named in the configuration file. For example, if you found a typo in the Concept section What is a Task?, open docs/concepts/what-is-a-task.md and make the edit directly there.
To run the Assembly Workflow using a local Cluster, such as Temporalite, do the following:
- Make sure you are in the
assembly
directory and run the Worker:
./worker.js
- In another terminal, from the root of the repo, run the following command:
yarn gen
These steps assume you have a Temporal Cloud Account and have already provisioned your Namespace, including a CA certificate.
To run the Assembly Workflow using Temporal Cloud, do the following:
- Create the directory
assembly/secure
and populate it with the following files:
docs-assembly.pem
: Paste and save the full CA certificate text.docs-assembly.key
: Paste and save the full secret that was generated with the certificate.cloud-connection.json
: Paste the following JSON, replacing the values with your own.
{
"address": "your-cloud-address",
"unique_id": "your-unique-custom-id",
"namespace": "your-namespace"
}
- Make sure you are in the
assembly
directory and run the Worker:
./worker.js --cloud
- In another terminal, from the root of the repo, run the following command:
yarn gen --cloud
You can preview the changes made by your PR by clicking "Details" next to the Netlify deploy-preview check.
When we merge your PR, a new build automatically occurs and your changes publish to https://docs.temporal.io.