user - allow 'groups', 'append' with 'local' (#62134)

pull/67174/head
Todd Lewis 5 years ago committed by GitHub
parent c3635532d3
commit 640bf31f87
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,2 @@
minor_changes:
- user - allow groups, append parameters with local

@ -59,14 +59,12 @@ options:
- List of groups user will be added to. When set to an empty string C(''),
the user is removed from all groups except the primary group.
- Before Ansible 2.3, the only input format allowed was a comma separated string.
- Mutually exclusive with C(local)
type: list
append:
description:
- If C(yes), add the user to the groups specified in C(groups).
- If C(no), user will only be added to the groups specified in C(groups),
removing them from all other groups.
- Mutually exclusive with C(local)
type: bool
default: no
shell:
@ -211,7 +209,6 @@ options:
- This will check C(/etc/passwd) for an existing account before invoking commands. If the local account database
exists somewhere other than C(/etc/passwd), this setting will not work properly.
- This requires that the above commands as well as C(/etc/passwd) must exist on the target host, otherwise it will be a fatal error.
- Mutually exclusive with C(groups) and C(append)
type: bool
default: no
version_added: "2.4"
@ -573,7 +570,7 @@ class User(object):
command_name = 'userdel'
cmd = [self.module.get_bin_path(command_name, True)]
if self.force:
if self.force and not self.local:
cmd.append('-f')
if self.remove:
cmd.append('-r')
@ -585,6 +582,7 @@ class User(object):
if self.local:
command_name = 'luseradd'
lgroupmod_cmd = self.module.get_bin_path('lgroupmod', True)
else:
command_name = 'useradd'
@ -613,7 +611,7 @@ class User(object):
if os.path.exists('/etc/redhat-release'):
dist = distro.linux_distribution(full_distribution_name=False)
major_release = int(dist[1].split('.')[0])
if major_release <= 5:
if major_release <= 5 or self.local:
cmd.append('-n')
else:
cmd.append('-N')
@ -627,8 +625,9 @@ class User(object):
else:
cmd.append('-N')
if self.groups is not None and not self.local and len(self.groups):
if self.groups is not None and len(self.groups):
groups = self.get_groups_set()
if not self.local:
cmd.append('-G')
cmd.append(','.join(groups))
@ -675,7 +674,17 @@ class User(object):
cmd.append('-r')
cmd.append(self.name)
return self.execute_command(cmd)
(rc, err, out) = self.execute_command(cmd)
if not self.local or rc != 0 or self.groups is None or len(self.groups) == 0:
return (rc, err, out)
for add_group in groups:
(rc, _err, _out) = self.execute_command([lgroupmod_cmd, '-M', self.name, add_group])
out += _out
err += _err
if rc != 0:
return (rc, out, err)
return (rc, out, err)
def _check_usermod_append(self):
# check if this version of usermod can append groups
@ -708,6 +717,9 @@ class User(object):
if self.local:
command_name = 'lusermod'
lgroupmod_cmd = self.module.get_bin_path('lgroupmod', True)
lgroupmod_add = set()
lgroupmod_del = set()
else:
command_name = 'usermod'
@ -754,7 +766,15 @@ class User(object):
else:
groups_need_mod = True
if groups_need_mod and not self.local:
if groups_need_mod:
if self.local:
if self.append:
lgroupmod_add = set(groups).difference(current_groups)
lgroupmod_del = set()
else:
lgroupmod_add = set(groups).difference(current_groups)
lgroupmod_del = set(current_groups).difference(groups)
else:
if self.append and not has_append:
cmd.append('-A')
cmd.append(','.join(group_diff))
@ -804,12 +824,30 @@ class User(object):
cmd.append('-p')
cmd.append(self.password)
# skip if no changes to be made
if len(cmd) == 1:
return (None, '', '')
(rc, err, out) = (None, '', '')
# skip if no usermod changes to be made
if len(cmd) > 1:
cmd.append(self.name)
return self.execute_command(cmd)
(rc, err, out) = self.execute_command(cmd)
if not self.local or not (rc is None or rc == 0) or (len(lgroupmod_add) == 0 and len(lgroupmod_del) == 0):
return (rc, err, out)
for add_group in lgroupmod_add:
(rc, _err, _out) = self.execute_command([lgroupmod_cmd, '-M', self.name, add_group])
out += _out
err += _err
if rc != 0:
return (rc, out, err)
for del_group in lgroupmod_del:
(rc, _err, _out) = self.execute_command([lgroupmod_cmd, '-m', self.name, del_group])
out += _out
err += _err
if rc != 0:
return (rc, out, err)
return (rc, out, err)
def group_exists(self, group):
try:
@ -2873,10 +2911,6 @@ def main():
role=dict(type='str'),
),
supports_check_mode=True,
mutually_exclusive=[
('local', 'groups'),
('local', 'append')
]
)
user = User(module)

@ -789,6 +789,7 @@
name: ansibulluser
state: present
generate_ssh_key: yes
force: yes
ssh_key_file: "{{ output_dir }}/test_id_rsa"
ssh_key_passphrase: secret_passphrase
@ -994,9 +995,14 @@
tags:
- user_test_local_mode
- name: Create test group
- name: Create test groups
group:
name: testgroup
name: "{{ item }}"
loop:
- testgroup1
- testgroup2
- testgroup3
- testgroup4
tags:
- user_test_local_mode
@ -1005,7 +1011,7 @@
name: local_ansibulluser
state: present
local: yes
groups: testgroup
groups: ['testgroup1', 'testgroup2']
register: local_user_test_3
ignore_errors: yes
tags:
@ -1016,6 +1022,7 @@
name: local_ansibulluser
state: present
local: yes
groups: ['testgroup3', 'testgroup4']
append: yes
register: local_user_test_4
ignore_errors: yes
@ -1032,15 +1039,34 @@
tags:
- user_test_local_mode
- name: Remove local_ansibulluser again
user:
name: local_ansibulluser
state: absent
remove: yes
local: yes
tags:
- user_test_local_mode
- name: Remove test groups
group:
name: "{{ item }}"
state: absent
loop:
- testgroup1
- testgroup2
- testgroup3
- testgroup4
tags:
- user_test_local_mode
- name: Ensure local user accounts were created and removed properly
assert:
that:
- local_user_test_1 is changed
- local_user_test_2 is not changed
- local_user_test_3 is failed
- 'local_user_test_3["msg"] is search("parameters are mutually exclusive: groups|local")'
- local_user_test_4 is failed
- 'local_user_test_4["msg"] is search("parameters are mutually exclusive: groups|append")'
- local_user_test_3 is changed
- local_user_test_4 is changed
- local_user_test_remove_1 is changed
- local_user_test_remove_2 is not changed
tags:

Loading…
Cancel
Save