nix-git/hosts/yodaNas/host-specific.nix

55 lines
1.4 KiB
Nix
Raw Normal View History

{ config, pkgs, ... }:
{
2023-11-28 15:21:03 +01:00
imports = [
./syncthing.nix
];
2023-11-20 14:09:10 +01:00
# Update and start Jinja-Compose project
# during boot and after every 30 minutes.
# To view the log, run
# journalctl -b -u Jinja-Compose -f
#
systemd.timers."Jinja-Compose" = {
wantedBy = [ "timers.target" ];
partOf = [ "Jinja-Compose.service" ];
timerConfig = {
OnBootSec = "0m";
OnUnitInactiveSec = "30m";
AccuracySec = "1m";
RandomizedDelaySec = "1m";
};
};
2024-01-08 18:40:18 +01:00
# TODO: Add shutdown script (./docker-compose down).
systemd.services."Jinja-Compose" = {
description = "Update and start Jinja-Compose project";
serviceConfig = {
Type = "oneshot";
PrivateTmp = true;
User = "root";
};
path = with pkgs; [
# The `docker-compose` helper script is written in `bash` (!)
bash
docker
];
script = ''
2023-10-08 15:38:44 +02:00
set -eu -o pipefail
2024-08-31 12:07:00 +02:00
# We use
# 2> >(sed 's/^/<3> /' >&2)
# to prefix each line of stderr with
# "<3> "
# Source: https://superuser.com/a/882025/919675
#
# With this prefix, the stderr output is treated as error messages by systemd.
# See https://www.freedesktop.org/software/systemd/man/latest/sd-daemon.html
# They can be viewed with
# journalctl -b -u Jinja-Compose.service
/jc-config/docker-compose pull 2> >(sed 's/^/<3> /' >&2)
/jc-config/docker-compose up -d --wait 2> >(sed 's/^/<3> /' >&2)
'';
};
}