96 lines
2.8 KiB
Nix
96 lines
2.8 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
let
|
|
inherit (lib) generators literalExample mkEnableOption mkIf mkOption recursiveUpdate types;
|
|
cfg = config.services.zeronet;
|
|
dataDir = "/var/lib/zeronet";
|
|
configFile = pkgs.writeText "zeronet.conf" (generators.toINI {} (recursiveUpdate defaultSettings cfg.settings));
|
|
|
|
defaultSettings = {
|
|
global = {
|
|
data_dir = dataDir;
|
|
log_dir = dataDir;
|
|
ui_port = cfg.port;
|
|
fileserver_port = cfg.fileserverPort;
|
|
tor = if !cfg.tor then "disable" else if cfg.torAlways then "always" else "enable";
|
|
};
|
|
};
|
|
in with lib; {
|
|
options.services.zeronet = {
|
|
enable = mkEnableOption "zeronet";
|
|
|
|
settings = mkOption {
|
|
type = with types; attrsOf (oneOf [ str int bool (listOf str) ]);
|
|
default = {};
|
|
example = literalExample "global.tor = enable;";
|
|
|
|
description = ''
|
|
<filename>zeronet.conf</filename> configuration. Refer to
|
|
<link xlink:href="https://zeronet.readthedocs.io/en/latest/faq/#is-it-possible-to-use-a-configuration-file"/>
|
|
for details on supported values;
|
|
'';
|
|
};
|
|
|
|
port = mkOption {
|
|
type = types.int;
|
|
default = 43110;
|
|
example = 43110;
|
|
description = "Optional zeronet web UI port.";
|
|
};
|
|
|
|
fileserverPort = mkOption {
|
|
# Not optional: when absent zeronet tries to write one to the
|
|
# read-only config file and crashes
|
|
type = types.int;
|
|
default = 12261;
|
|
example = 12261;
|
|
description = "Zeronet fileserver port.";
|
|
};
|
|
|
|
tor = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = "Use TOR for zeronet traffic where possible.";
|
|
};
|
|
|
|
torAlways = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = "Use TOR for all zeronet traffic.";
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
services.tor = mkIf cfg.tor {
|
|
enable = true;
|
|
controlPort = 9051;
|
|
|
|
extraConfig = ''
|
|
CacheDirectoryGroupReadable 1
|
|
CookieAuthentication 1
|
|
CookieAuthFileGroupReadable 1
|
|
'';
|
|
};
|
|
|
|
systemd.services.zeronet = {
|
|
description = "zeronet";
|
|
after = [ "network.target" (optionalString cfg.tor "tor.service") ];
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
User = "zeronet";
|
|
DynamicUser = true;
|
|
StateDirectory = "zeronet";
|
|
SupplementaryGroups = mkIf cfg.tor [ "tor" ];
|
|
ExecStart = "${pkgs.zeronet}/bin/zeronet --config_file ${configFile}";
|
|
};
|
|
};
|
|
};
|
|
|
|
imports = [
|
|
(mkRemovedOptionModule [ "services" "zeronet" "dataDir" ] "Zeronet will store data by default in /var/lib/zeronet")
|
|
(mkRemovedOptionModule [ "services" "zeronet" "logDir" ] "Zeronet will log by default in /var/lib/zeronet")
|
|
];
|
|
|
|
meta.maintainers = with maintainers; [ chiiruno ];
|
|
}
|