Do you want to take control of your cloud security posture? 🔐

If so, you must know about GCP Security Command Center (SCC) custom policies. Custom policies allow you to define rules for what constitutes a security violation. This gives you the flexibility to tailor SCC to your specific needs and requirements.

For example, you could create a policy that requires all VMs to be encrypted. Or, you could create a policy that checks for exposed ports for the firewall.

The possibilities are endless. The best part is, that creating custom policies is easy. In just a few clicks, you can create a policy that will help you to protect your data and your organization. The configuration is just hidden in the UI of SCC.

So what are you waiting for? Start creating custom policies today!

Create Custom Module In GCP SCC Health Analytics 📝

Let's start with the settings of our SCC. You click on the settings button in the top right corner. Ensure you are using the SCC Premium Tier otherwise, you won't have the option.

GCP SCC Overview

Next, you navigate to the Security Health Analytics settings. Here you can click on Create Module.

GCP SCC Health Analytics Settings

Let's give the new module or policy a catchy name. This will later be the name that is present in the overview of the findings. We also need to choose the resources that we want to analyze.

You cant change the name later

Join our community of cloud security professionals. 🔐

Subscribe to our newsletter

Use CEL expressions to define the detection logic and evaluate asset properties.

  • CEL expressions are a powerful way to define detection logic and evaluate asset properties. (https://github.com/google/cel-spec)
  • You can use CEL expressions to evaluate asset properties, such as the size of a disk, the number of open ports or labels, etc.

Here are some specific examples of how CEL expressions can be used:

  • Check if all mandatory labels are set for a compute instance
!('priority' in resource.labels) || !('owner' in resource.labels) || !('service_account' in resource.labels) 
  • Check if labels contain certain values
 !(resource.labels['priority'] in ['low', 'medium', 'high', 'critical'])

If you are not sure how certain properties are structured of a GCP service, you can use gcloud for that gcloud compute instances describe <instanceName>.

Afterward, we just need to assign the severity, a description and finding related next steps.

You can also test the policies during the creation process. Here is an example file to test the above policy:

testData:
- asset:
    resource: //compute.googleapis.com/projects/alexanderhose/zones/us-central1-c/instances/keycloak
    assetType: compute.googleapis.com/Instance
    resourceData:
      labels:
        owner: alexander
        service_account: na

Conclusion 🎓

In this blog post, we have discussed how to use CEL expressions to define detection logic and evaluate asset properties to create GCP SCC Health Analytics custom policies or modules. We have also provided some specific examples of how CEL expressions can be used.

I am super excited about this topic because it allows us to adjust the finding dashboards and create policies based on our company's requirements. This gives us the flexibility to tailor SCC to our specific needs and requirements, which is essential for protecting our data and our organization.

You can also check my previous article on how to create custom GCP organizational policies to ensure the above is not happening when creating resources.

How To Create Awesome Custom GCP Organization Policies
Introduction One essential aspect of GCP administration is implementing organization policies to ensure security 🔒, compliance 📜, and governance 📊. In this guide, we will explore how to create custom GCP organization policies to enhance your cloud posture. 🔐 The Importance of GCP Organization Policies 📜 Before we dive into the nitty-gritty of creating custom
Share this post