From 746c6a98df352fd3c64ebf0fe91aa66390bbac14 Mon Sep 17 00:00:00 2001 From: Juwon Date: Wed, 7 Aug 2024 11:36:11 +0900 Subject: [PATCH] Add feature : Secrets Manager bp check --- services/secrets_manager.py | 57 ++++++++++++++++++++++++++++++++++--- 1 file changed, 53 insertions(+), 4 deletions(-) diff --git a/services/secrets_manager.py b/services/secrets_manager.py index 4aac790..aa52ccd 100644 --- a/services/secrets_manager.py +++ b/services/secrets_manager.py @@ -1,23 +1,72 @@ from models import RuleCheckResult import boto3 +import datetime +from dateutil.tz import tzlocal -# client = boto3.client("") +client = boto3.client("secretsmanager") def secretsmanager_rotation_enabled_check(): + compliant_resources = [] + non_compliant_resources = [] + secrets = client.list_secrets()["SecretList"] + + for secret in secrets: + if secret["RotationEnabled"] == True: + compliant_resources.append(secret["ARN"]) + else: + non_compliant_resources.append(secret["ARN"]) + return RuleCheckResult( - passed=False, compliant_resources=[], non_compliant_resources=[] + passed=not non_compliant_resources, + compliant_resources=compliant_resources, + non_compliant_resources=non_compliant_resources, ) def secretsmanager_scheduled_rotation_success_check(): + compliant_resources = [] + non_compliant_resources = [] + secrets = client.list_secrets()["SecretList"] + + for secret in secrets: + if secret["RotationEnabled"] == True: + now = datetime.datetime.now(tz=tzlocal()) + rotation_period = datetime.timedelta( + days=secret["RotationRules"]["AutomaticallyAfterDays"] + 2 + ) # 최대 2일 지연 가능 (aws) + elapsed_time_after_rotation = now - secret["LastRotatedDate"] + + if elapsed_time_after_rotation > rotation_period: + non_compliant_resources.append(secret["ARN"]) + else: + compliant_resources.append(secret["ARN"]) + return RuleCheckResult( - passed=False, compliant_resources=[], non_compliant_resources=[] + passed=not non_compliant_resources, + compliant_resources=compliant_resources, + non_compliant_resources=non_compliant_resources, ) def secretsmanager_secret_periodic_rotation(): + compliant_resources = [] + non_compliant_resources = [] + secrets = client.list_secrets()["SecretList"] + + for secret in secrets: + if secret["RotationEnabled"] == True: + now = datetime.datetime.now(tz=tzlocal()) + elapsed_time_after_rotation = now - secret["LastRotatedDate"] + + if elapsed_time_after_rotation > datetime.timedelta(days=90): + non_compliant_resources.append(secret["ARN"]) + else: + compliant_resources.append(secret["ARN"]) + return RuleCheckResult( - passed=False, compliant_resources=[], non_compliant_resources=[] + passed=not non_compliant_resources, + compliant_resources=compliant_resources, + non_compliant_resources=non_compliant_resources, )