Notification when saving a draft.
[squirrelmail.git] / src / right_main.php
index 3071e422e3105839f113bf4c2f66a75c0dbd52b8..1df827331a95a0f954199645b6de1fb9218afd77 100644 (file)
@@ -1,34 +1,23 @@
-<?
+<?php
    /**
     **  right_main.php
     **
+    **  Copyright (c) 1999-2000 The SquirrelMail development team
+    **  Licensed under the GNU GPL. For full terms see the file COPYING.
+    **
     **  This is where the mailboxes are listed.  This controls most of what
     **  goes on in SquirrelMail.
     **
+    **  $Id$
     **/
 
-   if(!isset($logged_in)) {
-      echo "You must <a href=\"login.php\">login</a> first.";
-      exit;
-   }
-   if(!isset($username) || !isset($key)) {
-      echo "You need a valid user and password to access this page!";
-      exit;
-   }
-?>
-<HTML>
-<BODY TEXT="#000000" BGCOLOR="#FFFFFF" LINK="#0000EE" VLINK="#0000EE" ALINK="#0000EE">
-<FONT FACE="Arial,Helvetica">
-<?
-   include("../config/config.php");
-   include("../functions/imap.php");
-   include("../functions/strings.php");
-   include("../functions/date.php");
-   include("../functions/page_header.php");
-   include("../functions/array.php");
-   include("../functions/mailbox.php");
-   include("../functions/mailbox_display.php");
-   include("../functions/display_messages.php");
+   require_once('../src/validate.php');
+   require_once('../functions/imap.php');
+   require_once('../functions/date.php');
+   require_once('../functions/array.php');
+   require_once('../functions/mime.php');
+   require_once('../functions/mailbox_display.php');
+   require_once('../functions/display_messages.php');
 
    /////////////////////////////////////////////////////////////////////////////////
    //
    //
    /////////////////////////////////////////////////////////////////////////////////
 
-
    // open a connection on the imap port (143)
-   $imapConnection = loginToImapServer($username, $key, $imapServerAddress);
+   $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
+
+   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("None");
-      general_info($motd, $org_logo, $version, $org_name);
-      exit;
+      $mailbox = 'INBOX';
+      $startMessage = 1;
    }
 
-   // switch to the mailbox, and get the number of messages in it.
-   selectMailbox($imapConnection, $mailbox, $numMessages);
+   // compensate for the UW vulnerability
+   if ($imap_server_type == 'uw' && (strstr($mailbox, '../') !== false ||
+                                     substr($mailbox, 0, 1) == '/')) {
+      $mailbox = 'INBOX';
+   }
 
-   // Display the header at the top of the page
-   displayPageHeader($mailbox);
+   sqimap_mailbox_select($imapConnection, $mailbox);
+   displayPageHeader($color, $mailbox);
 
-   // Get the list of messages for this mailbox
-   showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort);
+   do_hook('right_main_after_header');
+   
+   if (isset($note))
+      echo "<CENTER><B>$note</B></CENTER><BR>\n";
+
+   if ($just_logged_in == true) {
+      $just_logged_in = false;
+      
+      if (strlen(trim($motd)) > 0) {
+?><br>
+<table align=center width=70% cellpadding=0 cellspacing=3 border=0
+bgcolor="<?PHP echo $color[9] ?>">
+<tr><td>
+  <table width=100% cellpadding=5 cellspacing=1 border=0 bgcolor="<?PHP
+    echo $color[4] ?>">
+    <tr><td align=center><?PHP 
+       echo $motd;
+       do_hook('motd');
+    ?></td></tr>
+  </table>
+</td></tr></table>
+<?PHP
+      }
+   }
+
+       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
-   fputs($imapConnection, "1 logout\n");
-   fclose($imapConnection);
+   do_hook('right_main_bottom');
+   sqimap_logout ($imapConnection);
 ?>
 </FONT>
 </BODY>