Getting ready for 1.2.0 release.
[squirrelmail.git] / src / webmail.php
index ee37c639bc3585edac470e70ec5f4f6c4a4b2370..3f9c11199a59b2ae9166f5b170ebfecfa8f2a146 100644 (file)
 <?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 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.
-    **
-    **/
-
-   // Before starting the session, the base URI must be known.
-   // Assuming that this file is in the src/ subdirectory (or
-   // something).
-   ereg ("(^.*/)[^/]+/[^/]+$", $PHP_SELF, $regs);
-   $base_uri = $regs[1];
-
-   session_set_cookie_params (0, $base_uri);
-   session_start();
-
-   session_register ("base_uri");
+/**
+ * webmail.php -- Displays the main frameset
+ *
+ * Copyright (c) 1999-2002 The SquirrelMail development team
+ * Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ * 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$
+ */
 
-   if(!isset($username)) {
-      echo _("You need a valid user and password to access this page!");
-      exit;
-   }
+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');
 
-   setcookie("username", $username, 0, $base_uri);
-   setcookie("key", $key, 0, $base_uri);
-   setcookie("logged_in", 1, 0, $base_uri);
-   
-   // Refresh the language cookie.
-   if (isset($squirrelmail_language)) {
-      setcookie("squirrelmail_language", $squirrelmail_language, time()+2592000);
-   }
+ereg( '(^.*/)[^/]+/[^/]+$', $PHP_SELF, $regs);
+$base_uri = $regs[1];
 
-   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");
+session_start();
+is_logged_in();
 
-   if (!session_is_registered("user_is_logged_in") || $logged_in != 1) {
-      do_hook ("login_before");
-      // verify that username and password are correct
-      $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
-      do_hook ("login_verified");
-   }
+/**
+ * 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);
+}
 
-   session_register ("user_is_logged_in");
-   $user_is_logged_in = true;
+set_up_language(getPref($data_dir, $username, 'language'));
 
-   include ("../src/load_prefs.php");
+echo "<html><head>\n";
+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, *\" BORDER=0>";
+}
 
-   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>";
-   } else {
-      echo "<FRAMESET COLS=\"$left_size, *\" NORESIZE BORDER=0>";
-   }
+/*
+ * 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.
+ *
+ * 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 (!isset($right_frame)) {
+    $right_frame = "";
+}
 
-/**
-    There are four 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.
+if ($right_frame == 'right_main.php') {
+    $urlMailbox = urlencode($mailbox);
+    $right_frame_url =
+        "right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=$startMessage";
+}
+elseif ($right_frame == 'options.php') {
+    $right_frame_url = 'options.php';
+}
+elseif ($right_frame == 'folders.php') {
+    $right_frame_url = 'folders.php';
+}
+elseif ($right_frame == 'compose.php') {
+    $right_frame_url = "compose.php?send_to=$rcptaddress";
+}
+else {
+    $right_frame_url = 'right_main.php';
+}
 
-    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 == "options.php") {
-      echo "<FRAME SRC=\"left_main.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"options.php\" NAME=\"right\">";
-   } else if ($right_frame == "folders.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\">";
-   } else {
-      echo "<FRAME SRC=\"left_main.php\" NAME=\"left\">";
-      echo "<FRAME SRC=\"right_main.php\" NAME=\"right\">";
-   }
+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>