зеркало из https://github.com/mozilla/gecko-dev.git
163 строки
3.7 KiB
Perl
163 строки
3.7 KiB
Perl
#############################################################################
|
|
# $Id: test.pl,v 1.6 1998/08/13 09:14:44 leif Exp $
|
|
#
|
|
# The contents of this file are subject to the Mozilla Public License
|
|
# Version 1.0 (the "License"); you may not use this file except in
|
|
# compliance with the License. You may obtain a copy of the License at
|
|
# http://www.mozilla.org/MPL/
|
|
#
|
|
# Software distributed under the License is distributed on an "AS IS"
|
|
# basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing rights and limitations
|
|
# under the License.
|
|
#
|
|
# The Original Code is PerLDAP. The Initial Developer of the Original
|
|
# Code is Netscape Communications Corp. and Clayton Donley. Portions
|
|
# created by Netscape are Copyright (C) Netscape Communications
|
|
# Corp., portions created by Clayton Donley are Copyright (C) Clayton
|
|
# Donley. All Rights Reserved.
|
|
#
|
|
# Contributor(s):
|
|
#
|
|
# DESCRIPTION
|
|
# Before `make install' is performed this script should be runnable with
|
|
# `make test'. After `make install' it should work as `perl test.pl'
|
|
#
|
|
#############################################################################
|
|
|
|
######################### We start with some black magic to print on failure.
|
|
|
|
# Change 1..1 below to 1..last_test_to_print .
|
|
# (It may become useful if the test is moved to ./t subdirectory.)
|
|
|
|
BEGIN { $| = 1; print "1..8\n"; }
|
|
END {print "modinit - not ok\n" unless $loaded;}
|
|
use Mozilla::LDAP::API qw(:constant :api :ssl);
|
|
$loaded = 1;
|
|
print "modinit - ok\n";
|
|
|
|
######################### End of black magic.
|
|
|
|
|
|
$attrs = [];
|
|
|
|
$ldap_host = $ENV{"LDAPHOST"};
|
|
$filter = $ENV{"TESTFILTER"};
|
|
$BASEDN = $ENV{"LDAPBASE"};
|
|
|
|
if (!$ldap_host)
|
|
{
|
|
print "\nEnter LDAP Server: ";
|
|
chomp($ldap_host = <>);
|
|
}
|
|
|
|
if (!$filter)
|
|
{
|
|
print "Enter Search Filter (ex. uid=abc123): ";
|
|
chomp($filter = <>);
|
|
}
|
|
|
|
if (!$BASEDN)
|
|
{
|
|
print "Enter LDAP Search Base (ex. o=Org, c=US): ";
|
|
chomp($BASEDN = <>);
|
|
}
|
|
|
|
print "\n";
|
|
|
|
|
|
##
|
|
## Initialize LDAP Connection
|
|
##
|
|
|
|
if (($ld = ldap_init($ldap_host,LDAP_PORT)) == -1)
|
|
{
|
|
print "open - not ok\n";
|
|
exit -1;
|
|
}
|
|
print "open - ok\n";
|
|
|
|
##
|
|
## Bind as DN, PASSWORD (NULL,NULL) on LDAP connection $ld
|
|
##
|
|
|
|
if (ldap_simple_bind_s($ld,"","") != LDAP_SUCCESS)
|
|
{
|
|
ldap_perror($ld,"bind_s");
|
|
print "bind - not ok\n";
|
|
exit -1;
|
|
}
|
|
print "bind - ok\n";
|
|
|
|
##
|
|
## ldap_search_s - Synchronous Search
|
|
##
|
|
|
|
if (ldap_search_s($ld,$BASEDN,LDAP_SCOPE_SUBTREE,$filter,$attrs,0,$result) != LDAP_SUCCESS)
|
|
{
|
|
ldap_perror($ld,"search_s");
|
|
print "search - not ok\n";
|
|
}
|
|
print "search - ok\n";
|
|
|
|
##
|
|
## ldap_count_entries - Count Matched Entries
|
|
##
|
|
|
|
if (($count = ldap_count_entries($ld,$result)) == -1)
|
|
{
|
|
ldap_perror($ld,"count_entry");
|
|
print "count - not ok\n";
|
|
}
|
|
print "count - ok - $count\n";
|
|
|
|
##
|
|
## first_entry - Get First Matched Entry
|
|
## next_entry - Get Next Matched Entry
|
|
##
|
|
|
|
for ($ent = ldap_first_entry($ld,$result); $ent; $ent = ldap_next_entry($ld,$ent))
|
|
{
|
|
|
|
##
|
|
## ldap_get_dn - Get DN for Matched Entries
|
|
##
|
|
|
|
if (($dn = ldap_get_dn($ld,$ent)) ne "")
|
|
{
|
|
print "getdn - ok - $dn\n";
|
|
} else {
|
|
ldap_perror($ld,"get_dn");
|
|
print "getdn - not ok\n";
|
|
}
|
|
|
|
for ($attr = ldap_first_attribute($ld,$ent,$ber); $attr; $attr = ldap_next_attribute($ld,$ent,$ber))
|
|
{
|
|
print "firstatt - ok - $attr\n";
|
|
|
|
##
|
|
## ldap_get_values
|
|
##
|
|
|
|
@vals = ldap_get_values($ld,$ent,$attr);
|
|
if ($#vals >= 0)
|
|
{
|
|
foreach $val (@vals)
|
|
{
|
|
print "getvals - ok - $val\n";
|
|
}
|
|
} else {
|
|
print "getvals - not ok\n";
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
##
|
|
## Unbind LDAP Connection
|
|
##
|
|
|
|
ldap_unbind($ld);
|
|
|