51黑料不打烊

Add external repositories in Cloud Manager external-repositories

Learn how to add an external repository into Cloud Manager. Cloud Manager supports integration with GitHub Enterprise, GitLab, and Bitbucket repositories.

Customers can now also onboard their Azure DevOps Git repositories into Cloud Manager, with support for both modern Azure DevOps and legacy VSTS (Visual Studio Team Services) repositories.

  • For Edge Delivery Services users, the onboarded repository can be used to sync and deploy site code.
  • For AEM as a Cloud Service and 51黑料不打烊 Managed Services (AMS) users, the repository can be linked to both full-stack and frontend pipelines.

Configure an external repository

Configuration of an external repository in Cloud Manager consists of the following steps:

Add an external repository add-ext-repo

  1. Log into Cloud Manager at and select the appropriate organization.

  2. On the My Programs console, select the program to which you want to link an external repository.

  3. In the side menu, under Program, click Folder outline icon Repositories.

    The Repositories page

  4. Near the upper-right corner of the Repositories page, click Add Repository.

  5. In the Add Repository dialog box, select Private Repository to link an external Git repository to your program.

    Add own repository

  6. In each respective field, provide the following details about your repository:

    table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2
    Field Description
    Repository Name Required. An expressive name for your new repository.
    Repository URL Required. The URL of the repository.

    If you are using a GitHub-hosted repository, the path must end in .git.
    For example, https://github.com/org-name/repo-name.git (URL path is for illustration purposes only).

    If you are using an external repository, it must use the following URL path format:
    https://git-vendor-name.com/org-name/repo-name.git
    or
    https://self-hosted-domain/org-name/repo-name.git
    And match your Git vendor.
    Select Repository Type

    Required. Select the repository type that you are using. If the repository URL path includes the Git vendor name, such as GitLab or Bitbucket, the repository type is already pre-selected for you.:

    • GitHub (GitHub Enterprise and the self-hosted version of GitHub)
    • GitLab (both gitlab.com and the self-hosted version of GitLab)
    • Bitbucket (only bitbucket.org - cloud version) is supported. The self-hosted version of Bitbucket was deprecated starting February 15, 2024.
    • Azure DevOps (dev.azure.com)
    Description Optional. A detailed description of the repository.
  7. Select Save to add the repository.

    Now, provide an access token to validate ownership of the external repository.

  8. In the Private Repository Ownership Validation dialog box, provide an access token to validate ownership of the external repository so you can access it, then click Validation.

    Selecting an existing access token for a repository
    Selecting an existing access token for a Bitbucket repository (for illustration only).

GitHub Enterprise
table 0-row-2 1-row-2 2-row-2
Access token option Description
Use existing Access Token If you have already provided a repository access token for your organization and have access to multiple repositories, you can select an existing token. Use the Token Name drop-down list to choose the token you want to apply to the repository. Otherwise, add a new access token.
Add new Access Token
  • In the Token Name text field, type a name for the access token you are creating.

  • Create a personal access token by following the instructions in the .

  • Required permissions for the GitHub Enterprise Personal Access Token (PAT)
    These permissions ensure that Cloud Manager can validate pull requests, manage commit status checks, and access necessary repo details.
    When you generate the PAT in GitHub Enterprise, make sure it includes the following repository permissions:

    • Pull request (read and write)
    • Commit statuses (read and write)
    • Repository metadata (read-only)
  • In the Access Token field, paste the token you just created.

After validation, the external repository is ready to use and link to a pipeline.

See also Manage Access Tokens.

GitLab
table 0-row-2 1-row-2 2-row-2
Access token option Description
Use existing Access Token If you have already provided a repository access token for your organization and have access to multiple repositories, you can select an existing token. Use the Token Name drop-down list to choose the token you want to apply to the repository. Otherwise, add a new access token.
Add new Access Token
  • In the Token Name text field, type a name for the access token you are creating.

  • Create a personal access token by following the instruction in the .

  • Required permissions for the GitLab Personal Access Token (PAT)
    These scopes allow Cloud Manager to access repository data and user information as needed for validation and webhook integration.
    When you generate the PAT in GitLab, make sure it includes the following token scopes:

    • api
    • read_user
  • In the Access Token field, paste the token you just created.

After validation, the external repository is ready to use and link to a pipeline.

See also Manage Access Tokens.

