diff --git a/library/group b/library/group index fc21c5c1a32..8f865bc1841 100755 --- a/library/group +++ b/library/group @@ -54,11 +54,10 @@ def add_group_info(kwargs): def group_del(group): cmd = [GROUPDEL, group] - rc = subprocess.call(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) - if rc == 0: - return True - else: - return False + p = subprocess.Popen(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) + (out, err) = p.communicate() + rc = p.returncode + return (rc, out, err) def group_add(group, **kwargs): cmd = [GROUPADD] @@ -69,11 +68,10 @@ def group_add(group, **kwargs): elif key == 'system' and kwargs[key] == 'yes': cmd.append('-r') cmd.append(group) - rc = subprocess.call(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) - if rc == 0: - return True - else: - return False + p = subprocess.Popen(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) + (out, err) = p.communicate() + rc = p.returncode + return (rc, out, err) def group_mod(group, **kwargs): cmd = [GROUPMOD] @@ -84,13 +82,12 @@ def group_mod(group, **kwargs): cmd.append('-g') cmd.append(kwargs[key]) if len(cmd) == 1: - return False + return (None, '', '') cmd.append(group) - rc = subprocess.call(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) - if rc == 0: - return True - else: - return False + p = subprocess.Popen(cmd, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE) + (out, err) = p.communicate() + rc = p.returncode + return (rc, out, err) def group_exists(group): try: @@ -156,18 +153,32 @@ if system not in ['yes', 'no']: if name is None: fail_json(msg='name is required') -changed = False -rc = 0 +rc = None +out = '' +err = '' +result = {} +result['name'] = name if state == 'absent': if group_exists(name): - changed = group_del(name) - exit_json(name=name, changed=changed) + (rc, out, err) = group_del(name) + if rc != 0: + fail_json(name=name, msg=err) elif state == 'present': if not group_exists(name): - changed = group_add(name, gid=gid, system=system) + (rc, out, err) = group_add(name, gid=gid, system=system) else: - changed = group_mod(name, gid=gid) + (rc, out, err) = group_mod(name, gid=gid) - exit_json(name=name, changed=changed) + if rc is not None and rc != 0: + fail_json(name=name, msg=err) +if rc is None: + result['changed'] = False +else: + result['changed'] = True +if out: + result['stdout'] = out +if err: + result['stderr'] = err +exit_json(**result) fail_json(name=name, msg='Unexpected position reached')