Index: third_party/gsutil/third_party/boto/boto/vpc/networkacl.py |
diff --git a/third_party/gsutil/third_party/boto/boto/vpc/networkacl.py b/third_party/gsutil/third_party/boto/boto/vpc/networkacl.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..9b8b1cddcfbec92cf672be5f8be052089e79682c |
--- /dev/null |
+++ b/third_party/gsutil/third_party/boto/boto/vpc/networkacl.py |
@@ -0,0 +1,164 @@ |
+# Copyright (c) 2009-2010 Mitch Garnaat http://garnaat.org/ |
+# |
+# 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 Network ACL |
+""" |
+ |
+from boto.ec2.ec2object import TaggedEC2Object |
+from boto.resultset import ResultSet |
+ |
+ |
+class Icmp(object): |
+ """ |
+ Defines the ICMP code and type. |
+ """ |
+ def __init__(self, connection=None): |
+ self.code = None |
+ self.type = None |
+ |
+ def __repr__(self): |
+ return 'Icmp::code:%s, type:%s)' % ( self.code, self.type) |
+ |
+ def startElement(self, name, attrs, connection): |
+ pass |
+ |
+ def endElement(self, name, value, connection): |
+ |
+ if name == 'code': |
+ self.code = value |
+ elif name == 'type': |
+ self.type = value |
+ |
+class NetworkAcl(TaggedEC2Object): |
+ |
+ def __init__(self, connection=None): |
+ super(NetworkAcl, self).__init__(connection) |
+ self.id = None |
+ self.vpc_id = None |
+ self.network_acl_entries = [] |
+ self.associations = [] |
+ |
+ def __repr__(self): |
+ return 'NetworkAcl:%s' % self.id |
+ |
+ def startElement(self, name, attrs, connection): |
+ result = super(NetworkAcl, self).startElement(name, attrs, connection) |
+ |
+ if result is not None: |
+ # Parent found an interested element, just return it |
+ return result |
+ |
+ if name == 'entrySet': |
+ self.network_acl_entries = ResultSet([('item', NetworkAclEntry)]) |
+ return self.network_acl_entries |
+ elif name == 'associationSet': |
+ self.associations = ResultSet([('item', NetworkAclAssociation)]) |
+ return self.associations |
+ else: |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'networkAclId': |
+ self.id = value |
+ elif name == 'vpcId': |
+ self.vpc_id = value |
+ else: |
+ setattr(self, name, value) |
+ |
+class NetworkAclEntry(object): |
+ def __init__(self, connection=None): |
+ self.rule_number = None |
+ self.protocol = None |
+ self.rule_action = None |
+ self.egress = None |
+ self.cidr_block = None |
+ self.port_range = PortRange() |
+ self.icmp = Icmp() |
+ |
+ def __repr__(self): |
+ return 'Acl:%s' % self.rule_number |
+ |
+ def startElement(self, name, attrs, connection): |
+ |
+ if name == 'portRange': |
+ return self.port_range |
+ elif name == 'icmpTypeCode': |
+ return self.icmp |
+ else: |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'cidrBlock': |
+ self.cidr_block = value |
+ elif name == 'egress': |
+ self.egress = value |
+ elif name == 'protocol': |
+ self.protocol = value |
+ elif name == 'ruleAction': |
+ self.rule_action = value |
+ elif name == 'ruleNumber': |
+ self.rule_number = value |
+ |
+ |
+class NetworkAclAssociation(object): |
+ def __init__(self, connection=None): |
+ self.id = None |
+ self.subnet_id = None |
+ self.network_acl_id = None |
+ |
+ def __repr__(self): |
+ return 'NetworkAclAssociation:%s' % self.id |
+ |
+ def startElement(self, name, attrs, connection): |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'networkAclAssociationId': |
+ self.id = value |
+ elif name == 'networkAclId': |
+ self.network_acl_id = value |
+ elif name == 'subnetId': |
+ self.subnet_id = value |
+ |
+class PortRange(object): |
+ """ |
+ Define the port range for the ACL entry if it is tcp / udp |
+ """ |
+ |
+ def __init__(self, connection=None): |
+ self.from_port = None |
+ self.to_port = None |
+ |
+ def __repr__(self): |
+ return 'PortRange:(%s-%s)' % ( self.from_port, self.to_port) |
+ |
+ def startElement(self, name, attrs, connection): |
+ pass |
+ |
+ def endElement(self, name, value, connection): |
+ |
+ if name == 'from': |
+ self.from_port = value |
+ elif name == 'to': |
+ self.to_port = value |
+ |
+ |