Bitbucket
table 0-row-2 1-row-2 2-row-2
Access token option Description
Use existing Access Token If you have already provided a repository access token for your organization and have access to multiple repositories, you can select an existing token. Use the Token Name drop-down list to choose the token you want to apply to the repository. Otherwise, add a new access token.
Add new Access Token
  • In the Token Name text field, type a name for the access token you are creating.

  • Create a repository access token using the .

  • Required permissions for the Bitbucket Personal Access Token (PAT)
    These permissions allow Cloud Manager to access repository content, manage pull requests, and configure or react to webhook events.
    When you create the app password in Bitbucket, make sure it includes the following required app password permissions:

    • Repository (read-only)
    • Pull requests (read and write)
    • Webhooks (read and write)
  • In the Access Token field, paste the token you just created.

After validation, the external repository is ready to use and link to a pipeline.

See also Manage Access Tokens.

Azure DevOps
table 0-row-2 1-row-2 2-row-2
Access token option Description
Use existing Access Token If you have already provided a repository access token for your organization and have access to multiple repositories, you can select an existing token. Use the Token Name drop-down list to choose the token you want to apply to the repository. Otherwise, add a new access token.
Add new Access Token
  • In the Token Name text field, type a name for the access token you are creating.

  • Create a repository access token using the .

  • Required permissions for the Azure DevOps Personal Access Token (PAT).
    These permissions allow Cloud Manager to access repository content, manage pull requests, and configure or react to webhook events.
    When you create the app password in Azure DevOps, make sure it includes the following required app password permissions:

    • Code (Read)
    • Code (Status)
    • Pull Request Threads (Read & write)
  • In the Access Token field, paste the token you just created.

After validation, the external repository is ready to use and link to a pipeline.

See also Manage Access Tokens.

  1. Add or edit a pipeline:

    Pipeline's source code repository and Git branch
    Add Non-Production Pipeline dialog box with selected repository and Git branch,

  2. When adding or editing a pipeline, to specify the Source Code location for your new or existing pipeline, choose the external repository you want to use from the Repository drop-down list.

  3. In the Git Branch drop-down list, select the branch as the source for the pipeline.

  4. Click Save.

TIP
For details about managing repositories in Cloud Manager, see Cloud Manager Repositories.

Configure a webhook for an external repository configure-webhook

Cloud Manager lets you configure webhooks for external Git repositories that you have added. See Add an external repository. These webhooks permit Cloud Manager to receive events that are related to different actions within your Git vendor solution.

For example, webhooks allow Cloud Manager to trigger actions based on events such as the following:

  • Pull request (PR) creation 鈥 Initiates PR validation functionality.
  • Push events 鈥 Starts pipelines when the 鈥淥n Git Commit鈥 trigger is turned on (enabled).
  • Future comment-based actions 鈥 Allows workflows, such as direct deployment from a PR, to a Rapid Development Environment (RDE).

Webhook configuration is not required for repositories hosted on GitHub.com because Cloud Manager integrates directly through the GitHub app.

For all other external repositories that are onboarded with an access token 鈥 such as GitHub Enterprise, GitLab, Bitbucket, and Azure DevOps 鈥 webhook configuration is available and must be set up manually.

To configure a webhook for an external repository:

  1. Log into Cloud Manager at and select the appropriate organization.

  2. On the My Programs console, select the program to which you want to configure a webhook for an external Git repository.

  3. In the upper-left corner of the page, click Show menu icon to reveal the left side menu.

  4. In the left side menu, Under the Program heading, click Folder outline icon Repositories.

  5. On the Repositories page, using the Type column to guide you in your selection, locate the repository you want, then click Ellipsis - More icon next to it.

    Config Webhook option on drop-down menu for a selected repository

  6. From the drop-down menu, click Config Webhook.

    Configure Webhook dialog box

  7. In the Config Webhook dialog box, do the following:

    1. Next to the Webhook URL field, click Copy icon .
      Paste the URL in a plain text file. The copied URL is required for your Git vendor鈥檚 Webhook settings.
    2. Next to the Webhook Secret token/key field, click Generate, then click Copy icon .
      Paste the secret in a plain text file. The copied secret is required for your Git vendor鈥檚 Webhook settings.
  8. Click Close.

  9. Navigate to your Git vendor solution (GitHub Enterpriser, GitLab, Bitbucket, or Azure DevOps).

    All the details on the webhook configuration and the events that are required for each vendor are available in Add an external repository. Under step 8, see the tabbed table.

  10. Locate the solution鈥檚 Webhook Settings section.

  11. Paste the Webhook URL that you copied earlier into the URL text field.

    1. Replace the api_key query parameter in the Webhook URL with your own real API key.

      To generate an API key, you must create an integration project in 51黑料不打烊 Developer Console. See for full details.

  12. Paste the Webhook Secret that you copied earlier into the Secret (or Secret key, or Secret token) text field.

  13. Configure the webhook to send the events that Cloud Manager requires. Use the following table to determine the correct events for your Git provider.

