configs/roles/config/tasks/main.yml

244 lines
4.9 KiB
YAML
Raw Normal View History

---
- name: Gather the package facts
ansible.builtin.package_facts:
2024-10-11 17:22:49 +02:00
tags: always
- name: Create backup structure
ansible.builtin.file:
path: "~/old_dat"
state: "directory"
tags: config
- name: Copy files to backup
ansible.builtin.copy:
src: "~/{{ item }}"
2024-10-10 20:37:44 +02:00
dest: "~/old_dat/"
2024-10-10 19:47:41 +02:00
remote_src: true
loop:
- ".config"
- ".local/share/applications"
- ".mozilla"
2024-10-10 20:40:07 +02:00
- ".ssh"
- "scripts"
2024-10-10 19:53:27 +02:00
ignore_errors: true
tags: config
2024-10-10 20:40:07 +02:00
- name: Remove old/unnecessary files and directories
ansible.builtin.file:
path: "{{ item }}"
state: "absent"
loop:
2024-10-10 20:40:07 +02:00
- "~/.emacs.d"
2024-10-13 09:23:23 +02:00
- "~/scripts"
tags: config
- name: Copy new files and directories
ansible.posix.synchronize:
src: "{{ item }}"
2024-10-10 20:08:24 +02:00
dest: "~/"
owner: false
group: false
2024-10-13 09:34:34 +02:00
checksum: true
loop:
- ".config"
- ".face"
2024-10-12 15:05:31 +02:00
- ".fonts"
- ".gitconfig"
- ".gtkrc-2.0"
- ".local"
- ".ssh"
2024-10-12 15:05:31 +02:00
- ".themes"
- "scripts"
tags: config
- name: Copy new files and directories (root)
ansible.posix.synchronize:
src: "{{ item }}"
2024-10-10 20:08:24 +02:00
dest: "/"
owner: false
group: false
2024-10-13 09:34:34 +02:00
checksum: true
loop:
- "etc"
2024-10-12 16:07:24 +02:00
- "usr"
become: true
tags: config
- name: x86_64 | Copy files (root)
ansible.builtin.copy:
src: "{{ item }}"
dest: "/etc/pacman.conf"
loop:
2024-10-10 20:00:40 +02:00
- "etc/pacman-x86_64.conf"
when: ansible_architecture == "x86_64"
become: true
tags: config
- name: Symlink xdg environment variables
ansible.builtin.file:
src: "~/.config/user-dirs.dirs"
dest: "~/.config/environment.d/user-dirs.dirs.conf"
state: "link"
tags: config
- name: Bash cat | Download
ansible.builtin.git:
repo: https://github.com/exu-g/bash-cat-with-cat.git
dest: "/tmp/bash-cat-with-cat"
tags: config
- name: Bash cat | Copy to scripts
ansible.builtin.copy:
src: "/tmp/bash-cat-with-cat/cat.sh"
dest: "~/scripts/pieces/cat.sh"
mode: "0755"
tags: config
- name: Reload user systemd services
ansible.builtin.systemd_service:
daemon_reload: true
2024-10-10 20:15:20 +02:00
scope: user
tags: services
- name: Enable fstrim
ansible.builtin.systemd_service:
name: fstrim.timer
state: "started"
enabled: true
become: true
tags: services
- name: Enable btrfsmaintenance timers
ansible.builtin.systemd_service:
name: "{{ item }}"
enabled: true
loop:
- "btrfs-balance.timer"
- "btrfs-scrub.timer"
when: ('btrfsmaintenance' in ansible_facts.packages)
become: true
tags: services
- name: Enable btrfsmaintenance services
ansible.builtin.systemd_service:
name: "{{ item }}"
state: "restarted"
loop:
- "btrfsmaintenance-refresh.service"
when: ('btrfsmaintenance' in ansible_facts.packages)
become: true
tags: services
- name: Enable reflector
ansible.builtin.systemd_service:
name: "{{ item }}"
enabled: true
loop:
- "reflector.timer"
when: ('reflector' in ansible_facts.packages)
become: true
tags: services
- name: Enable NTP
ansible.builtin.command: timedatectl set-ntp true
become: true
tags: services
- name: Enable ssh-agent
ansible.builtin.systemd_service:
name: ssh-agent
state: "restarted"
enabled: true
2024-10-10 20:15:20 +02:00
scope: user
tags: services
2024-10-10 20:27:06 +02:00
- name: Enable sddm
ansible.builtin.systemd_service:
name: sddm
enabled: true
become: true
tags: services
2024-10-10 21:45:05 +02:00
- name: Add group for libvirt
ansible.builtin.user:
name: "{{ ansible_user_id }}"
groups:
- libvirt
append: true
when: ('libvirt' in ansible_facts.packages)
become: true
tags: config
2024-10-10 21:45:05 +02:00
- name: Create groups
ansible.builtin.group:
name: "{{ item }}"
state: present
loop:
- video # backlight
- render # GPU passing
- wireguard # wireguard
become: true
tags: config
2024-10-10 21:45:05 +02:00
2024-10-11 18:51:51 +02:00
- name: Set fish for user
ansible.builtin.user:
name: "{{ ansible_user_id }}"
shell: "/usr/bin/fish"
2024-10-11 18:58:32 +02:00
become: true
2024-10-11 18:52:59 +02:00
tags: config
2024-10-11 18:51:51 +02:00
- name: Set fish for root
ansible.builtin.user:
name: "root"
shell: "/usr/bin/fish"
become: true
2024-10-11 18:52:59 +02:00
tags: config
2024-10-11 18:51:51 +02:00
2024-10-10 21:45:05 +02:00
- name: Add user to groups
ansible.builtin.user:
name: "{{ ansible_user_id }}"
groups:
- video # backlight
- render # GPU passing
- wireguard # wireguard
append: true
2024-10-11 17:11:30 +02:00
become: true
tags: config
2024-10-10 21:45:05 +02:00
- name: Set sudoers.d permissions
ansible.builtin.file:
path: /etc/sudoers.d
mode: "600"
owner: root
group: root
recurse: true
become: true
tags: config
2024-10-10 21:45:05 +02:00
- name: Make scripts executable
ansible.builtin.file:
2024-10-10 21:45:05 +02:00
path: "{{ item }}"
mode: u+x,g+x,o+x
recurse: true
loop:
- "~/scripts"
- "~/.local/share/applications"
tags: config
2024-10-10 21:45:05 +02:00
- name: Reload applications
ansible.builtin.shell:
cmd: "update-desktop-database ~/.local/share/applications/"
tags: config
- name: Doom Emacs | Check if installed
ansible.builtin.stat:
path: "~/.config/emacs/bin/doom"
register: doom_emacs
tags: config
- name: Doom Emacs | Update if present
ansible.builtin.shell:
cmd: "~/.config/emacs/bin/doom sync"
2024-10-11 17:18:22 +02:00
when: doom_emacs.stat.exists
tags: config