(Problems on cert login with "duplicate" serial numbers)
This commit is contained in:
Wytze van der Raay 2011-09-07 10:30:32 +00:00
parent d67dd3d438
commit d98d23ff5b
3 changed files with 65 additions and 13 deletions

50
includes/lib/general.php Normal file
View file

@ -0,0 +1,50 @@
<? /*
LibreSSL - CAcert web application
Copyright (C) 2004-2011 CAcert Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
/**
* Checks if the user may log in and retrieve the user id
*
* Usually called with $_SERVER['SSL_CLIENT_M_SERIAL'] and
* $_SERVER['SSL_CLIENT_I_DN_CN']
*
* @param $serial string
* usually $_SERVER['SSL_CLIENT_M_SERIAL']
* @param $issuer_cn string
* usually $_SERVER['SSL_CLIENT_I_DN_CN']
* @return int
* the user id, -1 in case of error
*/
function get_user_id_from_cert($serial, $issuer_cn)
{
$query = "select `memid` from `emailcerts` where
`serial`='".mysql_escape_string($serial)."' and
`rootcert`= (select `id` from `root_certs` where
`Cert_Text`='".mysql_escape_string($issuer_cn)."') and
`revoked`=0 and disablelogin=0 and
UNIX_TIMESTAMP(`expire`) - UNIX_TIMESTAMP() > 0";
$res = mysql_query($query);
if(mysql_num_rows($res) > 0)
{
$row = mysql_fetch_assoc($res);
return intval($row['memid']);
}
return -1;
}
?>

View file

@ -16,6 +16,7 @@
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
include_once("../includes/lib/general.php");
if($_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname'] && $_SESSION['profile']['id'] > 0 && $_SESSION['profile']['loggedin'] != 0) if($_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname'] && $_SESSION['profile']['id'] > 0 && $_SESSION['profile']['loggedin'] != 0)
{ {
@ -41,14 +42,11 @@
if($_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname'] && ($_SESSION['profile']['id'] == 0 || $_SESSION['profile']['loggedin'] == 0)) if($_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname'] && ($_SESSION['profile']['id'] == 0 || $_SESSION['profile']['loggedin'] == 0))
{ {
$query = "select * from `emailcerts` where `serial`='${_SERVER['SSL_CLIENT_M_SERIAL']}' and `revoked`=0 and disablelogin=0 and $user_id = get_user_id_from_cert($_SERVER['SSL_CLIENT_M_SERIAL'],
UNIX_TIMESTAMP(`expire`) - UNIX_TIMESTAMP() > 0"; $_SERVER['SSL_CLIENT_I_DN_CN']);
$res = mysql_query($query);
if(mysql_num_rows($res) > 0) if($user_id >= 0)
{ {
$row = mysql_fetch_assoc($res);
$_SESSION['profile']['loggedin'] = 0; $_SESSION['profile']['loggedin'] = 0;
$_SESSION['profile'] = ""; $_SESSION['profile'] = "";
foreach($_SESSION as $key) foreach($_SESSION as $key)
@ -61,7 +59,8 @@
session_unregister($key); session_unregister($key);
} }
$_SESSION['profile'] = mysql_fetch_assoc(mysql_query("select * from `users` where `id`='".$row['memid']."'")); $_SESSION['profile'] = mysql_fetch_assoc(mysql_query(
"select * from `users` where `id`='".$user_id."'"));
if($_SESSION['profile']['locked'] == 0) if($_SESSION['profile']['locked'] == 0)
$_SESSION['profile']['loggedin'] = 1; $_SESSION['profile']['loggedin'] = 1;
else else

View file

@ -148,13 +148,16 @@
if($id == 4 && $_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname']) if($id == 4 && $_SERVER['HTTP_HOST'] == $_SESSION['_config']['securehostname'])
{ {
$query = "select * from `emailcerts` where `serial`='$_SERVER[SSL_CLIENT_M_SERIAL]' and `revoked`=0 and disablelogin=0 and include_once("../includes/lib/general.php");
UNIX_TIMESTAMP(`expire`) - UNIX_TIMESTAMP() > 0"; $user_id = get_user_id_from_cert($_SERVER['SSL_CLIENT_M_SERIAL'],
$res = mysql_query($query); $_SERVER['SSL_CLIENT_I_DN_CN']);
if(mysql_num_rows($res) > 0)
if($user_id >= 0)
{ {
$row = mysql_fetch_assoc($res); $_SESSION['profile'] = mysql_fetch_assoc(mysql_query(
$_SESSION['profile'] = mysql_fetch_assoc(mysql_query("select * from `users` where `id`='$row[memid]' and `deleted`=0 and `locked`=0")); "select * from `users` where
`id`='$user_id' and `deleted`=0 and `locked`=0"));
if($_SESSION['profile']['id'] != 0) if($_SESSION['profile']['id'] != 0)
{ {
$_SESSION['profile']['loggedin'] = 1; $_SESSION['profile']['loggedin'] = 1;