X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fmailto.php;h=b69855d5d51bc586eec7edc445ef36e7170e1bb4;hp=b921e852752d5ab2ec188fc7a2ad8e1bb41838e5;hb=d69119eb8350e38dcd6774a678d90477315f22ac;hpb=0731faea6045e57835ff7814b29feb9fafb3cf4e diff --git a/src/mailto.php b/src/mailto.php index b921e852..b69855d5 100644 --- a/src/mailto.php +++ b/src/mailto.php @@ -12,7 +12,7 @@ * login first) * * Use the following url to use mailto: - * http:////src/mailto.php?emailaddress="%1" + * http:////src/mailto.php?emailaddress=%1 * see ../contrib/squirrelmail.mailto.reg for a Windows Registry file * @package squirrelmail */ @@ -25,52 +25,55 @@ require_once(SM_PATH . 'config/config.php'); require_once(SM_PATH . 'functions/global.php'); require_once(SM_PATH . 'functions/strings.php'); +/* Force users to login each time? */ +$force_login = true; +/* Open only the compose window, meaningless if $force_login is true */ +$compose_only = false; + header('Pragma: no-cache'); -if(!sqgetGlobalVar('emailaddress', $emailaddress)) { - return; -} -$mailto_pos = strpos(strtolower($emailaddress), 'mailto:'); -if($mailto_pos !== false) { - $emailaddress = substr($emailaddress, $mailto_pos+7); - $_GET['emailaddress'] = $emailaddress; -} -if(($pos = strpos($emailaddress, '?')) !== false) { - $a = substr($emailaddress, $pos+1); - list($emailaddress, $a) = explode('?', $emailaddress, 2); - $a = explode('=', $a, 2); - $_GET['emailaddress'] = $emailaddress; - $_GET[$a[0]] = $a[1]; -} -$trtable = array('emailaddress' => 'send_to', - 'cc' => 'send_to_cc', +$trtable = array('cc' => 'send_to_cc', 'bcc' => 'send_to_bcc', 'body' => 'body', 'subject' => 'subject'); $url = ''; -/* CC, BCC, etc could be any case, so we'll fix them here */ -foreach($_GET as $k=>$g) { - if($g != '') { + +if(sqgetGlobalVar('emailaddress', $emailaddress)) { + $emailaddress = trim($emailaddress); + if(stristr($emailaddress, 'mailto:')) { + $emailaddress = substr($emailaddress, 7); + } + if(strpos($emailaddress, '?') !== false) { + list($emailaddress, $a) = explode('?', $emailaddress, 2); + if(strlen(trim($a)) > 0) { + $a = explode('=', $a, 2); + $url .= $trtable[strtolower($a[0])] . '=' . urlencode($a[1]) . '&'; + } + } + $url = 'send_to=' . urlencode($emailaddress) . '&' . $url; + + /* CC, BCC, etc could be any case, so we'll fix them here */ + foreach($_GET as $k=>$g) { $k = strtolower($k); - $k = $trtable[$k]; - $url .= $k . '=' . urlencode($g) . '&'; + if(isset($trtable[$k])) { + $k = $trtable[$k]; + $url .= $k . '=' . urlencode($g) . '&'; + } } + $url = substr($url, 0, -1); } -$url = substr($url, 0, -1); - sqsession_is_active(); -/* Check to see if we're logged in */ -/* -if (sqsession_is_registered('user_is_logged_in')) { - $redirect = 'webmail.php?right_frame=compose.php?'; + +if($force_login == false && sqsession_is_registered('user_is_logged_in')) { + if($compose_only == true) { + $redirect = 'compose.php?' . $url; + } else { + $redirect = 'webmail.php?right_frame=compose.php?' . urlencode($url); + } } else { - $redirect = 'login.php?mailto='; + $redirect = 'login.php?mailto=' . urlencode($url); } -*/ -$url = urlencode($url); -/* $redirect .= $url; */ -$redirect = 'login.php?mailto=' . $url; + session_write_close(); header('Location: ' . get_location() . '/' . $redirect); - -?> \ No newline at end of file +?>