This commit is contained in:
ceb 2002-11-24 01:45:28 +00:00
parent fa68a06371
commit ba80c900a7

View File

@ -36,21 +36,27 @@
*/ */
error_reporting(0); error_reporting(0);
$ldap = ldap_connect($GLOBALS['phpgw_info']['server']['ldap_host']); if(!$ldap = @ldap_connect($GLOBALS['phpgw_info']['server']['ldap_host']))
if (! $ldap)
{ {
$GLOBALS['phpgw']->log->message('F-Abort, Failed connecting to LDAP server for authenication, execution stopped'); $GLOBALS['phpgw']->log->message('F-Abort, Failed connecting to LDAP server for authenication, execution stopped');
$GLOBALS['phpgw']->log->commit(); $GLOBALS['phpgw']->log->commit();
return False;
} }
/* Login with the LDAP Admin. User to find the User DN. */
if(!@ldap_bind($ldap, $GLOBALS['phpgw_info']['server']['ldap_root_dn'], $GLOBALS['phpgw_info']['server']['ldap_root_pw']))
{
return False;
}
/* find the dn for this uid, the uid is not always in the dn */ /* find the dn for this uid, the uid is not always in the dn */
$sri = ldap_search($ldap, $GLOBALS['phpgw_info']['server']['ldap_context'], 'uid='.$username); $attributes = array( "uid", "dn" );
$sri = ldap_search($ldap, $GLOBALS['phpgw_info']['server']['ldap_context'], "(uid=$username)", $attributes);
$allValues = ldap_get_entries($ldap, $sri); $allValues = ldap_get_entries($ldap, $sri);
if ($allValues['count'] > 0) if ($allValues['count'] > 0)
{ {
/* we only care about the first dn */ /* we only care about the first dn */
$userDN = $allValues[0]['dn']; $userDN = $allValues[0]['dn'];
/* /*
generate a bogus password to pass if the user doesn't give us one generate a bogus password to pass if the user doesn't give us one
this gets around systems that are anonymous search enabled this gets around systems that are anonymous search enabled
@ -60,7 +66,7 @@
$passwd = crypt(microtime()); $passwd = crypt(microtime());
} }
/* try to bind as the user with user suplied password */ /* try to bind as the user with user suplied password */
if (ldap_bind($ldap,$userDN, $passwd)) if (@ldap_bind($ldap, $userDN, $passwd))
{ {
return True; return True;
} }