本連載では今までさまざまなソフトウェアとLDAPの連携を紹介してきたわけですが、
エントリの追加
リスト1のようなLDIFファイルが存在した場合を考えてみましょう。
dn: dc=example,dc=com
objectClass: dcObject
objectClass: organization
dc: example
o: example
dn: ou=People,dc=example,dc=com
objectClass: organizationalUnit
ou: People
dn: cn=suzuki,ou=People,dc=example,dc=com
objectClass: inetOrgPerson
sn: suzuki
cn: suzuki
mail: suzuki@example.com
dn: cn=tanaka,ou=People,dc=example,dc=com
objectClass: inetOrgPerson
sn: tanaka
cn: tanaka
mail: tanaka@example.com
mail: a.tanaka@example.com
このエントリをLDAPサーバに追加するためには、
% ldapadd -x -D "cn=Manager,dc=example,dc=com" -w secret -f orig.ldif
すでにご存じの方もいらっしゃるかもしれませんが、
% ldapadd -x -D "cn=Manager,dc=example,dc=com" -w secret < orig.ldif
これをうまく使えば、
% lv -Ou8 orig.ldif | ldapadd -x -D "cn=Manager,dc=example,dc=com" -w secret
または
% nkf -w orig.ldif | ldapadd -x -D "cn=Manager,dc=example,dc=com" -w secret
また、
ldapmodifyコマンドは文字通りエントリを編集するために使われますが、
% ldapmodify -a -x -D "cn=Manager,dc=example,dc=com" -w secret -f orig.ldif
エントリの編集
orig.
もっとも基本的な方法はldapmodifyコマンドを使用することです。ldapaddコマンド同様、
dn: cn=suzuki,ou=People,dc=example,dc=com
objectClass: inetOrgPerson
sn: suzuki
cn: suzuki
mail: suzu@example.com
ldapmodifyコマンドを使用し、
% ldapmodify -x -D "cn=Manager,dc=example,dc=com" -w secret -f new1.ldif
この方法では、
dn: cn=tanaka,ou=People,dc=example,dc=com
changetype: modify
replace: mail
mail: suzu@example.com
% ldapmodify -x -D "cn=Manager,dc=example,dc=com" -w secret -f new2.ldif
このように、
dn: cn=tanaka,ou=People,dc=example,dc=com
changetype: modify
add: mail
mail: newaddress@example.com
リスト4のLDIFを日本語で説明するとすれば、
- dn: cn=tanaka,ou=People,dc=example,dc=com をこれから編集
- 変更内容はmodify
- mail属性を追加
- mail属性の内容はnewaddress@example.
com
同様に、
dn: cn=tanaka,ou=People,dc=example,dc=com
changetype: modify
replace: mail
mail: replace1@example.com
mail: replace2@example.com
この場合、
次はchangetypeにaddを指定した例です。実質ldapaddと同じ挙動となります。
dn: cn=tanaka2,ou=People,dc=example,dc=com
changetype: add
objectClass: inetOrgPerson
sn: tanaka2
cn: tanaka2
mail: tanaka2@example.com
次はエントリの一部を削除する場合です。これにより、
dn: cn=tanaka,ou=People,dc=example,dc=com
changetype: modify
delete: mail
mail: a.tanaka@example.com
今までの操作を1つにまとめることも可能です。その場合は次のように、
dn: cn=tanaka,ou=People,dc=example,dc=com
changetype: modify
replace: sn
sn: New Name
-
add: mail
mail: new@example.com
これらの用法に関してはldapmodifyコマンドのマニュアルにも記載されていますので、
DNの編集:ldapmodrdn
エントリの中身だけではなく、
dn: cn=tanaka,ou=People,dc=example,dc=com
というDNを
dn: cn=Taro Tanaka,ou=People,dc=example,dc=com
に変更するためには、
ldapmodrdn -x -D "cn=Manager,dc=example,dc=com" -w secret -r 'cn=tanaka,ou=People,dc=example,dc=com' 'cn=Taro Tanaka'
GUIツール
大量のデータ登録に際しては、
それぞれ長所、
GQ
http://gq-project.org/比較的昔から存在するツールで、
使用するためには、
% ./configure % make # make install
data:image/s3,"s3://crabby-images/9fcfa/9fcfa3594b66aa045f1e4e16f135a8d555cf1e1d" alt="図9 GQの画面(1) 図9 GQの画面(1)"
data:image/s3,"s3://crabby-images/a07bd/a07bd15be90f2bf2509abad7aa781bd3f285140c" alt="図10 GQの画面(2) 図10 GQの画面(2)"
phpLDAPadmin
http://phpldapadmin.sourceforge.net/こちらは文字通り、
そのため、
data:image/s3,"s3://crabby-images/8ca98/8ca98cc094c7918f923e15dca5a943679b8e8e04" alt="図11 phpLDAPadminの画面 図11 phpLDAPadminの画面"
Luma
http://luma.sourceforge.net/LumaはPythonスクリプトによるGUIツールです。Qtに依存しますので、
たとえばスキーマブラウザを使用すると、
# ./install.py --prefix=/usr/local
data:image/s3,"s3://crabby-images/812a4/812a40244a28a5fa98a2b797f13e20718c02985f" alt="図13 Lumaの画面(1) 図13 Lumaの画面(1)"
data:image/s3,"s3://crabby-images/e12a9/e12a9440f5342a22aa70d7375f83078f33598ed9" alt="図14 Lumaの画面(2) 図14 Lumaの画面(2)"
JXplorer
http://www.jxplorer.org/JXplorerはJavaで記述されたクライアントツールです。当然WindowsやMacでも動作するのがメリットです。動作についてもJREなどのランタイム環境が必要となります。こちらも日本語やスキーマブラウザに対応しています。
data:image/s3,"s3://crabby-images/31794/317945fe559345dceb796f5d7ebce9c43a8e056a" alt="図15 JXplorerの画面 図15 JXplorerの画面"
LDAP Explorer Tool
http://sourceforge.net/projects/ldaptoolこちらはGQ同様、
(必要に応じてGNUmakefile.configを編集)
% make
# make install
data:image/s3,"s3://crabby-images/02da9/02da947286fed06da72cada0b61d5226e4662fd1" alt="図17 LDAP Explorer Toolの画面 図17 LDAP Explorer Toolの画面"
GUIツールのまとめ
これらのツールの簡単な機能比較表を作ってみました。ただし内容はあくまでも筆者の主観ですので、
名称 | 多機能 | 導入のしやすさ | 日本語対応 | 依存ソフトウェアなど |
---|---|---|---|---|
GQ | △ | ○ | ○ | GTK+ |
phpLDAPadmin | ○ | △ | ○ | PHP, Apacheなど |
Luma | ◎ | △ | ○ | Python, PyQtなど |
JXplorer | ○ | ○ | ○ | Java |
LDAP Explorer Tool | △ | ○ | × | GTK+ |
最後に
今回はldapmodifyコマンドを筆頭に、