Manage access for GitOps Applications using labels
Harness uses role-based access control (RBAC) for managing user permissions platform wide. This extends to Harness GitOps as well. To learn more, go to RBAC in Harness
In addition to regular controls, access to GitOps applications can be controlled via label-based RBAC. This topic will teach you how it works, and how you can use it.
Before you begin
Ensure you are familiar with:
Why use label-based RBAC?
Label-based RBAC offers several advantages:
- Granular Control: Define permissions based on application characteristics rather than just names or namespaces.
- Scalability: Easily manage permissions for large numbers of applications.
- Consistency: Ensure uniform access policies across your entire application portfolio.
- Flexibility: Adapt to changing organizational structures and application architectures without major RBAC overhauls.
Implement label-based RBAC
Step 1: Define your labeling strategy
Before you start, define a consistent labeling strategy. For example:
- harness.io/env-type: [prod|staging|dev]
- harness.io/team: [frontend|backend|data]
- harness.io/criticality: [high|medium|low]
Step 2: Update your Application
Next, add a label to your GitOps Application. To do so, follow these steps:
- In your project, click GitOps.
- Click Applications, and select your application.
- In the options bar, select App Details.
- Add a Label that is consistent with your labeling strategy.
(Optional) Update your ApplicationSets
Instead of modifying your application directly, you can also modify your existing ApplicationSet templates to include the necessary labels. For example:
apiVersion: argoproj.io/v1alpha1
kind: ApplicationSet
metadata:
  name: my-apps
spec:
  generators:
  - list:
      elements:
      - name: app1
        env: prod
        team: frontend
      - name: app2
        env: dev
        team: backend
  template:
    metadata:
      name: '{{name}}'
      labels:
        harness.io/env-type: '{{env}}'
        harness.io/team: '{{team}}'
    spec:
      # ... rest of your application spec
Step 3: Create resource groups in Harness
Resource Groups in Harness allow you to group your applications. Here's how to create them:
- Navigate to Access Control > Resource Groups in your Project Settings.
- Click New Resource Group.
- Name your group and click Save.
- Select your Resources on the left. In this case you want Gitops > Applications.
- Select All and click on Save
You can also filter by labels by selecting By Label
Click Add
Add a label. Follow the labeling strategy you established in step 1. For example, a production application would have the label harness.io/env-type: [prod|staging|dev].
Click Add Application Labels.
Step 4: Create a role with permissions
Now, create roles that have specific permissions you want your users to have for a given resource group.
- Go to Access Control > Roles in your Project Settings.
- Click New Role.
- Name your role and click Save.
- Update your role permissions. In this case, you want to scroll down to GitOps and enable the following permissions:
- VIEW
- SYNC
 
Step 5: Bind roles and resource groups to users
Finally, assign the role and resource group you created to the user or user groups.
Once the binding is done, those users will be able to sync any applications that have the label you specified in the resource group in step 3!
Harness Default Labels
When applications are generated through appsets, Harness will apply some labels to associated the application with services and environments. You can use these labels:
- harness.io/envRef: Enter the environment id. Use this to associate your application with a Harness Environment.
- harness.io/serviceRef: Enter the service id. Use this to associate your application with a Harness Service.
Troubleshooting
Common issues and solutions:
- If the sync operation failed due to permissions issues:
- Check the user's role assignments in Harness.
- Verify application labels match the resource group filters.
 
- If the labels are not applying correctly:
- Ensure your PR pipeline scripts are executing correctly.
- Check for conflicts in your ApplicationSet definitions.
 
- If production changes bypass controls:
- Verify your Git hooks are installed and executable.
- Review your branch protection rules in your Git repository settings.