services: fix missing configurations for ospfv2 in config services
This commit is contained in:
parent
0fcc532c0d
commit
3c64654598
2 changed files with 47 additions and 13 deletions
|
@ -7,7 +7,8 @@ from core.configservice.base import ConfigService, ConfigServiceMode
|
||||||
from core.emane.nodes import EmaneNet
|
from core.emane.nodes import EmaneNet
|
||||||
from core.nodes.base import CoreNodeBase
|
from core.nodes.base import CoreNodeBase
|
||||||
from core.nodes.interface import DEFAULT_MTU, CoreInterface
|
from core.nodes.interface import DEFAULT_MTU, CoreInterface
|
||||||
from core.nodes.network import WlanNode
|
from core.nodes.network import PtpNet, WlanNode
|
||||||
|
from core.nodes.physical import Rj45Node
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
GROUP: str = "Quagga"
|
GROUP: str = "Quagga"
|
||||||
|
@ -55,6 +56,20 @@ def get_router_id(node: CoreNodeBase) -> str:
|
||||||
return "0.0.0.0"
|
return "0.0.0.0"
|
||||||
|
|
||||||
|
|
||||||
|
def rj45_check(iface: CoreInterface) -> bool:
|
||||||
|
"""
|
||||||
|
Helper to detect whether interface is connected an external RJ45
|
||||||
|
link.
|
||||||
|
"""
|
||||||
|
if iface.net:
|
||||||
|
for peer_iface in iface.net.get_ifaces():
|
||||||
|
if peer_iface == iface:
|
||||||
|
continue
|
||||||
|
if isinstance(peer_iface.node, Rj45Node):
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
class Zebra(ConfigService):
|
class Zebra(ConfigService):
|
||||||
name: str = "zebra"
|
name: str = "zebra"
|
||||||
group: str = GROUP
|
group: str = GROUP
|
||||||
|
@ -105,7 +120,13 @@ class Zebra(ConfigService):
|
||||||
ip4s.append(str(ip4))
|
ip4s.append(str(ip4))
|
||||||
for ip6 in iface.ip6s:
|
for ip6 in iface.ip6s:
|
||||||
ip6s.append(str(ip6))
|
ip6s.append(str(ip6))
|
||||||
ifaces.append((iface, ip4s, ip6s, iface.control))
|
configs = []
|
||||||
|
if not iface.control:
|
||||||
|
for service in services:
|
||||||
|
config = service.quagga_iface_config(iface)
|
||||||
|
if config:
|
||||||
|
configs.append(config.split("\n"))
|
||||||
|
ifaces.append((iface, ip4s, ip6s, configs))
|
||||||
|
|
||||||
return dict(
|
return dict(
|
||||||
quagga_bin_search=quagga_bin_search,
|
quagga_bin_search=quagga_bin_search,
|
||||||
|
@ -156,17 +177,32 @@ class Ospfv2(QuaggaService, ConfigService):
|
||||||
ipv4_routing: bool = True
|
ipv4_routing: bool = True
|
||||||
|
|
||||||
def quagga_iface_config(self, iface: CoreInterface) -> str:
|
def quagga_iface_config(self, iface: CoreInterface) -> str:
|
||||||
if has_mtu_mismatch(iface):
|
has_mtu = has_mtu_mismatch(iface)
|
||||||
return "ip ospf mtu-ignore"
|
has_rj45 = rj45_check(iface)
|
||||||
else:
|
is_ptp = isinstance(iface.net, PtpNet)
|
||||||
return ""
|
data = dict(has_mtu=has_mtu, is_ptp=is_ptp, has_rj45=has_rj45)
|
||||||
|
text = """
|
||||||
|
% if has_mtu:
|
||||||
|
ip ospf mtu-ignore
|
||||||
|
% endif
|
||||||
|
% if has_rj45:
|
||||||
|
<% return STOP_RENDERING %>
|
||||||
|
% endif
|
||||||
|
% if is_ptp:
|
||||||
|
ip ospf network point-to-point
|
||||||
|
% endif
|
||||||
|
ip ospf hello-interval 2
|
||||||
|
ip ospf dead-interval 6
|
||||||
|
ip ospf retransmit-interval 5
|
||||||
|
"""
|
||||||
|
return self.render_text(text, data)
|
||||||
|
|
||||||
def quagga_config(self) -> str:
|
def quagga_config(self) -> str:
|
||||||
router_id = get_router_id(self.node)
|
router_id = get_router_id(self.node)
|
||||||
addresses = []
|
addresses = []
|
||||||
for iface in self.node.get_ifaces(control=False):
|
for iface in self.node.get_ifaces(control=False):
|
||||||
for ip4 in iface.ip4s:
|
for ip4 in iface.ip4s:
|
||||||
addresses.append(str(ip4.ip))
|
addresses.append(str(ip4))
|
||||||
data = dict(router_id=router_id, addresses=addresses)
|
data = dict(router_id=router_id, addresses=addresses)
|
||||||
text = """
|
text = """
|
||||||
router ospf
|
router ospf
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
% for iface, ip4s, ip6s, is_control in ifaces:
|
% for iface, ip4s, ip6s, configs in ifaces:
|
||||||
interface ${iface.name}
|
interface ${iface.name}
|
||||||
% if want_ip4:
|
% if want_ip4:
|
||||||
% for addr in ip4s:
|
% for addr in ip4s:
|
||||||
|
@ -10,13 +10,11 @@ interface ${iface.name}
|
||||||
ipv6 address ${addr}
|
ipv6 address ${addr}
|
||||||
% endfor
|
% endfor
|
||||||
% endif
|
% endif
|
||||||
% if not is_control:
|
% for config in configs:
|
||||||
% for service in services:
|
% for line in config:
|
||||||
% for line in service.quagga_iface_config(iface).split("\n"):
|
|
||||||
${line}
|
${line}
|
||||||
% endfor
|
|
||||||
% endfor
|
% endfor
|
||||||
% endif
|
% endfor
|
||||||
!
|
!
|
||||||
% endfor
|
% endfor
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue