misc fixes; added log function to login to help diagnose errors
[mirror/userdir-ldap-cgi.git] / login.cgi
index cf5a138..3da2b3a 100755 (executable)
--- a/login.cgi
+++ b/login.cgi
@@ -1,6 +1,6 @@
 #!/usr/bin/perl
 
-# $Id: login.cgi,v 1.3 1999/12/09 02:18:14 tausq Exp $
+# $Id: login.cgi,v 1.4 1999/12/11 07:03:45 tausq Exp $
 # (c) 1999 Randolph Chung. Licensed under the GPL. <tausq@debian.org>
 
 use lib '.';
@@ -32,6 +32,9 @@ my $username = $query->param('username');
 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;
 
@@ -41,13 +44,29 @@ if ($mesg->code == LDAP_SUCCESS) {
   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 {
-    print "Location: $proto://$ENV{SERVER_NAME}/$config{websearchurl}?id=$username&authtoken=$cryptid,$hrkey\n\n";
+    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;