Mage Pro’s version control workflow has three parts: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.
- Authentication — Connect your Git host 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.
- Deployments — Deploy commits to your Mage Pro cluster or workspace from the visual Deployments app.
- Version control terminal — Run Git in the browser (push, pull, branches) once you are connected.
1. Authentication
Authentication is shared by the Deployments app and the 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. |
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.
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 theUSER_CODE_PATHenvironment 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.

HTTPS and personal access token (PAT)
- Under Connection, set Authentication type to HTTPS+PAT.
- 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. - 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.
- 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
reposcope; GitLab requiresread_repositoryandwrite_repository; Bitbucket uses therepository:writepermission. - 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).

SSH key authentication
- Under Connection, set Authentication type to SSH.
- Enter the remote repository URL in SSH form (for example
git@github.com:your-org/your-repo.gitor a supportedssh://URL from your provider). - Enter a username and email for Git commit identity (as shown in
git log), matching what you use for the repository. - 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.
- Click Save authentication settings.
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. A warning is shown in the app when this applies.
GitHub (OAuth)
Mage Pro supports integration with GitHub repositories for version control, collaboration, and deployments. For HTTPS+PAT or SSH, use PAT or SSH key 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.

- 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.
- If your organization isn’t appearing, enter the name in the Organization name field and click Set organization.
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.
- You should see all your GitHub repositories if you authenticated correctly.
- The production branch is the primary branch your production code will mirror.

Bitbucket (OAuth)
Mage Pro supports integration with Bitbucket repositories for version control, collaboration, and deployments. For HTTPS+PAT or SSH, use PAT or SSH key instead of the Bitbucket Connect OAuth flow below. Connect to Bitbucket using OAuth tokens:
- This will take you to the Bitbucket sign-in authentication.
- 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.

- If there are no workspaces listed, enter a workspace slug in the text field below and click Set workspace.
- You should see a list of all the repositories in that workspace.
- The production branch is the primary branch your production code will mirror.

GitLab (OAuth)
Mage Pro supports integration with GitLab repositories for version control, collaboration, and deployments. For HTTPS+PAT or SSH, use PAT or SSH key 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.
- 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.

- If there are no groups listed, enter a group name in the text field below and click Set group.
- You should see a list of all the repositories in that group.
- 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 or SSH key 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.
- 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.

- If your organization isn’t appearing in the dropdown, enter the name in the Organization name field and click Set organization.
- This is the project that contains the repository you want to deploy changes from.
- You should see a list of all repositories in that project.
- 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 merged work from Git to your Mage Pro cluster. It assumes you have already completed 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:- In Mage, go to the Deployments view and open the deployments list (highlighted in green at the top when updates are available).
- Click Deploy to ship the version you just merged. Use Rollback to deploy an earlier commit if you need to revert.

3. Version control terminal
Once you have completed Authentication, you can use standard Git in the browser: status, commit, push, pull, and branch operations against your configured remote.If you have not set up Git access yet, follow Authentication first: OAuth, or HTTPS+PAT / SSH in the Deployments connection settings. All three options enable the version control terminal.
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.)

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 — OAuth, HTTPS + PAT, or SSH; configured in the Deployments app and required for the tools below.
- Deployments app — Promote merged commits to your cluster (deploy / rollback) after work lands in your remote branch.
- Version control terminal — Run
gitin the browser; with SSH auth, some push/pull activities may be terminal-only if the host Git API is not used for your setup.
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