53 lines
1.8 KiB
Nix
53 lines
1.8 KiB
Nix
{
|
|
callPackage
|
|
, liminix
|
|
, ifwait
|
|
, lib
|
|
}:
|
|
let
|
|
inherit (liminix.services) oneshot longrun;
|
|
inherit (lib) concatStringsSep optional;
|
|
in {
|
|
interface = { type ? "hardware", device, link ? null, primary ? null, id ? null, dependencies ? [] } @ args:
|
|
let name = "${device}.link";
|
|
ups =
|
|
[]
|
|
++ optional (type == "bridge")
|
|
"ip link add name ${device} type bridge"
|
|
++ optional (type == "vlan")
|
|
"ip link add link ${link} name ${device} type vlan id ${id}"
|
|
++ ["${ifwait}/bin/ifwait -v ${device} present"]
|
|
++ ["ip link set up dev ${device}"]
|
|
++ optional (primary != null)
|
|
"ip link set dev ${device} master ${primary.device}";
|
|
in oneshot {
|
|
inherit name;
|
|
up = lib.concatStringsSep "\n" ups;
|
|
down = "ip link set down dev ${device}";
|
|
dependencies = dependencies ++ lib.optional (primary != null) primary;
|
|
} // {
|
|
inherit device;
|
|
};
|
|
address = interface: { family, dependencies ? [], prefixLength, address } @ args:
|
|
let inherit (builtins) toString;
|
|
in oneshot {
|
|
dependencies = [ interface ] ++ dependencies;
|
|
name = "${interface.device}.addr.${address}";
|
|
up = "ip address add ${address}/${toString prefixLength} dev ${interface.device} ";
|
|
down = "ip address del ${address}/${toString prefixLength} dev ${interface.device} ";
|
|
} // {
|
|
inherit (interface) device;
|
|
};
|
|
route = { name, target, via, dependencies, dev ? null }:
|
|
let with_dev = if dev != null then "dev ${dev}" else "";
|
|
in oneshot {
|
|
inherit name;
|
|
up = ''
|
|
ip route add ${target} via ${via} ${with_dev}
|
|
'';
|
|
down = ''
|
|
ip route del ${target} via ${via} ${with_dev}
|
|
'';
|
|
inherit dependencies;
|
|
};
|
|
}
|