diff options
author | 2017-07-27 00:59:13 +0000 | |
---|---|---|
committer | 2017-07-27 00:59:13 +0000 | |
commit | 55ab19b724474a7db45f7aa62d89097a57cb97cb (patch) | |
tree | c7e9147f37005bfcb6a3787d6e1a4a3f5d620069 /deploy/post/neutron.py | |
parent | 1efff0d9d55114ba5bad95c1e21c2909edd649f5 (diff) | |
parent | 8d951bd35aca9af5f4fa26fec643d25622f4f466 (diff) |
Merge "Convert the bash commands in post.sh to python code"
Diffstat (limited to 'deploy/post/neutron.py')
-rw-r--r-- | deploy/post/neutron.py | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/deploy/post/neutron.py b/deploy/post/neutron.py index 77791ea8..79703310 100644 --- a/deploy/post/neutron.py +++ b/deploy/post/neutron.py @@ -67,3 +67,31 @@ class Neutron(keystoneauth.ClientBase): except Exception, e: print('_create_subnet fail with: {}'.format(e)) return None + + def _list_security_groups(self): + return self.client.list_security_groups()['security_groups'] + + def get_security_group_by_name(self, name): + return query.find(lambda nw: nw['name'] == name, self._list_security_groups()) + + def _check_security_group_rule_conflict(self, security_group, body): + newrule = body['security_group_rule'] + rules = security_group['security_group_rules'] + for rule in rules: + is_same = True + for key in newrule.keys(): + if key in rule and newrule[key] != rule[key]: + is_same = False + break + if is_same: + print('The rule already exists in the security group %s' % security_group['id']) + return True + return False + + def create_security_group_rule(self, security_group, body): + if not self._check_security_group_rule_conflict(security_group, body): + try: + rule = self.client.create_security_group_rule(body=body) + print('create_security_group_rule success with id %s' % rule['security_group_rule']['id']) + except Exception, e: + print('create_security_group_rule fail with exception %s' % e) |