From 72bc37cfa4fac9546326b3d0b2a4054b6d8a71b4 Mon Sep 17 00:00:00 2001 From: Günther Deschner Date: Mon, 26 Jun 2006 16:14:40 +0000 Subject: r16521: Fix different extended_dn handling for win2k/2k3 (thanks to Frederic Brin at Novell). Guenther (This used to be commit f19f781e15da98cfaa94c71fc455fe095dac7b4d) --- examples/misc/adssearch.pl | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) (limited to 'examples/misc') diff --git a/examples/misc/adssearch.pl b/examples/misc/adssearch.pl index a26bb3b6c4..6a677fa205 100755 --- a/examples/misc/adssearch.pl +++ b/examples/misc/adssearch.pl @@ -87,7 +87,7 @@ GetOptions( 'base|b=s' => \$opt_base, 'D|DN=s' => \$opt_binddn, 'debug=i' => \$opt_debug, - 'extendeddn|e' => \$opt_display_extendeddn, + 'extendeddn|e=i' => \$opt_display_extendeddn, 'help' => \$opt_help, 'host|h=s' => \$opt_host, 'machine|P' => \$opt_machine, @@ -1396,12 +1396,12 @@ sub gen_controls { > ); - my $ctl_extended_dn_val = $asn_extended_dn->encode( mode => '1'); - my $ctl_extended_dn =Net::LDAP::Control->new( - type => $ads_controls{'LDAP_SERVER_EXTENDED_DN_OID'}, - critical => 'true', - value => $ctl_extended_dn_val); - + # only w2k3 accepts '1' and needs the ctl_val, w2k does not accept a ctl_val + my $ctl_extended_dn_val = $asn_extended_dn->encode( mode => $opt_display_extendeddn); + my $ctl_extended_dn = Net::LDAP::Control->new( + type => $ads_controls{'LDAP_SERVER_EXTENDED_DN_OID'}, + critical => 'true', + value => $opt_display_extendeddn ? $ctl_extended_dn_val : ""); # setup notify control my $ctl_notification = Net::LDAP::Control->new( @@ -1421,7 +1421,7 @@ sub gen_controls { push(@ctrls_s, "LDAP_PAGED_RESULT_OID_STRING" ); } - if ($opt_display_extendeddn) { + if (defined($opt_display_extendeddn)) { push(@ctrls, $ctl_extended_dn); push(@ctrls_s, "LDAP_SERVER_EXTENDED_DN_OID"); } -- cgit