Source code for infrahouse_core.aws.nat_gateway
"""
NAT Gateway resource wrapper.
Provides ``exists`` / ``delete()`` support. NAT Gateways have no
dependencies to clean up before deletion, but ``exists`` must account
for the ``deleting`` and ``deleted`` lifecycle states.
"""
from __future__ import annotations
from logging import getLogger
from botocore.exceptions import ClientError
from infrahouse_core.aws.base import AWSResource
LOG = getLogger(__name__)
# NAT Gateway states that mean the resource is effectively gone.
_GONE_STATES = frozenset({"deleting", "deleted"})
[docs]
class NATGateway(AWSResource):
"""Wrapper around an EC2 NAT Gateway.
:param nat_gateway_id: ID of the NAT Gateway (e.g. ``nat-0123456789abcdef0``).
:param region: AWS region.
:param role_arn: IAM role ARN for cross-account access.
"""
def __init__(self, nat_gateway_id, region=None, role_arn=None, session=None):
super().__init__(nat_gateway_id, "ec2", region=region, role_arn=role_arn, session=session)
@property
def nat_gateway_id(self) -> str:
"""Return the ID of the NAT Gateway.
:rtype: str
"""
return self._resource_id
@property
def exists(self) -> bool:
"""Return ``True`` if the NAT Gateway exists and is not being deleted.
A NAT Gateway in the ``deleting`` or ``deleted`` state is considered
non-existent. Returns ``False`` if the API returns no results or
raises ``NatGatewayNotFound``.
"""
try:
response = self._client.describe_nat_gateways(
NatGatewayIds=[self._resource_id],
)
gateways = response.get("NatGateways", [])
if not gateways:
return False
state = gateways[0].get("State", "")
return state not in _GONE_STATES
except ClientError as err:
if err.response["Error"]["Code"] == "NatGatewayNotFound":
return False
raise
# -- Delete --------------------------------------------------------------
[docs]
def delete(self) -> None:
"""Delete the NAT Gateway.
Idempotent -- does nothing if the NAT Gateway does not exist
or is already being deleted.
"""
try:
self._client.delete_nat_gateway(NatGatewayId=self._resource_id)
LOG.info("Deleted NAT Gateway %s", self._resource_id)
except ClientError as err:
if err.response["Error"]["Code"] == "NatGatewayNotFound":
LOG.info("NAT Gateway %s does not exist.", self._resource_id)
else:
raise