123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325 |
- <?php
- /** Message Source
- *
- * Plugin to view the RFC822 raw message output and the bodystructure of a message
- *
- * Copyright (c) 2002 Marc Groot Koerkamp, The Netherlands
- * Licensed under the GNU GPL. For full terms see the file COPYING.
- *
- * $Id$
- * @package plugins
- * @subpackage message_details
- */
- /** @ignore */
- define('SM_PATH','../../');
- /* SquirrelMail required files. */
- require_once(SM_PATH . 'include/validate.php');
- require_once(SM_PATH . 'functions/imap.php');
- require_once(SM_PATH . 'functions/mime.php');
- require_once(SM_PATH . 'config/config.php');
- require_once(SM_PATH . 'functions/prefs.php');
- global $color;
- sqgetGlobalVar('passed_id', $passed_id, SQ_GET);
- sqgetGlobalVar('mailbox', $mailbox, SQ_GET);
- sqgetGlobalVar('username', $username, SQ_SESSION);
- sqgetGlobalVar('key', $key, SQ_COOKIE);
- sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION);
- function CalcEntity($entString, $direction) {
- $result = $entString;
- if ($direction == -1) {
- $pos = strrpos($entString,'.');
- $result = substr($entString,0,$pos);
- }
- switch ($direction) {
- case 0:
- $pos = strrpos($entString,'.');
- if ($pos === false) {
- $entString++;
- $result= $entString;
- }
- else {
- $level = substr($entString,0,$pos);
- $sublevel = substr($entString,$pos+1);
- $sublevel++;
- $result = "$level".'.'."$sublevel";
- }
- break;
- case 1:
- $result = "$entString".".0";
- break;
- default:
- break;
- }
- return ($result);
- }
- function returnTime($start) {
- $stop = gettimeofday();
- $timepassed = 1000000 * ($stop['sec'] - $start['sec']) + $stop['usec'] - $start['usec'];
- return $timepassed;
- }
- function GetMimeProperties($header) {
- }
- $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
- $read = sqimap_mailbox_select($imapConnection, $mailbox);
- $start = gettimeofday();
- $body = sqimap_run_command($imapConnection, "FETCH $passed_id RFC822",true, $response, $readmessage, TRUE);
- $message_body = '';
- $header = false;
- $mimepart = false;
- $bnd_end = false;
- $messageheader = true;
- $messageheaderstart=false;
- $boundaries = array();
- $entities = array();
- session_unregister("entities");
- $pre = '<b>';
- $end = '</b>';
- $entStr = '';
- $bla ='';
- $content = array ();
- $content_indx = -1;
- $contentset = false;
- $count=count($body);
- $body[$count-1] = substr($body[$count-1], -1);
- for ($i=1; $i < $count; $i++) {
- $line = trim($body[$i]);
- if ($line == '') {
- $pre = '';
- $end = '';
- if ($bnd_end) {
- $header = true;
- $mimepart = false;
- } else if ($messageheader) {
- if ($header) {
- $header=false;
- $end = "\n \n".'</div>'."\n \n".'<div class="ent_body" ID="'.$entStr.'B">'."\n \n";
- }
- $mimepart = -$header;
- $bnd_end = false;
- if ($messageheaderstart) {
- $messageheaderstart=false;
- }
- } else if ($messageheaderstart) {
- $messageheader= false;
- } else {
- if ($header) {
- $pre = '';
- $end = "\n \n".'</div>'."\n \n".'<div class="ent_body" ID="'.$entStr.'B">'."\n \n";
- }
- $header = false;
- $mimepart=true;
- }
- $contentset = false;
- $nameset = false;
- } else {
- if (!$header && $messageheader) {
- $messageheaderstart=true;
- if ($pre != '<b>') {
- $pre = '<i><font color ='."$color[1]>";
- $end = '</i></font>';
- }
- }
- if (!$messageheader && !$header ) {
- $mimepart=true;
- } else {
- $mimepart=false;
- }
- $pre = '';
- $end = '';
- }
- if ( ( $header || $messageheader) && (preg_match("/^.*boundary=\"?(.+(?=\")|.+).*/i",$line,$reg)) ) {
- $bnd = $reg[1];
- $bndreg = $bnd;
- $bndreg = str_replace("\\","\\\\",$bndreg);
- $bndreg = str_replace("?","\\?",$bndreg);
- $bndreg = str_replace("+","\\+",$bndreg);
- $bndreg = str_replace(".","\\.",$bndreg);
- $bndreg = str_replace("/","\\/",$bndreg);
- $bndreg = str_replace("-","\\-",$bndreg);
- $bndreg = str_replace("(","\\(",$bndreg);
- $bndreg = str_replace(")","\\)",$bndreg);
- $boundaries[] = array( 'bnd' => $bnd, 'bndreg' => $bndreg);
- $messageheader = false;
- $messageheaderstart=false;
- $mimepart=false;
- if ($entStr=='') {
- $entStr='0';
- } else {
- $entStr = CalcEntity("$entStr",1);
- }
- }
-
- if (($line != '' && $line{0} == '-' || $header) && isset($boundaries[0])) {
- $cnt=count($boundaries)-1;
- $bnd = $boundaries[$cnt]['bnd'];
- $bndreg = $boundaries[$cnt]['bndreg'];
-
- $regstr = '/^--'."($bndreg)".".*".'/';
- if (preg_match($regstr,$line,$reg) ) {
- $bndlen = strlen($reg[1]);
- $bndend = false;
- if (strlen($line) > ($bndlen + 3)) {
- if ($line{$bndlen+2} == '-' && $line{$bndlen+3} == '-')
- $bndend = true;
- }
- if ($bndend) {
- $entStr = CalcEntity("$entStr",-1);
- array_pop($boundaries);
- $pre .= '<b><font color ='."$color[2]>";
- $end .= '</font></b>';
- $header = true;
- $mimepart = false;
- $bnd_end = true;
- $encoding = '';
- } else {
- $header = true;
- $bnd_end = false;
- $entStr = CalcEntity("$entStr",0);
- $content_indx++;
- $content[$content_indx]=array();
- $content[$content_indx]['ent'] = '<A HREF="#'."$entStr \">$entStr".'</a>';
- $pre .= "\n \n".'</div>'."\n \n".'<div class="entheader" ID="'.$entStr.'H"><a name="'."$entStr".'"><b><font color ='."$color[2]>";
- $end .= '</font></b>'."\n";
- $header = true;
- $mimepart = false;
- $encoding = '';
- }
- } else {
- if ($header) {
- if (!$contentset && preg_match("/^.*(content-type:)\s*(\w+)\/(\w+).*/i",$line,$reg)) {
- if (strtolower($reg[2]) == 'message' && strtolower($reg[3]) == 'rfc822') {
- $messageheader = true;
- }
- $content[$content_indx]['type'] = "$reg[2]/$reg[3]";
- $contentset = true;
- if ($reg[2] == 'image') {
- $entities["$entStr"] = array();
- $entities["$entStr"]['entity'] = $entStr;
- $entities["$entStr"]['contenttype']=$reg[2].'/'.$reg[3];
- }
- } else if (!$nameset && preg_match("/^.*(name=\s*)\"(.*)\".*/i",$line,$reg)) {
- $name = htmlspecialchars($reg[2]);
- $content[$content_indx]['name'] = decodeHeader($name);
- $nameset = true;
- if (isset($entities["$entStr"])) {
- $entities["$entStr"]['name'] = urlEncode($reg[2]);
- }
- } else if (preg_match("/^.*(content-transfer-encoding:)\s*(\w+-?(\w+)?).*/i",$line,$reg) ) {
- $encoding = $reg[2];
- if (isset($entities["$entStr"])) {
- $entities["$entStr"]['encoding']=$reg[2];
- }
- $content[$content_indx]['encoding'] = $encoding;
- $mimeentity = '';
- }
- $pre .= '<b><font color ='."$color[7]>";
- $end .= '</font></b>';
- //$mimepart=false;
- }
- }
- }
- /*
- if ($mimepart) {
- if (isset($entities["$entStr"])) {
- if (isset($encoding) && $encoding == 'base64') {
- if (!isset( $entities["$entStr"]['content'])) $entities[$entStr]['content'] = '';
- $entities["$entStr"]['content'] .= $line;
- }
- }
- }
- */
- $line = htmlspecialchars($line);
- $message_body .= "$pre"."$line"."$end".'<BR>'."\r\n";
- }
- //echo returnTime($start).'<BR>';
- $xtra = <<<ECHO
- <STYLE>
- <!--
- .ent_body {
- display:inline;
- }
- .header {
- display:inline;
- }
- .entheader {
- display:inline;
- width:99%;
- }
- //-->
- </STYLE>
- ECHO;
- displayHtmlHeader( _("Message Details"), $xtra, FALSE );
- /* body */
- echo "<body text=\"$color[8]\" bgcolor=\"$color[4]\" link=\"$color[7]\" vlink=\"$color[7]\" alink=\"$color[7]\">\n";
- echo '<code>'."\n";
- echo '<font face = "monospace">'."\n";
- echo '<BR>'."\n";
- //session_register("entities");
- //$keys = array_keys($entities);
- //$start = gettimeofday();
- //foreach ($keys as $key) {
- // if (isset($entities[$key])) {
- // if ($entities[$key]['encoding'] == 'base64') {
- // echo '<img src="message_viewentity.php?ent='.$entities[$key]['entity'].'&name='.$entities[$key]['name'].'"><br>';
- // }
- // }
- //}
- //session_unregister("entities");
- if (count($content) > 0) {
- echo '<h2> Bodystructure </h2>'."\n\n";
- echo '<table border=1 width="98%"><thead>'.
- '<tr bgcolor="'."$color[7]".'">'.
- '<td><b><font color="'."$color[5]".'">Entity</font></b></td>'.
- '<td><b><font color="'."$color[5]".'">Content-Type</font></b></td>'.
- '<td><b><font color="'."$color[5]".'">Name</font></b></td>'.
- '<td><b><font color="'."$color[5]".'">Encoding</font></b></td>'.
- '</tr>'.
- '</thead><tbody>';
- for ($i = 0; $i < count($content);$i++) {
- echo '<tr><td>';
- echo $content[$i]['ent'].'</td><td>';
- if (isset($content[$i]['type'])) {
- echo $content[$i]['type'];
- } else echo 'TEXT/PLAIN';
- echo '</td><td>';
- if (isset($content[$i]['name'])) {
- echo $content[$i]['name'];
- } else echo ' ';
- echo '</td><td>';
- if (isset($content[$i]['encoding'])) {
- echo $content[$i]['encoding'];
- } else echo ' ';
- echo '</td></tr>'."\n";
- }
- echo '</tbody></table><br>'."\n";
- }
- echo '<h2> RFC822 Message body </h2>'."\n\n";
- echo '<div><div class="header">'."\n\n";
- echo $message_body;
- echo '</div></div></font></code></body></html>';
- ?>
|