$saltset[int(rand(64))].$saltset[int(rand(64))] );
- my %attrib = map { /^\s*(\w+)\s+(.*\S)\s*$/; ( $1 => eval(qq("$2")) ); }
+ my $username_attrib;
+ my %attrib = map { /^\s*(\w+)\s+(.*\S)\s*$/;
+ $username_attrib = $1 if $2 eq '$username';
+ ( $1 => eval(qq("$2")) ); }
grep { /^\s*(\w+)\s+(.*\S)\s*$/ }
split("\n", $self->option('attributes'));
my $err_or_queue = $self->ldap_queue( $svc_acct->svcnum, 'insert',
#$svc_acct->username,
+ $username_attrib,
%attrib );
return $err_or_queue unless ref($err_or_queue);
}
sub ldap_insert { #subroutine, not method
- my $dn = ldap_connect(shift, shift, shift);
- my %attrib = @_;
+ my $ldap = ldap_connect(shift, (my $dn = shift), shift);
+ my( $username_attrib, %attrib ) = @_;
+
+ $dn = "$username_attrib=$attrib{$username_attrib}, $dn" if $username_attrib;
+ #icky hack, but should be unsurprising to the LDAPers
+ foreach my $key ( grep { $attrib{$_} =~ /,/ } keys %attrib ) {
+ $attrib{$key} = [ split(/,/, $attrib{$key}) ];
+ }
my $status = $ldap->add( $dn, attrs => [ %attrib ] );
die $status->error if $status->is_error;
sub ldap_connect {
my( $machine, $dn, $password ) = @_;
+ my %bind_options;
+ $bind_options{password} = $password if length($password);
eval "use Net::LDAP";
die $@ if $@;
- my $ldap = Net::LDAP->net($machine) or die $@;
- my $status = $ldap->bind( $dn, password=>$password );
+ my $ldap = Net::LDAP->new($machine) or die $@;
+ my $status = $ldap->bind( $dn, %bind_options );
die $status->error if $status->is_error;
- $dn;
+ $ldap;
}