miredo: init at 1.2.6
This commit is contained in:
parent
61027b7fce
commit
06b372f24f
@ -392,6 +392,7 @@
|
|||||||
./services/networking/minidlna.nix
|
./services/networking/minidlna.nix
|
||||||
./services/networking/miniupnpd.nix
|
./services/networking/miniupnpd.nix
|
||||||
./services/networking/mosquitto.nix
|
./services/networking/mosquitto.nix
|
||||||
|
./services/networking/miredo.nix
|
||||||
./services/networking/mstpd.nix
|
./services/networking/mstpd.nix
|
||||||
./services/networking/murmur.nix
|
./services/networking/murmur.nix
|
||||||
./services/networking/namecoind.nix
|
./services/networking/namecoind.nix
|
||||||
|
93
nixos/modules/services/networking/miredo.nix
Normal file
93
nixos/modules/services/networking/miredo.nix
Normal file
@ -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";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
34
pkgs/tools/networking/miredo/default.nix
Normal file
34
pkgs/tools/networking/miredo/default.nix
Normal file
@ -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;
|
||||||
|
};
|
||||||
|
}
|
@ -2801,6 +2801,8 @@ in
|
|||||||
|
|
||||||
minixml = callPackage ../development/libraries/minixml { };
|
minixml = callPackage ../development/libraries/minixml { };
|
||||||
|
|
||||||
|
miredo = callPackage ../tools/networking/miredo { };
|
||||||
|
|
||||||
mjpegtoolsFull = callPackage ../tools/video/mjpegtools { };
|
mjpegtoolsFull = callPackage ../tools/video/mjpegtools { };
|
||||||
|
|
||||||
mjpegtools = self.mjpegtoolsFull.override {
|
mjpegtools = self.mjpegtoolsFull.override {
|
||||||
|
Loading…
Reference in New Issue
Block a user