2018-11-17 14:02:00 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.syncthing.relay;
|
|
|
|
|
|
|
|
dataDirectory = "/var/lib/syncthing-relay";
|
|
|
|
|
|
|
|
relayOptions =
|
|
|
|
[
|
|
|
|
"--keys=${dataDirectory}"
|
|
|
|
"--listen=${cfg.listenAddress}:${toString cfg.port}"
|
|
|
|
"--status-srv=${cfg.statusListenAddress}:${toString cfg.statusPort}"
|
|
|
|
"--provided-by=${escapeShellArg cfg.providedBy}"
|
|
|
|
]
|
|
|
|
++ optional (cfg.pools != null) "--pools=${escapeShellArg (concatStringsSep "," cfg.pools)}"
|
|
|
|
++ optional (cfg.globalRateBps != null) "--global-rate=${toString cfg.globalRateBps}"
|
|
|
|
++ optional (cfg.perSessionRateBps != null) "--per-session-rate=${toString cfg.perSessionRateBps}"
|
|
|
|
++ cfg.extraOptions;
|
|
|
|
in {
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
options.services.syncthing.relay = {
|
2022-08-28 20:18:44 +01:00
|
|
|
enable = mkEnableOption (lib.mdDoc "Syncthing relay service");
|
2018-11-17 14:02:00 +00:00
|
|
|
|
|
|
|
listenAddress = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "";
|
|
|
|
example = "1.2.3.4";
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Address to listen on for relay traffic.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
port = mkOption {
|
|
|
|
type = types.port;
|
|
|
|
default = 22067;
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Port to listen on for relay traffic. This port should be added to
|
2022-07-28 22:19:15 +01:00
|
|
|
`networking.firewall.allowedTCPPorts`.
|
2018-11-17 14:02:00 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
statusListenAddress = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "";
|
|
|
|
example = "1.2.3.4";
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Address to listen on for serving the relay status API.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
statusPort = mkOption {
|
|
|
|
type = types.port;
|
|
|
|
default = 22070;
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Port to listen on for serving the relay status API. This port should be
|
2022-07-28 22:19:15 +01:00
|
|
|
added to `networking.firewall.allowedTCPPorts`.
|
2018-11-17 14:02:00 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
pools = mkOption {
|
|
|
|
type = types.nullOr (types.listOf types.str);
|
|
|
|
default = null;
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Relay pools to join. If null, uses the default global pool.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
providedBy = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "";
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Human-readable description of the provider of the relay (you).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
globalRateBps = mkOption {
|
|
|
|
type = types.nullOr types.ints.positive;
|
|
|
|
default = null;
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Global bandwidth rate limit in bytes per second.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
perSessionRateBps = mkOption {
|
|
|
|
type = types.nullOr types.ints.positive;
|
|
|
|
default = null;
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Per session bandwidth rate limit in bytes per second.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
extraOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [];
|
2022-07-28 22:19:15 +01:00
|
|
|
description = lib.mdDoc ''
|
2018-11-17 14:02:00 +00:00
|
|
|
Extra command line arguments to pass to strelaysrv.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
systemd.services.syncthing-relay = {
|
|
|
|
description = "Syncthing relay service";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
after = [ "network.target" ];
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
DynamicUser = true;
|
|
|
|
StateDirectory = baseNameOf dataDirectory;
|
|
|
|
|
|
|
|
Restart = "on-failure";
|
|
|
|
ExecStart = "${pkgs.syncthing-relay}/bin/strelaysrv ${concatStringsSep " " relayOptions}";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|