> ## Documentation Index
> Fetch the complete documentation index at: https://docs.mage.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Mage Pro Version Control

> Connect Mage Pro to GitHub, Bitbucket, GitLab, or Azure DevOps using OAuth, HTTPS+PAT, or SSH. Manage data pipelines with Git and deploy commits to your cluster.

export const ProOnly = ({button = 'Get started for free', description = 'Try our fully managed solution to access this advanced feature.', source = 'documentation', title = 'Only in Mage Pro.'}) => <a href={`https://cloud.mage.ai/sign-up?source=${source}`} className="block my-4 px-5 py-4 overflow-hidden rounded-xl flex gap-3 border border-emerald-500/20 bg-emerald-50/50 dark:border-emerald-500/30 dark:bg-emerald-500/10" target="_blank">
    <div style={{
  display: 'flex',
  alignItems: 'center',
  width: '100%'
}}>
      <div className="text-sm prose min-w-0 text-emerald-900 dark:text-emerald-200" style={{
  flex: 1
}}>
        {title}
        <p className="normal">{description}</p>
      </div>

      <div> </div>

      <div>
        <ProButton label={button} href={`https://cloud.mage.ai/sign-up?source=${source}`} />
      </div>
    </div>
  </a>;

export const ProButton = ({href, label = 'Get started with Mage Pro for free', source = 'documentation'}) => <div style={{
  height: 32,
  position: 'relative'
}}>
    <a target="_blank" className="group px-4 py-1.5 relative inline-flex items-center text-sm font-medium rounded-full" href={href ?? `https://cloud.mage.ai/sign-up?source=${source}`}>
      <span className="absolute inset-0 bg-primary-dark dark:bg-primary-light/10 border-primary-light/30 rounded-full dark:border group-hover:opacity-[0.9] dark:group-hover:border-primary-light/60">
      </span>

      <div className="mr-0.5 space-x-2.5 flex items-center">
        <span class="z-10 text-white dark:text-primary-light">
          {label}
        </span>

        <svg width="3" height="24" viewBox="0 -9 3 24" class="h-5 rotate-0 overflow-visible text-white/90 dark:text-primary-light">
          <path d="M0 0L3 3L0 6" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path>
        </svg>
      </div>
    </a>
  </div>;

<ProOnly source="version-control-guide" />

Mage Pro's version control workflow has three parts:

