Skip to content

Commit

Permalink
Merge pull request Checkmarx#6863 from Checkmarx/kics-1145
Browse files Browse the repository at this point in the history
feat(query): cloud formation api gateway access logging disabled
  • Loading branch information
asofsilva authored Feb 26, 2024
2 parents ca21626 + c04b09c commit be96e52
Show file tree
Hide file tree
Showing 27 changed files with 553 additions and 178 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"id": "80d45af4-4920-4236-a56e-b7ef419d1941",
"queryName": "API Gateway Stage Access Logging Settings Not Defined",
"queryName": "API Gateway Access Logging Disabled",
"severity": "MEDIUM",
"category": "Observability",
"descriptionText": "API Gateway Stage should have Access Logging Settings defined",
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,170 @@
package Cx

import data.generic.common as common_lib
import data.generic.cloudformation as cf_lib

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGatewayV2::Stage"

properties := resource.Properties
searchKeyValid := validNonEmptyKey(properties, "DefaultRouteSettings")

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties%s", [name, searchKeyValid]),
"issueType": "MissingAttribute",
"keyExpectedValue": sprintf("Resources.%s.Properties.DefaultRouteSettings should be defined and not null", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.DefaultRouteSettings are undefined or null", [name]),
}
}

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGatewayV2::Stage"

properties := resource.Properties
defaultRouteSettings := properties.DefaultRouteSettings
searchKeyValid := validNonEmptyKey(defaultRouteSettings, "LoggingLevel")

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties.DefaultRouteSettings%s", [name, searchKeyValid]),
"issueType": "MissingAttribute",
"keyExpectedValue": sprintf("Resources.%s.Properties.DefaultRouteSettings.LoggingLevel should be defined and not null", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.DefaultRouteSettings.LoggingLevel are undefined or null", [name]),
}
}

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGatewayV2::Stage"

properties := resource.Properties
loggingLevel := properties.DefaultRouteSettings.LoggingLevel
loggingLevel == "OFF"

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties.DefaultRouteSettings.LoggingLevel", [name]),
"issueType": "IncorrectValue",
"keyExpectedValue": sprintf("Resources.%s.Properties.DefaultRouteSettings.LoggingLevel should not be set to OFF", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.DefaultRouteSettings.LoggingLevel is OFF", [name]),
}
}

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGateway::Stage"

properties := resource.Properties
searchKeyValid := validNonEmptyKey(properties, "MethodSettings")

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties%s", [name, searchKeyValid]),
"issueType": "MissingAttribute",
"keyExpectedValue": sprintf("Resources.%s.Properties.MethodSettings should be defined and not null", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.MethodSettings are undefined or null", [name]),
}
}

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGateway::Stage"

properties := resource.Properties
methodSettings := properties.MethodSettings
searchKeyValid := validNonEmptyKey(methodSettings, "LoggingLevel")

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties.MethodSettings%s", [name, searchKeyValid]),
"issueType": "MissingAttribute",
"keyExpectedValue": sprintf("Resources.%s.Properties.MethodSettings.LoggingLevel should be defined and not null", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.MethodSettings.LoggingLevel are undefined or null", [name]),
}
}

CxPolicy[result] {
document := input.document
resource = document[i].Resources[name]
resource.Type == "AWS::ApiGateway::Stage"

properties := resource.Properties
loggingLevel := properties.MethodSettings.LoggingLevel
loggingLevel == "OFF"

result := {
"documentId": input.document[i].id,
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, name),
"searchKey": sprintf("Resources.%s.Properties.MethodSettings.LoggingLevel", [name]),
"issueType": "IncorrectValue",
"keyExpectedValue": sprintf("Resources.%s.Properties.MethodSettings.LoggingLevel should not be set to OFF", [name]),
"keyActualValue": sprintf("Resources.%s.Properties.MethodSettings.LoggingLevel is OFF", [name]),
}
}

CxPolicy[result] {
doc := input.document[i]
resource := doc.Resources[stage]
resource.Type == "AWS::ApiGatewayV2::Stage"
properties := resource.Properties

not properties.AccessLogSettings

result := {
"documentId": doc.id,
"issueType": "MissingAttribute",
"keyExpectedValue": "'AccessLogSettings' should be defined",
"keyActualValue": "'AccessLogSettings' is not defined",
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, stage),
"searchKey": sprintf("Resources.%s.Properties", [stage]),
}
}

CxPolicy[result] {
doc := input.document[i]
resource := doc.Resources[stage]
resource.Type == "AWS::ApiGateway::Stage"
properties := resource.Properties

not properties.AccessLogSetting

result := {
"documentId": doc.id,
"issueType": "MissingAttribute",
"keyExpectedValue": "'AccessLogSetting' should be defined",
"keyActualValue": "'AccessLogSetting' is not defined",
"resourceType": resource.Type,
"resourceName": cf_lib.get_resource_name(resource, stage),
"searchKey": sprintf("Resources.%s.Properties", [stage]),
}
}

