Implemented adding default entries to default network ACLs.
This commit is contained in:
parent
3c5ce6c09e
commit
68b8e6b636
@ -3560,8 +3560,22 @@ class NetworkAclBackend(object):
|
|||||||
self.get_vpc(vpc_id)
|
self.get_vpc(vpc_id)
|
||||||
network_acl = NetworkAcl(self, network_acl_id, vpc_id, default)
|
network_acl = NetworkAcl(self, network_acl_id, vpc_id, default)
|
||||||
self.network_acls[network_acl_id] = network_acl
|
self.network_acls[network_acl_id] = network_acl
|
||||||
|
if default:
|
||||||
|
self.add_default_entries(network_acl_id)
|
||||||
return network_acl
|
return network_acl
|
||||||
|
|
||||||
|
def add_default_entries(self, network_acl_id):
|
||||||
|
default_acl_entries = [
|
||||||
|
{'rule_number': 100, 'rule_action': 'allow', 'egress': 'true'},
|
||||||
|
{'rule_number': 32767, 'rule_action': 'deny', 'egress': 'true'},
|
||||||
|
{'rule_number': 100, 'rule_action': 'allow', 'egress': 'false'},
|
||||||
|
{'rule_number': 32767, 'rule_action': 'deny', 'egress': 'false'}
|
||||||
|
]
|
||||||
|
for entry in default_acl_entries:
|
||||||
|
self.create_network_acl_entry(network_acl_id=network_acl_id, rule_number=entry['rule_number'], protocol='-1',
|
||||||
|
rule_action=entry['rule_action'], egress=entry['egress'], cidr_block='0.0.0.0/0',
|
||||||
|
icmp_code=None, icmp_type=None, port_range_from=None, port_range_to=None)
|
||||||
|
|
||||||
def get_all_network_acls(self, network_acl_ids=None, filters=None):
|
def get_all_network_acls(self, network_acl_ids=None, filters=None):
|
||||||
network_acls = self.network_acls.values()
|
network_acls = self.network_acls.values()
|
||||||
|
|
||||||
|
@ -190,3 +190,27 @@ def test_new_subnet_in_new_vpc_associates_with_default_network_acl():
|
|||||||
new_vpcs_default_network_acl.vpc_id.should.equal(new_vpc.id)
|
new_vpcs_default_network_acl.vpc_id.should.equal(new_vpc.id)
|
||||||
new_vpcs_default_network_acl.associations.should.have.length_of(1)
|
new_vpcs_default_network_acl.associations.should.have.length_of(1)
|
||||||
new_vpcs_default_network_acl.associations[0]['SubnetId'].should.equal(subnet.id)
|
new_vpcs_default_network_acl.associations[0]['SubnetId'].should.equal(subnet.id)
|
||||||
|
|
||||||
|
|
||||||
|
@mock_ec2
|
||||||
|
def test_default_network_acl_default_entries():
|
||||||
|
ec2 = boto3.resource('ec2', region_name='us-west-1')
|
||||||
|
default_network_acl = next(iter(ec2.network_acls.all()), None)
|
||||||
|
default_network_acl.is_default.should.be.ok
|
||||||
|
|
||||||
|
default_network_acl.entries.should.have.length_of(4)
|
||||||
|
unique_entries = []
|
||||||
|
for entry in default_network_acl.entries:
|
||||||
|
entry['CidrBlock'].should.equal('0.0.0.0/0')
|
||||||
|
entry['Protocol'].should.equal('-1')
|
||||||
|
entry['RuleNumber'].should.be.within([100, 32767])
|
||||||
|
entry['RuleAction'].should.be.within(['allow', 'deny'])
|
||||||
|
assert type(entry['Egress']) is bool
|
||||||
|
if entry['RuleAction'] == 'allow':
|
||||||
|
entry['RuleNumber'].should.be.equal(100)
|
||||||
|
else:
|
||||||
|
entry['RuleNumber'].should.be.equal(32767)
|
||||||
|
if entry not in unique_entries:
|
||||||
|
unique_entries.append(entry)
|
||||||
|
|
||||||
|
unique_entries.should.have.length_of(4)
|
||||||
|
Loading…
Reference in New Issue
Block a user