X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=plugins%2Fmail_fetch%2Ffetch.php;h=0cbbfc2edcbbe57b0df19a1cc6e440920b7c9189;hp=0ba24dfe577f8d38bf182712a14e1439eb6daf94;hb=91e0dccca7b2452d8b450791cae3aa4125e8889e;hpb=6dc0e4643d9162034631ed7dac0a0a7cddc1f48d diff --git a/plugins/mail_fetch/fetch.php b/plugins/mail_fetch/fetch.php index 0ba24dfe..0cbbfc2e 100644 --- a/plugins/mail_fetch/fetch.php +++ b/plugins/mail_fetch/fetch.php @@ -1,147 +1,199 @@ ' . - htmlspecialchars( $msg ) . - ''; + echo html_tag( 'table', + html_tag( 'tr', + html_tag( 'td', htmlspecialchars( $msg ) , 'left' ) + ), + '', '', 'width="90%"' ); 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=0; - $mailfetch_cypher = getPref($data_dir, $username, "mailfetch_cypher"); - if ($mailfetch_server_number<1) $mailfetch_server_number=0; - for ($i=0;$i<$mailfetch_server_number;$i++) { - $mailfetch_server_[$i] = getPref($data_dir, $username, "mailfetch_server_$i"); - $mailfetch_alias_[$i] = getPref($data_dir, $username, "mailfetch_alias_$i"); - $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] ); + $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[$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 '
'; - - echo '' . - "' . - '
" . _("Remote POP server Fetching Mail") . '
'; - - if (!isset( $server_to_fetch ) ) { - - echo '
' . - "
" . - '' . - '' . - '' . - '' . - ''; - + + function Mail_Fetch_Select_Server($mailfetch) { + global $PHP_SELF; + + echo '
' . + '' . + html_tag( 'table', '', 'center', '', 'width="70%" cols="2"' ) . + html_tag( 'tr' ) . + html_tag( 'td', _("Select Server:") . '    ', 'right' ) . + html_tag( 'td', '', 'left' ) . + '' . + '' . + ''; + //if password not set, ask for it - for ($i=0;$i<$mailfetch_server_number;$i++) { - if ($mailfetch_pass_[$i]=="") { - echo "" . - '' . - "" . - ""; + for ($i = 0;$i < $mailfetch['server_number'];$i++) { + if ($mailfetch[$i]['pass'] == '') { + echo html_tag( 'tr', + html_tag( 'td', _("Password for") . ' ' . + htmlspecialchars($mailfetch[$i]['alias']) . + ':     ', + 'right' ) . + html_tag( 'td', '', 'left' ) + ); } } - echo '' . - '' . - ''. - '' . - '
' . _("Select Server:") . '     ' . - '
' . _("Password for") . ' ' . (($mailfetch_alias_[$i]=='')?$mailfetch_server_[$i]:$mailfetch_alias_[$i]) . ':    
 
