mirror of
https://github.com/arcan1s/ahriman.git
synced 2025-04-24 15:27:17 +00:00
This commit includes following changes * add newly added option to configuration referenec * remove few legacy options from configuration schemas used for validation, which might lead to errors during validation. Note, however, that settings will be still read by the service * add link to aurcache * hide service-setup command description under spoiler
97 lines
3.2 KiB
ReStructuredText
97 lines
3.2 KiB
ReStructuredText
Initial setup
|
|
=============
|
|
|
|
#.
|
|
Install package(s) as usual. At least, ``ahriman-core`` package is required; other features can be installed separately. Alternatively, it is possible to install meta-package, which includes everything.
|
|
#.
|
|
Change settings if required, see :doc:`configuration reference <configuration>` for more details.
|
|
#.
|
|
Perform initial setup:
|
|
|
|
.. code-block:: shell
|
|
|
|
sudo ahriman -a x86_64 -r aur service-setup ...
|
|
|
|
.. admonition:: Details
|
|
:collapsible: closed
|
|
|
|
``service-setup`` literally does the following steps:
|
|
|
|
#.
|
|
Create ``/var/lib/ahriman/.makepkg.conf`` with ``makepkg.conf`` overrides if required (at least you might want to set ``PACKAGER``):
|
|
|
|
.. code-block:: shell
|
|
|
|
echo 'PACKAGER="ahriman bot <ahriman@example.com>"' | sudo -u ahriman tee -a /var/lib/ahriman/.makepkg.conf
|
|
|
|
#.
|
|
Configure build tools (it is required for correct dependency management system):
|
|
|
|
#.
|
|
Create build command (you can choose any name for command, basically it should be ``{name}-{arch}-build``):
|
|
|
|
.. code-block:: shell
|
|
|
|
ln -s /usr/bin/archbuild /usr/local/bin/aur-x86_64-build
|
|
|
|
#.
|
|
Create configuration file (same as previous ``{name}.conf``):
|
|
|
|
.. code-block:: shell
|
|
|
|
cp /usr/share/devtools/pacman.conf.d/{extra,aur}.conf
|
|
|
|
#.
|
|
Change configuration file, add your own repository, add multilib repository etc:
|
|
|
|
.. code-block:: shell
|
|
|
|
echo '[multilib]' | tee -a /usr/share/devtools/pacman.conf.d/aur-x86_64.conf
|
|
echo 'Include = /etc/pacman.d/mirrorlist' | tee -a /usr/share/devtools/pacman.conf.d/aur-x86_64.conf
|
|
|
|
echo '[aur]' | tee -a /usr/share/devtools/pacman.conf.d/aur-x86_64.conf
|
|
echo 'SigLevel = Optional TrustAll' | tee -a /usr/share/devtools/pacman.conf.d/aur-x86_64.conf
|
|
echo 'Server = file:///var/lib/ahriman/repository/$repo/$arch' | tee -a /usr/share/devtools/pacman.conf.d/aur-x86_64.conf
|
|
|
|
#.
|
|
Set ``build_command`` option to point to your command:
|
|
|
|
.. code-block:: shell
|
|
|
|
echo '[build]' | tee -a /etc/ahriman.ini.d/build.ini
|
|
echo 'build_command = aur-x86_64-build' | tee -a /etc/ahriman.ini.d/build.ini
|
|
|
|
#.
|
|
Configure ``/etc/sudoers.d/ahriman`` to allow running command without a password:
|
|
|
|
.. code-block:: shell
|
|
|
|
echo 'Cmnd_Alias CARCHBUILD_CMD = /usr/local/bin/aur-x86_64-build *' | tee -a /etc/sudoers.d/ahriman
|
|
echo 'ahriman ALL=(ALL) NOPASSWD:SETENV: CARCHBUILD_CMD' | tee -a /etc/sudoers.d/ahriman
|
|
chmod 400 /etc/sudoers.d/ahriman
|
|
|
|
This command supports several arguments, kindly refer to its help message.
|
|
|
|
#.
|
|
Start and enable ``ahriman@.timer`` via ``systemctl``:
|
|
|
|
.. code-block:: shell
|
|
|
|
systemctl enable --now ahriman@x86_64-aur.timer
|
|
|
|
#.
|
|
Start and enable status page:
|
|
|
|
.. code-block:: shell
|
|
|
|
systemctl enable --now ahriman-web
|
|
|
|
#.
|
|
Add packages by using ``ahriman package-add {package}`` command:
|
|
|
|
.. code-block:: shell
|
|
|
|
sudo -u ahriman ahriman package-add ahriman --now --refresh
|
|
|
|
The ``--refresh`` flag is required in order to handle local database update.
|