Koha/t/db_dependent/LDAP/test_ldap_add.pl
Martin Renvoize e968af4377 Bug 21395: (QA follow-up) Remove some introduced issues
This patch removes some new error cases introduced during rebase

Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
2020-06-29 12:37:02 +02:00

99 lines
2.5 KiB
Perl
Executable file

#!/usr/bin/perl
#
# To start out, try something like this against your LDAP:
# ldapadd -w metavore -D'cn=Manager,dc=metavore,dc=com' -c -f example3.ldif
# ldapmodify -w metavore -D'cn=Manager,dc=metavore,dc=com' -c -f example3.ldif
#
# Then run this script to test perl interaction w/ LDAP.
#
use warnings;
use strict;
use Net::LDAP;
use Net::LDAP::Filter;
my $host = (@ARGV) ? shift : 'localhost';
my $filter = Net::LDAP::Filter->new((@ARGV) ? shift : 'objectClass=inetOrgPerson');
my %params = (
base => (@ARGV) ? shift : 'dc=metavore,dc=com',
filter => $filter,
);
my $ldap = Net::LDAP->new($host) or die "Cannot connect to ldap on $host";
$ldap->bind("cn=Manager," . $params{'base'}, password=>'metavore') or die "Cannot bind to ldap on $host";
&ldap_dse;
&ldap_search;
&ldap_add;
&ldap_search;
sub hashup {
my $query = shift or die "Bad hashup call";
my %memberhash = ();
my $key;
foreach my $user ($query->shift_entry){
foreach my $k (@$user) {
foreach my $k2 ( keys %$k ) {
if ($k2 eq 'type') {
$key = $$k{$k2};
} else {
$memberhash{$key} .= map {$_ . " "} @$k{$k2};
}
}
}
}
return %memberhash;
}
sub recursive_breakdown {
my $dse = shift or return;
if (ref($dse) =~ /HASH/) {
return join "\n", map {"$_\t=> " . recursive_breakdown($dse->{$_})} keys %$dse;
} elsif (ref($dse) =~ /ARRAY/) {
return " (\n" . join("\n", map {recursive_breakdown($_)} @$dse) . "\n)\n";
} else {
return $dse;
}
}
sub ldap_dse {
print "my root DSE: \n";
print recursive_breakdown $ldap->root_dse();
}
sub ldap_search {
my $query = $ldap->search(%params) or print "Search failed\n";
$query->code and die sprintf 'error (code:%s) - %s', $query->code , $query->error;
my $size = scalar($query->entries);
my $i=5;
print "\nNumber of records returned from search: $size.\n";
($size > $i) and print "Displaying the last $i records.\n\n";
foreach ($query->entries) {
($size-- > $i) and next;
$_->dump;
}
}
sub ldap_add {
my $cn = shift or return 0;
my $mail = lc $cn;
$mail =~ s/\s+/./;
print "Adding user $cn\n";
my $add;
$add = $ldap->add(
"cn=$cn," . $params{'base'},
attr => [
cn => $cn,
sn => 'atz',
mail => $mail . '@liblime.com',
telephoneNumber => '1 614 266 9798',
description => 'Implementer and Destroyer',
objectclass => ['person','inetOrgPerson'],
])
or printf "Add failed (code %s): %s\n", ($add->code||'unknown'), ($add->error||'unknown');
}
END {
($ldap) and $ldap->unbind;
print "\ndone.\n";
}