Set up Databricks Repos

Learn how to set up Databricks Repos for version control. Once you set up Databricks Repos, you can use it to perform common Git operations such as clone, checkout, commit, push, pull, and branch management. You can also see diffs for your changes as you develop with notebooks and files in Databricks.

Configure user settings

Databricks Repos uses a personal access token (PAT) or an equivalent credential to authenticate with your Git provider to perform operations such as clone, push, pull etc. To use Repos you first need to add your Git PAT and Git provider username to Databricks. See Get a Git access token & connect a remote repo to Databricks.

You can clone public remote repositories without Git credentials (a personal access token and a username). To modify a public remote repository, or to clone or modify a private remote repository, you must have a Git provider username and personal access token with read and write permissions for the remote repository.

Add Git credentials to Databricks

  1. Click User Settings Icon Settings at the top right of your screen and select User Settings.

  2. Click the Git Integration tab.

  3. If you have previously entered credentials, click the Change settings button.

  4. In the Git provider drop-down, select the provider name.

  5. Get a personal access token (PAT) or other credentials from your Git provider. For details, see Get a Git access token & connect a remote repo to Databricks

    Important

    Databricks recommends that you set an expiration date for all personal access tokens.

  1. For Azure DevOps, Git integration does not support Azure Active Directory tokens. You must use an Azure DevOps personal access token.

  2. If your organization has SAML SSO enabled in GitHub, ensure that you have authorized your personal access token for SSO.

  1. Paste your Git provider PAT token into the Token field.

  2. Enter your username into the Git provider username field and click Save.

You can also save a Git PAT token and username to Databricks by using the Databricks Repos API.

Network connectivity between Databricks Repos and a Git provider

Databricks Repos needs network connectivity to your Git provider to function. Ordinarily, this is over the internet and works out of the box. However, you might have setup additional restrictions on your Git provider for controlling access. For example, you might have a IP allow list in place or you might host your own private Git server—through services like GitHub Enterprise(GHE), Bitbucket Server(BBS), or Gitlab Self-managed—and your Git server might not be accessible via the internet.

Note

  • If you Git server is internet accessible but has a IP allow list in place, for example, GitHub allow lists you must add Databricks control plane NAT IPs to the Git server’s IP allow list. Use the IP for the region that your Databricks workspace is in.

  • If you are privately hosting a Git server please get in touch with your Databricks representative for onboarding instructions for access.

Security features in Databricks Repos

Databricks Repos comes with several security features. Following sections walk you through their setup and use:

  • Use of encrypted Git credentials.

  • An allow list

  • Workspace access control

  • Audit logging

  • Secrets detection

Bring your own key: Encrypt Git credentials

You can use AWS Key Management Service to encrypt a Git personal access token (PAT) or other Git credential. Using a key from an encryption service is referred to as a customer-managed key (CMK) or bring your own key (BYOK).

For more information, see Customer-managed keys for managed services

Restrict usage to URLs in an allow list

An admin can limit which remote repositories users can clone from and commit & push to. This helps prevent exfiltration of your code, for example, users cannot push code to an arbitrary repository if you have turned on the allow list restrictions. You can also prevent users from using unlicensed code by restricting clone operation to a list of allowed repositories.

To set up an allow list:

  1. Go to the Admin Console.

  2. Click the Workspace Settings tab.

  3. In the Repos section, choose an option from Repos Git Allow List:

    • Disabled (no restrictions): There are no checks against the allow list.

    • Restrict clone, commit & push to allowed Git repositories: Clone, commit, and push operations are allowed only for repository URLs in the allow list.

    • Only restrict commit & push to allowed Git repositories: Commit and push operations are allowed only for repository URLs in the allow list. Clone and pull operations are not restricted.

  4. In the field next to Repos Git URL Allow List: Empty list, enter a comma-separated list of URL prefixes.

  5. Click Save.

To allow access to all repositories, choose Disable (no restrictions).

Note

  • The list you save overwrites the existing set of saved URL prefixes.

  • It can take up to 15 minutes for the changes to take effect.

Control access to a Repo in your workspace

Set permissions for a Repo to control access. Permissions for a Repo apply to all content in that Repo. Menu options are Can Manage, Can Edit, Can Run and Can View.

Select Permissions to control access to a Repo.

When you create a repo, you have Can Manage permission on it. This lets you modify content in the Repo, perform Git operations or modify the remote repository. Users should develop in their own isolated Repo and collaborate on a shared code base via Git branches and PRs. Thus, you should not give other users Can Edit or Can Manage access to your development Repo.

Audit logging

When audit logging is enabled, audit events are logged when you interact with a Databricks repo. For example, an audit event is logged when you create, update, or delete a Databricks repo, when you list all Databricks Repos associated with a workspace, and when you sync changes between your Databricks repo and the remote Git repo.

Secrets detection

Databricks Repos scans code for access key IDs that begin with the prefix AKIA and warns the user before committing.