
Mage Pro
Unlock seamless version control and effortless deployments with Mage Pro! Check out this guide to experience a more intuitive, user-friendly way to manage and deploy your code.
Open source
Demo
Setup

Set Git directory
The Git directory is the local folder that will be linked to your remote repository.Authentication
You will be able to authenticate with GitHub by default, but if you need to authenticate with GitHub Enterprise (GHE) or other providers, you will need to follow the steps below. You can authenticate with multiple git providers if you need to. Mage will attempt to use the oauth provider based on the URL of the remote.Mage authenticates with a default GitHub OAuth application that may not be able to access
your repository depending on the repository or organization settings. If you encounter issues
accessing your repository after authenticating with GitHub, you may need to create your own
OAuth application that has access to the repositories you want to work with. You can follow the
steps in the 
Authenticate with GitHub or GHE section below to connect Mage with your OAuth
application.http(s)://<your-mage-url>/oauth.
Authenticate with GitHub or GHE
Authenticate with GitHub or GHE
1
Register Mage in GitHub
In order for Mage to authenticate with your GitHub host, you will need to add Mage as an
authorized oauth application. You can follow the steps here
to set it up.Make sure you copy the client id and client secret after the app is created.
2
Update environment variables
You will need to set the following environment variables in your Mage environment:
- GHE_HOSTNAME: the hostname of your GitHub instance. If you’re using non-enterprise GitHub or GitHub Enterprise Cloud, you should set this to github.com
- GHE_CLIENT_ID: the client id you retrieved in the previous step
- GHE_CLIENT_SECRET: the client secret you retrieved in the previous step
3
Authenticate with GitHub
You should now be able to authenticate with GitHub and follow the rest of the steps in this document.
Authenticate with BitBucket
Authenticate with BitBucket
1
Add Mage as an OAuth consumer
In order for Mage to authenticate with your BitBucket, you will need to add Mage as an
OAuth consumer. You can follow the steps here
to set it up.Make sure you copy the key and secret after the consumer is created.
2
Update environment variables
You will need to set the following environment variables in your Mage environment:
- BITBUCKET_OAUTH_KEY: the key you retrieved in the previous step
- BITBUCKET_OAUTH_SECRET: the secret you retrieved in the previous step
3
Authenticate Mage with Bitbucket
You should now be able to authenticate with Bitbucket and follow the rest of the steps in this document.
Authenticate with GitLab
Authenticate with GitLab
Mage will request 
read_user, write_repository, and api scopes from GitLab in order
to perform the necessary git actions.1
Add Mage Oauth application
In order for Mage to authenticate with your GitLab, you will need to add a Mage oauth application.
You can follow the steps here
to set it up.Make sure you copy the Application ID and Secret after the oauth app is created.
2
Update environment variables
You will need to set the following environment variables in your Mage environment:
- GITLAB_CLIENT_ID: the application ID you retrieved in the previous step
- GITLAB_CLIENT_SECRET: the secret you retrieved in the previous step
- GITLAB_HOST (optional): hostname for your GitLab instance. Defaults to https://gitlab.com
3
Authenticate Mage with GitLab
You should now be able to authenticate with GitLab and follow the rest of the steps in this document.
Authenticate with Azure DevOps
Authenticate with Azure DevOps
1
Enable Active Directory integration
First, you will need to enable the Active Directory integration in order for Mage to authenticate your user.
2
Update environment variables
Once the Active Directory integration is enabled, you simply need to add your DevOps organization as an environment variable.
3
Authenticate Mage with Azure DevOps
You should now be able to authenticate with Azure DevOps and follow the rest of the steps in this document.

Add remote
Enter a name for your new remote. For the remote URL, you must use thehttps version of the
GitHub repository (as opposed to the SSH version).
For example, the remote URL for Mage is https://github.com/mage-ai/mage-ai.git.
Note that a remote added via HTTPS/SSH authentication will not work— only a remote in the format above is accepted.
Once you fill in both input text fields, click the button labeled Create new remote.
Actions
Clone remote repository
Cloning will copy all the files and folders from the remote repository and put them into the Git directory you specified above.Cloning won’t automatically create a folder that is named after the remote repository.For example, if you have a file named 
magic.py in a remote repository named project_romeo
then that file will be cloned here <your git directory>/magic.py
as opposed to <your git directory>/project_romeo/magic.py.If you want to clone the content of a remote repository into a folder named after the remote repository, then change the Git init directory above to
<your git directory>/[remote repository name]- Under the Actions dropdown, select the option labeled Clone.
- Under the Remote dropdown, select the name of the remote you want to clone from (e.g. origin).
Pull remote branch
- Under the Actions dropdown, select the option labeled Pull.
- Under the Remote dropdown, select the name of the remote you want to pull from (e.g. origin).
- Under the Branch dropdown, select the name of the branch you want to pull from the remote you chose from the previous step.
Branches

Switch branch
- Under the dropdown labeled Current branch, select the name of the branch you want to change to.
- After selecting a branch, the current branch will be updated to what you selected.
Create branch
- Type in the name of the new branch in the text input field.
- Click the button labeled + Create new branch.
Merge branch
- Under the Base branch dropdown, select the name of the branch you want to merge into your current branch.
- Under the Action dropdown, select the option labeled Merge.
- Type a commit message for the merge action.
- Click the button labeled Merge.
Rebase branch
- Under the Base branch dropdown, select the name of the branch you want to rebase into your current branch.
- Under the Action dropdown, select the option labeled Rebase.
- Type a commit message for the rebase action.
- Click the button labeled Rebase.
Delete branch
- Under the Base branch dropdown, select the name of the branch you want to delete.
- Under the Action dropdown, select the option labeled Delete.
- Click the button labeled Delete.
- Confirm the popup dialog box.
Files

Add files
- On the left side under Not staged, check the boxes next to the files you want to add.
- Once you’re done selecting the files, click the button labeled Add files.
- The selected files will be staged.
Checkout files
- On the left side under Not staged, check the boxes next to the files you want to checkout.
- Once you’re done selecting the files, click the button labeled Checkout files.
- Confirm the popup dialog box.
- All changes to the selected files will be undone.
Reset files
- On the right side under Staged files, check the boxes next to the files you want to reset.
- Once you’re done selecting the files, click the button labeled Reset files.
- The selected files will be unstaged.
Commit
- Enter a commit message.
- Click the button labeled Commit N files with message.
Push

Push local changes
- Under the Remote dropdown, select the name of the remote you want to push to (e.g. origin).
- Under the Branch dropdown, select the name of the branch you want to push.
- Click the button labeled Push [remote] [branch].
Create pull request
- Under the Repository dropdown, select the name of the repository you want to create a pull request for.
- Under the Base branch dropdown, select the name of the branch you want your pull request to compare against (e.g. main).
- Under the Compare branch dropdown, select the name of the branch you want your pull request to be for (e.g. feature branch).
- Type the title of the pull request in the text input field labeled Title.
- Type the description of the pull request in the text input field labeled Description.