- Introduction
- 2022-03-16
- 2022-03-14
- 2022-01-07
- 2021-12-16
- 2021-12-10
- 2021-11-22
- 2021-11-20
- 2021-11-19
- 2021-09-02
- 2021-09-01
All notable changes to this project will be documented in this file.
- Fixed the Common Prerequisites solution to support Control Tower configurations with a single governed region.
- Added new document DOWNLOAD-AND-STAGE-SOLUTIONS.md to explain the steps for downloading the SRA example code and staging the solutions within the S3 staging bucket.
- Added Security Hub Organization solution to configure Security Hub using AWS Organizations. All existing accounts are added to the central admin account, standards are enabled/disabled per provided parameters, a region aggregator is created per the provided paramenter, and a parameter is provided for disabling Security Hub within all accounts and regions via SNS fanout.
- Updated the CFCT-DEPLOYMENT-INSTRUCTIONS.md document to remove references to the common_cfct_setup solution.
- CloudTrail solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Added integration with Secrets Manager to share CloudFormation output values with the management account.
- Updated the bucket policy to use aws:SourceArn to align with the updated documentation Organization Trail Bucket Policy.
- Updated the CFCT configuration to use the main templates and parameters.
- Common CFCT Setup solution
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Removed the Lambda function that created a new OU and moved the management account. This is no longer required due to the latest version of the CFCT solution supporting deployments to the management account within the root OU.
- Common Prerequisites solution
- Added a template to create a KMS key for sharing CloudFormation outputs via Secrets Manager secrets.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Updated the staging bucket policy to fix the reference to the AWSControlTowerExecution role ARN.
- Added SRA version parameter to main templates for triggering updates to StackSets.
- Added logic within the descriptions to reference the rControlTowerExecutionRoleStack resource if the cCreateAWSControlTowerExecutionRole condition is met. This logic avoids creating an empty stack when the condition is false.
- Common Register Delegated Administrator solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Updated the CFCT configuration to use the main templates and parameters.
- Added integration with Secrets Manager to share CloudFormation output values with the management account.
- Updated the Lambda function to align with latest coding standards.
- AWS Config Aggregator solution
- Added main templates to simplify deployments via nested stacks.
- Updated the CFCT configuration to use the main templates and parameters.
- Added pRegisterDelegatedAdminAccount parameter to determine whether or not to register the delegated administrator account. This allows the ability to register the delegated admin accounts outside of this solution.
- AWS Config Conformance Pack solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Updated the CFCT configuration to use the main templates and parameters.
- Added pRegisterDelegatedAdminAccount parameter to determine whether or not to register the delegated administrator account.
- Moved the list_config_recorder_status.py script from the utils/aws_control_tower/helper_scripts to the solution scripts folder.
- Updated and moved the Operational-Best-Practices-for-Encryption-and-Keys.yaml conformance pack template to the templates/aws_config_conformance_packs folder.
- AWS Config Management Account solution
- Added SRA version parameter to main templates for triggering updates to StackSets.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- EC2 Default EBS Encryption solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Firewall Manager solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- GuardDuty solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Added a parameter and logic to disable GuardDuty within all accounts and regions using SNS fanout.
- IAM Access Analyzer solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- IAM Password Policy solution
- Renamed solution and files to remove _acct suffix
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Macie solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- Added a parameter and logic to disable Macie within all accounts and regions using SNS fanout.
- S3 Block Account Public Access solution
- Added main templates to simplify deployments via nested stacks.
- Updated documentation, diagram, and templates to be consistent with the rest of the solutions.
- The
Account Security Hub Enabler
solution was replaced with the Security Hub Organization solution. - The
package-lambda.sh
script was replaced by the stage_solution.sh script. - The
Prerequisites for AWS Control Tower solutions
files were replaced with the Common Prerequisites solution.
- Fixed checkov metadata entries to use updated check suppression via CFN Metadata.
- Updates to the stage_solution.sh packaging script to support better error logging and include
packaging of
common
solutions. - In Common Prerequisites and AWS Config Management Account solutions:
- Updates to logging to include tracebacks for when exceptions are raised.
- In Common Prerequisites solution:
- Set
DeletionPolicy=Retain
andUpdateReplacePolicy=Retain
for the IAM Role:AWSControlTowerExecution
- Set
- Renamed
DEPLOYMENT-METHODS.md
to CFCT-DEPLOYMENT-INSTRUCTIONS.md to provide manual and automated steps for deployment of Customizations for Control Tower (CFCT), including prerequisites.
- CFCT deployment option for the Common Prerequisites solution.
- Config Management Account solution
- In Common Prerequisites solution:
- Removed
TAG_KEY/TAG_VALUE
as environment variables and only kept them as Custom Resource Properties, since CloudWatch event is no longer needed in this solution. - Removed
pManagementAccountId
from multiple templates, and instead used as neededAWS::AccountId
.
- Removed
- Nothing Fixed
- Common Prerequisites solution
Deployment Methods
documentation- Staging Script -
stage_solution.sh
- Nothing Changed
- Nothing Fixed
- EC2 Default EBS Encryption solution
- Nothing Changed
- S3 Block Account Public Access solution
- Nothing Changed
- Added
.flake8
,poetry.lock
,pyproject.toml
, and.markdownlint.json
to define coding standards that we will require and use when building future solutions. Contributors should use the standards defined within these files before submitting pull requests. Existing solutions will get refactored to these standards in future updates. - Added S3
BucketKeyEnabled
to the solutions that create S3 objects (e.g. CloudTrail, GuardDuty, and Macie)
- Removed the AWS Config Aggregator account solution since AWS Control Tower deploys an account aggregator within the Audit account.
- Modified the directory structure to support multiple internal packages (e.g. 1 for each solution). The folder structure also allows for tests (integration, unit, etc.). See Real Python Application with Internal Packages
- Renamed folders and files with snake_case to align with PEP8 Package and Module Names
- Modified links within
README.md
files to align with the updated folders and file names - Updated the
README.md
files to provide consistency and improved formatting. - Renamed parameter and template files to
sra-<solution_name>...
- Updated default values for parameters for resource names with sra- prefix to help with protecting resources deployed
- Nothing Added
- Removed all code and references to AWS Landing Zone as it is currently in Long-term Support and will not receive any additional features.
- Nothing Fixed
- AWS IAM Access Analyzer solution
- Organization AWS Config Aggregator solution
- Common Register Delegated Administrator solution
- Nothing Changed
- Nothing Fixed