Coverage for /pythoncovmergedfiles/medio/medio/usr/local/lib/python3.8/site-packages/adal/xmlutil.py: 61%
33 statements
« prev ^ index » next coverage.py v7.3.2, created at 2023-12-08 06:05 +0000
« prev ^ index » next coverage.py v7.3.2, created at 2023-12-08 06:05 +0000
1#------------------------------------------------------------------------------
2#
3# Copyright (c) Microsoft Corporation.
4# All rights reserved.
5#
6# This code is licensed under the MIT License.
7#
8# Permission is hereby granted, free of charge, to any person obtaining a copy
9# of this software and associated documentation files(the "Software"), to deal
10# in the Software without restriction, including without limitation the rights
11# to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
12# copies of the Software, and to permit persons to whom the Software is
13# furnished to do so, subject to the following conditions :
14#
15# The above copyright notice and this permission notice shall be included in
16# all copies or substantial portions of the Software.
17#
18# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
21# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24# THE SOFTWARE.
25#
26#------------------------------------------------------------------------------
28try:
29 from xml.etree import cElementTree as ET
30except ImportError:
31 from xml.etree import ElementTree as ET
33from . import constants
35XPATH_PATH_TEMPLATE = '*[local-name() = \'LOCAL_NAME\' and namespace-uri() = \'NAMESPACE\']'
37def expand_q_names(xpath):
39 namespaces = constants.XmlNamespaces.namespaces
40 path_parts = xpath.split('/')
41 for index, part in enumerate(path_parts):
42 if part.find(":") != -1:
43 q_parts = part.split(':')
44 if len(q_parts) != 2:
45 raise IndexError("Unable to parse XPath string: {} with QName: {}".format(xpath, part))
47 expanded_path = XPATH_PATH_TEMPLATE.replace('LOCAL_NAME', q_parts[1])
48 expanded_path = expanded_path.replace('NAMESPACE', namespaces[q_parts[0]])
49 path_parts[index] = expanded_path
51 return '/'.join(path_parts)
53def xpath_find(dom, xpath):
54 return dom.findall(xpath, constants.XmlNamespaces.namespaces)
56def serialize_node_children(node):
58 doc = ""
59 for child in node.iter():
60 if is_element_node(child):
61 estring = ET.tostring(child)
62 doc += estring if isinstance(estring, str) else estring.decode()
64 return doc if doc else None
66def is_element_node(node):
67 return hasattr(node, 'tag')
69def find_element_text(node):
71 for child in node.iter():
72 if child.text:
73 return child.text