openbsd_pkg: add upgrade argument.

Running the module with the argument "upgrade=yes" invokes an upgrade of
all installed packages.

While here clean up some comments.

Functionality requested by @qbit.
pull/18777/head
Patrik Lundin 11 years ago committed by Matt Clay
parent d2110d7502
commit 6aaf5eb1d6

@ -59,6 +59,9 @@ EXAMPLES = '''
# Specify the default flavour to avoid ambiguity errors # Specify the default flavour to avoid ambiguity errors
- openbsd_pkg: name=vim-- state=present - openbsd_pkg: name=vim-- state=present
# Make sure all packages are upgraded
- openbsd_pkg: upgrade=yes
''' '''
# Control if we write debug information to syslog. # Control if we write debug information to syslog.
@ -266,8 +269,8 @@ def package_absent(name, installed_state, module):
return (rc, stdout, stderr, changed) return (rc, stdout, stderr, changed)
# Function used to parse the package name based on packages-specs(7) # Function used to parse the package name based on packages-specs(7).
# The general name structure is "stem-version[-flavors]" # The general name structure is "stem-version[-flavors]".
def parse_package_name(name, pkg_spec, module): def parse_package_name(name, pkg_spec, module):
# Do some initial matches so we can base the more advanced regex on that. # Do some initial matches so we can base the more advanced regex on that.
version_match = re.search("-[0-9]", name) version_match = re.search("-[0-9]", name)
@ -321,20 +324,55 @@ def parse_package_name(name, pkg_spec, module):
if match: if match:
module.fail_json(msg="Trailing dash in flavor: " + pkg_spec['flavor']) module.fail_json(msg="Trailing dash in flavor: " + pkg_spec['flavor'])
# Function used for upgrading all installed packages.
def upgrade_packages(module):
if module.check_mode:
upgrade_cmd = 'pkg_add -Imnu'
else:
upgrade_cmd = 'pkg_add -Imu'
# Attempt to upgrade all packages.
rc, stdout, stderr = execute_command("%s" % upgrade_cmd, module)
# Try to find any occurance of a package changing version like:
# "bzip2-1.0.6->1.0.6p0: ok".
match = re.search("\W\w.+->.+: ok\W", stdout)
if match:
if module.check_mode:
module.exit_json(changed=True)
changed=True
else:
changed=False
# It seems we can not trust the return value, so depend on the presence of
# stderr to know if something failed.
if stderr:
rc = 1
else:
rc = 0
return (rc, stdout, stderr, changed)
# =========================================== # ===========================================
# Main control flow # Main control flow.
def main(): def main():
module = AnsibleModule( module = AnsibleModule(
argument_spec = dict( argument_spec = dict(
name = dict(required=True), name = dict(),
state = dict(required=True, choices=['absent', 'installed', 'latest', 'present', 'removed']), state = dict(choices=['absent', 'installed', 'latest', 'present', 'removed']),
upgrade = dict(choices=['yes']),
), ),
mutually_exclusive = [['name', 'upgrade']],
required_one_of = [['name', 'upgrade']],
supports_check_mode = True supports_check_mode = True
) )
name = module.params['name'] name = module.params['name']
state = module.params['state'] state = module.params['state']
upgrade = module.params['upgrade']
rc = 0 rc = 0
stdout = '' stdout = ''
@ -342,21 +380,31 @@ def main():
result = {} result = {}
result['name'] = name result['name'] = name
result['state'] = state result['state'] = state
result['upgrade'] = upgrade
# Parse package name and put results in the pkg_spec dictionary.
pkg_spec = {} if name:
parse_package_name(name, pkg_spec, module) if not state:
module.fail_json(msg="missing required arguments: state")
# Get package state.
installed_state = get_package_state(name, pkg_spec, module) # Parse package name and put results in the pkg_spec dictionary.
pkg_spec = {}
# Perform requested action. parse_package_name(name, pkg_spec, module)
if state in ['installed', 'present']:
(rc, stdout, stderr, changed) = package_present(name, installed_state, pkg_spec, module) # Get package state.
elif state in ['absent', 'removed']: installed_state = get_package_state(name, pkg_spec, module)
(rc, stdout, stderr, changed) = package_absent(name, installed_state, module)
elif state == 'latest': # Perform requested action.
(rc, stdout, stderr, changed) = package_latest(name, installed_state, pkg_spec, module) if state in ['installed', 'present']:
(rc, stdout, stderr, changed) = package_present(name, installed_state, pkg_spec, module)
elif state in ['absent', 'removed']:
(rc, stdout, stderr, changed) = package_absent(name, installed_state, module)
elif state == 'latest':
(rc, stdout, stderr, changed) = package_latest(name, installed_state, pkg_spec, module)
elif upgrade:
# Perform an upgrade of all installed packages.
(rc, stdout, stderr, changed) = upgrade_packages(module)
else:
module.fail_json(msg="Something is broken, you should never end up here")
if rc != 0: if rc != 0:
if stderr: if stderr:
@ -368,6 +416,6 @@ def main():
module.exit_json(**result) module.exit_json(**result)
# import module snippets # Import module snippets.
from ansible.module_utils.basic import * from ansible.module_utils.basic import *
main() main()

Loading…
Cancel
Save