fixed a few issues pointed out by @resmo, pyflakes, pep8

This commit is contained in:
Kim Nørgaard 2015-07-31 11:21:25 +02:00 committed by Matt Clay
parent 7cc2cd7881
commit 8a826d61e9

View file

@ -5,8 +5,8 @@
# Written by Kim Nørgaard <jasen@jasen.dk> # Written by Kim Nørgaard <jasen@jasen.dk>
# Based on pkgng module written by bleader <bleader@ratonland.org> # Based on pkgng module written by bleader <bleader@ratonland.org>
# that was based on pkgin module written by Shaun Zinck <shaun.zinck at gmail.com> # that was based on pkgin module written by Shaun Zinck <shaun.zinck at gmail.com>
# that was based on pacman module written by Afterburn <http://github.com/afterburn> # that was based on pacman module written by Afterburn <http://github.com/afterburn>
# that was based on apt module written by Matthew Williams <matthew@flowroute.com> # that was based on apt module written by Matthew Williams <matthew@flowroute.com>
# #
# This module is free software: you can redistribute it and/or modify # This module is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
@ -29,7 +29,7 @@ short_description: Package manager for Slackware >= 12.2
description: description:
- Manage binary packages for Slackware using 'slackpkg' which - Manage binary packages for Slackware using 'slackpkg' which
is available in versions after 12.2. is available in versions after 12.2.
version_added: "1.6" version_added: "2.0"
options: options:
name: name:
description: description:
@ -50,7 +50,8 @@ options:
default: false default: false
choices: [ true, false ] choices: [ true, false ]
author: Kim Nørgaard author: Kim Nørgaard (@KimNorgaard)
requirements: [ "Slackware" >= 12.2 ]
notes: [] notes: []
''' '''
@ -58,23 +59,19 @@ EXAMPLES = '''
# Install package foo # Install package foo
- slackpkg: name=foo state=present - slackpkg: name=foo state=present
# Remove packages foo and bar # Remove packages foo and bar
- slackpkg: name=foo,bar state=absent - slackpkg: name=foo,bar state=absent
''' '''
import json
import shlex
import os
import sys
def query_package(module, slackpkg_path, name): def query_package(module, slackpkg_path, name):
import glob import glob
import platform import platform
machine = platform.machine() machine = platform.machine()
packages = glob.glob("/var/log/packages/%s-*-[%s|noarch]*" % (name, machine)) packages = glob.glob("/var/log/packages/%s-*-[%s|noarch]*" % (name,
machine))
if len(packages) > 0: if len(packages) > 0:
return True return True
@ -83,7 +80,7 @@ def query_package(module, slackpkg_path, name):
def remove_packages(module, slackpkg_path, packages): def remove_packages(module, slackpkg_path, packages):
remove_c = 0 remove_c = 0
# Using a for loop incase of error, we can report the package that failed # Using a for loop incase of error, we can report the package that failed
for package in packages: for package in packages:
@ -92,11 +89,14 @@ def remove_packages(module, slackpkg_path, packages):
continue continue
if not module.check_mode: if not module.check_mode:
rc, out, err = module.run_command("%s -default_answer=y -batch=on remove %s" % (slackpkg_path, package)) rc, out, err = module.run_command("%s -default_answer=y -batch=on \
remove %s" % (slackpkg_path,
package))
if not module.check_mode and query_package(module, slackpkg_path, package): if not module.check_mode and query_package(module, slackpkg_path,
package):
module.fail_json(msg="failed to remove %s: %s" % (package, out)) module.fail_json(msg="failed to remove %s: %s" % (package, out))
remove_c += 1 remove_c += 1
if remove_c > 0: if remove_c > 0:
@ -115,55 +115,70 @@ def install_packages(module, slackpkg_path, packages):
continue continue
if not module.check_mode: if not module.check_mode:
rc, out, err = module.run_command("%s -default_answer=y -batch=on install %s" % (slackpkg_path, package)) rc, out, err = module.run_command("%s -default_answer=y -batch=on \
install %s" % (slackpkg_path,
package))
if not module.check_mode and not query_package(module, slackpkg_path, package): if not module.check_mode and not query_package(module, slackpkg_path,
module.fail_json(msg="failed to install %s: %s" % (package, out), stderr=err) package):
module.fail_json(msg="failed to install %s: %s" % (package, out),
stderr=err)
install_c += 1 install_c += 1
if install_c > 0: if install_c > 0:
module.exit_json(changed=True, msg="present %s package(s)" % (install_c)) module.exit_json(changed=True, msg="present %s package(s)"
% (install_c))
module.exit_json(changed=False, msg="package(s) already present") module.exit_json(changed=False, msg="package(s) already present")
def upgrade_packages(module, slackpkg_path, packages):
def upgrade_packages(module, slackpkg_path, packages):
install_c = 0 install_c = 0
for package in packages: for package in packages:
if not module.check_mode: if not module.check_mode:
rc, out, err = module.run_command("%s -default_answer=y -batch=on upgrade %s" % (slackpkg_path, package)) rc, out, err = module.run_command("%s -default_answer=y -batch=on \
upgrade %s" % (slackpkg_path,
package))
if not module.check_mode and not query_package(module, slackpkg_path, package): if not module.check_mode and not query_package(module, slackpkg_path,
module.fail_json(msg="failed to install %s: %s" % (package, out), stderr=err) package):
module.fail_json(msg="failed to install %s: %s" % (package, out),
stderr=err)
install_c += 1 install_c += 1
if install_c > 0: if install_c > 0:
module.exit_json(changed=True, msg="present %s package(s)" % (install_c)) module.exit_json(changed=True, msg="present %s package(s)"
% (install_c))
module.exit_json(changed=False, msg="package(s) already present") module.exit_json(changed=False, msg="package(s) already present")
def update_cache(module, slackpkg_path): def update_cache(module, slackpkg_path):
rc, out, err = module.run_command("%s -batch=on update" % (slackpkg_path)) rc, out, err = module.run_command("%s -batch=on update" % (slackpkg_path))
if rc != 0: if rc != 0:
module.fail_json(msg="Could not update package cache") module.fail_json(msg="Could not update package cache")
def main(): def main():
module = AnsibleModule( module = AnsibleModule(
argument_spec = dict( argument_spec=dict(
state = dict(default="installed", choices=['installed', 'removed', 'absent', 'present', 'latest']), state=dict(default="installed", choices=['installed', 'removed',
name = dict(aliases=["pkg"], required=True), 'absent', 'present',
update_cache = dict(default=False, aliases=["update-cache"], type='bool'), 'latest']),
name=dict(aliases=["pkg"], required=True, type='list'),
update_cache=dict(default=False, aliases=["update-cache"],
type='bool'),
), ),
supports_check_mode = True) supports_check_mode=True)
slackpkg_path = module.get_bin_path('slackpkg', True) slackpkg_path = module.get_bin_path('slackpkg', True)
p = module.params p = module.params
pkgs = p['name'].split(",") pkgs = p['name']
if p["update_cache"]: if p["update_cache"]:
update_cache(module, slackpkg_path) update_cache(module, slackpkg_path)
@ -171,13 +186,13 @@ def main():
if p['state'] == 'latest': if p['state'] == 'latest':
upgrade_packages(module, slackpkg_path, pkgs) upgrade_packages(module, slackpkg_path, pkgs)
elif p['state'] in [ 'present', 'installed' ]: elif p['state'] in ['present', 'installed']:
install_packages(module, slackpkg_path, pkgs) install_packages(module, slackpkg_path, pkgs)
elif p["state"] in [ 'removed', 'absent' ]: elif p["state"] in ['removed', 'absent']:
remove_packages(module, slackpkg_path, pkgs) remove_packages(module, slackpkg_path, pkgs)
# import module snippets # import module snippets
from ansible.module_utils.basic import * from ansible.module_utils.basic import *
main() main()