From e1a3726e6e4baa918b6983de33e2a1777d3c1d6a Mon Sep 17 00:00:00 2001 From: Alina Buzachis Date: Mon, 14 Oct 2024 15:25:49 +0200 Subject: [PATCH] module_utils/ec2 - Add utils for the ec2_vpc_vpn* modules (#2312) * Add utils for the ec2_vpc_vpn* modules Signed-off-by: Alina Buzachis * Modify upon review Signed-off-by: Alina Buzachis --------- Signed-off-by: Alina Buzachis --- changelogs/fragments/20240927-ec2-utils.yml | 2 + plugins/module_utils/ec2.py | 43 +++++++++++++++++++++ 2 files changed, 45 insertions(+) create mode 100644 changelogs/fragments/20240927-ec2-utils.yml diff --git a/changelogs/fragments/20240927-ec2-utils.yml b/changelogs/fragments/20240927-ec2-utils.yml new file mode 100644 index 00000000000..dae0ab47187 --- /dev/null +++ b/changelogs/fragments/20240927-ec2-utils.yml @@ -0,0 +1,2 @@ +minor_changes: + - module_utils/ec2 - add utils for the ec2_vpc_vpn* modules (https://github.com/ansible-collections/amazon.aws/pull/2312). diff --git a/plugins/module_utils/ec2.py b/plugins/module_utils/ec2.py index b00e8659571..80781d2668e 100644 --- a/plugins/module_utils/ec2.py +++ b/plugins/module_utils/ec2.py @@ -363,6 +363,49 @@ def reject_vpc_peering_connection(client, peering_id: str) -> bool: return True +# EC2 VPC VPN +class EC2VpnErrorHandler(AWSErrorHandler): + _CUSTOM_EXCEPTION = AnsibleEC2Error + + @classmethod + def _is_missing(cls): + return is_boto3_error_code(["InvalidVpnConnectionID.NotFound", "InvalidRoute.NotFound"]) + + +@EC2VpcErrorHandler.list_error_handler("describe vpn connections", []) +@AWSRetry.jittered_backoff() +def describe_vpn_connections(client, **params: Dict[str, Any]) -> List[Dict[str, Any]]: + # The paginator does not exist for `describe_vpn_connections` + return client.describe_vpn_connections(**params)["VpnConnections"] + + +@EC2VpcErrorHandler.common_error_handler("create vpn connection route") +@AWSRetry.jittered_backoff() +def create_vpn_connection_route(client, vpn_connection_id: str, route: Dict[str, Any]) -> bool: + client.create_vpn_connection_route(VpnConnectionId=vpn_connection_id, DestinationCidrBlock=route) + return True + + +@EC2VpcErrorHandler.deletion_error_handler("delete vpn connection route") +@AWSRetry.jittered_backoff() +def delete_vpn_connection_route(client, vpn_connection_id: str, route: Dict[str, Any]) -> bool: + client.delete_vpn_connection_route(VpnConnectionId=vpn_connection_id, DestinationCidrBlock=route) + return True + + +@EC2VpcErrorHandler.common_error_handler("create vpn connection") +@AWSRetry.jittered_backoff() +def create_vpn_connection(client, **params: Dict[str, Any]) -> Dict[str, Any]: + return client.create_vpn_connection(**params)["VpnConnection"] + + +@EC2VpcErrorHandler.deletion_error_handler("delete vpn connection") +@AWSRetry.jittered_backoff() +def delete_vpn_connection(client, vpn_connection_id: str) -> Dict[str, Any]: + client.delete_vpn_connection(VpnConnectionId=vpn_connection_id) + return True + + # EC2 Internet Gateway class EC2InternetGatewayErrorHandler(AWSErrorHandler): _CUSTOM_EXCEPTION = AnsibleEC2Error