Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix c-0077 c-0076 #518

Closed
wants to merge 8 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion ControlID_RuleName.csv
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ C-0073,naked-pods
C-0074,containers-mounting-docker-socket
C-0075,image-pull-policy-is-not-set-to-always
C-0076,label-usage-for-resources
C-0077,K8s common labels usage
C-0077,k8s-common-labels-usage
C-0078,container-image-repository
C-0079,CVE-2022-0185
C-0081,CVE-2022-24348
Expand Down
2 changes: 1 addition & 1 deletion controls/C-0077-k8scommonlabelsusage.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
"description": "Kubernetes common labels help manage and monitor Kubernetes cluster using different tools such as kubectl, dashboard and others in an interoperable way. Refer to https://kubernetes.io/docs/concepts/overview/working-with-objects/common-labels/ for more information. This control helps you find objects that don't have any of these labels defined.",
"remediation": "Define applicable labels or use the exception mechanism to prevent further notifications.",
"rulesNames": [
"K8s common labels usage"
"k8s-common-labels-usage"
],
"long_description": "Kubernetes common labels help manage and monitor Kubernetes cluster using different tools such as kubectl, dashboard and others in an interoperable way. Refer to https://kubernetes.io/docs/concepts/overview/working-with-objects/common-labels/ for more information. This control helps you find objects that don't have any of these labels defined.",
"test": "Test will check if the list of label that start with app.kubernetes.io/ are defined.",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,23 +86,26 @@ no_K8s_label_usage(wl, podSpec, beggining_of_pod_path) = path{

no_K8s_label_or_no_K8s_label_usage(wl, beggining_of_path) = path{
not wl.metadata.labels
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
}

no_K8s_label_or_no_K8s_label_usage(wl, beggining_of_path) = path{
metadata := wl.metadata
not metadata.labels
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
label_key := get_label_key("")
path = [{"path": sprintf("%vmetadata.labels.%v", [beggining_of_path, label_key]), "value": "YOUR_VALUE"}]
}

no_K8s_label_or_no_K8s_label_usage(wl, beggining_of_path) = path{
labels := wl.metadata.labels
not all_kubernetes_labels(labels)
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
label_key := get_label_key("")
path = [{"path": sprintf("%vmetadata.labels.%v", [beggining_of_path, label_key]), "value": "YOUR_VALUE"}]
}

all_kubernetes_labels(labels){
recommended_labels := data.postureControlInputs.k8sRecommendedLabels
recommended_label := recommended_labels[_]
labels[recommended_label]
}

# get_label_key accepts a parameter so it's not considered a rule
get_label_key(unused_param) = key {
recommended_labels := data.postureControlInputs.k8sRecommendedLabels
count(recommended_labels) > 0
key := recommended_labels[0]
} else = "YOUR_LABEL"
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"name": "K8s common labels usage",
"name": "k8s-common-labels-usage",
"attributes": {
"armoBuiltin": true
},
Expand Down
8 changes: 8 additions & 0 deletions rules/k8s-common-labels-usage/test/cronjob/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"postureControlInputs": {
"k8sRecommendedLabels": [
"app.kubernetes.io/name",
"app.kubernetes.io/instance"
]
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"alertMessage": "the following cronjobs the kubernetes common labels are not defined: hello",
"failedPaths": [],
"fixPaths": [{
"path": "spec.jobTemplate.spec.template.metadata.labels",
"path": "spec.jobTemplate.spec.template.metadata.labels.app.kubernetes.io/name",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down
5 changes: 5 additions & 0 deletions rules/k8s-common-labels-usage/test/pod/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"postureControlInputs": {
"k8sRecommendedLabels": []
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"alertMessage": "in the following pod the kubernetes common labels are not defined: command-demo",
"failedPaths": [],
"fixPaths": [{
"path": "metadata.labels",
"path": "metadata.labels.YOUR_LABEL",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down
8 changes: 8 additions & 0 deletions rules/k8s-common-labels-usage/test/workload-fail/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"postureControlInputs": {
"k8sRecommendedLabels": [
"app.kubernetes.io/name",
"app.kubernetes.io/instance"
]
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"alertMessage": "Deployment: kubernetes-dashboard the kubernetes common labels are is not defined:",
"failedPaths": [],
"fixPaths": [{
"path": "spec.template.metadata.labels",
"path": "spec.template.metadata.labels.app.kubernetes.io/name",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down
15 changes: 12 additions & 3 deletions rules/label-usage-for-resources/raw.rego
Original file line number Diff line number Diff line change
Expand Up @@ -84,19 +84,22 @@ no_label_usage(wl, podSpec, beggining_of_pod_path) = path{

no_label_or_no_label_usage(wl, beggining_of_path) = path{
not wl.metadata
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
label_key := get_label_key("")
path = [{"path": sprintf("%vmetadata.labels.%v", [beggining_of_path, label_key]), "value": "YOUR_VALUE"}]
}

no_label_or_no_label_usage(wl, beggining_of_path) = path{
metadata := wl.metadata
not metadata.labels
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
label_key := get_label_key("")
path = [{"path": sprintf("%vmetadata.labels.%v", [beggining_of_path, label_key]), "value": "YOUR_VALUE"}]
}

no_label_or_no_label_usage(wl, beggining_of_path) = path{
labels := wl.metadata.labels
not is_desired_label(labels)
path = [{"path": sprintf("%vmetadata.labels", [beggining_of_path]), "value": "YOUR_VALUE"}]
label_key := get_label_key("")
path = [{"path": sprintf("%vmetadata.labels.%v", [beggining_of_path, label_key]), "value": "YOUR_VALUE"}]
}

is_desired_label(labels) {
Expand All @@ -105,3 +108,9 @@ is_desired_label(labels) {
labels[recommended_label]
}

# get_label_key accepts a parameter so it's not considered a rule
get_label_key(unused_param) = key {
recommended_labels := data.postureControlInputs.recommendedLabels
count(recommended_labels) > 0
key := recommended_labels[0]
} else = "YOUR_LABEL"
5 changes: 5 additions & 0 deletions rules/label-usage-for-resources/test/cronjob/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"postureControlInputs": {
"recommendedLabels": []
}
}
4 changes: 2 additions & 2 deletions rules/label-usage-for-resources/test/cronjob/expected.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@
"alertMessage": "the following cronjobs a certain set of labels is not defined: hello",
"failedPaths": [],
"fixPaths": [{
"path": "metadata.labels",
"path": "metadata.labels.YOUR_LABEL",
"value": "YOUR_VALUE"
}, {
"path": "spec.jobTemplate.spec.template.metadata.labels",
"path": "spec.jobTemplate.spec.template.metadata.labels.YOUR_LABEL",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down
8 changes: 8 additions & 0 deletions rules/label-usage-for-resources/test/pod/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"postureControlInputs": {
"recommendedLabels": [
"app",
"tier"
]
}
}
2 changes: 1 addition & 1 deletion rules/label-usage-for-resources/test/pod/expected.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"alertMessage": "in the following pods a certain set of labels is not defined: command-demo",
"failedPaths": [],
"fixPaths": [{
"path": "metadata.labels",
"path": "metadata.labels.app",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down
8 changes: 8 additions & 0 deletions rules/label-usage-for-resources/test/workload-fail/data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"postureControlInputs": {
"recommendedLabels": [
"app",
"tier"
]
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"alertMessage": "Deployment: kubernetes-dashboard a certain set of labels is not defined:",
"failedPaths": [],
"fixPaths": [{
"path": "spec.template.metadata.labels",
"path": "spec.template.metadata.labels.app",
"value": "YOUR_VALUE"
}],
"ruleStatus": "",
Expand Down