Skip to main content
Multi-repository deployments are available on Enterprise plans.
Use a multi-repository deployment when one site needs content from more than one Git repository. When you configure multiple repositories as sources for the same Mintlify project, content from each repository has its own URL path. For example, you can combine separate repositories for product documentation, API reference, and SDK guides into one site:
docs.example.com/product
docs.example.com/api
docs.example.com/sdks

How multi-repository deployments work

Each repository in a multi-repository deployment has its own:
  • Git provider connection
  • Branch
  • Optional content directory
  • URL path
  • docs.json
During deployment, Mintlify reads each repository and combines the configured sources into one site. Each source appears under its configured URL path. One repository acts as the base source for the deployment. Its docs.json is the root docs.json and controls site-level configuration, including theme, colors, logo, site name, top-level navigation, integrations, SEO, and other top-level fields. Every other source contributes only its own navigation and content under its configured URL path. The first repository you configure is the base source by default, and you can change which source is the base at any time.
Multi-repository deployments are different from a monorepo setup. Use a monorepo setup when you store all content in a subdirectory alongside source code in a single repository. Use multi-repository deployments when you store content across separate repositories.

Requirements

  • An Enterprise plan
  • Admin access to your Mintlify project
  • A docs.json file in each repository source
  • All repository sources must use the same Git provider (all GitHub or all GitLab). Adding a source from a different provider removes all existing sources of the other type
URL paths must be unique and cannot overlap. For example, do not configure one source at /docs and another source at /docs/api.

Configure multiple repositories

1

Open Git settings

Navigate to Git settings in your dashboard.
The Git settings page in the Mintlify dashboard. The Add repository button is visible at the bottom.
2

Add another repository

Click Add repository.
3

Configure the repository source

Select the repository, branch, and any required Git provider-specific fields (GitHub or GitLab).
The repository configuration panel in the Git settings page. The repository, branch, and GitHub-specific fields are visible.
For GitHub sources, the Mintlify GitHub App must have access to the repository. For GitLab sources, provide the project ID and a deploy token with read_repository scope.If the repository’s docs.json is in a subdirectory rather than the root, enable docs.json is in a subdirectory and enter the path to that directory.
4

Set the URL path

Enter a URL path for the repository source.The URL path determines where the content from that repository appears on your docs site. For example, a URL path of api serves the content under docs.example.com/api.
You can enter the path with or without leading slashes. Mintlify normalizes the value when you save.
5

Save changes

Click Save changes. Mintlify saves the configuration and queues a deployment of the combined site.

Change the base source

The base source provides the site-wide configuration for your multi-repository deployment. Change the base source when you want a different repository’s docs.json to control settings like theme, colors, site name, and top-level navigation.
1

Open Git settings

Navigate to Git settings in your dashboard.The current base source shows a Base badge next to the repository name.
2

Set a new base source

On the repository you want to use as the base, click Set as base.Mintlify updates the base source immediately and queues a deployment using the new base repository’s docs.json for site-level configuration.
Changing the base source replaces site-level settings such as theme, colors, logo, site name, and top-level navigation with the values from the new base repository’s docs.json. URL paths and content from other sources are unaffected.

Example repository layout

In this example, each source has its own repository and its own docs.json.
acme/product-docs
├── docs.json
├── overview.mdx
└── guides/

acme/api-docs
├── docs.json
├── introduction.mdx
└── reference/

acme/sdk-docs
├── docs.json
├── quickstart.mdx
└── javascript/
Configure each repository with a URL path:
RepositoryURL pathPublished path
acme/product-docsproduct/product
acme/api-docsapi/api
acme/sdk-docssdks/sdks
Mintlify combines the navigation from each repository into one site navigation. Each repository source becomes a top-level product section under the configured URL path. The name of each product section comes from the name field in the corresponding repository’s docs.json. For example, if a repository’s docs.json sets "name": "API Reference", its product section appears as “API Reference” in the combined navigation. Keep each source’s navigation scoped to that repository. For example, pages in the API repository should reference only files that live in the API repository, and pages in the SDK repository should reference only files that live in the SDK repository. Nested navigation.products configurations are not supported inside individual source repositories.

Removing a repository source

You can remove a repository source from the Git settings page in your dashboard. When only one repository source remains, Mintlify removes the source URL path and treats the remaining repository as the root source for the deployment.