Bruno BELANYI
9f7472222c
Don't use it in wireguard to keep it consistent, as only half the commands could use it.
51 lines
1.1 KiB
Nix
51 lines
1.1 KiB
Nix
# A nice UI for various torrent clients
|
|
{ config, lib, pkgs, ... }:
|
|
let
|
|
cfg = config.my.services.flood;
|
|
in
|
|
{
|
|
options.my.services.flood = with lib; {
|
|
enable = mkEnableOption "Flood UI";
|
|
|
|
port = mkOption {
|
|
type = types.port;
|
|
default = 9092;
|
|
example = 3000;
|
|
description = "Internal port for Flood UI";
|
|
};
|
|
|
|
stateDir = mkOption {
|
|
type = types.str;
|
|
default = "flood";
|
|
example = "floodUI";
|
|
description = "Directory under `/var/run` for storing Flood's files";
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
systemd.services.flood = {
|
|
description = "Flood torrent UI";
|
|
after = [ "network.target" ];
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
ExecStart = lib.concatStringsSep " " [
|
|
(lib.getExe pkgs.flood)
|
|
"--port ${builtins.toString cfg.port}"
|
|
"--rundir /var/lib/${cfg.stateDir}"
|
|
];
|
|
DynamicUser = true;
|
|
StateDirectory = cfg.stateDir;
|
|
ReadWritePaths = "";
|
|
};
|
|
};
|
|
|
|
my.services.nginx.virtualHosts = [
|
|
{
|
|
subdomain = "flood";
|
|
inherit (cfg) port;
|
|
}
|
|
];
|
|
};
|
|
}
|