Skip to content

@alecpl alecpl released this Mar 31, 2019 · 11 commits to release-1.3 since this release

This is a service release to update the stable version 1.3 of Roundcube Webmail. It contains fixes to several bugs backported from the master branch. See the complete changelog below.

This version in considered stable and we recommend to update all productive installations
of Roundcube with it. Please do backup your data before updating!

CHANGELOG

  • Fix TinyMCE download location(s) (#6694)
  • Fix bug where a message/rfc822 part without a filename wasn't listed on the attachments list (#6494)
  • Fix handling of empty entries in vCard import (#6564)
  • Fix bug in parsing some IMAP command responses that include unsolicited replies (#6577)
  • Fix PHP 7.2 compatibility in debug_logger plugin (#6586)
  • Fix so ANY record is not used for email domain validation, use A, MX, CNAME, AAAA instead (#6581)
  • Fix so mime_content_type check in Installer uses files that should always be available (i.e. from program/resources) (#6599)
  • Fix missing CSRF token on a link to download too-big message part (#6621)
  • Fix bug when aborting dragging with ESC key didn't stop the move action (#6623)
  • Fix bug where next row wasn't selected after deleting a collapsed thread (#6655)
Assets 8
Pre-release

@thomascube thomascube released this Feb 28, 2019 · 171 commits to master since this release

This is a first release candidate for the next major version 1.4 of Roundcube webmail which has now been in development for quite a while. Although the new responsive Elastic skin is now functional and feature complete, it still lacks the final brush-up to make it shine. We have now finally found a volunteer to work on this and once completed, a second release candidate will follow.

For now you’re all invited to give the new 1.4 version another test run. Besides the responsive theme it comes with lots of new features and improvements since the beta release. Check the Changelog below for a complete list of changes.

Please also try customizing the Elastic skin using the _styles.less and _variables.less files and let us know what’s missing. You'll find guidance in the README.md file inside the skin folder.

Because we don’t yet consider the Elastic theme fully complete, it’s not set to be the default theme. Adjust your config in order to enable it with

$config['skin'] = 'elastic';

This is a beta release and we recommend to test it on a separate environment.
And don't forget to backup your data before installing it.

CHANGELOG

  • Changed 'password_charset' default to 'UTF-8' (#6522)
  • Add skins_allowed option (#6483)
  • SMTP GSSAPI support via krb_authentication plugin (#6417)
  • Avoid Referer leaking by using Referrer-Policy:same-origin header (#6385)
  • Removed 'referer_check' option (#6440)
  • Use constant prefix for temp file names, don't remove temp files from other apps (#6511)
  • Ignore 'Sender' header on Reply-All action (#6506)
  • deluser.sh: Add option to delete users who have not logged in for more than X days (#6340)
  • HTML5 Upload Progress - as a replacement for the old server-side solution (#6177)
  • Update to TinyMCE 4.8.2
  • Update to jQuery-MiniColors 2.3.4
  • Prevent from using deprecated timezone names from jsTimezoneDetect
  • Force session.gc_probability=1 when using custom session handlers (#6560)
  • Support simple field labels (e.g. LetterHub examples) in csv imports (#6541)
  • Add cache busters also to images used by templates (#6610)
  • Plugin API: Added 'raise_error' hook (#6199)
  • Plugin API: Added 'common_headers' hook (#6385)
  • Plugin API: Added 'ldap_connected' hook
  • Enigma: Update to OpenPGPjs 4.2.1 - fixes user name encoding issues in key generation (#6524)
  • Enigma: Fixed multi-host synchronization of private and deleted keys and pubring.kbx file
  • Managesieve: Added support for 'editheader' extension - RFC5293 (#5954)
  • Managesieve: Fix bug where custom header or variable could be lost on form submission (#6594)
  • Markasjunk: Integrate markasjunk2 features into markasjunk - marking as non-junk + learning engine (#6504)
  • Password: Added 'modoboa' driver (#6361)
  • Password: Fix bug where password_dovecotpw_with_method setting could be ignored (#6436)
  • Password: Fix bug where new users could skip forced password change (#6434)
  • Password: Allow drivers to override default password comparisons (eg new is not same as current) (#6473)
  • Password: Allow drivers to override default strength checks (eg allow for 'not the same as last x passwords') (#246)
  • Passowrd: Allow drivers to define password strength rules displayed to the user
  • Password: Allow separate password saving and strength drivers for use of strength checking services (#5040)
  • Password: Add zxcvbn driver for checking password strength (#6479)
  • Password: Disallow control characters in passwords
  • Password: Add support for Plesk >= 17.8 (#6526)
  • Elastic: Improved datepicker displayed always in parent window
  • Elastic: On touch devices display attachment icons on messages list (#6296)
  • Elastic: Make menu button inactive if all subactions are inactive (#6444)
  • Elastic: On mobile/tablet jump to the list on folder selection (#6415)
  • Elastic: Various improvements on mail compose screen (#6413)
  • Elastic: Support new-line char as a separator for pasted recipients (#6460)
  • Elastic: Improved UX of search dialogs (#6416)
  • Elastic: Fix unwanted thread expanding when selecting a collapsed thread in non-mobile mode (#6445)
  • Elastic: Fix too small height of mailvelope mail preview frame (#6600)
  • Elastic: Add "status bar" for mobile in mail composer
  • Elastic: Add selection options on contacts list (#6595)
  • Elastic: Fix unintentional layout preference overwrite (#6613)
  • Log errors caused by low pcre.backtrack_limit when sending a mail message (#6433)
  • Fix so max_message_size limit is checked also when forwarding messages as attachments (#6580)
  • Fix so performance stats are logged to the main console log also when per_user_logging=true
  • Fix malformed message saved into Sent folder when using big attachments and low memory limit (#6498)
  • Fix incorrect IMAP SASL GSSAPI negotiation (#6308)
  • Fix so unicode in local part of the email address is also supported in recipient inputs (#6490)
  • Fix bug where autocomplete list could be displayed out of screen (#6469)
  • Fix style/navigation on error page depending on authentication state (#6362)
  • Fix so invalid smtp_helo_host is never used, fallback to localhost (#6408)
  • Fix custom logo size in Elastic (#6424)
  • Fix listing the same attachment multiple times on forwarded messages
  • Fix bug where a message/rfc822 part without a filename wasn't listed on the attachments list (#6494)
  • Fix inconsistent offset for various time zones - always display Standard Time offset (#6531)
  • Fix dummy Message-Id when resuming a draft without Message-Id header (#6548)
  • Fix handling of empty entries in vCard import (#6564)
  • Fix bug in parsing some IMAP command responses that include unsolicited replies (#6577)
  • Fix PHP 7.2 compatibility in debug_logger plugin (#6586)
  • Fix so ANY record is not used for email domain validation, use A, MX, CNAME, AAAA instead (#6581)
  • Fix so mime_content_type check in Installer uses files that should always be available (i.e. from program/resources) (#6599)
  • Fix missing CSRF token on a link to download too-big message part (#6621)
  • Fix bug when aborting dragging with ESC key didn't stop the move action (#6623)
Assets 8

@thomascube thomascube released this Oct 26, 2018 · 1891 commits to master since this release

This is a service release to update the stable version 1.3 of Roundcube Webmail.
It contains fixes to several bugs backported from the master branch including a security fix for a reported XSS vulnerability plus updates to ensure compatibility with PHP 7.3 and recent versions of Courier-IMAP, Dovecot and MySQL 8. See the complete changelog below.

CHANGELOG

  • Fix PHP warnings on dummy QUOTA responses in Courier-IMAP 4.17.1 (#6374)
  • Fix so fallback from BINARY to BODY FETCH is used also on [PARSE] errors in dovecot 2.3 (#6383)
  • Enigma: Fix deleting keys with authentication subkeys (#6381)
  • Fix invalid regular expressions that throw warnings on PHP 7.3 (#6398)
  • Fix so Classic skin splitter does not escape out of window (#6397)
  • Fix XSS issue in handling invalid style tag content (#6410)
  • Fix compatibility with MySQL 8 - error on 'system' table use
  • Managesieve: Fix bug where show_real_foldernames setting wasn't respected (#6422)
  • New_user_identity: Fix %fu/%u vars substitution in user specific LDAP params (#6419)
  • Fix support for "allow-from " in x_frame_options config option (#6449)
  • Fix bug where valid content between HTML comments could have been skipped in some cases (#6464)
  • Fix multiple VCard field search (#6466)
  • Fix session issue on long running requests (#6470)
Assets 8
Pre-release

@thomascube thomascube released this Aug 25, 2018 · 435 commits to master since this release

This is a beta release of the next major version 1.4 of Roundcube webmail.
With this milestone we introduce some new features:

  • New responsive skin with mobile support
  • Email Resent (Bounce) feature
  • Improved Mailvelope integration
  • Support for Redis cache
  • Support for SMTPUTF8

Because the new responsive skin is not yet fully completed, it's not enabled
by default. In order to make it the default for your users, change your
config.inc.php accordingly:

$config['skin'] = 'elastic';

Although it still needs some polishing, the new skin solves the urgent need
to enable access to Roundcube for mobile devices. The plugin elastic4mobile
makes it the default for mobile devices while keeping the configured default
for desktop browsers.

The Elastic skin is built with LESS and of course the sources are included.
They allow a certain degree of customization by adjusting some color variables.
All you need is to compile your very own customized skin with lessc.

In case you're running Roundcube directly from source or if you're not using
the complete package, you need to install 3rd party javascript modules
by executing the following install script:

$ bin/install-jsdeps.sh

This is a beta release and we recommend to test it on a separate environment.
And don't forget to backup your data before installing it.

CHANGELOG

  • Added new skin with mobile support - the Elastic
  • Support Redis cache
  • Email Resent (Bounce) feature (#4985)
  • Improved Mailvelope integration
    • Added private key listing and generating to identity settings
    • Enable encrypt & sign option if Mailvelope supports it
  • Allow contacts without an email address (#5079)
  • Support SMTPUTF8 and relax email address validation to support unicode in local part (#5120)
  • Support for IMAP folders that cannot contain both folders and messages (#5057)
  • Update to jQuery-3.3.1
  • Update to jQuery-minicolors 2.2.6
  • Update to TinyMCE 4.7.13
  • Remove sample PHP configuration from .htaccess and .user.ini files (#5850)
  • Extend skin_logo setting to allow per skin logos (#6272)
  • Use Masterminds/HTML5 parser for better HTML5 support (#5761)
  • Add More actions button in Contacts toolbar with Copy/Move actions (#6081)
  • Display an error when clicking disabled link to register protocol handler (#6079)
  • Add option trusted_host_patterns (#6009, #5752)
  • Support additional connect parameters in PostgreSQL database wrapper
  • Use UI dialogs instead of confirm() and alert() where possible
  • Display value of the SMTP message size limit in the error message (#6032)
  • Show message flagged status in message view (#5080)
  • Skip redundant INSERT query on successful logon when using PHP7
  • Replace display_version with display_product_version (#5904)
  • Extend disabled_actions config so it accepts also button names (#5903)
  • Handle remote stylesheets the same as remote images, ask the user to allow them (#5994)
  • Add Message-ID to the sendmail log (#5871)
  • Add option to hide folders in share/other-user namespace or outside of the personal namespace root (#5073)
  • Archive: Fix archiving by sender address on cyrus-imap
  • Archive: Style Archive folder also on folder selector and folder manager lists
  • Archive: Add Thunderbird compatible Month option (#5623)
  • Archive: Create archive folder automatically if it's configured, but does not exist (#6076)
  • Enigma: Add button to send mail unencrypted if no key was found (#5913)
  • Enigma: Add options to set PGP cipher/digest algorithms (#5645)
  • Enigma: Multi-host support
  • Managesieve: Add ability to disable filter sets and other actions (#5496, #5898)
  • Managesieve: Add option managesieve_forward to enable settings dialog for simple forwarding (#6021)
  • Managesieve: Support filter action with custom IMAP flags (#6011)
  • Managesieve: Support 'mime' extension tests - RFC5703 (#5832)
  • Managesieve: Support GSSAPI authentication with krb_authentication plugin (#5779)
  • Managesieve: Support enabling the plugin for specified hosts only (#6292)
  • Password: Support host variables in password_db_dsn option (#5955)
  • Password: Automatic virtualmin domain setting, removed password_virtualmin_format option (#5759)
  • Password: Added password_username_format option (#5766)
  • subscriptions_option: show \Noselect folders greyed out (#5621)
  • zipdownload: Added option to define size limit for multiple messages download (#5696)
  • vcard_attachments: Add possibility to send contact vCard from Contacts toolbar (#6080)
  • Changed defaults for smtp_user (%u), smtp_pass (%p) and smtp_port (587)
  • Composer: Fix certificate validation errors by using packagist only (#5148)
  • Add --get and --extract arguments and CACHEDIR env-variable support to install-jsdeps.sh (#5882)
  • Support _filter and _scope as GET arguments for opening mail UI (#5825)
  • Various improvements for templating engine and skin behaviours
    • Support conditional include
    • Support for 'link' objects
    • Support including files with path relative to templates directory
    • Use instead of for submit button on logon screen
  • Support skin localization (#5853)
  • Reset onerror on images if placeholder does not exist to prevent from requests storm
  • Unified and simplified code for loading content frame for responses and identities
  • Display contact import and advanced search in popup dialogs
  • Display a dialog for mail import with supported format description and upload size hint
  • Make possible to set (some) config options from a skin
  • Added optional checkbox selection for the list widget
  • Make 'compose' command always enabled
  • Add .log suffix to all log file names, add option log_file_ext to control this (#313)
  • Return "401 Unauthorized" status when login fails (#5663)
  • Support both comma and semicolon as recipient separator, drop recipients_separator option (#5092)
  • Plugin API: Added 'show_bytes' hook (#5001)
  • Add option to not indent quoted text on top-posting reply (#5105)
  • Removed global $CONFIG variable
  • Removed debug_level setting
  • Support AUTHENTICATE LOGIN for IMAP connections (#5563)
  • Support LDAP GSSAPI authentication (#5703)
  • Localized timezone selector (#4983)
  • Use 7bit encoding for ISO-2022-* charsets in sent mail (#5640)
  • Handle inline images also inside multipart/mixed messages (#5905)
  • Allow style tags in HTML editor on composed/reply messages (#5751)
  • Use Github API as a fallback to fetch js dependencies to workaround throttling issues (#6248)
  • Show confirm dialog when moving folders using drag and drop (#6119)
  • Fix bug where new_user_dialog email check could have been circumvented by deleting / abandoning session (#5929)
  • Fix skin extending for assets (#5115)
  • Fix handling of forwarded messages inside of a TNEF message (#5632)
  • Fix bug where attachment size wasn't visible when the filename was too long (#6033)
  • Fix checking table columns when there's more schemas/databases in postgres/mysql (#6047)
  • Fix css conflicts in user interface and e-mail content (#5891)
  • Fix duplicated signature when using Back button in Chrome (#5809)
  • Fix touch event issue on messages list in IE/Edge (#5781)
  • Fix so links over images are not removed in plain text signatures converted from HTML (#4473)
  • Fix various issues when downloading files with names containing non-ascii chars, use RFC 2231 (#5772)
  • Fix PHP warnings on dummy QUOTA responses in Courier-IMAP 4.17.1 (#6374)
  • Fix so fallback from BINARY to BODY FETCH is used also on [PARSE] errors in dovecot 2.3 (#6383)
  • Enigma: Fix deleting keys with authentication subkeys (#6381)
  • Fix invalid regular expressions that throw warnings on PHP 7.3 (#6398)
  • Fix so Classic skin splitter does not escape out of window (#6397)
Assets 8

@thomascube thomascube released this Jul 27, 2018 · 1891 commits to master since this release

This is a service release to update the stable version 1.3 of Roundcube Webmail. It contains fixes to several bugs backported from the master branch including a security fix mitigating the EFAIL issue recently discovered in OpenPGP. See the complete changelog below.

This version in considered stable and we recommend to update all productive installations
of Roundcube with it. Please do backup your data before updating!

CHANGELOG

  • Fix PHP Warning: Use of undefined constant IDNA_DEFAULT on systems without php-intl (#6244)
  • Fix bug where some parts of quota information could have been ignored (#6280)
  • Fix bug where some escape sequences in html styles could bypass security checks
  • Fix bug where some forbidden characters on Cyrus-IMAP were not prevented from use in folder names
  • Fix bug where only attachments with the same name would be ignored on zip download (#6301)
  • Fix bug where unicode contact names could have been broken/emptied or caused DB errors (#6299)
  • Fix bug where after "mark all folders as read" action message counters were not reset (#6307)
  • Enigma: [EFAIL] Don't decrypt PGP messages with no MDC protection (#6289)
  • Fix bug where some HTML comments could have been malformed by HTML parser (#6333)
Assets 8

@thomascube thomascube released this Apr 29, 2018 · 2450 commits to master since this release

This is a follow-up to the recent security update for the stable version 1.2. It fixes a regression that sneaked in with the IMAP command injection protection which unintentionally disabled actions that operate on all selected messages (e.g. mark all as junk).

We recommend to update all productive installations of Roundcube 1.2.8.
Please do backup your data before updating!

CHANGELOG

  • Fix regression where IMAP commands with '*' uidset argument wasn't working
Assets 8

@thomascube thomascube released this Apr 29, 2018 · 3061 commits to master since this release

This is a follow-up to the recent security update for the stable version 1.1. It fixes a regression that sneaked in with the IMAP command injection protection which unintentionally disabled actions that operate on all selected messages (e.g. mark all as junk).

We recommend to update all productive installations of Roundcube 1.1.11.
Please do backup your data before updating!

CHANGELOG

  • Fix regression where IMAP commands with '*' uidset argument wasn't working
Assets 8

@thomascube thomascube released this Apr 18, 2018 · 3061 commits to master since this release

This is a security update to the stable version 1.2. It fixes a recently reported vulnerability allowing IMAP command injection via a GET parameters. More details about this are published under CVE-2018-9846.

The second fix is about a missed remote content blocking on HTML messages with specially crafted image and style tags.

We strongly recommend to update all productive installations of Roundcube 1.1.x.
Please do backup your data before updating!

CHANGELOG

  • Don't ignore (global) userlogins/sendmail logs in per_user_logging mode
  • Fix security issue in remote content blocking on HTML image and style tags (#6178)
  • Fix check_request() bypass in places using get_uids() [CVE-2018-9846] (#6238)
  • Fix possible IMAP command injection vulnerability [CVE-2018-9846] (#6229)
Assets 8

@thomascube thomascube released this Apr 17, 2018 · 2450 commits to master since this release

This is a security update to the stable version 1.2. It fixes a recently reported vulnerability allowing IMAP command injection via a GET parameters. More details about this are published under CVE-2018-9846.

The second fix is about a missed remote content blocking on HTML messages with specially crafted image and style tags.

We strongly recommend to update all productive installations of Roundcube 1.2.x.
Please do backup your data before updating!

CHANGELOG

  • Fix check_request() bypass in places using get_uids() [CVE-2018-9846] (#6238)
  • Fix possible IMAP command injection vulnerability [CVE-2018-9846] (#6229)
  • Fix security issue in remote content blocking on HTML image and style tags (#6178)
Assets 8

@thomascube thomascube released this Apr 11, 2018 · 1891 commits to master since this release

This is a security update to the stable version 1.3. It primarily fixes a recently discovered IMAP command injection vulnerability caused by insufficient input validation within the archive plugin. Details about the vulnerability are published under CVE-2018-9846.

Additionally, we back-ported some minor fixes from the master branch which improve PHP 7.2 compatibility as well as PGP signing and key handling for those who use the Enigma plugin. See the complete changelog below.

We strongly recommend to update all productive installations of Roundcube.
Please do backup your data before updating!

CHANGELOG

  • Fix parsing date strings (e.g. from a Date: mail header) with comments (#6216)
  • Fix PHP 7.2: count(): Parameter must be an array in enchant-based spellchecker (#6234)
  • Fix possible IMAP command injection and type juggling vulnerabilities (#6229)
  • Enigma: Fix key selection for signing
  • Enigma: Enable keypair generation on Internet Explorer 11
  • Fix check_request() bypass in places using get_uids() [CVE-2018-9846] (#6238)
  • Fix bug where usernames without domain part could be malformed or converted to lower-case on logon (#6224)
Assets 8
You can’t perform that action at this time.