Added multi package operation to remove as suggested by @abadger. Adding to latest is a little more complex due to '*' support.
This commit is contained in:
parent
32180c3c0e
commit
9707a5a95e
1 changed files with 14 additions and 9 deletions
|
@ -642,6 +642,7 @@ def install(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos):
|
||||||
|
|
||||||
def remove(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos):
|
def remove(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos):
|
||||||
|
|
||||||
|
pkgs = []
|
||||||
res = {}
|
res = {}
|
||||||
res['results'] = []
|
res['results'] = []
|
||||||
res['msg'] = ''
|
res['msg'] = ''
|
||||||
|
@ -658,17 +659,20 @@ def remove(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos):
|
||||||
res['results'].append('%s is not installed' % pkg)
|
res['results'].append('%s is not installed' % pkg)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
pkgs.append(pkg)
|
||||||
|
|
||||||
|
if pkgs:
|
||||||
# run an actual yum transaction
|
# run an actual yum transaction
|
||||||
cmd = yum_basecmd + ["remove", pkg]
|
cmd = yum_basecmd + ["remove"] + pkg
|
||||||
|
|
||||||
if module.check_mode:
|
if module.check_mode:
|
||||||
module.exit_json(changed=True)
|
module.exit_json(changed=True)
|
||||||
|
|
||||||
rc, out, err = module.run_command(cmd)
|
rc, out, err = module.run_command(cmd)
|
||||||
|
|
||||||
res['rc'] += rc
|
res['rc'] = rc
|
||||||
res['results'].append(out)
|
res['results'].append(out)
|
||||||
res['msg'] += err
|
res['msg'] = err
|
||||||
|
|
||||||
# compile the results into one batch. If anything is changed
|
# compile the results into one batch. If anything is changed
|
||||||
# then mark changed
|
# then mark changed
|
||||||
|
@ -677,12 +681,13 @@ def remove(module, items, repoq, yum_basecmd, conf_file, en_repos, dis_repos):
|
||||||
|
|
||||||
# at this point we should check to see if the pkg is no longer present
|
# at this point we should check to see if the pkg is no longer present
|
||||||
|
|
||||||
if not is_group: # we can't sensibly check for a group being uninstalled reliably
|
for pkg in pkgs:
|
||||||
# look to see if the pkg shows up from is_installed. If it doesn't
|
if not pkg.startswith('@'): # we can't sensibly check for a group being uninstalled reliably
|
||||||
if not is_installed(module, repoq, pkg, conf_file, en_repos=en_repos, dis_repos=dis_repos):
|
# look to see if the pkg shows up from is_installed. If it doesn't
|
||||||
res['changed'] = True
|
if not is_installed(module, repoq, pkg, conf_file, en_repos=en_repos, dis_repos=dis_repos):
|
||||||
else:
|
res['changed'] = True
|
||||||
module.fail_json(**res)
|
else:
|
||||||
|
module.fail_json(**res)
|
||||||
|
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
module.fail_json(**res)
|
module.fail_json(**res)
|
||||||
|
|
Loading…
Reference in a new issue