blob: 47187c96c6191bc21386b3b4453dace1c9fb56e1 [file] [log] [blame]
# Copyright 2017-present Adtran, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from adapters.adtran_common.net.adtran_netconf import adtran_module_url
from twisted.internet.defer import inlineCallbacks, returnValue
import xmltodict
import structlog
log = structlog.get_logger()
_phys_entities_rpc = """
<filter xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
<physical-entities-state xmlns="{}">
<physical-entity/>
</physical-entities-state>
</filter>
""".format(adtran_module_url('adtran-physical-entities'))
class PhysicalEntitiesState(object):
def __init__(self, session):
self._session = session
self._rpc_reply = None
@inlineCallbacks
def get_state(self):
self._rpc_reply = None
request = self._session.get(_phys_entities_rpc)
self._rpc_reply = yield request
returnValue(self._rpc_reply)
@property
def physical_entities(self):
"""
:return: (list) of OrderDict physical entities
"""
if self._rpc_reply is None:
# TODO: Support auto-get?
return None
result_dict = xmltodict.parse(self._rpc_reply.data_xml)
return result_dict['data']['physical-entities-state']['physical-entity']
def get_physical_entities(self, classification=None):
"""
Get the physical entities of a particular type
:param classification: (String or List) The classification or general hardware type of the
component identified by this physical entity
(case-insensitive)
:return: (list) of OrderDict physical entities
"""
entries = self.physical_entities
if classification is None:
return entries
# for entry in entries:
# import pprint
# log.info(pprint.PrettyPrinter(indent=2).pformat(entry))
def _matches(entry, value):
if 'classification' in entry and '#text' in entry['classification']:
text_val = entry['classification']['#text'].lower()
if isinstance(value, list):
return any(v.lower() in text_val for v in value)
return value.lower() in text_val
return False
return [entry for entry in entries if _matches(entry, classification)]