From 5687c6c38c48c23d03073b45e065aeb9b36873ae Mon Sep 17 00:00:00 2001
From: Jacek Kowalski <Jacek@jacekk.info>
Date: Sun, 03 May 2026 14:44:54 +0000
Subject: [PATCH] NetworkDriverData: only export selected objects
---
lib/NetworkDriver.py | 19 +++++++++++++++++--
1 files changed, 17 insertions(+), 2 deletions(-)
diff --git a/lib/NetworkDriver.py b/lib/NetworkDriver.py
index 948a6a6..306172d 100644
--- a/lib/NetworkDriver.py
+++ b/lib/NetworkDriver.py
@@ -15,7 +15,7 @@
return ''.join([random.choice(chars) for _ in range(size)])
-def create_interface(endpoint, network) -> str:
+def create_interface(endpoint, network) -> tuple[str, str]:
ifname0 = 'veth{}'.format(genid())
ifname1 = 'veth{}'.format(genid())
@@ -37,7 +37,7 @@
ip.link('set', index=idx, state='up')
if 'parent' in network.Options:
id_parent = ip.link_lookup(ifname=network.Options['parent'])[0]
- print(ip.link("set", index=idx, master=id_parent))
+ ip.link("set", index=idx, master=id_parent)
endpoint.Interface.Peer = ifname1
return ifname0, ifname1
@@ -157,11 +157,26 @@
'SrcName': interface,
'DstPrefix': 'eth',
},
+ 'StaticRoutes': [],
}
if gw4 is not None:
result['Gateway'] = gw4.ip.compressed
if gw6 is not None:
result['GatewayIPv6'] = gw6.ip.compressed
+ gw4 = endpoint.Options.get("gw4", network.Options.get("gw4", None))
+ if gw4 is not None:
+ result['StaticRoutes'].append({
+ 'Destination': gw4 + '/32',
+ 'RouteType': 1,
+ })
+ result['Gateway'] = gw4
+ gw6 = endpoint.Options.get("gw6", network.Options.get("gw6", None))
+ if gw6 is not None:
+ result['StaticRoutes'].append({
+ 'Destination': gw6 + '/128',
+ 'RouteType': 1,
+ })
+ result['GatewayIPv6'] = gw6
return result
--
Gitblit v1.10.0