Skip to main content

Connect a source code manager

Your deployment journey

Linking a source code manager provides the following benefits:

  • Allows the Semgrep org membership to be managed by GitHub or GitLab.
  • For GitHub users:
    • Provides Semgrep access to post PR or MR comments.
    • For GitHub Actions users: Enables you to add a Semgrep CI job to repositories in bulk.
  • Allows you to scan and manage your Azure DevOps and Bitbucket projects in Semgrep AppSec Platform.
  • Allows the Semgrep platform to generate hyperlinks to code in findings.

If your organization uses both GitHub and GitLab to manage source code, log in with the source code manager that you would prefer to use to manage Semgrep org membership. You can still scan repositories from other sources, including Azure DevOps and Bitbucket, though you will need to use a separate SSO provider to manage the authentication of your users in such cases.

The process to connect a source code manager depends on whether your SCM tool is cloud-hosted by the service provider, hosted on-premise, or hosted as a single tenant by the service provider.

Connect to cloud-hosted orgs

If you opted to scan a GitHub or GitLab repository when you initially signed in, you may have already performed these steps and can skip to Next steps.

Azure DevOps Cloud

  1. Sign in to Semgrep AppSec Platform.
  2. On the sidebar, click the account name to open the drop-down menu.
  3. Using the drop-down menu, select the account you want to make a connection for.
  4. Go to Settings > Source Code Managers, and click Add Azure DevOps. Source code manager tab
  5. In the Connect your Azure DevOps organization dialog box, provide:
  6. Click Connect to save and proceed.
  7. The Azure DevOps organization is now listed under Source Code managers. Click Test connection to verify that the new integration is installed correctly.

Bitbucket Cloud

  1. Sign in to Semgrep AppSec Platform.
  2. On the sidebar, click the account name to open the drop-down menu.
  3. Using the drop-down menu, select the account you want to make a connection for.
  4. Go to Settings > Source Code Managers, and click Add Bitbucket Cloud. Source code manager tab
  5. In the Connect your Bitbucket Workspace dialog box, provide:
  6. Click Connect to save and proceed.
  7. The Bitbucket project is now listed under Source Code organizations. Click Test connection to verify that the new integration is installed correctly.

GitHub Cloud

  1. Sign in to Semgrep AppSec Platform.
  2. On the sidebar, click the organization account you want to make a connection for.
  3. Click Settings > Source Code Managers. Source code manager tab
  4. Click Connect to GitHub.
  5. Review the permissions requested by Semgrep, then click Continue.
  6. Click the organization you want to install Semgrep on.
  7. Choose to authorize and install Semgrep for All repositories or Only select repositories.
  8. Click Install and authorize.
  9. After a successful link, you are signed out of Semgrep AppSec Platform automatically, as your credentials have changed after linking an organization.
  10. Sign back in to Semgrep AppSec Platform.

You have successfully connected an org in Semgrep AppSec Platform with an organization in your source code management tool.

GitLab Cloud

  1. Create a PAT by following the steps outlined in this guide to creating a PAT. Ensure that the PAT is created with the required api scope.
  2. Sign in to Semgrep AppSec Platform.
  3. Click Settings > Source Code Managers > Add GitLab Cloud and enter the personal access token generated into the Access token field.
  4. Enter your GitLab group's name into the Name of your GitLab Group field. If your repositories are organized in subgroups, you only need to provide the name of the top-level group.
  5. If you have multiple GitLab groups in your GitLab account, you need to create a source code manager per group. Repeat steps 1, 3-4 for each GitLab group.
  6. The GitLab groups are now listed under Source Code organizations. Click Test connection to verify that the new integration is installed correctly.

Connect to on-premise orgs and projects

Bitbucket Data Center

  1. Sign in to Semgrep AppSec Platform.
  2. Go to Settings > Source Code Managers, and click Add Bitbucket Data Center. Source code manager tab
  3. In the Connect your Bitbucket project (key) dialog box, provide:
  4. Click Connect to save and proceed.
  5. The Bitbucket project is now listed under Source Code organizations. Click Test connection to verify that the new integration was installed correctly.

GitHub Enterprise Server

This section is applicable to users on a GitHub Enterprise Server plan.

