Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit b2ec396

Browse files
committed
Improve SQS interoperability
1 parent 829566c commit b2ec396

File tree

1 file changed

+21
-5
lines changed
  • src/Symfony/Component/Messenger/Bridge/AmazonSqs/Transport

1 file changed

+21
-5
lines changed

src/Symfony/Component/Messenger/Bridge/AmazonSqs/Transport/Connection.php

Lines changed: 21 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -176,6 +176,7 @@ private function getNewMessages(): \Generator
176176
'Action' => 'ReceiveMessage',
177177
'VisibilityTimeout' => $this->configuration['visibility_timeout'],
178178
'MaxNumberOfMessages' => $this->configuration['buffer_size'],
179+
'MessageAttributeName.1' => 'All',
179180
'WaitTimeSeconds' => $this->configuration['wait_time'],
180181
]);
181182
}
@@ -186,9 +187,18 @@ private function getNewMessages(): \Generator
186187

187188
$xml = new \SimpleXMLElement($this->currentResponse->getContent());
188189
foreach ($xml->ReceiveMessageResult->Message as $xmlMessage) {
190+
$headers = [];
191+
foreach ($xmlMessage->MessageAttribute as $item) {
192+
if ('String' !== (string) $item->Value->DataType) {
193+
continue;
194+
}
195+
$headers[(string) $item->Name] = (string) $item->Value->StringValue;
196+
}
189197
$this->buffer[] = [
190198
'id' => (string) $xmlMessage->ReceiptHandle,
191-
] + json_decode($xmlMessage->Body, true);
199+
'body' => (string) $xmlMessage->Body,
200+
'headers' => $headers,
201+
];
192202
}
193203

194204
$this->currentResponse = null;
@@ -246,17 +256,23 @@ public function send(string $body, array $headers, int $delay = 0, ?string $mess
246256
$this->setup();
247257
}
248258

249-
$messageBody = json_encode(['body' => $body, 'headers' => $headers]);
250-
251259
$parameters = [
252260
'Action' => 'SendMessage',
253-
'MessageBody' => $messageBody,
261+
'MessageBody' => $body,
254262
'DelaySeconds' => $delay,
255263
];
256264

265+
$index = 0;
266+
foreach ($headers as $name => $value) {
267+
++$index;
268+
$parameters["MessageAttribute.$index.Name"] = $name;
269+
$parameters["MessageAttribute.$index.Value.DataType"] = 'String';
270+
$parameters["MessageAttribute.$index.Value.StringValue"] = $value;
271+
}
272+
257273
if ($this->isFifoQueue($this->configuration['queue_name'])) {
258274
$parameters['MessageGroupId'] = null !== $messageGroupId ? $messageGroupId : __METHOD__;
259-
$parameters['MessageDeduplicationId'] = null !== $messageDeduplicationId ? $messageDeduplicationId : sha1($messageBody);
275+
$parameters['MessageDeduplicationId'] = null !== $messageDeduplicationId ? $messageDeduplicationId : sha1(json_encode(['body' => $body, 'headers' => $headers]));
260276
}
261277

262278
$this->call($this->getQueueUrl(), $parameters);

0 commit comments

Comments
 (0)