Index: third_party/gsutil/third_party/boto/boto/vpc/vpc_peering_connection.py |
diff --git a/third_party/gsutil/third_party/boto/boto/vpc/vpc_peering_connection.py b/third_party/gsutil/third_party/boto/boto/vpc/vpc_peering_connection.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..cdb9af8daed348daf773c46ab373e7287e0e5bd5 |
--- /dev/null |
+++ b/third_party/gsutil/third_party/boto/boto/vpc/vpc_peering_connection.py |
@@ -0,0 +1,163 @@ |
+# Copyright (c) 2014 Skytap http://skytap.com/ |
+# |
+# Permission is hereby granted, free of charge, to any person obtaining a |
+# copy of this software and associated documentation files (the |
+# "Software"), to deal in the Software without restriction, including |
+# without limitation the rights to use, copy, modify, merge, publish, dis- |
+# tribute, sublicense, and/or sell copies of the Software, and to permit |
+# persons to whom the Software is furnished to do so, subject to the fol- |
+# lowing conditions: |
+# |
+# The above copyright notice and this permission notice shall be included |
+# in all copies or substantial portions of the Software. |
+# |
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
+# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT |
+# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
+# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
+# IN THE SOFTWARE. |
+ |
+""" |
+Represents a VPC Peering Connection. |
+""" |
+ |
+from boto.ec2.ec2object import TaggedEC2Object |
+ |
+class VpcInfo(object): |
+ def __init__(self): |
+ """ |
+ Information on peer Vpc. |
+ |
+ :ivar id: The unique ID of peer Vpc. |
+ :ivar owner_id: Owner of peer Vpc. |
+ :ivar cidr_block: CIDR Block of peer Vpc. |
+ """ |
+ |
+ self.vpc_id = None |
+ self.owner_id = None |
+ self.cidr_block = None |
+ |
+ def __repr__(self): |
+ return 'VpcInfo:%s' % self.vpc_id |
+ |
+ def startElement(self, name, attrs, connection): |
+ pass |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'vpcId': |
+ self.vpc_id = value |
+ elif name == 'ownerId': |
+ self.owner_id = value |
+ elif name == 'cidrBlock': |
+ self.cidr_block = value |
+ else: |
+ setattr(self, name, value) |
+ |
+class VpcPeeringConnectionStatus(object): |
+ """ |
+ The status of VPC peering connection. |
+ |
+ :ivar code: The status of the VPC peering connection. Valid values are: |
+ |
+ * pending-acceptance |
+ * failed |
+ * expired |
+ * provisioning |
+ * active |
+ * deleted |
+ * rejected |
+ |
+ :ivar message: A message that provides more information about the status of the VPC peering connection, if applicable. |
+ """ |
+ def __init__(self, code=0, message=None): |
+ self.code = code |
+ self.message = message |
+ |
+ def __repr__(self): |
+ return '%s(%d)' % (self.code, self.message) |
+ |
+ def startElement(self, name, attrs, connection): |
+ pass |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'code': |
+ self.code = value |
+ elif name == 'message': |
+ self.message = value |
+ else: |
+ setattr(self, name, value) |
+ |
+ |
+ |
+class VpcPeeringConnection(TaggedEC2Object): |
+ |
+ def __init__(self, connection=None): |
+ """ |
+ Represents a VPC peering connection. |
+ |
+ :ivar id: The unique ID of the VPC peering connection. |
+ :ivar accepter_vpc_info: Information on peer Vpc. |
+ :ivar requester_vpc_info: Information on requester Vpc. |
+ :ivar expiration_time: The expiration date and time for the VPC peering connection. |
+ :ivar status_code: The status of the VPC peering connection. |
+ :ivar status_message: A message that provides more information about the status of the VPC peering connection, if applicable. |
+ """ |
+ super(VpcPeeringConnection, self).__init__(connection) |
+ self.id = None |
+ self.accepter_vpc_info = VpcInfo() |
+ self.requester_vpc_info = VpcInfo() |
+ self.expiration_time = None |
+ self._status = VpcPeeringConnectionStatus() |
+ |
+ @property |
+ def status_code(self): |
+ return self._status.code |
+ |
+ @property |
+ def status_message(self): |
+ return self._status.message |
+ |
+ def __repr__(self): |
+ return 'VpcPeeringConnection:%s' % self.id |
+ |
+ def startElement(self, name, attrs, connection): |
+ retval = super(VpcPeeringConnection, self).startElement(name, attrs, connection) |
+ if retval is not None: |
+ return retval |
+ |
+ if name == 'requesterVpcInfo': |
+ return self.requester_vpc_info |
+ elif name == 'accepterVpcInfo': |
+ return self.accepter_vpc_info |
+ elif name == 'status': |
+ return self._status |
+ |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'vpcPeeringConnectionId': |
+ self.id = value |
+ elif name == 'expirationTime': |
+ self.expiration_time = value |
+ else: |
+ setattr(self, name, value) |
+ |
+ def delete(self): |
+ return self.connection.delete_vpc_peering_connection(self.id) |
+ |
+ def _update(self, updated): |
+ self.__dict__.update(updated.__dict__) |
+ |
+ def update(self, validate=False, dry_run=False): |
+ vpc_peering_connection_list = self.connection.get_all_vpc_peering_connections( |
+ [self.id], |
+ dry_run=dry_run |
+ ) |
+ if len(vpc_peering_connection_list): |
+ updated_vpc_peering_connection = vpc_peering_connection_list[0] |
+ self._update(updated_vpc_peering_connection) |
+ elif validate: |
+ raise ValueError('%s is not a valid VpcPeeringConnection ID' % (self.id,)) |
+ return self.status_code |