X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=plugins%2Fmail_fetch%2Ffetch.php;h=898cecc0275c33c2f3c46c34e569af001278703d;hb=6c84ba1ec45ab854c37b6f65c5b4d84ab1c7aad4;hp=1ac19ee54ddc899ee7f70bf1228b1f10eed25907;hpb=22476f18b2ff4ae81fd4a52e9f335691e31b7750;p=squirrelmail.git diff --git a/plugins/mail_fetch/fetch.php b/plugins/mail_fetch/fetch.php index 1ac19ee5..898cecc0 100644 --- a/plugins/mail_fetch/fetch.php +++ b/plugins/mail_fetch/fetch.php @@ -3,14 +3,17 @@ /** * mail_fetch/fetch.php * - * Copyright (c) 1999-2003 The SquirrelMail Project Team + * Copyright (c) 1999-2005 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * Fetch code. * * $Id$ + * @package plugins + * @subpackage mail_fetch */ +/** @ignore */ define('SM_PATH','../../'); require_once(SM_PATH . 'include/validate.php'); @@ -21,7 +24,7 @@ require_once(SM_PATH . 'plugins/mail_fetch/class.POP3.php'); require_once(SM_PATH . 'plugins/mail_fetch/functions.php' ); require_once(SM_PATH . 'functions/html.php' ); -/* globals */ +/* globals */ sqgetGlobalVar('username', $username, SQ_SESSION); sqgetGlobalVar('key', $key, SQ_COOKIE); sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); @@ -37,55 +40,51 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); flush(); } - displayPageHeader($color, 'None'); + function Mail_Fetch_Servers() { + global $data_dir, $username; - $mailfetch_server_number = getPref($data_dir, $username, 'mailfetch_server_number'); - if (!isset($mailfetch_server_number) || ($mailfetch_server_number < 1)) { - $mailfetch_server_number = 0; - } - $mailfetch_cypher = getPref($data_dir, $username, 'mailfetch_cypher'); - for ($i = 0;$i < $mailfetch_server_number;$i++) { - $mailfetch_server_[$i] = getPref($data_dir, $username, "mailfetch_server_$i"); - $mailfetch_port_[$i] = getPref($data_dir, $username, "mailfetch_port_$i"); - $mailfetch_alias_[$i] = getPref($data_dir, $username, "mailfetch_alias_$i"); - if($mailfetch_alias_[$i] == '') { - $mailfetch_alias_[$i] = $mailfetch_server_[$i]; + $mailfetch['server_number'] = getPref($data_dir, $username, "mailfetch_server_number"); + if (!isset($mailfetch['server_number']) || ($mailfetch['server_number'] < 1)) { + $mailfetch['server_number'] = 0; } - $mailfetch_user_[$i] = getPref($data_dir, $username, "mailfetch_user_$i"); - $mailfetch_pass_[$i] = getPref($data_dir, $username, "mailfetch_pass_$i"); - $mailfetch_lmos_[$i] = getPref($data_dir, $username, "mailfetch_lmos_$i"); - $mailfetch_login_[$i] = getPref($data_dir, $username, "mailfetch_login_$i"); - $mailfetch_uidl_[$i] = getPref($data_dir, $username, "mailfetch_uidl_$i"); - $mailfetch_subfolder_[$i] = getPref($data_dir, $username, "mailfetch_subfolder_$i"); - if($mailfetch_cypher == 'on') { - $mailfetch_pass_[$i] = decrypt( $mailfetch_pass_[$i] ); - } - if ($mailfetch_pass_[$i] == '') { - sqgetGlobalVar("pass_$i", $mailfetch_pass_[$i], SQ_POST); + $mailfetch['cypher'] = getPref($data_dir, $username, "mailfetch_cypher"); + for ($i = 0; $i < $mailfetch['server_number']; $i++) { + $mailfetch[$i]['server'] = getPref($data_dir, $username, "mailfetch_server_$i"); + $mailfetch[$i]['port'] = getPref($data_dir, $username, "mailfetch_port_$i"); + $mailfetch[$i]['alias'] = getPref($data_dir, $username, "mailfetch_alias_$i"); + $mailfetch[$i]['user'] = getPref($data_dir, $username, "mailfetch_user_$i"); + $mailfetch[$i]['pass'] = getPref($data_dir, $username, "mailfetch_pass_$i"); + if($mailfetch['cypher'] == 'on') { + $mailfetch[$i]['pass'] = decrypt($mailfetch[$i]['pass']); + } + if ($mailfetch[$i]['pass'] == '') { + sqgetGlobalVar("pass_$i", $mailfetch[$i]['pass'], SQ_POST); + } + $mailfetch[$i]['lmos'] = getPref($data_dir, $username, "mailfetch_lmos_$i"); + $mailfetch[$i]['login'] = getPref($data_dir, $username, "mailfetch_login_$i"); + $mailfetch[$i]['uidl'] = getPref($data_dir, $username, "mailfetch_uidl_$i"); + $mailfetch[$i]['subfolder'] = getPref($data_dir, $username, "mailfetch_subfolder_$i"); + if($mailfetch[$i]['alias'] == '') { + $mailfetch[$i]['alias'] == $mailfetch[$i]['server']; + } } + return $mailfetch; } - echo '
'; + function Mail_Fetch_Select_Server($mailfetch) { + global $PHP_SELF; - echo html_tag( 'table', - html_tag( 'tr', - html_tag( 'td', '' . _("Remote POP server Fetching Mail") . '', 'center', $color[0] ) - ) , - 'center', '', 'width="95%" cols="1"' ); - - if (!isset( $server_to_fetch ) ) { - - echo '
' . - "
" . + echo '
' . + '' . html_tag( 'table', '', 'center', '', 'width="70%" cols="2"' ) . html_tag( 'tr' ) . html_tag( 'td', _("Select Server:") . '    ', 'right' ) . html_tag( 'td', '', 'left' ) . '' . @@ -93,53 +92,79 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); ''; //if password not set, ask for it - for ($i = 0;$i < $mailfetch_server_number;$i++) { - if ($mailfetch_pass_[$i] == '') { + for ($i = 0;$i < $mailfetch['server_number'];$i++) { + if ($mailfetch[$i]['pass'] == '') { echo html_tag( 'tr', html_tag( 'td', _("Password for") . ' ' . - htmlspecialchars($mailfetch_alias_[$i]) . + htmlspecialchars($mailfetch[$i]['alias']) . ':     ', 'right' ) . - html_tag( 'td', '', 'left' ) + html_tag( 'td', '', 'left' ) ); } } echo html_tag( 'tr', html_tag( 'td', ' ' ) . - html_tag( 'td', '', 'left' ) + html_tag( 'td', '', 'left' ) ) . '
'; + } + + $mailfetch = Mail_Fetch_Servers(); + displayPageHeader($color, 'None'); + + echo '
'; + + echo html_tag( 'table', + html_tag( 'tr', + html_tag( 'td', '' . _("Remote POP server Fetching Mail") . '', 'center', $color[0] ) + ) , + 'center', '', 'width="95%" cols="1"' ); + + + /* there are no servers defined yet... */ + if($mailfetch['server_number'] == 0) { + echo '

' . _("No POP3 servers configured yet.") . '

'; + displayInternalLink('plugins/mail_fetch/options.php', + _("Click here to go to the options page.") ); + echo ''; + exit(); + } + + // get $server_to_fetch from globals, if not set display a choice to the user + if (! sqgetGlobalVar('server_to_fetch', $server_to_fetch, SQ_POST) ) { + Mail_Fetch_Select_Server($mailfetch); exit(); } if ( $server_to_fetch == 'all' ) { $i_start = 0; - $i_stop = $mailfetch_server_number; + $i_stop = $mailfetch['server_number']; } else { $i_start = $server_to_fetch; $i_stop = $i_start+1; } for ($i_loop=$i_start;$i_loop<$i_stop;$i_loop++) { - $mailfetch_server = $mailfetch_server_[$i_loop]; - $mailfetch_port = $mailfetch_port_[$i_loop]; - $mailfetch_user = $mailfetch_user_[$i_loop]; - $mailfetch_pass = $mailfetch_pass_[$i_loop]; - $mailfetch_lmos = $mailfetch_lmos_[$i_loop]; - $mailfetch_login = $mailfetch_login_[$i_loop]; - $mailfetch_uidl = $mailfetch_uidl_[$i_loop]; - $mailfetch_subfolder = $mailfetch_subfolder_[$i_loop]; + $mailfetch_server = $mailfetch[$i_loop]['server']; + $mailfetch_port = $mailfetch[$i_loop]['port']; + $mailfetch_user = $mailfetch[$i_loop]['user']; + $mailfetch_pass = $mailfetch[$i_loop]['pass']; + $mailfetch_lmos = $mailfetch[$i_loop]['lmos']; + $mailfetch_login = $mailfetch[$i_loop]['login']; + $mailfetch_uidl = $mailfetch[$i_loop]['uidl']; + $mailfetch_subfolder = $mailfetch[$i_loop]['subfolder']; if($mailfetch_subfolder == '') { $mailfetch_subfolder == 'INBOX'; } $pop3 = new POP3($mailfetch_server, 60); - echo '
' . + echo '
' . html_tag( 'table', html_tag( 'tr', - html_tag( 'td', '' . _("Fetching from ") . - htmlspecialchars($mailfetch_alias_[$i_loop]) . + html_tag( 'td', '' . _("Fetching from ") . + htmlspecialchars($mailfetch[$i_loop]['alias']) . '', 'center' ) , '', $color[9] ) , @@ -158,7 +183,7 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); Mail_Fetch_Status(_("Opening POP server")); $Count = $pop3->login($mailfetch_user, $mailfetch_pass); if (($Count == false || $Count == -1) && $pop3->ERROR != '') { - Mail_Fetch_Status(_("Login Failed:") . ' ' . $pop3->ERROR ); + Mail_Fetch_Status(_("Login Failed:") . ' ' . htmlspecialchars($pop3->ERROR) ); continue; } @@ -168,7 +193,7 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); $i = 1; for ($j = 1; $j < sizeof($msglist); $j++) { - if ($msglist["$j"] == $mailfetch_uidl) { + if ($msglist[$j] == $mailfetch_uidl) { $i = $j+1; break; } @@ -185,7 +210,8 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); continue; } else { $newmsgcount = $Count - $i + 1; - Mail_Fetch_Status(_("Login OK: Inbox contains [") . $newmsgcount . _("] messages")); + Mail_Fetch_Status(sprintf(ngettext("Login OK: Inbox contains %s message", + "Login OK: Inbox contains %s messages",$newmsgcount), $newmsgcount)); } Mail_Fetch_Status(_("Fetching UIDL...")); @@ -203,7 +229,9 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); for (; $i <= $Count; $i++) { Mail_Fetch_Status(_("Fetching message ") . "$i" ); - set_time_limit(20); // 20 seconds per message max + + if (!ini_get('safe_mode')) + set_time_limit(20); // 20 seconds per message max $Message = ''; $MessArray = $pop3->get($i); @@ -243,8 +271,10 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); fputs($imap_stream, $Message); fputs($imap_stream, "\r\n"); sqimap_read_data($imap_stream, "A3$i", false, $response, $message); + $response=(implode('',$response)); + $message=(implode('',$message)); if ($response != 'OK') { - Mail_Fetch_Status(_("Error Appending Message!")." ".$message ); + Mail_Fetch_Status(_("Error Appending Message!")." ".htmlspecialchars($message) ); Mail_Fetch_Status(_("Closing POP")); $pop3->quit(); Mail_Fetch_Status(_("Logging out from IMAP")); @@ -261,7 +291,7 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); if( $pop3->delete($i) ) { Mail_Fetch_Status(_("Message ") . $i . _(" deleted from Remote Server!")); } else { - Mail_Fetch_Status(_("Delete failed:") . $pop3->ERROR ); + Mail_Fetch_Status(_("Delete failed:") . htmlspecialchars($pop3->ERROR) ); } } } else { @@ -295,4 +325,4 @@ sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); ?>
- + \ No newline at end of file