parent
61027b7fce
commit
06b372f24f
@ -0,0 +1,93 @@ |
||||
{ config, lib, pkgs, ... }: |
||||
|
||||
with lib; |
||||
|
||||
let |
||||
cfg = config.services.miredo; |
||||
pidFile = "/run/miredo.pid"; |
||||
miredoConf = pkgs.writeText "miredo.conf" '' |
||||
InterfaceName ${cfg.interfaceName} |
||||
ServerAddress ${cfg.serverAddress} |
||||
${optionalString (cfg.bindAddress != null) "BindAddress ${cfg.bindAddress}"} |
||||
${optionalString (cfg.bindPort != null) "BindPort ${cfg.bindPort}"} |
||||
''; |
||||
in |
||||
{ |
||||
|
||||
###### interface |
||||
|
||||
options = { |
||||
|
||||
services.miredo = { |
||||
|
||||
enable = mkEnableOption "Whether miredo should be run on startup."; |
||||
|
||||
package = mkOption { |
||||
type = types.package; |
||||
default = pkgs.miredo; |
||||
defaultText = "pkgs.miredo"; |
||||
description = '' |
||||
The package to use for the miredo daemon's binary. |
||||
''; |
||||
}; |
||||
|
||||
serverAddress = mkOption { |
||||
default = "teredo.remlab.net"; |
||||
type = types.str; |
||||
description = '' |
||||
The hostname or primary IPv4 address of the Teredo server. |
||||
This setting is required if Miredo runs as a Teredo client. |
||||
"teredo.remlab.net" is an experimental service for testing only. |
||||
Please use another server for production and/or large scale deployments. |
||||
''; |
||||
}; |
||||
|
||||
interfaceName = mkOption { |
||||
default = "teredo"; |
||||
type = types.str; |
||||
description = '' |
||||
Name of the network tunneling interface. |
||||
''; |
||||
}; |
||||
|
||||
bindAddress = mkOption { |
||||
default = null; |
||||
type = types.nullOr types.str; |
||||
description = '' |
||||
Depending on the local firewall/NAT rules, you might need to force |
||||
Miredo to use a fixed UDP port and or IPv4 address. |
||||
''; |
||||
}; |
||||
|
||||
bindPort = mkOption { |
||||
default = null; |
||||
type = types.nullOr types.str; |
||||
description = '' |
||||
Depending on the local firewall/NAT rules, you might need to force |
||||
Miredo to use a fixed UDP port and or IPv4 address. |
||||
''; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
|
||||
###### implementation |
||||
|
||||
config = mkIf cfg.enable { |
||||
|
||||
systemd.services.miredo = { |
||||
wantedBy = [ "multi-user.target" ]; |
||||
after = [ "network.target" ]; |
||||
description = "Teredo IPv6 Tunneling Daemon"; |
||||
serviceConfig = { |
||||
Restart = "always"; |
||||
RestartSec = "5s"; |
||||
ExecStartPre = "${cfg.package}/bin/miredo-checkconf -f ${miredoConf}"; |
||||
ExecStart = "${cfg.package}/bin/miredo -c ${miredoConf} -p ${pidFile} -f"; |
||||
ExecReload = "/bin/kill -HUP $MAINPID"; |
||||
}; |
||||
}; |
||||
|
||||
}; |
||||
|
||||
} |
@ -0,0 +1,34 @@ |
||||
{ stdenv, fetchurl, nettools, iproute, judy }: |
||||
|
||||
stdenv.mkDerivation rec { |
||||
version = "1.2.6"; |
||||
name = "miredo-${version}"; |
||||
|
||||
buildInputs = [ judy ]; |
||||
|
||||
src = fetchurl { |
||||
url = "http://www.remlab.net/files/miredo/miredo-${version}.tar.xz"; |
||||
sha256 = "0j9ilig570snbmj48230hf7ms8kvcwi2wblycqrmhh85lksd49ps"; |
||||
}; |
||||
|
||||
postPatch = '' |
||||
substituteInPlace misc/client-hook.bsd \ |
||||
--replace '/sbin/route' '${nettools}/bin/route' \ |
||||
--replace '/sbin/ifconfig' '${nettools}/bin/ifconfig' |
||||
substituteInPlace misc/client-hook.iproute --replace '/sbin/ip' '${iproute}/bin/ip' |
||||
''; |
||||
|
||||
configureFlags = [ "--with-Judy" ]; |
||||
|
||||
postInstall = '' |
||||
rm -rf $out/lib/systemd $out/var $out/etc/miredo/miredo.conf |
||||
''; |
||||
|
||||
meta = with stdenv.lib; { |
||||
description = "Teredo IPv6 Tunneling Daemon"; |
||||
homepage = http://www.remlab.net/miredo/; |
||||
license = licenses.gpl2; |
||||
maintainers = [ maintainers.volth ]; |
||||
platforms = platforms.unix; |
||||
}; |
||||
} |
Loading…
Reference in new issue