in reply to Authenticating with LDAP

Ignoring issues with maintaing state, getting the username and password from <insert data source here>, etc etc...
use Net::LDAP; # Information you'll need to populate somehow (form?) my $base = 'dc=domain,dc=com'; my $user = 'testuser'; my $pass = 'p4ssw0rd'; my $ldap = Net::LDAP->new($host}); my $mesg = $ldap->search( base => $base, filter => "uid=$user" ); my ($dn); # Search for the user's DN within the base/filter my $max = $mesg->count; for (my $i = 0; $i < $max; $i++) { my $entry = $mesg->entry($i); $dn = $entry->dn; }; if ($dn) { # Bind with the DN & password if the user acct exists $mesg = $ldap->bind ($dn, password => $pass); unless ($mesg->code) { # Set the cookie here... } }
That should at least help you get started. It searches for the user, and if found, attempts to bind as the user (with the user's password). If it can successfully bind, you know the password supplied is correct and you can go ahead and set a cookie or whatnot.

Note that the above code is also untested, and should only be used as something to get you started thinking about the process you'll want to implement.

-s.