Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Star 3 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save okochang/c37b2055ecd8774dd250 to your computer and use it in GitHub Desktop.
Save okochang/c37b2055ecd8774dd250 to your computer and use it in GitHub Desktop.
Sample rule for AWS Config Rules that evaluate vpc flow logs enabled or disabled
import boto3
import datetime
import json
config = boto3.client("config")
ec2 = boto3.client("ec2")
def evaluate_flowlog(vpc_id):
response = ec2.describe_flow_logs(
Filter=[
{
"Name": "resource-id",
"Values": [
vpc_id,
]
},
],
)
if len(response[u"FlowLogs"]) != 0: return True
def evaluate_compliance(vpc_id):
if evaluate_flowlog(vpc_id):
return "COMPLIANT"
else:
return "NON_COMPLIANT"
def lambda_handler(event, context):
invocation_event = json.loads(event["invokingEvent"].encode("ascii"))
ordering_timestamp = invocation_event["notificationCreationTime"]
vpc_id = invocation_event["configurationItem"]["resourceId"]
resource_type = invocation_event["configurationItem"]["resourceType"]
result_token = event["resultToken"]
compliance = evaluate_compliance(vpc_id)
responce = config.put_evaluations(
Evaluations=[
{
"ComplianceResourceType": resource_type,
"ComplianceResourceId": vpc_id,
"ComplianceType": compliance,
"OrderingTimestamp": ordering_timestamp
},
],
ResultToken=result_token
)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment