X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fwebmail.php;h=c44e9461c5aba7335412f93bc909b65888cdfeb3;hb=1b15e6a5b3974eb9c77a5745246e889115efe881;hp=bb4f3d1e1cc698b98875eca48aaf876562ef1b69;hpb=871ab9eb66b04b97deba155b6182943736fa66af;p=squirrelmail.git diff --git a/src/webmail.php b/src/webmail.php index bb4f3d1e..c44e9461 100644 --- a/src/webmail.php +++ b/src/webmail.php @@ -1,57 +1,47 @@ \n"; -echo ''; -echo $org_title; -echo ''; - -$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 (!sqgetGlobalVar('mailbox', $mailbox)) { + $mailbox = 'INBOX'; } + +sqgetGlobalVar('right_frame', $right_frame, SQ_GET); + +if (sqgetGlobalVar('mailtodata', $mailtodata)) { + $mailtourl = 'mailtodata='.urlencode($mailtodata); +} else { + $mailtourl = ''; +} + +// Determine the size of the left frame +$left_size = getPref($data_dir, $username, 'left_size'); if ($left_size == "") { if (isset($default_left_size)) { $left_size = $default_left_size; @@ -59,15 +49,27 @@ if ($left_size == "") { else { $left_size = 200; } -} - -if ($location_of_bar == 'right') { - echo ""; } -else { - echo ""; + +// Determine where the navigation frame should be +$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 = $temp_location_of_bar; +} + +// this value may be changed by a plugin, but initialize +// it first to avoid register_globals headaches +// +$right_frame_url = ''; +do_hook('webmail_top', $null); +// Determine the main frame URL /* * There are three ways to call webmail.php * 1. webmail.php @@ -79,38 +81,55 @@ 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. + * + * The test for // should catch any attempt to include off-site webpages into + * our frameset. + * + * Note that plugins are allowed to completely and freely override the URI + * used for the "right" (content) frame, and they do so by modifying the + * global variable $right_frame_url. + * */ -if (!isset($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"; -} -elseif ($right_frame == 'options.php') { - $right_frame_url = 'options.php'; -} -elseif ($right_frame == 'folders.php') { - $right_frame_url = 'folders.php'; +if (empty($right_frame) || (strpos(urldecode($right_frame), '//') !== false)) { + $right_frame = ''; } -elseif ($right_frame == 'compose.php') { - $right_frame_url = "compose.php?send_to=$rcptaddress"; +if ( strpos($right_frame,'?') ) { + $right_frame_file = substr($right_frame,0,strpos($right_frame,'?')); +} else { + $right_frame_file = $right_frame; } -else { - $right_frame_url = 'right_main.php'; +if (empty($right_frame_url)) { + switch($right_frame) { + case 'right_main.php': + $right_frame_url = "right_main.php?mailbox=".urlencode($mailbox) + . (!empty($sort)?"&sort=$sort":'') + . (!empty($startMessage)?"&startMessage=$startMessage":''); + break; + case 'options.php': + $right_frame_url = 'options.php'; + break; + case 'folders.php': + $right_frame_url = 'folders.php'; + break; + case 'compose.php': + $right_frame_url = 'compose.php?' . $mailtourl; + break; + case '': + $right_frame_url = 'right_main.php'; + break; + default: + $right_frame_url = urlencode($right_frame); + break; + } } -if ($location_of_bar == 'right') { - echo ""; - echo ''; -} -else { - echo ''; - echo ""; -} +$oErrorHandler->setDelayedErrors(true); + +$oTemplate->assign('nav_size', $left_size); +$oTemplate->assign('nav_on_left', $location_of_bar=='left'); +$oTemplate->assign('right_frame_url', $right_frame_url); + +displayHtmlHeader($org_title, '', false, true); + +$oTemplate->display('webmail.tpl'); -?> - -