add new syncthing folder
This commit is contained in:
@@ -17,5 +17,6 @@
|
||||
./kop-fileshare.nix
|
||||
./adam-site.nix
|
||||
./plausible.nix
|
||||
./syncthing.nix
|
||||
];
|
||||
}
|
||||
|
||||
@@ -1,87 +1,103 @@
|
||||
{ config, pkgs, lib, ... }:
|
||||
let basePath = "/synced";
|
||||
{ config, pkgs, lib, inputs, ... }:
|
||||
let cfg = config.custom.services.syncthing;
|
||||
in {
|
||||
systemd.tmpfiles.rules =
|
||||
[ "d ${basePath} 0700 ${config.mainUser.name} users -" ];
|
||||
|
||||
# check device id: syncthing cli --gui-address=/synced/gui-socket --gui-apikey=<key> show system
|
||||
environment.systemPackages = with pkgs; [ syncthing ];
|
||||
|
||||
services.syncthing = {
|
||||
enable = true;
|
||||
dataDir = basePath;
|
||||
user = config.mainUser.name;
|
||||
group = "users";
|
||||
guiAddress = "${basePath}/gui-socket";
|
||||
overrideDevices = true;
|
||||
overrideFolders = true;
|
||||
|
||||
settings = {
|
||||
options.urAccepted = -1;
|
||||
options.relaysEnabled = false;
|
||||
options.globalAnnounceEnabled = false;
|
||||
options.crashReportingEnabled = false;
|
||||
|
||||
devices = {
|
||||
kop-pc = {
|
||||
id =
|
||||
"DZKIUS7-WCGTYEV-4OKVSZU-MIVL2NC-N45AKZL-ABT3VN2-I7RXUMF-RF4CYAU";
|
||||
addresses = [ "tcp://192.168.0.11" ];
|
||||
};
|
||||
server = {
|
||||
id =
|
||||
"HZUUQEQ-JOKYHTU-AVFVC3U-7KUAXVC-QY3OJTF-HGU7RZ3-5HA5TOE-VT4FNQB";
|
||||
addresses = [ "tcp://192.168.0.6" "tcp://192.168.2.1" ];
|
||||
};
|
||||
mini-pc = {
|
||||
id =
|
||||
"NKRWOR6-2YNLVY5-GH6TG7T-V3M4VHD-OFS4XR3-Q45CALD-JVSIBKU-JZBGRQ3";
|
||||
addresses = [ "tcp://192.168.0.10" "tcp://192.168.2.1" ];
|
||||
};
|
||||
mini-pc-proxmox = {
|
||||
id =
|
||||
"FK3DW4B-6Y7C25O-IDBSOMV-GOUSWZW-KQR7ELS-QUKS4UR-AFZXLZE-67QJXAX";
|
||||
addresses = [ "tcp://192.168.0.10" "tcp://192.168.2.1" ];
|
||||
};
|
||||
laptop = {
|
||||
id =
|
||||
"5T6Y3WO-FOQYYFQ-5MLNDSZ-7APIDUG-6KM2ZZM-RTRXMWX-MCZKLMH-BYNDJAQ";
|
||||
addresses = [ "tcp://192.168.2.22" ];
|
||||
};
|
||||
phone = {
|
||||
id =
|
||||
"XFQ7MV6-MKBYQXH-WGYVQUB-BYJJPFJ-HJTNZEP-PXWAMYY-DMADWSU-PQOTVAI";
|
||||
addresses = [ "tcp://192.168.0.15" "tcp://192.168.2.20" ];
|
||||
};
|
||||
};
|
||||
folders."default" = {
|
||||
id = "default";
|
||||
path = "${basePath}/default";
|
||||
devices =
|
||||
[ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" "phone" ];
|
||||
ignorePerms = false;
|
||||
};
|
||||
|
||||
folders."books" = {
|
||||
id = "books";
|
||||
path = "${basePath}/books";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
|
||||
folders."fh" = {
|
||||
id = "fh";
|
||||
path = "${basePath}/fh";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
|
||||
folders."work_drive" = {
|
||||
id = "work_drive";
|
||||
path = "${basePath}/work_drive";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
options.custom.services.syncthing = {
|
||||
enable = lib.mkEnableOption "Enables syncthing";
|
||||
basePath = lib.mkOption {
|
||||
type = with lib.types; string;
|
||||
default = "/synced";
|
||||
description = "Base path for syncthing data";
|
||||
};
|
||||
};
|
||||
config = lib.mkIf cfg.enable {
|
||||
systemd.tmpfiles.rules =
|
||||
[ "d ${cfg.basePath} 0700 ${config.mainUser.name} users -" ];
|
||||
|
||||
networking.firewall.allowedTCPPorts = [ 8384 22000 ];
|
||||
networking.firewall.allowedUDPPorts = [ 22000 21027 ];
|
||||
# check device id: syncthing cli --gui-address=/synced/gui-socket --gui-apikey=<key> show system
|
||||
environment.systemPackages = with pkgs; [ syncthing ];
|
||||
|
||||
services.syncthing = {
|
||||
enable = true;
|
||||
dataDir = cfg.basePath;
|
||||
user = config.mainUser.name;
|
||||
group = "users";
|
||||
guiAddress = "${cfg.basePath}/gui-socket";
|
||||
overrideDevices = true;
|
||||
overrideFolders = true;
|
||||
|
||||
settings = {
|
||||
options.urAccepted = -1;
|
||||
options.relaysEnabled = false;
|
||||
options.globalAnnounceEnabled = false;
|
||||
options.crashReportingEnabled = false;
|
||||
|
||||
devices = {
|
||||
kop-pc = {
|
||||
id =
|
||||
"DZKIUS7-WCGTYEV-4OKVSZU-MIVL2NC-N45AKZL-ABT3VN2-I7RXUMF-RF4CYAU";
|
||||
addresses = [ "tcp://192.168.0.11" ];
|
||||
};
|
||||
server = {
|
||||
id =
|
||||
"HZUUQEQ-JOKYHTU-AVFVC3U-7KUAXVC-QY3OJTF-HGU7RZ3-5HA5TOE-VT4FNQB";
|
||||
addresses = [ "tcp://192.168.0.6" "tcp://192.168.2.1" ];
|
||||
};
|
||||
mini-pc = {
|
||||
id =
|
||||
"NKRWOR6-2YNLVY5-GH6TG7T-V3M4VHD-OFS4XR3-Q45CALD-JVSIBKU-JZBGRQ3";
|
||||
addresses = [ "tcp://192.168.0.10" "tcp://192.168.2.1" ];
|
||||
};
|
||||
mini-pc-proxmox = {
|
||||
id =
|
||||
"FK3DW4B-6Y7C25O-IDBSOMV-GOUSWZW-KQR7ELS-QUKS4UR-AFZXLZE-67QJXAX";
|
||||
addresses = [ "tcp://192.168.0.10" "tcp://192.168.2.1" ];
|
||||
};
|
||||
laptop = {
|
||||
id =
|
||||
"5T6Y3WO-FOQYYFQ-5MLNDSZ-7APIDUG-6KM2ZZM-RTRXMWX-MCZKLMH-BYNDJAQ";
|
||||
addresses = [ "tcp://192.168.2.22" ];
|
||||
};
|
||||
phone = {
|
||||
id =
|
||||
"XFQ7MV6-MKBYQXH-WGYVQUB-BYJJPFJ-HJTNZEP-PXWAMYY-DMADWSU-PQOTVAI";
|
||||
addresses = [ "tcp://192.168.0.15" "tcp://192.168.2.20" ];
|
||||
};
|
||||
};
|
||||
folders."default" = {
|
||||
id = "default";
|
||||
path = "${cfg.basePath}/default";
|
||||
devices =
|
||||
[ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" "phone" ];
|
||||
ignorePerms = false;
|
||||
};
|
||||
|
||||
folders."books" = {
|
||||
id = "books";
|
||||
path = "${cfg.basePath}/books";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
|
||||
folders."fh" = {
|
||||
id = "fh";
|
||||
path = "${cfg.basePath}/fh";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
|
||||
folders."work_drive" = {
|
||||
id = "work_drive";
|
||||
path = "${cfg.basePath}/work_drive";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
|
||||
folders."no_backup" = {
|
||||
id = "no_backup";
|
||||
path = "${cfg.basePath}/no_backup";
|
||||
devices = [ "kop-pc" "server" "laptop" "mini-pc" "mini-pc-proxmox" ];
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
networking.firewall.allowedTCPPorts = [ 8384 22000 ];
|
||||
networking.firewall.allowedUDPPorts = [ 22000 21027 ];
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user