diff options
| author | Todd Willey <todd@ansolabs.com> | 2011-06-25 02:30:47 +0000 |
|---|---|---|
| committer | Tarmac <> | 2011-06-25 02:30:47 +0000 |
| commit | 4db84dc78ae6660dbced7e9382ae5c441a135908 (patch) | |
| tree | 64c242a2d4ca45772e3a010d2e99f939564eb06e /nova/api | |
| parent | e6f3ce3541d3ce380c00dda3b878a652fc31f2fc (diff) | |
| parent | 51d93c5b1722bef9783cd7572c1464a084ece0aa (diff) | |
Add api methods to delete provider firewall rules.
Diffstat (limited to 'nova/api')
| -rw-r--r-- | nova/api/ec2/admin.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/nova/api/ec2/admin.py b/nova/api/ec2/admin.py index 343bc61c4..df7876b9d 100644 --- a/nova/api/ec2/admin.py +++ b/nova/api/ec2/admin.py @@ -369,3 +369,23 @@ class AdminController(object): raise exception.ApiError(_('Duplicate rule')) self.compute_api.trigger_provider_fw_rules_refresh(context) return {'status': 'OK', 'message': 'Added %s rules' % rules_added} + + def describe_external_address_blocks(self, context): + blocks = db.provider_fw_rule_get_all(context) + # NOTE(todd): use a set since we have icmp/udp/tcp rules with same cidr + blocks = set([b.cidr for b in blocks]) + blocks = [{'cidr': b} for b in blocks] + return {'externalIpBlockInfo': + list(sorted(blocks, key=lambda k: k['cidr']))} + + def remove_external_address_block(self, context, cidr): + LOG.audit(_('Removing ip block from %s'), cidr, context=context) + cidr = urllib.unquote(cidr).decode() + # raise if invalid + netaddr.IPNetwork(cidr) + rules = db.provider_fw_rule_get_all_by_cidr(context, cidr) + for rule in rules: + db.provider_fw_rule_destroy(context, rule['id']) + if rules: + self.compute_api.trigger_provider_fw_rules_refresh(context) + return {'status': 'OK', 'message': 'Deleted %s rules' % len(rules)} |
