2024-03-21 15:00:36 +01:00
|
|
|
{ pkgs, lib, ... }:
|
|
|
|
{
|
|
|
|
imports = [
|
2024-06-27 16:18:37 +02:00
|
|
|
# ./goaccess.nix
|
2024-10-15 08:58:47 +02:00
|
|
|
./acme.nix
|
2024-03-21 15:00:36 +01:00
|
|
|
./backup.nix
|
2024-10-15 08:58:47 +02:00
|
|
|
./coturn.nix
|
|
|
|
./forgejo.nix
|
|
|
|
./hardware-configuration.nix
|
2024-03-21 15:00:36 +01:00
|
|
|
./kicker.nix
|
|
|
|
./mailserver.nix
|
|
|
|
./network.nix
|
2024-10-15 08:58:47 +02:00
|
|
|
./nextcloud.nix
|
|
|
|
./nginx.nix
|
|
|
|
./postgresql.nix
|
|
|
|
./rspamd.nix
|
|
|
|
./users.nix
|
2024-03-21 15:00:36 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
metacfg = {
|
|
|
|
base.enable = true;
|
|
|
|
nix.enable = true;
|
|
|
|
podman.enable = true;
|
|
|
|
secureboot.enable = false;
|
2024-11-28 10:01:46 +01:00
|
|
|
tools = {
|
|
|
|
direnv.enable = true;
|
|
|
|
};
|
2024-03-21 15:00:36 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
security = {
|
|
|
|
tpm2.enable = lib.mkDefault true;
|
|
|
|
tpm2.abrmd.enable = lib.mkDefault true;
|
|
|
|
};
|
|
|
|
|
|
|
|
system.autoUpgrade = {
|
|
|
|
enable = true;
|
|
|
|
dates = "04:00";
|
|
|
|
operation = "switch";
|
|
|
|
allowReboot = true;
|
2024-11-29 17:04:24 +01:00
|
|
|
# flake = lib.mkForce "git+file:///var/lib/gitea/repositories/harald/nixcfg.git#mx";
|
2024-11-29 16:57:32 +01:00
|
|
|
flake = lib.mkForce "/root/nixcfg/.#mx";
|
2024-03-21 15:00:36 +01:00
|
|
|
};
|
|
|
|
|
2024-11-29 17:04:24 +01:00
|
|
|
systemd.services.nixos-upgrade = {
|
|
|
|
preStart = ''
|
|
|
|
cd /root
|
|
|
|
git fetch origin
|
|
|
|
git reset --hard origin/HEAD
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-06-25 10:39:55 +02:00
|
|
|
nix.gc = {
|
2024-06-25 10:09:51 +02:00
|
|
|
dates = "daily";
|
|
|
|
options = "--delete-older-than 7d";
|
|
|
|
};
|
|
|
|
|
2024-11-29 12:10:02 +01:00
|
|
|
programs.git.config = {
|
|
|
|
safe.directory = "/var/lib/gitea/repositories/harald/nixcfg.git";
|
|
|
|
};
|
2024-06-12 10:41:52 +02:00
|
|
|
|
2024-03-21 15:00:36 +01:00
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
age
|
|
|
|
apacheHttpd # for mkpasswd
|
|
|
|
efibootmgr
|
|
|
|
fgallery
|
|
|
|
git
|
|
|
|
htop
|
|
|
|
mdadm
|
|
|
|
rrsync
|
|
|
|
tpm2-pkcs11
|
|
|
|
tpm2-pkcs11.out
|
|
|
|
tpm2-tools
|
|
|
|
zola
|
|
|
|
];
|
|
|
|
|
|
|
|
sops.age.sshKeyPaths = [ "/var/lib/secrets/ssh_host_ed25519_key" ];
|
|
|
|
|
|
|
|
services.openssh = {
|
|
|
|
enable = true;
|
|
|
|
hostKeys = [
|
|
|
|
{
|
|
|
|
path = "/var/lib/secrets/ssh_host_ed25519_key";
|
|
|
|
type = "ed25519";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
path = "/var/lib/secrets/ssh_host_rsa_key";
|
|
|
|
type = "rsa";
|
|
|
|
bits = 4096;
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2024-05-17 16:29:30 +02:00
|
|
|
systemd.services = {
|
|
|
|
check_boot = {
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
|
|
|
Environment = "PATH=/run/current-system/sw/bin";
|
|
|
|
ExecStart = toString (
|
|
|
|
pkgs.writeShellScript "check_boot.sh" ''
|
|
|
|
CURRENT=$(df /boot | grep /boot | awk '{ print $5}' | sed 's/%//g')
|
|
|
|
THRESHOLD=85
|
|
|
|
|
|
|
|
if [ "$CURRENT" -gt "$THRESHOLD" ] ; then
|
|
|
|
${pkgs.mailutils}/bin/mail -s '/boot Disk Space Alert' harald << EOF
|
|
|
|
Your /boot partition remaining free space is critically low. Used: $CURRENT%
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
''
|
|
|
|
);
|
|
|
|
};
|
|
|
|
wantedBy = [ "default.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.timers = {
|
|
|
|
check_boot = {
|
|
|
|
timerConfig = {
|
|
|
|
OnCalendar = "daily";
|
|
|
|
};
|
|
|
|
wantedBy = [ "timers.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-05-17 16:58:44 +02:00
|
|
|
systemd.services = {
|
|
|
|
check_root = {
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
|
|
|
Environment = "PATH=/run/current-system/sw/bin";
|
|
|
|
ExecStart = toString (
|
|
|
|
pkgs.writeShellScript "check_root.sh" ''
|
|
|
|
CURRENT=$(df / | grep / | awk '{ print $5}' | sed 's/%//g')
|
|
|
|
THRESHOLD=85
|
|
|
|
|
|
|
|
if [ "$CURRENT" -gt "$THRESHOLD" ] ; then
|
|
|
|
${pkgs.mailutils}/bin/mail -s '/boot Disk Space Alert' harald << EOF
|
|
|
|
Your root partition remaining free space is critically low. Used: $CURRENT%
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
''
|
|
|
|
);
|
|
|
|
};
|
|
|
|
wantedBy = [ "default.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.timers = {
|
|
|
|
check_root = {
|
|
|
|
timerConfig = {
|
|
|
|
OnCalendar = "daily";
|
|
|
|
};
|
|
|
|
wantedBy = [ "timers.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-03-21 15:00:36 +01:00
|
|
|
system.stateVersion = "23.05";
|
|
|
|
}
|