From: pdontthink Date: Fri, 9 Jan 2015 07:24:26 +0000 (+0000) Subject: Make sure the correct identity is used for list command mailto actions X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=commitdiff_plain;h=dd9c9e85a502de32ef949c5488d4dc8c8f9217f2 Make sure the correct identity is used for list command mailto actions git-svn-id: https://svn.code.sf.net/p/squirrelmail/code/trunk/squirrelmail@14492 7612ce4b-ef26-0410-bec9-ea0150e637f0 --- diff --git a/plugins/listcommands/functions.php b/plugins/listcommands/functions.php index 6c526c2a..63fa24c6 100644 --- a/plugins/listcommands/functions.php +++ b/plugins/listcommands/functions.php @@ -90,20 +90,39 @@ function plugin_listcommands_menu_do() { if ($proto == 'mailto') { + $identity = ''; + if (($cmd == 'post') || ($cmd == 'owner')) { $url = 'src/compose.php?'. (isset($startMessage)?'startMessage='.$startMessage.'&':''); } else { $url = "plugins/listcommands/mailout.php?action=$cmd&"; + + // try to find which identity the mail should come from + include_once(SM_PATH . 'functions/identity.php'); + $idents = get_identities(); + // ripped from src/compose.php + $identities = array(); + if (count($idents) > 1) { + foreach($idents as $nr=>$data) { + $enc_from_name = '"'.$data['full_name'].'" <'. $data['email_address'].'>'; + $identities[] = $enc_from_name; + } + + $identity_match = $message->rfc822_header->findAddress($identities); + if ($identity_match !== FALSE) { + $identity = $identity_match; + } + } } // if things like subject are given, peel them off and give // them to src/compose.php as is (not encoded) if (strpos($act, '?') > 0) { list($act, $parameters) = explode('?', $act, 2); - $parameters = '&' . $parameters; + $parameters = '&identity=' . $identity . '&' . $parameters; } else { - $parameters = ''; + $parameters = '&identity=' . $identity; } $url .= 'send_to=' . urlencode($act) . $parameters; diff --git a/plugins/listcommands/mailout.php b/plugins/listcommands/mailout.php index c94d875f..0ef95076 100644 --- a/plugins/listcommands/mailout.php +++ b/plugins/listcommands/mailout.php @@ -26,6 +26,7 @@ sqgetGlobalVar('send_to', $send_to, SQ_GET); sqgetGlobalVar('subject', $subject, SQ_GET); sqgetGlobalVar('body', $body, SQ_GET); sqgetGlobalVar('action', $action, SQ_GET); +sqgetGlobalVar('identity', $identity, SQ_GET); displayPageHeader($color, $mailbox); @@ -58,6 +59,7 @@ $oTemplate->assign('subject', $subject); $oTemplate->assign('body', $body); $oTemplate->assign('mailbox', $mailbox); $oTemplate->assign('idents', $idents); +$oTemplate->assign('identity', $identity); $oTemplate->display('plugins/listcommands/mailout.tpl'); $oTemplate->display('footer.tpl'); diff --git a/plugins/listcommands/templates/default/mailout.tpl b/plugins/listcommands/templates/default/mailout.tpl index 2aaa236f..b6ec5888 100644 --- a/plugins/listcommands/templates/default/mailout.tpl +++ b/plugins/listcommands/templates/default/mailout.tpl @@ -41,8 +41,10 @@ extract($t); echo '