Source code for infrahouse_core.aws.sqs_queue
"""
SQS Queue resource wrapper.
Provides ``exists`` / ``delete()`` support for Amazon SQS queues.
"""
from __future__ import annotations
from logging import getLogger
from botocore.exceptions import ClientError
from infrahouse_core.aws.base import AWSResource
LOG = getLogger(__name__)
# SQS uses different error codes depending on the API version / endpoint.
_QUEUE_NOT_FOUND_CODES = frozenset({"QueueDoesNotExist", "NonExistentQueue", "AWS.SimpleQueueService.NonExistentQueue"})
[docs]
class SQSQueue(AWSResource):
"""Wrapper around an SQS queue.
:param queue_url: URL of the SQS queue.
:param region: AWS region.
:param role_arn: IAM role ARN for cross-account access.
"""
def __init__(self, queue_url, region=None, role_arn=None, session=None):
super().__init__(queue_url, "sqs", region=region, role_arn=role_arn, session=session)
@property
def queue_url(self) -> str:
"""Return the URL of the queue.
:rtype: str
"""
return self._resource_id
@property
def exists(self) -> bool:
"""Return ``True`` if the queue exists.
Returns ``False`` if the API raises ``QueueDoesNotExist`` or
``NonExistentQueue``.
"""
try:
self._client.get_queue_attributes(
QueueUrl=self._resource_id,
AttributeNames=["QueueArn"],
)
return True
except ClientError as err:
if err.response["Error"]["Code"] in _QUEUE_NOT_FOUND_CODES:
return False
raise
# -- Delete --------------------------------------------------------------
[docs]
def delete(self) -> None:
"""Delete the queue.
Idempotent -- does nothing if the queue does not exist.
"""
try:
self._client.delete_queue(QueueUrl=self._resource_id)
LOG.info("Deleted SQS queue %s", self._resource_id)
except ClientError as err:
if err.response["Error"]["Code"] in _QUEUE_NOT_FOUND_CODES:
LOG.info("SQS queue %s does not exist.", self._resource_id)
else:
raise