mirror of
https://github.com/alyraffauf/nixcfg.git
synced 2024-11-22 06:33:56 -05:00
mauville/home: implify systemd units
This commit is contained in:
parent
0f523dd24c
commit
4d817c1f72
|
@ -18,75 +18,57 @@
|
|||
systemd.user = {
|
||||
services = {
|
||||
backblaze-sync = {
|
||||
Unit = {
|
||||
Description = "Backup to Backblaze.";
|
||||
};
|
||||
Service = {
|
||||
ExecStart = "${pkgs.writeShellScript "backblaze-sync" ''
|
||||
declare -A backups
|
||||
backups=(
|
||||
['/home/aly/pics/camera']="b2://aly-camera"
|
||||
['/home/aly/sync']="b2://aly-sync"
|
||||
['/mnt/Archive/Archive']="b2://aly-archive"
|
||||
['/mnt/Media/Audiobooks']="b2://aly-audiobooks"
|
||||
['/mnt/Media/Music']="b2://aly-music"
|
||||
)
|
||||
# Recursively backup folders to B2 with sanity checks.
|
||||
for folder in "''${!backups[@]}"; do
|
||||
if [ -d "$folder" ] && [ "$(ls -A "$folder")" ]; then
|
||||
${lib.getExe pkgs.backblaze-b2} sync --delete $folder ''${backups[$folder]}
|
||||
else
|
||||
echo "$folder does not exist or is empty."
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
''}";
|
||||
};
|
||||
Unit.Description = "Backup to Backblaze.";
|
||||
|
||||
Service.ExecStart = "${pkgs.writeShellScript "backblaze-sync" ''
|
||||
declare -A backups
|
||||
backups=(
|
||||
['/home/aly/pics/camera']="b2://aly-camera"
|
||||
['/home/aly/sync']="b2://aly-sync"
|
||||
['/mnt/Archive/Archive']="b2://aly-archive"
|
||||
['/mnt/Media/Audiobooks']="b2://aly-audiobooks"
|
||||
['/mnt/Media/Music']="b2://aly-music"
|
||||
)
|
||||
# Recursively backup folders to B2 with sanity checks.
|
||||
for folder in "''${!backups[@]}"; do
|
||||
if [ -d "$folder" ] && [ "$(ls -A "$folder")" ]; then
|
||||
${lib.getExe pkgs.backblaze-b2} sync --delete $folder ''${backups[$folder]}
|
||||
else
|
||||
echo "$folder does not exist or is empty."
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
''}";
|
||||
};
|
||||
|
||||
build-hosts = {
|
||||
Unit = {
|
||||
Description = "Build nixosConfiguration for each host.";
|
||||
};
|
||||
Service = {
|
||||
ExecStart = "${pkgs.writeShellScript "build-hosts" ''
|
||||
hosts=(
|
||||
fallarbor
|
||||
lavaridge
|
||||
petalburg
|
||||
rustboro
|
||||
)
|
||||
Unit.Description = "Build nixosConfiguration for each host.";
|
||||
|
||||
for h in "''${hosts[@]}"; do
|
||||
nix build github:alyraffauf/nixcfg#nixosConfigurations.$h.config.system.build.toplevel
|
||||
done
|
||||
''}";
|
||||
};
|
||||
Service.ExecStart = "${pkgs.writeShellScript "build-hosts" ''
|
||||
hosts=(
|
||||
fallarbor
|
||||
lavaridge
|
||||
petalburg
|
||||
rustboro
|
||||
)
|
||||
|
||||
for h in "''${hosts[@]}"; do
|
||||
nix build github:alyraffauf/nixcfg#nixosConfigurations.$h.config.system.build.toplevel
|
||||
done
|
||||
''}";
|
||||
};
|
||||
};
|
||||
|
||||
timers = {
|
||||
backblaze-sync = {
|
||||
Unit = {
|
||||
Description = "Daily backups to Backblaze.";
|
||||
};
|
||||
Install = {
|
||||
WantedBy = ["timers.target"];
|
||||
};
|
||||
Timer = {
|
||||
OnCalendar = "*-*-* 03:00:00";
|
||||
};
|
||||
Install.WantedBy = ["timers.target"];
|
||||
Timer.OnCalendar = "*-*-* 03:00:00";
|
||||
Unit.Description = "Daily backups to Backblaze.";
|
||||
};
|
||||
build-hosts = {
|
||||
Unit = {
|
||||
Description = "Build hosts daily.";
|
||||
};
|
||||
Install = {
|
||||
WantedBy = ["timers.target"];
|
||||
};
|
||||
Timer = {
|
||||
OnCalendar = "*-*-* 06:00:00";
|
||||
};
|
||||
Install.WantedBy = ["timers.target"];
|
||||
Timer.OnCalendar = "*-*-* 06:00:00";
|
||||
Unit.Description = "Build hosts daily.";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue