Skip to main content
OpenAPI is a specification for describing APIs. Mintlify supports OpenAPI 3.0+ documents to generate interactive API documentation and keep it up to date.

Add an OpenAPI specification file

To document your endpoints with OpenAPI, you need a valid OpenAPI specification in either JSON or YAML format that follows the OpenAPI specification 3.0+. You can reference multiple OpenAPI specifications to create pages for your API. Either organize sections for each specification in your navigation or reference specific endpoints from different specifications.
Mintlify supports $ref for internal references only within a single OpenAPI document. External references are not supported.

Describe your API

We recommend the following resources to learn about and construct your OpenAPI specification.
Swagger’s OpenAPI Guide is for OpenAPI v3.0, but nearly all of the information is applicable to v3.1. For more information on the differences between v3.0 and v3.1, see Migrating from OpenAPI 3.0 to 3.1.0 in the OpenAPI blog.

Specify the base URL for your API

To enable the API playground, add a servers field to your OpenAPI specification with your API’s base URL.
{
  "servers": [
    {
      "url": "https://api.example.com/v1"
    }
  ]
}
In an OpenAPI specification, different API endpoints are specified by their paths, like /users/{id} or simply /. The base URL defines where these paths should be appended. For more information on how to configure the servers field, see API Server and Base Path in the OpenAPI documentation. The API playground uses these server URLs to determine where to send requests. If you specify multiple servers, a dropdown allows users to toggle between servers. If you do not specify a server, the API playground uses simple mode since it cannot send requests without a base URL. If your API has endpoints that exist at different URLs, you can override the servers field for a given path or operation.

Specify authentication

To enable authentication in your API documentation and playground, configure the securitySchemes and security fields in your OpenAPI specification. The API descriptions and API playground add authentication fields based on the security configurations in your OpenAPI specification.
1

Define your authentication method.

Add a securitySchemes field to define how users authenticate.This example shows a configuration for bearer authentication.
{
  "components": {
    "securitySchemes": {
      "bearerAuth": {
        "type": "http",
        "scheme": "bearer"
      }
    }
  }
}
2

Apply authentication to your endpoints.

Add a security field to require authentication.
{
  "security": [
    {
      "bearerAuth": []
    }
  ]
}
Common authentication types include:
  • API Keys: For header, query, or cookie-based keys.
  • Bearer: For JWT or OAuth tokens.
  • Basic: For username and password.
If different endpoints within your API require different methods of authentication, you can override the security field for a given operation. For more information on defining and applying authentication, see Authentication in the OpenAPI documentation.

Customize your endpoint pages

Customize your endpoint pages by adding the x-mint extension to your OpenAPI specification. The x-mint extension provides additional control over how your API documentation is generated and displayed.

Metadata

Override the default metadata for generated API pages by adding x-mint: metadata to any operation. You can use any metadata field that would be valid in MDX frontmatter except for openapi.
{
  "paths": {
    "/users": {
      "get": {
        "summary": "Get users",
        "description": "Retrieve a list of users",
        "x-mint": {
          "metadata": {
            "title": "List all users",
            "description": "Fetch paginated user data with filtering options",
            "og:title": "Display a list of users"
          }
        },
        "parameters": [
          {
            // Parameter configuration
          }
        ]
      }
    }
  }
}

Content

Add content before the auto-generated API documentation using x-mint: content. The x-mint: content extension supports all Mintlify MDX components and formatting.
{
  "paths": {
    "/users": {
      "post": {
        "summary": "Create user",
        "x-mint": {
          "content": "## Prerequisites\n\nThis endpoint requires admin privileges and has rate limiting.\n\n<Note>User emails must be unique across the system.</Note>"
        },
        "parameters": [
          {
            // Parameter configuration
          }
        ]
      }
    }
  }
}

Href

Change the URL of the endpoint page in your docs using x-mint: href. When x-mint: href is present, the navigation entry links directly to the specified URL instead of generating an API page.
{
  "paths": {
    "/legacy-endpoint": {
      "get": {
        "summary": "Legacy endpoint",
        "x-mint": {
          "href": "/deprecated-endpoints/legacy-endpoint"
        }
      }
    },
    "/documented-elsewhere": {
      "post": {
        "summary": "Special endpoint",
        "x-mint": {
          "href": "/guides/special-endpoint-guide"
        }
      }
    }
  }
}

MCP

Selectively expose endpoints as Model Context Protocol (MCP) tools by using x-mint: mcp. Only enable endpoints that are safe for public access through AI tools.
mcp
object
The MCP configuration for the endpoint.
{
  "paths": {
    "/users": {
      "post": {
        "summary": "Create user",
        "x-mint": {
          "mcp": {
            "enabled": true
          },
          // ...
        }
      }
    },
    "/users": {
      "delete": {
        "summary": "Delete user (admin only)",
        // No `x-mint: mcp` so this endpoint is not exposed as an MCP tool
        // ...
      }
    }
  }
}
For more information, see Model Context Protocol.

Auto-populate API pages

Add an openapi field to any navigation element in your docs.json to automatically generate pages for OpenAPI endpoints. You can control where these pages appear in your navigation structure, as dedicated API sections or with other pages. The openapi field accepts either a file path in your docs repo or a URL to a hosted OpenAPI document. Generated endpoint pages have these default metadata values:
  • title: The operation’s summary field, if present. If there is no summary, the title is generated from the HTTP method and endpoint.
  • description: The operation’s description field, if present.
  • version: The version value from the parent anchor or tab, if present.
  • deprecated: The operation’s deprecated field. If true, a deprecated label appears next to the endpoint title in the side navigation and on the endpoint page.
