> ## Documentation Index
> Fetch the complete documentation index at: https://mintlify-mintlify-dc46da31.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Multi-repository deployments

> Combine multiple Git repositories into one Mintlify site, with a dedicated URL path for each source repo's content and navigation.

<Info>
  Multi-repository deployments are available on [Enterprise plans](https://mintlify.com/pricing?ref=multi-repo).
</Info>

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:

```text theme={null}
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](#change-the-base-source) at any time.

<Note>
  Multi-repository deployments are different from a [monorepo setup](/deploy/monorepo). 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.
</Note>

## 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

<Warning>
  URL paths must be unique and cannot overlap. For example, do not configure one source at `/docs` and another source at `/docs/api`.
</Warning>

## Configure multiple repositories

<Steps>
  <Step title="Open Git settings">
    Navigate to [Git settings](https://app.mintlify.com/settings/deployment/git-settings) in your dashboard.

    <Frame>
      <img src="https://mintcdn.com/mintlify-mintlify-dc46da31/E9HV5P80YQzKcyK3/images/deployments/add-repository-light.png?fit=max&auto=format&n=E9HV5P80YQzKcyK3&q=85&s=c0aa2245ee42ac9605e7d210e1b9e0c6" alt="The Git settings page in the Mintlify dashboard. The Add repository button is visible at the bottom." className="block dark:hidden" width="1827" height="1031" data-path="images/deployments/add-repository-light.png" />

      <img src="https://mintcdn.com/mintlify-mintlify-dc46da31/E9HV5P80YQzKcyK3/images/deployments/add-repository-dark.png?fit=max&auto=format&n=E9HV5P80YQzKcyK3&q=85&s=de5f8b747abbd47fe6d46f795d4280ef" alt="The Git settings page in the Mintlify dashboard. The Add repository button is visible at the bottom." className="hidden dark:block" width="1827" height="1031" data-path="images/deployments/add-repository-dark.png" />
    </Frame>
  </Step>

  <Step title="Add another repository">
    Click **Add repository**.
  </Step>

  <Step title="Configure the repository source">
    Select the repository, branch, and any required Git provider-specific fields (GitHub or GitLab).

    <Frame>
      <img src="https://mintcdn.com/mintlify-mintlify-dc46da31/E9HV5P80YQzKcyK3/images/deployments/repo-configuration-light.png?fit=max&auto=format&n=E9HV5P80YQzKcyK3&q=85&s=73026c875c424f77d4dcd02222a0093b" alt="The repository configuration panel in the Git settings page. The repository, branch, and GitHub-specific fields are visible." className="block dark:hidden" width="2119" height="1395" data-path="images/deployments/repo-configuration-light.png" />

      <img src="https://mintcdn.com/mintlify-mintlify-dc46da31/E9HV5P80YQzKcyK3/images/deployments/repo-configuration-dark.png?fit=max&auto=format&n=E9HV5P80YQzKcyK3&q=85&s=28c746fc99a53f5fbab6cdf5166263e0" alt="The repository configuration panel in the Git settings page. The repository, branch, and GitHub-specific fields are visible." className="hidden dark:block" width="2119" height="1395" data-path="images/deployments/repo-configuration-dark.png" />
    </Frame>

    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.
  </Step>

  <Step title="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`.

    <Note>
      You can enter the path with or without leading slashes. Mintlify normalizes the value when you save.
    </Note>
  </Step>

  <Step title="Save changes">
    Click **Save changes**. Mintlify saves the configuration and queues a deployment of the combined site.
  </Step>
</Steps>

## 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.

<Steps>
  <Step title="Open Git settings">
    Navigate to [Git settings](https://app.mintlify.com/settings/deployment/git-settings) in your dashboard.

    The current base source shows a **Base** badge next to the repository name.
  </Step>

  <Step title="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.
  </Step>
</Steps>

<Warning>
  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.
</Warning>

## Example repository layout

In this example, each source has its own repository and its own `docs.json`.

```text theme={null}
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:

| Repository          | URL path  | Published path |
| ------------------- | --------- | -------------- |
| `acme/product-docs` | `product` | `/product`     |
| `acme/api-docs`     | `api`     | `/api`         |
| `acme/sdk-docs`     | `sdks`    | `/sdks`        |

## Navigation behavior

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](https://app.mintlify.com/settings/deployment/git-settings) 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.
