/**
* mail_fetch/fetch.php
*
- * Copyright (c) 1999-2003 The SquirrelMail Project Team
+ * Copyright (c) 1999-2004 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');
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");
- $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;
}
- 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 '<br><center>';
+ function Mail_Fetch_Select_Server($mailfetch) {
+ global $PHP_SELF;
- echo html_tag( 'table',
- html_tag( 'tr',
- html_tag( 'td', '<b>' . _("Remote POP server Fetching Mail") . '</b>', 'center', $color[0] )
- ) ,
- 'center', '', 'width="95%" cols="1"' );
-
- if (!isset( $server_to_fetch ) ) {
-
- echo '<font size=-5><br></font>' .
- "<form action=\"$PHP_SELF\" method=\"post\" target=\"_self\">" .
+ echo '<font size="-5"><br /></font>' .
+ '<form action="'.$PHP_SELF.'" method="post" target="_self">' .
html_tag( 'table', '', 'center', '', 'width="70%" cols="2"' ) .
html_tag( 'tr' ) .
html_tag( 'td', _("Select Server:") . ' ', 'right' ) .
html_tag( 'td', '', 'left' ) .
'<select name="server_to_fetch" size="1">' .
- '<option value="all" selected>..' . _("All") . "...\n";
- for ($i = 0;$i < $mailfetch_server_number;$i++) {
+ '<option value="all" selected="selected">..' . _("All") . "...\n";
+ for ($i = 0;$i < $mailfetch['server_number'];$i++) {
echo "<option value=\"$i\">" .
- htmlspecialchars($mailfetch_alias_[$i]) .
+ htmlspecialchars($mailfetch[$i]['alias']) .
'</option>' . "\n";
- }
+ }
echo '</select>' .
'</td>' .
'</tr>';
//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") . ' <b>' .
- htmlspecialchars($mailfetch_alias_[$i]) .
+ htmlspecialchars($mailfetch[$i]['alias']) .
'</b>: ',
'right' ) .
- html_tag( 'td', '<input type="password" name="pass_' . $i . '">', 'left' )
+ html_tag( 'td', '<input type="password" name="pass_' . $i . '" />', 'left' )
);
}
}
echo html_tag( 'tr',
html_tag( 'td', ' ' ) .
- html_tag( 'td', '<input type=submit name=submit_mailfetch value="' . _("Fetch Mail"). '">', 'left' )
+ html_tag( 'td', '<input type="submit" name="submit_mailfetch" value="' . _("Fetch Mail"). '" />', 'left' )
) .
'</table></form>';
+ }
+
+ $mailfetch = Mail_Fetch_Servers();
+ displayPageHeader($color, 'None');
+
+ echo '<br /><center>';
+
+ echo html_tag( 'table',
+ html_tag( 'tr',
+ html_tag( 'td', '<b>' . _("Remote POP server Fetching Mail") . '</b>', 'center', $color[0] )
+ ) ,
+ 'center', '', 'width="95%" cols="1"' );
+
+
+ /* there are no servers defined yet... */
+ if($mailfetch['server_number'] == 0) {
+ echo '<p>' . _("No POP3 servers configured yet.") . '</p>';
+ displayInternalLink('plugins/mail_fetch/options.php',
+ _("Click here to go to the options page.") );
+ echo '</body></html>';
+ 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 '<br>' .
+ echo '<br />' .
html_tag( 'table',
html_tag( 'tr',
html_tag( 'td', '<b>' . _("Fetching from ") .
- htmlspecialchars($mailfetch_alias_[$i_loop]) .
+ htmlspecialchars($mailfetch[$i_loop]['alias']) .
'</b>',
'center' ) ,
'', $color[9] ) ,
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;
}
$i = 1;
for ($j = 1; $j < sizeof($msglist); $j++) {
- if ($msglist["$j"] == $mailfetch_uidl) {
+ if ($msglist[$j] == $mailfetch_uidl) {
$i = $j+1;
break;
}
continue;
} else {
$newmsgcount = $Count - $i + 1;
- Mail_Fetch_Status(_("Login OK: Inbox contains [") . $newmsgcount . _("] messages"));
+ Mail_Fetch_Status(sprintf(_("Login OK: Inbox contains %s messages"), $newmsgcount));
}
Mail_Fetch_Status(_("Fetching UIDL..."));
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);
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"));
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 {