Set up bidirectional sync for Git Experience
By default, Harness Git Experience syncs unidirectionally, from Harness to your Git repos. You can also have Harness Git Experience sync bidirectionally between Harness and your Git repo.
With bidirectional sync for Git Experience, changes made on either the Git repo or Harness are synced automatically.
This topic explains how to set up and use bidirectional sync.
Supported Entities
Generally Available
- Pipelines
- Templates
- Input Sets
- Services
- Environments
- Infrastructure
Important notes
- If users make changes on the Harness and Git side at the same time, precedence is given on a first come, first served basis.
- If you make an invalid YAML change to the YAML in the Git repo file an Invalid YAML Detected error appears in the Harness UI. You can fix the invalid YAML in Harness or in the Git repo.
- If your Git repo server is on-premise, it must have connectivity to Harness SaaS.
- Currently, only .yamland.ymlfiles are supported for bi-directional sync.
- When configuring a webhook, you need to be the owner of the relevant git repository.
- Bidirectional sync is not supported for Harness Code.
- If a change is made to a Git-backed entity directly in the Git repository with bidirectional sync enabled, it will bypass On SaveOPA policies. To ensure these entities comply with your OPA policies, define your policies asOn Runfor these entities.
Bi-directional Sync
GitX supports bi-directional sync by capturing changes committed directly to Git using webhook events. With bi-directional sync enabled, Harness treats its own cached copy of Git data as the source of truth, and uses this cached data for all operations—including pipeline execution.
This ensures fast, consistent execution of remote pipelines based on the latest committed changes received through webhooks.
Webhook Registration
Harness attempts to register webhooks automatically for GitX resources using the Git connector associated with the entity (e.g., pipeline, input set). This removes the need for most manual setup and helps prevent outdated pipeline configurations.
Automatic webhook registration follows these principles:
- Webhooks are registered using the same connector that was used to create the entity.
- Registration is performed on a best-effort basis:
- If the connector has sufficient permissions (e.g., admin:repo_hookfor GitHub), the webhook is created.
- If not, the operation is skipped, and users can manually register the webhook.
 
- If the connector has sufficient permissions (e.g., 
- Harness does not create duplicate webhooks:
- A webhook is only registered if one doesn't already exist for the given entity.
 
- Webhooks are registered at the nearest matching scope:
- For example, if an entity is created at the org level, the webhook is registered at the org level.
 
Disable Automatic Webhook Registration
By default, Harness attempts to register webhooks automatically for GitX entities using the associated Git connector. If your organization prefers to manage webhook registration externally, you can now disable webhook creation entirely from the Harness platform.
Skip Git Webhook Registration Setting
To disable automatic webhook registration:
- Go to Account Settings → Git Experience Settings.
- Enable the Skip Git Webhook Registration checkbox.
- Save your changes.
When this setting is enabled:
- Harness will not attempt to create or validate webhooks in your Git provider.
- When creating Git triggers, you will see a message indicating that webhook registration is skipped.
- You are responsible for manually creating and managing webhooks in your Git system.
This is useful for organizations that:
- Do not allow outbound connections or webhook creation from Harness.
- Use Git systems like GitLab with restricted permissions or intermediaries.
- Need full control over webhook behavior without triggering permission issues.
Here is an example of the message displayed during Git Webhook creation when this setting is enabled.

Manual Webhook Setup for Bi-directional Sync
There are three ways to manually set up a webhook when automatic registration is not preferred or not possible.
Setup Webhook via Banner Prompt
When an entity is not set up for bidirectional sync (that is, no webhook is registered for the corresponding Git repo or file path), Harness displays a banner to simplify webhook registration.
To register a webhook:
- Click Setup Webhook on the banner.
- Harness automatically registers the webhook using the same Git connector that was used when the entity was created.
- Upon success, a confirmation message appears.

When using Git Experience with GitHub in bidirectional sync mode, merging a commit with 300 or more files may cause some files to not sync properly in the GitEx cache. This is due to GitHub API limitations, which parse up to 300 files between two commits. Customers may see that the webhook payload lists a full list of files, but only 300 will be processed.
Additionally, such large merges has the potential to increase the possibility of hitting the GitHub API rate limit. This is due to the fact that each commit has three API calls correlated to each file transfer, and if multiple files across multiple pipelines are being committed at the same time, it can increase the possibility of a rate-limit situation.
It is recommended to keep the number of files in a single commit below 300 to ensure consistency and avoid potential rate limit issues.
To successfully register a webhook, ensure that the Harness Git connector you use has the necessary credentials. For example, when using GitHub, the GitHub user account must be a repo admin, and the Personal Access Token must include all repo, user, and admin:repo_hook scopes.
It is important to note that if you use a banner to set up the webhook, it will use the same connector that was used during the entity creation to create the webhook. Therefore, ensure that the connector has adequate permissions.

To view registered webhooks:
Project Settings → Project-level Resources → Webhooks

You can also explore Git Sync Activity to track webhook events.
Setup via Webhooks Page
If you want full control over webhook setup or if banner setup was skipped:
Choose the Scope
- Account Level:
 Account Settings → Account-level Resources → Webhooks → New Webhook
- Organization Level:
 Organization Resources → Organization-level Resources → Webhooks → New Webhook
- Project Level:
 Project Settings → Project-level Resources → Webhooks → New Webhook
Webhook Configuration Steps
- 
In Git Connector, select or create a Git Connector. 
- 
In Repository, select the Git repo where your Harness entities are stored. 
- 
In Folder Path, specify the directory (e.g., .harness/). This is optional. 
Harness tracks the .harness folder by default in all webhooks.
- Click Add to register the webhook.
Once synced, Git events appear in the Events tab under Webhooks, including event IDs for troubleshooting.
Sync a Harness entity
For this example, we'll create a new remote pipeline, sync it with the repo, make a change on the Git side, and then see the change on the Harness side.
- In Harness, in Pipelines, select Create a Pipeline.
- In How do you want to setup your pipeline?, select Remote.
- Specify the Git Connector, Repository, and Git branch for storing and syncing the pipeline.
- In YAML Path, you can enter the path to a repo folder where, if needed.
- Select Start. The pipeline is created.
- Add a CD or Custom stage to the pipeline and save it.
- In your repo, confirm that the YAML file for the pipeline exists.
- In your repo, open the YAML file for the pipeline and commit a change. For example, add a description.
- Back in Harness, review the pipeline to see the changes.
Troubleshooting
Harness provides the following troubleshooting features to help you diagnose sync errors:
- 
Webhooks page: In Account Settings, Account Resources, Webhooks, you can select the webhook for your Harness entity sync and view each event on the Events tab. For each event, you can select Payload Details to see the payload. 
- 
View Webhook Events: in the Git information on your Harness entity, you can select View Webhook Events and see each event and payload for that entity.  
- 
You can view the audit trail for webhooks that were created, deleted, or when webhook was enabled or disabled. 
