55 lines
1.6 KiB
Nix
55 lines
1.6 KiB
Nix
|
# See https://wiki.nixos.org/wiki/Syncthing
|
||
|
{ config, lib, ... }:
|
||
|
|
||
|
let
|
||
|
cfg = config.aux.system.services.syncthing;
|
||
|
in
|
||
|
{
|
||
|
options = {
|
||
|
aux.system.services.syncthing = {
|
||
|
enable = lib.mkEnableOption "Enables Syncthing";
|
||
|
home = lib.mkOption {
|
||
|
default = "/var/lib/syncthing";
|
||
|
type = lib.types.str;
|
||
|
description = "Where to store Syncthing's configuration files";
|
||
|
};
|
||
|
user = lib.mkOption {
|
||
|
type = lib.types.str;
|
||
|
default = "syncthing";
|
||
|
description = "User account under which Syncthing runs.";
|
||
|
};
|
||
|
web = {
|
||
|
enable = lib.mkEnableOption "Enables the Syncthing web UI.";
|
||
|
port = lib.mkOption {
|
||
|
type = lib.types.int;
|
||
|
default = 8384;
|
||
|
description = "The port to host Syncthing web on.";
|
||
|
};
|
||
|
public = lib.mkEnableOption "Whether to expose the Syncthing web UI to the network.";
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
config = lib.mkIf cfg.enable {
|
||
|
# If the web UI is public, open the port in the firewall
|
||
|
networking.firewall.allowedTCPPorts = with cfg.web; lib.mkIf (enable && public) [ port ];
|
||
|
|
||
|
services.syncthing = {
|
||
|
enable = true;
|
||
|
user = cfg.user;
|
||
|
group = config.users.users.${cfg.user}.group;
|
||
|
configDir = cfg.home;
|
||
|
guiAddress =
|
||
|
let
|
||
|
listenAddress = with cfg.web; (if (enable && public) then "0.0.0.0" else "127.0.0.1");
|
||
|
in
|
||
|
"${listenAddress}:${builtins.toString cfg.web.port}";
|
||
|
};
|
||
|
|
||
|
systemd.services.syncthing = {
|
||
|
environment.STNODEFAULTFOLDER = "true"; # Don't create default ~/Sync folder
|
||
|
unitConfig.RequiresMountsFor = cfg.home;
|
||
|
};
|
||
|
};
|
||
|
}
|