vyos_user fix idempotent (#26289)
Signed-off-by: Trishna Guha <trishnaguha17@gmail.com>
This commit is contained in:
parent
34589cee6d
commit
93bbcd8a32
3 changed files with 38 additions and 19 deletions
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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'))
|
||||||
|
|
Loading…
Reference in a new issue