trixie/lmn-client.yml

108 lines
3 KiB
YAML
Raw Normal View History

## This playbook deploys a client for LinuxMuster.
2023-10-12 20:00:19 +02:00
#
# Use the following in the installer's preseed file:
#
# d-i preseed/late_command string \
# mkdir -p /target/home/ansible/.ssh && \
# echo "ssh-ed25519 A...YOUR.KEY...Z" >> /target/home/ansible/.ssh/authorized_keys ; \
# in-target chown -R ansible:ansible /home/ansible/.ssh/ ; \
# in-target chmod -R og= /home/ansible/.ssh/ ; \
# if [ -n "$playbook" ] ; then \
# mkdir -v /target/dev/shm ; \
# in-target mount -v -t tmpfs tmpfs /dev/shm ; \
# echo "$vaultpw" > /target/dev/shm/vaultpw ; \
# in-target ansible-pull --verbose --purge --extra-vars="run_in_installer=true" \
# --vault-password-file /dev/shm/vaultpw \
# -i localhost, --url=git://ansible.example.org/.git -C YOUR_BRANCH $playbook ; \
# fi
#
2023-01-13 13:43:31 +01:00
---
- name: Apply common configuration to the machines
hosts: all # desktop:laptop
2023-01-13 13:43:31 +01:00
remote_user: ansible
become: true
2025-08-06 08:57:08 +02:00
vars_files:
- qgm-vars.yml
pre_tasks:
2025-08-06 08:46:39 +02:00
# - name: Ask for global-admin AD password
# ansible.builtin.pause:
# prompt: "Enter global-admin AD password. Leave empty to skip domain join"
# echo: false
# register: adpw
# no_log: true
# when: "ansible_cmdline.adpw is not defined"
2023-10-04 13:42:01 +02:00
- name: Preseed apparmor
ansible.builtin.debconf:
name: apparmor
question: apparmor/homedirs
value: >-
/srv/samba/schools/default-school/teachers/
/srv/samba/schools/default-school/students/*/
2023-10-19 21:30:25 +02:00
/srv/samba/schools/default-school/examusers/
vtype: string
- name: Preseed unattended-upgrades
ansible.builtin.debconf:
name: unattended-upgrades
question: unattended-upgrades/enable_auto_updates
value: true
vtype: boolean
2023-01-13 13:43:31 +01:00
roles:
2023-07-12 15:52:09 +02:00
- lmn_network
- role: up2date_debian
tags: upgrade
- lmn_sssd
- lmn_mount
- lmn_kde
2025-03-18 14:37:13 +01:00
- role: lmn_vm
when: vm_support
2025-04-04 15:41:29 +02:00
- role: lmn_printer
2025-04-04 15:23:33 +02:00
when: printservers is defined
2023-05-03 18:16:56 +02:00
- kerberize
- lmn_misc
- role: lmn_localproxy
when: localproxy
- role: lmn_localhome
when: localhome
- role: lmn_localuser
when: localuser
2025-03-18 14:37:13 +01:00
- role: lmn_exam
when: exam_mode
- role: lmn_wlan
when:
- ansible_interfaces | select('search', 'wl.+') | first is defined
- wlan != 'none'
2023-01-13 13:43:31 +01:00
tasks:
- name: Include custom roles
ansible.builtin.include_role:
name: "custom/{{ rolename }}"
loop: "{{ custom_roles }}"
loop_control:
loop_var: rolename
when: custom_roles is defined
- name: Final tasks
ansible.builtin.include_role:
name: "{{ role }}"
loop_control:
loop_var: role
loop:
- lmn_security
- lmn_finish
- lmn_tmpfixes
- name: Apply roles that must run serial
hosts: all
remote_user: ansible
become: true
serial: 1
ignore_unreachable: true
roles:
- role: lmn_vpn
when: vpn != "none"