Please read this guide before you open a pull request (yes, there is documentation for how to do documentation). If you're opening an issue, go ahead! And either way, thank you for your input, we appreciate you! 😍
- Before you start
- Content types
- Pull request process
- Style guide
- Further reading
- Appendix A: Templates
The goal of the docs is to support and enable users to achieve their goals, as quickly and easily as possible. We support that by providing accurate information in a concise format and a clear structure. It is better for one contributor to take time to make the content as clear as possible, than for many developers to have to spend time trying to understand something less clear.
Our intended audience is very technical, so does not need entry-level explanation of common concepts. They are here for advanced or Aiven-specific information. They might be in a hurry though (for example, during an incident on their platform) so clear, informative and friendly are the themes to aim for.
Aiven Docs uses the Diátaxis Framework as the basis of its content structure. This means that every article should be one of the following types:
- HowTo walks a developer through completing a specific task. It has a clear introduction of the task and what is is for, and numbered steps to follow (without choices, if there's more than one way to do something, pick one). If additional explanation could be useful, link to a related concept article.
- Concept is an explainer article that helps a developer to learn or understand something. Developers researching features, or who need extra background information on something that has been mentioned in a task, rely on these articles to fill gaps in their knowledge. It's common for HowTo articles to link to Concept articles.
- Reference starts with an overview of what can be found in this section, and then usually a list of some kind. We use this type of article for lists of extensions, configuration parameters, and that sort of bookmark-it-for-reference type of content.
The instructions for setting up local development are in the README
.
We heartily recommend you open an issue so that we can either help with outlines, or know that three people are working on the same thing.
Make your changes on a branch. We recommend a maximum of three articles, and don't review large changesets without prior discussion. File names are
kebab-case
, with hyphens, such asconnect-with-pgadmin.rst
. Files should also be added to the table of contents file_toc.yml
so they appear in the right location in the navigation.Open a pull request, use the template so we know what it is and why it's a great addition. If you need to publish this quickly for a reason, mention that as well.
If there is an associated issue, add
Fixes <issue-URL>
to the PR description text - this means the issue will automatically get closed when the PR is merged.We have an automated build process that checks your work against our in-house styles, gets product names with the right capitalization, and checks links that you added. Please don't be alarmed if your build fails! View the output of the failed jobs to find out what happened, or we can advise when we review. You can run these locally if you like:
make spell
andmake linkcheck
.
Tip
Don't add commands to the accepted words list, these should always be in literal
markup and ignored by the spell checker. Literal markup can't be used inside link text, so reword your link and sentence to avoid this.
- On devportal, some CI/CD processes run weekly. Some of those processes are automation that helps to keep our documentation up-to-date. In another process we [check](https://github.com/aiven/devportal/blob/main/.github/workflows/linkcheck.yaml) for broken links in our docs. If the build fails, a GitHub Issue is open to inform collaborators and maintainers about it.
- Every pull request generates a preview link, that will be added to your pull request as a comment. This link is publicly available and does not change during the lifetime of your pull request. Feel free to share it with others who might want a preview of your changes.
- Our docs team will review your pull request, and you will receive some feedback. It's expected that there will be 2 or 3 rounds of revisions, but if you'd rather we just made changes ourselves, let us know.
- The reviewer will merge the pull request once it is ready and has been approved.
We follow Google developer documentation style guide. Exceptions and Aiven-specific guidelines are detailed in this section.
Where possible, these rules are checked automatically using Vale. For more information on how this is set up, see the Vale readme file.
See the Content types section and work out whether you are writing a HowTo, Concept or Reference document. You might be writing more than one to cover the feature you have in mind! If you want to create a tutorial, please discuss that with us first.
If we have other resources that might help a developer, point them out! Whether that's linking to concepts from howto articles, linking to reference materials, adding a section at the end for further reading that links any blog posts or tutorials we have on the topic, or related tasks - it all helps! It's also fine to link to resources on other sites (including competitors), especially upstream documentation resources.
Note
All links should have text that makes it clear where the link goes to. Never use "here" as link text, instead try "the Grafana documentation for the sparkles plugin" or something else descriptive.
Use bold text for UI elements, such as page titles and buttons.
Advice on marking up elements correctly can be found in the README. Other useful tips and tricks are available in the working with Sphinx and reStructuredText section.
Screenshots might get outdated as soon as there's a visual change on the Aiven console. Although they can be helpful, especially where a user might have difficulty finding a particular element on a screen, use screenshots only when the textual instruction is not enough to help our audience.
The images
folder reflects the structure of the docs
folder, and the image should be in the folder matching the document that refers to it.
All images require alt text.
We do not use gif
or animation in Aiven docs.
Example values should not be "foo" or "bar". Instead, if it's a username, try "Alice". If it's an email address use someone@example.com
. A user can quickly identify which variable goes where if they look like the values they represent.
When using placeholders in code examples, follow the Google developer documentation style guide's rules for formatting placeholders.
The following items are only allowed in strict moderation:
- emoji 😄
- exclamation marks
- questions, especially in headlines
Aiven docs are built using Sphinx with pages written in reStructuredText. The following are some useful tips for working with Sphinx and reStructuredText.
Create anonymous links
If in a page you have multiple links having the same label, for instance:
`docs <http//docs.com>`_
`docs <http//docs2.com>`_
You'll see a warning in the logs stating Duplicate target name
. To resolve the warning you can either
change the link labels to be different, or
create an anonymous link by adding two
_
at the end of the link, for instance:`docs <http//docs2.com>`__
Create orphan pages
By default any pages created need to be added in the _toc.yml
file and therefore appear in the left navigation section. However you might want to create orphan pages which can be linked by other pages but are not present in the main navigation panel.
To achieve this and avoid build failures, you just need to add the :orphan:
directive in the page like:
:orphan:
Page title
==========
Body content
The :orphan:
section tells Sphinx not to include this page in any contents list, and therefore no warning is issued about the page not being added in the _toc.yaml
file.
Rename files and adding redirects
The project supports a redirects file, named _redirects
; the format is source and destination as paths relative to the root of the project. Here's an example:
/docs/products/flink/howto/real-time-alerting-solution-cli.html /docs/products/flink/howto/real-time-alerting-solution.html
If you are moving or renaming a file, put the old and new URLs into the file. If you are deleting a file, use the old URL and choose a good alternative landing place, such as a similar article, or a section homepage.
Tip
You can also create shortcut convenience URLs, but please use these sparingly.
You may get errors from the automated checks when using proper nouns. In these cases, you might need to add the words as an exception or add them to the dictionary file. For information on how to do this, see the Vale readme file.
You may get errors from the automated checks when using proper nouns. In these cases, you might need to add the words as an exception or add them to the dictionary file. For information on how to do this, see the Vale readme file.
These templates help you get started with the different types of content. Feel free to discuss with us if you need something different.
Title template: Start with a verb (e.g. Connect with Go, Install or upgrade an extension).
Article title ############# First paragraph: Explain what the task helps users accomplish, the benefits of the task, or the purpose of the task. Try to include information that will help users understand when the task is appropriate or why the task is necessary. The first few words of the article are used in the search results. Add links to any related articles such as supporting concept information, or similar tasks, if appropriate. Procedural section header here ------------------------------- Include prerequisite information or specific permissions information before we get started. 1. Then write procedural steps using ordered lists. 2. Include only one way of doing something. 3. If there's a shortcut, add it as a **Tip**. 4. Use full sentences with proper punctuation to explain a step. Optionally, another procedural section here ------------------------------------------- Keep adding procedures until you've finished writing your article.
Title template: About [subject] (if this is a background information for a task, e.g. About migrating to Aiven) / Subject (use noun or noun phrase, e.g. Authentication, High availability)
Article title ############# Introduce your topic with a short description: Answer the question "What is this?" and "Why do I care about this?" If the concept is unfamiliar, start with a brief definition. The first few words of the article also show up in the search results. A section here -------------- Write one or two paragraphs about the main idea of your topic. Add lists, diagrams or tables as necessary. Another section here -------------------- Write one or two paragraphs about another element of your topic. Keep adding headers and sections until you've completed your article. Next steps ---------- (optional) Share some links related to the topic. This could be more detailed upstream documentation, a task article that uses this knowledge. More links are good!
For features that are in the limited availability stage, add the following admonition directly undert the article title:
.. important:: {feature name} is a :doc:`limited availability feature </docs/platform/concepts/beta_services>`. If you're interested in trying out this feature, contact the sales team at sales@Aiven.io.
For features that are in the early availability stage and can be enabled in the Console, add the following admonition directly under the article title:
.. important:: {feature name} is an :doc:`early availability feature </docs/platform/concepts/beta_services>`. To use it, :doc:`enable the feature preview </docs/platform/howto/feature-preview.html>` in your user profile.