uplink: use route with lowest metric
This commit is contained in:
parent
e4f7e911b8
commit
b6a8048c8b
@ -1,4 +1,4 @@
|
|||||||
{ lua, lib, fetchFromGitHub, buildLuaPackage, libmnl }:
|
{ lua, lib, fetchpatch, fetchFromGitHub, buildLuaPackage, libmnl }:
|
||||||
let pname = "netlink";
|
let pname = "netlink";
|
||||||
in buildLuaPackage {
|
in buildLuaPackage {
|
||||||
inherit pname;
|
inherit pname;
|
||||||
@ -12,6 +12,12 @@ in buildLuaPackage {
|
|||||||
rev = "v0.1.1";
|
rev = "v0.1.1";
|
||||||
hash = "sha256:1833naskl4p7rz5kk0byfgngvw1mvf6cnz64sr3ny7i202wv7s52";
|
hash = "sha256:1833naskl4p7rz5kk0byfgngvw1mvf6cnz64sr3ny7i202wv7s52";
|
||||||
};
|
};
|
||||||
|
patches = [ (fetchpatch {
|
||||||
|
url = "https://github.com/chris2511/lua-netlink/compare/master...telent:rtnetlink-types.patch";
|
||||||
|
name = "rtnetlink-types.patch";
|
||||||
|
hash = "sha256-lBCfP8pMyBIY+XEGWD/nPQ9l2dDOnXeitR1TaRUXCq8=";
|
||||||
|
})];
|
||||||
|
|
||||||
buildPhase = "$CC -shared -l mnl -o netlink.so src/*.c";
|
buildPhase = "$CC -shared -l mnl -o netlink.so src/*.c";
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
|
@ -75,7 +75,11 @@
|
|||||||
;; (e.g wwan and wlan both have default route)
|
;; (e.g wwan and wlan both have default route)
|
||||||
;; we probably need to store all of them and
|
;; we probably need to store all of them and
|
||||||
;; distinguish by metric
|
;; distinguish by metric
|
||||||
(tset routes (or event.dst "default") event)
|
(let [dst (or event.dst "default")
|
||||||
|
existing (. routes dst)]
|
||||||
|
(if (or (not existing)
|
||||||
|
(< event.metric existing.metric))
|
||||||
|
(tset routes dst event)))
|
||||||
|
|
||||||
{} (print :unhandled event.event)
|
{} (print :unhandled event.event)
|
||||||
))
|
))
|
||||||
|
Loading…
Reference in New Issue
Block a user