Template out a backup module for desktops
Kinda primitive, but the idea is that I can just link shit into ~/.backups and it'll get backed up
This commit is contained in:
parent
6789d65054
commit
debfc714aa
@ -3,58 +3,63 @@
|
|||||||
---
|
---
|
||||||
- name: Configure desktop system
|
- name: Configure desktop system
|
||||||
block:
|
block:
|
||||||
- name: Create config directories
|
- name: Create config directories
|
||||||
file:
|
file:
|
||||||
path: "{{ item }}"
|
path: "{{ item }}"
|
||||||
state: directory
|
state: directory
|
||||||
recurse: yes
|
recurse: yes
|
||||||
loop:
|
loop:
|
||||||
- "/etc/X11/xorg.conf.d"
|
- "/etc/X11/xorg.conf.d"
|
||||||
- name: Nuke some configs
|
- name: Nuke some configs
|
||||||
file:
|
file:
|
||||||
path: "{{ item }}"
|
path: "{{ item }}"
|
||||||
state: absent
|
state: absent
|
||||||
loop:
|
loop:
|
||||||
# Works around a bug where this causes failed logins
|
# Works around a bug where this causes failed logins
|
||||||
- "/etc/X11/Xsession.d/70im-config_launch"
|
- "/etc/X11/Xsession.d/70im-config_launch"
|
||||||
- name: Copy system configs
|
- name: Copy system configs
|
||||||
template:
|
template:
|
||||||
src: "{{ item.src }}"
|
src: "{{ item.src }}"
|
||||||
dest: "{{ item.dest }}"
|
dest: "{{ item.dest }}"
|
||||||
mode: "{{ item.mode }}"
|
mode: "{{ item.mode }}"
|
||||||
loop:
|
loop:
|
||||||
- { src: "sshd_config", dest: "/etc/ssh/sshd_config", mode: "0644" }
|
- { src: "sshd_config", dest: "/etc/ssh/sshd_config", mode: "0644" }
|
||||||
- { src: "nomouseaccel.conf", dest: "/etc/X11/xorg.conf.d/90-mouse-acceleration.conf", mode: "0644" }
|
- { src: "nomouseaccel.conf", dest: "/etc/X11/xorg.conf.d/90-mouse-acceleration.conf", mode: "0644" }
|
||||||
- { src: "i3.desktop", dest: "/usr/share/xsessions/i3-custom.desktop", mode: "0644" }
|
- { src: "i3.desktop", dest: "/usr/share/xsessions/i3-custom.desktop", mode: "0644" }
|
||||||
- { src: "startx.desktop", dest: "/usr/share/xsessions/startx-custom.desktop", mode: "0644" }
|
- { src: "startx.desktop", dest: "/usr/share/xsessions/startx-custom.desktop", mode: "0644" }
|
||||||
- name: Copy udev rules
|
- name: Copy udev rules
|
||||||
template:
|
template:
|
||||||
src: "{{ item.src }}"
|
src: "{{ item.src }}"
|
||||||
dest: "{{ item.dest }}"
|
dest: "{{ item.dest }}"
|
||||||
mode: "{{ item.mode }}"
|
mode: "{{ item.mode }}"
|
||||||
loop:
|
loop:
|
||||||
- { src: "g810-led.rules", dest: "/etc/udev/rules.d/50-g810-led.rules", mode: "0644" }
|
- { src: "g810-led.rules", dest: "/etc/udev/rules.d/50-g810-led.rules", mode: "0644" }
|
||||||
- { src: "switch-rcm.rules", dest: "/etc/udev/rules.d/50-switch-rcm.rules", mode: "0644" }
|
- { src: "switch-rcm.rules", dest: "/etc/udev/rules.d/50-switch-rcm.rules", mode: "0644" }
|
||||||
notify: reload udev
|
notify: reload udev
|
||||||
- name: Configure SSH
|
- name: Configure SSH
|
||||||
include_tasks: sshd.yml
|
include_tasks: sshd.yml
|
||||||
- name: Configure system packages
|
- name: Configure system packages
|
||||||
include_tasks: packages.yml
|
include_tasks: packages.yml
|
||||||
- name: Configure Mopidy
|
- name: Configure Mopidy
|
||||||
include_tasks: mopidy.yml
|
include_tasks: mopidy.yml
|
||||||
- name: Stop services
|
- name: Stop services
|
||||||
systemd:
|
systemd:
|
||||||
name: "{{ item }}"
|
name: "{{ item }}"
|
||||||
enabled: no
|
enabled: no
|
||||||
state: stopped
|
state: stopped
|
||||||
loop:
|
loop:
|
||||||
- mopidy.service
|
- mopidy.service
|
||||||
- motd-news.timer
|
- motd-news.timer
|
||||||
- name: Start services
|
- name: Start services
|
||||||
systemd:
|
systemd:
|
||||||
name: "{{ item }}"
|
name: "{{ item }}"
|
||||||
enabled: yes
|
enabled: yes
|
||||||
state: started
|
state: started
|
||||||
loop:
|
loop:
|
||||||
- syncthing@salt.service
|
- syncthing@salt.service
|
||||||
|
- name: Template out backup module
|
||||||
|
template:
|
||||||
|
src: "backup.sh"
|
||||||
|
dest: "/opt/backups/modules/desktop.sh"
|
||||||
|
mode: "0600"
|
||||||
become: yes
|
become: yes
|
||||||
|
41
roles/desktop/templates/backup.sh
Normal file
41
roles/desktop/templates/backup.sh
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
#! /bin/bash
|
||||||
|
#
|
||||||
|
# desktop.sh
|
||||||
|
# Backup script for desktops. Meant to be sourced by our main backup script
|
||||||
|
# Copyright (C) 2020 Vintage Salt <rehashedsalt@cock.li>
|
||||||
|
#
|
||||||
|
# Distributed under terms of the MIT license.
|
||||||
|
#
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
export OUTDIR="$BACKUPSDIR/{{ dokuwiki_url }}"
|
||||||
|
retention=7 # 7-day retention period
|
||||||
|
|
||||||
|
# Sanity checks
|
||||||
|
if [ -z "$BACKUPSDIR" ]; then
|
||||||
|
log "BACKUPSDIR was undefined. Run the main backup script instead of this one."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if ! [ -d "$OUTDIR" ]; then
|
||||||
|
if ! mkdir "$OUTDIR"; then
|
||||||
|
log "Unable to find or create output directory: $OUTDIR"
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Purge oldest backup if we need to
|
||||||
|
currentbackupcount="$(ls -1 "$OUTDIR" | wc -l)"
|
||||||
|
if (( currentbackupcount >= retention )); then
|
||||||
|
lastbackup="$(find "$OUTDIR" -name \*.tar.gz 2>/dev/null | sort | head -n 1)"
|
||||||
|
if [ -f "$lastbackup" ]; then
|
||||||
|
log "Removing old backup: $lastbackup"
|
||||||
|
rm "$lastbackup"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# WE MAKE BACKUP NOW SERGEI
|
||||||
|
for dir in /home/*; do
|
||||||
|
username="$(basename -- "$dir")"
|
||||||
|
tar czhf "$OUTDIR/desktop-$username-{{ inventory_hostname }}-$(date -Iseconds).tar.gz" "$dir/.backup"
|
||||||
|
done
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user