Compare commits

...

124 Commits

Author SHA1 Message Date
kewl fft fe050018db galaxy version updated to 0.11.1 2023-07-08 19:37:19 +01:00
kewl fft 326836ddbe galaxy version updated 2023-07-08 19:36:22 +01:00
kewl fft 583c7597a9 minor optimizations 2023-07-08 19:20:32 +01:00
kewl fft cbf843e1db Replaced the changed_iter = changed_iter or ... statement with the changed_iter |= ... compound assignment operator for brevity 2023-07-08 18:56:02 +01:00
kewl fft 2a076dc6a0 optimize check_packages lists construction 2023-07-08 18:51:35 +01:00
kewl 8d177a7550
Merge pull request #78 from jp1995/master
fix for issue #77
2023-07-08 18:40:26 +01:00
kewl b469b5a641
Merge pull request #73 from LorenzoBettini/LorenzoBettini-patch-1
"mode: 0644" in the README example
2023-07-08 18:30:26 +01:00
jp1995 63d3056a82 fix for issue #77 2023-07-07 18:15:52 +03:00
Lorenzo Bettini 91c6d70184
"mode: 0644" in the README example
When using ansible-lint it would complain about "risky-file-permissions: File permissions unset or incorrect".
Making the `mode` explicit avoids the problem
2022-05-24 14:29:56 +02:00
kewl 9b25b11cea
Merge pull request #66 from gotmax23/master
Remove unnecessary files from collection tarball
2021-11-08 11:03:48 +00:00
kewl 2c090a49a8
Merge pull request #67 from LorenzoBettini/patch-1
Use become: yes in the example for creating aur_builder
2021-11-08 08:18:34 +00:00
Lorenzo Bettini 07e5fe301f
Use become: yes in the example for creating aur_builder
It is my understanding that for creating the `aur_builder` you have to become root; maybe that's something one does in the whole playbook, but if one wants to specify that only when it's needed, the example could be improved as suggested, so that it's self-contained and can be simply copied and pasted.
2021-11-07 13:08:56 +01:00
Maxwell G 49a077790e
Remove unnecessary files from collection tarball 2021-11-04 16:55:37 -05:00
kewl fft 87a15853fa proper version bump 2021-11-04 21:44:50 +00:00
kewl fft 7285f5aaaa correct version tag 2021-11-04 21:34:04 +00:00
kewl fft cda508cfc0 correct version tag 2021-11-04 21:30:30 +00:00
kewl c8bf68a91b
Merge pull request #63 from assapir/master
Add support for refresh package
2021-11-01 17:41:27 +00:00
Assaf Sapir 2319468c2e use update_cache 2021-10-22 12:23:07 +03:00
Assaf Sapir f12cb1b36b Fix parameter 2021-10-21 19:49:24 +03:00
Assaf Sapir e8108fe3e4 Fix parameter 2021-10-21 19:44:02 +03:00
Assaf Sapir 472a92ff8e fix bug and update version 2021-10-19 20:59:14 +03:00
Assaf Sapir b3e47d6395 Add support for refresh package 2021-10-19 20:48:51 +03:00
kewl fft 47fbee75b9 version bump 2021-09-04 08:55:14 +01:00
kewl a19f5db22a
Merge pull request #62 from gotmax23/patch-2
Fix spelling error in README
2021-09-04 08:42:34 +01:00
kewl 8cf53bd930
Merge pull request #61 from gotmax23/patch-1
Add direct link to AUR package
2021-09-04 08:42:03 +01:00
Maxwell G 095a450558
Fix spelling error in README
This commit fixes a spelling mistake that I made.
2021-09-03 16:27:23 -05:00
Maxwell G de8f8ef272
Add direct link to AUR package
I just pushed `ansible-collection-kewlfft-aur` to the AUR, so I added a direct link to it in the README.
2021-09-03 16:05:45 -05:00
kewl fft 7821c33f02 update version number 2021-09-03 21:32:45 +01:00
kewl fft a952d458b2 remove lf 2021-09-03 18:32:14 +01:00
kewl fft 7d1f3af8e5 minor punctuation changes 2021-09-03 18:30:57 +01:00
kewl fft 80da3e9725 minor wording improvements 2021-09-03 18:29:20 +01:00
kewl fft 9e763ce3f5 minor wording change 2021-09-03 18:08:21 +01:00
kewl fft 6a33062eab define fqcn at first use 2021-09-03 18:06:37 +01:00
kewl fft 319a451c6f comment # missing 2021-09-03 18:05:41 +01:00
kewl c64679b9ff
Merge pull request #58 from gotmax23/move_to_collection
Migrate `aur` module from legacy role to collection
2021-09-03 18:00:51 +01:00
Maxwell G 6c553054b9
Add information about installing `aur` as a local custom module
Please ignore the other reformatted table and other formatting changes.
My markdown editor automatically formats markdown.
2021-08-16 20:21:01 -05:00
Maxwell G ad64e0acb4
Properly format `aur_builder` example code block 2021-08-16 19:08:20 -05:00
Maxwell G ba04d0efc0
Change `create_home:no` to `create_home:yes` in README
For certain use cases, the `aur_builder` requires a home directory.