The Semgrep App for GitHub Enterprise (GHE) creates a connection between Semgrep and orgs in your GHE deployment. There are two primary installation steps:

  1. Install the Semgrep App for the first time using the GHE organization (org) that "owns" the app.
  2. Install the app for additional GHE orgs.

Initial Semgrep App installation

If your deployment contains many orgs, you must choose an org in the deployment that acts as the owner of the Semgrep App. As the owner, this org controls the settings and permissions granted to the app.

  1. Log in to Semgrep AppSec Platform.
  2. Click Settings > Source Code Managers, and click Add GitHub Enterprise.
  3. In the Connect your GitHub Organization dialog box, provide:
    • The Name of your GitHub Organization
    • The URL to access your deployment
  4. Click Connect to save your changes.
  5. In the Add GitHub App page that you're redirected to, ensure that:
    • You've selected Organization.
    • The GitHub Organization name is populated; if not, enter the name of your org.
    • You've selected the Use for multiple GitHub orgs (Enterprise-public app) checkbox.
  6. Select the features you'd like enabled. Enabling PR comments, Assistant recommendations, and Semgrep Managed Scans requires you to grant Semgrep Code Access, while enabling only PR comments does not.
  7. Review the permissions for the app; as the app owner, note that you can change these permissions later.
  8. Click Register GitHub App to proceed.
  9. You are taken to your GHE instance and asked to name your app. You can choose whatever name you'd like, but Semgrep recommends that you name it something that indicates that this is the Semgrep GHE app.
  10. After you name your app, choose the GHE org to which you want it installed.
  11. Select the org that you want to act as the owner of the app, and click Install.
  12. Wait for the installation to complete. When done, you will be redirected to Semgrep.
  13. Verify the installation by navigating to Settings > Source Code Managers. Ensure that the entry for your SCM shows a Connected badge.
  14. In GHE, you should see the app listed as installed on the GitHub Apps page. GHE showing installed Semgrep App You can click Configure to choose the repositories to which the app has access. Additionally, you can go to App settings to customize the permissions granted to the app. GitHub Apps page showing App settings link
  15. If you have additional GHE orgs you'd like to add, you can do so by repeating steps 2-15.

At this point, you've successfully installed the GHE Semgrep App on the owner GHE org. In the future, other members of your GHE instance can install the app on their GHE orgs using the public link if they have the proper permissions. You can get the public link from GHE by going to GitHub Apps > App settings.

App installation page

Install the app for subsequent GHE orgs

You can install the Semgrep app onto additional GHE orgs at any time. To do so:

  1. Go to the public link for the app shared with you by your admin. Click Install. App installation page
  2. Choose the GHE org to which you want the app installed, and click Install. Org list
  3. In the popup confirmation message, click Install. GitHub installation prompt
  4. The GHE org should now be listed under Source code organizations. Source code organizations list

You have successfully connected Semgrep to your GitHub Enterprise Server.

GitLab Self-Managed Plans

This section is applicable to users with subscriptions to any GitLab self-managed plan.

Connect Semgrep and GitLab Self-Managed accounts by creating a PAT and providing it to Semgrep using Semgrep AppSec Platform:

  1. Create a PAT by following the steps outlined in this guide to creating a PAT. Ensure that the PAT is created with the required api scope.
  2. Sign in to Semgrep AppSec Platform.
  3. Click Settings > Source Code Managers > Add GitLab Self-Managed and enter the personal access token generated into the Access token field.
  4. Enter your GLSM base URL into the URL field.
  5. Enter your GitLab group's name into the Name of your GitLab Group field. If your repositories are organized in subgroups, you only need to provide the name of the top-level group.
  6. If you have multiple GitLab groups in your GitLab account, you need to create a source code manager per group. Repeat steps 1, 3-5 for each GitLab group.
  7. The GitLab groups are now listed under Source Code organizations. Click Test connection to verify that the new integration is installed correctly.

Next steps

  • Optional: If you want to set up SSO to manage your users, see SSO authentication.
  • You are ready to scan your org's repositories with Semgrep.

Not finding what you need in this doc? Ask questions in our Community Slack group, or see Support for other ways to get help.