Skip to content

An Attack Framework to enumerate aws services and look for potential privilege escalation vulnerabilities in AWS , specifically within the IAM Service

License

Notifications You must be signed in to change notification settings

arniecommits/Cloud_Ripper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cloud Ripper

License

This is an effort to highlight risks from cloud misconfigurations; we also look at how seemingly unused artefacts such as IAM policies/Roles in your cloud environment can be easily misused to move laterally or exfiltrate data. This is an initial framework approach so that you can take and build upon the various service discovery and enumeration techniques that have been used in script. This particular version is aimed at AWS similar techniques can utilised with other CSP's.

Please Note: The purpose of the code is purely educational and should not be used with malicious intent or within infrastructure where you do not have permissions to run such tests.

Sample Application Architecture

Image

In the above example, we have a simple web app that uses a vulnerable version of PHP-ImageMagic Library to convert files to pdf, we trigger the initial C2 Connection based on an RCE vulnerability within this to establish a shell within the docker container. Once on the container we are able to query the instance metadata service to obtain the credentials for the role from this point the attack flows as follows:

Ima

MITRE TTP's

MITRE Tactics Used:

Install Pre-Reqs:

The attacker machine from which the RunAttack.py script is executed must have awscli installed and have the correct path set as well as python dependencies json,time,sys,os,subprocess.

The script has only been tested on Debian based Linux release.

Minimum Permissions the initial Role attached to the workload must have: IAM List/some type of read permissions, eg. policy bellow

{
 "Version": "2012-10-17",
 "Statement": [
 {
 "Sid": "VisualEditor0",
 "Effect": "Allow",
 "Action": [
 "sts:AssumeRole",
 "iam:List*",
 "iam:Get*"
 ],
 "Resource": "*"
 }
 ]
}

Usage Information:

Their are two parts to the script , the attack execution script and service enumeration dictionary file.

The attack execution script reads the awscli commands present in the enum.txt file to attempt to enumerate services and try to work out how deep the permissions are in terms of privileges for the exisiting role, it than moves to find other roles that can exploited and once assumed other roles successfully will loop through and discover additional vulnerable roles that can be potentially exploited.

The script can be run as python3 Run__Attack.py [the enum.txt file needs to be in the same dir as the script]

python3 Run_Attack.py

Defensive Advise:

  1. Ensure applications are scanned for vulnerabilities and code dependencies and libraries used are regularly updated.

  2. Ensure application traffic is inspected by a Cloud IPS solution so you can look for malicious traffic such as shellcode or injection attempts.

  3. Ensure outbound traffic from workloads are regulated and cant be misused for defense evasion techniques.

  4. Use Cloud Security Posture Management tool such as CNAPP which can look for building your resource inventory and run effective checks against privilege creep or unused resources.

  5. Remove unused Cloud config objects, and ensure any roles that have assume capabilities have strict conditions attached so they cannot be taken over and exploited.

About

An Attack Framework to enumerate aws services and look for potential privilege escalation vulnerabilities in AWS , specifically within the IAM Service

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages