Merge pull request #2930 from usmangani1/LSISSUE1450
EC2 enhancement create vpc end point
This commit is contained in:
commit
2e19666e67
@ -104,6 +104,7 @@ from .utils import (
|
||||
random_internet_gateway_id,
|
||||
random_ip,
|
||||
random_ipv6_cidr,
|
||||
randor_ipv4_cidr,
|
||||
random_launch_template_id,
|
||||
random_nat_gateway_id,
|
||||
random_key_pair,
|
||||
@ -112,6 +113,8 @@ from .utils import (
|
||||
random_reservation_id,
|
||||
random_route_table_id,
|
||||
generate_route_id,
|
||||
generate_vpc_end_point_id,
|
||||
create_dns_entries,
|
||||
split_route_id,
|
||||
random_security_group_id,
|
||||
random_snapshot_id,
|
||||
@ -2741,6 +2744,7 @@ class VPCBackend(object):
|
||||
|
||||
def __init__(self):
|
||||
self.vpcs = {}
|
||||
self.vpc_end_points = {}
|
||||
self.vpc_refs[self.__class__].add(weakref.ref(self))
|
||||
super(VPCBackend, self).__init__()
|
||||
|
||||
@ -2883,6 +2887,66 @@ class VPCBackend(object):
|
||||
vpc = self.get_vpc(vpc_id)
|
||||
return vpc.associate_vpc_cidr_block(cidr_block, amazon_provided_ipv6_cidr_block)
|
||||
|
||||
def create_vpc_endpoint(
|
||||
self,
|
||||
vpc_id,
|
||||
service_name,
|
||||
type=None,
|
||||
policy_document=False,
|
||||
route_table_ids=None,
|
||||
subnet_ids=[],
|
||||
network_interface_ids=[],
|
||||
dns_entries=None,
|
||||
client_token=None,
|
||||
security_group=None,
|
||||
tag_specifications=None,
|
||||
private_dns_enabled=None,
|
||||
):
|
||||
|
||||
vpc_endpoint_id = generate_vpc_end_point_id(vpc_id)
|
||||
|
||||
# validates if vpc is present or not.
|
||||
self.get_vpc(vpc_id)
|
||||
|
||||
if type and type.lower() == "interface":
|
||||
|
||||
network_interface_ids = []
|
||||
for subnet_id in subnet_ids:
|
||||
self.get_subnet(subnet_id)
|
||||
eni = self.create_network_interface(subnet_id, random_private_ip())
|
||||
network_interface_ids.append(eni.id)
|
||||
|
||||
dns_entries = create_dns_entries(service_name, vpc_endpoint_id)
|
||||
|
||||
else:
|
||||
# considering gateway if type is not mentioned.
|
||||
service_destination_cidr = randor_ipv4_cidr()
|
||||
|
||||
for route_table_id in route_table_ids:
|
||||
self.create_route(route_table_id, service_destination_cidr)
|
||||
if dns_entries:
|
||||
dns_entries = [dns_entries]
|
||||
|
||||
vpc_end_point = VPCEndPoint(
|
||||
vpc_endpoint_id,
|
||||
vpc_id,
|
||||
service_name,
|
||||
type,
|
||||
policy_document,
|
||||
route_table_ids,
|
||||
subnet_ids,
|
||||
network_interface_ids,
|
||||
dns_entries,
|
||||
client_token,
|
||||
security_group,
|
||||
tag_specifications,
|
||||
private_dns_enabled,
|
||||
)
|
||||
|
||||
self.vpc_end_points[vpc_endpoint_id] = vpc_end_point
|
||||
|
||||
return vpc_end_point
|
||||
|
||||
|
||||
class VPCPeeringConnectionStatus(object):
|
||||
def __init__(self, code="initiating-request", message=""):
|
||||
@ -3491,6 +3555,40 @@ class Route(object):
|
||||
return route_table
|
||||
|
||||
|
||||
class VPCEndPoint(TaggedEC2Resource):
|
||||
def __init__(
|
||||
self,
|
||||
id,
|
||||
vpc_id,
|
||||
service_name,
|
||||
type=None,
|
||||
policy_document=False,
|
||||
route_table_ids=None,
|
||||
subnet_ids=None,
|
||||
network_interface_ids=None,
|
||||
dns_entries=None,
|
||||
client_token=None,
|
||||
security_group=None,
|
||||
tag_specifications=None,
|
||||
private_dns_enabled=None,
|
||||
):
|
||||
|
||||
self.id = id
|
||||
self.vpc_id = vpc_id
|
||||
self.service_name = service_name
|
||||
self.type = type
|
||||
self.policy_document = policy_document
|
||||
self.route_table_ids = route_table_ids
|
||||
self.network_interface_ids = network_interface_ids
|
||||
self.subnet_ids = subnet_ids
|
||||
self.client_token = client_token
|
||||
self.security_group = security_group
|
||||
self.tag_specifications = tag_specifications
|
||||
self.private_dns_enabled = private_dns_enabled
|
||||
self.created_at = datetime.utcnow()
|
||||
self.dns_entries = dns_entries
|
||||
|
||||
|
||||
class RouteBackend(object):
|
||||
def __init__(self):
|
||||
super(RouteBackend, self).__init__()
|
||||
|
@ -163,6 +163,34 @@ class VPCs(BaseResponse):
|
||||
cidr_block_state="disassociating",
|
||||
)
|
||||
|
||||
def create_vpc_endpoint(self):
|
||||
vpc_id = self._get_param("VpcId")
|
||||
service_name = self._get_param("ServiceName")
|
||||
route_table_ids = self._get_multi_param("RouteTableId")
|
||||
subnet_ids = self._get_multi_param("SubnetId")
|
||||
type = self._get_param("VpcEndpointType")
|
||||
policy_document = self._get_param("PolicyDocument")
|
||||
client_token = self._get_param("ClientToken")
|
||||
tag_specifications = self._get_param("TagSpecifications")
|
||||
private_dns_enabled = self._get_param("PrivateDNSEnabled")
|
||||
security_group = self._get_param("SecurityGroup")
|
||||
|
||||
vpc_end_point = self.ec2_backend.create_vpc_endpoint(
|
||||
vpc_id=vpc_id,
|
||||
service_name=service_name,
|
||||
type=type,
|
||||
policy_document=policy_document,
|
||||
route_table_ids=route_table_ids,
|
||||
subnet_ids=subnet_ids,
|
||||
client_token=client_token,
|
||||
security_group=security_group,
|
||||
tag_specifications=tag_specifications,
|
||||
private_dns_enabled=private_dns_enabled,
|
||||
)
|
||||
|
||||
template = self.response_template(CREATE_VPC_END_POINT)
|
||||
return template.render(vpc_end_point=vpc_end_point)
|
||||
|
||||
|
||||
CREATE_VPC_RESPONSE = """
|
||||
<CreateVpcResponse xmlns="http://ec2.amazonaws.com/doc/{{doc_date}}/">
|
||||
@ -384,3 +412,40 @@ IPV6_DISASSOCIATE_VPC_CIDR_BLOCK_RESPONSE = """
|
||||
</ipv6CidrBlockState>
|
||||
</ipv6CidrBlockAssociation>
|
||||
</DisassociateVpcCidrBlockResponse>"""
|
||||
|
||||
CREATE_VPC_END_POINT = """ <CreateVpcEndpointResponse xmlns="http://monitoring.amazonaws.com/doc/2010-08-01/">
|
||||
<vpcEndpoint>
|
||||
<policyDocument>{{ vpc_end_point.policy_document }}</policyDocument>
|
||||
<state> available </state>
|
||||
<vpcEndpointPolicySupported> false </vpcEndpointPolicySupported>
|
||||
<serviceName>{{ vpc_end_point.service_name }}</serviceName>
|
||||
<vpcId>{{ vpc_end_point.vpc_id }}</vpcId>
|
||||
<vpcEndpointId>{{ vpc_end_point.id }}</vpcEndpointId>
|
||||
<routeTableIdSet>
|
||||
{% for routeid in vpc_end_point.route_table_ids %}
|
||||
<item>{{ routeid }}</item>
|
||||
{% endfor %}
|
||||
</routeTableIdSet>
|
||||
<networkInterfaceIdSet>
|
||||
{% for network_interface_id in vpc_end_point.network_interface_ids %}
|
||||
<item>{{ network_interface_id }}</item>
|
||||
{% endfor %}
|
||||
</networkInterfaceIdSet>
|
||||
<subnetIdSet>
|
||||
{% for subnetId in vpc_end_point.subnet_ids %}
|
||||
<item>{{ subnetId }}</item>
|
||||
{% endfor %}
|
||||
</subnetIdSet>
|
||||
<dnsEntrySet>
|
||||
{% if vpc_end_point.dns_entries %}
|
||||
{% for entry in vpc_end_point.dns_entries %}
|
||||
<item>
|
||||
<hostedZoneId>{{ entry["hosted_zone_id"] }}</hostedZoneId>
|
||||
<dnsName>{{ entry["dns_name"] }}</dnsName>
|
||||
</item>
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
</dnsEntrySet>
|
||||
<creationTimestamp>{{ vpc_end_point.created_at }}</creationTimestamp>
|
||||
</vpcEndpoint>
|
||||
</CreateVpcEndpointResponse>"""
|
||||
|
@ -181,6 +181,10 @@ def random_ip():
|
||||
)
|
||||
|
||||
|
||||
def randor_ipv4_cidr():
|
||||
return "10.0.{}.{}/16".format(random.randint(0, 255), random.randint(0, 255))
|
||||
|
||||
|
||||
def random_ipv6_cidr():
|
||||
return "2400:6500:{}:{}::/56".format(random_resource_id(4), random_resource_id(4))
|
||||
|
||||
@ -189,6 +193,19 @@ def generate_route_id(route_table_id, cidr_block):
|
||||
return "%s~%s" % (route_table_id, cidr_block)
|
||||
|
||||
|
||||
def generate_vpc_end_point_id(vpc_id):
|
||||
return "%s-%s" % ("vpce", vpc_id[4:])
|
||||
|
||||
|
||||
def create_dns_entries(service_name, vpc_endpoint_id):
|
||||
dns_entries = {}
|
||||
dns_entries["dns_name"] = "{}-{}.{}".format(
|
||||
vpc_endpoint_id, random_resource_id(8), service_name
|
||||
)
|
||||
dns_entries["hosted_zone_id"] = random_resource_id(13).upper()
|
||||
return dns_entries
|
||||
|
||||
|
||||
def split_route_id(route_id):
|
||||
values = route_id.split("~")
|
||||
return values[0], values[1]
|
||||
|
@ -618,3 +618,63 @@ def test_describe_route_tables_with_nat_gateway():
|
||||
nat_gw_routes[0]["DestinationCidrBlock"].should.equal("0.0.0.0/0")
|
||||
nat_gw_routes[0]["NatGatewayId"].should.equal(nat_gw_id)
|
||||
nat_gw_routes[0]["State"].should.equal("active")
|
||||
|
||||
|
||||
@mock_ec2
|
||||
def test_create_vpc_end_point():
|
||||
|
||||
ec2 = boto3.client("ec2", region_name="us-west-1")
|
||||
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
||||
subnet = ec2.create_subnet(VpcId=vpc["Vpc"]["VpcId"], CidrBlock="10.0.0.0/24")
|
||||
|
||||
route_table = ec2.create_route_table(VpcId=vpc["Vpc"]["VpcId"])
|
||||
|
||||
# test without any end point type specified
|
||||
vpc_end_point = ec2.create_vpc_endpoint(
|
||||
VpcId=vpc["Vpc"]["VpcId"],
|
||||
ServiceName="com.amazonaws.us-east-1.s3",
|
||||
RouteTableIds=[route_table["RouteTable"]["RouteTableId"]],
|
||||
)
|
||||
|
||||
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
||||
"com.amazonaws.us-east-1.s3"
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["RouteTableIds"][0].should.equal(
|
||||
route_table["RouteTable"]["RouteTableId"]
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
||||
vpc_end_point["VpcEndpoint"]["DnsEntries"].should.have.length_of(0)
|
||||
|
||||
# test with any end point type as gateway
|
||||
vpc_end_point = ec2.create_vpc_endpoint(
|
||||
VpcId=vpc["Vpc"]["VpcId"],
|
||||
ServiceName="com.amazonaws.us-east-1.s3",
|
||||
RouteTableIds=[route_table["RouteTable"]["RouteTableId"]],
|
||||
VpcEndpointType="gateway",
|
||||
)
|
||||
|
||||
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
||||
"com.amazonaws.us-east-1.s3"
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["RouteTableIds"][0].should.equal(
|
||||
route_table["RouteTable"]["RouteTableId"]
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
||||
vpc_end_point["VpcEndpoint"]["DnsEntries"].should.have.length_of(0)
|
||||
|
||||
# test with end point type as interface
|
||||
vpc_end_point = ec2.create_vpc_endpoint(
|
||||
VpcId=vpc["Vpc"]["VpcId"],
|
||||
ServiceName="com.amazonaws.us-east-1.s3",
|
||||
SubnetIds=[subnet["Subnet"]["SubnetId"]],
|
||||
VpcEndpointType="interface",
|
||||
)
|
||||
|
||||
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
||||
"com.amazonaws.us-east-1.s3"
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["SubnetIds"][0].should.equal(
|
||||
subnet["Subnet"]["SubnetId"]
|
||||
)
|
||||
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
||||
len(vpc_end_point["VpcEndpoint"]["DnsEntries"]).should.be.greater_than(0)
|
||||
|
Loading…
Reference in New Issue
Block a user