mirror of
				https://github.com/kewlfft/ansible-aur.git
				synced 2025-11-04 10:02:30 +03:00 
			
		
		
		
	Merge pull request #39 from chpatton013/use-args
Add extra_args option for helpers and makepkg
This commit is contained in:
		
							
								
								
									
										11
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								README.md
									
									
									
									
									
								
							@@ -13,14 +13,15 @@ The following helpers are supported and automatically selected, if present, in t
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
## Options
 | 
					## Options
 | 
				
			||||||
|Parameter      |Choices/**Default**                                    |Comments|
 | 
					|Parameter      |Choices/**Default**                                    |Comments|
 | 
				
			||||||
|---            |---                                                |---|
 | 
					|---            |---                                                    |---|
 | 
				
			||||||
|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 helper to use, 'auto' uses the first known helper found and makepkg as a fallback.|
 | 
					|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_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.|
 | 
					|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'.|
 | 
				
			||||||
|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.|
 | 
					|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'.|
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### 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,6 +5,7 @@
 | 
				
			|||||||
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
 | 
				
			||||||
@@ -34,20 +35,27 @@ options:
 | 
				
			|||||||
    upgrade:
 | 
					    upgrade:
 | 
				
			||||||
        description:
 | 
					        description:
 | 
				
			||||||
            - Whether or not to upgrade whole system.
 | 
					            - Whether or not to upgrade whole system.
 | 
				
			||||||
        type: bool
 | 
					 | 
				
			||||||
        default: no
 | 
					        default: no
 | 
				
			||||||
 | 
					        type: bool
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    use:
 | 
					    use:
 | 
				
			||||||
        description:
 | 
					        description:
 | 
				
			||||||
            - The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.
 | 
					            - The tool 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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -55,12 +63,15 @@ 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.
 | 
				
			||||||
@@ -80,7 +91,6 @@ 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 = {
 | 
				
			||||||
@@ -135,7 +145,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):
 | 
					def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch):
 | 
				
			||||||
    """
 | 
					    """
 | 
				
			||||||
    Install the specified package with makepkg
 | 
					    Install the specified package with makepkg
 | 
				
			||||||
    """
 | 
					    """
 | 
				
			||||||
@@ -150,21 +160,37 @@ def install_with_makepkg(module, package):
 | 
				
			|||||||
        tar = tarfile.open(mode='r|*', fileobj=f)
 | 
					        tar = tarfile.open(mode='r|*', fileobj=f)
 | 
				
			||||||
        tar.extractall(tmpdir)
 | 
					        tar.extractall(tmpdir)
 | 
				
			||||||
        tar.close()
 | 
					        tar.close()
 | 
				
			||||||
        if module.params['skip_pgp_check']:
 | 
					        command = build_command_prefix('makepkg', extra_args, skip_pgp_check=skip_pgp_check, ignore_arch=ignore_arch)
 | 
				
			||||||
            use_cmd['makepkg'].append('--skippgpcheck')
 | 
					        rc, out, err = module.run_command(command, cwd=os.path.join(tmpdir, result['Name']), check_rc=True)
 | 
				
			||||||
        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 upgrade(module, use, aur_only):
 | 
					def build_command_prefix(use, extra_args, skip_pgp_check=False, ignore_arch=False, aur_only=False):
 | 
				
			||||||
 | 
					    """
 | 
				
			||||||
 | 
					    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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    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 = build_command_prefix(use, extra_args, aur_only=aur_only)
 | 
				
			||||||
 | 
					    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),
 | 
				
			||||||
@@ -173,7 +199,7 @@ def upgrade(module, use, aur_only):
 | 
				
			|||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def install_packages(module, packages, use, state, aur_only):
 | 
					def install_packages(module, packages, use, extra_args, state, skip_pgp_check, ignore_arch, aur_only):
 | 
				
			||||||
    """
 | 
					    """
 | 
				
			||||||
    Install the specified packages
 | 
					    Install the specified packages
 | 
				
			||||||
    """
 | 
					    """
 | 
				
			||||||
@@ -187,9 +213,11 @@ def install_packages(module, packages, use, state, aur_only):
 | 
				
			|||||||
                rc = 0
 | 
					                rc = 0
 | 
				
			||||||
                continue
 | 
					                continue
 | 
				
			||||||
        if use == 'makepkg':
 | 
					        if use == 'makepkg':
 | 
				
			||||||
            rc, out, err = install_with_makepkg(module, package)
 | 
					            rc, out, err = install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch)
 | 
				
			||||||
        else:
 | 
					        else:
 | 
				
			||||||
            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 = build_command_prefix(use, extra_args, aur_only=aur_only)
 | 
				
			||||||
 | 
					            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)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -203,7 +231,7 @@ def install_packages(module, packages, use, state, aur_only):
 | 
				
			|||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def main():
 | 
					def make_module():
 | 
				
			||||||
    module = AnsibleModule(
 | 
					    module = AnsibleModule(
 | 
				
			||||||
        argument_spec={
 | 
					        argument_spec={
 | 
				
			||||||
            'name': {
 | 
					            'name': {
 | 
				
			||||||
@@ -213,35 +241,45 @@ def main():
 | 
				
			|||||||
                '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 module.check_mode:
 | 
					    if params['use'] == 'auto' and params['extra_args'] is not None:
 | 
				
			||||||
        check_packages(module, params['name'])
 | 
					        module.fail_json(msg="You must specify a tool other than 'auto' to use the 'extra_args' option.")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    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'
 | 
				
			||||||
@@ -253,13 +291,26 @@ def main():
 | 
				
			|||||||
    else:
 | 
					    else:
 | 
				
			||||||
        use = params['use']
 | 
					        use = params['use']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if params['upgrade'] and (params['name'] or use == 'makepkg'):
 | 
					    if params.get('upgrade', False) and use == 'makepkg':
 | 
				
			||||||
        module.fail_json(msg="Upgrade cannot be used with this option.")
 | 
					        module.fail_json(msg="Upgrade cannot be used with the tool 'makepkg'.")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    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:
 | 
				
			||||||
        if params['upgrade']:
 | 
					        install_packages(module, params['name'], use, params['extra_args'], params['state'], params['skip_pgp_check'], params['ignore_arch'], params['aur_only'])
 | 
				
			||||||
            upgrade(module, use, params['aur_only'])
 | 
					
 | 
				
			||||||
        else:
 | 
					
 | 
				
			||||||
            install_packages(module, params['name'], use, params['state'], params['aur_only'])
 | 
					def main():
 | 
				
			||||||
 | 
					    module, use = make_module()
 | 
				
			||||||
 | 
					    apply_module(module, use)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if __name__ == '__main__':
 | 
					if __name__ == '__main__':
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user