mirror of
https://github.com/kewlfft/ansible-aur.git
synced 2025-09-17 08:30:39 +03:00
Compare commits
29 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
eeca05b629 | ||
![]() |
f92a1522a3 | ||
![]() |
6f5a4f9b6d | ||
![]() |
85f6d7c93f | ||
![]() |
80279644a8 | ||
![]() |
3901eb7368 | ||
![]() |
9772b680dd | ||
![]() |
349e237307 | ||
![]() |
3ebf634913 | ||
![]() |
5b4dd96294 | ||
![]() |
2add192d89 | ||
![]() |
2f67cbcc9f | ||
![]() |
2df576955a | ||
![]() |
13a45e35a8 | ||
![]() |
38d3785501 | ||
![]() |
50ca93f6bf | ||
![]() |
9636c0b1ea | ||
![]() |
3813de8e7e | ||
![]() |
fd510b7c61 | ||
![]() |
98031b260a | ||
![]() |
5bd9caa63f | ||
![]() |
a9a8d3e706 | ||
![]() |
6147c18b30 | ||
![]() |
8fae2a78e9 | ||
![]() |
ec89080a7d | ||
![]() |
8194eb2ac0 | ||
![]() |
338fe36f2f | ||
![]() |
0d51932a6a | ||
![]() |
c804201144 |
38
README.md
38
README.md
@@ -2,24 +2,24 @@
|
|||||||
Ansible module to use some Arch User Repository (AUR) helpers as well as makepkg.
|
Ansible module to use some Arch User Repository (AUR) helpers as well as makepkg.
|
||||||
|
|
||||||
The following helpers are supported and automatically selected in the order they are listed:
|
The following helpers are supported and automatically selected in the order they are listed:
|
||||||
|
- [yay](https://github.com/Jguer/yay)
|
||||||
- [aurman](https://github.com/polygamma/aurman)
|
- [aurman](https://github.com/polygamma/aurman)
|
||||||
- [pacaur](https://github.com/rmarquis/pacaur)
|
- [pacaur](https://github.com/rmarquis/pacaur)
|
||||||
- [trizen](https://github.com/trizen/trizen)
|
- [trizen](https://github.com/trizen/trizen)
|
||||||
- [pikaur](https://github.com/actionless/pikaur)
|
- [pikaur](https://github.com/actionless/pikaur)
|
||||||
- [yaourt](https://github.com/archlinuxfr/yaourt)
|
|
||||||
- [yay](https://github.com/Jguer/yay)
|
|
||||||
|
|
||||||
makepkg will be used if no helper was found or if it's specified explicitly.
|
*makepkg* will be used if no helper was found or if it is explicitly specified.
|
||||||
- [makepkg](https://wiki.archlinux.org/index.php/makepkg)
|
- [makepkg](https://wiki.archlinux.org/index.php/makepkg)
|
||||||
|
|
||||||
## Options
|
## Options
|
||||||
|parameter |required |default |choices |comments|
|
|parameter |required |default |choices |comments|
|
||||||
|--- |--- |--- |--- |---|
|
|--- |--- |--- |--- |---|
|
||||||
|name |no | | |Name or list of names of the package(s) to install or upgrade.|
|
|name |no | | |Name or list of names of the package(s) to install or upgrade.|
|
||||||
|upgrade |no |no |yes, no |Whether or not to upgrade whole system.|
|
|upgrade |no |no |yes, no |Whether or not to upgrade whole system.|
|
||||||
|use |no |auto |auto, aurman, pacaur, trizen, pikaur, yaourt, yay, makepkg |The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.|
|
|use |no |auto |auto, yay, aurman, pacaur, trizen, pikaur, makepkg |The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.|
|
||||||
|skip_installed |no |no |yes, no |Skip operations if the package is present.|
|
|skip_installed |no |no |yes, no |Skip operations if the package is present.|
|
||||||
|skip_pgp_check |no |no |yes, no |Skip verification of PGP signatures. This is useful when installing packages on a host without GnuPG (properly) configured. Only valid with makepkg.|
|
|skip_pgp_check |no |no |yes, no |Skip verification of PGP signatures. This is useful when installing packages on a host without GnuPG (properly) configured. Only valid with makepkg.|
|
||||||
|
|aur_only |no |no |yes, no |Limit operation to the AUR. Compatible with yay, aurman, pacaur and trizen.|
|
||||||
|
|
||||||
### Note
|
### Note
|
||||||
* Either *name* or *upgrade* is required, both cannot be used together.
|
* Either *name* or *upgrade* is required, both cannot be used together.
|
||||||
@@ -27,22 +27,20 @@ makepkg will be used if no helper was found or if it's specified explicitly.
|
|||||||
* In the *use*=*auto* mode, makepkg is used as a fallback if no known helper is found.
|
* In the *use*=*auto* mode, makepkg is used as a fallback if no known helper is found.
|
||||||
|
|
||||||
## Installing
|
## Installing
|
||||||
1. Clone the *ansibe-aur* repository in your playbook custom-module directory:
|
### AUR package
|
||||||
```
|
The [aur-ansible-git](https://aur.archlinux.org/packages/ansible-aur-git) package is available in the AUR.
|
||||||
mkdir --parents library
|
Note the module is installed in `/usr/share/ansible/plugins/modules` which is one of the default module library paths.
|
||||||
cd library
|
|
||||||
git clone git@github.com:kewlfft/ansible-aur.git
|
|
||||||
```
|
|
||||||
|
|
||||||
2. Link the script to `library/aur`:
|
### Manual installation
|
||||||
|
Just clone the *ansible-aur* repository into your user custom-module directory:
|
||||||
```
|
```
|
||||||
ln --symbolic ansible-aur/aur.py aur
|
git clone https://github.com/kewlfft/ansible-aur.git ~/.ansible/plugins/modules/aur
|
||||||
```
|
```
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
### Note
|
### Note
|
||||||
* This module aims to cover the AUR, for package removal or system upgrade with the repositories, it is recommended to use the official *pacman* module,
|
* This module aims to cover the AUR; for package removal or system upgrade with the repositories, it is recommended to use the official *pacman* module,
|
||||||
* A package is reinstalled only if an update is available, using the *--needed* parameter, except for *yay* which does not support it and systematically reinstalls.
|
* A package is reinstalled only if an update is available, using the *--needed* parameter.
|
||||||
|
|
||||||
### Examples
|
### Examples
|
||||||
Use it in a task, as in the following examples:
|
Use it in a task, as in the following examples:
|
||||||
|
91
aur.py
91
aur.py
@@ -1,4 +1,6 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
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
|
||||||
@@ -9,18 +11,80 @@ import os.path
|
|||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
|
|
||||||
|
DOCUMENTATION = '''
|
||||||
|
---
|
||||||
|
module: aur
|
||||||
|
short_description: Manage packages from the AUR
|
||||||
|
description:
|
||||||
|
- Manage packages from the Arch User Repository (AUR)
|
||||||
|
author:
|
||||||
|
- Kewl <xrjy@nygb.rh.bet(rot13)>
|
||||||
|
options:
|
||||||
|
name:
|
||||||
|
description:
|
||||||
|
- Name or list of names of the package(s) to install or upgrade.
|
||||||
|
|
||||||
|
upgrade:
|
||||||
|
description:
|
||||||
|
- Whether or not to upgrade whole system.
|
||||||
|
type: bool
|
||||||
|
default: no
|
||||||
|
|
||||||
|
use:
|
||||||
|
description:
|
||||||
|
- The helper to use, 'auto' uses the first known helper found and makepkg as a fallback.
|
||||||
|
default: auto
|
||||||
|
choices: [ auto, yay, aurman, pacaur, trizen, pikaur, makepkg ]
|
||||||
|
|
||||||
|
skip_installed:
|
||||||
|
description:
|
||||||
|
- Skip operations if the package is present.
|
||||||
|
type: bool
|
||||||
|
default: no
|
||||||
|
|
||||||
|
skip_pgp_check:
|
||||||
|
description:
|
||||||
|
- Skip verification of PGP signatures.
|
||||||
|
This is useful when installing packages on a host without GnuPG (properly) configured.
|
||||||
|
Only valid with makepkg.
|
||||||
|
type: bool
|
||||||
|
default: no
|
||||||
|
|
||||||
|
aur_only:
|
||||||
|
description:
|
||||||
|
- Limit operation to the AUR. Compatible with yay, aurman, pacaur and trizen.
|
||||||
|
notes:
|
||||||
|
- 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.
|
||||||
|
'''
|
||||||
|
|
||||||
|
RETURN = '''
|
||||||
|
msg:
|
||||||
|
description: action that has been taken
|
||||||
|
helper:
|
||||||
|
the helper that was actually used
|
||||||
|
'''
|
||||||
|
|
||||||
|
EXAMPLES = '''
|
||||||
|
- name: Install trizen using makepkg, skip if trizen is already installed
|
||||||
|
aur: name=trizen use=makepkg skip_installed=true
|
||||||
|
become: yes
|
||||||
|
become_user: aur_builder
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
def_lang = ['env', 'LC_ALL=C']
|
def_lang = ['env', 'LC_ALL=C']
|
||||||
|
|
||||||
use_cmd = {
|
use_cmd = {
|
||||||
'aurman': ['aurman', '-S', '--noconfirm', '--noedit', '--needed'],
|
'yay': ['yay', '-S', '--noconfirm', '--needed'],
|
||||||
|
'aurman': ['aurman', '-S', '--noconfirm', '--noedit', '--needed', '--skip_news', '--pgp_fetch', '--skip_new_locations'],
|
||||||
'pacaur': ['pacaur', '-S', '--noconfirm', '--noedit', '--needed'],
|
'pacaur': ['pacaur', '-S', '--noconfirm', '--noedit', '--needed'],
|
||||||
'trizen': ['trizen', '-S', '--noconfirm', '--noedit', '--needed'],
|
'trizen': ['trizen', '-S', '--noconfirm', '--noedit', '--needed'],
|
||||||
'pikaur': ['pikaur', '-S', '--noconfirm', '--noedit', '--needed'],
|
'pikaur': ['pikaur', '-S', '--noconfirm', '--noedit', '--needed'],
|
||||||
'yaourt': ['yaourt', '-S', '--noconfirm', '--needed'],
|
|
||||||
'yay': ['yay', '-S', '--noconfirm'],
|
|
||||||
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
|
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
|
||||||
}
|
}
|
||||||
# optional: aurman, pacaur, trizen have a --aur option, do things only for aur
|
|
||||||
|
has_aur_option = ['yay', 'aurman', 'pacaur', 'trizen']
|
||||||
|
|
||||||
|
|
||||||
def package_installed(module, package):
|
def package_installed(module, package):
|
||||||
@@ -61,6 +125,7 @@ def install_with_makepkg(module, package):
|
|||||||
"""
|
"""
|
||||||
Install the specified package with makepkg
|
Install the specified package with makepkg
|
||||||
"""
|
"""
|
||||||
|
module.get_bin_path('fakeroot', required=True)
|
||||||
f = open_url('https://aur.archlinux.org/rpc/?v=5&type=info&arg={}'.format(package))
|
f = open_url('https://aur.archlinux.org/rpc/?v=5&type=info&arg={}'.format(package))
|
||||||
result = json.loads(f.read().decode('utf8'))
|
result = json.loads(f.read().decode('utf8'))
|
||||||
if result['resultcount'] != 1:
|
if result['resultcount'] != 1:
|
||||||
@@ -84,13 +149,13 @@ def install_with_makepkg(module, package):
|
|||||||
return (rc, out, err)
|
return (rc, out, err)
|
||||||
|
|
||||||
|
|
||||||
def upgrade(module, use):
|
def upgrade(module, use, 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] + ['-u'], check_rc=True)
|
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)
|
||||||
|
|
||||||
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),
|
||||||
@@ -99,7 +164,7 @@ def upgrade(module, use):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def install_packages(module, packages, use, skip_installed):
|
def install_packages(module, packages, use, skip_installed, aur_only):
|
||||||
"""
|
"""
|
||||||
Install the specified packages
|
Install the specified packages
|
||||||
"""
|
"""
|
||||||
@@ -115,7 +180,7 @@ def install_packages(module, packages, use, skip_installed):
|
|||||||
if use == 'makepkg':
|
if use == 'makepkg':
|
||||||
rc, out, err = install_with_makepkg(module, package)
|
rc, out, err = install_with_makepkg(module, package)
|
||||||
else:
|
else:
|
||||||
rc, out, err = module.run_command(def_lang + use_cmd[use] + [package], check_rc=True)
|
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)
|
||||||
|
|
||||||
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)
|
||||||
|
|
||||||
@@ -154,6 +219,10 @@ def main():
|
|||||||
'default': False,
|
'default': False,
|
||||||
'type': 'bool',
|
'type': 'bool',
|
||||||
},
|
},
|
||||||
|
'aur_only': {
|
||||||
|
'default': False,
|
||||||
|
'type': 'bool',
|
||||||
|
},
|
||||||
},
|
},
|
||||||
required_one_of=[['name', 'upgrade']],
|
required_one_of=[['name', 'upgrade']],
|
||||||
supports_check_mode=True
|
supports_check_mode=True
|
||||||
@@ -178,9 +247,9 @@ def main():
|
|||||||
module.fail_json(msg="Upgrade cannot be used with this option.")
|
module.fail_json(msg="Upgrade cannot be used with this option.")
|
||||||
else:
|
else:
|
||||||
if params['upgrade']:
|
if params['upgrade']:
|
||||||
upgrade(module, use)
|
upgrade(module, use, params['aur_only'])
|
||||||
else:
|
else:
|
||||||
install_packages(module, params['name'], use, params['skip_installed'])
|
install_packages(module, params['name'], use, params['skip_installed'], params['aur_only'])
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
Reference in New Issue
Block a user