mirror of
https://github.com/kewlfft/ansible-aur.git
synced 2025-09-17 08:30:39 +03:00
Compare commits
17 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
60c02a6652 | ||
![]() |
6f5df32b4b | ||
![]() |
93230880db | ||
![]() |
813cbadc18 | ||
![]() |
dc101ae394 | ||
![]() |
706b236058 | ||
![]() |
e8655fcf1c | ||
![]() |
d05e0bc979 | ||
![]() |
bff54cb367 | ||
![]() |
652b11fd76 | ||
![]() |
5d5cc1e20d | ||
![]() |
95aa8f3047 | ||
![]() |
592c6d9841 | ||
![]() |
e1a11c703b | ||
![]() |
71c32ac3f5 | ||
![]() |
ddab7c7403 | ||
![]() |
c2fd7b31e4 |
23
README.md
23
README.md
@@ -3,6 +3,7 @@ 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, if present, in the order listed below:
|
||||||
- [yay](https://github.com/Jguer/yay)
|
- [yay](https://github.com/Jguer/yay)
|
||||||
|
- [paru](https://github.com/Morganamilo/paru)
|
||||||
- [pacaur](https://github.com/E5ten/pacaur)
|
- [pacaur](https://github.com/E5ten/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)
|
||||||
@@ -17,9 +18,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, 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.|
|
|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.|
|
|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.|
|
|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.|
|
|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.|
|
||||||
|
|
||||||
@@ -30,7 +32,8 @@ The following helpers are supported and automatically selected, if present, in t
|
|||||||
## Installing
|
## Installing
|
||||||
### AUR package
|
### AUR package
|
||||||
The [ansible-aur-git](https://aur.archlinux.org/packages/ansible-aur-git) package is available in the AUR.
|
The [ansible-aur-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.
|
|
||||||
|
Note: The module is installed in `/usr/share/ansible/plugins/modules` which is one of the default module library paths.
|
||||||
|
|
||||||
### Manual installation
|
### Manual installation
|
||||||
Just clone the *ansible-aur* repository into your user custom-module directory:
|
Just clone the *ansible-aur* repository into your user custom-module directory:
|
||||||
@@ -44,7 +47,7 @@ git clone https://github.com/kewlfft/ansible-aur.git ~/.ansible/plugins/modules/
|
|||||||
ansible-galaxy install kewlfft.aur
|
ansible-galaxy install kewlfft.aur
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that if this module is installed from Ansible Galaxy, you will need to list it explicitly in your playbook:
|
Note: If this module is installed from Ansible Galaxy, you will need to list it explicitly in your playbook:
|
||||||
```
|
```
|
||||||
# playbook.yml
|
# playbook.yml
|
||||||
- hosts: localhost
|
- hosts: localhost
|
||||||
@@ -78,6 +81,7 @@ This user can be created in an Ansible task with the following actions:
|
|||||||
```
|
```
|
||||||
- user:
|
- user:
|
||||||
name: aur_builder
|
name: aur_builder
|
||||||
|
create_home: no
|
||||||
group: wheel
|
group: wheel
|
||||||
- lineinfile:
|
- lineinfile:
|
||||||
path: /etc/sudoers.d/11-install-aur_builder
|
path: /etc/sudoers.d/11-install-aur_builder
|
||||||
@@ -106,6 +110,17 @@ Use it in a task, as in the following examples:
|
|||||||
- package_name_1
|
- package_name_1
|
||||||
- package_name_2
|
- package_name_2
|
||||||
|
|
||||||
# Upgrade the system using yay, only act on AUR packages, note that dependency resolving will still include repository packages
|
# Upgrade the system using yay, only act on AUR packages.
|
||||||
|
# Note: Dependency resolving will still include repository packages.
|
||||||
- aur: upgrade=yes use=yay aur_only=yes
|
- aur: upgrade=yes use=yay aur_only=yes
|
||||||
|
|
||||||
|
# Install gnome-shell-extension-caffeine-git using pikaur and a local PKGBUILD.
|
||||||
|
# Skip if it is already installed
|
||||||
|
- 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
|
||||||
```
|
```
|
||||||
|
114
library/aur.py
114
library/aur.py
@@ -2,13 +2,14 @@
|
|||||||
|
|
||||||
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
# 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 AnsibleModule
|
||||||
from ansible.module_utils.urls import open_url
|
from ansible.module_utils.urls import open_url
|
||||||
import json
|
import json
|
||||||
import shlex
|
import shlex
|
||||||
import tarfile
|
import tarfile
|
||||||
import os
|
import os
|
||||||
import os.path
|
import os.path
|
||||||
|
import shutil
|
||||||
import tempfile
|
import tempfile
|
||||||
import urllib.parse
|
import urllib.parse
|
||||||
|
|
||||||
@@ -42,7 +43,7 @@ options:
|
|||||||
description:
|
description:
|
||||||
- The tool 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, paru, pacaur, trizen, pikaur, aurman, makepkg ]
|
||||||
|
|
||||||
extra_args:
|
extra_args:
|
||||||
description:
|
description:
|
||||||
@@ -72,6 +73,14 @@ options:
|
|||||||
- Limit helper operation to the AUR.
|
- Limit helper operation to the AUR.
|
||||||
type: bool
|
type: bool
|
||||||
default: no
|
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:
|
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.
|
||||||
@@ -81,7 +90,7 @@ RETURN = '''
|
|||||||
msg:
|
msg:
|
||||||
description: action that has been taken
|
description: action that has been taken
|
||||||
helper:
|
helper:
|
||||||
the helper that was actually used
|
description: the helper that was actually used
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
@@ -91,10 +100,11 @@ EXAMPLES = '''
|
|||||||
become_user: aur_builder
|
become_user: aur_builder
|
||||||
'''
|
'''
|
||||||
|
|
||||||
def_lang = ['env', 'LC_ALL=C']
|
def_lang = ['env', 'LC_ALL=C', 'LANGUAGE=C']
|
||||||
|
|
||||||
use_cmd = {
|
use_cmd = {
|
||||||
'yay': ['yay', '-S', '--noconfirm', '--needed', '--cleanafter'],
|
'yay': ['yay', '-S', '--noconfirm', '--needed', '--cleanafter'],
|
||||||
|
'paru': ['paru', '-S', '--noconfirm', '--needed', '--cleanafter'],
|
||||||
'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'],
|
||||||
@@ -102,7 +112,12 @@ use_cmd = {
|
|||||||
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
|
'makepkg': ['makepkg', '--syncdeps', '--install', '--noconfirm', '--needed']
|
||||||
}
|
}
|
||||||
|
|
||||||
has_aur_option = ['yay', 'pacaur', 'trizen', 'pikaur', 'aurman']
|
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):
|
def package_installed(module, package):
|
||||||
@@ -145,10 +160,13 @@ def check_packages(module, packages):
|
|||||||
module.exit_json(changed=status, msg=message, diff=diff)
|
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):
|
def build_command_prefix(use, extra_args, skip_pgp_check=False, ignore_arch=False, aur_only=False, local_pkgbuild=None):
|
||||||
"""
|
"""
|
||||||
Create the prefix of a command that can be used by the install and upgrade functions.
|
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]
|
command = def_lang + use_cmd[use]
|
||||||
if skip_pgp_check:
|
if skip_pgp_check:
|
||||||
command.append('--skippgpcheck')
|
command.append('--skippgpcheck')
|
||||||
@@ -156,15 +174,18 @@ def build_command_prefix(use, extra_args, skip_pgp_check=False, ignore_arch=Fals
|
|||||||
command.append('--ignorearch')
|
command.append('--ignorearch')
|
||||||
if aur_only and use in has_aur_option:
|
if aur_only and use in has_aur_option:
|
||||||
command.append('--aur')
|
command.append('--aur')
|
||||||
|
if local_pkgbuild and use != 'makepkg':
|
||||||
|
command.append(local_pkgbuild)
|
||||||
if extra_args:
|
if extra_args:
|
||||||
command += shlex.split(extra_args)
|
command += shlex.split(extra_args)
|
||||||
return command
|
return command
|
||||||
|
|
||||||
|
|
||||||
def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch):
|
def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arch, local_pkgbuild=None):
|
||||||
"""
|
"""
|
||||||
Install the specified package with makepkg
|
Install the specified package or a local PKGBUILD with makepkg
|
||||||
"""
|
"""
|
||||||
|
if not local_pkgbuild:
|
||||||
module.get_bin_path('fakeroot', required=True)
|
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)))
|
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'))
|
result = json.loads(f.read().decode('utf8'))
|
||||||
@@ -173,6 +194,11 @@ def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arc
|
|||||||
result = result['results'][0]
|
result = result['results'][0]
|
||||||
f = open_url('https://aur.archlinux.org/{}'.format(result['URLPath']))
|
f = open_url('https://aur.archlinux.org/{}'.format(result['URLPath']))
|
||||||
with tempfile.TemporaryDirectory() as tmpdir:
|
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 = tarfile.open(mode='r|*', fileobj=f)
|
||||||
tar.extractall(tmpdir)
|
tar.extractall(tmpdir)
|
||||||
tar.close()
|
tar.close()
|
||||||
@@ -181,6 +207,31 @@ def install_with_makepkg(module, package, extra_args, skip_pgp_check, ignore_arc
|
|||||||
return (rc, out, err)
|
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)
|
||||||
|
data = stdout.split('\n')
|
||||||
|
data.remove('')
|
||||||
|
module.exit_json(
|
||||||
|
changed=len(data) > 0,
|
||||||
|
msg="{} package(s) would be upgraded".format(len(data)),
|
||||||
|
helper=use,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def upgrade(module, use, extra_args, aur_only):
|
def upgrade(module, use, extra_args, aur_only):
|
||||||
"""
|
"""
|
||||||
Upgrade the whole system
|
Upgrade the whole system
|
||||||
@@ -193,16 +244,19 @@ def upgrade(module, use, extra_args, aur_only):
|
|||||||
rc, out, err = module.run_command(command, check_rc=True)
|
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.lower() or 'No AUR updates found' in out),
|
||||||
msg='upgraded system',
|
msg='upgraded system',
|
||||||
helper=use,
|
helper=use,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def install_packages(module, packages, use, extra_args, state, skip_pgp_check, ignore_arch, aur_only):
|
def install_packages(module, packages, use, extra_args, state, skip_pgp_check, ignore_arch, aur_only, local_pkgbuild):
|
||||||
"""
|
"""
|
||||||
Install the specified packages
|
Install the specified packages
|
||||||
"""
|
"""
|
||||||
|
if local_pkgbuild:
|
||||||
|
assert use in use_cmd_local_pkgbuild
|
||||||
|
else:
|
||||||
assert use in use_cmd
|
assert use in use_cmd
|
||||||
|
|
||||||
changed_iter = False
|
changed_iter = False
|
||||||
@@ -213,13 +267,15 @@ 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, 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:
|
else:
|
||||||
command = build_command_prefix(use, extra_args, aur_only=aur_only)
|
command = build_command_prefix(use, extra_args, aur_only=aur_only)
|
||||||
command.append(package)
|
command.append(package)
|
||||||
rc, out, err = module.run_command(command, check_rc=True)
|
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.lower())
|
||||||
|
|
||||||
message = 'installed package(s)' if changed_iter else 'package(s) already installed'
|
message = 'installed package(s)' if changed_iter else 'package(s) already installed'
|
||||||
|
|
||||||
@@ -264,6 +320,10 @@ def make_module():
|
|||||||
'default': False,
|
'default': False,
|
||||||
'type': 'bool',
|
'type': 'bool',
|
||||||
},
|
},
|
||||||
|
'local_pkgbuild': {
|
||||||
|
'default': None,
|
||||||
|
'type': 'path',
|
||||||
|
},
|
||||||
},
|
},
|
||||||
mutually_exclusive=[['name', 'upgrade']],
|
mutually_exclusive=[['name', 'upgrade']],
|
||||||
required_one_of=[['name', 'upgrade']],
|
required_one_of=[['name', 'upgrade']],
|
||||||
@@ -274,6 +334,9 @@ def make_module():
|
|||||||
|
|
||||||
use = params['use']
|
use = params['use']
|
||||||
|
|
||||||
|
if params['name'] == []:
|
||||||
|
module.fail_json(msg="'name' cannot be empty.")
|
||||||
|
|
||||||
if use == 'auto':
|
if use == 'auto':
|
||||||
if params['extra_args'] is not None:
|
if params['extra_args'] is not None:
|
||||||
module.fail_json(msg="'extra_args' cannot be used with 'auto', a tool must be specified.")
|
module.fail_json(msg="'extra_args' cannot be used with 'auto', a tool must be specified.")
|
||||||
@@ -287,6 +350,15 @@ def make_module():
|
|||||||
if use != 'makepkg' and (params['skip_pgp_check'] or params['ignore_arch']):
|
if use != 'makepkg' and (params['skip_pgp_check'] or params['ignore_arch']):
|
||||||
module.fail_json(msg="This option is only available with 'makepkg'.")
|
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':
|
if params.get('upgrade', False) and use == 'makepkg':
|
||||||
module.fail_json(msg="The 'upgrade' action cannot be used with 'makepkg'.")
|
module.fail_json(msg="The 'upgrade' action cannot be used with 'makepkg'.")
|
||||||
|
|
||||||
@@ -296,12 +368,24 @@ def make_module():
|
|||||||
def apply_module(module, use):
|
def apply_module(module, use):
|
||||||
params = module.params
|
params = module.params
|
||||||
|
|
||||||
|
if params.get('upgrade', False):
|
||||||
if module.check_mode:
|
if module.check_mode:
|
||||||
check_packages(module, params['name'])
|
check_upgrade(module, use)
|
||||||
elif params.get('upgrade', False):
|
else:
|
||||||
upgrade(module, use, params['extra_args'], params['aur_only'])
|
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 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'])
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
Reference in New Issue
Block a user