AWS - Lambda Post Exploitation

Tip

Ucz się & ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się & ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ucz się & ćwicz Az Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Wspieraj HackTricks

Lambda

For more information check:

AWS - Lambda Enum

Eksfiltracja poświadczeń Lambda

Lambda używa zmiennych środowiskowych do wstrzykiwania poświadczeń w czasie wykonywania. Jeśli uzyskasz do nich dostęp (czytając /proc/self/environ lub wykorzystując samą podatną funkcję), możesz ich użyć samodzielnie. Znajdują się one w domyślnych zmiennych o nazwach AWS_SESSION_TOKEN, AWS_SECRET_ACCESS_KEY oraz AWS_ACCESS_KEY_ID.

Domyślnie mają one uprawnienia do zapisu do cloudwatch log group (jej nazwa jest przechowywana w AWS_LAMBDA_LOG_GROUP_NAME), a także do tworzenia dowolnych log groups, jednak lambda functions często mają więcej uprawnień przypisanych w zależności od ich przeznaczenia.

lambda:Delete*

An attacker granted lambda:Delete* can delete Lambda functions, versions/aliases, layers, event source mappings and other associated configurations.

aws lambda delete-function \
--function-name <LAMBDA_NAME>

Kradzież żądań URL innych użytkowników do Lambda

Jeśli atakujący w jakiś sposób uzyska RCE wewnątrz funkcji Lambda, będzie w stanie przechwycić żądania HTTP innych użytkowników kierowane do tej funkcji. Jeśli żądania zawierają wrażliwe informacje (cookies, credentials…) będzie mógł je wykradać.

AWS - Lambda Steal Requests

Kradzież żądań URL innych użytkowników i żądań Extensions

Wykorzystując Lambda Layers, możliwe jest także nadużycie extensions i utrwalenie się w funkcji Lambda, a także kradzież i modyfikacja żądań.

AWS - Abusing Lambda Extensions

AWS Lambda – VPC Egress Bypass

Force a Lambda function out of a restricted VPC by updating its configuration with an empty VpcConfig (SubnetIds=[], SecurityGroupIds=[]). The function will then run in the Lambda-managed networking plane, regaining outbound internet access and bypassing egress controls enforced by private VPC subnets without NAT.

AWS - Lambda VPC Egress Bypass

AWS Lambda – Runtime Pinning/Rollback Abuse

Abuse lambda:PutRuntimeManagementConfig to pin a function to a specific runtime version (Manual) or freeze updates (FunctionUpdate). This preserves compatibility with malicious layers/wrappers and can keep the function on an outdated, vulnerable runtime to aid exploitation and long-term persistence.

AWS - Lambda Runtime Pinning Abuse

AWS Lambda – Log Siphon via LoggingConfig.LogGroup Redirection

Abuse lambda:UpdateFunctionConfiguration advanced logging controls to redirect a function’s logs to an attacker-chosen CloudWatch Logs log group. This works without changing code or the execution role (most Lambda roles already include logs:CreateLogGroup/CreateLogStream/PutLogEvents via AWSLambdaBasicExecutionRole). If the function prints secrets/request bodies or crashes with stack traces, you can collect them from the new log group.

AWS - Lambda LoggingConfig Redirection

AWS - Lambda Function URL Public Exposure

Turn a private Lambda Function URL into a public unauthenticated endpoint by switching the Function URL AuthType to NONE and attaching a resource-based policy that grants lambda:InvokeFunctionUrl to everyone. This enables anonymous invocation of internal functions and can expose sensitive backend operations.

AWS - Lambda Function URL Public Exposure

AWS Lambda – Event Source Mapping Target Hijack

Abuse UpdateEventSourceMapping to change the target Lambda function of an existing Event Source Mapping (ESM) so that records from DynamoDB Streams, Kinesis, or SQS are delivered to an attacker-controlled function. This silently diverts live data without touching producers or the original function code.

AWS - Lambda Event Source Mapping Hijack

AWS Lambda – EFS Mount Injection data exfiltration

Abuse lambda:UpdateFunctionConfiguration to attach an existing EFS Access Point to a Lambda, then deploy trivial code that lists/reads files from the mounted path to exfiltrate shared secrets/config that the function previously couldn’t access.

AWS - Lambda EFS Mount Injection

Tip

Ucz się & ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się & ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ucz się & ćwicz Az Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Wspieraj HackTricks