AFT Modules Deployment Checklist

NOTE: https://github.com/aws-ia/terraform-aws-control_tower_account_factory.git
Step 1: Deploy Packaging Module
Module:
packaging
Source:
./modules/aft-archives
Purpose: Package Lambda archives and artifacts.
Command:
terraform apply -target=module.packaging
Outcome: Artifact files (Lambda zips) uploaded and ready.
Step 2: Deploy Account Request Framework
Module:
aft_account_request_framework
Source:
./modules/aft-account-request-framework
Purpose: Manage account request lifecycle (DynamoDB, queues, SNS, VPC).
Dependencies: Needs packaging artifacts from Step 1.
Command:
terraform apply -target=module.aft_account_request_framework
Outcome: Core request infrastructure deployed.
Step 3: Deploy Lambda Layer Module
Module:
aft_lambda_layer
Source:
./modules/aft-lambda-layer
Purpose: Create shared Lambda layer.
Dependencies: Uses keys, VPC, archives from Steps 1 and 2.
Command:
terraform apply -target=module.aft_lambda_layer
Outcome: Shared Lambda layer ready for provisioning Lambdas.
Step 4: Deploy Account Provisioning Framework
Module:
aft_account_provisioning_framework
Source:
./modules/aft-account-provisioning-framework
Purpose: Step Functions and Lambdas that provision accounts.
Dependencies: Needs SNS, KMS, Lambda layer, archives.
Command:
terraform apply -target=module.aft_account_provisioning_framework
Outcome: Account provisioning automation deployed.
Step 5: Deploy Backend Infrastructure
Module:
aft_backend
Source:
./modules/aft-backend
Purpose: S3 buckets and DynamoDB tables for state and config.
Dependencies: Independent but needed early.
Command:
terraform apply -target=module.aft_backend
Outcome: Persistent backend storage ready.
Step 6: Deploy Code Repositories
Module:
aft_code_repositories
Source:
./modules/aft-code-repositories
Purpose: Create/configure repos for provisioning/customization code.
Dependencies: Needs VPC info and backend from Steps 2 and 5.
Command:
terraform apply -target=module.aft_code_repositories
Outcome: Code repos provisioned.
Step 7: Deploy Customizations
Module:
aft_customizations
Source:
./modules/aft-customizations
Purpose: Pipelines and orchestration for account customizations.
Dependencies: Needs backend, provisioning framework, repos.
Command:
terraform apply -target=module.aft_customizations
Outcome: Customization pipelines set.
Step 8: Deploy Feature Options
Module:
aft_feature_options
Source:
./modules/aft-feature-options
Purpose: Optional features (CloudTrail, support, default VPC deletion).
Dependencies: After provisioning framework and customizations.
Command:
terraform apply -target=module.aft_feature_options
Outcome: Optional features enabled.
Step 9: Deploy IAM Roles
Module:
aft_iam_roles
Source:
./modules/aft-iam-roles
Purpose: IAM roles for cross-account access.
Dependencies: Needs foundational accounts ready.
Command:
terraform apply -target=module.aft_iam_roles
Outcome: IAM roles deployed.
Step 10: Deploy SSM Parameters
Module:
aft_ssm_parameters
Source:
./modules/aft-ssm-parameters
Purpose: Store configs in SSM Parameter Store.
Dependencies: Needs outputs from nearly all other modules.
Command:
terraform apply -target=module.aft_ssm_parameters
Outcome: Configuration parameters stored centrally.
Optional: Full deployment
Once you have tested the modules individually in order, you can deploy all with:
terraform apply
Make sure your terraform.tfvars
and backend config are correctly set up.
If you want, I can help prepare a sample Terraform workflow or scripts to automate these steps! Would you like that?
You said:
yes, please
ChatGPT said:
Awesome! Hereโs a simple Bash script you can run in your AFT Terraform root folder to deploy the modules in the correct order automatically.
#!/bin/bash
set -e # Exit on any error
echo "Starting AFT modules deployment..."
declare -a modules=(
"module.packaging"
"module.aft_account_request_framework"
"module.aft_lambda_layer"
"module.aft_account_provisioning_framework"
"module.aft_backend"
"module.aft_code_repositories"
"module.aft_customizations"
"module.aft_feature_options"
"module.aft_iam_roles"
"module.aft_ssm_parameters"
)
for mod in "${modules[@]}"
do
echo "Deploying $mod ..."
terraform apply -auto-approve -target=$mod
echo "$mod deployed successfully."
done
echo "All AFT modules deployed!"
How to use:
Save this script as
deploy_aft_
modules.sh
in your Terraform root directory.Make it executable:
bashCopyEditchmod +x deploy_aft_modules.sh
- Run the script:
bashCopyEdit./deploy_aft_modules.sh
Notes:
The script uses
-auto-approve
to avoid manual confirmation at each step.It deploys modules one by one in the exact order required by dependencies.
If any step fails, the script will exit immediately (
set -e
).Make sure your Terraform backend is configured and
terraform init
has been run before this.Adjust module names if your Terraform module blocks use different names.
Subscribe to my newsletter
Read articles from Chinnayya Chintha directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by

