зеркало из https://github.com/mozilla/pjs.git
322 строки
8.3 KiB
Perl
Executable File
322 строки
8.3 KiB
Perl
Executable File
#!/usr/bin/perl5
|
||
#############################################################################
|
||
# $Id: conn.pl,v 1.5 2000-10-05 19:47:44 leif%netscape.com Exp $
|
||
#
|
||
# The contents of this file are subject to the Mozilla Public License
|
||
# Version 1.1 (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
|
||
# Test most (all?) of the LDAP::Mozilla::Conn methods. This code
|
||
# needs to be rewritten to use the standard test harness in Perl...
|
||
#
|
||
#############################################################################
|
||
|
||
use Getopt::Std; # To parse command line arguments.
|
||
use Mozilla::LDAP::Conn; # Main "OO" layer for LDAP
|
||
use Mozilla::LDAP::Utils; # LULU, utilities.
|
||
use Mozilla::LDAP::API;
|
||
|
||
use strict;
|
||
no strict "vars";
|
||
|
||
|
||
# Uncomment for somewhat more verbose messages from core modules
|
||
#$LDAP_DEBUG = 1;
|
||
|
||
|
||
#################################################################################
|
||
# Configurations, modify these as needed.
|
||
#
|
||
$BASE = "dc=netscape,dc=com";
|
||
$PEOPLE = "ou=people";
|
||
$GROUPS = "ou=groups";
|
||
$UID = "leif-test";
|
||
$CN = "test-group-1";
|
||
|
||
|
||
#################################################################################
|
||
# Constants, shouldn't have to edit these...
|
||
#
|
||
$APPNAM = "conn.pl";
|
||
$USAGE = "$APPNAM -b base -h host -D bind -w pswd -P cert";
|
||
|
||
|
||
#################################################################################
|
||
# Check arguments, and configure some parameters accordingly..
|
||
#
|
||
if (!getopts('b:h:D:p:s:w:P:'))
|
||
{
|
||
print "usage: $APPNAM $USAGE\n";
|
||
exit;
|
||
}
|
||
%ld = Mozilla::LDAP::Utils::ldapArgs(undef, $BASE);
|
||
$BASE = $ld{"base"};
|
||
Mozilla::LDAP::Utils::userCredentials(\%ld) unless $opt_n;
|
||
|
||
|
||
#################################################################################
|
||
# Get an LDAP connection
|
||
#
|
||
sub getConn
|
||
{
|
||
my ($conn);
|
||
|
||
if ($main::reuseConn)
|
||
{
|
||
if (!defined($main::mainConn))
|
||
{
|
||
$main::mainConn = new Mozilla::LDAP::Conn(\%main::ld);
|
||
die "Could't connect to LDAP server $main::ld{host}"
|
||
unless $main::mainConn;
|
||
}
|
||
return $main::mainConn;
|
||
}
|
||
else
|
||
{
|
||
$conn = new Mozilla::LDAP::Conn(\%main::ld);
|
||
die "Could't connect to LDAP server $main::ld{host}" unless $conn;
|
||
}
|
||
|
||
return $conn;
|
||
}
|
||
|
||
|
||
#################################################################################
|
||
# Some small help functions...
|
||
#
|
||
sub dotPrint
|
||
{
|
||
my ($str) = shift;
|
||
|
||
print $str . '.' x (20 - length($str));
|
||
}
|
||
|
||
sub attributeEQ
|
||
{
|
||
my (@a, @b);
|
||
my ($i);
|
||
|
||
@a = @{$_[0]};
|
||
@b = @{$_[1]};
|
||
return 1 if (($#a < 0) && ($#b < 0));
|
||
return 0 unless ($#a == $#b);
|
||
|
||
@a = sort(@a);
|
||
@b = sort(@b);
|
||
for ($i = 0; $i <= $#a; $i++)
|
||
{
|
||
return 0 unless ($a[$i] eq $b[$i]);;
|
||
}
|
||
|
||
return 1; # We passed all the tests, we're ok.
|
||
}
|
||
|
||
|
||
#################################################################################
|
||
# Test adding, deleting and retrieving entries.
|
||
#
|
||
$filter = "(uid=$UID)";
|
||
undef $reuseConn;
|
||
$conn = getConn();
|
||
$nentry = Mozilla::LDAP::Conn->newEntry();
|
||
|
||
$hash = { "dn" => "uid=$UID, $PEOPLE, $BASE",
|
||
"objectclass" => [ "top", "person", "inetOrgPerson", "mailRecipient" ],
|
||
"uid" => [ $UID ],
|
||
"sn" => [ "Hedstrom" ],
|
||
"givenName" => [ "Leif" ],
|
||
"mail" => [ "leif\@ogre.com" ],
|
||
"cn" => [ "Leif Hedstrom", "Leif P. Hedstrom" ],
|
||
"description" => [ "Hockey Goon", "LDAP dolt" ]
|
||
};
|
||
|
||
$ent = $conn->search($ld{root}, $ld{scope}, $filter);
|
||
$conn->delete($ent->getDN()) if $ent;
|
||
|
||
$nentry->setDN("uid=$UID, $PEOPLE, $BASE");
|
||
$nentry->{objectclass} = [ "top", "person", "inetOrgPerson", "mailRecipient" ];
|
||
$nentry->addValue("uid", $UID);
|
||
$nentry->addValue("sn", "Hedstrom");
|
||
$nentry->addValue("givenName", "Leif");
|
||
$nentry->addValue("cn", "Leif Hedstrom");
|
||
$nentry->addValue("cn", "Leif P. Hedstrom");
|
||
$nentry->addValue("cn", "The Swede");
|
||
($nentry->size("cn") != 3) && die "Entry->addValue() is broken!\n";
|
||
$nentry->addValue("mail", "leif\@ogre.com");
|
||
$nentry->setValue("description", "Hockey Goon", "LDAP dolt");
|
||
$nentry->setValue("jpegPhoto", "Before-Bin: f<><66><01><><EFBFBD> |