Closes bug #479899
[squirrelmail.git] / src / webmail.php
index 6a1eae8da33a0b55a2361babab6f0588cd9b9f58..3544d162c557b6e22ee820fceb836527988adc89 100644 (file)
 <?php
+
    /**
-    **  webmail.php
+    **  webmail.php -- Displays the main frameset
+    **
+    **  Copyright (c) 1999-2000 The SquirrelMail development team
+    **  Licensed under the GNU GPL. For full terms see the file COPYING.
     **
-    **  This simply creates the frames.
+    **  This file generates the main frameset. The files that are
+    **  shown can be given as parameters. If the user is not logged in
+    **  this file will verify username and password.
     **
+    **  $Id$
     **/
 
-   session_start();
+   require_once('../functions/strings.php');
+   require_once('../config/config.php');
+   require_once('../functions/prefs.php');
+   require_once('../functions/imap.php');
+   require_once('../functions/plugin.php');
+   require_once('../functions/i18n.php');
+   require_once('../functions/auth.php');
 
-   if(!isset($username)) {
-      echo _("You need a valid user and password to access this page!");
-      exit;
-   }
+   ereg ("(^.*/)[^/]+/[^/]+$", $PHP_SELF, $regs);
+   $base_uri = $regs[1];
 
-   setcookie("username", $username, 0, "/");
-   setcookie("key", $key, 0, "/");
-   setcookie("logged_in", 1, 0, "/");
-   
-   // Refresh the language cookie.
-   if (isset($squirrelmail_language)) {
-      setcookie("squirrelmail_language", $squirrelmail_language, time()+2592000);
-   }
-
-   include ("../config/config.php");
-   include ("../functions/prefs.php");
-   include ("../functions/imap.php");
-   if (!isset($plugin_php))
-      include ("../functions/plugin.php");
-   if (!isset($auth_php))
-      include ("../functions/auth.php");
-
-   if (session_is_registered("user_is_logged_in")) {
-      do_hook ("login_before");
-      // verify that username and password are correct
-      $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
-      do_hook ("login_verified");
-   }
+   session_start();
+   is_logged_in();
+   checkForPrefs($data_dir, $username);
 
-   session_register ("user_is_logged_in");
-   $user_is_logged_in = true;
+   // We'll need this to later have a noframes version
+   //
+   // Check if the user has a language preference, but no cookie.
+   // Send him a cookie with his language preference, if there is
+   // such discrepancy.
+   $my_language=getPref($data_dir, $username, "language");
+   if ($my_language != $squirrelmail_language)
+     setcookie('squirrelmail_language', $my_language, time()+2592000, $base_uri);
 
-   include ("../src/load_prefs.php");
+   set_up_language(getPref($data_dir, $username, 'language'));
 
    echo "<html><head>\n";
-   echo "<TITLE>";
-   echo "$org_title";
-   echo "</TITLE>";
-   $ishelp = substr(getenv(REQUEST_URI),-8);                   // If calling help, set left frame to 300
-   if ($ishelp == "help.php") {                        
-      echo "<FRAMESET COLS=\"300, *\" NORESIZE BORDER=0>";
+   echo '<TITLE>';
+   echo $org_title;
+   echo '</TITLE>';
+   
+   $left_size = getPref($data_dir, $username, "left_size");
+   $location_of_bar = getPref($data_dir, $username, "location_of_bar");
+   if ($location_of_bar == '')
+       $location_of_bar = 'left';
+   if ($left_size == "") {
+      if (isset($default_left_size))
+         $left_size = $default_left_size;
+      else  
+         $left_size = 200;
+   }      
+   
+   if ($location_of_bar == 'right')
+   {
+      echo "<FRAMESET COLS=\"*, $left_size\" BORDER=0>";
    } else {
-      echo "<FRAMESET COLS=\"$left_size, *\" NORESIZE BORDER=0>";
+      echo "<FRAMESET COLS=\"$left_size, *\" BORDER=0>";
    }
 
 /**
-    There are four ways to call webmail.php
+    There are three ways to call webmail.php
     1.  webmail.php
          - This just loads the default entry screen.
     2.  webmail.php?right_frame=right_main.php&sort=X&startMessage=X&mailbox=XXXX
          - This loads the frames starting at the given values.
     3.  webmail.php?right_frame=folders.php
          - Loads the frames with the Folder options in the right frame.
-    4.  webmail.php?right_frame=help.php
-        - Lets the left frame set up different menu for help and calls the right frame.
 
     This was done to create a pure HTML way of refreshing the folder list since
     we would like to use as little Javascript as possible.
 **/
-   if ($right_frame == "right_main.php") {
-      $urlMailbox = urlencode($mailbox);
-      echo "<FRAME SRC=\"left_main.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=$startMessage\" NAME=\"right\">";
-   } else if ($right_frame == "folders.php") {
+   if (!isset($right_frame)) $right_frame = "";
+
+   if ($right_frame == 'right_main.php') {
       $urlMailbox = urlencode($mailbox);
-      echo "<FRAME SRC=\"left_main.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"folders.php\" NAME=\"right\">";
-   } else if ($right_frame == "help.php") {
-      echo "<FRAME SRC=\"left_help.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"help.php\" NAME=\"right\">";
+      $right_frame_url = "right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=$startMessage";
+   } else if ($right_frame == 'options.php') {
+      $right_frame_url = 'options.php';
+   } else if ($right_frame == 'folders.php') {
+      $right_frame_url = 'folders.php';
+   } else if ($right_frame == 'compose.php') {
+      $right_frame_url = "compose.php?send_to=$rcptaddress";
    } else {
-      echo "<FRAME SRC=\"left_main.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"right_main.php\" NAME=\"right\">";
+      $right_frame_url = "right_main.php";
+   }
+
+   if ($location_of_bar == 'right')
+   {
+      echo "<FRAME SRC=\"$right_frame_url\" NORESIZE NAME=\"right\">";
+      echo '<FRAME SRC="left_main.php" NORESIZE NAME="left">';
+   }
+   else
+   {
+      echo '<FRAME SRC="left_main.php" NORESIZE NAME="left">';
+      echo "<FRAME SRC=\"$right_frame_url\" NORESIZE NAME=\"right\">";
    }
 
 ?>
 </FRAMESET>
-</HEAD></HTML>
+</HEAD></HTML>
\ No newline at end of file