mirror of https://github.com/kewlfft/ansible-aur
Revert "Add use_args option for explicit helpers"
parent
e03b3f0579
commit
89deaaa772
|
@ -17,11 +17,10 @@ The following helpers are supported and automatically selected, if present, in t
|
||||||
|name | |Name or list of names of the package(s) to install or upgrade.|
|
|name | |Name or list of names of the package(s) to install or upgrade.|
|
||||||
|state |**present**, latest |Desired state of the package, 'present' skips operations if the package is already installed.|
|
|state |**present**, latest |Desired state of the package, 'present' skips operations if the package is already installed.|
|
||||||
|upgrade |yes, **no** |Whether or not to upgrade whole system.|
|
|upgrade |yes, **no** |Whether or not to upgrade whole system.|
|
||||||
|use |**auto**, yay, pacaur, trizen, pikaur, aurman, makepkg |The tool to use, 'auto' uses the first known helper found and makepkg as a fallback.|
|
|use |**auto**, yay, pacaur, trizen, pikaur, aurman, makepkg |The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.|
|
||||||
|use_args |[] |A list of arguments to pass directly to the used tool. Cannot be used unless use is set to something other than 'auto'.|
|
|
||||||
|aur_only |yes, **no** |Limit helper operation to the AUR.|
|
|aur_only |yes, **no** |Limit helper operation to the AUR.|
|
||||||
|skip_pgp_check |yes, **no** |Only valid with makepkg. Skip PGP signatures verification of source file, useful when installing packages without GnuPG properly configured. Cannot be used unless use is set to 'makepkg'.|
|
|skip_pgp_check |yes, **no** |Only valid with makepkg. Skip PGP signatures verification of source file, useful when installing packages without GnuPG properly configured.|
|
||||||
|ignore_arch |yes, **no** |Only valid with makepkg. Ignore a missing or incomplete arch field, useful when the PKGBUILD does not have the arch=('yourarch') field. Cannot be used unless use is set to 'makepkg'.|
|
|ignore_arch |yes, **no** |Only valid with makepkg. Ignore a missing or incomplete arch field, useful when the PKGBUILD does not have the arch=('yourarch') field.|
|
||||||
|
|
||||||
### Note
|
### Note
|
||||||
* Either *name* or *upgrade* is required, both cannot be used together.
|
* Either *name* or *upgrade* is required, both cannot be used together.
|
||||||
|
|
107
library/aur.py
107
library/aur.py
|
@ -5,7 +5,6 @@
|
||||||
from ansible.module_utils.basic import *
|
from ansible.module_utils.basic import *
|
||||||
from ansible.module_utils.urls import open_url
|
from ansible.module_utils.urls import open_url
|
||||||
import json
|
import json
|
||||||
import shlex
|
|
||||||
import tarfile
|
import tarfile
|
||||||
import os
|
import os
|
||||||
import os.path
|
import os.path
|
||||||
|
@ -35,27 +34,20 @@ options:
|
||||||
upgrade:
|
upgrade:
|
||||||
description:
|
description:
|
||||||
- Whether or not to upgrade whole system.
|
- Whether or not to upgrade whole system.
|
||||||
default: no
|
|
||||||
type: bool
|
type: bool
|
||||||
|
default: no
|
||||||
|
|
||||||
use:
|
use:
|
||||||
description:
|
description:
|
||||||
- The tool to use, 'auto' uses the first known helper found and makepkg as a fallback.
|
- The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.
|
||||||
default: auto
|
default: auto
|
||||||
choices: [ auto, yay, pacaur, trizen, pikaur, aurman, makepkg ]
|
choices: [ auto, yay, pacaur, trizen, pikaur, aurman, makepkg ]
|
||||||
|
|
||||||
extra_args:
|
|
||||||
description:
|
|
||||||
- Arguments to pass to the tool.
|
|
||||||
Requires that the 'use' option be set to something other than 'auto'.
|
|
||||||
type: str
|
|
||||||
|
|
||||||
skip_pgp_check:
|
skip_pgp_check:
|
||||||
description:
|
description:
|
||||||
- Only valid with makepkg.
|
- Only valid with makepkg.
|
||||||
Skip PGP signatures verification of source file.
|
Skip PGP signatures verification of source file.
|
||||||
This is useful when installing packages without GnuPG (properly) configured.
|
This is useful when installing packages without GnuPG (properly) configured.
|
||||||
Cannot be used unless use is set to 'makepkg'.
|
|
||||||
type: bool
|
type: bool
|
||||||
default: no
|
default: no
|
||||||
|
|
||||||
|
@ -63,15 +55,12 @@ options:
|
||||||
description:
|
description:
|
||||||
- Only valid with makepkg.
|
- Only valid with makepkg.
|
||||||
Ignore a missing or incomplete arch field, useful when the PKGBUILD does not have the arch=('yourarch') field.
|
Ignore a missing or incomplete arch field, useful when the PKGBUILD does not have the arch=('yourarch') field.
|
||||||
Cannot be used unless use is set to 'makepkg'.
|
|
||||||
type: bool
|
type: bool
|
||||||
default: no
|
default: no
|
||||||
|
|
||||||
aur_only:
|
aur_only:
|
||||||
description:
|
description:
|
||||||
- Limit helper operation to the AUR.
|
- Limit helper operation to the AUR.
|
||||||
type: bool
|
|
||||||
default: no
|
|
||||||
notes:
|
notes:
|
||||||
- When used with a `loop:` each package will be processed individually,
|
- When used with a `loop:` each package will be processed individually,
|
||||||
it is much more efficient to pass the list directly to the `name` option.
|
it is much more efficient to pass the list directly to the `name` option.
|
||||||
|
@ -91,6 +80,7 @@ EXAMPLES = '''
|
||||||
become_user: aur_builder
|
become_user: aur_builder
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
|
||||||
def_lang = ['env', 'LC_ALL=C']
|
def_lang = ['env', 'LC_ALL=C']
|
||||||
|
|
||||||
use_cmd = {
|
use_cmd = {
|
||||||
|
@ -145,7 +135,7 @@ def check_packages(module, packages):
|
||||||
module.exit_json(changed=status, msg=message, diff=diff)
|
module.exit_json(changed=status, msg=message, diff=diff)
|
||||||
|
|
||||||
|
|
||||||
def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch):
|
def install_with_makepkg(module, package):
|
||||||
"""
|
"""
|
||||||
Install the specified package with makepkg
|
Install the specified package with makepkg
|
||||||
"""
|
"""
|
||||||
|
@ -160,37 +150,21 @@ def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arc
|
||||||
tar = tarfile.open(mode='r|*', fileobj=f)
|
tar = tarfile.open(mode='r|*', fileobj=f)
|
||||||
tar.extractall(tmpdir)
|
tar.extractall(tmpdir)
|
||||||
tar.close()
|
tar.close()
|
||||||
command = build_command_prefix('makepkg', extra_args, skip_pgp_check=skip_pgp_check, ignore_arch=ignore_arch)
|
if module.params['skip_pgp_check']:
|
||||||
rc, out, err = module.run_command(command, cwd=os.path.join(tmpdir, result['Name']), check_rc=True)
|
use_cmd['makepkg'].append('--skippgpcheck')
|
||||||
|
if module.params['ignore_arch']:
|
||||||
|
use_cmd['makepkg'].append('--ignorearch')
|
||||||
|
rc, out, err = module.run_command(use_cmd['makepkg'], cwd=os.path.join(tmpdir, result['Name']), check_rc=True)
|
||||||
return (rc, out, err)
|
return (rc, out, err)
|
||||||
|
|
||||||
|
|
||||||
def build_command_prefix(use, extra_args, skip_pgp_check=False, ignore_arch=False, aur_only=False):
|
def upgrade(module, use, aur_only):
|
||||||
"""
|
|
||||||
Create the prefix of a command that can be used by the install and upgrade functions.
|
|
||||||
"""
|
|
||||||
command = def_lang + use_cmd[use]
|
|
||||||
if skip_pgp_check:
|
|
||||||
command.append('--skippgpcheck')
|
|
||||||
if ignore_arch:
|
|
||||||
command.append('--ignorearch')
|
|
||||||
if (aur_only and use in has_aur_option):
|
|
||||||
command.append('--aur')
|
|
||||||
if extra_args:
|
|
||||||
command += shlex.split(extra_args)
|
|
||||||
return command
|
|
||||||
|
|
||||||
|
|
||||||
def upgrade(module, use, extra_args, aur_only):
|
|
||||||
"""
|
"""
|
||||||
Upgrade the whole system
|
Upgrade the whole system
|
||||||
"""
|
"""
|
||||||
assert use in use_cmd
|
assert use in use_cmd
|
||||||
|
|
||||||
command = build_command_prefix(use, extra_args, aur_only=aur_only)
|
rc, out, err = module.run_command(def_lang + use_cmd[use] + ['--aur' if (aur_only and use in has_aur_option) else None] + ['-u'], check_rc=True)
|
||||||
command.append('-u')
|
|
||||||
|
|
||||||
rc, out, err = module.run_command(command, check_rc=True)
|
|
||||||
|
|
||||||
module.exit_json(
|
module.exit_json(
|
||||||
changed=not (out == '' or 'nothing to do' in out or 'No AUR updates found' in out),
|
changed=not (out == '' or 'nothing to do' in out or 'No AUR updates found' in out),
|
||||||
|
@ -199,7 +173,7 @@ def upgrade(module, use, extra_args, aur_only):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def install_packages(module, packages, use, extra_args, state, skip_pgp_check, ignore_arch, aur_only):
|
def install_packages(module, packages, use, state, aur_only):
|
||||||
"""
|
"""
|
||||||
Install the specified packages
|
Install the specified packages
|
||||||
"""
|
"""
|
||||||
|
@ -213,11 +187,9 @@ def install_packages(module, packages, use, extra_args, state, skip_pgp_check, i
|
||||||
rc = 0
|
rc = 0
|
||||||
continue
|
continue
|
||||||
if use == 'makepkg':
|
if use == 'makepkg':
|
||||||
rc, out, err = install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch)
|
rc, out, err = install_with_makepkg(module, package)
|
||||||
else:
|
else:
|
||||||
command = build_command_prefix(use, extra_args, aur_only=aur_only)
|
rc, out, err = module.run_command(def_lang + use_cmd[use] + ['--aur' if (aur_only and use in has_aur_option) else None] + [package], check_rc=True)
|
||||||
command.append(package)
|
|
||||||
rc, out, err = module.run_command(command, check_rc=True)
|
|
||||||
|
|
||||||
changed_iter = changed_iter or not (out == '' or '-- skipping' in out or 'nothing to do' in out)
|
changed_iter = changed_iter or not (out == '' or '-- skipping' in out or 'nothing to do' in out)
|
||||||
|
|
||||||
|
@ -231,7 +203,7 @@ def install_packages(module, packages, use, extra_args, state, skip_pgp_check, i
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def make_module():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec={
|
argument_spec={
|
||||||
'name': {
|
'name': {
|
||||||
|
@ -241,45 +213,35 @@ def make_module():
|
||||||
'default': 'present',
|
'default': 'present',
|
||||||
'choices': ['present', 'latest'],
|
'choices': ['present', 'latest'],
|
||||||
},
|
},
|
||||||
|
'ignore_arch': {
|
||||||
|
'default': False,
|
||||||
|
'type': 'bool',
|
||||||
|
},
|
||||||
'upgrade': {
|
'upgrade': {
|
||||||
|
'default': False,
|
||||||
'type': 'bool',
|
'type': 'bool',
|
||||||
},
|
},
|
||||||
'use': {
|
'use': {
|
||||||
'default': 'auto',
|
'default': 'auto',
|
||||||
'choices': ['auto'] + list(use_cmd.keys()),
|
'choices': ['auto'] + list(use_cmd.keys()),
|
||||||
},
|
},
|
||||||
'extra_args': {
|
|
||||||
'default': None,
|
|
||||||
'type': 'str',
|
|
||||||
},
|
|
||||||
'skip_pgp_check': {
|
'skip_pgp_check': {
|
||||||
'default': False,
|
'default': False,
|
||||||
'type': 'bool',
|
'type': 'bool',
|
||||||
},
|
},
|
||||||
'ignore_arch': {
|
|
||||||
'default': False,
|
|
||||||
'type': 'bool',
|
|
||||||
},
|
|
||||||
'aur_only': {
|
'aur_only': {
|
||||||
'default': False,
|
'default': False,
|
||||||
'type': 'bool',
|
'type': 'bool',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
mutually_exclusive=[['name', 'upgrade']],
|
|
||||||
required_one_of=[['name', 'upgrade']],
|
required_one_of=[['name', 'upgrade']],
|
||||||
required_by={'use': ['extra_args', 'skip_pgp_check', 'ignore_arch']},
|
|
||||||
supports_check_mode=True
|
supports_check_mode=True
|
||||||
)
|
)
|
||||||
|
|
||||||
params = module.params
|
params = module.params
|
||||||
|
|
||||||
if params['use'] == 'auto' and params['extra_args'] is not None:
|
if module.check_mode:
|
||||||
module.fail_json(msg="You must specify a tool other than 'auto' to use the 'extra_args' option.")
|
check_packages(module, params['name'])
|
||||||
|
|
||||||
if params['use'] != 'makepkg' and params['skip_pgp_check']:
|
|
||||||
module.fail_json(msg="You must use 'makepkg' to use the 'skip_pgp_check' option.")
|
|
||||||
if params['use'] != 'makepkg' and params['ignore_arch']:
|
|
||||||
module.fail_json(msg="You must use 'makepkg' to use the 'ignore_arch' option.")
|
|
||||||
|
|
||||||
if params['use'] == 'auto':
|
if params['use'] == 'auto':
|
||||||
use = 'makepkg'
|
use = 'makepkg'
|
||||||
|
@ -291,26 +253,13 @@ def make_module():
|
||||||
else:
|
else:
|
||||||
use = params['use']
|
use = params['use']
|
||||||
|
|
||||||
if params.get('upgrade', False) and use == 'makepkg':
|
if params['upgrade'] and (params['name'] or use == 'makepkg'):
|
||||||
module.fail_json(msg="Upgrade cannot be used with the tool 'makepkg'.")
|
module.fail_json(msg="Upgrade cannot be used with this option.")
|
||||||
|
|
||||||
return module, use
|
|
||||||
|
|
||||||
|
|
||||||
def apply_module(module, use):
|
|
||||||
params = module.params
|
|
||||||
|
|
||||||
if module.check_mode:
|
|
||||||
check_packages(module, params['name'])
|
|
||||||
elif params.get('upgrade', False):
|
|
||||||
upgrade(module, use, params['extra_args'], params['aur_only'])
|
|
||||||
else:
|
else:
|
||||||
install_packages(module, params['name'], use, params['extra_args'], params['state'], params['skip_pgp_check'], params['ignore_arch'], params['aur_only'])
|
if params['upgrade']:
|
||||||
|
upgrade(module, use, params['aur_only'])
|
||||||
|
else:
|
||||||
def main():
|
install_packages(module, params['name'], use, params['state'], params['aur_only'])
|
||||||
module, use = make_module()
|
|
||||||
apply_module(module, use)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
Loading…
Reference in New Issue