'; + echo html_tag( 'tr', + html_tag( 'td', ' ' ) . + 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; + $i_stop = $i_start+1; } - + for ($i_loop=$i_start;$i_loop<$i_stop;$i_loop++) { - $mailfetch_server=$mailfetch_server_[$i_loop]; - $mailfetch_user=$mailfetch_user_[$i_loop]; - if ($mailfetch_pass_[$i_loop]=="") { - $tmp="pass_$i_loop"; - $mailfetch_pass=$$tmp; - } else { - $mailfetch_pass=$mailfetch_pass_[$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'; } - $mailfetch_lmos=$mailfetch_lmos_[$i_loop]; - $mailfetch_login=$mailfetch_login_[$i_loop]; - $mailfetch_uidl=$mailfetch_uidl_[$i_loop]; - $mailfetch_subfolder=$mailfetch_subfolder_[$i_loop]; - - + $pop3 = new POP3($mailfetch_server, 60); - - echo "
" . - _("Fetching from ") . - (($mailfetch_alias_[$i_loop] == '')?$mailfetch_server:$mailfetch_alias_[$i_loop]) . - "
"; - + + echo '
' . + html_tag( 'table', + html_tag( 'tr', + html_tag( 'td', '' . _("Fetching from ") . + htmlspecialchars($mailfetch[$i_loop]['alias']) . + '', + 'center' ) , + '', $color[9] ) , + '', '', 'width="90%"' ); + flush(); - - if (!$pop3->connect($mailfetch_server)) { + + if (!$pop3->connect($mailfetch_server,$mailfetch_port)) { Mail_Fetch_Status(_("Oops, ") . $pop3->ERROR ); continue; } - + Mail_Fetch_Status(_("Opening IMAP server")); $imap_stream = sqimap_login($username, $key, $imapServerAddress, $imapPort, 10); - + 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; } - + // register_shutdown_function($pop3->quit()); - + $msglist = $pop3->uidl(); - + $i = 1; for ($j = 1; $j < sizeof($msglist); $j++) { - if ($msglist["$j"] == $mailfetch_uidl) { + if ($msglist[$j] == $mailfetch_uidl) { $i = $j+1; break; } @@ -158,13 +210,14 @@ 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...")); // Faster to get them all at once $mailfetch_uidl = $pop3->uidl(); - + if (! is_array($mailfetch_uidl) && $mailfetch_lmos == 'on') Mail_Fetch_Status(_("Server does not support UIDL.")); @@ -173,46 +226,89 @@ } else { Mail_Fetch_Status(_("Deleting messages from server...")); } - + for (; $i <= $Count; $i++) { Mail_Fetch_Status(_("Fetching message ") . "$i" ); - set_time_limit(20); // 20 seconds per message max - $Message = ""; + + if (!ini_get('safe_mode')) + set_time_limit(20); // 20 seconds per message max + $Message = ''; $MessArray = $pop3->get($i); - - if ( (!$MessArray) or (gettype($MessArray) != "array")) { - Mail_Fetch_Status(_("Oops, ") . $pop3->ERROR); - continue 2; - } - + + while ( (!$MessArray) or (gettype($MessArray) != "array")) { + Mail_Fetch_Status(_("Oops, ") . $pop3->ERROR); + // re-connect pop3 + Mail_Fetch_Status(_("Server error...Disconnect")); + $pop3->quit(); + Mail_Fetch_Status(_("Reconnect from dead connection")); + if (!$pop3->connect($mailfetch_server)) { + Mail_Fetch_Status(_("Oops, ") . $pop3->ERROR ); + Mail_Fetch_Status(_("Saving UIDL")); + setPref($data_dir,$username,"mailfetch_uidl_$i_loop", $mailfetch_uidl[$i-1]); + + continue; + } + $Count = $pop3->login($mailfetch_user, $mailfetch_pass); + if (($Count == false || $Count == -1) && $pop3->ERROR != '') { + Mail_Fetch_Status(_("Login Failed:") . ' ' . $pop3->ERROR ); + Mail_Fetch_Status(_("Saving UIDL")); + setPref($data_dir,$username,"mailfetch_uidl_$i_loop", $mailfetch_uidl[$i-1]); + + continue; + } + Mail_Fetch_Status(_("Refetching message ") . "$i" ); + $MessArray = $pop3->get($i); + + } // end while + while (list($lineNum, $line) = each ($MessArray)) { $Message .= $line; } - - if ($mailfetch_subfolder=="") { - fputs($imap_stream, "A3$i APPEND INBOX {" . (strlen($Message) - 1) . "}\r\n"); - } else { - fputs($imap_stream, "A3$i APPEND \"$mailfetch_subfolder\" {" . (strlen($Message) - 1) . "}\r\n"); - } + + fputs($imap_stream, "A3$i APPEND \"$mailfetch_subfolder\" {" . strlen($Message) . "}\r\n"); $Line = fgets($imap_stream, 1024); if (substr($Line, 0, 1) == '+') { fputs($imap_stream, $Message); + fputs($imap_stream, "\r\n"); sqimap_read_data($imap_stream, "A3$i", false, $response, $message); - Mail_Fetch_Status(_("Message appended to mailbox")); - + $response=(implode('',$response)); + $message=(implode('',$message)); + if ($response != 'OK') { + Mail_Fetch_Status(_("Error Appending Message!")." ".htmlspecialchars($message) ); + Mail_Fetch_Status(_("Closing POP")); + $pop3->quit(); + Mail_Fetch_Status(_("Logging out from IMAP")); + sqimap_logout($imap_stream); + + Mail_Fetch_Status(_("Saving UIDL")); + setPref($data_dir,$username,"mailfetch_uidl_$i_loop", $mailfetch_uidl[$i-1]); + exit; + } else { + Mail_Fetch_Status(_("Message appended to mailbox")); + } + if ($mailfetch_lmos != 'on') { 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 { - echo "$Line"; + echo $Line; Mail_Fetch_Status(_("Error Appending Message!")); + Mail_Fetch_Status(_("Closing POP")); + $pop3->quit(); + Mail_Fetch_Status(_("Logging out from IMAP")); + sqimap_logout($imap_stream); + + // not gurantee corect! + Mail_Fetch_Status(_("Saving UIDL")); + setPref($data_dir,$username,"mailfetch_uidl_$i_loop", $mailfetch_uidl[$i-1]); + exit; } } - + Mail_Fetch_Status(_("Closing POP")); $pop3->quit(); Mail_Fetch_Status(_("Logging out from IMAP")); @@ -221,7 +317,7 @@ Mail_Fetch_Status(_("Saving UIDL")); setPref($data_dir,$username,"mailfetch_uidl_$i_loop", array_pop($mailfetch_uidl)); } - + Mail_Fetch_Status(_("Done")); }