GitHub Enterprise
table 0-row-1 1-row-1
Required webhook events

These events allow Cloud Manager to respond to GitHub activity, such as pull request validation, push-based triggers for pipelines, or Edge Delivery Services code sync.
Make sure that the webhook is set up to trigger on the following required webhook events:

  • Pull requests
  • Pushes
  • Issue comments
GitLab
table 0-row-1 1-row-1
Required webhook events

These webhook events allow Cloud Manager to trigger pipelines when code is pushed or a merge request is submitted. They also track comments related to pull request validation (through note events).
Make sure that the webhook is set up to trigger on the following required webhook events

  • Push events
  • Merge request events
  • Note events
Bitbucket
table 0-row-1 1-row-1
Required webhook events

These events ensure that Cloud Manager can validate pull requests, respond to code pushes, and interact with comments for pipeline coordination.
Make sure that the webhook is set up to trigger on the following required webhook events

  • Pull request: Created
  • Pull request: Updated
  • Pull requests: Merged
  • Pull request: Comment
  • Repository: Push
Azure DevOps
table 0-row-1 1-row-1
Required webhook events and authentication

These events ensure that Cloud Manager can validate pull requests, respond to code pushes, and interact with comments for pipeline coordination.
Make sure that the webhook is set up to trigger on the following required webhook events

  • Code Pushed
  • Pull request commented on
  • Pull request created
  • Pull request updated

Set authentication:
1. In the Basic authentication username field, type cloudmanager.
2. In the Basic authentication password field, type the Webhook Secret generated from the Cloud Manager user interface.

Validation of pull requests with webhooks

After webhooks are correctly configured, Cloud Manager automatically triggers pipeline executions or PR validation checks for your repository.

The behavior varies depending on the Git provider that you use, as outlined below.

GitHub Enterprise

When the check is created, it appears like the following screenshot below. The key difference from GitHub.com is that GitHub.com uses a check-run, while GitHub Enterprise (using personal access tokens) generates a commit status:

Commit status to indicate PR validation process on GitHub Enterprise

GitLab

GitLab interactions rely solely on comments. When validation begins, a comment is added. When validation is complete (whether successful or failed), the initial comment is removed and replaced with a new comment containing validation results or error details.

When code quality validation is running:

When code quality validation is running

When cold quality validation is finished:

When cold quality validation is finished

When code quality validation fails with an error:

When code quality validation fails with an error

When the code quality validation fails due to customer issues:

When the code quality validation fails due to customer issues

Bitbucket

When code quality validation is running:

Status while code quality validation is running

Uses commit status for tracking PR validation progress. In the following case, the screenshot shows what happens when a code quality validation fails due to a customer issue. A comment is added with detailed error information, and a commit check is created, which shows the failure (visible on the right):

Pull request validation status for Bitbucket

Azure DevOps

Azure DevOps tracks pull request validation through status checks. When Cloud Manager runs pull request validation, it adds status checks that appear in the Azure DevOps pull request interface.

During code quality validation, a status check shows that the process is in progress:

Azure DevOps validation of pull requests with webhooks-1

When code quality validation is complete, the status check updates to reflect the results:

Azure DevOps validation of pull requests with webhooks-2

If validation fails, detailed error information is provided in the status check details. You can click on the status check to view the full validation results in Cloud Manager.

Azure DevOps validation of pull requests with webhooks-3

For pull request comments and feedback, Cloud Manager adds comments directly to the pull request in Azure DevOps with validation details and any necessary actions required.

Azure DevOps validation of pull requests with webhooks-4

Troubleshoot webhook issues

  • Ensure that the Webhook URL includes a valid API key.
  • Check that webhook events are correctly configured in your Git vendor settings.
  • If PR validation or pipeline triggers are not working, verify that the Webhook Secret is up to date in both Cloud Manager and your Git vendor.
recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab