Many API governance resources dive in quickly to getting the right rulesets and linting. We have lots of resources about API governance and linting rules, but if you're at the "but where do I put these things?" stage, then keep reading. This article gets you started with the simplest possible OpenAPI governance setup, and sends you on your journey of rulesets and standards.

Aim small: a valid OpenAPI file

Most API linting tools come with a recommended standard to adhere to. What nobody tells you is: that's not a standard that many organizations actually use in the real world. Most recommended rulesets create a high barrier for an API that isn't built against such a standard, leading to adoption problems when the linting tools seem to create more problems than they solve!

Instead, build a strong and simple foundation by answering one question: "Is my API description valid?".

How to lint an OpenAPI file

Use our open source tool, Redocly CLI, to lint your OpenAPI files. We have detailed documentation that you can dive into for more details, but for most platforms, you can install it with the following command:

npm install -g @redocly/cli

The command installs globally so it's available in your terminal as redocly. Check it worked by running redocly --version.

With your OpenAPI file in openapi.yaml, the following command lints it using the recommended ruleset (you may get a lot of output so be prepared!):

redocly lint openapi.yaml

Have a look at what you got back. For most un-governanced APIs, there will be a whole host of listed warnings and errors. And if you look at the details, not all of them are super important to having a working API. That's because the recommended ruleset is just that: recommendations. If you and your API are new to API governance, then they're not that useful at this point. Instead, start smaller.

Minimum Viable API linting

A much better starting point is to enable the spec rule only, to simply check that the OpenAPI file is correct.

To do that, create a file named redocly.yaml and add the following content:

rules:
  spec: error

Redocly CLI detects this configuration file, and lints the API description with only this one rule.

Run the following lint command again and check the output:

redocly lint openapi.yaml

This list is (hopefully!) more manageable than the output you received the first time around, and keeps a tight focus on things that are actual problems. Every API is different, so it's difficult to generalize the advice here. However, each problem listed has an explanation of what's wrong. Take the time to pick up and fix each one of the reported problems.

VSCode linting

While you're working on updating your OpenAPI description, you might like to try the Redocly VSCode extension for contextual linting feedback if an IDE is your preferred tool.

Continuous linting

The most important thing with API governance is to apply the standards you choose consistently, throughout the API lifecycle. Therefore it is recommended to add the linting that you are already running locally into your CI (Continuous Integration) setup. This example uses GitHub Actions but the idea is transferrable to Jenkins, or any other CI pipeline.

A simple GitHub Action configuration would look like the example below; mine is in .github/workflows/api-lint.yaml:

name: Lint API
on: pull_request

jobs:
  api_lint:
    name: Run API linting
    runs-on: ubuntu-latest
    steps:
      - name: Check out repo's default branch
        uses: actions/checkout@v4
      - name: Set up node
        uses: actions/setup-node@v4
      - name: Install Redocly CLI
        run: npm install -g @redocly/cli@latest
      - name: Lint API
        run: redocly lint openapi.yaml

With this action in your repository, every pull request has this action run on it, so you can be sure that each change meets the API standards that are configured in the project. Automating the linting is good practice, just like running tests in CI is, and for all the same reasons. There's no way to forget to check something, and the automation stops us from making mistakes that might not be spotted until later.

Beyond the first steps

This post showed how to set up linting, configure the simplest API standards ruleset, and crucially apply that standard using Redocly CLI both locally and in your source control setup. This approach might seem like a small start, but that spec rule is the most important and you may well have a lot to do to get everything ready and compliant with it.

You have built a strong foundation, getting one rule activated and applied with ongoing automation. For your next steps, you can build your own API governance ruleset by looking at the aspects that are most important for your business and adding them to your Redocly config file. Adding the rules one at a time and updating the API description to satisfy each rule as you go along, is a good and manageable way to level up your API standards.

These resources might also be useful to you as you continue maturing your API governance practice:

Latest from our blog

Redocly CLI for AsyncAPI descriptions

Embrace multiple specification standards with one tool, Redocly CLI.

Best practices for building and adopting...

API governance is important. Learn how to do it well.

My favorite new features

Top 8 new features I’m most excited about.