#!/usr/bin/perl
-# $Id: login.cgi,v 1.4 1999/12/11 07:03:45 tausq Exp $
+# $Id: login.cgi,v 1.5 1999/12/13 05:03:47 tausq Exp $
# (c) 1999 Randolph Chung. Licensed under the GPL. <tausq@debian.org>
use lib '.';
my $password = $query->param('password');
my $binddn = "uid=$username,$config{basedn}";
-&logf(sprintf("proto=[%s]; key=[%s]; hrkey=[%s]; username=[%s]; passwd=[%s]; binddn=[%s]",
- $proto, $key, $hrkey, $username, ($password ? "shh!" : "(null)"), $binddn));
-
my $mesg = $ldap->bind($binddn, password => $password);
$mesg->sync;
if ($query->param('update')) {
my $url = "$proto://$ENV{SERVER_NAME}/$config{webupdateurl}?id=$username&authtoken=$cryptid,$hrkey&editdn=";
$url .= uri_escape("uid=$username,$config{basedn}", "\x00-\x40\x7f-\xff");
- &logf("redirect url = [$url]");
print "Location: $url\n\n";
} else {
my $url = "$proto://$ENV{SERVER_NAME}/$config{websearchurl}?id=$username&authtoken=$cryptid,$hrkey";
- &logf("redirect url = [$url]");
print "Location: $url\n\n";
}
$ldap->unbind;
} else {
- &logf("bad auth");
print "Content-type: text/html\n\n";
print "<html><body><h1>Not authenticated</h1></body></html>\n";
}
-sub logf {
- my $msg = shift;
- my $t = localtime;
-
- if (open(L, ">>$config{weblogfile}")) {
- print L sprintf("[%s] %s: %s\n", $ENV{REMOTE_ADDR}, $t, $msg);
- close L;
- }
-}
-
-exit 0;