2024-04-12 07:57:12 -04:00
|
|
|
{ pkgs, ... }:
|
2024-03-17 21:55:48 -04:00
|
|
|
{
|
2024-05-11 09:46:55 -04:00
|
|
|
imports = [
|
|
|
|
../../users/richie/global/syncthing_base.nix
|
|
|
|
../../users/richie/global/zerotier.nix
|
2024-05-27 15:52:07 -04:00
|
|
|
./docker
|
2024-05-11 09:46:55 -04:00
|
|
|
];
|
2024-04-10 18:23:40 -04:00
|
|
|
|
2024-03-17 21:55:48 -04:00
|
|
|
networking = {
|
|
|
|
hostId = "1beb3027";
|
|
|
|
firewall.enable = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
boot = {
|
|
|
|
zfs.extraPools = [
|
|
|
|
"Media"
|
|
|
|
"Storage"
|
|
|
|
"Torenting"
|
|
|
|
];
|
|
|
|
filesystem = "zfs";
|
|
|
|
useSystemdBoot = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
environment = {
|
|
|
|
systemPackages = with pkgs; [ docker-compose ];
|
|
|
|
etc = {
|
|
|
|
# Creates /etc/lynis/custom.prf
|
|
|
|
"lynis/custom.prf" = {
|
|
|
|
text = ''
|
|
|
|
skip-test=BANN-7126
|
|
|
|
skip-test=BANN-7130
|
|
|
|
skip-test=DEB-0520
|
|
|
|
skip-test=DEB-0810
|
|
|
|
skip-test=FIRE-4513
|
|
|
|
skip-test=HRDN-7222
|
|
|
|
skip-test=KRNL-5820
|
|
|
|
skip-test=LOGG-2190
|
|
|
|
skip-test=LYNIS
|
|
|
|
skip-test=TOOL-5002
|
|
|
|
'';
|
|
|
|
mode = "0440";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
nfs.server.enable = true;
|
|
|
|
|
|
|
|
openssh.ports = [ 629 ];
|
|
|
|
|
|
|
|
plex = {
|
|
|
|
enable = true;
|
|
|
|
dataDir = "/ZFS/Media/Plex/";
|
|
|
|
};
|
|
|
|
|
|
|
|
smartd.enable = true;
|
|
|
|
|
|
|
|
sysstat.enable = true;
|
|
|
|
|
2024-04-13 08:51:00 -04:00
|
|
|
syncthing.guiAddress = "192.168.90.40:8384";
|
2024-05-27 10:27:37 -04:00
|
|
|
syncthing.settings.folders = {
|
2024-04-13 08:51:00 -04:00
|
|
|
"notes" = {
|
2024-04-20 12:54:33 -04:00
|
|
|
id = "l62ul-lpweo"; # cspell:disable-line
|
2024-04-13 08:51:00 -04:00
|
|
|
path = "/ZFS/Media/Notes";
|
|
|
|
devices = [
|
2024-06-09 09:47:30 -04:00
|
|
|
"bob"
|
2024-04-13 08:51:00 -04:00
|
|
|
"phone"
|
|
|
|
"rhapsody-in-green"
|
|
|
|
];
|
|
|
|
fsWatcherEnabled = true;
|
|
|
|
};
|
|
|
|
"books" = {
|
2024-04-20 12:54:33 -04:00
|
|
|
id = "6uppx-vadmy"; # cspell:disable-line
|
2024-04-13 08:51:00 -04:00
|
|
|
path = "/ZFS/Storage/Syncthing/books";
|
|
|
|
devices = [
|
2024-06-09 09:47:30 -04:00
|
|
|
"bob"
|
2024-04-13 08:51:00 -04:00
|
|
|
"phone"
|
|
|
|
"rhapsody-in-green"
|
|
|
|
];
|
|
|
|
fsWatcherEnabled = true;
|
|
|
|
};
|
|
|
|
"important" = {
|
2024-04-20 12:54:33 -04:00
|
|
|
id = "4ckma-gtshs"; # cspell:disable-line
|
2024-04-13 08:51:00 -04:00
|
|
|
path = "/ZFS/Storage/Syncthing/important";
|
|
|
|
devices = [
|
2024-06-09 09:47:30 -04:00
|
|
|
"bob"
|
2024-04-13 08:51:00 -04:00
|
|
|
"phone"
|
|
|
|
"rhapsody-in-green"
|
|
|
|
];
|
|
|
|
fsWatcherEnabled = true;
|
|
|
|
};
|
|
|
|
"music" = {
|
2024-04-20 12:54:33 -04:00
|
|
|
id = "vprc5-3azqc"; # cspell:disable-line
|
2024-04-13 08:51:00 -04:00
|
|
|
path = "/ZFS/Storage/Syncthing/music";
|
|
|
|
devices = [
|
2024-06-09 09:47:30 -04:00
|
|
|
"bob"
|
2024-04-13 08:51:00 -04:00
|
|
|
"phone"
|
|
|
|
"rhapsody-in-green"
|
|
|
|
];
|
|
|
|
fsWatcherEnabled = true;
|
|
|
|
};
|
|
|
|
"projects" = {
|
2024-04-20 12:54:33 -04:00
|
|
|
id = "vyma6-lqqrz"; # cspell:disable-line
|
2024-04-13 08:51:00 -04:00
|
|
|
path = "/ZFS/Storage/Syncthing/projects";
|
2024-06-09 09:47:30 -04:00
|
|
|
devices = [
|
|
|
|
"bob"
|
|
|
|
"rhapsody-in-green"
|
|
|
|
];
|
2024-04-13 08:51:00 -04:00
|
|
|
fsWatcherEnabled = true;
|
2024-04-12 07:38:29 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-03-17 21:55:48 -04:00
|
|
|
usbguard = {
|
|
|
|
enable = false;
|
|
|
|
rules = ''
|
|
|
|
allow id 1532:0241
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
zfs = {
|
|
|
|
trim.enable = true;
|
|
|
|
autoScrub.enable = true;
|
2024-05-28 19:31:16 -04:00
|
|
|
};
|
|
|
|
};
|
2024-05-28 19:36:53 -04:00
|
|
|
systemd = {
|
|
|
|
services."snapshot_manager" = {
|
|
|
|
description = "ZFS Snapshot Manager";
|
|
|
|
requires = [ "zfs-import.target" ];
|
|
|
|
after = [ "zfs-import.target" ];
|
|
|
|
serviceConfig = {
|
2024-05-28 20:36:41 -04:00
|
|
|
Environment = "ZFS_BIN=${pkgs.zfs}/bin/zfs";
|
2024-05-28 19:36:53 -04:00
|
|
|
Type = "oneshot";
|
2024-05-28 20:09:45 -04:00
|
|
|
ExecStart = "${pkgs.python3}/bin/python3 /ZFS/Media/Scripts/new/ZFS/snapshot_manager.py --config-file='/ZFS/Media/Scripts/new/config.toml'";
|
2024-05-28 19:36:53 -04:00
|
|
|
};
|
2024-05-28 19:31:16 -04:00
|
|
|
};
|
2024-05-28 19:36:53 -04:00
|
|
|
timers."snapshot_manager" = {
|
2024-05-28 19:38:33 -04:00
|
|
|
wantedBy = [ "timers.target" ];
|
2024-05-28 19:36:53 -04:00
|
|
|
timerConfig = {
|
|
|
|
OnBootSec = "15m";
|
|
|
|
OnUnitActiveSec = "15m";
|
|
|
|
Unit = "snapshot_manager.service";
|
|
|
|
};
|
2024-03-17 21:55:48 -04:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
system.stateVersion = "23.11";
|
|
|
|
}
|