validNonEmptyKey(field, key) = output {
not common_lib.valid_key(field, key)
output = ""
} else = output {
keyObj := field[key]
is_object(keyObj)
count(keyObj) == 0
output := concat(".", ["", key])
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
{
"AWSTemplateFormatVersion": "2010-09-09",
"Resources": {
"MyStage": {
"Type": "AWS::ApiGateway::Stage",
"Properties": {
"StageName": "Prod",
"Description": "Prod Stage",
"AccessLogSetting": {
"DestinationArn": "dest",
"Format": "format"
},
"DeploymentId": {
"Ref": "MyDeployment"
},
"MethodSettings": {
"DetailedMetricsEnabled": true,
"LoggingLevel": "INFO",
"DataTraceEnabled": false,
"ThrottlingBurstLimit": 10,
"ThrottlingRateLimit": 10
},
"RestApiId": {
"Ref": "CFNWebSocket"
}
}
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Resources:
Prod:
Type: AWS::ApiGateway::Stage
Properties:
StageName: Prod
Description: Prod Stage
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
MethodSettings:
LoggingLevel: "ON"
AccessLogSetting:
DestinationArn: "dest"
Format: "format"
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ Resources:
Properties:
StageName: Prod
Description: Prod Stage
AccessLogSetting:
DestinationArn: "dest"
Format: "format"
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
{
"AWSTemplateFormatVersion": "2010-09-09",
"Resources": {
"MyStage": {
"Type": "AWS::ApiGateway::Stage",
"Properties": {
"StageName": "Prod",
"Description": "Prod Stage",
"AccessLogSetting": {
"DestinationArn": "dest",
"Format": "format"
},
"DeploymentId": {
"Ref": "MyDeployment"
},
"RestApiId": {
"Ref": "CFNWebSocket"
},
"MethodSettings": {
}
}
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
Resources:
Prod:
Type: AWS::ApiGateway::Stage
Properties:
StageName: Prod
Description: Prod Stage
AccessLogSetting:
DestinationArn: "dest"
Format: "format"
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
MethodSettings:
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
{
"AWSTemplateFormatVersion": "2010-09-09",
"Resources": {
"MyStage": {
"Type": "AWS::ApiGateway::Stage",
"Properties": {
"StageName": "Prod",
"Description": "Prod Stage",
"AccessLogSetting": {
"DestinationArn": "dest",
"Format": "format"
},
"DeploymentId": {
"Ref": "MyDeployment"
},
"RestApiId": {
"Ref": "CFNWebSocket"
},
"MethodSettings": {
"DetailedMetricsEnabled": true,
"LoggingLevel": "OFF",
"DataTraceEnabled": false,
"ThrottlingBurstLimit": 10,
"ThrottlingRateLimit": 10
}
}
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Resources:
Prod:
Type: AWS::ApiGatewayV2::Stage
Properties:
StageName: Prod
Description: Prod Stage
AccessLogSettings:
DestinationArn: "dest"
Format: "format"
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
ApiId: "teste"
DefaultRouteSettings:
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Resources:
Prod:
Type: AWS::ApiGateway::Stage
Properties:
StageName: Prod
Description: Prod Stage
AccessLogSetting:
DestinationArn: "dest"
Format: "format"
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
MethodSettings:
LoggingLevel: "OFF"
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
Resources:
Prod:
Type: AWS::ApiGatewayV2::Stage
Properties:
StageName: Prod
Description: Prod Stage
AccessLogSettings:
DestinationArn: "dest"
Format: "format"
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
ApiId: "teste"
DefaultRouteSettings:
LoggingLevel: "OFF"
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
Resources:
Prod:
Type: AWS::ApiGateway::Stage
Properties:
StageName: Prod
Description: Prod Stage
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
MethodSettings:
LoggingLevel: "ON"
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
Resources:
Prod:
Type: AWS::ApiGatewayV2::Stage
Properties:
StageName: Prod
Description: Prod Stage
RestApiId: !Ref MyRestApi
DeploymentId: !Ref TestDeployment
DocumentationVersion: ""
ApiId: "teste"
DefaultRouteSettings:
LoggingLevel: "ON"
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@
"Type": "AWS::ApiGatewayV2::Stage",
"Properties": {
"Description": "Prod Stage",
"AccessLogSettings": {
"DestinationArn": "dest",
"Format": "format"
},
"DeploymentId": "MyDeployment",
"ApiId": "CFNWebSocket",
"StageName": "Prod"
Expand Down
Loading

0 comments on commit be96e52

Please sign in to comment.