From 8fc29d1b467a286d154e463ae5e00037dbfd1e54 Mon Sep 17 00:00:00 2001 From: Jarrod Johnson Date: Fri, 1 Jun 2018 16:09:13 -0400 Subject: [PATCH] Correctly allow manual discovery through ambiguous situation Manual discovery may 'catch' some incidental data from auto-discovery. Since the operation is manual, trust the user rather than assume the user is confused. --- confluent_server/confluent/discovery/core.py | 37 ++++++++++---------- 1 file changed, 18 insertions(+), 19 deletions(-) diff --git a/confluent_server/confluent/discovery/core.py b/confluent_server/confluent/discovery/core.py index 645d533c..4773a703 100644 --- a/confluent_server/confluent/discovery/core.py +++ b/confluent_server/confluent/discovery/core.py @@ -953,26 +953,25 @@ def eval_node(cfg, handler, info, nodename, manual=False): # but... is this really ok? could be on an upstream port or # erroneously put in the enclosure with no nodes yet # so first, see if the candidate node is a chain host - if info.get('maccount', False): - # discovery happened through switch - nl = list(cfg.filter_node_attributes( - 'enclosure.extends=' + nodename)) - if nl: - # The candidate nodename is the head of a chain, we must - # validate the smm certificate by the switch - macmap.get_node_fingerprint(nodename, cfg) - util.handler.cert_matches(fprint, handler.https_cert) + if not manual: + if info.get('maccount', False): + # discovery happened through switch + nl = list(cfg.filter_node_attributes( + 'enclosure.extends=' + nodename)) + if nl: + # The candidate nodename is the head of a chain, we must + # validate the smm certificate by the switch + macmap.get_node_fingerprint(nodename, cfg) + util.handler.cert_matches(fprint, handler.https_cert) + return + if (info.get('maccount', False) and + not handler.discoverable_by_switch(info['maccount'])): + errorstr = 'The detected node {0} was detected using switch, ' \ + 'however the relevant port has too many macs learned ' \ + 'for this type of device ({1}) to be discovered by ' \ + 'switch.'.format(nodename, handler.devname) + log.log({'error': errorstr}) return - if (info.get('maccount', False) and - not handler.discoverable_by_switch(info['maccount'])): - errorstr = 'The detected node {0} was detected using switch, ' \ - 'however the relevant port has too many macs learned ' \ - 'for this type of device ({1}) to be discovered by ' \ - 'switch.'.format(nodename, handler.devname) - if manual: - raise exc.InvalidArgumentException(errorstr) - log.log({'error': errorstr}) - return if not discover_node(cfg, handler, info, nodename, manual): pending_nodes[nodename] = info