To exclude specific endpoints from your auto-generated API pages, add the x-hidden property to the operation in your OpenAPI spec.
There are two approaches for adding endpoint pages into your documentation:
  1. Dedicated API sections: Reference OpenAPI specs in navigation elements for dedicated API sections.
  2. Selective endpoints: Reference specific endpoints in your navigation alongside other pages.

Dedicated API sections

Generate dedicated API sections by adding an openapi field to a navigation element and no other pages. All endpoints in the specification are included.
"navigation": {
  "tabs": [
    {
        "tab": "API Reference",
        "openapi": "https://petstore3.swagger.io/api/v3/openapi.json"
    }
  ]
}
To organize multiple OpenAPI specifications in separate sections of your documentation, assign each specification to a different group in your navigation hierarchy. Each group can reference its own OpenAPI specification.
"navigation": {
  "tabs": [
    {
      "tab": "API Reference",
      "groups": [
        {
          "group": "Users API",
          "openapi": {
            "source": "/path/to/users-openapi.json",
            "directory": "users-api-reference"
          }
        },
        {
          "group": "Admin API",
          "openapi": {
            "source": "/path/to/admin-openapi.json",
            "directory": "admin-api-reference"
          }
        }
      ]
    }
  ]
}
The directory field is optional and specifies where generated API pages are stored in your docs repo. If not specified, defaults to the api-reference directory of your repo.

Selective endpoints

When you want more control over where endpoints appear in your documentation, you can reference specific endpoints in your navigation. This approach allows you to generate pages for API endpoints alongside other content. You can also use this approach to mix endpoints from different OpenAPI specifications.

Set a default OpenAPI spec

Configure a default OpenAPI specification for a navigation element. Then reference specific endpoints in the pages field.
"navigation": {
  "tabs": [
    {
      "tab": "Getting started",
      "pages": [
        "quickstart",
        "installation"
      ]
    },
    {
      "tab": "API reference",
      "openapi": "/path/to/openapi.json",
      "pages": [
        "api-overview",
        "GET /users",
        "POST /users",
        "guides/authentication"
      ]
    }
  ]
}
Any page entry matching the format METHOD /path generates an API page for that endpoint using the default OpenAPI specification.

OpenAPI spec inheritance

OpenAPI specifications are inherited down the navigation hierarchy. Child navigation elements inherit their parent’s OpenAPI specification unless they define their own.
{
  "group": "API reference",
  "openapi": "/path/to/openapi-v1.json",
  "pages": [
    "overview",
    "authentication",
    "GET /users",
    "POST /users",
    {
      "group": "Orders",
      "openapi": "/path/to/openapi-v2.json",
      "pages": [
        "GET /orders",
        "POST /orders"
      ]
    }
  ]
}

Individual endpoints

Reference specific endpoints without setting a default OpenAPI specification by including the file path. You can reference endpoints from multiple OpenAPI specifications in the same documentation section.
"navigation": {
  "pages": [
    "introduction",
    "user-guides",
    "/path/to/users-openapi.json POST /users",
    "/path/to/orders-openapi.json GET /orders"
  ]
}
This approach is useful when you need individual endpoints from different specifications, only want to include select endpoints, or want to include endpoints alongside other types of documentation.

Create MDX pages from your OpenAPI specification

For more granular control over individual endpoint pages, create MDX pages from your OpenAPI specification. This lets you customize page metadata, content, and reorder or exclude pages in your navigation while still using the auto-generated parameters and responses. There are two ways to document your OpenAPI specification with individual MDX pages:
  • Document endpoints with the openapi field in the frontmatter.
  • Document data models with the openapi-schema field in the frontmatter.

Document endpoints

Create a page for each endpoint and specify which OpenAPI operation to display using the openapi field in the frontmatter.
---
title: "Get users"
description: "Returns all plants from the system that the user has access to"
openapi: "/path/to/openapi-1.json GET /users"
deprecated: true
version: "1.0"
---
The method and path must exactly match your OpenAPI spec. If you have multiple OpenAPI specifications, include the file path in your reference. External OpenAPI URLs can be referenced in docs.json.

Autogenerate endpoint pages

To autogenerate MDX files from your OpenAPI specification, use the Mintlify scraper.
npx @mintlify/scraping@latest openapi-file <path-to-openapi-file> -o <folder-name>
Add the -o flag to specify a folder to populate the files into. If a folder is not specified, the files will populate in the working directory.

Document data models

Create a page for each data structure defined in your OpenAPI specification’s components.schemas using the openapi-schema field in the frontmatter.
---
openapi-schema: OrderItem
---
If you have schemas with the same name in multiple files, specify the OpenAPI file:
---
openapi-schema: en-schema.json OrderItem
---

Webhooks

Webhooks are HTTP callbacks that your API sends to notify external systems when events occur. Webhooks are supported in OpenAPI 3.1+ documents. Add a webhooks field to your OpenAPI document alongside the paths field. For more information on defining webhooks, see Webhooks in the OpenAPI documentation. To create an MDX page for a webhook (OpenAPI 3.1+), use webhook instead of an HTTP method:
---
title: "Order updated webhook"
description: "Triggered when an order is updated"
openapi: "openapi.json webhook orderUpdated"
---
The webhook name must exactly match the key in your OpenAPI spec’s webhooks field.