2011-04-27 15:16:33 +02:00
|
|
|
{ config, pkgs, ... }:
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
with pkgs.lib;
|
2009-03-06 13:25:48 +01:00
|
|
|
|
|
|
|
let
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
cfg = config.services.gw6c;
|
|
|
|
|
2011-04-27 16:03:46 +02:00
|
|
|
gw6cService = pkgs.stdenv.mkDerivation {
|
|
|
|
name = "gw6c-service";
|
|
|
|
inherit (pkgs) gw6c coreutils procps upstart iputils gnused gnugrep seccure;
|
|
|
|
|
|
|
|
inherit (cfg) username password keepAlive everPing;
|
|
|
|
|
|
|
|
gw6server = cfg.server;
|
|
|
|
authMethod = if cfg.username == "" then "anonymous" else "any";
|
|
|
|
gw6dir = pkgs.gw6c;
|
|
|
|
|
|
|
|
pingBefore = if cfg.waitPingableBroker then "true" else "";
|
|
|
|
|
|
|
|
pubkey = config.security.seccureKeys.public;
|
|
|
|
privkey = config.security.seccureKeys.private;
|
|
|
|
|
|
|
|
buildCommand =
|
|
|
|
''
|
|
|
|
mkdir -p $out/bin $out/conf
|
|
|
|
|
|
|
|
mkdir conf
|
|
|
|
chmod 0700 conf
|
|
|
|
touch conf/raw
|
|
|
|
chmod 0700 conf/raw
|
|
|
|
|
|
|
|
substituteAll ${./gw6c.conf} conf/raw
|
|
|
|
$seccure/bin/seccure-encrypt "$(cat $pubkey)" -i conf/raw -o $out/conf/gw6c.conf
|
|
|
|
substituteAll ${./control.in} $out/bin/control
|
|
|
|
chmod a+x $out/bin/control
|
|
|
|
'';
|
2009-10-12 18:36:19 +02:00
|
|
|
};
|
2011-04-27 16:03:46 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
###### interface
|
2009-03-06 13:25:48 +01:00
|
|
|
|
|
|
|
options = {
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
services.gw6c = {
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
enable = mkOption {
|
|
|
|
default = false;
|
|
|
|
description = "
|
|
|
|
Whether to enable Gateway6 client (IPv6 tunnel).
|
|
|
|
";
|
2009-03-06 13:25:48 +01:00
|
|
|
};
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
autorun = mkOption {
|
|
|
|
default = true;
|
|
|
|
description = "
|
2011-09-14 20:20:50 +02:00
|
|
|
Switch to false to create upstart-job and configuration,
|
2009-10-12 18:36:19 +02:00
|
|
|
but not run it automatically
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
username = mkOption {
|
|
|
|
default = "";
|
|
|
|
description = "
|
|
|
|
Your Gateway6 login name, if any.
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
password = mkOption {
|
|
|
|
default = "";
|
|
|
|
description = "
|
|
|
|
Your Gateway6 password, if any.
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
server = mkOption {
|
|
|
|
default = "anon.freenet6.net";
|
|
|
|
example = "broker.freenet6.net";
|
|
|
|
description = "
|
|
|
|
Used Gateway6 server.
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
keepAlive = mkOption {
|
|
|
|
default = "30";
|
|
|
|
example = "2";
|
|
|
|
description = "
|
|
|
|
Gateway6 keep-alive period.
|
|
|
|
";
|
2009-03-06 13:25:48 +01:00
|
|
|
};
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
everPing = mkOption {
|
|
|
|
default = "1000000";
|
|
|
|
example = "2";
|
|
|
|
description = "
|
|
|
|
Gateway6 manual ping period.
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
waitPingableBroker = mkOption {
|
|
|
|
default = true;
|
|
|
|
example = false;
|
|
|
|
description = "
|
|
|
|
Whether to wait until tunnel broker returns ICMP echo.
|
|
|
|
";
|
|
|
|
};
|
|
|
|
|
2009-03-06 13:25:48 +01:00
|
|
|
};
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
security.seccureKeys = {
|
|
|
|
|
|
|
|
# !!! It's not clear to me (ED) what additional security this
|
|
|
|
# provides. Passwords shouldn't be in configuration.nix,
|
|
|
|
# period. You could just place the password in
|
|
|
|
# /var/blah/password or whatever.
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
public = mkOption {
|
|
|
|
default = /var/elliptic-keys/public;
|
|
|
|
description = "
|
|
|
|
Public key. Make it path argument, so it is copied into store and
|
2011-09-14 20:20:50 +02:00
|
|
|
hashed.
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
The key is used to encrypt Gateway 6 configuration in store, as it
|
2011-09-14 20:20:50 +02:00
|
|
|
contains a password for external service. Unfortunately,
|
|
|
|
derivation file should be protected by other means. For example,
|
2009-10-12 18:36:19 +02:00
|
|
|
nix-http-export.cgi will happily export any non-derivation path,
|
|
|
|
but not a derivation.
|
|
|
|
";
|
|
|
|
};
|
2009-03-06 13:25:48 +01:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
private = mkOption {
|
|
|
|
default = "/var/elliptic-keys/private";
|
|
|
|
description = "
|
|
|
|
Private key. Make it string argument, so it is not copied into store.
|
|
|
|
";
|
|
|
|
};
|
2009-03-06 13:25:48 +01:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
};
|
2009-03-06 13:25:48 +01:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
};
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
|
|
|
|
###### implementation
|
2009-03-06 13:25:48 +01:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
config = mkIf cfg.enable {
|
2009-03-06 13:25:48 +01:00
|
|
|
|
2009-10-12 20:09:34 +02:00
|
|
|
jobs.gw6c =
|
2009-10-12 18:36:19 +02:00
|
|
|
{ description = "Gateway6 client";
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2009-11-06 23:19:17 +01:00
|
|
|
startOn = if cfg.autorun then "started network-interfaces" else "";
|
|
|
|
stopOn = "stopping network-interfaces";
|
2007-07-09 13:21:04 +02:00
|
|
|
|
2009-10-12 18:36:19 +02:00
|
|
|
exec = "${gw6cService}/bin/control start";
|
|
|
|
};
|
2007-07-09 13:21:04 +02:00
|
|
|
|
2012-03-04 13:58:14 +01:00
|
|
|
networking = {
|
|
|
|
enableIPv6 = true;
|
|
|
|
interfaceJobs = optional cfg.autorun config.jobs.gw6c;
|
|
|
|
};
|
|
|
|
|
2009-03-06 13:25:48 +01:00
|
|
|
};
|
2009-10-12 18:36:19 +02:00
|
|
|
|
2007-07-09 13:21:04 +02:00
|
|
|
}
|