2004-10-16 00:28:17 +00:00
< ? /*
2008-04-06 19:45:09 +00:00
LibreSSL - CAcert web application
Copyright ( C ) 2004 - 2008 CAcert Inc .
2004-10-16 00:28:17 +00:00
2008-04-06 19:45:09 +00:00
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 .
2004-10-16 00:28:17 +00:00
2008-04-06 19:45:09 +00:00
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 .
2004-10-16 00:28:17 +00:00
2008-04-06 19:45:09 +00:00
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
2004-10-16 00:28:17 +00:00
*/
2008-08-17 23:25:30 +00:00
$id = 0 ; if ( array_key_exists ( " id " , $_REQUEST )) $id = intval ( $_REQUEST [ 'id' ]);
2008-08-27 23:09:02 +00:00
$expand = " " ;
2006-02-03 18:45:23 +00:00
2004-10-16 00:28:17 +00:00
function showheader ( $title = " CAcert.org " , $title2 = " " )
{
2004-12-07 13:21:06 +00:00
global $id , $PHP_SELF ;
2008-08-27 23:09:02 +00:00
$expand = " " ;
2004-10-16 00:28:17 +00:00
$tmpid = $id ;
if ( $PHP_SELF == " /wot.php " )
$tmpid = $id + 500 ;
2004-11-10 06:12:43 +00:00
if ( $PHP_SELF == " /gpg.php " )
$tmpid = $id + 1000 ;
2005-03-12 19:40:24 +00:00
if ( $PHP_SELF == " /disputes.php " )
$tmpid = $id + 1500 ;
2006-12-09 14:26:30 +00:00
if ( $PHP_SELF == " /advertising.php " )
$tmpid = $id + 2000 ;
2004-10-16 00:28:17 +00:00
switch ( $tmpid )
{
case 1 :
case 2 : $expand = " explode('emailacc'); " ; break ;
case 3 :
case 4 :
case 5 :
case 6 : $expand = " explode('clicerts'); " ; break ;
case 7 :
case 8 :
case 9 : $expand = " explode('domains'); " ; break ;
case 10 :
case 11 :
case 12 :
case 15 : $expand = " explode('servercert'); " ; break ;
case 13 :
case 14 :
case 36 :
2004-10-28 02:13:59 +00:00
case 41 :
2004-10-16 00:28:17 +00:00
case 507 :
2005-12-04 21:04:05 +00:00
case 508 :
case 513 : $expand = " explode('mydetails'); " ; break ;
2004-10-16 00:28:17 +00:00
case 16 :
case 17 :
case 18 :
case 19 : $expand = " explode('clientorg'); " ; break ;
case 20 :
case 21 :
2005-05-23 01:53:59 +00:00
case 22 :
2004-10-16 00:28:17 +00:00
case 23 : $expand = " explode('serverorg'); " ; break ;
case 24 :
case 25 :
case 26 :
case 27 :
case 28 :
case 29 :
case 30 :
case 31 :
case 32 :
case 33 :
case 34 :
case 35 : $expand = " explode('orgadmin'); " ; break ;
2004-10-28 02:13:59 +00:00
case 42 :
2004-11-03 01:45:21 +00:00
case 43 :
2004-12-07 12:35:40 +00:00
case 44 :
case 45 :
case 46 :
case 47 :
case 48 :
2004-12-07 13:21:06 +00:00
case 49 :
2005-11-20 08:16:55 +00:00
case 50 :
2005-12-04 21:04:05 +00:00
case 54 :
2005-11-20 08:16:55 +00:00
case 53 : $expand = " explode('sysadmin'); " ; break ;
2004-10-16 00:28:17 +00:00
case 500 :
case 501 :
case 502 :
case 503 :
case 504 :
case 505 :
2005-05-13 15:34:39 +00:00
case 506 :
case 509 :
case 510 :
2005-12-04 21:04:05 +00:00
case 511 :
case 512 : $expand = " explode('WoT'); " ; break ;
2004-11-10 06:12:43 +00:00
case 1000 :
case 1001 :
case 1002 :
case 1003 :
case 1004 :
case 1005 :
case 1006 :
case 1007 :
case 1008 :
case 1009 :
case 1010 : $expand = " explode('gpg'); " ; break ;
2005-03-12 19:40:24 +00:00
case 1500 :
case 1501 :
case 1502 :
case 1503 :
case 1504 :
case 1505 :
case 1506 :
case 1507 :
case 1508 :
case 1509 :
case 1510 : $expand = " explode('disputes'); " ; break ;
2006-12-09 14:26:30 +00:00
case 2000 :
case 2001 :
case 2002 :
case 2003 :
case 2004 :
case 2005 :
case 2006 :
case 2007 :
case 2008 :
case 2009 : $expand = " explode('advertising'); " ; break ;
2004-10-16 00:28:17 +00:00
}
?> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
< html >
< head >
< title >< ? = $title ?> </title>
2008-08-27 23:09:02 +00:00
< ? if ( array_key_exists ( 'header' , $_SESSION ) && $_SESSION [ '_config' ][ 'header' ] != " " ) { ?> <?=$_SESSION['_config']['header']?><? } ?>
2007-12-19 22:09:05 +00:00
< link rel = " stylesheet " href = " /styles/default.css " type = " text/css " />
2006-12-09 14:26:30 +00:00
< meta http - equiv = " Content-Type " content = " text/html; charset=utf-8 " />
2004-10-16 00:28:17 +00:00
< script language = " JavaScript " type = " text/javascript " >
function explode ( e ) {
if ( document . getElementById ( e ) . style . display == 'none' ) {
document . getElementById ( e ) . style . display = 'block' ;
} else {
document . getElementById ( e ) . style . display = 'none' ;
}
}
function hideall () {
var Nodes = document . getElementsByTagName ( 'ul' )
var max = Nodes . length
for ( var i = 0 ; i < max ; i ++ ) {
var nodeObj = Nodes . item ( i )
if ( nodeObj . className == " menu " ) {
nodeObj . style . display = 'none' ;
}
}
}
</ script >
</ head >
< body onload = " hideall(); explode('home');<?= $expand ?> " >
< div id = " pagecell1 " >
< div id = " pageName " >< br >
2008-03-14 18:11:02 +00:00
< div id = " pageLogo " >< a href = " http://<?= $_SESSION['_config'] ['normalhostname']?> " >< img src = " /images/cacert4.png " border = " 0 " alt = " CAcert.org logo " ></ a ></ div >
2005-06-09 15:21:55 +00:00
< div id = " googlead " >< h2 >< ? = _ ( " Free digital certificates! " ) ?> </h2></div>
2004-10-16 00:28:17 +00:00
</ div >
< div id = " pageNav " >
< div class = " relatedLinks " >
< h3 > CAcert . org </ h3 >
2010-08-03 11:29:09 +00:00
< ul class = " menu " id = " home " >< li >< a href = " /index.php " >< ? = _ ( " Go Home " ) ?> </a></li><li><a href="account.php?id=logout"><?=_("Logout")?></a></li></ul>
2004-10-16 00:28:17 +00:00
</ div >
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('mydetails') " >+ < ? = _ ( " My Details " ) ?> </h3>
2006-08-13 21:08:49 +00:00
< ul class = " menu " id = " mydetails " >< li >< a href = " account.php?id=13 " >< ? = _ ( " Edit " ) ?> </a></li><li><a href="account.php?id=14"><?=_("Change Password")?></a></li><li><a href="account.php?id=41"><?=_("Default Language")?></a></li><li><a href="wot.php?id=8"><?=_("My Listing")?></a></li><li><a href="wot.php?id=13"><?=_("My Location")?></a></li><li><a href="account.php?id=36"><?=_("My Alert Settings")?></a></li><li><a href="wot.php?id=10"><?=_("My Points")?></a></li><?
if ( $_SESSION [ 'profile' ][ 'id' ] == 1 || $_SESSION [ 'profile' ][ 'id' ] == 5897 )
echo " <li><a href='sqldump.php'>SQL Dump</a></li> " ;
?> </ul>
2004-10-16 00:28:17 +00:00
</ div >
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('emailacc') " >+ < ? = _ ( " Email Accounts " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " emailacc " >< li >< a href = " account.php?id=1 " >< ? = _ ( " Add " ) ?> </a></li><li><a href="account.php?id=2"><?=_("View")?></a></li></ul>
</ div >
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('clicerts') " >+ < ? = _ ( " Client Certificates " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " clicerts " >< li >< a href = " account.php?id=3 " >< ? = _ ( " New " ) ?> </a></li><li><a href="account.php?id=5"><?=_("View")?></a></li></ul>
</ div >
2006-11-27 02:17:48 +00:00
< ? if ( $_SESSION [ 'profile' ][ 'points' ] >= 50 ) { ?>
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('gpg') " >+ < ? = _ ( " GPG/PGP Keys " ) ?> </h3>
2006-11-27 02:17:48 +00:00
< ul class = " menu " id = " gpg " >< li >< a href = " gpg.php?id=0 " >< ? = _ ( " New " ) ?> </a></li><li><a href="gpg.php?id=2"><?=_("View")?></a></li></ul>
</ div >
< ? } ?>
2004-10-16 00:28:17 +00:00
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('domains') " >+ < ? = _ ( " Domains " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " domains " >< li >< a href = " account.php?id=7 " >< ? = _ ( " Add " ) ?> </a></li><li><a href="account.php?id=9"><?=_("View")?></a></li></ul>
</ div >
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('servercert') " >+ < ? = _ ( " Server Certificates " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " servercert " >< li >< a href = " account.php?id=10 " >< ? = _ ( " New " ) ?> </a></li><li><a href="account.php?id=12"><?=_("View")?></a></li></ul>
</ div >
2008-08-27 23:09:02 +00:00
< ? if ( mysql_num_rows ( mysql_query ( " select * from `org` where `memid`=' " . intval ( $_SESSION [ 'profile' ][ 'id' ]) . " ' " )) > 0 || $_SESSION [ 'profile' ][ 'orgadmin' ] == 1 ) { ?>
2004-10-16 00:28:17 +00:00
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('clientorg') " >+ < ? = _ ( " Org Client Certs " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " clientorg " >< li >< a href = " account.php?id=16 " >< ? = _ ( " New " ) ?> </a></li><li><a href="account.php?id=18"><?=_("View")?></a></li></ul>
</ div >
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('serverorg') " >+ < ? = _ ( " Org Server Certs " ) ?> </h3>
2004-10-16 00:28:17 +00:00
< ul class = " menu " id = " serverorg " >< li >< a href = " account.php?id=20 " >< ? = _ ( " New " ) ?> </a></li><li><a href="account.php?id=22"><?=_("View")?></a></li></ul>
</ div >
< ? } ?>
2008-08-27 23:09:02 +00:00
< ? if ( mysql_num_rows ( mysql_query ( " select * from `org` where `memid`=' " . intval ( $_SESSION [ 'profile' ][ 'id' ]) . " ' and `masteracc`='1' " )) > 0 || $_SESSION [ 'profile' ][ 'orgadmin' ] == 1 ) { ?>
2004-10-16 00:28:17 +00:00
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('orgadmin') " >+ < ? = _ ( " Org Admin " ) ?> </h3>
2006-11-27 02:02:09 +00:00
< ul class = " menu " id = " orgadmin " >< ? if ( $_SESSION [ 'profile' ][ 'orgadmin' ] == 1 ) { ?> <li><a href="account.php?id=24"><?=_("New Organisation")?></a></li><li><a href="account.php?id=25"><?=_("View Organisations")?></a></li><? } ?><li><a href="account.php?id=35"><?=_("View")?></a></li></ul>
2004-10-16 00:28:17 +00:00
</ div >
< ? } ?>
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('WoT') " >+ < ? = _ ( " CAcert Web of Trust " ) ?> </h3>
2009-04-05 00:30:33 +00:00
< ul class = " menu " id = " WoT " >< li >< a href = " wot.php?id=0 " >< ? = _ ( " About " ) ?> </a></li><li><a href="wot.php?id=12"><?=_("Find an Assurer")?></a></li><li><a href="wot.php?id=3"><?=_("Rules")?></a></li><li><? if($_SESSION['profile']['assurer'] != 1) { ?><a href="wot.php?id=2"><?=_("Becoming an Assurer")?></a><? } else { ?><a href="wot.php?id=5"><?=_("Assure Someone")?></a><? } ?></li><li><a href="wot.php?id=4"><?=_("Trusted ThirdParties")?></a></li><? if($_SESSION['profile']['points'] >= 500) { ?><li><a href="wot.php?id=11"><div style="white-space:nowrap"><?=_("Organisation Assurance")?></div></a></li><? } ?><li><a href="account.php?id=55"><?=_("Training")?></a></li></ul>
2006-08-16 04:15:16 +00:00
</ div >
< div class = " relatedLinks " >
2009-12-04 18:31:35 +00:00
< h3 class = " pointer " onclick = " explode('WoTForms') " >+ < ? = _ ( " CAP Forms " ) ?> </h3><?
2005-06-12 03:51:48 +00:00
$name = $_SESSION [ 'profile' ][ 'fname' ] . " " . $_SESSION [ 'profile' ][ 'mname' ] . " " . $_SESSION [ 'profile' ][ 'lname' ] . " " . $_SESSION [ 'profile' ][ 'suffix' ];
while ( strstr ( $name , " " ))
$name = str_replace ( " " , " " , $name );
$extra = " ?name= " . urlencode ( $name );
2007-12-19 22:09:05 +00:00
$extra .= " &dob= " . urlencode ( $_SESSION [ 'profile' ][ 'dob' ]);
$extra .= " &email= " . urlencode ( $_SESSION [ 'profile' ][ 'email' ]);
2006-08-15 19:00:15 +00:00
2007-12-19 22:09:05 +00:00
$extra2 = " ?assurer= " . urlencode ( $name ) . " &date=now&maxpoints= " . maxpoints ();
2005-06-12 03:51:48 +00:00
?>
2009-12-04 18:31:35 +00:00
< ul class = " menu " id = " WoTForms " >
< li >< a href = " /cap.php<?= $extra ?> " > A4 - < ? = _ ( " WoT Form " ) ?> </a></li>
< li >< a href = " /cap.php<?= $extra ?>&format=letter " > US - < ? = _ ( " WoT Form " ) ?> </a></li>
< ? /* < li >< div style = " white-space:nowrap " >< a href = " /ttp.php<?= $extra ?> " > A4 - < ? = _ ( " TTP Form " ) ?> </a></div></li>
< li >< div style = " white-space:nowrap " >< a href = " /ttp.php<?= $extra ?>&format=letter " > US - < ? = _ ( " TTP Form " ) ?> </a></div></li> */
?>
< ? if ( $_SESSION [ 'profile' ][ 'points' ] > 100 ) { ?> <li><div style="white-space:nowrap"><a href="/cap.php<?=$extra2?>">A4 - <?=_("Assurance Form")?></a></div></li>
< li >< div style = " white-space:nowrap " >< a href = " /cap.php<?= $extra2 ?>&format=letter " > US - < ? = _ ( " Assurance Form " ) ?> </a></div></li>
< ? } ?>
< ? /*
< li >< div style = " white-space:nowrap " >< a href = " /ttp.php " > A4 - < ? = _ ( " Blank TTP Form " ) ?> </a></div></li>
< li >< div style = " white-space:nowrap " >< a href = " /ttp.php?&format=letter " > US - < ? = _ ( " Blank TTP Form " ) ?> </a></div></li>
*/ ?>
< li >< div style = " white-space:nowrap " >< a href = " /cap.php " > A4 - < ? = _ ( " Blank CAP Form " ) ?> </a></div></li>
< li >< div style = " white-space:nowrap " >< a href = " /cap.php?&format=letter " > US - < ? = _ ( " Blank CAP Form " ) ?> </a></div></li></ul>
2004-10-16 00:28:17 +00:00
</ div >
2005-11-20 08:16:55 +00:00
< ? if ( $_SESSION [ 'profile' ][ 'admin' ] == 1 || $_SESSION [ 'profile' ][ 'locadmin' ] == 1 ) { ?>
2004-10-28 02:13:59 +00:00
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('sysadmin') " >+ < ? = _ ( " System Admin " ) ?> </h3>
2005-11-20 08:16:55 +00:00
< ul class = " menu " id = " sysadmin " >< ? if ( $_SESSION [ 'profile' ][ 'admin' ] == 1 ) { ?> <li><a href="account.php?id=42"><?=_("Find User")?></a></li><li><a href="account.php?id=48"><?=_("Find Domain")?></a></li><? } if($_SESSION['profile']['locadmin'] == 1) { ?><li><a href="account.php?id=53"><?=_("Location DB")?></a></li><? } ?></ul>
2004-10-28 02:13:59 +00:00
</ div >
2004-10-16 00:28:17 +00:00
< ? } ?>
2005-03-12 19:40:24 +00:00
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('disputes') " >+ < ? = _ ( " Disputes/Abuses " ) ?> </h3>
2006-08-16 18:47:22 +00:00
< ul class = " menu " id = " disputes " >< li >< a href = " disputes.php?id=0 " >< ? = _ ( " More Information " ) ?> </a></li><li><a href="disputes.php?id=1"><?=_("Email Dispute")?></a></li><li><a href="disputes.php?id=2"><?=_("Domain Dispute")?></a></li><? if($_SESSION['profile']['admin'] == 1) { ?><li><a href="disputes.php?id=3"><?=_("Abuses")?></a></li><? } ?></ul>
2005-03-12 19:40:24 +00:00
</ div >
2006-12-09 14:26:30 +00:00
< ? if ( $_SESSION [ 'profile' ][ 'adadmin' ] >= 1 ) { ?>
< div class = " relatedLinks " >
2009-09-21 18:26:43 +00:00
< h3 class = " pointer " onclick = " explode('advertising') " >+ < ? = _ ( " Advertising " ) ?> </h3>
2006-12-09 14:26:30 +00:00
< ul class = " menu " id = " advertising " >< li >< a href = " advertising.php?id=1 " >< ? = _ ( " New Ad " ) ?> </a></li><li><a href="advertising.php?id=0"><?=_("View Ads")?></a></li></ul>
</ div >
< ? } ?>
2004-10-16 00:28:17 +00:00
</ div >
< div id = " content " >
< div class = " story " >
< h3 >< ? = $title2 ?> </h3>
< ? if ( $_SESSION [ '_config' ][ 'errmsg' ] != " " ) { ?>
2008-08-27 23:09:02 +00:00
< p >< font color = " #ff0000 " size = " +2 " >< ? echo $_SESSION [ '_config' ][ 'errmsg' ]; $_SESSION [ '_config' ][ 'errmsg' ] = " " ; ?> </font></p>
2004-10-16 00:28:17 +00:00
< ? } ?>
< ?
}
function showfooter ()
{
?>
</ div >
</ div >
2007-04-04 12:31:22 +00:00
< div id = " siteInfo " >< a href = " account.php?id=37 " >< ? = _ ( " About Us " ) ?> </a> | <a href="account.php?id=38"><?=_("Donations")?></a> | <a href="http://wiki.cacert.org/wiki/CAcertIncorporated"><?=_("Association Membership")?></a> |
2011-07-27 10:41:01 +00:00
< a href = " /policy/PrivacyPolicy.html " >< ? = _ ( " Privacy Policy " ) ?> </a> | <a href="account.php?id=40"><?=_("Contact Us")?></a>
2009-05-31 16:46:49 +00:00
| & copy ; 2002 -< ? = date ( " Y " ) ?> <?=_("by CAcert")?></div>
2004-10-16 00:28:17 +00:00
</ div >
</ body >
</ html >< ?
}
2011-06-16 09:19:58 +00:00
/**
* Produces a log entry with the error message with log level E_USER_WARN
* and a random ID an returns a message that can be displayed to the user
* including the generated ID
*
* @ param $errormessage string
* The error message that should be logged
* @ return string containing the generated ID that can be displayed to the
* user
*/
function failWithId ( $errormessage ) {
$errorId = rand ();
trigger_error ( " $errormessage . ID: $errorId " , E_USER_WARNING );
return sprintf ( _ ( " Something went wrong when processing your request. " .
" Please contact %s for help and provide them with the " .
" following ID: %d " ),
" <a href='mailto:support@cacert.org?subject=System%20Error%20-%20 " .
" ID%3A%20 $errorId '>support@cacert.org</a> " ,
$errorId );
}
/**
* Checks whether the given CSR contains a vulnerable key
*
* @ param $csr string
* The CSR to be checked
* @ param $encoding string [ optional ]
* The encoding the CSR is in ( for the " -inform " parameter of OpenSSL ,
* currently only " PEM " ( default ) or " DER " allowed )
* @ return string containing the reason if the key is considered weak ,
* empty string otherwise
*/
function checkWeakKeyCSR ( $csr , $encoding = " PEM " )
{
// non-PEM-encodings may be binary so don't use echo
$descriptorspec = array (
0 => array ( " pipe " , " r " ), // STDIN for child
1 => array ( " pipe " , " w " ), // STDOUT for child
);
$encoding = escapeshellarg ( $encoding );
$proc = proc_open ( " openssl req -inform $encoding -text -noout " ,
$descriptorspec , $pipes );
if ( is_resource ( $proc ))
{
fwrite ( $pipes [ 0 ], $csr );
fclose ( $pipes [ 0 ]);
$csrText = " " ;
while ( ! feof ( $pipes [ 1 ]))
{
$csrText .= fread ( $pipes [ 1 ], 8192 );
}
fclose ( $pipes [ 1 ]);
if (( $status = proc_close ( $proc )) !== 0 || $csrText === " " )
{
return _ ( " I didn't receive a valid Certificate Request, hit " .
" the back button and try again. " );
}
} else {
return failWithId ( " checkWeakKeyCSR(): Failed to start OpenSSL " );
}
return checkWeakKeyText ( $csrText );
}
/**
* Checks whether the given X509 certificate contains a vulnerable key
*
* @ param $cert string
* The X509 certificate to be checked
* @ param $encoding string [ optional ]
* The encoding the certificate is in ( for the " -inform " parameter of
* OpenSSL , currently only " PEM " ( default ), " DER " or " NET " allowed )
* @ return string containing the reason if the key is considered weak ,
* empty string otherwise
*/
function checkWeakKeyX509 ( $cert , $encoding = " PEM " )
{
// non-PEM-encodings may be binary so don't use echo
$descriptorspec = array (
0 => array ( " pipe " , " r " ), // STDIN for child
1 => array ( " pipe " , " w " ), // STDOUT for child
);
$encoding = escapeshellarg ( $encoding );
$proc = proc_open ( " openssl x509 -inform $encoding -text -noout " ,
$descriptorspec , $pipes );
if ( is_resource ( $proc ))
{
fwrite ( $pipes [ 0 ], $cert );
fclose ( $pipes [ 0 ]);
$certText = " " ;
while ( ! feof ( $pipes [ 1 ]))
{
$certText .= fread ( $pipes [ 1 ], 8192 );
}
fclose ( $pipes [ 1 ]);
if (( $status = proc_close ( $proc )) !== 0 || $certText === " " )
{
return _ ( " I didn't receive a valid Certificate Request, hit " .
" the back button and try again. " );
}
} else {
return failWithId ( " checkWeakKeyCSR(): Failed to start OpenSSL " );
}
return checkWeakKeyText ( $certText );
}
/**
* Checks whether the given SPKAC contains a vulnerable key
*
* @ param $spkac string
* The SPKAC to be checked
* @ param $spkacname string [ optional ]
* The name of the variable that contains the SPKAC . The default is
* " SPKAC "
* @ return string containing the reason if the key is considered weak ,
* empty string otherwise
*/
function checkWeakKeySPKAC ( $spkac , $spkacname = " SPKAC " )
{
/* Check for the debian OpenSSL vulnerability */
$spkac = escapeshellarg ( $spkac );
$spkacname = escapeshellarg ( $spkacname );
$spkacText = `echo $spkac | openssl spkac -spkac $spkacname` ;
if ( $spkacText === null ) {
return _ ( " I didn't receive a valid Certificate Request, hit the " .
" back button and try again. " );
}
return checkWeakKeyText ( $spkacText );
}
/**
* Checks whether the given text representation of a CSR or a SPKAC contains
* a weak key
*
* @ param $text string
* The text representation of a key as output by the
* " openssl <foo> -text -noout " commands
* @ return string containing the reason if the key is considered weak ,
* empty string otherwise
*/
function checkWeakKeyText ( $text )
{
/* Which public key algorithm? */
if ( ! preg_match ( '/^\s*Public Key Algorithm: ([^\s]+)$/m' , $text ,
$algorithm ))
{
return failWithId ( " checkWeakKeyText(): Couldn't extract the " .
" public key algorithm used " );
} else {
$algorithm = $algorithm [ 1 ];
}
if ( $algorithm === " rsaEncryption " )
{
if ( ! preg_match ( '/^\s*RSA Public Key: \((\d+) bit\)$/m' , $text ,
$keysize ))
{
return failWithId ( " checkWeakKeyText(): Couldn't parse the RSA " .
" key size " );
} else {
$keysize = intval ( $keysize [ 1 ]);
}
if ( $keysize < 1024 )
{
return sprintf ( _ ( " The keys that you use are very small " .
" and therefore insecure. Please generate stronger " .
" keys. More information about this issue can be " .
" found in %sthe wiki%s " ),
" <a href='//wiki.cacert.org/WeakKeys#SmallKey'> " ,
" </a> " );
} elseif ( $keysize < 2048 ) {
// not critical but log so we have some statistics about
// affected users
trigger_error ( " checkWeakKeyText(): Certificate for small " .
" key (< 2048 bit) requested " , E_USER_NOTICE );
}
$debianVuln = checkDebianVulnerability ( $text , $keysize );
if ( $debianVuln === true )
{
return sprintf ( _ ( " The keys you use have very likely been " .
" generated with a vulnerable version of OpenSSL which " .
" was distributed by debian. Please generate new keys. " .
" More information about this issue can be found in " .
" %sthe wiki%s " ),
" <a href='//wiki.cacert.org/WeakKeys#DebianVulnerability'> " ,
" </a> " );
} elseif ( $debianVuln === false ) {
// not vulnerable => do nothing
} else {
return failWithId ( " checkWeakKeyText(): Something went wrong in " .
" checkDebianVulnerability() " );
}
if ( ! preg_match ( '/^\s*Exponent: (\d+) \(0x[0-9a-fA-F]+\)$/m' , $text ,
$exponent ))
{
return failWithId ( " checkWeakKeyText(): Couldn't parse the RSA " .
" exponent " );
} else {
$exponent = $exponent [ 1 ]; // exponent might be very big =>
//handle as string using bc*()
if ( bccomp ( $exponent , " 3 " ) === 0 )
{
return sprintf ( _ ( " The keys you use might be insecure. " .
" Although there is currently no known attack for " .
" reasonable encryption schemes, we're being " .
" cautious and don't allow certificates for such " .
" keys. Please generate stronger keys. More " .
" information about this issue can be found in " .
" %sthe wiki%s " ),
" <a href='//wiki.cacert.org/WeakKeys#SmallExponent'> " ,
" </a> " );
} elseif ( ! ( bccomp ( $exponent , " 65537 " ) >= 0 &&
( bccomp ( $exponent , " 100000 " ) === - 1 ||
// speed things up if way smaller than 2^256
bccomp ( $exponent , bcpow ( " 2 " , " 256 " )) === - 1 ) )) {
// 65537 <= exponent < 2^256 recommended by NIST
// not critical but log so we have some statistics about
// affected users
trigger_error ( " checkWeakKeyText(): Certificate for " .
" unsuitable exponent ' $exponent ' requested " ,
E_USER_NOTICE );
}
}
}
/* No weakness found */
return " " ;
}
/**
* Reimplement the functionality of the openssl - vulnkey tool
*
* @ param $text string
* The text representation of a key as output by the
* " openssl <foo> -text -noout " commands
* @ param $keysize int [ optional ]
* If the key size is already known it can be provided so it doesn ' t
* have to be parsed again . This also skips the check whether the key
* is an RSA key => use wisely
* @ return TRUE if key is vulnerable , FALSE otherwise , NULL in case of error
*/
function checkDebianVulnerability ( $text , $keysize = 0 )
{
$keysize = intval ( $keysize );
if ( $keysize === 0 )
{
/* Which public key algorithm? */
if ( ! preg_match ( '/^\s*Public Key Algorithm: ([^\s]+)$/m' , $text ,
$algorithm ))
{
trigger_error ( " checkDebianVulnerability(): Couldn't extract " .
" the public key algorithm used " , E_USER_WARNING );
return null ;
} else {
$algorithm = $algorithm [ 1 ];
}
if ( $algorithm !== " rsaEncryption " ) return false ;
/* Extract public key size */
if ( ! preg_match ( '/^\s*RSA Public Key: \((\d+) bit\)$/m' , $text ,
$keysize ))
{
trigger_error ( " checkDebianVulnerability(): Couldn't parse the " .
" RSA key size " , E_USER_WARNING );
return null ;
} else {
$keysize = intval ( $keysize [ 1 ]);
}
}
// $keysize has been made sure to contain an int
$blacklist = " /usr/share/openssl-blacklist/blacklist.RSA- $keysize " ;
if ( ! ( is_file ( $blacklist ) && is_readable ( $blacklist )))
{
if ( in_array ( $keysize , array ( 512 , 1024 , 2048 , 4096 )))
{
trigger_error ( " checkDebianVulnerability(): Blacklist for " .
" $keysize bit keys not accessible. Expected at " .
" $blacklist " , E_USER_ERROR );
return null ;
}
trigger_error ( " checkDebianVulnerability(): $blacklist is not " .
" readable. Unsupported key size? " , E_USER_WARNING );
return false ;
}
/* Extract RSA modulus */
if ( ! preg_match ( '/^\s*Modulus \(\d+ bit\):\n' .
'((?:\s*[0-9a-f][0-9a-f]:(?:\n)?)+[0-9a-f][0-9a-f])$/m' ,
$text , $modulus ))
{
trigger_error ( " checkDebianVulnerability(): Couldn't extract the " .
" RSA modulus " , E_USER_WARNING );
return null ;
} else {
$modulus = $modulus [ 1 ];
// strip whitespace and colon leftovers
$modulus = str_replace ( array ( " " , " \t " , " \n " , " : " ), " " , $modulus );
// when using "openssl xxx -text" first byte was 00 in all my test
// cases but 00 not present in the "openssl xxx -modulus" output
if ( $modulus [ 0 ] === " 0 " && $modulus [ 1 ] === " 0 " )
{
$modulus = substr ( $modulus , 2 );
} else {
trigger_error ( " checkDebianVulnerability(): First byte is not " .
" zero " , E_USER_NOTICE );
}
$modulus = strtoupper ( $modulus );
}
/* calculate checksum and look it up in the blacklist */
$checksum = substr ( sha1 ( " Modulus= $modulus\n " ), 20 );
// $checksum and $blacklist should be safe, but just to make sure
$checksum = escapeshellarg ( $checksum );
$blacklist = escapeshellarg ( $blacklist );
exec ( " grep $checksum $blacklist " , $dummy , $debianVuln );
if ( $debianVuln === 0 ) // grep returned something => it is on the list
{
return true ;
} elseif ( $debianVuln === 1 ) { // grep returned nothing
return false ;
} else {
trigger_error ( " checkDebianVulnerability(): Something went wrong " .
" when looking up the key with checksum $checksum in the " .
" blacklist $blacklist " , E_USER_ERROR );
return null ;
}
// Should not get here
return null ;
}
2004-10-16 00:28:17 +00:00
?>