2009-03-06 12:26:26 +00:00
|
|
|
{pkgs, config, ...}:
|
2008-09-04 20:28:02 +00:00
|
|
|
|
2009-03-06 12:26:26 +00:00
|
|
|
###### interface
|
|
|
|
let
|
|
|
|
inherit (pkgs.lib) mkOption mkIf;
|
2008-09-04 20:28:02 +00:00
|
|
|
|
2009-03-06 12:26:26 +00:00
|
|
|
options = {
|
|
|
|
services = {
|
|
|
|
gnunet = {
|
|
|
|
|
|
|
|
enable = mkOption {
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to run the GNUnet daemon. GNUnet is GNU's anonymous
|
|
|
|
peer-to-peer communication and file sharing framework.
|
|
|
|
'';
|
|
|
|
};
|
2008-09-04 20:28:02 +00:00
|
|
|
|
2009-03-06 12:26:26 +00:00
|
|
|
home = mkOption {
|
|
|
|
default = "/var/lib/gnunet";
|
|
|
|
description = ''
|
|
|
|
Directory where the GNUnet daemon will store its data.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
debug = mkOption {
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
When true, run in debug mode; gnunetd will not daemonize and
|
|
|
|
error messages will be written to stderr instead of a
|
|
|
|
logfile.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
logLevel = mkOption {
|
|
|
|
default = "ERROR";
|
|
|
|
example = "INFO";
|
|
|
|
description = ''
|
|
|
|
Log level of the deamon (see `gnunetd(1)' for details).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
hostLists = mkOption {
|
|
|
|
default = [
|
|
|
|
"http://gnunet.org/hostlist.php"
|
|
|
|
"http://gnunet.mine.nu:8081/hostlist"
|
|
|
|
"http://vserver1236.vserver-on.de/hostlist-074"
|
|
|
|
];
|
|
|
|
description = ''
|
|
|
|
URLs of host lists.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
applications = mkOption {
|
|
|
|
default = [ "advertising" "getoption" "fs" "stats" "traffic" ];
|
|
|
|
example = [ "chat" "fs" ];
|
|
|
|
description = ''
|
|
|
|
List of GNUnet applications supported by the daemon. Note that
|
|
|
|
`fs', which means "file sharing", is probably the one you want.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
transports = mkOption {
|
|
|
|
default = [ "udp" "tcp" "http" "nat" ];
|
|
|
|
example = [ "smtp" "http" ];
|
|
|
|
description = ''
|
|
|
|
List of transport methods used by the server.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
fileSharing = {
|
|
|
|
quota = mkOption {
|
|
|
|
default = 1024;
|
|
|
|
description = ''
|
|
|
|
Maximum file system usage (in MiB) for file sharing.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
activeMigration = mkOption {
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to allow active migration of content originating
|
|
|
|
from other nodes.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
load = {
|
|
|
|
maxNetDownBandwidth = mkOption {
|
|
|
|
default = 50000;
|
|
|
|
description = ''
|
|
|
|
Maximum bandwidth usage (in bits per second) for GNUnet
|
|
|
|
when downloading data.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
maxNetUpBandwidth = mkOption {
|
|
|
|
default = 50000;
|
|
|
|
description = ''
|
|
|
|
Maximum bandwidth usage (in bits per second) for GNUnet
|
|
|
|
when downloading data.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
hardNetUpBandwidth = mkOption {
|
|
|
|
default = 0;
|
|
|
|
description = ''
|
|
|
|
Hard bandwidth limit (in bits per second) when uploading
|
|
|
|
data.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
maxCPULoad = mkOption {
|
|
|
|
default = 100;
|
|
|
|
description = ''
|
|
|
|
Maximum CPU load (percentage) authorized for the GNUnet
|
|
|
|
daemon.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
interfaces = mkOption {
|
|
|
|
default = [ "eth0" ];
|
|
|
|
example = [ "wlan0" "eth1" ];
|
|
|
|
description = ''
|
|
|
|
List of network interfaces to use.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
extraOptions = mkOption {
|
|
|
|
default = "";
|
|
|
|
example = ''
|
|
|
|
[NETWORK]
|
|
|
|
INTERFACE = eth3
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Additional options that will be copied verbatim in `gnunetd.conf'.
|
|
|
|
See `gnunetd.conf(5)' for details.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
in
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
|
|
|
mkIf config.services.gnunet.enable {
|
|
|
|
require = [
|
|
|
|
options
|
2008-09-04 20:28:02 +00:00
|
|
|
];
|
|
|
|
|
2009-03-06 12:26:26 +00:00
|
|
|
users = {
|
|
|
|
extraUsers = [
|
|
|
|
{ name = "gnunetd";
|
2009-05-29 14:25:56 +00:00
|
|
|
uid = config.ids.uids.gnunetd;
|
2009-03-06 12:26:26 +00:00
|
|
|
description = "GNUnet Daemon User";
|
|
|
|
home = "/var/empty";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
extraJobs = [{
|
|
|
|
name = "gnunetd";
|
|
|
|
|
|
|
|
job =
|
|
|
|
with config.services.gnunet;
|
|
|
|
let
|
|
|
|
inherit (pkgs) lib gnunet;
|
|
|
|
configFile = pkgs.writeText "gnunetd.conf" ''
|
|
|
|
[PATHS]
|
|
|
|
GNUNETD_HOME = ${home}
|
|
|
|
|
|
|
|
[GNUNETD]
|
|
|
|
HOSTLISTURL = ${lib.concatStringsSep " " hostLists}
|
|
|
|
APPLICATIONS = ${lib.concatStringsSep " " applications}
|
|
|
|
TRANSPORTS = ${lib.concatStringsSep " " transports}
|
|
|
|
|
|
|
|
[LOAD]
|
|
|
|
MAXNETDOWNBPSTOTAL = ${toString load.maxNetDownBandwidth}
|
|
|
|
MAXNETUPBPSTOTAL = ${toString load.maxNetUpBandwidth}
|
|
|
|
HARDUPLIMIT = ${toString load.hardNetUpBandwidth}
|
|
|
|
MAXCPULOAD = ${toString load.maxCPULoad}
|
|
|
|
INTERFACES = ${lib.concatStringsSep " " load.interfaces}
|
|
|
|
|
|
|
|
[FS]
|
|
|
|
QUOTA = ${toString fileSharing.quota}
|
|
|
|
ACTIVEMIGRATION = ${if fileSharing.activeMigration then "YES" else "NO"}
|
|
|
|
|
|
|
|
[MODULES]
|
|
|
|
sqstore = sqstore_sqlite
|
|
|
|
dstore = dstore_sqlite
|
|
|
|
topology = topology_default
|
|
|
|
|
|
|
|
${extraOptions}
|
|
|
|
'';
|
|
|
|
in ''
|
|
|
|
description "The GNUnet Daemon"
|
|
|
|
|
|
|
|
start on network-interfaces/started
|
|
|
|
stop on network-interfaces/stop
|
|
|
|
|
|
|
|
start script
|
|
|
|
test -d "${home}" || \
|
|
|
|
( mkdir -m 755 -p "${home}" && chown -R gnunetd:users "${home}")
|
|
|
|
end script
|
2008-09-04 20:28:02 +00:00
|
|
|
|
2009-03-06 12:26:26 +00:00
|
|
|
respawn ${gnunet}/bin/gnunetd \
|
|
|
|
${if debug then "--debug" else "" } \
|
|
|
|
--user="gnunetd" \
|
|
|
|
--config="${configFile}" \
|
|
|
|
--log="${logLevel}"
|
|
|
|
'';
|
|
|
|
}];
|
|
|
|
};
|
2008-09-04 20:28:02 +00:00
|
|
|
}
|