Files
@ b3e67fd6c0c1
Branch filter:
Location: majic-ansible-roles/roles/ldap_server/molecule/default/tests/helpers.py - annotation
b3e67fd6c0c1
756 B
text/x-python
MAR-187: Reorder the deprecation tasks for xmpp_server role to make the runs reliable:
- Deprecated apt repository really needs to be removed first in case
it has an unresolvable URL (so the backports repository cache update
would trigger correctly).
- Use the file removal for Prosody repository as well to make sure the
file is dropped.
- Deprecated apt repository really needs to be removed first in case
it has an unresolvable URL (so the backports repository cache update
would trigger correctly).
- Use the file removal for Prosody repository as well to make sure the
file is dropped.
d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 d77f12671189 | import io
import ldif
def parse_ldif(ldif_input):
"""
Helper function that parses the passed-in LDIF string. This is a
simple wrapper around the Python LDAP ldif.LDIFRecordList class.
Entries are returned as list of (dn, attributes)
tuples. Attributes are represented by a dictionary mapping
attribute names to list of associated values.
:param ldif_input: LDIF to parse.
:type ldif_input: str
:returns: List of parsed entries.
:rtype: list[tuple(str, dict{str: list[str]})]
Returns:
"""
parser = ldif.LDIFRecordList(io.StringIO(ldif_input))
try:
parser.parse()
except Exception as e:
raise ValueError("Failed to parse input: %s" % str(e))
return parser.all_records
|