Skip to content

Commit

Permalink
fix checks related to security groups
Browse files Browse the repository at this point in the history
Signed-off-by: Nikita Pivkin <nikita.pivkin@smartforce.io>
  • Loading branch information
nikpivkin authored and simar7 committed Dec 6, 2024
1 parent 22b28f5 commit f1ca50e
Show file tree
Hide file tree
Showing 8 changed files with 73 additions and 7 deletions.
18 changes: 17 additions & 1 deletion checks/cloud/aws/ec2/add_description_to_security_group_rule.rego
Original file line number Diff line number Diff line change
Expand Up @@ -41,19 +41,35 @@ import rego.v1
import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
rules := [
rule |
some group in input.aws.ec2.securitygroups
some rule in array.concat(
object.get(group, "egressrules", []),
object.get(group, "ingressrules", []),
)
]

deny contains res if {
some rule in rules
isManaged(rule)
without_description(rule)
res := result.new(
"Security group rule does not have a description.",
metadata.obj_by_path(rule, ["description"]),
)
}

deny contains res if {
some rule in rules
isManaged(rule)
rule.description.value == "Managed by Terraform"
res := result.new(
"Security group explicitly uses the default description.",
rule.description,
)
}

without_description(rule) if value.is_empty(rule.description)

without_description(rule) if not rule.description
Original file line number Diff line number Diff line change
Expand Up @@ -39,13 +39,24 @@ import data.lib.cloud.value

deny contains res if {
some secgroup in input.aws.elasticache.securitygroups
isManaged(secgroup)
without_description(secgroup)
res := result.new(
"Security group does not have a description.",
metadata.obj_by_path(secgroup, ["description"]),
)
}

deny contains res if {
some secgroup in input.aws.elasticache.securitygroups
isManaged(secgroup)
secgroup.description.value == "Managed by Terraform"
res := result.new(
"Security group explicitly uses the default description.",
secgroup.description,
)
}

without_description(sg) if value.is_empty(sg.description)

without_description(sg) if not sg.description
14 changes: 13 additions & 1 deletion checks/cloud/aws/redshift/add_description_to_security_group.rego
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,26 @@ package builtin.aws.redshift.aws0083

import rego.v1

import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
some group in input.aws.redshift.securitygroups
isManaged(group)
without_description(group)
res := result.new(
"Security group has no description.",
object.get(group, "description", group),
metadata.obj_by_path(group, ["description"]),
)
}

deny contains res if {
some group in input.aws.redshift.securitygroups
isManaged(group)
group.description.value == "Managed by Terraform"
res := result.new(
"Security group explicitly uses the default description.",
group.description,
)
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,16 +34,22 @@ package builtin.nifcloud.computing.nifcloud0002

import rego.v1

import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
some sg in input.nifcloud.computing.securitygroups
isManaged(sg)
without_description(sg)
res := result.new("Security group does not have a description.", sg.description)
res := result.new(
"Security group does not have a description.",
metadata.obj_by_path(sg, ["description"]),
)
}

deny contains res if {
some sg in input.nifcloud.computing.securitygroups
isManaged(sg)
sg.description.value == "Managed by Terraform"
res := result.new("Security group explicitly uses the default description.", sg.description)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,18 @@ import rego.v1
import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
rules := [
rule |
some sg in input.nifcloud.computing.securitygroups
some rule in array.concat(
object.get(sg, "ingressrules", []),
object.get(sg, "egressrules", []),
)
]

deny contains res if {
some rule in rules
isManaged(rule)
without_description(rule)
res := result.new(
"Security group rule does not have a description.",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,18 +34,27 @@ package builtin.nifcloud.nas.nifcloud0015

import rego.v1

import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
some sg in input.nifcloud.nas.nassecuritygroups
isManaged(sg)
without_description(sg)
res := result.new("NAS security group does not have a description.", sg.description)
res := result.new(
"NAS security group does not have a description.",
metadata.obj_by_path(sg, ["description"]),
)
}

deny contains res if {
some sg in input.nifcloud.nas.nassecuritygroups
isManaged(sg)
sg.description.value == "Managed by Terraform"
res := result.new("NAS security group explicitly uses the default description.", sg.description)
res := result.new(
"NAS security group explicitly uses the default description.",
sg.description,
)
}

without_description(sg) if value.is_empty(sg.description)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,12 +38,14 @@ import data.lib.cloud.value

deny contains res if {
some sg in input.nifcloud.rdb.dbsecuritygroups
isManaged(sg)
without_description(sg)
res := result.new("DB security group does not have a description.", sg.description)
}

deny contains res if {
some sg in input.nifcloud.rdb.dbsecuritygroups
isManaged(sg)
sg.description.value == "Managed by Terraform"
res := result.new("DB security group explicitly uses the default description.", sg.description)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,12 +26,17 @@ package builtin.openstack.networking.openstack0005

import rego.v1

import data.lib.cloud.metadata
import data.lib.cloud.value

deny contains res if {
some sg in input.openstack.networking.securitygroups
isManaged(sg)
without_description(sg)
res := result.new("Network security group does not have a description.", sg.description)
res := result.new(
"Network security group does not have a description.",
metadata.obj_by_path(sg, ["description"]),
)
}

without_description(sg) if value.is_empty(sg.description)
Expand Down

0 comments on commit f1ca50e

Please sign in to comment.