dhcp6c subscribe to ppp ifindex
when the peer bounces ppp, s6 will restart the ppp process but not restart the dependent services (because the service isn't considered to have gone down) so the dependent services need to notice when the outputs from ppp have changed
This commit is contained in:
parent
01fe2159b4
commit
53c6d506cf
@ -25,6 +25,7 @@
|
||||
(fn run []
|
||||
(let [[state-directory lan-device] arg
|
||||
dir (svc.open state-directory)]
|
||||
(update-prefixes lan-device [] (or (dir:output "prefix") []) system)
|
||||
(accumulate [addresses []
|
||||
v (dir:events)]
|
||||
(update-prefixes lan-device addresses (or (v:output "prefix") []) system))))
|
||||
|
@ -25,6 +25,7 @@
|
||||
(fn run []
|
||||
(let [[state-directory wan-device] arg
|
||||
dir (svc.open state-directory)]
|
||||
(update-addresses wan-device [] (or (dir:output "address") []) system)
|
||||
(accumulate [addresses []
|
||||
v (dir:events)]
|
||||
(update-addresses wan-device addresses (or (v:output "address") []) system))))
|
||||
|
@ -2,19 +2,29 @@
|
||||
liminix,
|
||||
odhcp6c,
|
||||
odhcp-script,
|
||||
svc
|
||||
}:
|
||||
{ interface }:
|
||||
let
|
||||
inherit (liminix.services) longrun;
|
||||
inherit (liminix) outputRef;
|
||||
name = "dhcp6c.${interface.name}";
|
||||
in
|
||||
longrun {
|
||||
inherit name;
|
||||
notification-fd = 10;
|
||||
run = ''
|
||||
export SERVICE_STATE=$SERVICE_OUTPUTS/${name}
|
||||
${odhcp6c}/bin/odhcp6c -s ${odhcp-script} -e -v -p /run/${name}.pid -P0 $(output ${interface} ifname)
|
||||
)
|
||||
'';
|
||||
dependencies = [ interface ];
|
||||
service =
|
||||
longrun {
|
||||
inherit name;
|
||||
notification-fd = 10;
|
||||
run = ''
|
||||
export SERVICE_STATE=$SERVICE_OUTPUTS/${name}
|
||||
ifname=$(output ${interface} ifname)
|
||||
test -n "$ifname" && ${odhcp6c}/bin/odhcp6c -s ${odhcp-script} -e -v -p /run/${name}.pid -P0 $ifname
|
||||
)
|
||||
'';
|
||||
dependencies = [ interface ];
|
||||
};
|
||||
in svc.secrets.subscriber.build {
|
||||
# if the ppp service gets restarted, the interface may be different and
|
||||
# we will have to restart dhcp on the new one
|
||||
watch = [ (outputRef interface "ifindex") ];
|
||||
action = "restart";
|
||||
inherit service;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user