X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fright_main.php;h=b8bf19ab492d77119bff1f4b1becccb8f68445b6;hb=8061a3fb7663a4e8edf2f415e5547fc81bcdbcb6;hp=18eb55399c6dbc4fcaa3e8bd4f38c9ace7bdec76;hpb=2a32fc83f95eba42be0d1752ef685adf10e1edc9;p=squirrelmail.git
diff --git a/src/right_main.php b/src/right_main.php
index 18eb5539..b8bf19ab 100644
--- a/src/right_main.php
+++ b/src/right_main.php
@@ -1,45 +1,24 @@
-
+
-
-
-
/////////////////////////////////////////////////////////////////////////////////
//
// incoming variables from URL:
@@ -58,26 +37,71 @@
// open a connection on the imap port (143)
$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
- /** If it was a successful login, lets load their preferences **/
- include("../src/load_prefs.php");
- echo "\n";
+ if (isset($newsort) && $newsort != $sort) {
+ setPref($data_dir, $username, 'sort', $newsort);
+ }
// If the page has been loaded without a specific mailbox,
- // just show a page of general info.
+ // send them to the inbox
if (!isset($mailbox)) {
- displayPageHeader($color, "None");
- general_info($motd, $org_logo, $version, $org_name, $color);
- echo "";
- exit;
+ $mailbox = 'INBOX';
+ $startMessage = 1;
+ }
+
+ // compensate for the UW vulnerability
+ if ($imap_server_type == 'uw' && (strstr($mailbox, '../') !== false ||
+ substr($mailbox, 0, 1) == '/')) {
+ $mailbox = 'INBOX';
}
sqimap_mailbox_select($imapConnection, $mailbox);
- $numMessages = sqimap_get_num_messages ($imapConnection, $mailbox);
displayPageHeader($color, $mailbox);
- showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort, $color);
+ do_hook('right_main_after_header');
+
+ if (isset($just_logged_in) && $just_logged_in == 1 &&
+ strlen(trim($motd)) > 0) {
+ echo "
\n";
+ echo "\n";
+ echo "\n";
+ echo "$motd\n";
+ echo " | \n";
+ echo " |
\n";
+ echo "
\n";
+ }
+
+ if (isset($newsort)) {
+ $sort = $newsort;
+ session_register('sort');
+ }
+
+ // Check to see if we can use cache or not. Currently the only time when you wont use it is
+ // when a link on the left hand frame is used. Also check to make sure we actually have the
+ // array in the registered session data. :)
+ if (! isset($use_mailbox_cache))
+ $use_mailbox_cache = 0;
+ if ($use_mailbox_cache && session_is_registered('msgs')) {
+ showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort, $color, $show_num, $use_mailbox_cache);
+ } else {
+ if (session_is_registered('msgs'))
+ unset($msgs);
+ if (session_is_registered('msort'))
+ unset($msort);
+ if (session_is_registered('numMessages'))
+ unset($numMessages);
+
+ $numMessages = sqimap_get_num_messages ($imapConnection, $mailbox);
+
+ showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort, $color, $show_num, $use_mailbox_cache);
+
+ if (session_is_registered('msgs') && isset($msgs))
+ session_register('msgs');
+ if (session_is_registered('msort') && isset($msort))
+ session_register('msort');
+ session_register('numMessages');
+ }
- // close the connection
+ do_hook('right_main_bottom');
sqimap_logout ($imapConnection);
?>