Назад | Перейти на главную страницу

поиск и замена атрибута ldap

У меня достаточно большой набор данных на сервере LDAP. Некоторые атрибуты появляются во многих местах, и я хотел бы их заменить.

Данные небольшие, но их достаточно, чтобы исключить редактирование и экспорт вручную.

Какой лучший подход для этого? Используйте инструмент LDAP, чтобы найти и заменить их? Написать сценарий для изменения записей? Экспортировать данные и редактировать их локально?

Любые предложения будут полезны.

Предположительно вы можете найти все dn для записей, где эти атрибуты заменяются чем-то вроде ldapsearch '(attribute=value)' |grep ^dn а затем для каждой записи сделайте ldapmodify script, поэтому, используя немного Python:

from subprocess import Popen, PIPE

input=('searchoutput.txt')
for line in input:
    dn = line.rstrip().split()[1]
    modify_str = line
    modify_str += 'changetype: modify\nreplace: attribute\nattribute: newvalue'
    lm = Popen('ldapmodify <various args>', shell=True, stdin=PIPE, stdout=PIPE, stderr=PIPE)
    (out, err) = lm.communicate(modify_str)
    if lm.wait() != 0:
        sys.stderr.write('ldapmodify of {0} failed:\n{1}'.format(dn, err))

Т.е. для каждой записи, которую необходимо изменить, создайте предложение, в котором говорится:

dn: MyEntryCN
changetype: modify
replace: attribute
attribute: newvalue

и скормить это ldapmodify (с соответствующей аутентификацией и т. д. аргументами командной строки).