Add a bit more information for network facts on BSD
This was tested on FreeBSD 11, NetBSD 7 and OpenBSD 6.0 This currently detect ether, loopback and tunnel.
This commit is contained in:
parent
c048198567
commit
435dfc2b9c
1 changed files with 16 additions and 0 deletions
|
@ -2550,6 +2550,7 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
|
|
||||||
default_ipv4, default_ipv6 = self.get_default_interfaces(route_path)
|
default_ipv4, default_ipv6 = self.get_default_interfaces(route_path)
|
||||||
interfaces, ips = self.get_interfaces_info(ifconfig_path)
|
interfaces, ips = self.get_interfaces_info(ifconfig_path)
|
||||||
|
self.detect_type_media(interfaces)
|
||||||
self.merge_default_interface(default_ipv4, interfaces, 'ipv4')
|
self.merge_default_interface(default_ipv4, interfaces, 'ipv4')
|
||||||
self.merge_default_interface(default_ipv6, interfaces, 'ipv6')
|
self.merge_default_interface(default_ipv6, interfaces, 'ipv6')
|
||||||
self.facts['interfaces'] = interfaces.keys()
|
self.facts['interfaces'] = interfaces.keys()
|
||||||
|
@ -2564,6 +2565,12 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
|
|
||||||
return self.facts
|
return self.facts
|
||||||
|
|
||||||
|
def detect_type_media(self, interfaces):
|
||||||
|
for iface in interfaces:
|
||||||
|
if 'media' in interfaces[iface]:
|
||||||
|
if 'ether' in interfaces[iface]['media'].lower():
|
||||||
|
interfaces[iface]['type'] = 'ether'
|
||||||
|
|
||||||
def get_default_interfaces(self, route_path):
|
def get_default_interfaces(self, route_path):
|
||||||
|
|
||||||
# Use the commands:
|
# Use the commands:
|
||||||
|
@ -2636,6 +2643,8 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
self.parse_inet_line(words, current_if, ips)
|
self.parse_inet_line(words, current_if, ips)
|
||||||
elif words[0] == 'inet6':
|
elif words[0] == 'inet6':
|
||||||
self.parse_inet6_line(words, current_if, ips)
|
self.parse_inet6_line(words, current_if, ips)
|
||||||
|
elif words[0] == 'tunnel':
|
||||||
|
self.parse_tunnel_line(words, current_if, ips)
|
||||||
else:
|
else:
|
||||||
self.parse_unknown_line(words, current_if, ips)
|
self.parse_unknown_line(words, current_if, ips)
|
||||||
|
|
||||||
|
@ -2645,6 +2654,8 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
device = words[0][0:-1]
|
device = words[0][0:-1]
|
||||||
current_if = {'device': device, 'ipv4': [], 'ipv6': [], 'type': 'unknown'}
|
current_if = {'device': device, 'ipv4': [], 'ipv6': [], 'type': 'unknown'}
|
||||||
current_if['flags'] = self.get_options(words[1])
|
current_if['flags'] = self.get_options(words[1])
|
||||||
|
if 'LOOPBACK' in current_if['flags']:
|
||||||
|
current_if['type'] = 'loopback'
|
||||||
current_if['macaddress'] = 'unknown' # will be overwritten later
|
current_if['macaddress'] = 'unknown' # will be overwritten later
|
||||||
|
|
||||||
if len(words) >= 5 : # Newer FreeBSD versions
|
if len(words) >= 5 : # Newer FreeBSD versions
|
||||||
|
@ -2665,6 +2676,7 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
|
|
||||||
def parse_ether_line(self, words, current_if, ips):
|
def parse_ether_line(self, words, current_if, ips):
|
||||||
current_if['macaddress'] = words[1]
|
current_if['macaddress'] = words[1]
|
||||||
|
current_if['type'] = 'ether'
|
||||||
|
|
||||||
def parse_media_line(self, words, current_if, ips):
|
def parse_media_line(self, words, current_if, ips):
|
||||||
# not sure if this is useful - we also drop information
|
# not sure if this is useful - we also drop information
|
||||||
|
@ -2723,6 +2735,9 @@ class GenericBsdIfconfigNetwork(Network):
|
||||||
ips['all_ipv6_addresses'].append(address['address'])
|
ips['all_ipv6_addresses'].append(address['address'])
|
||||||
current_if['ipv6'].append(address)
|
current_if['ipv6'].append(address)
|
||||||
|
|
||||||
|
def parse_tunnel_line(self, words, current_if, ips):
|
||||||
|
current_if['type'] = 'tunnel'
|
||||||
|
|
||||||
def parse_unknown_line(self, words, current_if, ips):
|
def parse_unknown_line(self, words, current_if, ips):
|
||||||
# we are going to ignore unknown lines here - this may be
|
# we are going to ignore unknown lines here - this may be
|
||||||
# a bad idea - but you can override it in your subclass
|
# a bad idea - but you can override it in your subclass
|
||||||
|
@ -2970,6 +2985,7 @@ class OpenBSDNetwork(GenericBsdIfconfigNetwork):
|
||||||
# Return macaddress instead of lladdr
|
# Return macaddress instead of lladdr
|
||||||
def parse_lladdr_line(self, words, current_if, ips):
|
def parse_lladdr_line(self, words, current_if, ips):
|
||||||
current_if['macaddress'] = words[1]
|
current_if['macaddress'] = words[1]
|
||||||
|
current_if['type'] = 'ether'
|
||||||
|
|
||||||
class NetBSDNetwork(GenericBsdIfconfigNetwork):
|
class NetBSDNetwork(GenericBsdIfconfigNetwork):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in a new issue