1. **Authentication** — [Connect your Git host](#1-authentication) to Mage (OAuth with GitHub, Bitbucket, GitLab, or Azure DevOps; HTTPS with a personal access token; or SSH). You do this in the **Deployments** app, but it also enables the [Version control terminal](#3-version-control-terminal).
2. **Deployments** — [Deploy](#2-deployments-app) commits to your Mage Pro cluster or workspace from the visual Deployments app.
3. **Version control terminal** — [Run Git in the browser](#3-version-control-terminal) (push, pull, branches) once you are connected.

## 1. Authentication

**Authentication is shared** by the [Deployments app](#2-deployments-app) and the [version control terminal](#3-version-control-terminal). Configure it in **Deployments** → open **Connect repository** or deployment **Setup** → **Connection** → **Authentication type**. Until this is set up, you cannot use Git-based deployment or the terminal.

Mage Pro supports three **authentication types**:

| Type            | When to use                                                                                                                        |
| --------------- | ---------------------------------------------------------------------------------------------------------------------------------- |
| **OAuth**       | Default path: sign in with GitHub, Bitbucket, GitLab, or Azure DevOps and pick org/workspace, repo, and branch from the UI.        |
| **HTTPS + PAT** | Your organization requires a **personal access token** instead of OAuth, or you use a provider / URL where OAuth is not an option. |
| **SSH**         | You use **deploy keys** or user SSH keys and `git@…` (or `ssh://`) remotes.                                                        |

If you change authentication type, **save authentication settings** before continuing with the rest of the connection configuration. Switching types clears the credentials from the other method in your deployment settings.

### Open the connection UI

From the Home page, select **Deployments** in the left-hand navigation menu to access the Deployments interface.

Click the **Setup connection** button to begin syncing with your code repository.

<Frame>
  <img alt="Mage Pro deployments button" src="https://mage-ai.github.io/assets/pro/features/deployments/setup-connection-091925.png" />
</Frame>

### Project settings

Fill in the **Project settings** fields at the top of the Connect repository page, then click **Save settings** before configuring authentication below.

* **Configuration name** — a label for this deployment configuration.
* **Project directory** — the user code path for your project. The default in Mage Pro is `/home/src/default_repo`. If you changed the `USER_CODE_PATH` environment variable in the Mage Cloud Management Portal, set this field to match.
* **Target directory (optional)** — the directory code changes are deployed into. If left empty, the project directory is used. For a nested repository you may want to set this to `/home/src`.

<Frame>
  <img alt="Mage Pro deployments button" src="https://mage-ai.github.io/assets/pro/features/deployments/connect-repo-091925.png" />
</Frame>

After clicking **Save settings**, proceed to the **Connection** section below to set your authentication type and connect your provider.

### HTTPS and personal access token (PAT)

1. Under **Connection**, set **Authentication type** to **HTTPS+PAT**.
2. Enter the **remote repository URL** in HTTPS form (for example `https://github.com/your-org/your-repo.git`). The UI derives owner and repository name from this URL.
3. Enter a **username** and **email** for Git commit authorship. These are also used as HTTP credentials: the username is your Git host account name and the PAT is sent in place of a password.
4. In your Git host, create a **personal access token** (or app password) scoped to at least **clone, fetch, and push**. Scope names differ by provider — for example, GitHub requires the `repo` scope; GitLab requires `read_repository` and `write_repository`; Bitbucket uses the `repository:write` permission.
5. Paste the token into **Personal access token** and click **Save authentication settings**. The token is stored as a **Mage secret** named `mage_git_access_token_{user_id}` (where `{user_id}` is your Mage user ID).

HTTPS+PAT uses your stored credentials for Git in the [version control terminal](#3-version-control-terminal) the same way OAuth does.

<Frame>
  <img alt="Connect with PAT" src="https://mage-ai.github.io/assets/pro/features/deployments/connect-pat.png" />
</Frame>

### SSH key authentication

1. Under **Connection**, set **Authentication type** to **SSH**.
2. Enter the **remote repository URL** in SSH form (for example `git@github.com:your-org/your-repo.git` or a supported `ssh://` URL from your provider).
3. Enter a **username** and **email** for Git **commit** identity (as shown in `git log`), matching what you use for the repository.
4. Add **SSH public and private key** values. The form expects the key material in **base64** (as labeled in the UI). In your Git host, add the public key as a **deploy key** (repo-scoped) or a user key, with permission to read/write the repo as needed.
5. Click **Save authentication settings**.

<Note>
  With **SSH** authentication, Mage cannot use the provider’s **Git hosting API** for some deployment flows the same way as with OAuth (for example, **listing commits in the Deployments** UI). For **`git push`**, **`git pull`**, fetches, and other Git wire operations, use the **[version control terminal](#access-the-version-control-terminal)**. A warning is shown in the app when this applies.
</Note>

<Frame>
  <img alt="Connect with SSH keys" src="https://mage-ai.github.io/assets/pro/features/deployments/connect-ssh.png" />
</Frame>

### GitHub (OAuth)

Mage Pro supports integration with GitHub repositories for version control, collaboration, and deployments. For **HTTPS+PAT** or **SSH**, use [PAT](#https-and-personal-access-token-pat) or [SSH key](#ssh-key-authentication) instead of the GitHub **Connect** OAuth flow below.

**Connect to GitHub using OAuth tokens:**

**Step 1**: Click the **Connect** button to the right of the GitHub connection.

* This will take you to the GitHub sign-in authentication.

<Frame>
  <img alt="Connect GitHub" src="https://mage-ai.github.io/assets/pro/features/deployments/connect-oauth-github.png" />
</Frame>

**Step 2**: Sign in with your GitHub login credentials.

* After authenticating you will return to the Mage Pro deployment app.
* You should now see that you are connected to GitHub.
* Click **Save authentication settings**.

**Step 3**: Select your GitHub organization from the list.

* If your organization isn't appearing, enter the name in the **Organization name** field and click **Set organization**.

<Note>
  To deploy from a **private repository**, click the **Install Mage Pro app on GitHub** button that appears below the Organization section. Once installed, you can verify or update the installation at any time using the **Verify installation** or **Configure installation settings** buttons.
</Note>

**Step 4**: Select the repository from the dropdown.

* You should see all your GitHub repositories if you authenticated correctly.

**Step 5**: Select the production branch from the dropdown.

* The production branch is the primary branch your production code will mirror.

<Frame>
  <img alt="Mage Pro install app button" src="https://mage-ai.github.io/assets/pro/features/deployments/set-branch-09192025.png" />
</Frame>

### Bitbucket (OAuth)

Mage Pro supports integration with Bitbucket repositories for version control, collaboration, and deployments. For **HTTPS+PAT** or **SSH**, use [PAT](#https-and-personal-access-token-pat) or [SSH key](#ssh-key-authentication) instead of the Bitbucket **Connect** OAuth flow below.

**Connect to Bitbucket using OAuth tokens:**

<Frame>
  <img alt="Connect repository" src="https://raw.githubusercontent.com/mage-ai/assets/main/version-control/bitbucket/bitbucket-connect-repo.png" />
</Frame>

**Step 1**: Click the **Connect** button to the right of the Bitbucket connection.

* This will take you to the Bitbucket sign-in authentication.

**Step 2**: Sign in with your Bitbucket login credentials.

* After authenticating you will return to the Mage Pro deployment app.
* You should now see that you are connected to Bitbucket.
* Click **Save authentication settings**.

<Frame>
  <img alt="Connect Button" src="https://raw.githubusercontent.com/mage-ai/assets/main/version-control/bitbucket/bitbucket-connect.png" />
</Frame>

**Step 3**: Select your Bitbucket workspace from the dropdown list.

* If there are no workspaces listed, enter a workspace slug in the text field below and click **Set workspace**.

**Step 4**: Select the repository from the dropdown menu.

* You should see a list of all the repositories in that workspace.

**Step 5**: Select the production branch from the dropdown list.

* The production branch is the primary branch your production code will mirror.

<Frame>
  <img alt="Bitbucket workspace" src="https://raw.githubusercontent.com/mage-ai/assets/main/version-control/bitbucket/bitbucket-workspace.png" />
</Frame>

### GitLab (OAuth)

Mage Pro supports integration with GitLab repositories for version control, collaboration, and deployments. For **HTTPS+PAT** or **SSH**, use [PAT](#https-and-personal-access-token-pat) or [SSH key](#ssh-key-authentication) instead of the **Connect** GitLab OAuth flow below.

**Connect to GitLab using OAuth tokens:**

**Step 1**: Click the **Connect** button to the right of the GitLab connection.

* This will take you to the GitLab sign-in authentication.

**Step 2**: Sign in with your GitLab login credentials.

* After authenticating you will return to the Mage Pro deployment app.
* You should now see that you are connected to GitLab.
* Click **Save authentication settings**.

<Frame>
  <img alt="Connect Button" src="https://raw.githubusercontent.com/mage-ai/assets/main/version-control/gitlab/gitlab-connect.png" />
</Frame>

**Step 3**: Select your GitLab group from the dropdown list.

* If there are no groups listed, enter a group name in the text field below and click **Set group**.

**Step 4**: Select the repository from the dropdown menu.

* You should see a list of all the repositories in that group.

**Step 5**: Select the production branch from the dropdown list.

* The production branch is the primary branch your production code will mirror.

### Azure DevOps (OAuth)

Mage Pro supports integration with Azure DevOps repositories for version control, collaboration, and deployments. For **HTTPS+PAT** or **SSH**, use [PAT](#https-and-personal-access-token-pat) or [SSH key](#ssh-key-authentication) instead of the Azure DevOps **Connect** OAuth flow below.

**Connect to Azure DevOps using OAuth tokens:**

**Step 1**: Click the **Connect** button to the right of the Azure DevOps connection.

* This will take you to the Azure DevOps sign-in authentication.

**Step 2**: Sign in with your Azure DevOps credentials.

* After authenticating you will return to the Mage Pro deployment app.
* You should now see that you are connected to Azure DevOps.
* Click **Save authentication settings**.

<Frame>
  <img alt="Connect repository" src="https://mage-ai.github.io/assets/pro/features/deployments/azuredevops-connect.png" />
</Frame>

**Step 3**: Select your Azure DevOps **organization** from the dropdown, or type the organization name directly in the text field and click **Save**.

* If your organization isn't appearing in the dropdown, enter the name in the **Organization name** field and click **Set organization**.

**Step 4**: Select your **Azure DevOps project** from the dropdown.

* This is the project that contains the repository you want to deploy changes from.

**Step 5**: Select the **repository** from the dropdown.

* You should see a list of all repositories in that project.

**Step 6**: Select the **production branch** from the dropdown.

* This is the primary branch your production code will mirror.
* If your branch isn't listed, type the branch name into the text field and click **Set branch**.

## 2. Deployments App

The Deployments app is the control surface for [deploying](#merge-pull-request-and-deploy) merged work from Git to your Mage Pro cluster. It assumes you have already completed [authentication](#1-authentication).

### Merge pull request and deploy

Once you push code to your Git branch, open your Git provider and merge the pull request. When the merge is done, the deployment is available in the Deployments app.

Mage then deploys a chosen commit to your environment:

1. In Mage, go to the **Deployments** view and open the deployments list (highlighted in green at the top when updates are available).
2. Click **Deploy** to ship the version you just merged. Use **Rollback** to deploy an earlier commit if you need to revert.

<Frame>
  <img alt="Mage Pro deployments page" src="https://mage-ai.github.io/assets/pro/features/deployments/deployments-page.png" />
</Frame>

## 3. Version control terminal

Once you have completed [Authentication](#1-authentication), you can use standard Git in the browser: status, commit, push, pull, and branch operations against your configured remote.

<Note>
  If you have not set up Git access yet, follow [Authentication](#1-authentication) first: **OAuth**, or **HTTPS+PAT** / **SSH** in the **Deployments** connection settings. All three options enable the version control terminal.
</Note>

### Access the version control terminal

* From the home page, open the left navigation and select **Version control** (or the Version control / terminal app, depending on your layout).
* When the page loads, type Git commands in the terminal and press **Enter** to run them.

### Essential Git commands

`git checkout -b <branch-name>`

*(Creates and switches to a new branch named `<branch-name>`, enabling isolated development for features or fixes.)*

`git status`

*Displays the current state of the working directory and staging area, highlighting modified, staged, and untracked files.*

`git add .`

*(Stages all changes in the current directory and its subdirectories, preparing them for the next commit.)*

`git commit -m "<commit-message>"`

*(Records the staged changes in the repository with a descriptive message `<commit-message>`, creating a new commit in the current branch.)*

`git push origin <branch-name>`

*(Uploads the commits from the local `<branch-name>` to the corresponding remote branch, making the changes available to collaborators.)*

<Frame>
  <img alt="Mage Pro install app button" src="https://mage-ai.github.io/assets/pro/features/deployments/version-control.png" />
</Frame>

### Troubleshooting Git commands

When running Git commands, you may run into a few common issues:

* Make sure you are in the correct folder: `/home/src/<your user code path>`
* If Git doesn't recognize your identity, configure your email and username globally:
  * `git config --global user.email "your_email@example.com"`
  * `git config --global user.name "Your Username"`

## Summary

Mage Pro supports a full Git-based workflow in three steps:

* **[Authentication](#1-authentication)** — **OAuth**, **HTTPS + PAT**, or **SSH**; configured in the Deployments app and required for the tools below.
* **[Deployments app](#2-deployments-app)** — Promote merged commits to your cluster (deploy / rollback) after work lands in your remote branch.
* **[Version control terminal](#3-version-control-terminal)** — Run `git` in the browser; with **SSH** auth, some push/pull activities may be terminal-only if the host Git API is not used for your setup.

This enables version control for data pipelines through both the visual Deployments interface and a standard terminal workflow.

## Best Practices for Environment Management

### Development Environment

* **Primary Tool - Version Control Terminal**:
  * Create feature branches, develop code, commit changes, push to Git
  * Switch between branches, merge changes
* **Secondary Tool - Deployments App**:
  * Deploy to dev environment for testing and validation
  * Rollback changes or switch to another feature branch (can also be done via terminal)
* **Workflow**: Develop in Mage Pro → Commit to feature branch → Deploy to dev environment for testing

### Staging Environment

* **Primary Tool - Deployments App**:
  * Pull changes from Git (staging/main/master branch)
  * Deploy to staging environment and run testing
* **Secondary Tool - Version Control Terminal**:
  * Make hotfixes and push changes to Git
  * Merge feature branches and prepare releases
* **Workflow**: Pull from Git → Deploy to staging → Run integration tests → Make hotfixes if needed

### Production Environment

* **Primary Tool - Deployments App**:
  * Deploy commits from main/master branch
  * Rollback changes if issues occur
  * Monitor deployment status
* **Secondary Tool - Version Control Terminal**:
  * Emergency patches and hotfixes only
* **Workflow**: Deploy from main/master → Monitor → Rollback if needed
