Source code for infrahouse_core.aws.internet_gateway
"""
Internet Gateway resource wrapper.
Provides ``exists`` / ``delete()`` support. The gateway must be detached
from all VPCs before it can be deleted -- ``delete()`` handles this
automatically.
"""
from __future__ import annotations
from logging import getLogger
from botocore.exceptions import ClientError
from infrahouse_core.aws.base import AWSResource
LOG = getLogger(__name__)
[docs]
class InternetGateway(AWSResource):
"""Wrapper around an EC2 Internet Gateway.
:param igw_id: Internet gateway ID (e.g. ``igw-0123456789abcdef0``).
:param region: AWS region.
:param role_arn: IAM role ARN for cross-account access.
"""
def __init__(self, igw_id, region=None, role_arn=None, session=None):
super().__init__(igw_id, "ec2", region=region, role_arn=role_arn, session=session)
@property
def igw_id(self) -> str:
"""Return the internet gateway ID.
:rtype: str
"""
return self._resource_id
@property
def exists(self) -> bool:
"""Return ``True`` if the internet gateway exists."""
try:
self._client.describe_internet_gateways(InternetGatewayIds=[self._resource_id])
return True
except ClientError as err:
if err.response["Error"]["Code"] == "InvalidInternetGatewayID.NotFound":
return False
raise
[docs]
def delete(self) -> None:
"""Detach from all VPCs and delete the internet gateway.
Idempotent -- does nothing if the gateway does not exist.
"""
# Detach from all VPCs first
try:
response = self._client.describe_internet_gateways(InternetGatewayIds=[self._resource_id])
except ClientError as err:
if err.response["Error"]["Code"] == "InvalidInternetGatewayID.NotFound":
LOG.info("Internet gateway %s does not exist.", self._resource_id)
return
raise
for attachment in response["InternetGateways"][0].get("Attachments", []):
vpc_id = attachment["VpcId"]
self._client.detach_internet_gateway(InternetGatewayId=self._resource_id, VpcId=vpc_id)
LOG.info("Detached internet gateway %s from VPC %s", self._resource_id, vpc_id)
try:
self._client.delete_internet_gateway(InternetGatewayId=self._resource_id)
LOG.info("Deleted internet gateway %s", self._resource_id)
except ClientError as err:
if err.response["Error"]["Code"] == "InvalidInternetGatewayID.NotFound":
LOG.info("Internet gateway %s does not exist.", self._resource_id)
else:
raise