forked from dan/liminix
extract pppoe/l2tp common code
This commit is contained in:
parent
c7bcfbfa34
commit
091d863710
modules/ppp
83
modules/ppp/common.nix
Normal file
83
modules/ppp/common.nix
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
{ writeAshScript, liminix, svc, lib, serviceFns, output-template }:
|
||||||
|
{
|
||||||
|
command,
|
||||||
|
name,
|
||||||
|
debug
|
||||||
|
, username,
|
||||||
|
password,
|
||||||
|
lcpEcho,
|
||||||
|
ppp-options,
|
||||||
|
dependencies ? []
|
||||||
|
} :
|
||||||
|
let
|
||||||
|
inherit (lib) optional optionals escapeShellArgs concatStringsSep;
|
||||||
|
inherit (liminix.services) longrun;
|
||||||
|
inherit (builtins) toJSON toString typeOf;
|
||||||
|
|
||||||
|
ip-up = writeAshScript "ip-up" {} ''
|
||||||
|
. ${serviceFns}
|
||||||
|
(in_outputs ${name}
|
||||||
|
echo $1 > ifname
|
||||||
|
echo $2 > tty
|
||||||
|
echo $3 > speed
|
||||||
|
echo $4 > address
|
||||||
|
echo $5 > peer-address
|
||||||
|
echo $DNS1 > ns1
|
||||||
|
echo $DNS2 > ns2
|
||||||
|
)
|
||||||
|
echo >/proc/self/fd/10
|
||||||
|
'';
|
||||||
|
ip6-up = writeAshScript "ip6-up" {} ''
|
||||||
|
. ${serviceFns}
|
||||||
|
(in_outputs ${name}
|
||||||
|
echo $4 > ipv6-address
|
||||||
|
echo $5 > ipv6-peer-address
|
||||||
|
)
|
||||||
|
echo >/proc/self/fd/10
|
||||||
|
'';
|
||||||
|
literal_or_output =
|
||||||
|
let v = o: ({
|
||||||
|
string = toJSON;
|
||||||
|
int = toJSON;
|
||||||
|
lambda = (o: "output(${toJSON (o "service")}, ${toJSON (o "path")})");
|
||||||
|
}.${typeOf o}) o;
|
||||||
|
in o: "{{ ${v o} }}";
|
||||||
|
|
||||||
|
ppp-options' =
|
||||||
|
["+ipv6" "noauth"]
|
||||||
|
++ optional debug "debug"
|
||||||
|
++ optionals (username != null) ["name" (literal_or_output username)]
|
||||||
|
++ optionals (password != null) ["password" (literal_or_output password)]
|
||||||
|
++ optional lcpEcho.adaptive "lcp-echo-adaptive"
|
||||||
|
++ optionals (lcpEcho.interval != null)
|
||||||
|
["lcp-echo-interval" (toString lcpEcho.interval)]
|
||||||
|
++ optionals (lcpEcho.failure != null)
|
||||||
|
["lcp-echo-failure" (toString lcpEcho.failure)]
|
||||||
|
++ ppp-options
|
||||||
|
++ ["ip-up-script" ip-up
|
||||||
|
"ipv6-up-script" ip6-up
|
||||||
|
"ipparam" name
|
||||||
|
"nodetach"
|
||||||
|
"usepeerdns"
|
||||||
|
"nodefaultroute"
|
||||||
|
"logfd" "2"
|
||||||
|
];
|
||||||
|
service = longrun {
|
||||||
|
inherit name;
|
||||||
|
run = ''
|
||||||
|
mkdir -p /run/${name}
|
||||||
|
chmod 0700 /run/${name}
|
||||||
|
in_outputs ${name}
|
||||||
|
echo ${escapeShellArgs ppp-options'} | ${output-template}/bin/output-template '{{' '}}' > /run/${name}/ppp-options
|
||||||
|
${command}
|
||||||
|
'';
|
||||||
|
notification-fd = 10;
|
||||||
|
timeout-up = if lcpEcho.failure != null
|
||||||
|
then (10 + lcpEcho.failure * lcpEcho.interval) * 1000
|
||||||
|
else 60 * 1000;
|
||||||
|
inherit dependencies;
|
||||||
|
};
|
||||||
|
in svc.secrets.subscriber.build {
|
||||||
|
watch = [ username password ];
|
||||||
|
inherit service;
|
||||||
|
}
|
@ -7,6 +7,7 @@
|
|||||||
writeAshScript,
|
writeAshScript,
|
||||||
writeText,
|
writeText,
|
||||||
xl2tpd,
|
xl2tpd,
|
||||||
|
callPackage
|
||||||
} :
|
} :
|
||||||
{ lns,
|
{ lns,
|
||||||
ppp-options,
|
ppp-options,
|
||||||
@ -16,58 +17,8 @@
|
|||||||
debug
|
debug
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (liminix.services) longrun;
|
|
||||||
inherit (lib) optional optionals escapeShellArgs concatStringsSep;
|
|
||||||
name = "${lns}.l2tp";
|
name = "${lns}.l2tp";
|
||||||
ip-up = writeAshScript "ip-up" {} ''
|
common = callPackage ./common.nix { inherit svc; };
|
||||||
. ${serviceFns}
|
|
||||||
(in_outputs ${name}
|
|
||||||
echo $1 > ifname
|
|
||||||
echo $2 > tty
|
|
||||||
echo $3 > speed
|
|
||||||
echo $4 > address
|
|
||||||
echo $5 > peer-address
|
|
||||||
echo $DNS1 > ns1
|
|
||||||
echo $DNS2 > ns2
|
|
||||||
)
|
|
||||||
echo >/proc/self/fd/10
|
|
||||||
'';
|
|
||||||
ip6-up = writeAshScript "ip6-up" {} ''
|
|
||||||
. ${serviceFns}
|
|
||||||
(in_outputs ${name}
|
|
||||||
echo $4 > ipv6-address
|
|
||||||
echo $5 > ipv6-peer-address
|
|
||||||
)
|
|
||||||
echo >/proc/self/fd/10
|
|
||||||
'';
|
|
||||||
|
|
||||||
literal_or_output =
|
|
||||||
let v = o: ({
|
|
||||||
string = builtins.toJSON;
|
|
||||||
int = builtins.toJSON;
|
|
||||||
lambda = (o: "output(${builtins.toJSON (o "service")}, ${builtins.toJSON (o "path")})");
|
|
||||||
}.${builtins.typeOf o}) o;
|
|
||||||
in o: "{{ ${v o} }}";
|
|
||||||
|
|
||||||
ppp-options' =
|
|
||||||
["+ipv6" "noauth"]
|
|
||||||
++ optional debug "debug"
|
|
||||||
++ optionals (username != null) ["name" (literal_or_output username)]
|
|
||||||
++ optionals (password != null) ["password" (literal_or_output password)]
|
|
||||||
++ optional lcpEcho.adaptive "lcp-echo-adaptive"
|
|
||||||
++ optionals (lcpEcho.interval != null)
|
|
||||||
["lcp-echo-interval" (builtins.toString lcpEcho.interval)]
|
|
||||||
++ optionals (lcpEcho.failure != null)
|
|
||||||
["lcp-echo-failure" (builtins.toString lcpEcho.failure)]
|
|
||||||
++ ppp-options
|
|
||||||
++ ["ip-up-script" ip-up
|
|
||||||
"ipv6-up-script" ip6-up
|
|
||||||
"ipparam" name
|
|
||||||
"nodetach"
|
|
||||||
"usepeerdns"
|
|
||||||
"nodefaultroute"
|
|
||||||
"logfd" "2"
|
|
||||||
];
|
|
||||||
|
|
||||||
conf = writeText "xl2tpd.conf" ''
|
conf = writeText "xl2tpd.conf" ''
|
||||||
[lac upstream]
|
[lac upstream]
|
||||||
@ -80,19 +31,10 @@ let
|
|||||||
max redials = 2 # this gives 1 actual retry, as xl2tpd can't count
|
max redials = 2 # this gives 1 actual retry, as xl2tpd can't count
|
||||||
'';
|
'';
|
||||||
control = "/run/${name}/control";
|
control = "/run/${name}/control";
|
||||||
service = longrun {
|
in common {
|
||||||
inherit name;
|
inherit name debug username password lcpEcho ppp-options;
|
||||||
run = ''
|
command = ''
|
||||||
mkdir -p /run/${name}
|
touch ${control}
|
||||||
chmod 0700 /run/${name}
|
exec ${xl2tpd}/bin/xl2tpd -D -p /run/${name}/${name}.pid -c ${conf} -C ${control}
|
||||||
touch ${control}
|
'';
|
||||||
in_outputs ${name}
|
|
||||||
echo ${escapeShellArgs ppp-options'} | ${output-template}/bin/output-template '{{' '}}' > /run/${name}/ppp-options
|
|
||||||
exec ${xl2tpd}/bin/xl2tpd -D -p /run/${name}/${name}.pid -c ${conf} -C ${control}
|
|
||||||
'';
|
|
||||||
notification-fd = 10;
|
|
||||||
};
|
|
||||||
in svc.secrets.subscriber.build {
|
|
||||||
watch = [ username password ];
|
|
||||||
inherit service;
|
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
serviceFns,
|
serviceFns,
|
||||||
svc,
|
svc,
|
||||||
writeAshScript,
|
writeAshScript,
|
||||||
|
callPackage
|
||||||
} :
|
} :
|
||||||
{ interface,
|
{ interface,
|
||||||
ppp-options,
|
ppp-options,
|
||||||
@ -16,75 +17,14 @@
|
|||||||
debug
|
debug
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (liminix.services) longrun;
|
|
||||||
inherit (lib) optional optionals escapeShellArgs concatStringsSep;
|
|
||||||
name = "${interface.name}.pppoe";
|
name = "${interface.name}.pppoe";
|
||||||
ip-up = writeAshScript "ip-up" {} ''
|
common = callPackage ./common.nix { inherit svc; };
|
||||||
. ${serviceFns}
|
|
||||||
(in_outputs ${name}
|
|
||||||
echo $1 > ifname
|
|
||||||
echo $2 > tty
|
|
||||||
echo $3 > speed
|
|
||||||
echo $4 > address
|
|
||||||
echo $5 > peer-address
|
|
||||||
echo $DNS1 > ns1
|
|
||||||
echo $DNS2 > ns2
|
|
||||||
)
|
|
||||||
echo >/proc/self/fd/10
|
|
||||||
'';
|
|
||||||
ip6-up = writeAshScript "ip6-up" {} ''
|
|
||||||
. ${serviceFns}
|
|
||||||
(in_outputs ${name}
|
|
||||||
echo $4 > ipv6-address
|
|
||||||
echo $5 > ipv6-peer-address
|
|
||||||
)
|
|
||||||
echo >/proc/self/fd/10
|
|
||||||
'';
|
|
||||||
|
|
||||||
literal_or_output =
|
|
||||||
let v = o: ({
|
|
||||||
string = builtins.toJSON;
|
|
||||||
int = builtins.toJSON;
|
|
||||||
lambda = (o: "output(${builtins.toJSON (o "service")}, ${builtins.toJSON (o "path")})");
|
|
||||||
}.${builtins.typeOf o}) o;
|
|
||||||
in o: "{{ ${v o} }}";
|
|
||||||
|
|
||||||
ppp-options' =
|
|
||||||
["+ipv6" "noauth"]
|
|
||||||
++ optional debug "debug"
|
|
||||||
++ optionals (username != null) ["name" (literal_or_output username)]
|
|
||||||
++ optionals (password != null) ["password" (literal_or_output password)]
|
|
||||||
++ optional lcpEcho.adaptive "lcp-echo-adaptive"
|
|
||||||
++ optionals (lcpEcho.interval != null)
|
|
||||||
["lcp-echo-interval" (builtins.toString lcpEcho.interval)]
|
|
||||||
++ optionals (lcpEcho.failure != null)
|
|
||||||
["lcp-echo-failure" (builtins.toString lcpEcho.failure)]
|
|
||||||
++ ppp-options
|
|
||||||
++ ["ip-up-script" ip-up
|
|
||||||
"ipv6-up-script" ip6-up
|
|
||||||
"ipparam" name
|
|
||||||
"nodetach"
|
|
||||||
"usepeerdns"
|
|
||||||
"nodefaultroute"
|
|
||||||
"logfd" "2"
|
|
||||||
];
|
|
||||||
timeoutOpt = if lcpEcho.interval != null then "-T ${builtins.toString (4 * lcpEcho.interval)}" else "";
|
timeoutOpt = if lcpEcho.interval != null then "-T ${builtins.toString (4 * lcpEcho.interval)}" else "";
|
||||||
service = longrun {
|
in common {
|
||||||
inherit name;
|
inherit name debug username password lcpEcho ppp-options;
|
||||||
run = ''
|
command = ''
|
||||||
mkdir -p /run/${name}
|
exec ${ppp}/bin/pppd pty "${pppoe}/bin/pppoe ${timeoutOpt} -I $(output ${interface} ifname)" file /run/${name}/ppp-options
|
||||||
chmod 0700 /run/${name}
|
'';
|
||||||
in_outputs ${name}
|
dependencies = [ interface ];
|
||||||
echo ${escapeShellArgs ppp-options'} | ${output-template}/bin/output-template '{{' '}}' > /run/${name}/ppp-options
|
|
||||||
exec ${ppp}/bin/pppd pty "${pppoe}/bin/pppoe ${timeoutOpt} -I $(output ${interface} ifname)" file /run/${name}/ppp-options
|
|
||||||
'';
|
|
||||||
notification-fd = 10;
|
|
||||||
timeout-up = if lcpEcho.failure != null
|
|
||||||
then (10 + lcpEcho.failure * lcpEcho.interval) * 1000
|
|
||||||
else 60 * 1000;
|
|
||||||
dependencies = [ interface ];
|
|
||||||
};
|
|
||||||
in svc.secrets.subscriber.build {
|
|
||||||
watch = [ username password ];
|
|
||||||
inherit service;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user