runbooks 0.7.0__py3-none-any.whl → 0.7.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. runbooks/__init__.py +87 -37
  2. runbooks/cfat/README.md +300 -49
  3. runbooks/cfat/__init__.py +2 -2
  4. runbooks/finops/__init__.py +1 -1
  5. runbooks/finops/cli.py +1 -1
  6. runbooks/inventory/collectors/__init__.py +8 -0
  7. runbooks/inventory/collectors/aws_management.py +791 -0
  8. runbooks/inventory/collectors/aws_networking.py +3 -3
  9. runbooks/main.py +3389 -782
  10. runbooks/operate/__init__.py +207 -0
  11. runbooks/operate/base.py +311 -0
  12. runbooks/operate/cloudformation_operations.py +619 -0
  13. runbooks/operate/cloudwatch_operations.py +496 -0
  14. runbooks/operate/dynamodb_operations.py +812 -0
  15. runbooks/operate/ec2_operations.py +926 -0
  16. runbooks/operate/iam_operations.py +569 -0
  17. runbooks/operate/s3_operations.py +1211 -0
  18. runbooks/operate/tagging_operations.py +655 -0
  19. runbooks/remediation/CLAUDE.md +100 -0
  20. runbooks/remediation/DOME9.md +218 -0
  21. runbooks/remediation/README.md +26 -0
  22. runbooks/remediation/Tests/__init__.py +0 -0
  23. runbooks/remediation/Tests/update_policy.py +74 -0
  24. runbooks/remediation/__init__.py +95 -0
  25. runbooks/remediation/acm_cert_expired_unused.py +98 -0
  26. runbooks/remediation/acm_remediation.py +875 -0
  27. runbooks/remediation/api_gateway_list.py +167 -0
  28. runbooks/remediation/base.py +643 -0
  29. runbooks/remediation/cloudtrail_remediation.py +908 -0
  30. runbooks/remediation/cloudtrail_s3_modifications.py +296 -0
  31. runbooks/remediation/cognito_active_users.py +78 -0
  32. runbooks/remediation/cognito_remediation.py +856 -0
  33. runbooks/remediation/cognito_user_password_reset.py +163 -0
  34. runbooks/remediation/commons.py +455 -0
  35. runbooks/remediation/dynamodb_optimize.py +155 -0
  36. runbooks/remediation/dynamodb_remediation.py +744 -0
  37. runbooks/remediation/dynamodb_server_side_encryption.py +108 -0
  38. runbooks/remediation/ec2_public_ips.py +134 -0
  39. runbooks/remediation/ec2_remediation.py +892 -0
  40. runbooks/remediation/ec2_subnet_disable_auto_ip_assignment.py +72 -0
  41. runbooks/remediation/ec2_unattached_ebs_volumes.py +448 -0
  42. runbooks/remediation/ec2_unused_security_groups.py +202 -0
  43. runbooks/remediation/kms_enable_key_rotation.py +651 -0
  44. runbooks/remediation/kms_remediation.py +717 -0
  45. runbooks/remediation/lambda_list.py +243 -0
  46. runbooks/remediation/lambda_remediation.py +971 -0
  47. runbooks/remediation/multi_account.py +569 -0
  48. runbooks/remediation/rds_instance_list.py +199 -0
  49. runbooks/remediation/rds_remediation.py +873 -0
  50. runbooks/remediation/rds_snapshot_list.py +192 -0
  51. runbooks/remediation/requirements.txt +118 -0
  52. runbooks/remediation/s3_block_public_access.py +159 -0
  53. runbooks/remediation/s3_bucket_public_access.py +143 -0
  54. runbooks/remediation/s3_disable_static_website_hosting.py +74 -0
  55. runbooks/remediation/s3_downloader.py +215 -0
  56. runbooks/remediation/s3_enable_access_logging.py +562 -0
  57. runbooks/remediation/s3_encryption.py +526 -0
  58. runbooks/remediation/s3_force_ssl_secure_policy.py +143 -0
  59. runbooks/remediation/s3_list.py +141 -0
  60. runbooks/remediation/s3_object_search.py +201 -0
  61. runbooks/remediation/s3_remediation.py +816 -0
  62. runbooks/remediation/scan_for_phrase.py +425 -0
  63. runbooks/remediation/workspaces_list.py +220 -0
  64. runbooks/security/__init__.py +9 -10
  65. runbooks/security/security_baseline_tester.py +4 -2
  66. runbooks-0.7.5.dist-info/METADATA +606 -0
  67. {runbooks-0.7.0.dist-info → runbooks-0.7.5.dist-info}/RECORD +72 -44
  68. {runbooks-0.7.0.dist-info → runbooks-0.7.5.dist-info}/entry_points.txt +0 -1
  69. runbooks/aws/__init__.py +0 -58
  70. runbooks/aws/dynamodb_operations.py +0 -231
  71. runbooks/aws/ec2_copy_image_cross-region.py +0 -195
  72. runbooks/aws/ec2_describe_instances.py +0 -202
  73. runbooks/aws/ec2_ebs_snapshots_delete.py +0 -186
  74. runbooks/aws/ec2_run_instances.py +0 -213
  75. runbooks/aws/ec2_start_stop_instances.py +0 -212
  76. runbooks/aws/ec2_terminate_instances.py +0 -143
  77. runbooks/aws/ec2_unused_eips.py +0 -196
  78. runbooks/aws/ec2_unused_volumes.py +0 -188
  79. runbooks/aws/s3_create_bucket.py +0 -142
  80. runbooks/aws/s3_list_buckets.py +0 -152
  81. runbooks/aws/s3_list_objects.py +0 -156
  82. runbooks/aws/s3_object_operations.py +0 -183
  83. runbooks/aws/tagging_lambda_handler.py +0 -183
  84. runbooks/inventory/FAILED_SCRIPTS_TROUBLESHOOTING.md +0 -619
  85. runbooks/inventory/PASSED_SCRIPTS_GUIDE.md +0 -738
  86. runbooks/inventory/cfn_move_stack_instances.py +0 -1526
  87. runbooks/inventory/delete_s3_buckets_objects.py +0 -169
  88. runbooks/inventory/lockdown_cfn_stackset_role.py +0 -224
  89. runbooks/inventory/update_aws_actions.py +0 -173
  90. runbooks/inventory/update_cfn_stacksets.py +0 -1215
  91. runbooks/inventory/update_cloudwatch_logs_retention_policy.py +0 -294
  92. runbooks/inventory/update_iam_roles_cross_accounts.py +0 -478
  93. runbooks/inventory/update_s3_public_access_block.py +0 -539
  94. runbooks/organizations/__init__.py +0 -12
  95. runbooks/organizations/manager.py +0 -374
  96. runbooks-0.7.0.dist-info/METADATA +0 -375
  97. /runbooks/{aws → operate}/tags.json +0 -0
  98. {runbooks-0.7.0.dist-info → runbooks-0.7.5.dist-info}/WHEEL +0 -0
  99. {runbooks-0.7.0.dist-info → runbooks-0.7.5.dist-info}/licenses/LICENSE +0 -0
  100. {runbooks-0.7.0.dist-info → runbooks-0.7.5.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,98 @@
1
+ """
2
+ ACM Certificate Cleanup - Remove expired and unused SSL certificates.
3
+ """
4
+
5
+ import logging
6
+
7
+ import click
8
+ from botocore.exceptions import ClientError
9
+
10
+ from .commons import display_aws_account_info, get_client
11
+
12
+ logger = logging.getLogger(__name__)
13
+
14
+
15
+ @click.command()
16
+ @click.option("--dry-run", is_flag=True, default=True, help="Preview mode - show actions without making changes")
17
+ def clean_acm_certificates(dry_run):
18
+ """Clean up expired and unused ACM certificates."""
19
+ logger.info(f"Cleaning ACM certificates in {display_aws_account_info()}")
20
+
21
+ try:
22
+ acm_client = get_client("acm")
23
+
24
+ # Get all certificates
25
+ response = acm_client.list_certificates()
26
+ certificates = response.get("CertificateSummaryList", [])
27
+
28
+ if not certificates:
29
+ logger.info("No ACM certificates found")
30
+ return
31
+
32
+ logger.info(f"Found {len(certificates)} certificates to check")
33
+
34
+ # Track results
35
+ expired_unused = []
36
+ expired_in_use = []
37
+ unused_valid = []
38
+ certificates_deleted = []
39
+
40
+ # Check each certificate
41
+ for cert in certificates:
42
+ cert_arn = cert["CertificateArn"]
43
+ cert_status = cert.get("Status", "Unknown")
44
+ cert_in_use = cert.get("InUse", False)
45
+
46
+ logger.info(f"Certificate: {cert_arn[:50]}...")
47
+ logger.info(f" Status: {cert_status}, In Use: {cert_in_use}")
48
+
49
+ # Categorize certificates
50
+ if cert_status == "EXPIRED" and not cert_in_use:
51
+ expired_unused.append(cert_arn)
52
+ logger.info(f" → Expired and unused - candidate for deletion")
53
+
54
+ # Delete if not in dry-run mode
55
+ if not dry_run:
56
+ try:
57
+ acm_client.delete_certificate(CertificateArn=cert_arn)
58
+ certificates_deleted.append(cert_arn)
59
+ logger.info(f" ✓ Successfully deleted")
60
+ except ClientError as e:
61
+ logger.error(f" ✗ Failed to delete: {e}")
62
+
63
+ elif cert_status == "EXPIRED" and cert_in_use:
64
+ expired_in_use.append(cert_arn)
65
+ logger.info(f" ⚠ Expired but still in use - requires manual review")
66
+
67
+ elif not cert_in_use and cert_status in ["ISSUED", "PENDING_VALIDATION"]:
68
+ unused_valid.append(cert_arn)
69
+ logger.info(f" ⚠ Valid but unused - consider for cleanup")
70
+
71
+ else:
72
+ logger.info(f" ✓ Active certificate")
73
+
74
+ # Summary
75
+ logger.info("\n=== SUMMARY ===")
76
+ logger.info(f"Total certificates: {len(certificates)}")
77
+ logger.info(f"Expired & unused: {len(expired_unused)}")
78
+ logger.info(f"Expired but in use: {len(expired_in_use)}")
79
+ logger.info(f"Valid but unused: {len(unused_valid)}")
80
+
81
+ if dry_run and expired_unused:
82
+ logger.info(f"To delete {len(expired_unused)} expired certificates, run with --no-dry-run")
83
+ elif not dry_run:
84
+ logger.info(f"Successfully deleted {len(certificates_deleted)} certificates")
85
+
86
+ if expired_in_use:
87
+ logger.warning(f"⚠ {len(expired_in_use)} expired certificates are still in use - manual review needed")
88
+
89
+ except ClientError as e:
90
+ logger.error(f"Failed to process ACM certificates: {e}")
91
+ raise
92
+ except Exception as e:
93
+ logger.error(f"Unexpected error: {e}")
94
+ raise
95
+
96
+
97
+ if __name__ == "__main__":
98
+ clean_acm_certificates()