Fixes #59
2021-08-04 14:11:13 -05:00
Maxwell G 6a32a018ee
Update README with information about collection 2021-08-04 14:11:13 -05:00
Maxwell G 97851cd308
Create workflow to push collection to Galaxy
This is a Github Actions workflow that pushes the collection to Ansible
Galaxy when a Github release is created.
2021-08-04 14:10:58 -05:00
Maxwell G 91fd5a6513
Create collection metadata and directory structure 2021-08-02 21:20:39 -05:00
kewl 60c02a6652
Merge pull request #56 from grcancelliere/bugfix/def-lang-upgrade
Fix upgrade changed logic and language definition when using pikaur
2021-04-16 08:21:57 +01:00
kewl fft 6f5df32b4b lower case before test 2021-04-16 08:20:52 +01:00
kewl fft 93230880db capital N with pikaur 2021-04-16 08:15:27 +01:00
grcancelliere 813cbadc18 Fix upgrade changed logic and language definition when using pikaur 2021-04-16 07:55:46 +02:00
kewl dc101ae394
Merge pull request #55 from Terseus/bugfix/ansible-doc-2.10-fix
Fix `ansible-doc aur` error about dictionary element length
2021-04-03 11:31:48 +01:00
Terseus 706b236058 Fix `ansible-doc aur` error about dictionary element length
Fixes the following error when running `ansible-doc aur`:

```
ERROR! Unable to retrieve documentation from 'aur' due to: dictionary
update sequence element #0 has length 1; 2 is required
```

