This configuration reference is intended to help you manage the custom resources created by the rancher-cis-benchmark application. These resources are used for performing CIS scans on a cluster, skipping tests, setting the test profile that will be used during a scan, and other customization.

To configure the custom resources, go to the Cluster Explorer in the Rancher UI. In dropdown menu in the top left corner, click Cluster Explorer > CIS Benchmark.

Scans

A scan is created to trigger a CIS scan on the cluster based on the defined profile. A report is created after the scan is completed.

When configuring a scan, you need to define the name of the scan profile that will be used with the scanProfileName directive.

An example ClusterScan custom resource is below:

  1. apiVersion: cis.cattle.io/v1
  2. kind: ClusterScan
  3. metadata:
  4. name: rke-cis
  5. spec:
  6. scanProfileName: rke-profile-hardened

Profiles

A profile contains the configuration for the CIS scan, which includes the benchmark version to use and any specific tests to skip in that benchmark.

By default, a few ClusterScanProfiles are installed as part of the rancher-cis-benchmark chart. If a user edits these default benchmarks or profiles, the next chart update will reset them back. So it is advisable for users to not edit the default ClusterScanProfiles.

Users can clone the ClusterScanProfiles to create custom profiles.

Skipped tests are listed under the skipTests directive.

When you create a new profile, you will also need to give it a name.

An example ClusterScanProfile is below:

  1. apiVersion: cis.cattle.io/v1
  2. kind: ClusterScanProfile
  3. metadata:
  4. annotations:
  5. meta.helm.sh/release-name: clusterscan-operator
  6. meta.helm.sh/release-namespace: cis-operator-system
  7. labels:
  8. app.kubernetes.io/managed-by: Helm
  9. name: "<example-profile>"
  10. spec:
  11. benchmarkVersion: cis-1.5
  12. skipTests:
  13. - "1.1.20"
  14. - "1.1.21"

Benchmark Versions

A benchmark version is the name of benchmark to run using kube-bench, as well as the valid configuration parameters for that benchmark.

A ClusterScanBenchmark defines the CIS BenchmarkVersion name and test configurations. The BenchmarkVersion name is a parameter provided to the kube-bench tool.

By default, a few BenchmarkVersion names and test configurations are packaged as part of the CIS scan application. When this feature is enabled, these default BenchmarkVersions will be automatically installed and available for users to create a ClusterScanProfile.

If the default BenchmarkVersions are edited, the next chart update will reset them back. Therefore we don’t recommend editing the default ClusterScanBenchmarks.

A ClusterScanBenchmark consists of the fields:

  • ClusterProvider: This is the cluster provider name for which this benchmark is applicable. For example: RKE, EKS, GKE, etc. Leave it empty if this benchmark can be run on any cluster type.
  • MinKubernetesVersion: Specifies the cluster’s minimum kubernetes version necessary to run this benchmark. Leave it empty if there is no dependency on a particular Kubernetes version.
  • MaxKubernetesVersion: Specifies the cluster’s maximum Kubernetes version necessary to run this benchmark. Leave it empty if there is no dependency on a particular k8s version.

An example ClusterScanBenchmark is below:

  1. apiVersion: cis.cattle.io/v1
  2. kind: ClusterScanBenchmark
  3. metadata:
  4. annotations:
  5. meta.helm.sh/release-name: clusterscan-operator
  6. meta.helm.sh/release-namespace: cis-operator-system
  7. creationTimestamp: "2020-08-28T18:18:07Z"
  8. generation: 1
  9. labels:
  10. app.kubernetes.io/managed-by: Helm
  11. name: cis-1.5
  12. resourceVersion: "203878"
  13. selfLink: /apis/cis.cattle.io/v1/clusterscanbenchmarks/cis-1.5
  14. uid: 309e543e-9102-4091-be91-08d7af7fb7a7
  15. spec:
  16. clusterProvider: ""
  17. minKubernetesVersion: 1.15.0