vyos_user fix idempotent (#26289)

Signed-off-by: Trishna Guha <trishnaguha17@gmail.com>
This commit is contained in:
Trishna Guha 2017-06-30 19:44:08 +05:30 committed by GitHub
parent 34589cee6d
commit 93bbcd8a32
3 changed files with 38 additions and 19 deletions

View file

@ -159,7 +159,10 @@ def spec_to_commands(updates, module):
continue continue
if needs_update(want, have, 'level'): if needs_update(want, have, 'level'):
add(commands, want, 'level %s' % want['level']) add(commands, want, "level %s" % want['level'])
if needs_update(want, have, 'full_name'):
add(commands, want, "full-name %s" % want['full_name'])
if needs_update(want, have, 'password'): if needs_update(want, have, 'password'):
if update_password == 'always' or not have: if update_password == 'always' or not have:
@ -168,24 +171,41 @@ def spec_to_commands(updates, module):
return commands return commands
def parse_level(data):
match = re.search(r'level (\S+)', data, re.M)
if match:
level = match.group(1)[1:-1]
return level
def parse_full_name(data):
match = re.search(r'full-name (\S+)', data, re.M)
if match:
full_name = match.group(1)[1:-1]
return full_name
def config_to_dict(module): def config_to_dict(module):
data = get_config(module) data = get_config(module)
instances = []
config = {'name': [], 'level': [], 'full_name': [], 'password': None, 'state': 'present'} match = re.findall(r'^set system login user (\S+)', data, re.M)
if not match:
return list()
for line in data.split('\n'): instances = list()
if line.startswith('set system login user'):
match = re.findall(r'user (\S+)', line, re.M)
config['name'].extend(match)
if 'level' in line:
match = re.findall(r'level (\S+)', line, re.M)
config['level'].extend(match)
if 'full-name' in line:
match = re.findall(r'full-name (\S+)', line, re.M)
config['full_name'].extend(match)
instances = [config] for user in set(match):
regex = r' %s .+$' % user
cfg = re.findall(regex, data, re.M)
cfg = '\n'.join(cfg)
obj = {
'name': user,
'state': 'present',
'password': None,
'level': parse_level(cfg),
'full_name': parse_full_name(cfg)
}
instances.append(obj)
return instances return instances
@ -234,6 +254,7 @@ def map_params_to_obj(module):
for item in collection: for item in collection:
get_value = partial(get_param_value, item=item, module=module) get_value = partial(get_param_value, item=item, module=module)
item['password'] = get_value('password') item['password'] = get_value('password')
item['full_name'] = get_value('full_name')
item['level'] = get_value('level') item['level'] = get_value('level')
item['state'] = get_value('state') item['state'] = get_value('state')
objects.append(item) objects.append(item)
@ -243,7 +264,6 @@ def map_params_to_obj(module):
def update_objects(want, have): def update_objects(want, have):
updates = list() updates = list()
for entry in want: for entry in want:
item = next((i for i in have if i['name'] == entry['name']), None) item = next((i for i in have if i['name'] == entry['name']), None)
if item is None: if item is None:
@ -292,8 +312,7 @@ def main():
if module.params['purge']: if module.params['purge']:
want_users = [x['name'] for x in want] want_users = [x['name'] for x in want]
for x in have: have_users = [x['name'] for x in have]
have_users = x['name']
for item in set(have_users).difference(want_users): for item in set(have_users).difference(want_users):
commands.append('delete system login user %s' % item) commands.append('delete system login user %s' % item)

View file

@ -33,6 +33,7 @@
name: ansibletest1 name: ansibletest1
password: test password: test
state: present state: present
update_password: on_create
provider: "{{ cli }}" provider: "{{ cli }}"
register: result register: result

View file

@ -77,8 +77,7 @@ class TestVyosUserModule(TestVyosModule):
def test_vyos_user_update_password_on_create_ok(self): def test_vyos_user_update_password_on_create_ok(self):
set_module_args(dict(name='ansible', password='test', update_password='on_create')) set_module_args(dict(name='ansible', password='test', update_password='on_create'))
result = self.execute_module(changed=True) self.execute_module()
self.assertEqual(result['commands'], ['set system login user ansible authentication plaintext-password test'])
def test_vyos_user_update_password_always(self): def test_vyos_user_update_password_always(self):
set_module_args(dict(name='ansible', password='test', update_password='always')) set_module_args(dict(name='ansible', password='test', update_password='always'))