1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

svr4pkg supports the -G switch for pkgadd

This commit is contained in:
Alexander Winkler 2014-03-25 09:03:48 +00:00
parent 605156c904
commit 03040a97c8

View file

@ -57,6 +57,13 @@ options:
description: description:
- Specifies the location of a response file to be used if package expects input on install. (added in Ansible 1.4) - Specifies the location of a response file to be used if package expects input on install. (added in Ansible 1.4)
required: false required: false
zone:
description:
- Whether to install the package only in the current zone, or install it into all zones.
- The installation into all zones works only if you are working with the global zone.
required: false
default: "all"
choices: ["current", "all"]
''' '''
EXAMPLES = ''' EXAMPLES = '''
@ -64,7 +71,7 @@ EXAMPLES = '''
- svr4pkg: name=CSWcommon src=/tmp/cswpkgs.pkg state=present - svr4pkg: name=CSWcommon src=/tmp/cswpkgs.pkg state=present
# 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 zone=current
# Install a package with a response file # Install a package with a response file
- svr4pkg: name=CSWggrep src=/tmp/third-party.pkg response_file=/tmp/ggrep.response state=present - svr4pkg: name=CSWggrep src=/tmp/third-party.pkg response_file=/tmp/ggrep.response state=present
@ -116,9 +123,12 @@ 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, response_file): def package_install(module, name, src, proxy, response_file, zone):
adminfile = create_admin_file() adminfile = create_admin_file()
cmd = [ 'pkgadd', '-na', adminfile, '-d', src ] cmd = [ 'pkgadd', '-n']
if zone == 'current':
cmd += [ '-G' ]
cmd += [ '-a', adminfile, '-d', src ]
if proxy is not None: if proxy is not None:
cmd += [ '-x', proxy ] cmd += [ '-x', proxy ]
if response_file is not None: if response_file is not None:
@ -142,7 +152,8 @@ def main():
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),
response_file = dict(default = None) response_file = dict(default = None),
zone = dict(required=False, default = 'all', choices=['current','all'])
), ),
supports_check_mode=True supports_check_mode=True
) )
@ -151,6 +162,7 @@ def main():
src = module.params['src'] src = module.params['src']
proxy = module.params['proxy'] proxy = module.params['proxy']
response_file = module.params['response_file'] response_file = module.params['response_file']
zone = module.params['zone']
rc = None rc = None
out = '' out = ''
err = '' err = ''
@ -165,7 +177,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, response_file) (rc, out, err) = package_install(module, name, src, proxy, response_file, zone)
# 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: