iam-vulnerable

iam-vulnerable

500 Stars

Use Terraform to create your own vulnerable by design AWS IAM privilege escalation playground.

BishopFox
May 27, 2025
500 stars
Category
Vulnerable-labs
GitHub Stars
500
Project Added On
May 27, 2025
Contributors
4

IAM Vulnerable

Use Terraform to create your own vulnerable by design AWS IAM privilege escalation playground.

IAM Vulnerable uses the Terraform binary and your AWS credentials to deploy over 250 IAM resources into your selected AWS account. Within minutes, you can start learning how to identify and exploit vulnerable IAM configurations that allow for privilege escalation.

IAM Vulnerable’s big brother - CloudFoxable

Hey all. IAM Vulnerable is still immensely useful for understanding the basic building blocks of AWS IAM privilege escaltion. However, a few years after making IAM vulnerable, I created CloudFoxable, a CTF style version that teachers you the basics of cloud penetration testing more wholisisticlly.

Intentionally Vulnerable Playground

Want to chat about IAM-Vulnerable, CloudFox, and CloudFoxable?

Join us on the RedSec discord server

:fox_face: Currently supported privilege escalation paths: 31

Table of Contents

Recommended Approach

  1. Select or create an AWS account - Do NOT use an account that has any production resources or sensitive data.
  2. Create your vulnerable playground - Use this repo to create the IAM principals and policies that support 31 unique AWS IAM privesc paths.
  3. Do your homework - Learn about the 21 original privesc paths pioneered by Spencer Gietzen.
  4. Hacky, hack - Practice exploitation in your new playground using Gerben Kleijn’s guide.
  5. Level up - Run your tools against your new IAM privesc playground account (i.e., Cloudsplaining, AWSPX, Principal Mapper, Pacu).

Detailed Usage Instructions

Blog Post: IAM Vulnerable - An AWS IAM Privilege Escalation Playground

Quick Start

This quick start outlines an opinionated approach to getting IAM Vulnerable up and running in your AWS account as quickly as possible. You might have many of these steps already completed, or you might want to tweak things to work with your current configuration. Check out the Other Use Cases section in this repository for some additional configuration options.

  1. Select or create an AWS account. (Do NOT use an account that has any production resources or sensitive data!)
  2. Create a non-root user with administrative access that you will use when running Terraform.
  3. Create an access key for that user.
  4. Install the AWS CLI.
  5. Configure your AWS CLI with your newly created admin user as the default profile.
  6. Confirm your CLI is working as expected by executing aws sts get-caller-identity.
  7. Install the Terraform binary and add the binary location to your path.
  8. git clone https://github.com/BishopFox/iam-vulnerable
  9. cd iam-vulnerable/
  10. terraform init
  11. (Optional) export TF_VAR_aws_local_profile=PROFILE_IN_AWS_CREDENTIALS_FILE_IF_OTHER_THAN_DEFAULT
  12. (Optional) export TF_VAR_aws_local_creds_file=FILE_LOCATION_IF_NON_DEFAULT
  13. (Optional) terraform plan
  14. terraform apply
  15. (Optional) Add the IAM vulnerable profiles to your AWS credentials file, and change the account number.
    • The following commands make a backup of your current AWS credentials file, then takes the example credentials file from the repo and replaces the placeholder account with your target account number, and finally adds all of the IAM Vulnerable privesc profiles to your credentials file so you can use them:
    • cp ~/.aws/credentials ~/.aws/credentials.backup
    • tail -n +7 aws_credentials_file_example | sed s/111111111111/$(aws sts get-caller-identity | grep Account | awk -F\" '{print $4}')/g >> ~/.aws/credentials

Cleanup

Whenever you want to remove all of the IAM Vulnerable-created resources, you can run these commands:
1. cd iam-vulnerable/
1. terraform destroy

What resources were just created?

The Terraform binary just used your default AWS account profile credentials to create:
31 users, roles, and policies each with a unique exploit path to administrative access of the playground account
Some additional users, groups, roles, and policies that are required to fully realize certain exploit paths
* Some additional users, roles, and policies that test the detection capabilities of other tools

By default, every role created by this Terraform module is assumable by the user or role you used to run Terraform.
* If you’d like Terraform to use a profile other than the default profile, or you’d like to hard-code the assume_role_policy ARN, see Other Use Cases.

How much is this going to cost?

Deploying IAM vulnerable in its default configuration will cost nothing. See the next section to learn how to enable non-default modules that do incur cost, and how much each module will cost per month if you deploy it.

A Modular Approach

IAM Vulnerable groups certain resources together in modules. Some of the modules are enabled by default (the ones that don’t have any cost implications), and others are disabled by default (the ones that incur cost if deployed). This way, you can enable specific modules as needed.

For example, when you are ready to play with the exploit paths like ssm:StartSession that involve resources outside of IAM, you can deploy and tear down these resources on demand by uncommenting the module in the iam-vulnerable/main.tf file, and re-running terraform apply:

# Uncomment the next four lines to create an ec2 instance and related resources
#module "ec2" {
#  source = "./modules/non-free-resources/ec2"
#  aws_assume_role_arn = (var.aws_assume_role_arn != "" ? var.aws_assume_role_arn : data.aws_caller_identity.current.arn)
#}

After you uncomment the ec2 module, run:

terraform init
terraform apply

You have now deployed the required components to try the SSM privesc paths.

Free Resource Modules

There is no cost to anything deployed within free-resources:

Name Default Status Estimated Cost Description
privesc-paths Enabled None Contains all of the IAM privesc paths
tool-testing Enabled None Contains test cases that evaluate the capabilities of the different IAM privesc tools

Non-free Resource Modules

Deploying these additional modules can result in cost:

Name Default Status Estimated Cost Description Required for
EC2 Disabled :heavy_dollar_sign:
$4.50/month
Creates an EC2 instance and a security group that allows SSH from anywhere ssm-SendCommand
ssm-StartSession
ec2InstanceConnect-SendSSHPublicKey
Lambda Disabled :slightly_smiling_face:
Monthly cost depends on usage (cost should be zero)
Creates a Lambda function Lambda-EditExistingLambdaFunctionWithRole
Glue Disabled :heavy_dollar_sign::heavy_dollar_sign::heavy_dollar_sign::heavy_dollar_sign:
$4/hour
Creates a Glue dev endpoint Glue-UpdateExistingGlueDevEndpoint
SageMaker Disabled Not sure yet Creates a SageMaker notebook sageMakerCreatePresignedNotebookURL
CloudFormation Disabled :slightly_smiling_face:
$0.40/month for the secret created via CloudFormation. Nothing or barely nothing for the stack itself
Creates a CloudFormation stack that creates a secret in secret manager privesc-cloudFormationUpdateStack

Supported Privilege Escalation Paths

Path Name IAM Vulnerable Profile Name Non-Default Modules Required Exploitation References
Category: IAM Permissions on Other Users
IAM-CreateAccessKey privesc4 None :fox_face: Well, That Escalated Quickly - Privesc 04
:lock: s3cur3.it IAMVulnerable - Part 3
IAM-CreateLoginProfile privesc5 None :fox_face: Well, That Escalated Quickly - Privesc 05
:lock: s3cur3.it IAMVulnerable - Part 3
IAM-UpdateLoginProfile privesc6 None :fox_face: Well, That Escalated Quickly - Privesc 06
:lock: s3cur3.it IAMVulnerable - Part 3
**Categor

... Content truncated. Click "See More" to view the full README.

Tool Information

Author

BishopFox

Project Added On

May 27, 2025

License

Open Source

Tags

security tool