@ -5,7 +5,7 @@
| program/steps/mail/compose.inc |
| |
| This file is part of the Roundcube Webmail client |
| Copyright (C) 2005-2016 , The Roundcube Dev Team |
| Copyright (C) 2005-2017 , The Roundcube Dev Team |
| |
| Licensed under the GNU General Public License version 3 or |
| any later version with exceptions for skins & plugins. |
@ -19,18 +19,12 @@
+-----------------------------------------------------------------------+
*/
// define constants for message compose mode
define('RCUBE_COMPOSE_REPLY', 'reply');
define('RCUBE_COMPOSE_FORWARD', 'forward');
define('RCUBE_COMPOSE_DRAFT', 'draft');
define('RCUBE_COMPOSE_EDIT', 'edit');
$COMPOSE_ID = rcube_utils::get_input_value('_id', rcube_utils::INPUT_GET);
$COMPOSE = null;
$MESSAGE_FORM = null;
$COMPOSE_ID = rcube_utils::get_input_value('_id', rcube_utils::INPUT_GET);
$COMPOSE = null;
if ($COMPOSE_ID & & $_SESSION['compose_data_'.$COMPOSE_ID])
$COMPOSE =& $_SESSION['compose_data_'.$COMPOSE_ID];
if ($COMPOSE_ID & & $_SESSION['compose_data_'.$COMPOSE_ID]) {
$COMPOSE =& $_SESSION['compose_data_'.$COMPOSE_ID];
}
// give replicated session storage some time to synchronize
$retries = 0;
@ -67,7 +61,7 @@ if (!is_array($COMPOSE)) {
// check if folder for saving sent messages exists and is subscribed (#1486802)
if ($sent_folder = $COMPOSE['param']['sent_mbox']) {
rcmail_check_sent_folder($sent_folder, true);
rcmail_sendmail:: check_sent_folder($sent_folder, true);
}
// redirect to a unique URL with all parameters stored in session
@ -99,7 +93,6 @@ $OUTPUT->set_env('mailbox', $RCMAIL->storage->get_folder());
$OUTPUT->set_env('top_posting', intval($RCMAIL->config->get('reply_mode')) > 0);
$OUTPUT->set_env('sig_below', $RCMAIL->config->get('sig_below'));
$OUTPUT->set_env('save_localstorage', (bool)$RCMAIL->config->get('compose_save_localstorage'));
$OUTPUT->set_env('max_disclosed_recipients', (int) $RCMAIL->config->get('max_disclosed_recipients', 5));
$OUTPUT->set_env('is_sent', false);
$OUTPUT->set_env('mimetypes', rcmail_supported_mimetypes());
@ -125,20 +118,20 @@ if ($font_size = $RCMAIL->config->get('default_font_size')) {
// get reference message and set compose mode
if ($msg_uid = $COMPOSE['param']['draft_uid']) {
$compose_mode = RCUBE_COMPOS E_DRAFT;
$compose_mode = rcmail_sendmail::MOD E_DRAFT;
$OUTPUT->set_env('draft_id', $msg_uid);
$RCMAIL->storage->set_folder($drafts_mbox);
}
else if ($msg_uid = $COMPOSE['param']['reply_uid']) {
$compose_mode = RCUBE_COMPOS E_REPLY;
$compose_mode = rcmail_sendmail::MOD E_REPLY;
}
else if ($msg_uid = $COMPOSE['param']['forward_uid']) {
$compose_mode = RCUBE_COMPOS E_FORWARD;
$compose_mode = rcmail_sendmail::MOD E_FORWARD;
$COMPOSE['forward_uid'] = $msg_uid;
$COMPOSE['as_attachment'] = !empty($COMPOSE['param']['attachment']);
}
else if ($msg_uid = $COMPOSE['param']['uid']) {
$compose_mode = RCUBE_COMPOS E_EDIT;
$compose_mode = rcmail_sendmail::MOD E_EDIT;
}
if ($compose_mode) {
@ -146,7 +139,7 @@ if ($compose_mode) {
$OUTPUT->set_env('compose_mode', $compose_mode);
}
if ($compose_mode == RCUBE_COMPOSE_EDIT || $compose_mode == RCUBE_COMPOS E_DRAFT) {
if ($compose_mode == rcmail_sendmail::MODE_EDIT || $compose_mode == rcmail_sendmail::MOD E_DRAFT) {
// don't add signature in draft/edit mode, we'll also not remove the old-one
// but only on page display, later we should be able to change identity/sig (#1489229)
if ($config_show_sig == 1 || $config_show_sig == 2) {
@ -157,7 +150,7 @@ else if ($config_show_sig == 1)
$OUTPUT->set_env('show_sig', true);
else if ($config_show_sig == 2 & & empty($compose_mode))
$OUTPUT->set_env('show_sig', true);
else if ($config_show_sig == 3 & & ($compose_mode == RCUBE_COMPOSE_REPLY || $compose_mode == RCUBE_COMPOS E_FORWARD))
else if ($config_show_sig == 3 & & ($compose_mode == rcmail_sendmail::MODE_REPLY || $compose_mode == rcmail_sendmail::MOD E_FORWARD))
$OUTPUT->set_env('show_sig', true);
// set line length for body wrapping
@ -173,7 +166,7 @@ if (!empty($msg_uid) && empty($COMPOSE['as_attachment'])) {
}
else {
$prefer_html = $RCMAIL->config->get('prefer_html') || $RCMAIL->config->get('htmleditor')
|| $compose_mode == RCUBE_COMPOSE_DRAFT || $compose_mode == RCUBE_COMPOS E_EDIT;
|| $compose_mode == rcmail_sendmail::MODE_DRAFT || $compose_mode == rcmail_sendmail::MOD E_EDIT;
$RCMAIL->config->set('prefer_html', $prefer_html);
}
@ -192,8 +185,8 @@ if (!empty($msg_uid) && empty($COMPOSE['as_attachment'])) {
if (!$MESSAGE->headers) {
// error
}
else if ($compose_mode == RCUBE_COMPOSE_FORWARD || $compose_mode == RCUBE_COMPOS E_REPLY) {
if ($compose_mode == RCUBE_COMPOS E_REPLY) {
else if ($compose_mode == rcmail_sendmail::MODE_FORWARD || $compose_mode == rcmail_sendmail::MOD E_REPLY) {
if ($compose_mode == rcmail_sendmail::MOD E_REPLY) {
$COMPOSE['reply_uid'] = $MESSAGE->context === null ? $msg_uid : null;
if (!empty($COMPOSE['param']['all'])) {
@ -209,16 +202,16 @@ if (!empty($msg_uid) && empty($COMPOSE['as_attachment'])) {
// Save the sent message in the same folder of the message being replied to
if ($RCMAIL->config->get('reply_same_folder') & & ($sent_folder = $COMPOSE['mailbox'])
& & rcmail_check_sent_folder($sent_folder, false)
& & rcmail_sendmail:: check_sent_folder($sent_folder, false)
) {
$COMPOSE['param']['sent_mbox'] = $sent_folder;
}
}
else if ($compose_mode == RCUBE_COMPOSE_DRAFT || $compose_mode == RCUBE_COMPOS E_EDIT) {
if ($compose_mode == RCUBE_COMPOS E_DRAFT) {
else if ($compose_mode == rcmail_sendmail::MODE_DRAFT || $compose_mode == rcmail_sendmail::MOD E_EDIT) {
if ($compose_mode == rcmail_sendmail::MOD E_DRAFT) {
if ($draft_info = $MESSAGE->headers->get('x-draft-info')) {
// get reply_uid/forward_uid to flag the original message when sending
$info = rcmail_draftinfo_decode($draft_info);
$info = rcmail_sendmail:: draftinfo_decode($draft_info);
if ($info['type'] == 'reply')
$COMPOSE['reply_uid'] = $info['uid'];
@ -229,7 +222,7 @@ if (!empty($msg_uid) && empty($COMPOSE['as_attachment'])) {
// Save the sent message in the same folder of the message being replied to
if ($RCMAIL->config->get('reply_same_folder') & & ($sent_folder = $info['folder'])
& & rcmail_check_sent_folder($sent_folder, false)
& & rcmail_sendmail:: check_sent_folder($sent_folder, false)
) {
$COMPOSE['param']['sent_mbox'] = $sent_folder;
}
@ -265,51 +258,27 @@ if (!empty($COMPOSE['reply_msgid'])) {
$OUTPUT->set_env('reply_msgid', $COMPOSE['reply_msgid']);
}
$MESSAGE->compose = array();
// get user's identities
$MESSAGE->identities = $RCMAIL->user->list_identities(null, true);
// Set From field value
if (!empty($_POST['_from'])) {
$MESSAGE->compose['from'] = rcube_utils::get_input_value('_from', rcube_utils::INPUT_POST);
}
else if (!empty($COMPOSE['param']['from'])) {
$MESSAGE->compose['from'] = $COMPOSE['param']['from'];
}
else if (count($MESSAGE->identities)) {
$ident = rcmail_identity_select($MESSAGE, $MESSAGE->identities, $compose_mode);
$MESSAGE->compose['from'] = $ident['identity_id'];
$MESSAGE->compose['ident'] = $ident;
}
// Initialize helper class to build the UI
$SENDMAIL = new rcmail_sendmail($COMPOSE, array('message' => $MESSAGE));
// process $MESSAGE body/attachments, set $MESSAGE_BODY/$HTML_MODE vars and some session data
$MESSAGE_BODY = rcmail_prepare_message_body();
$OUTPUT->include_script('publickey.js');
// register UI objects
// register UI objects (Note: some objects are registered by rcmail_sendmail above)
$OUTPUT->add_handlers(array(
'composeformhead' => 'rcmail_compose_form_head',
'composeheaders' => 'rcmail_compose_headers',
'composesubject' => 'rcmail_compose_subject',
'composebody' => 'rcmail_compose_body',
'composeattachmentlist' => 'rcmail_compose_attachment_list',
'composeattachmentform' => 'rcmail_compose_attachment_form',
'composeattachment' => 'rcmail_compose_attachment_field',
'filedroparea' => 'compose_file_drop_area',
'priorityselector' => 'rcmail_priority_selector',
'filedroparea' => 'rcmail_compose_file_drop_area',
'editorselector' => 'rcmail_editor_selector',
'receiptcheckbox' => 'rcmail_mdn_checkbox', // deprecated
'mdncheckbox' => 'rcmail_mdn_checkbox',
'dsncheckbox' => 'rcmail_dsn_checkbox',
'storetarget' => 'rcmail_store_target_selection',
'addressbooks' => 'rcmail_addressbook_list',
'addresslist' => 'rcmail_contacts_list',
'responseslist' => 'rcmail_compose_responses_list',
));
$OUTPUT->include_script('publickey.js');
$OUTPUT->send('compose');
@ -412,316 +381,6 @@ function rcmail_process_compose_params(&$COMPOSE)
}
}
function rcmail_compose_form_head($attrib)
{
list($form_start,) = get_form_tags($attrib);
return $form_start;
}
function rcmail_compose_headers($attrib)
{
global $RCMAIL, $MESSAGE;
list($form_start,) = get_form_tags($attrib);
$out = '';
$part = strtolower($attrib['part']);
switch ($part) {
case 'from':
return $form_start . rcmail_compose_header_from($attrib);
case 'to':
case 'cc':
case 'bcc':
$fname = '_' . $part;
$header = $param = $part;
$allow_attrib = array('id', 'class', 'style', 'cols', 'rows', 'tabindex');
$field_type = 'html_textarea';
break;
case 'replyto':
case 'reply-to':
$fname = '_replyto';
$param = 'replyto';
$header = 'reply-to';
case 'followupto':
case 'followup-to':
if (!$fname) {
$fname = '_followupto';
$param = 'followupto';
$header = 'mail-followup-to';
}
$allow_attrib = array('id', 'class', 'style', 'size', 'tabindex');
$field_type = 'html_inputfield';
break;
}
if ($fname & & $field_type) {
// pass the following attributes to the form class
$field_attrib = array('name' => $fname, 'spellcheck' => 'false');
foreach ($attrib as $attr => $value) {
if (stripos($attr, 'data-') === 0 || in_array($attr, $allow_attrib)) {
$field_attrib[$attr] = $value;
}
}
// create teaxtarea object
$input = new $field_type($field_attrib);
$out = $input->show(rcmail_compose_header_value($param));
}
if ($form_start) {
$out = $form_start . $out;
}
// configure autocompletion
$RCMAIL->autocomplete_init();
return $out;
}
function rcmail_compose_header_from($attrib)
{
global $MESSAGE, $OUTPUT, $RCMAIL, $COMPOSE;
// pass the following attributes to the form class
$field_attrib = array('name' => '_from');
foreach ($attrib as $attr => $value) {
if (in_array($attr, array('id', 'class', 'style', 'size', 'tabindex'))) {
$field_attrib[$attr] = $value;
}
}
if (count($MESSAGE->identities)) {
$a_signatures = array();
$identities = array();
$top_posting = intval($RCMAIL->config->get('reply_mode')) > 0
& & !$RCMAIL->config->get('sig_below')
& & ($COMPOSE['mode'] == RCUBE_COMPOSE_REPLY || $COMPOSE['mode'] == RCUBE_COMPOSE_FORWARD);
$separator = $top_posting ? '---' : '-- ';
$add_separator = (bool) $RCMAIL->config->get('sig_separator');
$field_attrib['onchange'] = rcmail_output::JS_OBJECT_NAME.".change_identity(this)";
$select_from = new html_select($field_attrib);
// create SELECT element
foreach ($MESSAGE->identities as $sql_arr) {
$identity_id = $sql_arr['identity_id'];
$select_from->add(format_email_recipient($sql_arr['email'], $sql_arr['name']), $identity_id);
// add signature to array
if (!empty($sql_arr['signature']) & & empty($COMPOSE['param']['nosig'])) {
$text = $html = $sql_arr['signature'];
if ($sql_arr['html_signature']) {
$text = $RCMAIL->html2text($html, array('links' => false));
$text = trim($text, "\r\n");
}
else {
$t2h = new rcube_text2html($text, false);
$html = $t2h->get_html();
}
if ($add_separator & & !preg_match('/^--[ -]\r?\n/m', $text)) {
$text = $separator . "\n" . ltrim($text, "\r\n");
$html = $separator . "< br > " . $html;
}
$a_signatures[$identity_id]['text'] = $text;
$a_signatures[$identity_id]['html'] = $html;
}
// add bcc and reply-to
if (!empty($sql_arr['reply-to'])) {
$identities[$identity_id]['replyto'] = $sql_arr['reply-to'];
}
if (!empty($sql_arr['bcc'])) {
$identities[$identity_id]['bcc'] = $sql_arr['bcc'];
}
$identities[$identity_id]['email'] = $sql_arr['email'];
}
$out = $select_from->show($MESSAGE->compose['from']);
// add signatures to client
$OUTPUT->set_env('signatures', $a_signatures);
$OUTPUT->set_env('identities', $identities);
}
// no identities, display text input field
else {
$field_attrib['class'] = 'from_address';
$input_from = new html_inputfield($field_attrib);
$out = $input_from->show($MESSAGE->compose['from']);
}
return $out;
}
function rcmail_compose_header_value($header)
{
global $COMPOSE, $MESSAGE;
$RCMAIL = rcube::get_instance();
$fvalue = '';
$decode_header = true;
$charset = $MESSAGE->headers->charset;
$separator = ', ';
// we have a set of recipients stored is session
if ($header == 'to' & & ($mailto_id = $COMPOSE['param']['mailto'])
& & $_SESSION['mailto'][$mailto_id]
) {
$fvalue = urldecode($_SESSION['mailto'][$mailto_id]);
$decode_header = false;
$charset = $RCMAIL->output->charset;
// make session to not grow up too much
unset($_SESSION['mailto'][$mailto_id]);
$COMPOSE['param']['to'] = $fvalue;
}
else if (!empty($_POST['_' . $header])) {
$fvalue = rcube_utils::get_input_value('_' . $header, rcube_utils::INPUT_POST, true);
$charset = $RCMAIL->output->charset;
}
else if (!empty($COMPOSE['param'][$header])) {
$fvalue = $COMPOSE['param'][$header];
$charset = $RCMAIL->output->charset;
}
else if ($COMPOSE['mode'] == RCUBE_COMPOSE_REPLY) {
// get recipent address(es) out of the message headers
if ($header == 'to') {
$mailfollowup = $MESSAGE->headers->others['mail-followup-to'];
$mailreplyto = $MESSAGE->headers->others['mail-reply-to'];
// Reply to mailing list...
if ($MESSAGE->reply_all == 'list' & & $mailfollowup) {
$fvalue = $mailfollowup;
}
else if ($MESSAGE->reply_all == 'list'
& & preg_match('/< mailto: ( [ ^ > ]+)>/i', $MESSAGE->headers->others['list-post'], $m)
) {
$fvalue = $m[1];
}
// Reply to...
else if ($MESSAGE->reply_all & & $mailfollowup) {
$fvalue = $mailfollowup;
}
else if ($mailreplyto) {
$fvalue = $mailreplyto;
}
else if (!empty($MESSAGE->headers->replyto)) {
$fvalue = $MESSAGE->headers->replyto;
$replyto = true;
}
else if (!empty($MESSAGE->headers->from)) {
$fvalue = $MESSAGE->headers->from;
}
// Reply to message sent by yourself (#1487074, #1489230, #1490439)
// Reply-To address need to be unset (#1490233)
if (!empty($MESSAGE->compose['ident']) & & empty($replyto)) {
foreach (array($fvalue, $MESSAGE->headers->from) as $sender) {
$senders = rcube_mime::decode_address_list($sender, null, false, $charset, true);
if (in_array($MESSAGE->compose['ident']['email_ascii'], $senders)) {
$fvalue = $MESSAGE->headers->to;
break;
}
}
}
}
// add recipient of original message if reply to all
else if ($header == 'cc' & & !empty($MESSAGE->reply_all) & & $MESSAGE->reply_all != 'list') {
if ($v = $MESSAGE->headers->to) {
$fvalue .= $v;
}
if ($v = $MESSAGE->headers->cc) {
$fvalue .= (!empty($fvalue) ? $separator : '') . $v;
}
// Use Sender header (#1489011)
if ($v = $MESSAGE->headers->get('Sender', false)) {
// Skip common mailing lists addresses: *-bounces@ and *-request@ (#1490452)
if (empty($MESSAGE->headers->others['list-post']) || !preg_match('/-(bounces|request)@/', $v)) {
$fvalue .= (!empty($fvalue) ? $separator : '') . $v;
}
}
// When To: and Reply-To: are the same we add From: address to the list (#1489037)
if ($v = $MESSAGE->headers->from) {
$from = rcube_mime::decode_address_list($v, null, false, $charset, true);
$to = rcube_mime::decode_address_list($MESSAGE->headers->to, null, false, $charset, true);
$replyto = rcube_mime::decode_address_list($MESSAGE->headers->replyto, null, false, $charset, true);
if (count($replyto) & & !count(array_diff($to, $replyto)) & & count(array_diff($from, $to))) {
$fvalue .= (!empty($fvalue) ? $separator : '') . $v;
}
}
}
}
else if (in_array($COMPOSE['mode'], array(RCUBE_COMPOSE_DRAFT, RCUBE_COMPOSE_EDIT))) {
// get drafted headers
if ($header == 'to' & & !empty($MESSAGE->headers->to)) {
$fvalue = $MESSAGE->get_header('to', true);
}
else if ($header == 'cc' & & !empty($MESSAGE->headers->cc)) {
$fvalue = $MESSAGE->get_header('cc', true);
}
else if ($header == 'bcc' & & !empty($MESSAGE->headers->bcc)) {
$fvalue = $MESSAGE->get_header('bcc', true);
}
else if ($header == 'replyto' & & !empty($MESSAGE->headers->others['mail-reply-to'])) {
$fvalue = $MESSAGE->get_header('mail-reply-to');
}
else if ($header == 'replyto' & & !empty($MESSAGE->headers->replyto)) {
$fvalue = $MESSAGE->get_header('reply-to');
}
else if ($header == 'followupto' & & !empty($MESSAGE->headers->others['mail-followup-to'])) {
$fvalue = $MESSAGE->get_header('mail-followup-to');
}
}
// split recipients and put them back together in a unique way
if (!empty($fvalue) & & in_array($header, array('to', 'cc', 'bcc'))) {
$from_email = @mb_strtolower($MESSAGE->compose['ident']['email']);
$to_addresses = rcube_mime::decode_address_list($fvalue, null, $decode_header, $charset);
$fvalue = array();
foreach ($to_addresses as $addr_part) {
if (empty($addr_part['mailto'])) {
continue;
}
// According to RFC5321 local part of email address is case-sensitive
// however, here it is better to compare addresses in case-insensitive manner
$mailto = format_email(rcube_utils::idn_to_utf8($addr_part['mailto']));
$mailto_lc = mb_strtolower($addr_part['mailto']);
if (($header == 'to' || $COMPOSE['mode'] != RCUBE_COMPOSE_REPLY || $mailto_lc != $from_email)
& & !in_array($mailto_lc, (array) $MESSAGE->recipients)
) {
if ($addr_part['name'] & & $mailto != $addr_part['name']) {
$mailto = format_email_recipient($mailto, $addr_part['name']);
}
$fvalue[] = $mailto;
$MESSAGE->recipients[] = $mailto_lc;
}
}
$fvalue = implode($separator, $fvalue);
}
return $fvalue;
}
function rcmail_compose_editor_mode()
{
global $RCMAIL, $COMPOSE;
@ -740,13 +399,13 @@ function rcmail_compose_editor_mode()
else if (isset($_POST['_is_html'])) {
$useHtml = !empty($_POST['_is_html']);
}
else if ($compose_mode == RCUBE_COMPOSE_DRAFT || $compose_mode == RCUBE_COMPOS E_EDIT) {
else if ($compose_mode == rcmail_sendmail::MODE_DRAFT || $compose_mode == rcmail_sendmail::MOD E_EDIT) {
$useHtml = rcmail_message_is_html();
}
else if ($compose_mode == RCUBE_COMPOS E_REPLY) {
else if ($compose_mode == rcmail_sendmail::MOD E_REPLY) {
$useHtml = $html_editor == 1 || ($html_editor >= 2 & & rcmail_message_is_html());
}
else if ($compose_mode == RCUBE_COMPOS E_FORWARD) {
else if ($compose_mode == rcmail_sendmail::MOD E_FORWARD) {
$useHtml = $html_editor == 1 || $html_editor == 4
|| ($html_editor == 3 & & rcmail_message_is_html());
}
@ -778,14 +437,14 @@ function rcmail_prepare_message_body()
$isHtml = (bool) $COMPOSE['param']['html'];
}
// forward as attachment
else if ($COMPOSE['mode'] == RCUBE_COMPOS E_FORWARD & & $COMPOSE['as_attachment']) {
else if ($COMPOSE['mode'] == rcmail_sendmail::MOD E_FORWARD & & $COMPOSE['as_attachment']) {
$isHtml = rcmail_compose_editor_mode();
$body = '';
rcmail_write_forward_attachments();
}
// reply/edit/draft/forward
else if ($COMPOSE['mode'] & & ($COMPOSE['mode'] != RCUBE_COMPOS E_REPLY || intval($RCMAIL->config->get('reply_mode')) != -1)) {
else if ($COMPOSE['mode'] & & ($COMPOSE['mode'] != rcmail_sendmail::MOD E_REPLY || intval($RCMAIL->config->get('reply_mode')) != -1)) {
$isHtml = rcmail_compose_editor_mode();
$messages = array();
@ -832,7 +491,7 @@ function rcmail_prepare_message_body()
}
// compose reply-body
if ($COMPOSE['mode'] == RCUBE_COMPOS E_REPLY) {
if ($COMPOSE['mode'] == rcmail_sendmail::MOD E_REPLY) {
$body = rcmail_create_reply_body($body, $isHtml);
if ($MESSAGE->pgp_mime) {
@ -840,11 +499,11 @@ function rcmail_prepare_message_body()
}
}
// forward message body inline
else if ($COMPOSE['mode'] == RCUBE_COMPOS E_FORWARD) {
else if ($COMPOSE['mode'] == rcmail_sendmail::MOD E_FORWARD) {
$body = rcmail_create_forward_body($body, $isHtml);
}
// load draft message body
else if ($COMPOSE['mode'] == RCUBE_COMPOSE_DRAFT || $COMPOSE['mode'] == RCUBE_COMPOS E_EDIT) {
else if ($COMPOSE['mode'] == rcmail_sendmail::MODE_DRAFT || $COMPOSE['mode'] == rcmail_sendmail::MOD E_EDIT) {
$body = rcmail_create_draft_body($body, $isHtml);
}
}
@ -910,7 +569,7 @@ function rcmail_compose_part_body($part, $isHtml = false)
}
else {
// try to remove the signature
if ($COMPOSE['mode'] != RCUBE_COMPOSE_DRAFT & & $COMPOSE['mode'] != RCUBE_COMPOS E_EDIT) {
if ($COMPOSE['mode'] != rcmail_sendmail::MODE_DRAFT & & $COMPOSE['mode'] != rcmail_sendmail::MOD E_EDIT) {
if ($RCMAIL->config->get('strip_existing_sig', true)) {
$body = rcmail_remove_signature($body);
}
@ -929,7 +588,7 @@ function rcmail_compose_part_body($part, $isHtml = false)
if ($part->ctype_secondary == 'html') {
// use html part if it has been used for message (pre)viewing
// decrease line length for quoting
$len = $COMPOSE['mode'] == RCUBE_COMPOS E_REPLY ? $LINE_LENGTH-2 : $LINE_LENGTH;
$len = $COMPOSE['mode'] == rcmail_sendmail::MOD E_REPLY ? $LINE_LENGTH-2 : $LINE_LENGTH;
$body = $RCMAIL->html2text($body, array('width' => $len));
}
else {
@ -938,7 +597,7 @@ function rcmail_compose_part_body($part, $isHtml = false)
}
// try to remove the signature
if ($COMPOSE['mode'] != RCUBE_COMPOSE_DRAFT & & $COMPOSE['mode'] != RCUBE_COMPOS E_EDIT) {
if ($COMPOSE['mode'] != rcmail_sendmail::MODE_DRAFT & & $COMPOSE['mode'] != rcmail_sendmail::MOD E_EDIT) {
if ($RCMAIL->config->get('strip_existing_sig', true)) {
$body = rcmail_remove_signature($body);
}
@ -951,9 +610,9 @@ function rcmail_compose_part_body($part, $isHtml = false)
function rcmail_compose_body($attrib)
{
global $RCMAIL, $OUTPUT, $HTML_MODE, $MESSAGE_BODY;
global $RCMAIL, $OUTPUT, $HTML_MODE, $MESSAGE_BODY, $SENDMAIL ;
list($form_start, $form_end) = get_ form_tags($attrib);
list($form_start, $form_end) = $SENDMAIL-> form_tags($attrib);
unset($attrib['form']);
if (empty($attrib['id'])) {
@ -1041,7 +700,6 @@ function rcmail_compose_body($attrib)
. ' style="width:0;height:0;border:none;visibility:hidden;" aria-hidden="true">< / iframe > ';
}
function rcmail_create_reply_body($body, $bodyIsHtml)
{
global $RCMAIL, $MESSAGE, $LINE_LENGTH;
@ -1239,7 +897,7 @@ function rcmail_create_draft_body($body, $bodyIsHtml)
return $body;
}
// Removes signature from the message body
function rcmail_remove_signature($body)
{
global $RCMAIL;
@ -1261,7 +919,6 @@ function rcmail_remove_signature($body)
return $body;
}
function rcmail_write_compose_attachments(& $message, $bodyIsHtml)
{
global $RCMAIL, $COMPOSE;
@ -1290,12 +947,12 @@ function rcmail_write_compose_attachments(&$message, $bodyIsHtml)
}
// skip message attachments in reply mode
if ($part->ctype_primary == 'message' & & $COMPOSE['mode'] == RCUBE_COMPOS E_REPLY) {
if ($part->ctype_primary == 'message' & & $COMPOSE['mode'] == rcmail_sendmail::MOD E_REPLY) {
continue;
}
// skip inline images when forwarding in text mode
if ($part->content_id & & $part->disposition == 'inline' & & !$bodyIsHtml & & $COMPOSE['mode'] == RCUBE_COMPOS E_FORWARD) {
if ($part->content_id & & $part->disposition == 'inline' & & !$bodyIsHtml & & $COMPOSE['mode'] == rcmail_sendmail::MOD E_FORWARD) {
continue;
}
@ -1332,7 +989,6 @@ function rcmail_write_compose_attachments(&$message, $bodyIsHtml)
return $cid_map;
}
function rcmail_write_inline_attachments(& $message)
{
global $RCMAIL, $COMPOSE;
@ -1445,6 +1101,7 @@ function rcmail_write_forward_attachments()
}
}
// Saves an image as attachment
function rcmail_save_image($path, $mimetype = '', $data = null)
{
global $COMPOSE;
@ -1484,6 +1141,7 @@ function rcmail_save_image($path, $mimetype = '', $data = null)
return false;
}
// Unicode-safe basename()
function rcmail_basename($filename)
{
// basename() is not unicode safe and locale dependent
@ -1496,69 +1154,8 @@ function rcmail_basename($filename)
}
/**
* Creates reply subject by removing common subject
* prefixes/suffixes from the original message subject
* Attachments list object for templates
*/
function rcmail_reply_subject($subject)
{
$subject = trim($subject);
// replace Re:, Re[x]:, Re-x (#1490497)
$prefix = '/^(re:|re\[\d\]:|re-\d:)\s*/i';
do {
$subject = preg_replace($prefix, '', $subject, -1, $count);
}
while ($count);
// replace (was: ...) (#1489375)
$subject = preg_replace('/\s*\([wW]as:[^\)]+\)\s*$/', '', $subject);
return 'Re: ' . $subject;
}
function rcmail_compose_subject($attrib)
{
global $MESSAGE, $COMPOSE;
list($form_start, $form_end) = get_form_tags($attrib);
unset($attrib['form']);
$attrib['name'] = '_subject';
$attrib['spellcheck'] = 'true';
$textfield = new html_inputfield($attrib);
$subject = '';
// use subject from post
if (isset($_POST['_subject'])) {
$subject = rcube_utils::get_input_value('_subject', rcube_utils::INPUT_POST, TRUE);
}
else if (!empty($COMPOSE['param']['subject'])) {
$subject = $COMPOSE['param']['subject'];
}
// create a reply-subject
else if ($COMPOSE['mode'] == RCUBE_COMPOSE_REPLY) {
$subject = rcmail_reply_subject($MESSAGE->subject);
}
// create a forward-subject
else if ($COMPOSE['mode'] == RCUBE_COMPOSE_FORWARD) {
if (preg_match('/^fwd:/i', $MESSAGE->subject))
$subject = $MESSAGE->subject;
else
$subject = 'Fwd: '.$MESSAGE->subject;
}
// creeate a draft-subject
else if ($COMPOSE['mode'] == RCUBE_COMPOSE_DRAFT || $COMPOSE['mode'] == RCUBE_COMPOSE_EDIT) {
$subject = $MESSAGE->subject;
}
$out = $form_start ? "$form_start\n" : '';
$out .= $textfield->show($subject);
$out .= $form_end ? "\n$form_end" : '';
return $out;
}
function rcmail_compose_attachment_list($attrib)
{
global $RCMAIL, $OUTPUT, $COMPOSE;
@ -1645,7 +1242,9 @@ function rcmail_compose_attachment_list($attrib)
return html::tag('ul', $attrib, $out, html::$common_attrib);
}
/**
* Attachment upload form object for templates
*/
function rcmail_compose_attachment_form($attrib)
{
global $RCMAIL;
@ -1653,98 +1252,22 @@ function rcmail_compose_attachment_form($attrib)
return $RCMAIL->upload_form($attrib, 'uploadform', 'send-attachment', array('multiple' => true));
}
function rcmail_priority_selector($attrib)
{
global $RCMAIL, $MESSAGE;
list($form_start, $form_end) = get_form_tags($attrib);
unset($attrib['form']);
$attrib['name'] = '_priority';
$prio_list = array(
$RCMAIL->gettext('lowest') => 5,
$RCMAIL->gettext('low') => 4,
$RCMAIL->gettext('normal') => 0,
$RCMAIL->gettext('high') => 2,
$RCMAIL->gettext('highest') => 1,
);
$selector = new html_select($attrib);
$selector->add(array_keys($prio_list), array_values($prio_list));
if (isset($_POST['_priority']))
$sel = $_POST['_priority'];
else if (isset($MESSAGE->headers->priority) & & intval($MESSAGE->headers->priority) != 3)
$sel = $MESSAGE->headers->priority;
else
$sel = 0;
$out = $form_start ? "$form_start\n" : '';
$out .= $selector->show((int) $sel);
$out .= $form_end ? "\n$form_end" : '';
return $out;
}
function rcmail_mdn_checkbox($attrib)
{
global $RCMAIL, $MESSAGE;
list($form_start, $form_end) = get_form_tags($attrib);
unset($attrib['form']);
if (!isset($attrib['id']))
$attrib['id'] = 'receipt';
$attrib['name'] = '_mdn';
$attrib['value'] = '1';
$checkbox = new html_checkbox($attrib);
if (isset($_POST['_mdn']))
$mdn_default = $_POST['_mdn'];
else if (in_array($COMPOSE['mode'], array(RCUBE_COMPOSE_DRAFT, RCUBE_COMPOSE_EDIT)))
$mdn_default = (bool) $MESSAGE->headers->mdn_to;
else
$mdn_default = $RCMAIL->config->get('mdn_default');
$out = $form_start ? "$form_start\n" : '';
$out .= $checkbox->show($mdn_default);
$out .= $form_end ? "\n$form_end" : '';
return $out;
}
function rcmail_dsn_checkbox($attrib)
/**
* Register a certain container as active area to drop files onto
*/
function rcmail_compose_file_drop_area($attrib)
{
global $RCMAIL;
list($form_start, $form_end) = get_form_tags($attrib);
unset($attrib['form']);
if (!isset($attrib['id']))
$attrib['id'] = 'dsn';
$attrib['name'] = '_dsn';
$attrib['value'] = '1';
$checkbox = new html_checkbox($attrib);
if (isset($_POST['_dsn']))
$dsn_value = (int) $_POST['_dsn'];
else
$dsn_value = $RCMAIL->config->get('dsn_default');
$out = $form_start ? "$form_start\n" : '';
$out .= $checkbox->show($dsn_value);
$out .= $form_end ? "\n$form_end" : '';
global $OUTPUT;
return $out;
if ($attrib['id']) {
$OUTPUT->add_gui_object('filedrop', $attrib['id']);
$OUTPUT->set_env('filedrop', array('action' => 'upload', 'fieldname' => '_attachments'));
}
}
/**
* Editor mode selector object for templates
*/
function rcmail_editor_selector($attrib)
{
global $RCMAIL;
@ -1768,78 +1291,9 @@ function rcmail_editor_selector($attrib)
return $select->show($useHtml ? 'html' : 'plain');
}
function rcmail_store_target_selection($attrib)
{
global $COMPOSE, $RCMAIL;
$attrib['name'] = '_store_target';
$select = $RCMAIL->folder_selector(array_merge($attrib, array(
'noselection' => '- ' . $RCMAIL->gettext('dontsave') . ' -',
'folder_filter' => 'mail',
'folder_rights' => 'w',
)));
return $select->show(isset($_POST['_store_target']) ? $_POST['_store_target'] : $COMPOSE['param']['sent_mbox'], $attrib);
}
function rcmail_check_sent_folder($folder, $create=false)
{
global $RCMAIL;
// we'll not save the message, so it doesn't matter
if ($RCMAIL->config->get('no_save_sent_messages')) {
return true;
}
if ($RCMAIL->storage->folder_exists($folder, true)) {
return true;
}
// folder may exist but isn't subscribed (#1485241)
if ($create) {
if (!$RCMAIL->storage->folder_exists($folder))
return $RCMAIL->storage->create_folder($folder, true);
else
return $RCMAIL->storage->subscribe($folder);
}
return false;
}
function get_form_tags($attrib)
{
global $RCMAIL, $MESSAGE_FORM, $COMPOSE;
if (rcube_utils::get_boolean((string) $attrib['noform'])) {
return array('', '');
}
$form_start = '';
if (!$MESSAGE_FORM) {
$hiddenfields = new html_hiddenfield(array('name' => '_task', 'value' => $RCMAIL->task));
$hiddenfields->add(array('name' => '_action', 'value' => 'send'));
$hiddenfields->add(array('name' => '_id', 'value' => $COMPOSE['id']));
$hiddenfields->add(array('name' => '_attachments'));
$form_start = empty($attrib['form']) ? $RCMAIL->output->form_tag(array('name' => "form", 'method' => "post")) : '';
$form_start .= $hiddenfields->show();
}
$form_end = ($MESSAGE_FORM & & !strlen($attrib['form'])) ? '< / form > ' : '';
$form_name = $attrib['form'] ?: 'form';
if (!$MESSAGE_FORM)
$RCMAIL->output->add_gui_object('messageform', $form_name);
$MESSAGE_FORM = $form_name;
return array($form_start, $form_end);
}
/**
* Addressbooks list object for templates
*/
function rcmail_addressbook_list($attrib = array())
{
global $RCMAIL, $OUTPUT;
@ -1874,7 +1328,9 @@ function rcmail_addressbook_list($attrib = array())
return html::tag('ul', $attrib, $out, html::$common_attrib);
}
// return the contacts list as HTML table
/**
* Contacts list object for templates
*/
function rcmail_contacts_list($attrib = array())
{
global $RCMAIL, $OUTPUT;
@ -1890,23 +1346,8 @@ function rcmail_contacts_list($attrib = array())
return $RCMAIL->table_output($attrib, array(), array('name'), 'ID');
}
/**
* Register a certain container as active area to drop files onto
*/
function compose_file_drop_area($attrib)
{
global $OUTPUT;
if ($attrib['id']) {
$OUTPUT->add_gui_object('filedrop', $attrib['id']);
$OUTPUT->set_env('filedrop', array('action' => 'upload', 'fieldname' => '_attachments'));
}
}
/**
*
* Responses list object for templates
*/
function rcmail_compose_responses_list($attrib)
{
@ -1919,11 +1360,11 @@ function rcmail_compose_responses_list($attrib)
foreach ($RCMAIL->get_compose_responses(true) as $response) {
$key = $response['key'];
$item = html::a(array(
'href' => '#'.urlencode($response['name']),
'class' => rtrim('insertresponse ' . $attrib['itemclass']),
'unselectable' => 'on',
'tabindex' => '0',
'rel' => $key,
'href' => '#' . urlencode($response['name']),
'class' => rtrim('insertresponse ' . $attrib['itemclass']),
'unselectable' => 'on',
'tabindex' => '0',
'rel' => $key,
), rcube::Q($response['name']));
$jsenv[$key] = $response;