It was because the `helper` value in the `RETURN` section was missing
the `description` key.
2021-04-03 12:17:10 +02:00
kewl e8655fcf1c
Merge pull request #53 from brettinternet/patch-1
Improve aur_builder example
2021-01-30 08:01:42 -05:00
Brett d05e0bc979
add field for aur_builder user example without home dir 2021-01-29 22:43:26 -07:00
kewl bff54cb367
Merge pull request #52 from hummeltech/Paru
Added `paru` as a helper option
2021-01-26 14:31:25 -05:00
David Hummel 652b11fd76 Alignment adjustment of `Options` table in `README.md` 2021-01-26 12:28:14 -07:00
David Hummel 5d5cc1e20d Added `paru` as a helper option 2021-01-26 10:41:55 -07:00
kewl fft 95aa8f3047 exit with error if empty name list 2021-01-20 16:57:45 -05:00
kewl 592c6d9841
Merge pull request #46 from ckotte/pkgbuild
Add pkgbuild option to build local package
2020-10-01 13:39:11 +02:00
Christian Kotte e1a11c703b
Change formatting of notes in README 2020-10-01 13:10:52 +02:00
Christian Kotte 71c32ac3f5
Add pkgbuild option 2020-10-01 13:10:50 +02:00
Christian Kotte ddab7c7403
Change module_utils.basic import to AnsibleModule
Flake 8 displays a warning: unable to detect undefined names
2020-09-24 12:30:03 +02:00
kewl fft c2fd7b31e4 add check_mode for upgrade 2020-08-08 17:58:32 -04:00
kewl fft 5aebeda3d4 combine auto tests 2020-05-31 19:56:33 -04:00
kewl fft a470eed6e1 review extra args comments 2020-05-31 19:47:54 -04:00
kewl fft 559f25fc41 allow use of makepkg options with auto as long as the only tool available 2020-05-31 19:40:17 -04:00
kewl fft c14810589a allow makepkg options with auto as long as only tool available 2020-05-31 19:39:46 -04:00
kewl fft 5717af2db0 remove useless brackets 2020-05-31 19:25:13 -04:00
kewl fft a5877d3698 correct extra_args option in readme 2020-05-31 19:23:01 -04:00
kewl fft d23b822be0 combine checks for makepkg 2020-05-31 19:19:31 -04:00
kewl fft 3e5e49114d remove incorrect use of required_by 2020-05-31 19:15:38 -04:00
kewl e03b3f0579
Merge pull request #39 from chpatton013/use-args
Add extra_args option for helpers and makepkg
2020-05-31 19:00:33 -04:00
Christopher Patton 2e5b1d883d Rename and re-type use_args to extra_args 2020-05-31 10:24:29 -07:00
Christopher Patton 30d818dbee Pass use_args to makepkg as well 2020-05-31 08:33:45 -07:00
Christopher Patton 59d3e012ea Explicitly pass makepkg-specific params through install functions 2020-05-31 08:33:28 -07:00
Christopher Patton 6615fd76e9 Fix inaccurate docs about option compatibility 2020-05-30 20:07:14 -07:00
Christopher Patton 707f445620 Distinguish between helpers and tools in documentation 2020-05-30 19:35:02 -07:00
Christopher Patton ce466fc05d Update documentation to reflect practical default of upgrade 2020-05-30 19:35:02 -07:00
Christopher Patton 6cc320a5e2 Add use_args option 2020-05-30 19:35:02 -07:00
Christopher Patton 43f8736f76 Split main into testable functions 2020-05-30 12:00:08 -07:00
Christopher Patton cc5012c5af Dedupe install and upgrade command generation 2020-05-30 12:00:08 -07:00
Christopher Patton 1f09b94fbb Simplify error reporting 2020-05-30 12:00:08 -07:00
kewl fft 5ac7c0ef86 aur_only extended to all helpers 2020-05-24 10:08:21 -04:00
kewl fft 10d9c76a31 readme minor 2020-05-24 09:58:09 -04:00
kewl fft 37815ae827 readme improve comments 2020-05-24 09:54:40 -04:00
kewl fft d180d480bc align center table 2020-05-23 23:27:05 -04:00
kewl fft a06f0d741c left align column 2020-05-23 23:24:57 -04:00
kewl fft 90cbeed546 readme titles 2020-05-23 22:53:53 -04:00
kewl fft 0c7f34f187 readme defaults and choices in same column 2020-05-23 22:51:32 -04:00
kewl fft c9d7c94bbe closes #9 2020-05-23 22:44:58 -04:00
kewl fft 7c3def3680 update readme 2020-05-23 22:35:09 -04:00
kewl fft f161d9e769 state update readme 2020-05-23 22:34:42 -04:00
kewl fft 08c4dd6fbd replace skip_installed by state 2020-05-23 22:28:10 -04:00
kewl dff3cfb450
Merge pull request #36 from juergenhoetzel/diff
Add diff support in check mode
2020-05-10 08:42:43 -04:00
Juergen Hoetzel 89e26748da Add diff support in check mode 2020-05-10 14:31:49 +02:00
kewl de92aa87cb
Merge pull request #34 from juergenhoetzel/on-the-fly-extract
Extract tar file on-the-fly
2020-05-09 10:40:18 -04:00
Juergen Hoetzel 5d952d26fd Extract tar file on-the-fly
Instead of creating an intermediate tar file use the open_url response
as fileobj.
2020-05-09 16:19:12 +02:00
kewl fft 026786beb0 deprioritize aurman - discontinued 2020-04-12 20:00:50 -04:00
kewl fft c24454a159 readme minor improvements 2020-04-12 19:45:52 -04:00
kewl fft 63e60fc256 add comments for ignore_arch 2020-04-12 19:40:51 -04:00
kewl e643e8f450
Merge pull request #30 from neilmunday/master
Added ignore_arch option for makepkg
2020-04-12 19:24:49 -04:00
neilmunday bd374b15d9 Added ignore_arch option for makepkg 2020-04-13 00:05:35 +01:00
kewl fft d6d25c6738 readme update 2020-03-03 07:26:29 -05:00
kewl 672b060fe9
Merge pull request #29 from pallxk/embed-module-in-role
Embed module in role
2020-03-02 20:54:00 -05:00
pallxk c26e14c8ce Update README for installation via Ansible Galaxy 2020-03-02 13:43:56 +08:00
pallxk 74b538db28 Embed module in role 2020-02-28 11:23:41 +08:00
kewl 9f52f507c6
Merge pull request #25 from hvariant/fix-package-name-quote
fix quoting of package name
2019-08-31 09:02:49 +01:00
Zhansong Li e1443632a3 use the correct module and function name 2019-08-31 17:41:39 +10:00
Zhansong Li f4868a5bac fix quoting of package name 2019-08-31 11:17:57 +10:00
kewl fft 9a2500338c improved readme 2019-07-28 09:30:00 +02:00
kewl fft 5acabdc819 optional argument default for get bin path removed 2019-04-11 20:09:27 +01:00
kewl fft 2766c2661c if in one line 2019-04-11 20:03:55 +01:00
kewl fft 473d06fe54 revert grammatical correction 2019-04-11 19:59:22 +01:00
kewl fft 59d69056a2 grammatical correction always many packages at this point 2019-04-11 19:45:03 +01:00
kewl fft 8b1ba99cdc choices list is now dynamic 2019-04-11 19:39:01 +01:00
kewl fft 72d432ac7a yaourt remove from choices 2019-04-11 19:17:36 +01:00
kewl fft b462d9893f improved error message when pkg not found thanks @juergenhoetzel 2019-04-11 19:05:57 +01:00
kewl fft 8f8af5fa5f correct package name in readme 2018-12-21 08:33:16 +00:00
kewl fft 6ee60c77bb yay afterclean added 2018-11-15 20:08:23 +00:00
kewl eeca05b629
Merge pull request #21 from juergenhoetzel/check-for-fakeroot
makepkg: Check for "fakeroot" binary
2018-10-30 19:18:28 +00:00
Juergen Hoetzel f92a1522a3
makepkg: Check for "fakeroot" binary 2018-10-30 16:50:07 +01:00
kewl fft 6f5a4f9b6d yay positionned #1 and comments refreshed 2018-10-13 12:01:48 +01:00
kewl 85f6d7c93f
Merge pull request #19 from visibilityspots/master
Feature: use the skip_new_locations option for aurman wrapper
2018-08-21 21:18:42 +01:00
Jan Collijs 80279644a8
Feature: use the skip_new_locations option for aurman wrapper 2018-08-21 11:42:38 +02:00
kewl fft 3901eb7368 aur_only param added 2018-07-25 21:19:02 +01:00
kewl 9772b680dd
Merge pull request #15 from visibilityspots/master
Aurman feature: fetch new pgp keys without interaction
2018-07-24 14:21:01 +01:00
Jan Collijs 349e237307
Aurman feature: fetch new pgp keys without interaction 2018-07-24 10:40:52 +02:00
kewl 3ebf634913
Merge pull request #14 from gliech/master
Skip the archlinux.org news in aurman
2018-07-17 11:11:37 +01:00
Der Gliech 5b4dd96294
added '--skip_news' to the options for aurman 2018-07-17 10:23:03 +02:00
7 changed files with 675 additions and 305 deletions

55
.github/workflows/galaxy.yml vendored Normal file
View File

