CHANGELOG | ●●●●● patch | view | raw | blame | history | |
config/defaults.inc.php | ●●●●● patch | view | raw | blame | history | |
index.php | ●●●●● patch | view | raw | blame | history | |
program/include/rcmail_output_html.php | ●●●●● patch | view | raw | blame | history | |
program/lib/Roundcube/rcube_ldap_generic.php | ●●●●● patch | view | raw | blame | history | |
program/steps/addressbook/save.inc | ●●●●● patch | view | raw | blame | history | |
program/steps/mail/check_recent.inc | ●●●●● patch | view | raw | blame | history | |
program/steps/mail/list.inc | ●●●●● patch | view | raw | blame | history | |
program/steps/mail/move_del.inc | ●●●●● patch | view | raw | blame | history | |
skins/larry/styles.css | ●●●●● patch | view | raw | blame | history |
CHANGELOG
@@ -16,6 +16,8 @@ - Set In-Reply-To and References for forwarded messages (#1489593) - Removed redundant default_folders config option (#1489737) - Implemented IMAP SPECIAL-USE extension support [RFC6154] (#1487830) - Add configurable LDAP_OPT_DEREF option (#1489864) - Optimize some framed pages content for better performance (#1489792) - Fix mbox files import RELEASE 1.0.1 config/defaults.inc.php
@@ -784,6 +784,8 @@ 'sizelimit' => '0', // Enables you to limit the count of entries fetched. Setting this to 0 means no limit. 'timelimit' => '0', // Sets the number of seconds how long is spend on the search. Setting this to 0 means no limit. 'referrals' => false, // Sets the LDAP_OPT_REFERRALS option. Mostly used in multi-domain Active Directory setups 'dereference' => 0, // Sets the LDAP_OPT_DEREF option. One of: LDAP_DEREF_NEVER, LDAP_DEREF_SEARCHING, LDAP_DEREF_FINDING, LDAP_DEREF_ALWAYS // Used where addressbook contains aliases to objects elsewhere in the LDAP tree. // definition for contact groups (uncomment if no groups are supported) // for the groups base_dn, the user replacements %fu, %u, $d and %dc work as for base_dn (see above) index.php
@@ -211,7 +211,7 @@ $OUTPUT->show_message('sessionerror', 'error', null, true, -1); } if ($OUTPUT->ajax_call || !empty($_REQUEST['_framed'])) { if ($OUTPUT->ajax_call || $OUTPUT->framed) { $OUTPUT->command('session_error', $RCMAIL->url(array('_err' => 'session'))); $OUTPUT->send('iframe'); } program/include/rcmail_output_html.php
@@ -30,12 +30,12 @@ { public $type = 'html'; protected $message = null; protected $message; protected $template_name; protected $js_env = array(); protected $js_labels = array(); protected $js_commands = array(); protected $skin_paths = array(); protected $template_name; protected $scripts_path = ''; protected $script_files = array(); protected $css_files = array(); @@ -58,8 +58,6 @@ /** * Constructor * * @todo Replace $this->config with the real rcube_config object */ public function __construct($task = null, $framed = false) { @@ -67,7 +65,6 @@ $this->devel_mode = $this->config->get('devel_mode'); //$this->framed = $framed; $this->set_env('task', $task); $this->set_env('x_frame_options', $this->config->get('x_frame_options', 'sameorigin')); $this->set_env('standard_windows', (bool) $this->config->get('standard_windows')); @@ -84,7 +81,7 @@ if (!empty($_REQUEST['_extwin'])) $this->set_env('extwin', 1); if ($this->framed || !empty($_REQUEST['_framed'])) if ($this->framed || $framed) $this->set_env('framed', 1); $lic = <<<EOF @@ -256,8 +253,9 @@ public function get_skin_file($file, &$skin_path = null, $add_path = null) { $skin_paths = $this->skin_paths; if ($add_path) if ($add_path) { array_unshift($skin_paths, $add_path); } foreach ($skin_paths as $skin_path) { $path = realpath($skin_path . $file); @@ -429,20 +427,27 @@ array_unshift($this->js_commands, array('hide_message', $unlock)); } if (!empty($this->script_files)) if (!empty($this->script_files)) { $this->set_env('request_token', $this->app->get_request_token()); // write all env variables to client if ($commands = $this->get_js_commands()) { $js = $this->framed ? "if (window.parent) {\n" : ''; $js .= $commands . ($this->framed ? ' }' : ''); $this->add_script($js, 'head_top'); } $commands = $this->get_js_commands($framed); // if all js commands go to parent window we can ignore all // script files and skip rcube_webmail initialization (#1489792) if ($framed) { $this->scripts = array(); $this->script_files = array(); } // write all javascript commands $this->add_script($commands, 'head_top'); // send clickjacking protection headers $iframe = $this->framed || !empty($_REQUEST['_framed']); if (!headers_sent() && ($xframe = $this->app->config->get('x_frame_options', 'sameorigin'))) $iframe = $this->framed || $this->env['framed']; if (!headers_sent() && ($xframe = $this->app->config->get('x_frame_options', 'sameorigin'))) { header('X-Frame-Options: ' . ($iframe && $xframe == 'deny' ? 'sameorigin' : $xframe)); } // call super method $this->_write($template, $this->config->get('skin_path')); @@ -564,27 +569,47 @@ * * @return string $out */ protected function get_js_commands() protected function get_js_commands(&$framed = null) { $out = ''; if (!$this->framed && !empty($this->js_env)) { $out .= self::JS_OBJECT_NAME . '.set_env('.self::json_serialize($this->js_env).");\n"; $this->command('set_env', $this->js_env); } if (!empty($this->js_labels)) { $this->command('add_label', $this->js_labels); } $out = ''; $parent_commands = 0; foreach ($this->js_commands as $i => $args) { $method = array_shift($args); $parent = $this->framed || preg_match('/^parent\./', $method); foreach ($args as $i => $arg) { $args[$i] = self::json_serialize($arg); } $parent = $this->framed || preg_match('/^parent\./', $method); $out .= sprintf( "%s.%s(%s);\n", ($parent ? 'if(window.parent && parent.'.self::JS_OBJECT_NAME.') parent.' : '') . self::JS_OBJECT_NAME, preg_replace('/^parent\./', '', $method), implode(',', $args) ); if ($parent) { $parent_commands++; $method = preg_replace('/^parent\./', '', $method); $parent_prefix = 'if (window.parent && parent.' . self::JS_OBJECT_NAME . ') parent.'; $method = $parent_prefix . self::JS_OBJECT_NAME . '.' . $method; } else { $method = self::JS_OBJECT_NAME . '.' . $method; } $out .= sprintf("%s(%s);\n", $method, implode(',', $args)); } $framed = $parent_prefix && $parent_commands == count($this->js_commands); // make the output more compact if all commands go to parent window if ($framed) { $out = "if (window.parent && parent." . self::JS_OBJECT_NAME . ") {\n" . str_replace($parent_prefix, "\tparent.", $out) . "}\n"; } return $out; @@ -600,12 +625,13 @@ public function abs_url($str, $search_path = false) { if ($str[0] == '/') { if ($search_path && ($file_url = $this->get_skin_file($str, $skin_path))) if ($search_path && ($file_url = $this->get_skin_file($str, $skin_path))) { return $file_url; } return $this->base_path . $str; } else return $str; } @@ -1322,13 +1348,8 @@ $output = trim($templ); if (empty($output)) { $output = $this->default_template; $output = html::doctype('html5') . "\n" . $this->default_template; $is_empty = true; } // set default page title if (empty($this->pagetitle)) { $this->pagetitle = 'Roundcube Mail'; } // replace specialchars in content @@ -1478,7 +1499,7 @@ */ public function form_tag($attrib, $content = null) { if ($this->framed || !empty($_REQUEST['_framed'])) { if ($this->framed || $this->env['framed']) { $hiddenfield = new html_hiddenfield(array('name' => '_framed', 'value' => '1')); $hidden = $hiddenfield->show(); } @@ -1518,7 +1539,7 @@ // we already have a <form> tag if ($attrib['form']) { if ($this->framed || !empty($_REQUEST['_framed'])) if ($this->framed || $this->env['framed']) $hidden->add(array('name' => '_framed', 'value' => '1')); return $hidden->show() . $content; } program/lib/Roundcube/rcube_ldap_generic.php
@@ -190,6 +190,9 @@ if (isset($this->config['referrals'])) ldap_set_option($lc, LDAP_OPT_REFERRALS, $this->config['referrals']); if (isset($this->config['dereference'])) ldap_set_option($lc, LDAP_OPT_DEREF, $this->config['dereference']); } else { $this->_debug("S: NOT OK"); program/steps/addressbook/save.inc
@@ -165,6 +165,10 @@ $a_js_cols[] = rcube::Q((string)$record[$col]); } // performance: unset some big data items we don't need here $record = array_intersect_key($record, array('ID' => 1,'email' => 1,'name' => 1)); $record['_type'] = 'person'; // update the changed col in list $OUTPUT->command('parent.update_contact_row', $cid, $a_js_cols, $newcid, $source, $record); program/steps/mail/check_recent.inc
@@ -85,7 +85,7 @@ $OUTPUT->command('set_quota', $RCMAIL->quota_content()); } $OUTPUT->set_env('exists', $RCMAIL->storage->count($mbox_name, 'EXISTS')); $OUTPUT->set_env('exists', $RCMAIL->storage->count($mbox_name, 'EXISTS', true)); // "No-list" mode, don't get messages if (empty($_POST['_list'])) { @@ -146,7 +146,7 @@ // set trash folder state if ($mbox_name === $trash) { $OUTPUT->command('set_trash_count', $RCMAIL->storage->count($mbox_name, 'EXISTS')); $OUTPUT->command('set_trash_count', $RCMAIL->storage->count($mbox_name, 'EXISTS', true)); } } program/steps/mail/list.inc
@@ -93,7 +93,7 @@ // update message count display $pages = ceil($count/$RCMAIL->storage->get_pagesize()); $exists = $RCMAIL->storage->count($mbox_name, 'EXISTS'); $exists = $RCMAIL->storage->count($mbox_name, 'EXISTS', true); $OUTPUT->set_env('messagecount', $count); $OUTPUT->set_env('pagecount', $pages); program/steps/mail/move_del.inc
@@ -166,7 +166,7 @@ $OUTPUT->command('set_trash_count', $exists); } else if ($target !== null && $target === $trash) { $OUTPUT->command('set_trash_count', $RCMAIL->storage->count($trash, 'EXISTS')); $OUTPUT->command('set_trash_count', $RCMAIL->storage->count($trash, 'EXISTS', true)); } } skins/larry/styles.css
@@ -2489,6 +2489,11 @@ margin-bottom: 1px; } .attachmentslist li.txt, .attachmentslist li.text { background-position: 0 -416px; } .attachmentslist li.pdf { background-position: 0 -26px; } @@ -2546,11 +2551,6 @@ .attachmentslist li.video { background-position: 0 -338px; } .attachmentslist li.txt, .attachmentslist li.text { background-position: 0 -416px; } .attachmentslist li.ics,