Chinnayya Chintha
Chinnayya Chintha
I am ๐๐ต๐ถ๐ป๐ป๐ฎ๐๐๐ฎ ๐๐ต๐ถ๐ป๐๐ต๐ฎ, ๐ฎ ๐ฟ๐ฒ๐๐๐น๐๐-๐ฑ๐ฟ๐ถ๐๐ฒ๐ป ๐ฆ๐ถ๐๐ฒ ๐ฅ๐ฒ๐น๐ถ๐ฎ๐ฏ๐ถ๐น๐ถ๐๐ ๐๐ป๐ด๐ถ๐ป๐ฒ๐ฒ๐ฟ (๐ฆ๐ฅ๐) with proven expertise in ๐ฎ๐๐๐ผ๐บ๐ฎ๐๐ถ๐ป๐ด, ๐ฎ๐ป๐ฑ ๐บ๐ฎ๐ป๐ฎ๐ด๐ถ๐ป๐ด ๐๐ฒ๐ฐ๐๐ฟ๐ฒ, ๐๐ฐ๐ฎ๐น๐ฎ๐ฏ๐น๐ฒ, ๐ฎ๐ป๐ฑ ๐ฟ๐ฒ๐น๐ถ๐ฎ๐ฏ๐น๐ฒ ๐ถ๐ป๐ณ๐ฟ๐ฎ๐๐๐ฟ๐๐ฐ๐๐๐ฟ๐ฒ ๐๐ผ๐น๐๐๐ถ๐ผ๐ป๐. My experience spans ๐ฐ๐น๐ผ๐๐ฑ-๐ป๐ฎ๐๐ถ๐๐ฒ ๐๐ฒ๐ฐ๐ต๐ป๐ผ๐น๐ผ๐ด๐ถ๐ฒ๐, ๐๐/๐๐ ๐ฎ๐๐๐ผ๐บ๐ฎ๐๐ถ๐ผ๐ป, ๐ฎ๐ป๐ฑ ๐๐ป๐ณ๐ฟ๐ฎ๐๐๐ฟ๐๐ฐ๐๐๐ฟ๐ฒ ๐ฎ๐ ๐๐ผ๐ฑ๐ฒ (๐๐ฎ๐), enabling me to deliver ๐ต๐ถ๐ด๐ต-๐ฝ๐ฒ๐ฟ๐ณ๐ผ๐ฟ๐บ๐ถ๐ป๐ด ๐๐๐๐๐ฒ๐บ๐ that enhance operational efficiency and drive innovation. As a ๐๐ฟ๐ฒ๐ฒ๐น๐ฎ๐ป๐ฐ๐ฒ ๐ฆ๐ถ๐๐ฒ ๐ฅ๐ฒ๐น๐ถ๐ฎ๐ฏ๐ถ๐น๐ถ๐๐ ๐๐ป๐ด๐ถ๐ป๐ฒ๐ฒ๐ฟ, I specialize in: โ ๐๐บ๐ฝ๐น๐ฒ๐บ๐ฒ๐ป๐๐ถ๐ป๐ด ๐๐ฒ๐ฐ๐๐ฟ๐ฒ ๐ฎ๐ป๐ฑ ๐๐ฐ๐ฎ๐น๐ฎ๐ฏ๐น๐ฒ ๐ฝ๐ฎ๐๐บ๐ฒ๐ป๐ ๐ด๐ฎ๐๐ฒ๐๐ฎ๐ ๐๐ผ๐น๐๐๐ถ๐ผ๐ป๐ ๐๐๐ถ๐ป๐ด ๐๐ช๐ฆ ๐๐ฒ๐ฟ๐๐ถ๐ฐ๐ฒ๐ ๐น๐ถ๐ธ๐ฒ ๐๐ฃ๐ ๐๐ฎ๐๐ฒ๐๐ฎ๐, ๐๐ฎ๐บ๐ฏ๐ฑ๐ฎ, ๐ฎ๐ป๐ฑ ๐๐๐ป๐ฎ๐บ๐ผ๐๐.. โ ๐๐๐๐ผ๐บ๐ฎ๐๐ถ๐ป๐ด ๐ถ๐ป๐ณ๐ฟ๐ฎ๐๐๐ฟ๐๐ฐ๐๐๐ฟ๐ฒ ๐ฝ๐ฟ๐ผ๐๐ถ๐๐ถ๐ผ๐ป๐ถ๐ป๐ด with ๐ง๐ฒ๐ฟ๐ฟ๐ฎ๐ณ๐ผ๐ฟ๐บ. โ ๐ข๐ฝ๐๐ถ๐บ๐ถ๐๐ถ๐ป๐ด ๐บ๐ผ๐ป๐ถ๐๐ผ๐ฟ๐ถ๐ป๐ด using ๐๐น๐ผ๐๐ฑ๐ช๐ฎ๐๐ฐ๐ต. โ Ensuring compliance with ๐ฃ๐๐-๐๐ฆ๐ฆ ๐๐๐ฎ๐ป๐ฑ๐ฎ๐ฟ๐ฑ๐ through ๐ฒ๐ป๐ฐ๐ฟ๐๐ฝ๐๐ถ๐ผ๐ป ๐บ๐ฒ๐ฐ๐ต๐ฎ๐ป๐ถ๐๐บ๐ โ implemented with ๐๐ช๐ฆ ๐๐ ๐ฆ and ๐ฆ๐ฒ๐ฐ๐ฟ๐ฒ๐๐ ๐ ๐ฎ๐ป๐ฎ๐ด๐ฒ๐ฟ. These efforts have resulted in ๐ฒ๐ป๐ต๐ฎ๐ป๐ฐ๐ฒ๐ฑ ๐๐ฟ๐ฎ๐ป๐๐ฎ๐ฐ๐๐ถ๐ผ๐ป ๐ฟ๐ฒ๐น๐ถ๐ฎ๐ฏ๐ถ๐น๐ถ๐๐ and ๐๐๐ฟ๐ฒ๐ฎ๐บ๐น๐ถ๐ป๐ฒ๐ฑ ๐ผ๐ฝ๐ฒ๐ฟ๐ฎ๐๐ถ๐ผ๐ป๐ฎ๐น ๐๐ผ๐ฟ๐ธ๐ณ๐น๐ผ๐๐ for payment processing systems. I am passionate about ๐บ๐ฒ๐ป๐๐ผ๐ฟ๐ถ๐ป๐ด ๐ฎ๐ป๐ฑ ๐ธ๐ป๐ผ๐๐น๐ฒ๐ฑ๐ด๐ฒ ๐๐ต๐ฎ๐ฟ๐ถ๐ป๐ด, having delivered ๐ต๐ฎ๐ป๐ฑ๐-๐ผ๐ป ๐๐ฟ๐ฎ๐ถ๐ป๐ถ๐ป๐ด in ๐ฐ๐น๐ผ๐๐ฑ ๐๐ฒ๐ฐ๐ต๐ป๐ผ๐น๐ผ๐ด๐ถ๐ฒ๐, ๐๐๐ฏ๐ฒ๐ฟ๐ป๐ฒ๐๐ฒ๐, ๐ฎ๐ป๐ฑ ๐ฎ๐๐๐ผ๐บ๐ฎ๐๐ถ๐ผ๐ป. My proactive approach helps me anticipate system challenges and create ๐ฟ๐ผ๐ฏ๐๐๐, ๐๐ฐ๐ฎ๐น๐ฎ๐ฏ๐น๐ฒ ๐๐ผ๐น๐๐๐ถ๐ผ๐ป๐ ๐๐ต๐ฎ๐ ๐ฒ๐ป๐ต๐ฎ๐ป๐ฐ๐ฒ ๐๐ฒ๐ฐ๐๐ฟ๐ถ๐๐, ๐ฐ๐ผ๐บ๐ฝ๐น๐ถ๐ฎ๐ป๐ฐ๐ฒ, ๐ฎ๐ป๐ฑ ๐ผ๐ฝ๐ฒ๐ฟ๐ฎ๐๐ถ๐ผ๐ป๐ฎ๐น ๐ฒ๐ณ๐ณ๐ถ๐ฐ๐ถ๐ฒ๐ป๐ฐ๐. Dedicated to ๐ฐ๐ผ๐ป๐๐ถ๐ป๐๐ผ๐๐ ๐น๐ฒ๐ฎ๐ฟ๐ป๐ถ๐ป๐ด, I stay updated with ๐ฒ๐บ๐ฒ๐ฟ๐ด๐ถ๐ป๐ด ๐๐ฒ๐ฐ๐ต๐ป๐ผ๐น๐ผ๐ด๐ถ๐ฒ๐ and thrive on contributing to ๐๐ฟ๐ฎ๐ป๐๐ณ๐ผ๐ฟ๐บ๐ฎ๐๐ถ๐๐ฒ ๐ฝ๐ฟ๐ผ๐ท๐ฒ๐ฐ๐๐ that push boundaries in technology.