Files
dotfiles/playbook.yml

898 lines
26 KiB
YAML
Raw Normal View History

2025-10-02 11:10:27 +02:00
---
2020-04-11 14:07:51 +02:00
- name: configure system
hosts: localhost
2018-02-05 20:09:05 +01:00
connection: local
become: false
tasks:
2025-10-02 11:10:27 +02:00
- name: Read machine-specific variables
ansible.builtin.include_vars:
2018-08-17 19:44:31 +02:00
file: _machines/{{ ansible_hostname }}.yml
name: machine
tags:
- always
2025-10-02 11:10:27 +02:00
- ansible.builtin.set_fact:
distro: "{{ ansible_distribution | lower }}"
2018-08-17 19:44:31 +02:00
tags:
- always
2018-02-08 21:45:02 +01:00
2025-10-02 11:10:27 +02:00
- name: Check for valid distro
ansible.builtin.assert:
2024-04-10 15:57:38 +02:00
that: distro in ('archlinux')
2020-03-02 11:52:45 +01:00
2024-04-10 15:57:38 +02:00
- block:
2025-10-02 11:10:27 +02:00
- name: Install ansible requirements
ansible.builtin.package:
name: "{{ packages[distro] }}"
state: present
become: true
vars:
packages:
archlinux:
- python-jmespath
- name: Pacman
2024-04-26 12:04:12 +02:00
tags:
- pacman
block:
2025-10-02 11:10:27 +02:00
- name: Enable multilib repository
ansible.builtin.blockinfile:
2024-04-26 12:04:12 +02:00
path: /etc/pacman.conf
block: |
[multilib]
Include = /etc/pacman.d/mirrorlist
marker: "# {mark} ANSIBLE MANAGED multilib"
notify:
- refresh package lists
2024-04-26 12:04:12 +02:00
become: true
- name: Make sure that package lists are refreshed if necessary
ansible.builtin.meta: flush_handlers
2025-10-02 11:10:27 +02:00
- name: Enable parallel download
ansible.builtin.blockinfile:
2024-04-26 12:04:12 +02:00
path: /etc/pacman.conf
2025-10-02 11:10:27 +02:00
insertafter: "\\[options\\]"
2024-04-26 12:04:12 +02:00
block: |
ParallelDownloads = 5
marker: "# {mark} ANSIBLE MANAGED parallel_download"
become: true
2025-10-02 11:10:27 +02:00
- name: Install pacman-contrib for paccache
ansible.builtin.package:
2024-04-26 12:04:12 +02:00
name: pacman-contrib
state: present
2020-12-08 22:00:44 +01:00
become: true
2024-04-26 12:04:12 +02:00
- block:
2025-10-02 11:10:27 +02:00
- name: Install pacman cache clean service
ansible.builtin.copy:
dest: /etc/systemd/system/pacman-cache-cleanup.service
owner: root
group: root
mode: "0644"
content: |
[Service]
Type=oneshot
ExecStart=/bin/sh -c '/usr/bin/paccache -rk1 && /usr/bin/paccache -ruk0'
RemainAfterExit=true
become: true
- name: Install pacman cache clean timer
ansible.builtin.copy:
dest: /etc/systemd/system/pacman-cache-cleanup.timer
owner: root
group: root
mode: "0644"
content: |
[Timer]
OnCalendar=daily
[Install]
WantedBy=multi-user.target
become: true
- ansible.builtin.systemd:
name: pacman-cache-cleanup.timer
enabled: true
state: started
daemon_reload: true
become: true
name: Enable pacman cache clean timer
2024-04-26 12:04:12 +02:00
- name: dotfiles directory
tags:
- dotfiles-directory
block:
- name: create dotfiles group
group:
name: dotfiles
state: present
2020-12-08 22:00:44 +01:00
become: true
2024-04-26 12:04:12 +02:00
become_user: root
- name: create dotfiles user
user:
name: dotfiles
group: dotfiles
home: /var/lib/dotfiles
create_home: false
shell: /bin/bash
system: true
2020-12-08 22:00:44 +01:00
become: true
2024-04-26 12:04:12 +02:00
become_user: root
- name: create dotfiles directory
file:
state: directory
path: /var/lib/dotfiles
owner: dotfiles
group: dotfiles
2025-10-02 11:10:27 +02:00
mode: "0775" # group needs write access!
2024-04-26 12:04:12 +02:00
become: true
become_user: root
- name: fix group for dotfiles directory
2024-04-26 12:04:12 +02:00
shell: |
chgrp --changes --recursive dotfiles . | grep -Ev "changed group of ('./.git/index'|'./.git/modules/)"
args:
executable: /bin/bash
chdir: /var/lib/dotfiles
register: dotfiles_group_change
become: true
become_user: root
failed_when: dotfiles_group_change.rc not in (0, 1)
changed_when: dotfiles_group_change.rc == 0 # == lines selected, i.e. some output
- name: fix group permissions for dotfiles directory
shell: |
chmod --changes --recursive g+rwX . | grep -Ev "mode of ('./.git/index'|'./.git/modules/)"
2024-04-26 12:04:12 +02:00
args:
executable: /bin/bash
chdir: /var/lib/dotfiles
register: dotfiles_permission_change
become: true
become_user: root
failed_when: dotfiles_permission_change.rc not in (0, 1)
changed_when: dotfiles_permission_change.rc == 0 # == lines selected, i.e. some output
2024-04-20 12:09:28 +02:00
2024-04-26 12:04:12 +02:00
- name: packages
tags:
- packages
block:
- name: load package list
include_vars:
file: packages.yml
2024-05-08 11:52:10 +02:00
name: defined_packages
2024-04-26 12:04:12 +02:00
2024-05-11 10:47:02 +02:00
- name: force-update iptables to iptables-nft on arch
shell: |
if ! pacman -Qi iptables | grep '^Name.*iptables-nft' ; then
# --noconfirm does not cut it
yes | pacman -S iptables-nft
exit 100
fi
exit 0
become: true
register: force_install_iptables
changed_when: force_install_iptables.rc == 100
failed_when: force_install_iptables.rc not in (0, 100)
2024-04-26 12:04:12 +02:00
- set_fact:
2024-05-08 11:52:10 +02:00
distro_packages: "{{ defined_packages|json_query('*.%s'|format(distro)) }}"
2024-04-20 12:09:28 +02:00
2024-04-26 12:04:12 +02:00
- name: check list
assert:
that: "defined_packages|length == distro_packages|length"
2024-04-20 12:09:28 +02:00
2024-04-26 12:04:12 +02:00
- name: install packages
package:
2025-01-31 19:45:44 +01:00
name: "{{ defined_packages|json_query(pkg_query) }}"
2024-04-26 12:04:12 +02:00
state: present
become: true
vars:
2025-01-31 19:45:44 +01:00
pkg_query: "{{ '*.%s[]'|format(distro) }}"
2024-04-26 12:04:12 +02:00
2025-10-11 17:04:49 +02:00
- name: install additional packages
package:
name: "{{ machine.additional_packages|default([]) }}"
state: present
become: true
2024-05-06 11:18:56 +02:00
- name: remove unconfigured packages
script:
cmd: ./remove-unconfigured-packages.sh --noconfirm
register: unconfigured_packages_cmd
failed_when: unconfigured_packages_cmd.rc not in (0, 123)
changed_when: unconfigured_packages_cmd.rc == 123
become: true
2025-10-21 10:36:47 +02:00
- name: Enable reflector timer
ansible.builtin.systemd:
name: reflector.timer
enabled: true
state: started
daemon_reload: true
become: true
2024-04-26 12:04:12 +02:00
- name: aur
tags:
- aur
block:
- name: create build user on arch
user:
name: makepkg
home: /var/lib/makepkg
create_home: true
shell: /bin/bash
system: true
become: true
2024-04-20 12:09:28 +02:00
2024-04-26 12:04:12 +02:00
- set_fact:
aur_packages:
# local packages:
- name: workstation-mgr
2024-04-26 12:04:12 +02:00
- name: portfolio-performance-bin
preexec: |
#!/usr/bin/env bash
source ./env
curl -sSf --proto '=https' https://keys.openpgp.org/vks/v1/by-fingerprint/E46E6F8FF02E4C83569084589239277F560C95AC | gpg --import -
2024-04-20 12:09:28 +02:00
2024-04-26 12:04:12 +02:00
- name: spotify
preexec: |
#!/usr/bin/env bash
source ./env
2025-01-09 17:24:46 +01:00
echo lel
curl -sSf --proto '=https' https://download.spotify.com/debian/pubkey_C85668DF69375001.gpg | gpg --import -
2024-04-14 00:06:57 +02:00
2024-05-07 18:47:47 +02:00
- name: nodejs-intelephense
2024-05-04 21:34:03 +02:00
- name: terraform-ls-bin
2024-05-07 17:04:00 +02:00
- name: grm-git
2024-05-07 18:47:47 +02:00
- name: screencfg-git
2024-07-07 17:14:26 +02:00
- name: google-earth-pro
2024-05-07 17:04:00 +02:00
2024-08-16 09:58:05 +02:00
# ===
- name: python-botocore-stubs
# dependency of
- name: python-boto3-stubs
- name: python-chevron
- name: python-aws-lambda-builders
# === dependencies of
- name: aws-sam-cli
2024-09-30 17:28:32 +02:00
# ===
- name: python-vdf
# dependency of
- name: protontricks
2024-11-02 10:59:25 +01:00
# ===
- name: slack-desktop
2024-11-02 11:26:08 +01:00
# ===
- name: python-class-registry
- name: python-rst2ansi
# dependency of
- name: backblaze-b2
2025-10-14 10:37:09 +02:00
# ===
- name: claude-code
2024-04-26 12:04:12 +02:00
- set_fact:
aur_packages: "{{ aur_packages|map(attribute='dependencies', default=[]) | flatten + aur_packages }}"
2024-04-14 00:06:57 +02:00
2024-04-26 12:04:12 +02:00
- name: install dependencies
shell: |
aur_packages=({{ aur_packages | map(attribute='name') | join(' ') }})
2024-04-26 11:37:29 +02:00
2024-04-26 12:04:12 +02:00
source pkgbuilds/{{ item.name }}/PKGBUILD
2024-04-14 18:43:52 +02:00
2024-04-26 12:04:12 +02:00
installed=0
2024-04-14 18:43:52 +02:00
2024-10-02 22:54:53 +02:00
dependencies=(${depends[@]} ${makedepends[@]} ${checkdepends[@]})
2024-04-26 12:04:12 +02:00
for dep in "${dependencies[@]}" ; do
aur=0
for aur_pkg in "${aur_packages[@]}" ; do
if [[ "${aur_pkg}" == "${dep}" ]] ; then
aur=1
break
fi
done
2024-04-14 18:43:52 +02:00
2024-04-26 12:04:12 +02:00
if (( aur )) ; then
continue
fi
2024-04-14 18:43:52 +02:00
2024-04-26 12:04:12 +02:00
if ! pacman -Qq "${dep}" >/dev/null 2>&1 ; then
installed=1
pacman -S --noconfirm --needed "${dep}"
2024-04-14 18:43:52 +02:00
fi
done
2024-04-26 12:04:12 +02:00
if (( installed )) ; then
exit 123
else
exit 0
2024-04-14 18:43:52 +02:00
fi
2024-04-26 12:04:12 +02:00
args:
executable: /bin/bash
register: install_deps
failed_when: install_deps.rc not in (0, 123)
changed_when: install_deps.rc == 123
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: create build root directory
file:
path: "/var/lib/makepkg/{{ item.name }}/"
state: directory
2025-10-02 11:10:27 +02:00
mode: "0700"
2024-04-26 12:04:12 +02:00
owner: makepkg
group: makepkg
become_user: makepkg
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: create build gpg directory
file:
path: "/var/lib/makepkg/{{ item.name }}/gnupg"
state: directory
2025-10-02 11:10:27 +02:00
mode: "0700"
2024-04-26 12:04:12 +02:00
owner: makepkg
group: makepkg
become_user: makepkg
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
2021-10-03 15:44:48 +02:00
2024-04-26 12:04:12 +02:00
- name: create env file
copy:
dest: /var/lib/makepkg/{{ item.name }}/env
owner: makepkg
group: makepkg
mode: "0600"
content: |
export GNUPGHOME="/var/lib/makepkg/{{ item.name }}/gnupg"
become_user: makepkg
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: check preexec script
stat:
path: /var/lib/makepkg/{{ item.name }}/preexec
become_user: makepkg
become: true
when: item.preexec is defined
loop: "{{ aur_packages }}"
register: preexec_before
loop_control:
label: "{{ item.name }}"
2020-12-09 23:58:24 +01:00
2024-04-26 12:04:12 +02:00
- name: install preexec script
copy:
dest: /var/lib/makepkg/{{ item.name }}/preexec
owner: makepkg
group: makepkg
mode: "0700"
content: "{{ item.preexec }}"
become_user: makepkg
become: true
when: item.preexec is defined
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: check preexec script
stat:
path: /var/lib/makepkg/{{ item.name }}/preexec
become_user: makepkg
become: true
when: item.preexec is defined
loop: "{{ aur_packages }}"
register: preexec_after
loop_control:
label: "{{ item.name }}"
- name: run preexec script
command:
cmd: "{{ item.1.stat.path }}"
chdir: "{{ item.1.stat.path | dirname }}"
become_user: makepkg
become: true
2025-01-09 17:24:58 +01:00
when: not item[0].stat.exists or (item[0].stat.checksum|default('') != item[1].stat.checksum)
2024-04-26 12:04:12 +02:00
loop: "{{ preexec_before.results| reject('skipped')|zip(preexec_after.results| reject('skipped')) }}"
loop_control:
label: "{{ item.1.stat.path }}"
- name: create build script
copy:
owner: makepkg
group: makepkg
mode: "0700"
dest: /var/lib/makepkg/{{ item.name }}/build.sh
content: |
#!/usr/bin/env bash
2024-04-26 12:04:12 +02:00
source /var/lib/makepkg/{{ item.name }}/env
2024-04-22 14:01:53 +02:00
2024-04-26 12:04:12 +02:00
export PKGEXT='.pkg.tar'
export BUILDDIR=/var/lib/makepkg/{{ item.name }}/build/
export SRCDEST=/var/lib/makepkg/{{ item.name }}/src/
export PKGDEST=/var/lib/makepkg/{{ item.name }}/
2024-04-26 12:04:12 +02:00
cd /var/lib/dotfiles/pkgbuilds/{{ item.name }}/
2024-04-14 18:43:52 +02:00
2024-04-26 12:04:12 +02:00
source ./PKGBUILD
2024-04-22 14:01:53 +02:00
2024-04-26 12:04:12 +02:00
for arch in "${arch[@]}" ; do
if [[ "${arch}" == "any" ]] ; then
arch="any"
break
fi
if [[ "${arch}" == "x86_64" ]] ; then
arch="x86_64"
fi
done
2024-04-14 18:43:52 +02:00
2024-04-26 12:04:12 +02:00
if [[ ! "${arch}" ]] ; then
2024-05-27 12:36:34 +02:00
printf 'unsupported arch\n' >&2
2024-04-26 12:04:12 +02:00
exit 1
2024-04-14 18:43:52 +02:00
fi
2024-04-26 12:04:12 +02:00
if [[ "${epoch}" ]] ; then
version="${epoch}:${pkgver}-${pkgrel}"
else
version="${pkgver}-${pkgrel}"
fi
2024-04-22 14:01:53 +02:00
2024-04-26 12:04:12 +02:00
filename="${PKGDEST%/}/${pkgname}-${version}-${arch}${PKGEXT}"
2024-04-22 14:01:53 +02:00
2024-04-26 12:04:12 +02:00
if [[ ! -e "${filename}" ]] ; then
makepkg \
--clean \
--nosign || exit 1
fi
2020-12-09 23:58:24 +01:00
2024-04-26 12:04:12 +02:00
printf '%s' "${filename}" > /var/lib/makepkg/{{ item.name }}/pkgname
become: true
become_user: makepkg
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
2024-04-14 00:06:57 +02:00
2024-04-26 12:04:12 +02:00
- name: create install script
copy:
owner: root
group: root
mode: "0700"
dest: /var/lib/makepkg/{{ item.name }}/install.sh
content: |
#!/usr/bin/env bash
2020-12-09 23:58:24 +01:00
2024-04-26 12:04:12 +02:00
sudo -u makepkg -g makepkg /var/lib/makepkg/{{ item.name }}/build.sh || exit 1
2020-12-09 21:43:57 +01:00
2024-04-26 12:04:12 +02:00
filename="$(</var/lib/makepkg/{{ item.name }}/pkgname)"
2020-12-09 21:43:57 +01:00
2025-09-04 14:24:51 +02:00
name=$(pacman -Qi --file "${filename}" | grep '^Name' | awk '{print $3}')
version=$(pacman -Qi --file "${filename}" | grep '^Version' | awk '{print $3}')
2020-12-08 22:00:44 +01:00
2024-04-26 12:04:12 +02:00
if [[ "$(pacman -Q "${name}")" == "${name} ${version}" ]] ; then
exit 0
else
pacman --upgrade --needed --noconfirm "$filename" || exit 1
exit 123
fi
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: build and install aur package
command: /var/lib/makepkg/{{ item.name }}/install.sh
register: aur_install
changed_when: aur_install.rc == 123
failed_when: aur_install.rc not in (0, 123)
become: true
loop: "{{ aur_packages }}"
loop_control:
label: "{{ item.name }}"
- name: clean up build leftovers
file:
path: /var/lib/makepkg/{{ item[0].name }}/{{ item[1] }}/
state: absent
become_user: makepkg
become: true
with_nested:
- "{{ aur_packages }}"
2025-10-02 11:10:27 +02:00
- - build
2024-04-26 12:04:12 +02:00
- src
loop_control:
label: "{{ item[0].name }}/{{ item[1] }}"
- name: configure timesyncd on arch
copy:
owner: root
group: root
mode: "0644"
dest: /etc/systemd/timesyncd.conf
content: |
[Time]
NTP=0.arch.pool.ntp.org 1.arch.pool.ntp.org 2.arch.pool.ntp.org 3.arch.pool.ntp.org
FallbackNTP=0.pool.ntp.org 1.pool.ntp.org 2.pool.ntp.org 3.pool.ntp.org
become: true
2019-05-20 21:29:26 +02:00
2024-04-26 12:04:12 +02:00
- name: install lz4
package:
name: lz4
state: present
2018-02-09 17:56:43 +01:00
become: true
2020-12-08 22:00:44 +01:00
2025-10-21 10:24:22 +02:00
- name: set mkinitcpio hooks
set_fact:
mkinitcpio_hooks: "base udev autodetect microcode modconf kms keyboard keymap consolefont block encrypt lvm2 filesystems resume fsck"
when: machine.encrypted_root|bool
- name: set mkinitcpio hooks
set_fact:
mkinitcpio_hooks: "base udev autodetect microcode modconf kms keyboard keymap consolefont block filesystems resume fsck"
when: not machine.encrypted_root|bool
- name: configure mkinitcpio hooks
lineinfile:
path: /etc/mkinitcpio.conf
regexp: "^#?HOOKS=.*$"
line: 'HOOKS=({{ mkinitcpio_hooks }})'
become: true
notify:
- rebuild initrd
2024-04-26 12:04:12 +02:00
- name: use vz4 for mkinitcpio compression
lineinfile:
path: /etc/mkinitcpio.conf
2025-10-02 11:10:27 +02:00
regexp: "^#?COMPRESSION=.*$"
2024-04-26 12:04:12 +02:00
line: 'COMPRESSION="lz4"'
2020-02-23 14:56:14 +01:00
become: true
2024-04-26 12:04:12 +02:00
notify:
- rebuild initrd
2024-10-02 23:34:23 +02:00
- name: libvirtd
tags:
- libvirtd
# Arch defaults to systemd socket activation. Hate that stuff, just run the
# damn daemon (so I notice early when something is wrong, not just when I
# want to use it).
block:
- name: mask sockets
service:
state: stopped
enabled: false
masked: true
name: "{{ item }}"
loop:
- libvirtd.socket
- libvirtd-tls.socket
- libvirtd-tcp.socket
- libvirtd-ro.socket
- libvirtd-admin.socket
become: true
# the libvirtd unit file contains the following setting:
#
# Environment=LIBVIRTD_ARGS="--timeout 120"
#
# This will make libvirtd stop after 120 seconds without connections or running
# domains. To convince the daemon to just keep being a daemon, this needs to be
# removed. Fortunately, the unit also contains the following:
#
# EnvironmentFile=-/etc/conf.d/libvirtd
#
# And `EnvironmentFile` trumps `Environment`. Otherwise we'd need to do some
# damn systemd override shenanigans.
- name: configure libvirtd env variable override
copy:
owner: root
group: root
mode: "0600"
dest: /etc/conf.d/libvirtd
content: |
LIBVIRTD_ARGS=
become: true
notify:
- restart libvirtd
- name: enable libvirtd
service:
state: started
enabled: true
name: libvirtd.service
become: true
2024-04-26 12:04:12 +02:00
- name: services
tags:
- services
block:
- set_fact:
disable_services:
2024-10-02 23:18:58 +02:00
- sshd
2024-04-26 12:04:12 +02:00
- name: disable services
service:
state: stopped
enabled: false
2024-10-02 23:18:58 +02:00
name: "{{ item }}.service"
2024-04-26 12:04:12 +02:00
with_items: "{{ disable_services }}"
become: true
- set_fact:
enable_services:
- NetworkManager
- docker
- systemd-timesyncd
- name: enable services
service:
state: started
enabled: true
2024-10-02 23:18:58 +02:00
name: "{{ item }}.service"
2024-04-26 12:04:12 +02:00
with_items: "{{ enable_services }}"
become: true
2020-02-23 14:56:14 +01:00
2024-11-09 19:05:21 +01:00
- name: enable sockets
service:
state: started
enabled: true
name: "{{ item }}.socket"
loop:
- pcscd
become: true
2018-02-09 17:56:43 +01:00
- name: get systemd boot target
command: systemctl get-default
register: systemd_target
changed_when: false
2020-04-01 10:15:58 +02:00
check_mode: false
2018-02-09 17:56:43 +01:00
- name: define systemd default target
set_fact:
default_target: "{{ machine.system_default_target|default('multi-user.target') }}"
2018-02-09 17:56:43 +01:00
- name: set systemd boot target
command: systemctl set-default {{ default_target }}
when: systemd_target.stdout != default_target
become: true
- name: handle lid switch
lineinfile:
path: /etc/systemd/logind.conf
2025-10-02 11:10:27 +02:00
regexp: "^HandleLidSwitch="
line: "HandleLidSwitch=ignore"
2018-02-09 17:56:43 +01:00
become: true
- name: handle power key
lineinfile:
path: /etc/systemd/logind.conf
2025-10-02 11:10:27 +02:00
regexp: "^HandlePowerKey="
line: "HandlePowerKey=suspend"
2018-02-09 17:56:43 +01:00
become: true
2024-04-14 00:27:09 +02:00
- name: limit journald size
lineinfile:
path: /etc/systemd/journald.conf
2025-10-02 11:10:27 +02:00
regexp: "^#?SystemMaxUse=.*$"
line: "SystemMaxUse=50M"
2024-04-14 00:27:09 +02:00
become: true
notify:
- restart journald
2024-04-10 15:57:38 +02:00
- name: create sudonopw group
group:
name: sudonopw
system: true
- name: configure passwordless sudo
copy:
owner: root
group: root
mode: "0600"
dest: /etc/sudoers.d/sudonopw
content: |
%sudonopw ALL=(ALL) NOPASSWD: ALL
become: true
2020-12-08 22:00:44 +01:00
- name: configure passwordless doas
copy:
owner: root
group: root
mode: "0400"
dest: /etc/doas.conf
content: |
permit nopass nolog setenv {PATH=/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin} :sudonopw
become: true
2024-05-10 18:52:51 +02:00
- name: hardware-specific configuration
2024-05-05 11:55:06 +02:00
tags:
2024-05-10 18:52:51 +02:00
- hardware
2024-05-05 11:55:06 +02:00
block:
2024-05-10 18:52:51 +02:00
- name: read driver variables
include_vars:
file: drivers.yml
name: drivers
tags:
- always
- name: gpu configuration
tags:
- hardware:gpu
2024-05-05 11:55:06 +02:00
block:
2024-05-10 18:52:51 +02:00
- name: install AMD cpu packages
2024-05-05 11:55:06 +02:00
package:
2024-05-10 18:52:51 +02:00
name: "{{ drivers.cpu.amd }}"
2024-05-05 11:55:06 +02:00
state: present
become: true
2024-05-10 18:52:51 +02:00
when: machine.cpu == 'amd'
2024-05-05 11:55:06 +02:00
2024-05-10 18:52:51 +02:00
- name: install Intel cpu packages
2024-05-05 11:55:06 +02:00
package:
2024-05-10 18:52:51 +02:00
name: "{{ drivers.cpu.intel }}"
2024-05-05 11:55:06 +02:00
state: present
become: true
2024-05-10 18:52:51 +02:00
when: machine.cpu == 'intel'
2024-10-02 23:34:23 +02:00
2024-05-10 18:52:51 +02:00
when:
- machine.cpu is defined
- name: gpu configuration
tags:
- hardware:gpu
block:
- name: AMD configuration
when: machine.gpu == 'amd'
block:
- name: install AMDGPU packages
package:
name: "{{ drivers.gpu.amd }}"
state: present
become: true
- name: set AMDGPU options
copy:
owner: root
group: root
mode: "0600"
dest: /etc/X11/xorg.conf.d/20-amdgpu.conf
content: |
Section "Device"
Identifier "AMD"
Driver "amdgpu"
Option "VariableRefresh" "true"
Option "TearFree" "true"
EndSection
become: true
- name: Nvidia configuration
when: machine.gpu == 'nvidia'
block:
- name: install nouveau packages
package:
2024-05-15 16:52:48 +02:00
name: "{{ drivers.gpu.nvidia }}"
2024-05-10 18:52:51 +02:00
state: present
become: true
2025-10-19 23:06:08 +02:00
- name: Intel configuration
when: machine.gpu == 'intel'
block:
- name: install intel packages
package:
name: "{{ drivers.gpu.intel }}"
state: present
become: true
2024-05-10 18:52:51 +02:00
when:
- machine.gpu is defined
2020-12-08 22:00:44 +01:00
2024-04-22 12:08:32 +02:00
# See https://bbs.archlinux.org/viewtopic.php?id=259764
- block:
2025-10-02 11:10:27 +02:00
- name: configure pacman to skip installing nextcloud dbus file
blockinfile:
path: /etc/pacman.conf
insertafter: "^#NoExtract"
block: |
NoExtract = usr/share/dbus-1/services/com.nextcloudgmbh.Nextcloud.service
marker: "# {mark} ANSIBLE MANAGED noextract nextcloud"
become: true
- name: remove nextcloud dbus file
file:
path: /usr/share/dbus-1/services/com.nextcloudgmbh.Nextcloud.service
state: absent
become: true
2024-04-22 12:08:32 +02:00
- name: try to make gpg agent behave
block:
2025-10-02 11:10:27 +02:00
- name: configure pacman to skip installing gpg user units
blockinfile:
path: /etc/pacman.conf
insertafter: "^#NoExtract"
block: |
NoExtract = usr/lib/systemd/user/gpg-agent*
marker: "# {mark} ANSIBLE MANAGED noextract gpg-agent"
become: true
2024-05-03 14:38:37 +02:00
- name: backlight configuration
tags:
- backlight
block:
# See https://wiki.archlinux.org/title/backlight#ACPI
- name: create udev rule to allow video group backlight access
copy:
dest: /etc/udev/rules.d/backlight.rules
owner: root
group: root
2025-10-02 11:10:27 +02:00
mode: "0644"
2024-05-03 14:38:37 +02:00
content: |
ACTION=="add", SUBSYSTEM=="backlight", RUN+="/bin/chgrp video $sys$devpath/brightness", RUN+="/bin/chmod g+w $sys$devpath/brightness"
become: true
2025-10-10 13:02:52 +02:00
- set_fact:
users: "{{ machine.users }}"
tags:
- always
2019-11-14 09:16:55 +01:00
- include_tasks: user.yml
2018-08-17 21:16:54 +02:00
args:
2019-11-14 09:16:55 +01:00
apply:
become: true
become_user: "{{ user.name }}"
2024-04-26 12:04:12 +02:00
tags:
- user
2019-11-14 09:16:55 +01:00
with_items: "{{ users }}"
2025-10-02 11:10:27 +02:00
no_log: true # less spam
2019-11-14 09:16:55 +01:00
loop_control:
loop_var: user
tags:
- always
2025-10-11 09:52:10 +02:00
- include_tasks: "{{ item }}"
with_first_found:
- files:
- "_machines/{{ ansible_hostname }}-tasks.yml"
skip: true
tags:
- always
handlers:
- name: refresh package lists
community.general.pacman:
update_cache: true
become: true
- name: rebuild initrd
command: mkinitcpio -P
become: true
2021-10-03 15:25:35 +02:00
register: mkinitcpio_cmd
failed_when: >
mkinitcpio_cmd.rc != 0
and
not (mkinitcpio_cmd.rc == 1 and "file not found: `fsck.overlay'" in mkinitcpio_cmd.stderr)
2024-04-14 00:27:09 +02:00
- name: restart journald
service:
name: systemd-journald
state: restarted
become: true
2024-10-02 23:34:23 +02:00
- name: restart libvirtd
service:
name: libvirtd
state: restarted
become: true