38 lines
1.1 KiB
Python
38 lines
1.1 KiB
Python
import logging
|
|
import validator.lcp as lcp
|
|
|
|
class NullHandler(logging.Handler):
|
|
def emit(self, record):
|
|
pass
|
|
|
|
def get_by_name(yaml, ifname):
|
|
""" Return the loopback by name, if it exists. Return None otherwise. """
|
|
try:
|
|
if ifname in yaml['loopbacks']:
|
|
return yaml['loopbacks'][ifname]
|
|
except:
|
|
pass
|
|
return None
|
|
|
|
|
|
def validate_loopbacks(yaml):
|
|
result = True
|
|
msgs = []
|
|
logger = logging.getLogger('vppcfg.validator')
|
|
logger.addHandler(NullHandler())
|
|
|
|
if not 'loopbacks' in yaml:
|
|
return result, msgs
|
|
|
|
logger.debug("Validating loopbacks...")
|
|
for ifname, iface in yaml['loopbacks'].items():
|
|
logger.debug("loopback %s" % iface)
|
|
if 'addresses' in iface and not 'lcp' in iface:
|
|
msgs.append("loopback %s has an address but no LCP" % ifname)
|
|
result = False
|
|
if 'lcp' in iface and not lcp.is_unique(yaml, iface['lcp']):
|
|
msgs.append("loopback %s does not have a unique LCP name %s" % (ifname, iface['lcp']))
|
|
result = False
|
|
|
|
return result, msgs
|