From 6a0d1c785459cd90a66d6956ab77c90b3614fd8a Mon Sep 17 00:00:00 2001 From: mpenning Date: Thu, 2 Nov 2023 13:35:55 -0500 Subject: [PATCH] Add type checks to ConfigList() elements --- ciscoconfparse/ciscoconfparse.py | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/ciscoconfparse/ciscoconfparse.py b/ciscoconfparse/ciscoconfparse.py index 072aef3..82d10bc 100644 --- a/ciscoconfparse/ciscoconfparse.py +++ b/ciscoconfparse/ciscoconfparse.py @@ -635,6 +635,29 @@ def __init__( self.encoding = encoding or ENCODING self.read_only = read_only + if len(config) > 0: + try: + correct_element_types = [] + for ii in config: + # Check whether the elements are the correct types... + if isinstance(ii, (str, BaseCfgLine)): + correct_element_types.append(True) + else: + correct_element_types.append(False) + + elements_have_len = all(correct_element_types) + except AttributeError: + elements_have_len = False + except TypeError: + elements_have_len = False + else: + elements_have_len = None + + if elements_have_len is False: + error = f"All ConfigList elements must have a length()" + logger.error(error) + raise InvalidParameters(error) + # Read the configuration lines and detect invalid inputs... # tmp_lines = self._get_ccp_lines(config=config, logger=logger) if isinstance(config, (str, pathlib.Path,)):