2004-11-10 06:12:43 +00:00
< ? /*
Copyright ( C ) 2004 by Duane Groth < duane_at_CAcert_dot_org >
This file is part of CAcert .
CAcert has been released under the CAcert Source License
which can be found included with these source files or can
be downloaded from the internet from the following address :
http :// www . cacert . org / src - lic . php
CAcert is distributed WITHOUT ANY WARRANTY ; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE . See the License for more details .
*/ ?>
< ?
require_once ( " ../includes/loggedin.php " );
2006-02-03 18:45:23 +00:00
$id = intval ( $_REQUEST [ 'id' ]);
$oldid = $_REQUEST [ 'oldid' ] = intval ( $_REQUEST [ 'oldid' ]);
2005-02-16 18:11:53 +00:00
if ( $_SESSION [ 'profile' ][ 'points' ] < 50 )
{
header ( " location: /account.php " );
exit ;
}
2004-11-10 06:12:43 +00:00
loadem ( " account " );
2007-11-17 12:27:15 +00:00
2004-11-18 23:21:15 +00:00
if ( $oldid == " 0 " )
2004-11-10 06:12:43 +00:00
{
2006-08-03 13:20:55 +00:00
if ( $_REQUEST [ 'process' ] == _ ( " Submit " ) && $_REQUEST [ 'CSR' ] == " " )
2004-11-10 06:12:43 +00:00
{
2004-11-18 23:21:15 +00:00
$_SESSION [ '_config' ][ 'errmsg' ] = _ ( " You failed to paste a valid GPG/PGP key. " );
2004-11-10 06:12:43 +00:00
$id = $oldid ;
unset ( $oldid );
}
}
2007-02-07 13:50:25 +00:00
$keyid = " " ;
2007-11-17 12:27:15 +00:00
//if($_SESSION["profile"]["id"] != 5897)
//{
// showheader(_("Welcome to CAcert.org"));
2007-11-18 01:16:36 +00:00
// echo "The OpenPGP signing system is currently shutdown due to a maintenance. We hope to get it fixed within the next few hours. We are very sorry for the inconvenience.";
2007-11-17 12:27:15 +00:00
//
// exit(0);
//}
function verifyName ( $name )
{
2007-11-18 01:16:36 +00:00
if ( $name == " " ) return 0 ;
2007-11-17 12:27:15 +00:00
if ( $name == $_SESSION [ 'profile' ][ 'fname' ] . " " . $_SESSION [ 'profile' ][ 'lname' ]) return 1 ;
if ( $name == $_SESSION [ 'profile' ][ 'fname' ] . " " . $_SESSION [ 'profile' ][ 'mname' ] . " " . $_SESSION [ 'profile' ][ 'lname' ]) return 1 ;
if ( $name == $_SESSION [ 'profile' ][ 'fname' ] . " " . $_SESSION [ 'profile' ][ 'lname' ] . " " . $_SESSION [ 'profile' ][ 'suffix' ]) return 1 ;
if ( $name == $_SESSION [ 'profile' ][ 'fname' ] . " " . $_SESSION [ 'profile' ][ 'mname' ] . " " . $_SESSION [ 'profile' ][ 'lname' ] . " " . $_SESSION [ 'profile' ][ 'suffix' ]) return 1 ;
return 0 ;
}
function verifyEmail ( $email )
{
2007-11-18 01:16:36 +00:00
if ( $email == " " ) return 0 ;
2007-11-17 12:27:15 +00:00
if ( mysql_num_rows ( mysql_query ( " select * from `email` where `memid`=' " . $_SESSION [ 'profile' ][ 'id' ] . " ' and `email`=' " . mysql_real_escape_string ( $email ) . " ' and `deleted`=0 and `hash`='' " )) > 0 ) return 1 ;
return 0 ;
}
$ToBeDeleted = array ();
2006-08-03 13:20:55 +00:00
if ( $oldid == " 0 " && $_REQUEST [ 'CSR' ] != " " )
2004-11-10 06:12:43 +00:00
{
2006-08-03 13:20:55 +00:00
$debugkey = $gpgkey = clean_csr ( stripslashes ( $_REQUEST [ 'CSR' ]));
2007-11-17 12:27:15 +00:00
$debugpg = $gpg = trim ( `echo "$gpgkey"|gpg --with-colons --homedir /tmp 2>&1` );
2004-11-10 06:12:43 +00:00
$lines = " " ;
2006-08-03 13:20:55 +00:00
$gpgarr = explode ( " \n " , $gpg );
foreach ( $gpgarr as $line )
2004-11-10 06:12:43 +00:00
{
2007-11-17 12:27:15 +00:00
#echo "Line[]: $line <br/>\n";
2004-11-10 06:12:43 +00:00
if ( substr ( $line , 0 , 3 ) == " pub " || substr ( $line , 0 , 3 ) == " uid " )
{
if ( $lines != " " )
$lines .= " \n " ;
$lines .= $line ;
}
}
$gpg = $lines ;
2004-11-18 23:21:15 +00:00
$expires = 0 ;
2007-11-17 12:27:15 +00:00
$nerr = 0 ; $nok = 0 ;
$multiple = 0 ;
2004-11-10 06:12:43 +00:00
2007-11-17 12:27:15 +00:00
$resulttable = _ ( " The following UIDs were found your key: " ) . " <br/><table border='1'><tr><td>#</td><td> " . _ ( " Name " ) . " </td><td> " . _ ( " Email " ) . " </td><td>Result</td> " ;
$i = 0 ;
2004-11-10 06:12:43 +00:00
foreach ( explode ( " \n " , $gpg ) as $line )
{
2007-11-17 12:27:15 +00:00
$resulttable .= " <tr><td> " .++ $i . " </td> " ;
2004-11-10 06:12:43 +00:00
$name = $comment = " " ;
$bits = explode ( " : " , $line );
if ( $bits [ 0 ] == " pub " && ( ! $keyid || ! $when ))
{
$keyid = $bits [ 4 ];
$when = $bits [ 5 ];
2004-11-18 23:21:15 +00:00
if ( $bits [ 6 ] != " " )
$expires = 1 ;
2004-11-10 06:12:43 +00:00
}
2007-11-18 01:16:36 +00:00
//if(!strstr($line, "@")) continue;
2004-11-10 06:12:43 +00:00
$pos = strpos ( $bits [ 9 ], " ( " ) - 1 ;
$nocomment = 0 ;
if ( $pos < 0 )
{
$nocomment = 1 ;
$pos = strpos ( $bits [ 9 ], " < " ) - 1 ;
}
2007-11-18 01:16:36 +00:00
if ( $pos < 0 )
{
$pos = strlen ( $bits [ 9 ]);
}
2004-11-10 06:12:43 +00:00
$name = trim ( hex2bin ( trim ( substr ( $bits [ 9 ], 0 , $pos ))));
2007-11-17 12:27:15 +00:00
$nameok = verifyName ( $name );
$resulttable .= " <td bgcolor='# " . ( $nameok ? " c0ffc0 " : " ffc0c0 " ) . " '> $name </td> " ;
2007-11-18 01:16:36 +00:00
if ( $nocomment == 0 && ( strpos ( $bits [ 9 ], " ) " ) > $pos ))
2004-11-10 06:12:43 +00:00
{
$pos += 2 ;
$pos2 = strpos ( $bits [ 9 ], " ) " );
$comm = trim ( hex2bin ( trim ( substr ( $bits [ 9 ], $pos , $pos2 - $pos ))));
if ( $comm != " " )
$comment [] = $comm ;
$pos = $pos2 + 3 ;
} else {
$pos = strpos ( $bits [ 9 ], " < " ) + 1 ;
}
2007-11-18 01:16:36 +00:00
$mail = " " ;
if ( preg_match ( " /<([ \ w.-]* \ @[ \ w.-]*)>/ " , $bits [ 9 ], $match )) {
//echo "Found: ".$match[1];
$mail = trim ( hex2bin ( $match [ 1 ]));
}
else
{
//echo "Not found!\n";
}
2007-11-17 12:27:15 +00:00
$emailok = verifyEmail ( $mail );
2007-11-18 01:16:36 +00:00
2007-11-17 12:27:15 +00:00
$resulttable .= " <td bgcolor='# " . ( $emailok ? " c0ffc0 " : " ffc0c0 " ) . " '> $mail </td> " ;
$uidok = 0 ;
if ( $mail == " " and $name == " " )
{
$rmessage = _ ( " Error: Both Name and Email address are empty " );
}
elseif ( $emailok and $nameok )
{
$uidok = 1 ;
$rmessage = _ ( " Name and Email OK. " );
}
elseif ( ! $emailok and ! $nameok )
{
$rmessage = _ ( " Name and Email both cannot be matched with your account. " );
}
elseif ( $emailok and $name == " " )
{
$uidok = 1 ;
2007-11-18 01:16:36 +00:00
$rmessage = _ ( " The email is OK. The name is empty. " );
2007-11-17 12:27:15 +00:00
}
2007-11-18 01:16:36 +00:00
elseif ( $nameok and $mail == " " )
2007-11-17 12:27:15 +00:00
{
$uidok = 1 ;
2007-11-18 01:16:36 +00:00
$rmessage = _ ( " The name is OK. The email is empty. " );
2007-11-17 12:27:15 +00:00
}
elseif ( ! $emailok )
{
$rmessage = _ ( " The email address has not been registered and verified in your account. Please add the email address to your account first. " );
}
elseif ( ! $nameok )
{
$rmessage = _ ( " The name in the UID does not match the name in your account. Please verify the name. " );
}
2004-11-18 23:21:15 +00:00
2007-11-17 12:27:15 +00:00
else
{
$rmessage = _ ( " Error " );
}
if ( $uidok )
{
$nok ++ ;
$resulttable .= " <td> $rmessage </td> " ;
}
else
2004-11-18 23:21:15 +00:00
{
2007-11-17 12:27:15 +00:00
$nerr ++ ;
//$ToBeDeleted[]=$i;
//echo "Adding UID $i\n";
$resulttable .= " <td bgcolor='#ffc0c0'> $rmessage </td> " ;
2004-11-18 23:21:15 +00:00
}
2007-11-17 12:27:15 +00:00
$resulttable .= " </tr> \n " ;
if ( $emailok ) $multiple ++ ;
2004-11-10 06:12:43 +00:00
}
2007-11-17 12:27:15 +00:00
$resulttable .= " </table> " ;
2004-11-10 06:12:43 +00:00
2007-11-17 12:27:15 +00:00
if ( $nok == 0 )
2004-11-10 06:12:43 +00:00
{
2007-11-18 01:16:36 +00:00
showheader ( _ ( " Welcome to CAcert.org " ));
echo $resulttable ;
echo " <font color='#ff0000'> " . _ ( " No valid UIDs found on your key " ) . " </font> " ;
2006-08-03 13:20:55 +00:00
unset ( $_REQUEST [ 'process' ]);
2004-11-10 06:12:43 +00:00
$id = $oldid ;
unset ( $oldid );
2006-08-03 13:20:55 +00:00
$do = `echo "$debugkey\n--\n$debugpg\n--" >> /www/tmp/gpg.debug` ;
2007-11-18 01:16:36 +00:00
exit ();
2004-11-10 06:12:43 +00:00
}
2007-11-17 12:27:15 +00:00
elseif ( $nerr )
{
$resulttable .= _ ( " The unverified UIDs have been removed, the verified UIDs have been signed. " );
}
2004-11-10 06:12:43 +00:00
}
2007-11-17 12:27:15 +00:00
2006-08-03 13:20:55 +00:00
if ( $oldid == " 0 " && $_REQUEST [ 'CSR' ] != " " )
2004-11-10 06:12:43 +00:00
{
2004-11-18 23:21:15 +00:00
$query = " insert into `gpg` set `memid`=' " . $_SESSION [ 'profile' ][ 'id' ] . " ',
2006-04-20 20:48:35 +00:00
`email` = '".mysql_real_escape_string($emailaddies[' 0 '])."' ,
2005-02-16 18:11:53 +00:00
`level` = '1' ,
2006-04-20 20:48:35 +00:00
`expires` = '".mysql_real_escape_string($expires)."' ,
`multiple` = '".mysql_real_escape_string($multiple)."' " ;
2004-11-10 06:12:43 +00:00
mysql_query ( $query );
$id = mysql_insert_id ();
2007-02-07 13:50:25 +00:00
$cwd = '/tmp/gpgspace' . $id ;
mkdir ( $cwd , 0755 );
$fp = fopen ( " $cwd /gpg.csr " , " w " );
2006-08-03 13:20:55 +00:00
fputs ( $fp , clean_csr ( stripslashes ( $_REQUEST [ 'CSR' ])));
2004-11-10 06:12:43 +00:00
fclose ( $fp );
2007-02-07 13:50:25 +00:00
system ( " gpg --homedir $cwd --import $cwd /gpg.csr " );
2007-11-17 12:27:15 +00:00
$debugpg = $gpg = trim ( `gpg --homedir $cwd --with-colons --fixed-list-mode --list-keys $keyid 2>&1` );
$lines = " " ;
$gpgarr = explode ( " \n " , $gpg );
foreach ( $gpgarr as $line )
{
//echo "Line[]: $line <br/>\n";
if ( substr ( $line , 0 , 4 ) == " uid: " )
{
$name = $comment = " " ;
$bits = explode ( " : " , $line );
$pos = strpos ( $bits [ 9 ], " ( " ) - 1 ;
$nocomment = 0 ;
if ( $pos < 0 )
{
$nocomment = 1 ;
$pos = strpos ( $bits [ 9 ], " < " ) - 1 ;
}
$name = trim ( hex2bin ( trim ( substr ( $bits [ 9 ], 0 , $pos ))));
$nameok = verifyName ( $name );
if ( $nocomment == 0 )
{
$pos += 2 ;
$pos2 = strpos ( $bits [ 9 ], " ) " );
$comm = trim ( hex2bin ( trim ( substr ( $bits [ 9 ], $pos , $pos2 - $pos ))));
if ( $comm != " " )
$comment [] = $comm ;
$pos = $pos2 + 3 ;
} else {
$pos = strpos ( $bits [ 9 ], " < " ) + 1 ;
}
$pos2 = strpos ( $bits [ 9 ], " > " , $pos );
$mail = trim ( hex2bin ( trim ( substr ( $bits [ 9 ], $pos , $pos2 - $pos ))));
$emailok = verifyEmail ( $mail );
$uidid = $bits [ 7 ];
if ( $mail == " " and $name == " " )
{
//echo "$uidid will be deleted\n";
$ToBeDeleted [] = $uidid ;
}
elseif ( $emailok and $nameok )
{
}
elseif ( ! $emailok and ! $nameok )
{
//echo "$uidid will be deleted\n";
$ToBeDeleted [] = $uidid ;
}
elseif ( $emailok and $name == " " )
{
}
elseif ( $nameok and $mail = " " )
{
}
elseif ( ! $emailok )
{
//echo "$uidid will be deleted\n";
$ToBeDeleted [] = $uidid ;
}
elseif ( ! $nameok )
{
//echo "$uidid will be deleted\n";
$ToBeDeleted [] = $uidid ;
}
}
}
if ( count ( $ToBeDeleted ) > 0 )
{
2007-02-07 13:50:25 +00:00
$descriptorspec = array (
0 => array ( " pipe " , " r " ), // stdin is a pipe that the child will read from
1 => array ( " pipe " , " w " ), // stdout is a pipe that the child will write to
2 => array ( " pipe " , " w " ) // stderr is a file to write to
);
$stderr = fopen ( 'php://stderr' , 'w' );
2007-11-17 12:27:15 +00:00
//echo "Keyid: $keyid\n";
2007-02-07 13:50:25 +00:00
2007-11-17 12:27:15 +00:00
$process = proc_open ( " /usr/bin/gpg --homedir $cwd --no-tty --command-fd 0 --status-fd 1 --logger-fd 2 --edit-key $keyid " , $descriptorspec , $pipes );
2007-02-07 13:50:25 +00:00
//echo "Process: $process\n";
//fputs($stderr,"Process: $process\n");
if ( is_resource ( $process )) {
2007-11-17 12:27:15 +00:00
//echo("it is a resource\n");
2007-02-07 13:50:25 +00:00
// $pipes now looks like this:
// 0 => writeable handle connected to child stdin
// 1 => readable handle connected to child stdout
// Any error output will be appended to /tmp/error-output.txt
while ( ! feof ( $pipes [ 1 ]))
{
$buffer = fgets ( $pipes [ 1 ], 4096 );
2007-11-17 12:27:15 +00:00
//echo $buffer;
2007-02-07 13:50:25 +00:00
if ( $buffer == " [GNUPG:] GET_BOOL keyedit.sign_all.okay \n " )
{
2007-11-17 12:27:15 +00:00
fputs ( $pipes [ 0 ], " yes \n " );
2007-02-07 13:50:25 +00:00
}
elseif ( $buffer == " [GNUPG:] GOT_IT \n " )
{
}
elseif ( ereg ( " ^ \ [GNUPG: \ ] GET_BOOL keyedit \ .remove \ .uid \ .okay \ s* " , $buffer ))
{
2007-11-17 12:27:15 +00:00
fputs ( $pipes [ 0 ], " yes \n " );
2007-02-07 13:50:25 +00:00
}
2007-11-17 12:27:15 +00:00
elseif ( ereg ( " ^ \ [GNUPG: \ ] GET_LINE keyedit \ .prompt \ s* " , $buffer ))
2007-02-07 13:50:25 +00:00
{
if ( count ( $ToBeDeleted ) > 0 )
{
2007-11-17 12:27:15 +00:00
$delthisuid = array_pop ( $ToBeDeleted );
//echo "Deleting an UID $delthisuid\n";
fputs ( $pipes [ 0 ], " uid " . $delthisuid . " \n " );
2007-02-07 13:50:25 +00:00
}
else
{
2007-11-17 12:27:15 +00:00
//echo "Saving\n";
fputs ( $pipes [ 0 ], $state ? " save \n " : " deluid \n " );
2007-02-07 13:50:25 +00:00
$state ++ ;
}
}
elseif ( $buffer == " [GNUPG:] GOOD_PASSPHRASE \n " )
{
}
elseif ( ereg ( " ^ \ [GNUPG: \ ] KEYEXPIRED " , $buffer ))
{
echo " Key expired! \n " ;
exit ;
}
elseif ( $buffer == " " )
{
2007-11-17 12:27:15 +00:00
//echo "Empty!\n";
2007-02-07 13:50:25 +00:00
}
else
{
echo " ERROR: UNKNOWN $buffer\n " ;
}
}
//echo "Fertig\n";
fclose ( $pipes [ 0 ]);
//echo stream_get_contents($pipes[1]);
fclose ( $pipes [ 1 ]);
// It is important that you close any pipes before calling
// proc_close in order to avoid a deadlock
$return_value = proc_close ( $process );
//echo "command returned $return_value\n";
}
else
{
echo " Keine ressource! \n " ;
}
2007-11-17 12:27:15 +00:00
}
2007-02-07 13:50:25 +00:00
$do = `gpg --homedir $cwd --batch --export-options export-minimal --export $keyid >../csr/gpg-$id.csr` ;
//echo "Export: $do\n";
//$fp = fopen("../csr/gpg-$id.csr", "w");
//fputs($fp, clean_csr(stripslashes($_REQUEST['CSR'])));
//fclose($fp);
2007-11-17 12:27:15 +00:00
if ( 1 )
{
2007-02-07 13:50:25 +00:00
2004-11-10 06:12:43 +00:00
mysql_query ( " update `gpg` set `csr`='../csr/gpg- $id .csr' where `id`=' $id ' " );
2007-01-28 18:34:05 +00:00
waitForResult ( 'gpg' , $id );
2007-11-17 12:27:15 +00:00
}
2004-11-10 06:12:43 +00:00
showheader ( _ ( " Welcome to CAcert.org " ));
2007-11-17 12:27:15 +00:00
echo $resulttable ;
2004-11-10 06:12:43 +00:00
$query = " select * from `gpg` where `id`=' $id ' and `crt`!='' " ;
$res = mysql_query ( $query );
if ( mysql_num_rows ( $res ) <= 0 )
{
2006-08-03 13:20:55 +00:00
echo _ ( " Your certificate request has failed to be processed correctly, please try submitting it again. " ) . " <br> \n " ;
echo _ ( " If this is a re-occuring problem, please send a copy of the key you are trying to signed to support@cacert.org. Thank you. " );
2004-11-10 06:12:43 +00:00
} else {
echo " <pre> " ;
readfile ( " ../crt/gpg- $id .crt " );
echo " </pre> " ;
}
showfooter ();
exit ;
}
2004-11-18 23:21:15 +00:00
$id = intval ( $id );
$_SESSION [ '_config' ][ 'cert' ] = intval ( $cert );
2004-11-10 06:12:43 +00:00
showheader ( _ ( " Welcome to CAcert.org " ));
includeit ( $id , " gpg " );
showfooter ();
?>