Parse LDIF data into common text formats. It currently supports conversion to JSON and to YAML.
This is a thin wrapper around the python-ldap package.
From:
$ ldapsearch -Q -L -Y EXTERNAL -H ldapi:/// -b dc=company,dc=com
version: 1
#
# LDAPv3
# base <dc=company,dc=com> with scope subtree
# filter: (objectclass=*)
# requesting: ALL
#
# company.com
dn: dc=company,dc=com
objectClass: top
objectClass: dcObject
objectClass: organization
o: company
dc: company
# admin, company.com
dn: cn=admin,dc=company,dc=com
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin
description: LDAP administrator
# search result
# numResponses: 3
# numEntries: 2To :
$ ldapsearch -Q -L -Y EXTERNAL -H ldapi:/// -b dc=company,dc=com | ldifparse
cn=admin,dc=company,dc=com:
cn: admin
description: LDAP administrator
objectClass:
- simpleSecurityObject
- organizationalRole
dc=company,dc=com:
dc: company
o: company
objectClass:
- top
- dcObject
- organizationThe recommended way of installing ldifparse is through the pipx installer :
pipx install ldifparseldifparse will be installed in an isolated environment but will be available globally as a shell application.
Alternatively, you can install ldifparse in an environment of your choosing with pip :
pip install ldifparseYou can also download the source code from github :
git clone https://github.com/MatteoBouvier/ldifparse.gitWe recommend also installing jq for viewing and manipulating JSON in the terminal. The YAML equivalent is yq.
The simplest way to use ldifparse is by piping it some LDIF data :
cat input.ldif | ldifparseThis will print a YAML version of the data to stdout.
You can specify the ouput format with the --output parameter (-o for the short version). The output can either be
json or yaml (-oj and -oy are also accepted as shorthands).
Instead of a perfect translation of LDIF to JSON/YAML, you can get a tree representation with the --tree (-t)
parameter.