X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fwebmail.php;h=aaad5e5fc3ae2f9213c382b4cc90e1b8c9710270;hp=c2768dc8bee885374c626812ec1035a675cc9f51;hb=a2b193bc8c1cefe3db9f4b38ce346f0527a0ec0e;hpb=85b454a07d818465b91a2c3ae507e221fc5ba7e9 diff --git a/src/webmail.php b/src/webmail.php index c2768dc8..aaad5e5f 100644 --- a/src/webmail.php +++ b/src/webmail.php @@ -3,29 +3,69 @@ /** * webmail.php -- Displays the main frameset * - * Copyright (c) 1999-2002 The SquirrelMail development team + * Copyright (c) 1999-2005 The SquirrelMail Project 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$ + * @version $Id$ + * @package squirrelmail */ -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'); +/** + * Path for SquirrelMail required files. + * @ignore + */ +define('SM_PATH','../'); + +/* SquirrelMail required files. */ +require_once(SM_PATH . 'functions/strings.php'); +require_once(SM_PATH . 'config/config.php'); +require_once(SM_PATH . 'functions/prefs.php'); +require_once(SM_PATH . 'functions/imap.php'); +require_once(SM_PATH . 'functions/plugin.php'); +require_once(SM_PATH . 'functions/i18n.php'); +require_once(SM_PATH . 'functions/auth.php'); +require_once(SM_PATH . 'functions/global.php'); + +if (!function_exists('sqm_baseuri')){ + require_once(SM_PATH . 'functions/display_messages.php'); +} +$base_uri = sqm_baseuri(); + +sqsession_is_active(); -$base_uri = dirname(dirname($PHP_SELF)); +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); + +if (sqgetGlobalVar('sort', $sort)) { + $sort = (int) $sort; +} + +if (sqgetGlobalVar('startMessage', $startMessage)) { + $startMessage = (int) $startMessage; +} + +if (!sqgetGlobalVar('mailbox', $mailbox)) { + $mailbox = 'INBOX'; +} + +sqgetGlobalVar('right_frame', $right_frame, SQ_GET); + +if ( isset($_SESSION['session_expired_post']) ) { + sqsession_unregister('session_expired_post'); +} +if(!sqgetGlobalVar('mailto', $mailto)) { + $mailto = ''; +} -session_start(); is_logged_in(); +do_hook('webmail_top'); + /** * We'll need this to later have a noframes version * @@ -38,16 +78,42 @@ if ($my_language != $squirrelmail_language) { setcookie('squirrelmail_language', $my_language, time()+2592000, $base_uri); } -set_up_language(getPref($data_dir, $username, 'language')); +$err=set_up_language(getPref($data_dir, $username, 'language')); -echo "\n" . - "$org_title"; +$output = "\n". + "\n" . + "\n" . + "$org_title\n". + ""; + +// Japanese translation used without mbstring support +if ($err==2) { + echo $output. + "\n". + "

You need to have php4 installed with the multibyte string function \n". + "enabled (using configure option --enable-mbstring).

\n". + "

System assumed that you accidently switched to Japanese translation \n". + "and reverted your language preference to English.

\n". + "

Please refresh this page in order to use webmail.

\n". + ""; + return; +} $left_size = getPref($data_dir, $username, 'left_size'); $location_of_bar = getPref($data_dir, $username, 'location_of_bar'); + +if (isset($languages[$squirrelmail_language]['DIR']) && + strtolower($languages[$squirrelmail_language]['DIR']) == 'rtl') { + $temp_location_of_bar = 'right'; +} else { + $temp_location_of_bar = 'left'; +} + if ($location_of_bar == '') { - $location_of_bar = 'left'; + $location_of_bar = $temp_location_of_bar; } +$temp_location_of_bar = ''; + if ($left_size == "") { if (isset($default_left_size)) { $left_size = $default_left_size; @@ -58,10 +124,10 @@ if ($left_size == "") { } if ($location_of_bar == 'right') { - echo ""; + $output .= "\n"; } else { - echo ""; + $output .= "\n"; } /* @@ -76,33 +142,45 @@ else { * 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)) { + +if (empty($right_frame) || (strpos(urldecode($right_frame), '://'))) { $right_frame = ''; } if ($right_frame == 'right_main.php') { $urlMailbox = urlencode($mailbox); - $right_frame_url = - "right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=$startMessage"; + $right_frame_url = "right_main.php?mailbox=$urlMailbox" + . (!empty($sort)?"&sort=$sort":'') + . (!empty($startMessage)?"&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 = 'compose.php?' . $mailto; +} else if ($right_frame == '') { $right_frame_url = 'right_main.php'; +} else { + $right_frame_url = htmlspecialchars($right_frame); } +$left_frame = '\n"; +$right_frame = '\n"; + if ($location_of_bar == 'right') { - echo "" . - ''; + $output .= $right_frame . $left_frame; } else { - echo ''. - ""; + $output .= $left_frame . $right_frame; +} +$ret = concat_hook_function('webmail_bottom', $output); +if($ret != '') { + $output = $ret; } -do_hook('webmail_bottom'); +echo $output; + ?> - - + + \ No newline at end of file