@ -0,0 +1,55 @@
---
name: Build and Publish Collection to Ansible Galaxy
'on':
release:
types: [ published ]
workflow_dispatch:
defaults:
run:
working-directory: collections/ansible_collections/kewlfft/aur
jobs:
release:
runs-on: ubuntu-20.04
steps:
- name: Checkout git repo
uses: actions/checkout@v2
with:
path: collections/ansible_collections/kewlfft/aur
- name: Ensure that `version:` in `galaxy.yml` matches `GITHUB_REF`
id: version
run: |
[ "$(cat galaxy.yml | grep version: | awk '{print $2}')" = $(awk -F '/' '{print substr($3, 2)}' <<< ${GITHUB_REF}) ] || exit 1
echo ::set-output name=version::$(awk -F '/' '{print substr($3, 2)}' <<< ${GITHUB_REF})
- name: "Set up Python"
uses: actions/setup-python@v2
with:
python-version: "3.11"
- name: Generate cache keys
id: keys
run: |
echo ::set-output name=pip_cache_dir::$(pip cache dir)
# This ensures that the cache is invalidated after a week
echo ::set-output name=date::$(date +%Y_%g)
- name: Pip Cache
uses: actions/cache@v2
with:
path: ${{ steps.keys.outputs.pip_cache_dir }}
key: ansible-pip-${{ steps.keys.outputs.date }}
- name: Install pip packages
run: |
pip3 install -U pip
pip3 install wheel
pip3 install ansible-core
- name: Deploy collection
run: |
ansible-galaxy collection build
ansible-galaxy collection publish --api-key ${{ secrets.GALAXY_API_KEY }} "./kewlfft-aur-${{ steps.version.outputs.version }}.tar.gz"

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
kewlfft-aur-*.tar.gz
*.swp

207
README.md
View File

