commit
d0fdad5f36
@ -173,6 +173,7 @@
|
|||||||
peerflix = 163;
|
peerflix = 163;
|
||||||
chronos = 164;
|
chronos = 164;
|
||||||
gitlab = 165;
|
gitlab = 165;
|
||||||
|
tox-bootstrapd = 166;
|
||||||
|
|
||||||
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
||||||
|
|
||||||
|
@ -286,6 +286,7 @@
|
|||||||
./services/networking/tcpcrypt.nix
|
./services/networking/tcpcrypt.nix
|
||||||
./services/networking/teamspeak3.nix
|
./services/networking/teamspeak3.nix
|
||||||
./services/networking/tftpd.nix
|
./services/networking/tftpd.nix
|
||||||
|
./services/networking/tox-bootstrapd.nix
|
||||||
./services/networking/unbound.nix
|
./services/networking/unbound.nix
|
||||||
./services/networking/unifi.nix
|
./services/networking/unifi.nix
|
||||||
./services/networking/vsftpd.nix
|
./services/networking/vsftpd.nix
|
||||||
|
80
nixos/modules/services/networking/tox-bootstrapd.nix
Normal file
80
nixos/modules/services/networking/tox-bootstrapd.nix
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
home = "/var/lib/tox-bootstrapd";
|
||||||
|
PIDFile = "${home}/pid";
|
||||||
|
|
||||||
|
pkg = pkgs.libtoxcore;
|
||||||
|
cfg = config.services.toxBootstrapd;
|
||||||
|
cfgFile = builtins.toFile "tox-bootstrapd.conf"
|
||||||
|
''
|
||||||
|
port = ${toString cfg.port}
|
||||||
|
keys_file_path = "${home}/keys"
|
||||||
|
pid_file_path = "${PIDFile}"
|
||||||
|
${cfg.extraConfig}
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options =
|
||||||
|
{ services.toxBootstrapd =
|
||||||
|
{ enable = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description =
|
||||||
|
''
|
||||||
|
Whether to enable the Tox DHT boostrap daemon.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
port = mkOption {
|
||||||
|
type = types.int;
|
||||||
|
default = 33445;
|
||||||
|
description = "Listening port (UDP).";
|
||||||
|
};
|
||||||
|
|
||||||
|
keysFile = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "${home}/keys";
|
||||||
|
description = "Node key file.";
|
||||||
|
};
|
||||||
|
|
||||||
|
extraConfig = mkOption {
|
||||||
|
type = types.lines;
|
||||||
|
default = "";
|
||||||
|
description =
|
||||||
|
''
|
||||||
|
Configuration for boostrap daemon.
|
||||||
|
See <link xlink:href="https://github.com/irungentoo/toxcore/blob/master/other/bootstrap_daemon/tox-bootstrapd.conf"/>
|
||||||
|
and <link xlink:href="http://wiki.tox.im/Nodes"/>.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf config.services.toxBootstrapd.enable {
|
||||||
|
|
||||||
|
users.extraUsers = singleton
|
||||||
|
{ name = "tox-bootstrapd";
|
||||||
|
uid = config.ids.uids.tox-bootstrapd;
|
||||||
|
description = "Tox bootstrap daemon user";
|
||||||
|
inherit home;
|
||||||
|
createHome = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.services.tox-bootstrapd = {
|
||||||
|
description = "Tox DHT bootstrap daemon";
|
||||||
|
after = [ "network.target" ];
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
serviceConfig =
|
||||||
|
{ ExecStart = "${pkg}/bin/tox-bootstrapd ${cfgFile}";
|
||||||
|
Type = "forking";
|
||||||
|
inherit PIDFile;
|
||||||
|
User = "tox-bootstrapd";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
@ -1,17 +1,18 @@
|
|||||||
{ stdenv, fetchurl, autoconf, libtool, automake, libsodium, ncurses, libopus
|
{ stdenv, fetchFromGitHub, autoconf, libtool, automake, libsodium, ncurses, libopus
|
||||||
, libvpx, check, libconfig, pkgconfig }:
|
, libvpx, check, libconfig, pkgconfig }:
|
||||||
|
|
||||||
let
|
let
|
||||||
version = "f6b3e6e8fe98d2457827ac6da944e715f008a08a";
|
version = "f6b3e6e8fe98d2457827ac6da944e715f008a08a";
|
||||||
date = "20141203";
|
date = "20141219";
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "tox-core-${date}-${version}";
|
name = "tox-core-${date}-${builtins.substring 0 7 version}";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchFromGitHub {
|
||||||
url = "https://github.com/irungentoo/toxcore/tarball/${version}";
|
owner = "irungentoo";
|
||||||
name = "${name}.tar.gz";
|
repo = "toxcore";
|
||||||
sha256 = "1zsx7saqs25vva3pp0bw31yqzrn40fx84w42ig6fiv723k9gpdzy";
|
rev = version;
|
||||||
|
sha256 = "1wd817kix3zjyzzb68jz02iir3z4y5k5p40dgl7a29757yb9m608";
|
||||||
};
|
};
|
||||||
|
|
||||||
NIX_LDFLAGS = "-lgcc_s";
|
NIX_LDFLAGS = "-lgcc_s";
|
||||||
@ -33,6 +34,7 @@ stdenv.mkDerivation rec {
|
|||||||
"--with-libsodium-headers=${libsodium}/include"
|
"--with-libsodium-headers=${libsodium}/include"
|
||||||
"--with-libsodium-libs=${libsodium}/lib"
|
"--with-libsodium-libs=${libsodium}/lib"
|
||||||
"--enable-ntox"
|
"--enable-ntox"
|
||||||
|
"--enable-daemon"
|
||||||
];
|
];
|
||||||
|
|
||||||
buildInputs = [
|
buildInputs = [
|
||||||
|
Loading…
x
Reference in New Issue
Block a user