2014-05-05 18:58:51 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
2014-03-29 00:40:30 +00:00
|
|
|
|
2014-05-05 18:58:51 +00:00
|
|
|
with lib;
|
2014-03-29 00:40:30 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
ts3 = pkgs.teamspeak_server;
|
|
|
|
cfg = config.services.teamspeak3;
|
|
|
|
user = "teamspeak";
|
|
|
|
group = "teamspeak";
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
2016-05-12 05:10:17 +00:00
|
|
|
|
2014-03-29 00:40:30 +00:00
|
|
|
###### interface
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
services.teamspeak3 = {
|
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Whether to run the Teamspeak3 voice communication server daemon.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
dataDir = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/var/lib/teamspeak3-server";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Directory to store TS3 database and other state/data files.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
logPath = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/var/log/teamspeak3-server/";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Directory to store log files in.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
voiceIP = mkOption {
|
2018-10-20 12:09:41 +00:00
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
2021-11-04 02:30:24 +00:00
|
|
|
example = "[::]";
|
2014-03-29 00:40:30 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
IP on which the server instance will listen for incoming voice connections. Defaults to any IP.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
defaultVoicePort = mkOption {
|
2023-12-06 16:08:29 +00:00
|
|
|
type = types.port;
|
2014-03-29 00:40:30 +00:00
|
|
|
default = 9987;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Default UDP port for clients to connect to virtual servers - used for first virtual server, subsequent ones will open on incrementing port numbers by default.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
fileTransferIP = mkOption {
|
2018-10-20 12:09:41 +00:00
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
2021-11-04 02:30:24 +00:00
|
|
|
example = "[::]";
|
2014-03-29 00:40:30 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
IP on which the server instance will listen for incoming file transfer connections. Defaults to any IP.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
fileTransferPort = mkOption {
|
2023-12-06 16:08:29 +00:00
|
|
|
type = types.port;
|
2014-03-29 00:40:30 +00:00
|
|
|
default = 30033;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
TCP port opened for file transfers.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
queryIP = mkOption {
|
2018-10-20 12:09:41 +00:00
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
|
|
|
example = "0.0.0.0";
|
2014-03-29 00:40:30 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
IP on which the server instance will listen for incoming ServerQuery connections. Defaults to any IP.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
queryPort = mkOption {
|
2023-12-06 16:08:29 +00:00
|
|
|
type = types.port;
|
2014-03-29 00:40:30 +00:00
|
|
|
default = 10011;
|
|
|
|
description = lib.mdDoc ''
|
2023-12-06 16:08:29 +00:00
|
|
|
TCP port opened for ServerQuery connections using the raw telnet protocol.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
querySshPort = mkOption {
|
|
|
|
type = types.port;
|
|
|
|
default = 10022;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
TCP port opened for ServerQuery connections using the SSH protocol.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
queryHttpPort = mkOption {
|
|
|
|
type = types.port;
|
|
|
|
default = 10080;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
TCP port opened for ServerQuery connections using the HTTP protocol.
|
2014-03-29 00:40:30 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-11-04 02:30:24 +00:00
|
|
|
openFirewall = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = lib.mdDoc "Open ports in the firewall for the TeamSpeak3 server.";
|
|
|
|
};
|
|
|
|
|
|
|
|
openFirewallServerQuery = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = lib.mdDoc "Open ports in the firewall for the TeamSpeak3 serverquery (administration) system. Requires openFirewall.";
|
|
|
|
};
|
|
|
|
|
2014-03-29 00:40:30 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
2016-05-09 05:53:27 +00:00
|
|
|
config = mkIf cfg.enable {
|
|
|
|
users.users.teamspeak = {
|
|
|
|
description = "Teamspeak3 voice communication server daemon";
|
|
|
|
group = group;
|
|
|
|
uid = config.ids.uids.teamspeak;
|
|
|
|
home = cfg.dataDir;
|
|
|
|
createHome = true;
|
|
|
|
};
|
2014-03-29 00:40:30 +00:00
|
|
|
|
2016-05-09 05:53:27 +00:00
|
|
|
users.groups.teamspeak = {
|
|
|
|
gid = config.ids.gids.teamspeak;
|
|
|
|
};
|
2014-03-29 00:40:30 +00:00
|
|
|
|
2019-02-24 13:16:35 +00:00
|
|
|
systemd.tmpfiles.rules = [
|
|
|
|
"d '${cfg.logPath}' - ${user} ${group} - -"
|
|
|
|
];
|
|
|
|
|
2021-11-04 02:30:24 +00:00
|
|
|
networking.firewall = mkIf cfg.openFirewall {
|
2023-12-06 16:08:29 +00:00
|
|
|
allowedTCPPorts = [ cfg.fileTransferPort ] ++ (map (port:
|
|
|
|
mkIf cfg.openFirewallServerQuery port
|
|
|
|
) [cfg.queryPort cfg.querySshPort cfg.queryHttpPort]);
|
2021-11-04 02:30:24 +00:00
|
|
|
# subsequent vServers will use the incremented voice port, let's just open the next 10
|
|
|
|
allowedUDPPortRanges = [ { from = cfg.defaultVoicePort; to = cfg.defaultVoicePort + 10; } ];
|
|
|
|
};
|
|
|
|
|
2016-05-09 05:53:27 +00:00
|
|
|
systemd.services.teamspeak3-server = {
|
|
|
|
description = "Teamspeak3 voice communication server daemon";
|
|
|
|
after = [ "network.target" ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = ''
|
|
|
|
${ts3}/bin/ts3server \
|
2023-12-06 16:08:29 +00:00
|
|
|
dbsqlpath=${ts3}/lib/teamspeak/sql/ \
|
|
|
|
logpath=${cfg.logPath} \
|
|
|
|
license_accepted=1 \
|
2018-10-20 12:09:41 +00:00
|
|
|
default_voice_port=${toString cfg.defaultVoicePort} \
|
|
|
|
filetransfer_port=${toString cfg.fileTransferPort} \
|
2023-12-06 16:08:29 +00:00
|
|
|
query_port=${toString cfg.queryPort} \
|
|
|
|
query_ssh_port=${toString cfg.querySshPort} \
|
|
|
|
query_http_port=${toString cfg.queryHttpPort} \
|
|
|
|
${optionalString (cfg.voiceIP != null) "voice_ip=${cfg.voiceIP}"} \
|
|
|
|
${optionalString (cfg.fileTransferIP != null) "filetransfer_ip=${cfg.fileTransferIP}"} \
|
2018-10-20 12:09:41 +00:00
|
|
|
${optionalString (cfg.queryIP != null) "query_ip=${cfg.queryIP}"} \
|
2023-12-06 16:08:29 +00:00
|
|
|
${optionalString (cfg.queryIP != null) "query_ssh_ip=${cfg.queryIP}"} \
|
|
|
|
${optionalString (cfg.queryIP != null) "query_http_ip=${cfg.queryIP}"} \
|
2016-05-12 05:10:17 +00:00
|
|
|
'';
|
2016-05-09 05:53:27 +00:00
|
|
|
WorkingDirectory = cfg.dataDir;
|
|
|
|
User = user;
|
|
|
|
Group = group;
|
2022-09-03 12:52:59 +00:00
|
|
|
Restart = "on-failure";
|
2014-03-29 00:40:30 +00:00
|
|
|
};
|
2016-05-09 05:53:27 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = with lib.maintainers; [ arobyn ];
|
2014-03-29 00:40:30 +00:00
|
|
|
}
|