@ -1,81 +1,170 @@
# Ansible AUR helper
Ansible module to use some Arch User Repository (AUR) helpers as well as makepkg.
# Ansible Collection - kewlfft.aur
## Description
This collection includes an Ansible module to manage packages from the AUR.
## Installation
### Install the `kewlfft.aur` collection from Ansible Galaxy
To install this collection from Ansible Galaxy, run the following command:
```shell
ansible-galaxy collection install kewlfft.aur
```
Alternatively, you can include the collection in a `requirements.yml` file and then run `ansible-galaxy collection install -r requirements.yml`. Here is an example of `requirements.yml` file:
```yaml
collections:
- name: kewlfft.aur
```
### Install the `kewlfft.aur` collection from the AUR
The `kewlfft.aur` collection is also available in the AUR as the [`ansible-collection-kewlfft-aur`](https://aur.archlinux.org/packages/ansible-collection-kewlfft-aur/) package.
### Install the `kewlfft.aur` collection locally for development
If you want to test changes to the source code, run the following commands from the root of this git repository to locally build and install the collection:
```shell
ansible-galaxy collection build --force
ansible-galaxy collection install --force "./kewlfft-aur-$(cat galaxy.yml | grep version: | awk '{print $2}').tar.gz"
```
### Install the `aur` module as a local custom module
Alternatively, you may manually install the `aur` module itself as a [local custom module](https://docs.ansible.com/ansible/latest/dev_guide/developing_locally.html) instead of installing the module through the `kewlfft.aur` Ansible collection. However, it is recommended to use `kewlfft.aur` collection unless you have a good reason not to. Here are the commands to install the `aur` module as a local custom module:
```shell
# Create the user custom module directory
mkdir ~/.ansible/plugins/modules
# Install the aur module into the user custom module directory
curl -o ~/.ansible/plugins/modules/aur.py https://raw.githubusercontent.com/kewlfft/ansible-aur/master/plugins/modules/aur.py
```
## kewlfft.aur.aur Module
Ansible module to use some Arch User Repository (AUR) helpers as well as makepkg.
The following helpers are supported and automatically selected, if present, in the order listed below:
The following helpers are supported and automatically selected in the order they are listed:
- [aurman](https://github.com/polygamma/aurman)
- [yay](https://github.com/Jguer/yay)
- [pacaur](https://github.com/rmarquis/pacaur)
- [paru](https://github.com/Morganamilo/paru)
- [pacaur](https://github.com/E5ten/pacaur)
- [trizen](https://github.com/trizen/trizen)
- [pikaur](https://github.com/actionless/pikaur)
- [aurman](https://github.com/polygamma/aurman) (discontinued)
*makepkg* will be used if no helper was found or if it is explicitly specified:
makepkg will be used if no helper was found or if it's specified explicitly.
- [makepkg](https://wiki.archlinux.org/index.php/makepkg)
## Options
|parameter |required |default |choices |comments|
|--- |--- |--- |--- |---|
|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.|
|use |no |auto |auto, aurman, yay, 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_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.|
### Options
| Parameter | Choices/**Default** | Comments |
| -------------- | ------------------------------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------- |
| 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. |
| upgrade | yes, **no** | Whether or not to upgrade whole system. |
| update_cache | yes, **no** | Whether or not to refresh the packages cache |
| use | **auto**, yay, paru, pacaur, trizen, pikaur, aurman, makepkg | The tool to use, 'auto' uses the first known helper found and makepkg as a fallback. |
| extra_args | **null** | A list of additional arguments to pass directly to the tool. Cannot be used in 'auto' mode. |
| aur_only | yes, **no** | Limit helper operation to the AUR. |
| local_pkgbuild | Local directory with PKGBUILD, **null** | Only valid with makepkg or pikaur. Don't download the package from AUR. Build the package using a local PKGBUILD and the other build files. |
| 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. |
#### Note
### Note
* Either *name* or *upgrade* is required, both cannot be used together.
* *skip_installed* cannot be used with *upgrade*.
* In the *use*=*auto* mode, makepkg is used as a fallback if no known helper is found.
## Installing
### AUR package
The [aur-ansible-git](https://aur.archlinux.org/packages/ansible-aur-git) package is available in the AUR.
Note the module is installed in `/usr/share/ansible/plugins/modules` which is one of the default module library paths.
### Usage
### Manual installation
Just clone the *ansible-aur* repository into your user custom-module directory:
```
git clone https://github.com/kewlfft/ansible-aur.git ~/.ansible/plugins/modules/aur
```
#### Notes
## Usage
### 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,
* 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.
* The scope of this module is installation and update from the AUR; for package removal or for updates from the repositories, it is recommended to use the official *pacman* module.
* The *--needed* parameter of the helper is systematically used, it means if a package is up-to-date, it is not built and reinstalled.
### Examples
Use it in a task, as in the following examples:
```
# Install trizen using makepkg, skip if trizen is already installed
- aur: name=trizen use=makepkg skip_installed=true
#### Create the "aur_builder" user
While Ansible expects to SSH as root, makepkg or AUR helpers do not allow executing operations as root, they fail with "you cannot perform this operation as root". It is therefore recommended to create a user, which is non-root but has no need for password with pacman in sudoers, let's call it *aur_builder*.
This user can be created in an Ansible task with the following actions:
```yaml
- name: Create the `aur_builder` user
become: yes
become_user: aur_builder
# Install package_name using the first known helper found
- aur: name=package_name
...
# Install package_name_1 and package_name_2 using trizen
- aur:
use: trizen
name:
- package_name_1
- package_name_2
...
# Upgrade - using pacaur
- aur: upgrade=yes use=pacaur
...
```
### Create the "aur_builder" user
While Ansible expects to SSH as root, AUR helpers do not allow executing operations as root, they all fail with "you cannot perform this operation as root". It is therefore recommended to create a user, that we will call for example *aur_builder*, that has no need for password with pacman in sudoers.
This can be done in Ansible with the following actions:
```
- user:
ansible.builtin.user:
name: aur_builder
create_home: yes
group: wheel
- lineinfile:
- name: Allow the `aur_builder` user to run `sudo pacman` without a password
become: yes
ansible.builtin.lineinfile:
path: /etc/sudoers.d/11-install-aur_builder
line: 'aur_builder ALL=(ALL) NOPASSWD: /usr/bin/pacman'
create: yes
mode: 0644
validate: 'visudo -cf %s'
```
#### Fully Qualified Collection Names (FQCNs)
In order to use an Ansible module that is distributed in a collection, you must use its FQCN. This corresponds to "the full definition of a module, plugin, or role hosted within a collection, in the form `namespace.collection.content_name`" ([Source](https://github.com/ansible-collections/overview#terminology)). In this case, the `aur` module resides in the `aur` collection which is under the `kewlfft` namespace, so its FQCN is `kewlfft.aur.aur`.
Please note that this does not apply if you installed the `aur` module as a local custom module. Due to the nature of local custom modules, you can simply use the module's short name: `aur`.
#### Examples
Use it in a task, as in the following examples:
```yaml
# This task uses the module's short name instead of its FQCN (Fully Qualified Collection Name).
# Use the short name if the module was installed as a local custom module.
# Otherwise, if it was installed through the `kewlfft.aur` collection, this task will fail.
- name: Install trizen using makepkg if it isn't installed already
aur:
name: trizen
use: makepkg
state: present
become: yes
become_user: aur_builder
# This task uses the `aur` module's FQCN.
- name: Install trizen using makepkg if it isn't installed already
kewlfft.aur.aur:
name: trizen
use: makepkg
state: present
become: yes
become_user: aur_builder
- name: Install package_name_1 and package_name_2 using yay
kewlfft.aur.aur:
use: yay
name:
- package_name_1
- package_name_2
# Note: Dependency resolution will still include repository packages.
- name: Upgrade the system using yay, only act on AUR packages.
kewlfft.aur.aur:
upgrade: yes
use: yay
aur_only: yes
# Skip if it is already installed
- name: Install gnome-shell-extension-caffeine-git using pikaur and a local PKGBUILD.
kewlfft.aur.aur:
name: gnome-shell-extension-caffeine-git
use: pikaur
local_pkgbuild: {{ role_path }}/files/gnome-shell-extension-caffeine-git
state: present
become: yes
become_user: aur_builder
```

246
aur.py
View File

@ -1,246 +0,0 @@
#!/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.urls import open_url
import json
import tarfile
import os
import os.path
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, aurman, pacaur, trizen, pikaur, yay, 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
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']
use_cmd = {
'aurman': ['aurman', '-S', '--noconfirm', '--noedit', '--needed'],
'yay': ['yay', '-S', '--noconfirm', '--needed'],
'pacaur': ['pacaur', '-S', '--noconfirm', '--noedit', '--needed'],
'trizen': ['trizen', '-S', '--noconfirm', '--noedit', '--needed'],
'pikaur': ['pikaur', '-S', '--noconfirm', '--noedit', '--needed'],
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
}
# optional: aurman, pacaur, trizen have a --aur option, do things only for aur
def package_installed(module, package):
"""
Determine if the package is already installed
"""
rc, _, _ = module.run_command(['pacman', '-Q', package], check_rc=False)
return rc == 0
def check_packages(module, packages):
"""
Inform the user what would change if the module were run
"""
would_be_changed = []
for package in packages:
installed = package_installed(module, package)
if not installed:
would_be_changed.append(package)
if would_be_changed:
status = True
if (len(packages) > 1):
message = '%s package(s) would be installed' % str(len(would_be_changed))
else:
message = 'package would be installed'
else:
status = False
if (len(packages) > 1):
message = 'all packages are already installed'
else:
message = 'package is already installed'
module.exit_json(changed=status, msg=message)
def install_with_makepkg(module, package):
"""
Install the specified package with makepkg
"""
f = open_url('https://aur.archlinux.org/rpc/?v=5&type=info&arg={}'.format(package))
result = json.loads(f.read().decode('utf8'))
if result['resultcount'] != 1:
return (1, '', 'package not found')
result = result['results'][0]
f = open_url('https://aur.archlinux.org/{}'.format(result['URLPath']))
current_path = os.getcwd()
with tempfile.TemporaryDirectory() as tmpdir:
os.chdir(tmpdir)
tar_file = '{}.tar.gz'.format(result['Name'])
with open(tar_file, 'wb') as out:
out.write(f.read())
tar = tarfile.open(tar_file)
tar.extractall()
tar.close()
os.chdir(format(result['Name']))
if module.params['skip_pgp_check']:
use_cmd['makepkg'].append('--skippgpcheck')
rc, out, err = module.run_command(use_cmd['makepkg'], check_rc=True)
os.chdir(current_path)
return (rc, out, err)
def upgrade(module, use):
"""
Upgrade the whole system
"""
assert use in use_cmd
rc, out, err = module.run_command(def_lang + use_cmd[use] + ['-u'], check_rc=True)
module.exit_json(
changed=not (out == '' or 'nothing to do' in out or 'No AUR updates found' in out),
msg='upgraded system',
helper=use,
)
def install_packages(module, packages, use, skip_installed):
"""
Install the specified packages
"""
assert use in use_cmd
changed_iter = False
for package in packages:
if skip_installed:
if package_installed(module, package):
rc = 0
continue
if use == 'makepkg':
rc, out, err = install_with_makepkg(module, package)
else:
rc, out, err = module.run_command(def_lang + use_cmd[use] + [package], check_rc=True)
changed_iter = changed_iter or not (out == '' or '-- skipping' in out or 'nothing to do' in out)
if changed_iter:
message = 'installed package(s)'
else:
message = 'package(s) already installed'
module.exit_json(
changed=changed_iter,
msg=message if not rc else err,
helper=use,
rc=rc,
)
def main():
module = AnsibleModule(
argument_spec={
'name': {
'type': 'list',
},
'upgrade': {
'default': False,
'type': 'bool',
},
'use': {
'default': 'auto',
'choices': ['auto', 'aurman', 'pacaur', 'trizen', 'pikaur', 'yaourt', 'yay', 'makepkg'],
},
'skip_installed': {
'default': False,
'type': 'bool',
},
'skip_pgp_check': {
'default': False,
'type': 'bool',
},
},
required_one_of=[['name', 'upgrade']],
supports_check_mode=True
)
params = module.params
if module.check_mode:
check_packages(module, params['name'])
if params['use'] == 'auto':
use = 'makepkg'
# auto: select the first helper for which the bin is found
for k in use_cmd:
if module.get_bin_path(k, False):
use = k
break
else:
use = params['use']
if params['upgrade'] and (params['name'] or params['skip_installed'] or use == 'makepkg'):
module.fail_json(msg="Upgrade cannot be used with this option.")
else:
if params['upgrade']:
upgrade(module, use)
else:
install_packages(module, params['name'], use, params['skip_installed'])
if __name__ == '__main__':
main()

70
galaxy.yml Normal file
View File

@ -0,0 +1,70 @@
### REQUIRED
# The namespace of the collection. This can be a company/brand/organization or product namespace under which all
# content lives. May only contain alphanumeric lowercase characters and underscores. Namespaces cannot start with
# underscores or numbers and cannot contain consecutive underscores
namespace: kewlfft
# The name of the collection. Has the same character restrictions as 'namespace'
name: aur
# The version of the collection. Must be compatible with semantic versioning
version: 0.11.1
# The path to the Markdown (.md) readme file. This path is relative to the root of the collection
readme: README.md
# A list of the collection's content authors. Can be just the name or in the format 'Full Name <email> (url)
# @nicks:irc/im.site#channel'
authors:
- kewl fft <kewl@alto.eu.org>
### OPTIONAL but strongly recommended
# A short summary description of the collection
description: This collection includes an Ansible module to manage packages from the AUR.
# Either a single license or a list of licenses for content inside of a collection. Ansible Galaxy currently only
# accepts L(SPDX,https://spdx.org/licenses/) licenses. This key is mutually exclusive with 'license_file'
license:
- GPL-3.0-or-later
# The path to the license file for the collection. This path is relative to the root of the collection. This key is
# mutually exclusive with 'license'
license_file: ''
# A list of tags you want to associate with the collection for indexing/searching. A tag name has the same character
# requirements as 'namespace' and 'name'
tags:
- aur
- arch_user_repository
- arch
- archlinux
- arch_linux
- packaging
- software
# Collections that this collection requires to be installed for it to be usable. The key of the dict is the
# collection label 'namespace.name'. The value is a version range
# L(specifiers,https://python-semanticversion.readthedocs.io/en/latest/#requirement-specification). Multiple version
# range specifiers can be set and are separated by ','
dependencies: {}
# The URL of the originating SCM repository
repository: https://github.com/kewlfft/ansible-aur
# The URL to any online docs
documentation: https://github.com/kewlfft/ansible-aur/blob/master/README.md
# The URL to the homepage of the collection/project
homepage: https://github.com/kewlfft/ansible-aur
# The URL to the collection issue tracker
issues: https://github.com/kewlfft/ansible-aur/issues
# A list of file glob-like patterns used to filter any files or directories that should not be included in the build
# artifact. A pattern is matched from the relative path of the file or directory of the collection directory. This
# uses 'fnmatch' to match the files or directories. Some directories and files like 'galaxy.yml', '*.pyc', '*.retry',
# and '.git' are always filtered
build_ignore:
- .github
- .gitignore

2
meta/runtime.yml Normal file
View File

@ -0,0 +1,2 @@
---
requires_ansible: '>=2.9.10'

398
plugins/modules/aur.py Normal file
View File

@ -0,0 +1,398 @@
#!/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 AnsibleModule
from ansible.module_utils.urls import open_url
import json
import shlex
import tarfile
import os
import os.path
import shutil
import tempfile
import urllib.parse
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.
state:
description:
- Desired state of the package.
default: present
choices: [ present, latest ]
upgrade:
description:
- Whether or not to upgrade whole system.
default: no
type: bool
update_cache:
description:
- Whether or not to update_cache the package cache.
default: no
type: bool
use:
description:
- The tool to use, 'auto' uses the first known helper found and makepkg as a fallback.
default: auto
choices: [ auto, yay, paru, 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:
description:
- Only valid with makepkg.
Skip PGP signatures verification of source file.
This is useful when installing packages without GnuPG (properly) configured.
Cannot be used unless use is set to 'makepkg'.
type: bool
default: no
ignore_arch:
description:
- 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'.
type: bool
default: no
aur_only:
description:
- Limit helper operation to the AUR.
type: bool
default: no
local_pkgbuild:
description:
- Only valid with makepkg or pikaur.
Directory with PKGBUILD and build files.
Cannot be used unless use is set to 'makepkg' or 'pikaur'.
type: path
default: no
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:
description: the helper that was actually used
'''
EXAMPLES = '''
- name: Install trizen using makepkg, skip if trizen is already installed
aur: name=trizen use=makepkg state=present
become: yes
become_user: aur_builder
'''
def_lang = ['env', 'LC_ALL=C', 'LANGUAGE=C']
use_cmd = {
'yay': ['yay', '-S', '--noconfirm', '--needed', '--cleanafter'],
'paru': ['paru', '-S', '--noconfirm', '--needed', '--cleanafter'],
'pacaur': ['pacaur', '-S', '--noconfirm', '--noedit', '--needed'],
'trizen': ['trizen', '-S', '--noconfirm', '--noedit', '--needed'],
'pikaur': ['pikaur', '-S', '--noconfirm', '--noedit', '--needed'],
'aurman': ['aurman', '-S', '--noconfirm', '--noedit', '--needed', '--skip_news', '--pgp_fetch', '--skip_new_locations'],
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
}
use_cmd_local_pkgbuild = {
'pikaur': ['pikaur', '-P', '--noconfirm', '--noedit', '--needed', '--install'],
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
}
has_aur_option = ['yay', 'paru', 'pacaur', 'trizen', 'pikaur', 'aurman']
def package_installed(module, package):
"""
Determine if the package is already installed
"""
rc, _, _ = module.run_command(['pacman', '-Q', package], check_rc=False)
return rc == 0
def check_packages(module, packages):
"""
Inform the user what would change if the module were run
"""
would_be_changed = [package for package in packages if not package_installed(module, package)]
diff = {'before': '', 'after': '\n'.join(package for package in would_be_changed if module._diff)}
if would_be_changed:
status = True
if len(packages) > 1:
message = '{} package(s) would be installed'.format(len(would_be_changed))
else:
message = 'package would be installed'
else:
status = False
if len(packages) > 1:
message = 'all packages are already installed'
else:
message = 'package is already installed'
module.exit_json(changed=status, msg=message, diff=diff)
def build_command_prefix(use, extra_args, skip_pgp_check=False, ignore_arch=False, aur_only=False, local_pkgbuild=None, update_cache=False):
"""
Create the prefix of a command that can be used by the install and upgrade functions.
"""
if local_pkgbuild:
command = def_lang + use_cmd_local_pkgbuild[use]
else:
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 local_pkgbuild and use != 'makepkg':
command.append(local_pkgbuild)
if update_cache:
command.append('-y')
if extra_args:
command += shlex.split(extra_args)
return command
def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch, local_pkgbuild=None):
"""
Install the specified package or a local PKGBUILD with makepkg
"""
if not local_pkgbuild:
module.get_bin_path('fakeroot', required=True)
f = open_url('https://aur.archlinux.org/rpc/?v=5&type=info&arg={}'.format(urllib.parse.quote(package)))
result = json.loads(f.read().decode('utf8'))
if result['resultcount'] != 1:
return (1, '', 'package {} not found'.format(package))
result = result['results'][0]
f = open_url('https://aur.archlinux.org/{}'.format(result['URLPath']))
with tempfile.TemporaryDirectory() as tmpdir:
if local_pkgbuild:
shutil.copytree(local_pkgbuild, tmpdir, dirs_exist_ok=True)
command = build_command_prefix('makepkg', extra_args)
rc, out, err = module.run_command(command, cwd=tmpdir, check_rc=True)
else:
tar = tarfile.open(mode='r|*', fileobj=f)
tar.extractall(tmpdir)
tar.close()
command = build_command_prefix('makepkg', extra_args, skip_pgp_check=skip_pgp_check, ignore_arch=ignore_arch)
rc, out, err = module.run_command(command, cwd=os.path.join(tmpdir, result['Name']), check_rc=True)
return (rc, out, err)
def install_local_package(module, package, use, extra_args, local_pkgbuild):
"""
Install the specified package with a local PKGBUILD
"""
with tempfile.TemporaryDirectory() as tmpdir:
shutil.copytree(local_pkgbuild, tmpdir, dirs_exist_ok=True)
command = build_command_prefix(use, extra_args, local_pkgbuild=tmpdir + '/PKGBUILD')
rc, out, err = module.run_command(command, check_rc=True)
return (rc, out, err)
def check_upgrade(module, use):
"""
Inform user how many packages would be upgraded
"""
rc, stdout, stderr = module.run_command([use, '-Qu'], check_rc=True)
num_packages = sum(1 for line in stdout.splitlines() if line.strip())
module.exit_json(
changed=num_packages > 0,
msg=f"{num_packages} package(s) would be upgraded",
helper=use,
)
def upgrade(module, use, extra_args, aur_only, update_cache):
"""
Upgrade the whole system
"""
assert use in use_cmd
command = build_command_prefix(use, extra_args, aur_only=aur_only, update_cache=update_cache)
command.append('-u')
rc, out, err = module.run_command(command, check_rc=True)
module.exit_json(
changed=not (out == '' or 'nothing to do' in out.lower() or 'No AUR updates found' in out),
msg='upgraded system',
helper=use,
)
def install_packages(module, packages, use, extra_args, state, skip_pgp_check, ignore_arch, aur_only, local_pkgbuild, update_cache):
"""
Install the specified packages
"""
if local_pkgbuild:
assert use in use_cmd_local_pkgbuild
else:
assert use in use_cmd
changed_iter = False
for package in packages:
if state == 'present' and package_installed(module, package):
rc = 0
continue
if use == 'makepkg':
rc, out, err = install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch, local_pkgbuild)
elif local_pkgbuild:
rc, out, err = install_local_package(module, package, use, extra_args, local_pkgbuild)
else:
command = build_command_prefix(use, extra_args, aur_only=aur_only, update_cache=update_cache)
command.append(package)
rc, out, err = module.run_command(command, check_rc=True)
changed_iter |= not (out == '' or 'up-to-date -- skipping' in out or 'nothing to do' in out.lower())
message = 'installed package(s)' if changed_iter else 'package(s) already installed'
module.exit_json(
changed=changed_iter,
msg=message if not rc else err,
helper=use,
rc=rc,
)
def make_module():
module = AnsibleModule(
argument_spec={
'name': {
'type': 'list',
},
'state': {
'default': 'present',
'choices': ['present', 'latest'],
},
'upgrade': {
'type': 'bool',
},
'update_cache': {
'default': False,
'type': 'bool',
},
'use': {
'default': 'auto',
'choices': ['auto'] + list(use_cmd.keys()),
},
'extra_args': {
'default': None,
'type': 'str',
},
'skip_pgp_check': {
'default': False,
'type': 'bool',
},
'ignore_arch': {
'default': False,
'type': 'bool',
},
'aur_only': {
'default': False,
'type': 'bool',
},
'local_pkgbuild': {
'default': None,
'type': 'path',
},
},
mutually_exclusive=[['name', 'upgrade']],
required_one_of=[['name', 'upgrade']],
supports_check_mode=True
)
params = module.params
use = params['use']
if params['name'] == []:
module.fail_json(msg="'name' cannot be empty.")
if use == 'auto':
if params['extra_args'] is not None:
module.fail_json(msg="'extra_args' cannot be used with 'auto', a tool must be specified.")
use = 'makepkg'
# auto: select the first helper for which the bin is found
for k in use_cmd:
if module.get_bin_path(k):
use = k
break
if use != 'makepkg' and (params['skip_pgp_check'] or params['ignore_arch']):
module.fail_json(msg="This option is only available with 'makepkg'.")
if not (use in use_cmd_local_pkgbuild) and params['local_pkgbuild']:
module.fail_json(msg="This option is not available with '%s'" % use)
if params['local_pkgbuild'] and not os.path.isdir(params['local_pkgbuild']):
module.fail_json(msg="Directory %s not found" % (params['local_pkgbuild']))
if params['local_pkgbuild'] and not os.access(params['local_pkgbuild'] + '/PKGBUILD', os.R_OK):
module.fail_json(msg="PKGBUILD inside %s not readable" % (params['local_pkgbuild']))
if params.get('upgrade', False) and use == 'makepkg':
module.fail_json(msg="The 'upgrade' action cannot be used with 'makepkg'.")
return module, use
def apply_module(module, use):
params = module.params
if params.get('upgrade', False):
if module.check_mode:
check_upgrade(module, use)
else:
upgrade(module, use, params['extra_args'], params['aur_only'], params['update_cache'])
else:
if module.check_mode:
check_packages(module, params['name'])
else:
install_packages(module,
params['name'],
use,
params['extra_args'],
params['state'],
params['skip_pgp_check'],
params['ignore_arch'],
params['aur_only'],
params['local_pkgbuild'],
params['update_cache'])
def main():
module, use = make_module()
apply_module(module, use)
if __name__ == '__main__':
main()