mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Added resp= option for svr4pkg to enable the -r option in pkgadd for response files
This commit is contained in:
parent
3f968ff46a
commit
e581156dfc
1 changed files with 13 additions and 3 deletions
|
@ -53,6 +53,9 @@ options:
|
||||||
proxy:
|
proxy:
|
||||||
description:
|
description:
|
||||||
- HTTP[s] proxy to be used if C(src) is a URL.
|
- HTTP[s] proxy to be used if C(src) is a URL.
|
||||||
|
resp:
|
||||||
|
description:
|
||||||
|
- Specifies the location of a response file to be used if package expects input on install.
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
|
@ -62,6 +65,9 @@ EXAMPLES = '''
|
||||||
# Install a package directly from an http site
|
# Install a package directly from an http site
|
||||||
- svr4pkg: name=CSWpkgutil src=http://get.opencsw.org/now state=present
|
- svr4pkg: name=CSWpkgutil src=http://get.opencsw.org/now state=present
|
||||||
|
|
||||||
|
# Install a package with a response file
|
||||||
|
- svr4pkg: name=CSWggrep src=/tmp/third-party.pkg resp=/tmp/ggrep.response state=present
|
||||||
|
|
||||||
# Ensure that a package is not installed.
|
# Ensure that a package is not installed.
|
||||||
- svr4pkg: name=SUNWgnome-sound-recorder state=absent
|
- svr4pkg: name=SUNWgnome-sound-recorder state=absent
|
||||||
'''
|
'''
|
||||||
|
@ -109,11 +115,13 @@ def run_command(module, cmd):
|
||||||
cmd[0] = module.get_bin_path(progname, True)
|
cmd[0] = module.get_bin_path(progname, True)
|
||||||
return module.run_command(cmd)
|
return module.run_command(cmd)
|
||||||
|
|
||||||
def package_install(module, name, src, proxy):
|
def package_install(module, name, src, proxy, resp):
|
||||||
adminfile = create_admin_file()
|
adminfile = create_admin_file()
|
||||||
cmd = [ 'pkgadd', '-na', adminfile, '-d', src ]
|
cmd = [ 'pkgadd', '-na', adminfile, '-d', src ]
|
||||||
if proxy is not None:
|
if proxy is not None:
|
||||||
cmd += [ '-x', proxy ]
|
cmd += [ '-x', proxy ]
|
||||||
|
if resp is not None:
|
||||||
|
cmd += [ '-r', resp ]
|
||||||
cmd.append(name)
|
cmd.append(name)
|
||||||
(rc, out, err) = run_command(module, cmd)
|
(rc, out, err) = run_command(module, cmd)
|
||||||
os.unlink(adminfile)
|
os.unlink(adminfile)
|
||||||
|
@ -132,7 +140,8 @@ def main():
|
||||||
name = dict(required = True),
|
name = dict(required = True),
|
||||||
state = dict(required = True, choices=['present', 'absent']),
|
state = dict(required = True, choices=['present', 'absent']),
|
||||||
src = dict(default = None),
|
src = dict(default = None),
|
||||||
proxy = dict(default = None)
|
proxy = dict(default = None),
|
||||||
|
resp = dict(default = None)
|
||||||
),
|
),
|
||||||
supports_check_mode=True
|
supports_check_mode=True
|
||||||
)
|
)
|
||||||
|
@ -140,6 +149,7 @@ def main():
|
||||||
name = module.params['name']
|
name = module.params['name']
|
||||||
src = module.params['src']
|
src = module.params['src']
|
||||||
proxy = module.params['proxy']
|
proxy = module.params['proxy']
|
||||||
|
resp = module.params['resp']
|
||||||
rc = None
|
rc = None
|
||||||
out = ''
|
out = ''
|
||||||
err = ''
|
err = ''
|
||||||
|
@ -154,7 +164,7 @@ def main():
|
||||||
if not package_installed(module, name):
|
if not package_installed(module, name):
|
||||||
if module.check_mode:
|
if module.check_mode:
|
||||||
module.exit_json(changed=True)
|
module.exit_json(changed=True)
|
||||||
(rc, out, err) = package_install(module, name, src, proxy)
|
(rc, out, err) = package_install(module, name, src, proxy, resp)
|
||||||
# Stdout is normally empty but for some packages can be
|
# Stdout is normally empty but for some packages can be
|
||||||
# very long and is not often useful
|
# very long and is not often useful
|
||||||
if len(out) > 75:
|
if len(out) > 75:
|
||||||
|
|
Loading…
Reference in a new issue