2014-04-14 15:26:48 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
2013-02-15 02:50:41 +00:00
|
|
|
|
2014-04-14 15:26:48 +01:00
|
|
|
with lib;
|
2013-02-15 02:50:41 +00:00
|
|
|
|
|
|
|
let cfg = config.services.networking.websockify; in {
|
|
|
|
options = {
|
|
|
|
services.networking.websockify = {
|
2020-08-07 14:43:58 +01:00
|
|
|
enable = mkOption {
|
2013-02-18 16:51:33 +00:00
|
|
|
description = "Whether to enable websockify to forward websocket connections to TCP connections.";
|
2013-02-15 02:50:41 +00:00
|
|
|
|
2020-08-07 14:43:58 +01:00
|
|
|
default = false;
|
2013-02-15 02:50:41 +00:00
|
|
|
|
2020-08-07 14:43:58 +01:00
|
|
|
type = types.bool;
|
2013-02-15 02:50:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
sslCert = mkOption {
|
2013-02-18 16:51:33 +00:00
|
|
|
description = "Path to the SSL certificate.";
|
2013-02-15 02:50:41 +00:00
|
|
|
type = types.path;
|
|
|
|
};
|
|
|
|
|
|
|
|
sslKey = mkOption {
|
2013-02-18 16:51:33 +00:00
|
|
|
description = "Path to the SSL key.";
|
2013-02-15 02:50:41 +00:00
|
|
|
default = cfg.sslCert;
|
2021-10-03 17:06:03 +01:00
|
|
|
defaultText = literalExpression "config.services.networking.websockify.sslCert";
|
2013-02-15 02:50:41 +00:00
|
|
|
type = types.path;
|
|
|
|
};
|
|
|
|
|
|
|
|
portMap = mkOption {
|
2013-02-18 16:51:33 +00:00
|
|
|
description = "Ports to map by default.";
|
2013-02-15 02:50:41 +00:00
|
|
|
default = {};
|
|
|
|
type = types.attrsOf types.int;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
systemd.services."websockify@" = {
|
2013-02-18 16:55:10 +00:00
|
|
|
description = "Service to forward websocket connections to TCP connections (from port:to port %I)";
|
2013-02-15 02:50:41 +00:00
|
|
|
script = ''
|
|
|
|
IFS=':' read -a array <<< "$1"
|
|
|
|
${pkgs.pythonPackages.websockify}/bin/websockify --ssl-only \
|
|
|
|
--cert=${cfg.sslCert} --key=${cfg.sslKey} 0.0.0.0:''${array[0]} 0.0.0.0:''${array[1]}
|
|
|
|
'';
|
|
|
|
scriptArgs = "%i";
|
|
|
|
};
|
|
|
|
|
2019-08-13 22:52:01 +01:00
|
|
|
systemd.targets.default-websockify = {
|
2013-02-18 16:55:10 +00:00
|
|
|
description = "Target to start all default websockify@ services";
|
2019-08-13 22:52:01 +01:00
|
|
|
unitConfig.X-StopOnReconfiguration = true;
|
2013-02-15 02:50:41 +00:00
|
|
|
wants = mapAttrsToList (name: value: "websockify@${name}:${toString value}.service") cfg.portMap;
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|