e87ff6340d2caaf4c457c400424b85e90387c33d
[squirrelmail.git] / doc / ChangeLog
1 *************************************
2 *** SquirrelMail Devel Series 1.5 ***
3 *************************************
4
5 Version 1.5.2 - SVN
6 -------------------
7 - Fixed system lock-ups caused by a combination of certain rare, malformed
8 message headers and buggy versions of PHP mbstring (#3053349, $2987016).
9 - Fix broken set_url_var function in functions/html.php (#1729814).
10 - Fix incorrect detection of auth mechanisms in conf.pl (#1727033).
11 - The search expression in the LDAP backend of the Addressbook is now
12 configurable, which can allow the result set to be expanded.
13 - Preliminary support for NAMESPACE in Squirrelmail IMAP Backend: NAMESPACE
14 is parsed and stored in session upon login.
15 - Now uses the $Forwarded IMAP keyword for forwarded messages, when it is
16 enabled or when arbitrary keywords ("PERMANENT FLAGS \*") are permitted.
17 RFC 4550, paragraph 2.8.
18 - Added support for authorization identifier in IMAP backend, for SASL
19 authentication mechanisms PLAIN and DIGEST-MD5. This can be set upon login
20 by use of an external plugin.
21 - Fix warning about array required in array_keys for display options when no
22 fontset is defined.
23 - Added "bad plugin" blacklist in configtest.php.
24 - Fix MagicHTML fix with respect to parsing of u\rl in IE.
25 - Added monitored folders option to newmail plugin.
26 - Tweaked STARTTLS option for SMTP/IMAP to allow previous settings of just
27 pure TLS not to be used to assume STARTTLS.
28 - Fixed quotes in configuration strings in administrator plugin.
29 - Fixed View as HTML link so it doesn't forget it was part of a seach result.
30 - Don't use delimiter in IMAP subscription command, when noselect folder is
31 created.
32 - Security: Possible cookie theft in src/redirect.php if
33 register_globals is enabled, and malicous site is running
34 in same domain.
35 - Stop URL parsing, if 8bit symbols or HTML entities are detected (#1356798).
36 - Added new color themes by Jeremy Landes, Tammi Maggard and Lucas Austin-Howe
37 (#1378332), (#1377567), (#1377529), (#1377528), (#1377527), (#1377526),
38 (#1377525), (#1393188).
39 - Issue loading options page always loaded the prefs
40 initial_value on display, instead of the users' value.
41 - Adding the message_body hook to src/view_html.php and src/view_text.php,
42 allowing display of unsafe images when viewing HTML attachments and when
43 HTML is in an <iframe>.
44 - Fixed from address in case of MDN receipts (patch from Dimitar Pashev)
45 - Advanced tree folder listing is moved to templates. $advanced_tree
46 configuration variable is removed.
47 - Added system locale tests to configtest.php script.
48 - Fixed invalid HTML output that caused error notices in compose.php (#1454409).
49 - Introduction of centralised initialization file init.php. Location of some
50 scripts is changed. If code tries to use older script layout, scripts will
51 break and display error messages.
52 - Added session regenrate id functionality to prohibit session hijacking.
53 - Fixed sqsession_cookie function for setting HttpOnly cookie attribute.
54 - Reduce references header in a smart way to avoid "header too long"
55 errors from SMTP servers in really long threads (#1167754, #1465342).
56 - Added code that allows to use internal password functions in sqimap_login().
57 Switched plugins to use this code instead of accessing key and otp information
58 directly.
59 - Fixed automatic mailbox creation in left_main.php. 1.5.1 mailbox caching
60 broke detection of unsubscribed special folders (#1461578).
61 - Undo extra sanitizing in decodeHeader() function (#1460638).
62 - Added workaround for broken OpenBSD 3.8+ setlocale() function (#1427512).
63 - Fixed session lockups on large attachment downloads.
64 - Added configtest hook in src/configtest.php.
65 - Improved error handling for the help pages.
66 - Fixed possibility to use single quote in provider name (#1475744).
67 - Improve recovery when EHLO not supported on legacy SMTP servers
68 (#1031455).
69 - Added error handling and $onlylocal argument to abook_init hook.
70 - Added PHP 5.1.0 date_default_timezone_set() function support. Allows
71 to use time zone settings in PHP safe_mode.
72 - Sanitized IMAP folder names in error_message() function and filters plugin.
73 - Take X-Forwarded-Host HTTP header in consideration when constructing
74 base_uri for redirects; reduces problems with transparent proxies
75 (#1488590).
76 - Fixed server capability retrieval for "double" cases in capability
77 response, like "FOO FOO=bar".
78 - Various address book database backend modifications. Fixed invalid
79 error checks in insert() and delete() methods (checks caused PHP
80 warnings). Turned on Pear DB field case portability mode. Escaped SQL
81 wildcards in search() method. Handle nickname changes in modify()
82 method when new nickname is already in use. Made search expressions
83 case insensitive in search() method.
84 - Added special folder (Drafts, Sent, Trash) translations in mailbox
85 tree and folder selection boxes.
86 - Added write support to address book LDAP backend. Patch by David
87 Hardeman (#1495763).
88 - Added message copy options.
89 - Removed html formating from address book backend classes. Added
90 fullname() method to addressbook_backend class. Moved
91 htmlspecialchars() sanitizing from address book backend classes to
92 html output code. If third party code displays errors from address
93 book object in html, errors must be sanitized and ASCII line feeds
94 should be converted to html line breaks.
95 - Add note to conf.pl / config_default.php to warn users that set
96 sensitive passwords in that file to properly secure it.
97 - Prevent modifications in advanced identities, when editing of
98 identities is disabled.
99 - Configuration utility does not allow 8bit symbols in IMAP folder names
100 (#1485501).
101 - Address book file backend will break with error message, if required
102 address book fields are not available. Prevents address book corruption
103 and address book format violations that can cause PHP notices.
104 - Added line length setting in local_file address book backend (#1181561).
105 - Removed proprietary wrap attribute from compose form (#1512681).
106 - Fix URL for Read Receipts being incorrect in some cases (#1177518).
107 - Don't allow selecting INBOX as Sent, Draft or Trash folder (#1242346).
108 - Session cookies are turned on, if session.use_cookies is turned off
109 in PHP configuration (#1518885).
110 - Make the default attachment dir /var/local/squirrelmail/attach, not
111 $data_dir.
112 - Add HTML labels for form elements.
113 - Fixed spamcop web based reporting form (#1519673) and removed service
114 type options from spamcop plugin.
115 - Removed trailing ?> from function scripts.
116 - Added checks for non-existent backend to AddressBook class.
117 - Make the base for the SquirrelMail URL configurable. Adds a new variable
118 config_base_location to config.php and a new option to conf.pl. This is
119 to prevent problems in installs where our heuristic doesn't work
120 correctly (#1521299, #1460675, #1110064, #1000850, #1113791).
121 - Removed conf.pl dependency on Perl IO::Socket module. Automatic detection
122 of supported authentication mechanisms is disabled, if IO::Socket is not
123 available.
124 - Removed HTTP Status header from signout page (#1424748).
125 - config_default.php is loaded before site configuration file.
126 config_local.php overrides are removed from config.php and loaded by
127 main initiation script.
128 - Fixed resuming of compose when session expired while writing, and make
129 sure the code only sets those variables that are needed in compose and
130 are not already set. Thanks James Bercegay from GulfTech for pointing
131 this out.
132 - Subfolders of system folders are not tagged as special in folder
133 management page in order to allow rename and delete operations with
134 subfolders (#1460011).
135 - Trash subfolders are allowed in courier. INBOX.Trash is not treated
136 as special on Courier, unless some SquirrelMail configuration option
137 marks this folder as special (#1354393). Configtest utility should
138 display warning, if Courier IMAP XMAGICTRASH extension is detected.
139 - Show purge link for Trash folder without any messages, if folder has
140 subfolders (#1413569).
141 - Custom SMTP AUTH configuration variables are moved from config_local.php
142 to main configuration file.
143 - Fixed subscription of new 'noselect' folders (#1315912).
144 - Moving the development documentation to the documentation module.
145 - Drop obsolete script plugins/make_archive.pl.
146 - Fix misspelled constant PREG_SPLIT_NI_EMPTY in sqimap_get_message
147 (#1543573).
148 - Provide View Unsafe Images link on viewing a text/html attachment.
149 - Added APOP, TLS and STLS support to mail_fetch plugin (#575299).
150 - Added Courier IMAP OUTBOX check to configtest utility.
151 - Moved login_form hook to its own table row on login page.
152 - Added check_plugin_version() function.
153 - If mailbox name starts with slash or contains ../, error message is
154 generated. Safety check for insecure default UW IMAP setup (#1557078).
155 - Ignore message copy errors when messages are deleted. Allows to delete
156 messages when quota is exceeded. (#614887) (#646386) (#1446026)
157 - Fixed unintended literal fetching (#1562271).
158 - Checked if configuration file is readable in configuration utility
159 (#1568355).
160 - Added PHP pspell extension support to squirrelspell plugin.
161 - Add CEST and MEST (non-standard) timezone codes for +0200.
162 - Add support for SpamAssassin's X-Spam-Status header (#1589520).
163 - Added plugin on/off switch, which completely disables all plugins
164 (optionally for one named user, otherwise for all users).
165 - Security: close cross site scripting vulnerability in draft, compose
166 and mailto functionality [CVE-2006-6142].
167 - Security: work around an issue in Internet Explorer that would guess
168 the mime type of a file based on contents, not Content-Type header.
169 - Security: Multiple IE cross site scripting issues related to the
170 generous parsing of the words 'expression' and 'url' by IE.
171 - Security: Removing @import when sanitizing html mail.
172 - Redesigned plugin hook system. do_hook_function() has been removed
173 and do_hook() now emulates do_hook_function()'s return value and
174 also has its plugin arguments passed by value, etc.
175 - Drop obsolete ORDB RBL from filters plugin (#1629398).
176 - Add warning about magic_quotes_* in configtest.
177 - Unify accepted versions for imap_server_type and set_defaults (#1629722).
178 - Improve attachment temp file creation.
179 - Add ability for listcommands plugin to show post and reply links for
180 user-configured non-RFC 2369-compliant lists; admin must enable by
181 configuring plugin. Thanks to Peter Steiner.
182 - Fixed HttpOnly cookies again.
183 - Update for switch from CVS to Subversion.
184 - Default provider URI link fixed (was broken when on plugin options pages, etc)
185 - Fix URL to send read receipts from read_body (#1637572).
186 - Add option to ask users for personal information on first login.
187 - Drop redundant call to session_register, which could trigger a segfault
188 in PHP 4.4.5 (#1664155).
189 - If a date-header cannot be parsed, display the unparsed version as a
190 better-than-nothing alternative.
191 - Fix Priority and Receipt compose options being reset after return from
192 HTML addressbook, and allow returning from an empty address book (#1673056).
193 - Do not special case the 'None' folder.
194 - Fixes for filters issues. (#1634735)
195 - session_id reporting session id when no active session (#1685031).
196 - Added sq_change_text_domain() for plugins to use when switching text
197 domains. If plugins use this function, it fixes #1434043.
198 - Add dynamic textarea sizing slider control to compose screen (default_advanced
199 skin)
200 - Security: fixes for the HTML filter to counter further XSS exploits:
201 HTML attachments containing 'data:' URLs, Internet Explorer-specifc
202 charset conversion exploits, and request forgery through included
203 images. Thanks to Mikhail Markin, Tomas Kuliavas and Michael Jordon
204 for reporting these issues. [CVE-2007-1262, CVE-2007-2589]
205 - Fix busy loop and notice when two literals in IMAP fetch (#1739433).
206 - Resolved issue with compose session not being updated after send/save.
207 - Added ability to detect HTTP_X_FORWARDED_PROTO in get_location(),
208 thanks to Daniel Watts.
209 - Fix test for signout.php in the logged in check in init.php so it
210 cannot be circumvented by manipulating the URL. External plugins might
211 rely on init.php guaranteeing that the user is logged in.
212 - Sort readdir() output in conf.pl (#1755886).
213 - Made the webmail_top hook work again for plugins that want to change
214 the URI of the "right" frame; plugins have to change the value of the
215 global variable $right_frame_url
216 - No longer store all message composition sessions in the PHP session,
217 since it was not made use of and in rare cases, made sessions too big
218 - Composition restoration functionality now correctly restores attachments
219 - Added smtp_auth hook
220 - Removed "Include CCs when Forwarding Messages", which had no functionality
221 whatsoever.
222 - Added "preselected" query argument to mailbox list.
223 - Make the Message Details plugin actually show the correct entity when
224 viewing details of attached messages.
225 - Enabled user selection of address format when adding from address
226 book during message composition.
227 - Added a "short_open_tag" configuration test.
228 - Fixed outgoing messages to allow addresses such as "0@..." or "000@...",
229 etc. (#1818398).
230 - PAGE_NAME might not be defined in all plugins, which might cause a
231 "not defined" error on session timeouts.
232 - Allow custom session handlers to work correctly (and be defined at the
233 application level with SquirrelMail).
234 - Fix off-by-one in bodystructure parsing triggered by servers sending
235 a body location part (e.g. Sun Java System Messaging Server). Thanks
236 John Callahan (#1808382).
237 - Invalid initialization of To: header (#1772893).
238 - Added SquirrelMail debug mode.
239 - Handle PHP's insistence on setting the value to 'deleted' for destroyed sessions
240 (#1829098).
241 - Some IMAP servers send nil for an empty email body (See RFC2180,
242 section 4.1.3 on empty strings).
243 - Let configtest.php use optional PEAR dynamic extension loading,
244 patch by Walter Huijbers (#1833123).
245 - Fix for IMAP servers that were having problems saving sent messages
246 - Added "Secured Configuration" mode.
247 - Added edit list, checkbox, radio group, multiple-select folder list
248 and multiple-select string list option widget types.
249 - Allow database based preferences to read in default settings from the
250 default_pref file next to hardcoding them into the DB class, thanks
251 Thierry Godefroy.
252 - Reimplement printer friendly to make use of CSS.
253 - Enhanced address book page: added address list pagination, added
254 'Compose to' button, put labels around address entries tied to
255 checkboxes, added hook and template plugin output sections for
256 plugins that can filter address book listings and modify the abook
257 navigation bar. Complements RisuMail team (risumail.jp).
258 - Added submit button type option widget
259 - Allow address lookup by fields other than nickname/alias
260 - Implement preference override hooks for database prefs backend that
261 have long been in the file-based prefs backend
262 - Removed the Address Take (abook_take) plugin; please see the Add Address
263 (third party) plugin.
264 - Allow a different server address for the POP server to be configured when
265 using POP before SMTP.
266 - Seed random number generator in one place during script init.
267 - Add native output buffering.
268 - Allow control over white space wrapping of auto-generated SquirrelMail
269 option widgets.
270 - Add informational type option widget
271 - Add password type option widget
272 - Make all submit button names unique on compose screen
273 - Make address book file permissions 0600 - same as preference files
274 - Added compatibility with Dovecot's bigint UIDs
275 - Ensure that hash directory computation is the same on both 32 and
276 64 bit architectures. (#2596879)
277 - Allow multiple addresses in one abook entry (separate with commas),
278 although we HIGHLY DISCOURAGE grouping in this manner - note amongst
279 other issues that can come up, sizing for large groups will be a
280 problem. (#2611967)
281 - Added Tamil translation (Thanks to Kengatharaiyer Sarveswaran).
282 - Added Bengali (Bangladesh) translation (Thanks to Jamil Ahmed).
283 - Implemented accesskeys on primary pages; is user-configurable in the
284 Options -> Accessibility Preferences page
285 - Moved documentation to doc/ directory and added example .htaccess
286 files in all directories to which browsers don't need direct access.
287 - Added RFC 2231 support. Thanks to Piotr Pawlow. (#2501379)
288 - Date headers in outgoing messages have been brought into RFC 822
289 compliance (removed time zone name). (#1849410)
290 - Default Content-Transfer-Encoding is now RFC-compliant "7bit"
291 instead of "us-ascii". (#1942060)
292 - Outgoing attachments that have lines longer than allowed per RFC
293 are now encoded so they are not corrupted by artificial line folds.
294 Thanks to Kelly Fallon. (#2226470, $1473714)
295 - Completed a massive update to contrib/flat2sql.pl.
296 - Display visual indication of forwarded messages.
297 - Added Khmer translation (Thanks to Khoem Sokhem).
298 - Removed use of session_unregister() for compatibility with PHP 5.3.0
299 and PHP 6
300 - Remove ability for HTML emails to use CSS positioning to overlay
301 SquirrelMail content (Thanks to Luc Beurton). (#2723196) [CVE-2009-1581]
302 - Fixed improper sanitizing of PHP_SELF and the lack of sanitizing of
303 QUERY_STRING server environment variables (Thanks to Niels Teusink
304 and Christian Balzer). [CVE-2009-1578]
305 - Fixed the lack of sanitizing of contrib/decrypt_headers.php input;
306 also includes general cleanup of that page (Thanks to Niels Teusink).
307 [also CVE-2009-1578]
308 - Fixed unsanitized shell command in example IMAP username mapping
309 function (map_yp_alias) (Thanks to Niels Teusink).
310 [CVE-2009-1579, CVE-2009-1381]
311 - Fixed session fixation issues where someone who can modify a user's
312 cookies could gain control of their login session. The SquirrelMail
313 base URI is now uniformly generated, extraneous cookies are cleaned
314 up and session IDs are regenerated upon every login (Thanks to Tomas
315 Hoger). [CVE-2009-1580]
316 - Cleanup variable name in address search for compose to clearup confusion.
317 - Remove Javascript from address search page when JavaScript is disabled.
318 - Add "Check All" function to address book when using "in-page" addressbook.
319 - Fixed the Filters plugin to allow commas in filter criteria text.
320 - In SMTP, when we EHLO with an IP, wrap it in brackets (#2793154).
321 - Bug Report plugin not handling multiple same key capabilities (thread/auth)
322 (#2796007).
323 - Removed the shut down DSBL blocklists (#2796734).
324 - Fixed broken RFC1918 reference in contrib/.htaccess and doc/.htaccess (#2798839).
325 - Stop using deprecated ereg functions. (#2820952)
326 - Remove personal data from Message ID seed. (#880029/847107)
327 - Implemented page referal verification mechanism. (Secunia Advisory SA34627)
328 - Implemented security token system. (Secunia Advisory SA34627)
329 - Fix issue with multi-part related messages not showing all attachments (#2830140).
330 - Fix for security token missing in newmail plugin (#2919418).
331 - Fix for mailto: urls containing + characters, thanks to Michael Puls II for the
332 patch.
333 - Make base URL autodetection more robust; fixes some lighttpd issues
334 (probably #1741469).
335 - Encoded From headers now properly quoted (#2830141).
336 - Multibyte strings (notably subjects) are now handled correctly (#2824813,
337 #2925731).
338 - X-DNS-Prefetch-Control: off header is now sent to browsers to prevent information
339 leakage when Firefox does DNS prefetching for URLs contained in emails.
340 - Added the ability to configure Google Mail (Gmail) as the mail server
341 behind SquirrelMail.
342 - Fix error with SpamCop reporting plugin not being able to send report as
343 emails (#1795310).
344 - Fix typo in SpamCop plugin.
345 - Reduced default time security tokens stay valid from 30 days to 2 days
346 (reduces chances of session data growing too large)
347 - Fixed minor vulnerability in Mail Fetch plugin [CVE-2010-1637/TEHTRI-SA-2010-009]
348 - Now properly quote personal part of encoded addresses when replying.
349 - Now fill in default subject when forwarding as attachment (#2936541).
350 - Fixed issues caused by use of PostgreSQL keyword "user" in SquirrelMail's
351 default preferences database schema (#2943483).
352 - Fixed attachment filename decoding problems (#2994865).
353 - Now allow multiple plugins to handle (add links for) a single
354 attachment MIME type.
355 - Fixed sqauth_read_password() for plugins on the login_verified hook.
356 - Forced addition of a file suffix to attachments that lack a filename
357 (helps forwarded messages avoid spam filters) (thanks to Petr
358 Kletecka) (#3139004).
359 - Added smtp_authenticate hook (thanks to Emmanuel Dreyfus).
360 - Allow administrators to configure subfolders of user INBOXes to be
361 treated as special folders by adding $subfolders_of_inbox_are_special
362 to config_local.php.
363 - Added clickjacking protection (thanks to Asbjorn Thorsen and Geir Hansen
364 for bringing this to our attention). [CVE-2010-4554]
365 - Fixed XSS holes in generic options inputs, XSS hole in the SquirrelSpell
366 plugin, and added anti-CSRF protection to the empty trash feature (thanks
367 to Nicholas Carlini for finding all these issues).
368 [CVE-2011-2752, CVE-2011-2753, CVE-2010-4555]
369 - Fixed XSS problem with unsanitized style tags in messages. [CVE-2011-2023]
370 - Always ensure that the Reply-To header is a full email address in
371 outgoing messages
372 - Unified address book searches somewhat: file-backed address books now
373 search in each field individually; database-backed address books now
374 search in fields other than first/last name (nickname, email)
375 - Made performance improvements in security token handling
376 - Improvements for PHP 5.4 compatibility.
377 - Added option that allows users to have replies to their own
378 messages sent to the recipient of the previous message (#3520988).
379 - Added associative edit list option widget, with optional folder
380 list selector for values
381 - Added option to use blank spacer instead of security image ("This
382 image has been removed for security reasons.") for replacing
383 unsafe images.
384 - Full date and time is used as "title" (mouseover) text for dates
385 shown on the message list screen
386 - Added advanced control over the SSL context used when connecting
387 to the SMTP and IMAP servers over SSL/TLS (thanks to Emmanuel
388 Dreyfus). See $imap_stream_options and $smtp_stream_options in
389 config_local.example.php for more information.
390 - Added ability to show login error from the IMAP server instead of
391 traditional "Unknown user or password incorrect" (thanks to Alain
392 Williams). See $display_imap_login_error in the configuration
393 file or "4. General Options ==> 21. Display login error from IMAP"
394 in the configuration tool.
395 - Configuration tool now shows the SquirrelMail version
396 - Prevent session lock-up caused by filters plugin trying to move
397 messages in an account that is over quota.
398 - Added MD5 alternative to directory hash calculation
399 - Added ability for administrator to control whether or not users
400 can edit their reply-to address ($edit_reply_to in config.php)
401 - Added new "login_before_page_header" (boolean) hook; allows
402 plugins to have more explicit control over login page header
403 - Added new "smtp_helo_override" hook; allows plugins to override
404 the HELO host sent to the SMTP server when sending messages
405 - Added PDO support for database connections, so no external
406 database module needs to be installed
407 - Fixed insufficient sendmail command argument escaping (thanks
408 to Mitchel Sahertian, Beyond Security/Dawid Golunski and Filippo
409 Cavallarin for bringing this to our attention). [CVE-2017-7692]
410 - Added ability to control the display of the "Check Spelling"
411 button provided by the squirrelspell plugin, which allows
412 administrators to offer this plugin but keep it out of the way
413 for users who do not want it. Put sqspell_show_button=0 in
414 default preferences if it should be hidden by default
415 - Add ability for saved drafts to indicate if they are a reply
416 or forward and if so, to which message, and mark that message
417 as replied or forwarded when the draft is finally sent
418 - Added option to allow returning to the message one had been
419 replying to after sending
420 - Sanitize user-supplied attachment filenames [CVE-2017-7692]
421
422 Version 1.5.1 (branched on 2006-02-12)
423 --------------------------------------
424 - New reply citation to include date and author.
425 - Security: Fix some possible XSS bugs.
426 - Norwegian Bokmal translation uses nb_NO.
427 - Integrated Msg_Flags plugin - turn on/off icons using configuration tool,
428 menu number 11 (Tweaks), option number 3, after which users must select an
429 icon theme in Options/Display Preferences.
430 "Flag"/"Unflag" buttons are implemented as separate plugin.
431 - Added Farsi and Tagalog translation support.
432 - Enabled Ukrainian and Russian-Ukrainian support
433 - Fixed subfolders named "foo.inbox" didn't always work well.
434 - sqimap_create_stream() was not obeying passed params properly.
435 - Fix non-selectable inbox.
436 - Add src/configtest.php script which checks for common errors in the config.
437 - Improve display of some unparsable/absent dates (#891354).
438 - Add comment (Highest,Normal,Lowest) to X-Priority header.
439 Some SpamAssassin rule triggers on the absence of such a comment.
440 - Corrected moving of last message in a folder using Delete-Move-Next
441 functionality added to core in 1.5.0.
442 - Fix test for LOGINDISABLED, should only test when the auth mech actually
443 is 'login'.
444 - Update required PHP version to 4.1.0, and remove PHP 4.0.x legacy code.
445 - Make writing of preferences, abook, calendars fail better when disk full
446 (#915527).
447 - Remove code related to non-UID-supporting IMAP servers.
448 - Fix quoteimap() regex escaping problem (#921291).
449 - Added option to suppress Received: line in outbound SM headers (#847107).
450 - Changed read_body header from links to buttons (looks like message index).
451 - Add functions for building HTML forms (functions/forms.php).
452 - Moved javascript_on to session (from prefs). Centralized JavaScript
453 detection in prefs.php method checkForJavascript.
454 - Added abook_init and abook_add_class hooks.
455 - Fixed "Resume Draft" to continue using selected identities (#845290).
456 - Fixed RFC2821 incompliancy by adding a fallback mechanism to HELO if
457 EHLO is not supported.
458 - Fixed RFC2298 incompliancy by setting envelope sender to null.
459 - Fixed problem where setting all the messages on the last page of the
460 message list would return one page higher.
461 - Remove call to perform expunge on mailbox select - auto-expunge will
462 still be performed on message delete, etc.
463 - Allow single quotes to be used in theme name in conf.pl (#805309).
464 - Fixed on the fly decoding of base64 encoded attachments.
465 - Fixed message rejects by the Postfix sendmail wrapper when attachments were
466 involved.
467 - Fixed date display bug for messages of today. Show short format in case
468 of long format. (only occurs in the timeframe around 0:00 AM till
469 timezone).
470 - Added address book sorting options. Ascending/descending sorting code
471 written by Bryan Loniewski.
472 - Use Special Folder Color config option works again (#931956).
473 - In POP3-class, be more liberal regarding RFC-incompliant POP3-servers.
474 - Set up language before outputing errors in auth.php to make them appear in
475 the correct language.
476 - Added Basque translation support.
477 - Remove flag buttons / links from display if mailbox doesn't allow it.
478 - Make used of cached ordered uid list in case of server_side_sorting.
479 - Rewrite of internal mailbox sorting routines.
480 - Added sort by message size.
481 - Security: Fixed XSS vulnerability in content-type display in the attachment
482 area of read_body.php discovered by Roman Medina.
483 - Removed src/move_messages.php, move_before_move and move_messages_button_action
484 hooks. Mailbox listing actions should be handled by src/right_main.php and
485 functions/mailbox_display.php hooks.
486 - Get alternating row colors of addressbook in sync with mailbox list.
487 - Give proper error when PEAR DB not found.
488 - Remove inappropriate strip_tags() from add-to-addressbook (#968475).
489 - Prefs caching didn't work properly with register_globals off (#995102).
490 - Security: fix SQL injection vulnerability in addressbook.
491 [CVE-2004-0521]
492 - Removed html_top and html_bottom hooks. No longer used/needed.
493 - Added "trailing text" for options built by SquirrelMail (text placed
494 after text and select list inputs on options pages)
495 - Custom option page values now repopulate correctly
496 - Added "no focus" option for compose page in display preferences (setting
497 reply focus to "No focus" also affects composing new messages)
498 - Current hook name is now globally available when running a hook
499 ($currentHookName)
500 - Fix bug when Saving to Draft folder that contains special characters.
501 - Added size limit to signatures saved in file backend. Created
502 error_option_save function, that allows sending error message to options
503 page. Thanks to Martynas Bieliauskas for spotting big signature "option".
504 - Make SquirrelSpell work with safe_mode enabled, if using PHP >=4.3.0.
505 Patch by Ray Ferguson.
506 - Make IP-address in Message-ID RFC822 compliant.
507 - Uneditable address book entries no longer have checkboxes on addresses page.
508 - Alignment of title text above folder list fixed.
509 - Changed structure of xtra_code functions that are used by some translations.
510 - Added Uighur language support.
511 - Added status bar to compose window when "Compose In New Window" is used.
512 - Reenabled the move_messages_button_action hook and changed its name to
513 mailbox_display_button_action to promote the new location
514 - Making delete button, when viewing a message, consider which page was viewed
515 before.
516 - $agresive_decoding configuration option changed to $aggressive_decoding.
517 Fixed spelling.
518 - Added $lossy_encoding option (provides fix for #806698)
519 - Reenabled use of $default_charset option. Option works only with en_US
520 translation in order to prevent language/charset misconfiguration.
521 - Fixes for nonpopulation of folder lists and errors when emptying the trash
522 (provides fixes for #1019185 and #1017941)
523 - Fixed $custom_css loading in squirrelspell plugin.
524 - Turkish translation uses C character case conversion rules. Fixes PHP and
525 SquirrelMail functions are assume English conversion rules.
526 - Fixed problem that caused an error when deleting all messages on the last
527 page of a paginated view (provides fix for #1014612).
528 - Added MySQL password/UNIX crypt support to mysql backend in the
529 change_password plugin.
530 - Make SMTP Authentication detection in conf.pl more RFC-compliant.
531 - Fixed IMAP errors when using mail_fetch plugin to auto-fetch on login.
532 - Fixed folder list in Create Folders list for Courier (properly skip INBOX).
533 - Fixed undefined variables in sqimap_create_stream().
534 - Added Bengali translation support.
535 - Fixed left frame mailbox list when sorting by case.
536 - Separated fortune plugin configuration variables from main plugin scripts.
537 See plugins/fortune/INSTALL.
538 - Fix for #906217 when checking spelling of inline replies, the corrected
539 words would appear through original email.
540 - Fixed empty information menu when viewing vCards without information
541 but name and e-mail address.
542 - User may now add an e-mail address when adding vCards without one to the
543 address book. No need to wait for the error message anymore.
544 - Removed japanese_xtra function used by older XTRA_CODE calls. Plugins
545 should use separate xtra_code functions. Older function does not provide
546 information about supported options.
547 - Added php-gettext classes (see class/l10n/*.php) and ngettext support
548 functions (provides fix for #1019007).
549 - LC_NUMERIC locale is set to C. (workaround for #1027130). Some plugins
550 might use decimal delimiters incorrectly.
551 - Added sq_is8bit function that can be used to detect 8bit strings.
552 - Added sq_mb_list_encodings function that provides list of encodings
553 supported by PHP mbstring module.
554 - Added Content-Transfer-Encoding: 8bit header for read receipts that contain
555 8bit symbols. (provides fix for #934033).
556 - Fixed decoding function problems when mbstring.func_override has
557 MB_OVERLOAD_REGEX enabled.
558 - Security: Fixed XSS exploit in decodeHeader function. [CVE-2004-1036]
559 - Added site configuration and custom translation engine support to translate
560 plugin.
561 - Fixed SquirrelSpell error output. Patch courtesy David Boone.
562 - Fixed bug in IMAP read routines that treated "0" as false instead of
563 a string (patch courtesy Maurice Makaay).
564 - Fixed PHP notice when header property value is blank.
565 - Added compact paginator option. Patch by Felix Egli.
566 - Fixed reply/forward form in order to avoid warnings in SSL enabled sites.
567 Patch by Felix Egli.
568 - Removed command line option unsupported by qmail-inject in
569 class/deliver/Deliver_SendMail.class.php. Thanks to Ken Brush.
570 - Global file based address book is controled in configuration. Removed
571 global_file address book backend (use 'local_file' instead).
572 - Added Net-Style theme by Gabriele Maidecchi. Closes patch #1041323.
573 - Fix: Messages shown with bad times in message list due to misinterpreted
574 UW IMAP internal date.
575 - Fixed path used by random theme.
576 - Utf7-imap encoding/decoding functions will check, if required charset is
577 supported by mbstring and use it. Fixes bug #1005353.
578 - LDAP backend will use internal SquirrelMail charset conversion functions
579 instead of PHP XML extension. Fixes bug #655137.
580 - Added Wood and Silver Steel themes by Pavel Spatny and Simple Green theme.
581 - Fix two time zone calculation bugs, thanks to David White. Fixes #1063879.
582 - 'Priority' and 'Importance' headers are now also recognised, next to the
583 'X-Priority' header that we've supported since a long time. Fixes #1039935.
584 - Handle a reload of the signout page gracefully: do not present an error
585 about having to be logged in to be able to sign out. Fixes #1070069.
586 - Prevent & being eaten in set_url_var, thanks Marcin Orlowski (#1053725).
587 - Removed internal_link hook.
588 - Added sq_setlocale function in order to use multiple locale names.
589 - Set up language before outputing errors in signout.php to make them appear
590 in the correct language.
591 - Added size attributes to new_mail sound tags. Fixes #818958.
592 - Removed extra ; in SquirrelMail added Received header per RFC 822
593 (#1088548).
594 - Add IMAP server type "hmailserver" to make search work with hMailServer.
595 Fixes #1085377.
596 - Reuploaded newmail plugin sounds. Fixes files uploaded to cvs without binary
597 option.
598 - Changing your JavaScript preference required a re-login to work.
599 Fixes #983614.
600 - Fix listcommands plugin to behave like normal reply/compose
601 links, and return to message page that originally called from.
602 - Max upload file size now correctly handles a '-1' value, meaning
603 unlimited. (#1094569).
604 - Security: Added hook for Preferences Backend to resolve potential
605 file inclusions. [CVE-2005-0075]
606 - Remove Printer Friendly Clean Display config option, the cleaning
607 is now always done.
608 - Create new Options section "Compose Preferences" and move some
609 options from Display Preferences there; also move some around within
610 Display Preferences.
611 - Security: Fix possible file/offsite inclusion in src/webmail.php.
612 [CVE-2005-0103]
613 - Security: Fix possible XSS issues in src/webmail.php. [CVE-2005-0104]
614 - Fix undefined variables in src/webmail.php.
615 - 24hr clock format should include a leading 0.
616 - Removed numeric keys for plugin array in config.php.
617 - Fixed translations of "On DATE, AUTHOR Wrote" and "AUTHOR Wrote" replies.
618 - Added sq_str_pad function for padding of multi-byte strings.
619 - Added sq_strlen function for calculation of multi-byte string length.
620 - Quoted "INBOX" in check for the status of INBOX in a LIST call. Fixes an
621 issue with a specific IMAP server.
622 - Move default_pref to the config/ dir, but keep checking legacy locations
623 first for bc. Do not fail with an error when default_pref not found, just
624 create an empty one.
625 - Add trailing slash for data directory used by global file based address
626 book (#1105760).
627 - Fixed sorting problem is get_squirrel_sort() function (#1115403).
628 - Add "Show Only Subscribed Folders" option to allow users to show all
629 folders instead of only subscribed ones (#1105756, #1105250).
630 - Add workaround for Mercury/32 servers that will subscribe again to
631 an already subscribed folder (#1115409).
632 - Added blank.png for missing image support.
633 - Use the proper attachment filenames in case of forwarding a message.
634 - Fix for #855320 where Outlook Express was creating CID: based URLs,
635 but not assigning a content-id to the attachment. This is a bug in
636 Outlook Express and is non-RFC compliant behaviour.
637 - Strip <outbind://> tags out. This is a Microsoft only protocol and
638 references files local to the sending machine. This causes issues
639 with Internet Explorer.
640 - Replace <img src="outbind://"> links with clean images to stop
641 issues with Internet Explorer not being able to track down the image.
642 - Empty src attribute on img tags causes logouts (IE only), replacing
643 string with blank.png.
644 - Added vmailmgrd backend to change_password plugin.
645 - Fixed change_password_init hook.
646 - Give an error to the user when SquirrelMail is not configured yet
647 (instead of "failed to include config.php").
648 - Added swf and mp3 support to newmail plugin. Restored custom user media
649 support.
650 - Removed unused save_option_header() function from display and compose
651 option includes.
652 - Fixed bug #1124764, view unsafe images inside printer friendly view.
653 - Fixed bug #1032366, remove NUL characters in text attachments on sent.
654 - URL Encode required for string being passed in mailto: links to pass on
655 additional values (cc, body, subject etc).
656 - Fixed bug #801060. Removed option for INBOX in filters plugin as source
657 is always INBOX.
658 - Always show Purge link next to Trash, even when empty.
659 - errors in addressbook_init() function are no longer fatal. If function
660 fails to activate address book backend, it displays error box (with
661 error_box() function). error box can be hidden by setting first
662 function argument to false.
663 - Sanitized search in ldap address book backend. Use of asterisk
664 together with other symbols is not supported.
665 - Added ldap backend to change_password plugin.
666 - Change defaults of some prefs to more sensible / usable settings.
667 - Revise the documentation of the packaged plugins.
668 - Fixed edit form checks in address listing (#1124018).
669 - After sending resumed draft, return to message list.
670 - Parse and replace mailto: links with internal compose links when
671 viewing in HTML format.
672 - Plugins may now define an "extra" array element to return to the attachment
673 types hook, which will be also inserted in the attachment link for the
674 plugin.
675 - Added mouseover row highlighting on message index.
676 - Added <label> for checkboxes on message index (when highlighting is off).
677 - Fixed mailto: parsing in functions/url_parser.php.
678 - Fixed broken signout page (plugins work here again).
679 - Fixed configtest to use correct PostgreSQL connection function
680 (#1166228).
681 - Added configuration option that blocks remote use of
682 src/configtest.php by default.
683 - Fixed ldap checks in configtest.php.
684 - Added configuration option that controls listing of global file based
685 address book.
686 - Fixed administrator's plugin breaks related to latest sqGetGlobalVar()
687 and $plugins array changes.
688 - Included local configuration file in config.php generated by
689 administrator's plugin.
690 - Updated the Filters plugin to comply with our Plugin Standards.
691 - Fixed Filters plugin problems with duplicate rule processing and false
692 unread message counts (Bug# 676073 and patch #919045).
693 - Strip position:absolute style from HTML mails.
694 - Add ability to the Filters plugin to filter on Message Body, or both
695 the Headers and the Message Body.
696 - Update the message copy and move functions to allow for error handling.
697 - Fix the filter plugin from halting the login process when copying errors
698 occur.
699 - Clean up the folder management (create, rename, subscribe) code.
700 - Added filtering support to address book LDAP backend (#539534). Thanks
701 to Tim Bell.
702 - Added domain scope limit controls to address book LDAP backend. Issue
703 is specific to Microsoft ADS (#1035454). Thanks to Michael Brown.
704 - Missing PHP LDAP extension errors are now handled by ldap backend and
705 errors are displayed after address book initialization.
706 - LDAP connections are opened during search and not during address book
707 initialization.
708 - Fixed wrapping of multibyte strings in message view and replies
709 (#1043576).
710 - mbstring internal encoding is switched to ASCII, if mbstring.func_overload
711 is enabled (#929644).
712 - Fixed checking for quota when appending to Sent folder (#1172694).
713 - Create a generic function to empty a folder tree, thanks to
714 Randy Smith (#1145578).
715 - Add robots noindex/nofollow meta tag to SquirrelMail generated pages.
716 - Fix incorrect folder hierarchy display (#1009654), thanks
717 Awais Ahmad for the patch (#1082558).
718 - src/delete_message.php script is disabled. It provided functions that
719 could be implemented without playing with multiple redirects.
720 - Remove lots of obsoleted code from left_main.php.
721 - Partial support of IMAP REFERRAL: do not fail on IMAP REFERRAL response
722 (RFC 2221) but log the user out with a hint. Patch by Ariel Arjona
723 (#1006242).
724 - Fixed SquirrelMail language cookie detection in php register_globals=off.
725 - If default SquirrelMail language is set to empty string, interface will
726 try to follow browser's HTTP_ACCEPT_LANGUAGE header or fallback to en_US
727 (#764709).
728 - If From: field is unset in an email, header object for from field is not
729 correctly set, and generates an error on reply (#1179754).
730 - Add Cancel button to addressbook (#1180565).
731 - RFC 2046: Send mixed messages with multipart/alternative nested boundaries
732 with correct boundary strings.
733 - EXPERIMENTAL: Mailbox listing converted to templated layout. Added
734 template support functions and classes. Rewrote some page header and
735 mailbox listing functions. Disabled 'show_recipient_instead' option.
736 Added more columns to mailbox listing and index order options.
737 - Removed sort by internal date option. Now you can use the Received column
738 in the index order option page for that.
739 - WARNING: if same user data storage location is used to store SquirrelMail
740 1.4.x and 1.5.1+ user settings, SquirrelMail 1.5.1+ will reset mailbox
741 display order (Options->Index Options) in stable. Backup your data before
742 testing 1.5.1+ or use different storage location.
743 - Added experimental iframe sandbox for display of html formated emails.
744 - Disabled LOGINDISABLED check in src/login.php when IMAP server mapping is
745 used.
746 - Check destination folder in mail_fetch plugin before storing messages
747 in it. Modify destination folder, if it is renamed or deleted within
748 SquirrelMail (#584658).
749 - Made the Flags column a required column in the index order options page to
750 prohibit missing seen/unseen info in the messages list.
751 - Fixed disabled prev/next links in the message display when you reach the
752 end of the page (message set).
753 - Moved delete button to the right in the message list.
754 - Fixed imap capability detection in bug_report plugin. It was broken
755 when IMAP TLS was enabled or imap server mapping was used.
756 - Added mail_fetch plugin configuration file and moved plugin functions
757 from setup.php to functions.php file.
758 - SquirrelSpell plugin was modified to use standard SquirrelMail
759 preference system. User dictionaries that are stored in $username.words
760 files should be automatically updated to new format, when user logs in.
761 Fixed possible php script errors caused by $SQSPELL_APP configuration
762 variable changes. Removed $SQSPELL_EREG configuration option. Plugin's
763 version increased to 0.5.
764 - $skip_SM_header option was replaced with $encode_header_key and
765 $hide_auth_header options. First option allows to encode user's information
766 with provided encryption key (set in 2. Server settings -> B. Update SMTP /
767 Sendmail settings). Second option allows to disable authenticated user part
768 in Received: header, when user can't forge used email address. It is set in
769 4. General Options -> 9. Allow editing of identity.
770 - Added dovecot preset to configuration utility.
771 - Modified mercury32 preset in order to remove INBOX prefix in mercury32 4.01.
772 - Added peardb backend to change_password plugin.
773 - Tweak IMAP connection error display (#1203154).
774 - Gracefully recover from over quota error while sending a mail (#1145144).
775 - Fix get_identities() for the case where the user has not set an email
776 address: use the fallback $username@$domain that's used in compose aswell.
777 - Fix "Include me in CC on Reply All" for the case where email address was
778 not set in the prefs (#781202, #1093363).
779 - Move documentation for SquirrelMail developers to doc/Development.
780 - Added id attribute support to form functions. It can be used for Section
781 508 or WAI fixes. Original idea and patch by dugan <at> passwall.com.
782 - Fixed broken attachments caused by inconsistency of PHP chunk_split().
783 Thanks to Roalt Zijlstra.
784 - Identity code was not checking for domain part in username before setting
785 email address (Bug #1219184).
786 - Disallow access to the administrator plugin screens when the plugin is
787 not enabled in the config.
788 - Security: fix several cross site scripting (XSS) attacks. Thanks go to
789 Martijn Brinkers for finding a lot of these. [CVE-2005-1769]
790 - Update COPYING with new address of the FSF.
791 - Fixed missing quote character when trying to build cid: urls.
792 - Added address listing functions and listing controls to address
793 book LDAP backend. Blocked wildcard searches in file and database
794 backends when listing is disabled (#529563).
795 - Some LDAP address book backend configuration options (listing
796 controls, filtering, scope limit) are moved to 'advanced
797 configuration' subsection.
798 - Javascript relied on rg=1 in the login page to force focus to
799 password box if username was supplied as a url arg (#1222617).
800 - Fix variable typo in parseFetch which caused IMAP errors on Exchange.
801 Thanks Christian Froemmel.
802 - Added Bluesome theme by Saku Lehtiö (#1188209).
803 - Rewrite of advanced identity handlying to remove stupid extraction
804 of all post variables. [CVE-2005-2095]
805 - Added StartTLS support to address book LDAP backend (#1197703). Patch
806 by John Lane.
807 - Added subtree/one level search options to address book LDAP backend
808 (#1212618).
809 - Added Simple Green 2 and Simple Purple themes by Vicky Pyne (#1217066
810 and #1217069).
811 - sqimap_messages_delete|copy|flag and sqimap_get_small_header()
812 functions are removed from SquirrelMail IMAP API. Use sqimap_msgs_*
813 and sqimap_get_small_header_list() functions instead.
814 - Fix for bad cache on massive expunge/delete/move operations.
815 - Moved time zone configuration from locale/timezones.cfg to php array.
816 Adds time zone name localization options and fixes problems on systems
817 that don't support GNU C time zone mappings (#1177067).
818 - Use default color theme in logout_error function when possible.
819 - Fixes for increased error checking in PHP 5.0.5+ array_shift() (#1237160).
820 - Added extra checks in delivery class for In-Reply-To header. Fixes
821 E_NOTICE level warnings in php 5.0.4 and later (#1206474). [php5]
822 - Added extra checks in SquirrelMail charset_encode() function in case
823 somebody removes HTML to US-ASCII conversion library (#1239782).
824 - Fixed invalid reference in src/download.php. E_NOTICE level warnings
825 could corrupt attachments in php 4.4.0.
826 - Added internal dgettext() and dngettext() functions.
827 - Added display of attachments on printer friendly page.
828 - Added custom error handling class and related functions.
829 - Added option to disable upload of sounds in newmail plugin.
830 - Removed full URL from sound file preferences in newmail plugin
831 (#1233530).
832 - Stripped BaseDN from nicknames in address book's ldap_server backend.
833 - Fixed error handling in SquirrelSpell plugin. sprintf and gettext
834 formating errors in check_me.mod. Reported by Edward Chapman.
835 - Translations are loaded automatically from locale/<localename>/setup.php
836 files (#1240889).
837 - Allow configure to be ran from any directory, thanks Ceri Davies.
838 - Removed $available_languages configuration option. List is limited to
839 installed translations. Similar feature is implemented in limit_languages
840 plugin.
841 - Don't load plugins/administrator/auth.php during plugin initiation.
842 - Removed function references from address book database backend class,
843 list_addr(), lookup() and search() functions. Referenced lookup()
844 function caused E_NOTICE warnings in php 4.4.0. Reported by Cor Bosman.
845 - Test to ensure folder exists before attempting to delete it, otherwise
846 IMAP server will return an error.
847 - Added $save_html argument to charset_decode() function in order to be
848 able to convert html formated mails to different character set. Initial
849 patch by Peter Draganov (#1195232). Fixed display of html formated emails
850 in formatBody() function (#1258925).
851 - login_form hook changed from do_hook to concat_hook_function in order to
852 place form elements before login button (#1245070).
853 - Forwarding broken when not using compose in new window (#1222436).
854 - Drop data/ dir from distributed tarball.
855 - Readded options_identity_process and options_identity_renumber hooks
856 broken by CVE-2005-2095 fixes.
857 - Removed duplicate generic_header hook call in src/right_main.php (#1269189).
858 - Removed other special folders from rename/delete/unsubscribe folder forms.
859 Suggested by Florian Daumling.
860 - Focus on compose screen no longer shifts automatically if user has manually
861 focused somewhere herself.
862 - Running SquirrelMail with PHP register_globals = on will cause fatal error
863 in src/configtest.php.
864 - Added field size controls to database preference backend (#1233721).
865 - Added bincimap preset (#1285099).
866 - Fixed IMAP search command in filters plugin. Command was breaking
867 sqimap_mailbox_exists() check. Reported by Daniel Watts.
868 - Fixed decoding of quoted-printable text in decodeBody function.
869 Reported by João Carlos Mendes Luís.
870 - Added CR trimming to SquirrelSpell plugin in order to fix problems on
871 Windows systems.
872 - Sanitized names displayed in address book listing.
873 - Added extra field controls to address book class.
874 - HttpOnly cookie support (cookies inaccessible by JS). This will protect
875 IE6 browsers.
876 - Rare case of session being destroyed causing PHP errors, so ensure session
877 is restarted.
878 - If you don't have any filters defined, and spam filters are disabled, no
879 point issuing a STATUS call on INBOX for the filters plugin.
880 - Added folder filtering controls to SMOPT_TYPE_FLDRLIST option widget.
881 - Security: Fixed possible XSS issue in search feature. Issue was
882 originally resolved in stable, but changes not migrated forward.
883 - Update the cached mailbox header with the \Answered flag in case of an
884 reply.
885 - Added site configuration options to bug_report plugin. Plugin is available
886 only to interface administrators by default. See more information in
887 plugins/bug_report/README file.
888 - E_NOTICE and unlink error message if user hits delete multiple times
889 before compose page has reloaded.
890 - Undefined variable in rare case in view_header.php
891 - Variable by reference fix in printer_friendly_bottom.php.
892 - Undefined index in addressbook backends.
893 - sqimap_utf7_decode_mbx_tree returns variables by reference, rather than a
894 return value (#1351822)
895 - Make test for IE6 in SendDownloadHeaders also match versions higher
896 than 6 (#1339211).
897 - Allow double quote to be used in MOTD (#1276959).
898 - Prevent right_frame to be set to '//www.example.com'.
899 - Tweak printer friendly attachment view.
900 - Added new compose_send_after hook.
901 - Added new scheme to allow multiple plugins to share the onsubmit handler
902 for the compose form from the compose_form hook. See plugin.txt for more
903 information.
904 - Support for LIST-SUBSCRIBED extension. This speeds up the retrieval of
905 the subscribed mailbox-list.
906 - Properly clean up temporary attachment files when saving as Draft
907 (#1358407) and fix attachment cleaning code on logout.
908 - Fixed error message in addressbook.php lookup (#1351825).
909 - Fixed incorrect curly escape in sqimap_append(). Error triggered by PHP 5.1
910 bugfix (#1366982).
911 - Fixed ContentType object check in Rfc822Header class. E_NOTICE error
912 in PHP 5.1.
913 - Key value being overwritten by reuse of var in filters plugin.
914 - Add doc/security.txt with some hints for a more secure installation.
915 - Added sqauth_read_password() and sqauth_save_password() functions.
916 - Unset global GET, POST and COOKIE variables registered in PHP
917 register_globals=on setups. (Also addresses: CVE-2006-2842, CVE-2006-3174)
918 - Capabilities array now contains all multivalue information provided
919 by the IMAP server. (Such as THREAD=SORT, THREAD=REFERENCES).
920 - Inclusion of Compatibility plugin automatic (no patch needed for plugin)
921 - Moved sqm_baseuri() into more centralized location (strings.php)
922 - Introduced $sendmail_args configuration variable in order to control
923 /usr/sbin/sendmail command arguments (#1365779). Deliver_SendMail class was
924 modified to provide support of $sendmail_args. Modifications broke backwards
925 compatibility with qmail-inject workarounds.
926 - Added execution error handling in Deliver_SendMail class (#1374174).
927 - Sanitized Draft folder error message in compose.
928 - Fixed character wrapping/encoding issues in Japanese translation (#1377622).
929 Issue is specific to sqBodyWrap() and string function wrappers introduced in
930 1.5.1.
931 - Security: MagicHTML fix for comments in styles which allowed
932 for cross site scripting when using Internet Explorer
933 [CVE-2006-0195].
934 - Added 'mail' and 'sn' attributes to address book LDAP backend search
935 expression (#1368154).
936 - Added mailbox caching code by Michael Long.
937 - Prevent output of whitespace during plugin activation. Fixes possible
938 attachment corruption by incorrectly coded plugins.
939 - Fixed data sanitizing in calendar plugin (#1291081)(#705796).
940 - Security: Prohibit imap injection attempts (reported by Vicente Aguilera)
941 [CVE-2006-0377].
942 - Don't move messages in sqimap_msgs_list_move() function call, when target
943 mailbox is same as source mailbox. Adds fifth argument to
944 sqimap_msgs_list_move() function. Fixes possible issues on MacOS Cyrus
945 IMAP server (#1409453).
946 - Style sheets are moved to template.
947 - displayHtmlHeader() function call sends http headers in order to prevent
948 page caching.
949 - Added Template set selection.
950 - Merged patch from Steve Brown to transform current templates to css
951 based templates.
952 - Added footer template to every page.
953 - Added experimental IMAP and SMTP STARTTLS extension support.
954 - Security: Fix possible cross site scripting through the right_main
955 parameter of webmail.php. This now uses a whitelist of acceptable
956 values. [CVE-2006-0188]
957 - Disabled display of regexp compilation errors in local_file address
958 book backend.
959 - DOCTYPE tags are switched from quirks to standard compliance mode.
960 - Improved error reporting concerning THREAD, SORT and BADCHARSET.
961 - Added options to disable THREAD and SORT extension.
962 - Fixed mailbox cache issues caused by using prev/next links in
963 read_body.php.
964 - Added View as HTML support to the SquirrelMail core.
965 - Fixed bug #550557.
966 - Applied status cache patch created by Michael Long.
967 - Updated newmail plugin to make use of status cache (Michael Long)
968 - Added RECENT check to left_main.php to bold the unseen message string if
969 there are recent messages.
970 - Fixed search query in filters.php, now we respect the imap continuation
971 request (Michael Long).
972 - Fixed bug in digest message view where the from name disappeared after
973 opening a digest message.
974 - Fixed checkall link in case javascript was disabled.
975 - Rewrite of thread parsing code in order to improve performance.
976 - Adapted message squisher function to gain performance.
977 - Fixed bug #1093360, skip untagged NO responses in APPEND query.
978
979 Version 1.5.0 - 2 February 2004
980 -------------------------------
981 - Added new preference that determines cursor focus when replying
982 - Added support in conf.pl for MS cls command.
983 - conf.pl changes for relative paths outside the SM tree (#715119).
984 - conf.pl changes for delete_folder restrictions with Courier-IMAP and
985 UW-IMAP (#715550).
986 - Fixed code to allow for \ in password/username (#718116).
987 - Added mailto: support for Windows clients. See
988 contrib/squirrelmail.mailto.reg
989 - Added lowsrc to the list of attributes to be removed.
990 - Fixed message highlighting for To, CC and From and
991 for RFC1522 headers (bug #719564)
992 - Fixed incorrect folding inside message-id's
993 - Fix for Folders being listed in create/remove/rename operations
994 (#725443, #722823, #729225)
995 - Fix for bad attachment view link (#697381, #729295)
996 - Fix comp_in_new in search and addressbook not having right parameters (#731768).
997 - Fix max attachment filesize off by factor 10 when ini_var set in bytes (#730742).
998 - Fix for parsing fetch results. We are now able to extract the UID if it's
999 returned after the header.
1000 - Remove obsoleted parsing functions.
1001 - Fixed language bug in posting on modifying/deleting servers on mail_fetch plugin
1002 (#742705).
1003 - Fixed infinite loop in parseAddress on invalid mailaddress (#742584).
1004 - Rewrote ugly "Not a very useful errormessage" to something more friendly.
1005 - Make central function for compose links to make sure compose_in_new always
1006 works the same way.
1007 - Fix that when JavaScript off, compose in new was broken (#749654).
1008 - Do not output JavaScript functions in page_header when JavaScript off.
1009 - Support MS Exchange "DOMAIN/username/mailbox"-style usernames (#745814).
1010 - Do not set Full Name to empty when edit_identity is false and edit_name is true (#750728).
1011 - Added koi8-u, windows-1255, windows-1256, iso-8859-6 charset decoding support.
1012 - Rewrite of sqimap_read_data_list which as result we better handle the
1013 returned imap responses and we display error messages when connections are
1014 dropped.
1015 - Rewrite of email address parser and solve the infinite loops issues due to
1016 bad formatted addresses.
1017 - Modified conf.pl: default to force usernames lowercase for servers which
1018 are case-insensitive.
1019 - Applied bugfixes from stable to htmlfilter code.
1020 - Fix bug #722933 where resuming a draft message would lose the reference headers.
1021 - Removed hard coded colors from login.php and made it use the default theme and css file
1022 - Fix that sending of read receipts failed when JavaScript on and comp in new off (#738130).
1023 - Replaced search with new version by Alex Lemaresquier. (Originally
1024 "asearch" plugin).
1025 - New debugging function: sm_print_r() in strings.php.
1026 - Use SM_PATH in config_default. Change default server type to 'other' instead
1027 of cyrus. (#766577).
1028 - Added feature to allow user to switch on full date display in mailboxes instead
1029 of just partial date/time based on time of email and current date.
1030 - Fixed bug that would cause e-mails dated in the future to be displayed with only
1031 the time.
1032 - Fixed unseen/total notifications to return behaviour back to 1.2.x style.
1033 - Added 4 hooks (internal_link, mailbox_display_buttons, move_messages_button_action, create_collapse_link)
1034 - Fix SquirrelSpell JS problem with other plugins that use forms (ie Menu Buttons).
1035 - Fix when forwarding messages as attachment from message list, the displayed subject
1036 was wrong (appearing to the user that the wrong messages were attached).
1037 Closes #772371.
1038 - Fix that when user has no theme preference set, Alien Glow would be selected under
1039 display preferences instead of Default.
1040 - Updated 'action' to be 'smaction' so that plugins can modify the submit/action of
1041 forms. This was suggested for the gpg plugin, but might be useful elsewhere.
1042 - Add support for Mail-Followup-To header.
1043 - Add a confirmation for the user that their mail has been sent.
1044 - Fixed issue with forwarding emails having a ) appended to the end.
1045 - Add "attachments_bottom" hook to allow manipulating/adding to the attachments
1046 - Fix to prevent username & password from being displayed in error messages
1047 if IMAP connection dropped during login
1048 - Modified preference loading code to always have a complete $color array
1049 set in case a user uses an incomplete theme.
1050 - new function sqimap_msgs_list_move() to replace sqimap_msgs_list_copy()
1051 - sqimap_msgs_list_copy() no longer deletes messages copied.
1052 - Workaround for Mozilla bug #200412 in order to show multipart/related html mail.
1053 - Fix for disappearing '0' from decoded strings (bug #784193).
1054 - Replace all session_start() calls with sqsession_is_active() to be compatible
1055 with upcoming PHP 4.3.3.
1056 - Encoding of Russian translation changed to utf-8. Lithuanian translation changed
1057 to utf-8. Fix allows to use national letters in folder names correctly.
1058 - Added "Bypass Trash" checkbox to folder index, used with the Delete
1059 button. (update: This needs work and will be changed, possibly removed)
1060 - Fixed a problem with delete_move_next and server thread-sorting.
1061 - New hook function: boolean_hook_function() Used for true/false hooks.
1062 - Calendar plugin: in month view, display events on the same day sorted by time,
1063 and include the time of the event in its tooltip.
1064 - Added default settings for Mercury/32 to conf.pl.
1065 - Fix to prevent mailboxes are deleted in selected stage which is against
1066 RFC3501.
1067 - Fix reply all address string in case the personal name contained a comma
1068 (address separator).
1069 - Added SASL PLAIN to IMAP and SMTP. Thanks to avel for the prodding and
1070 code snippet.
1071 - conf.pl will no longer offer to detect login methods if TLS is enabled.
1072 - conf.pl no longer offers UID support toggle, which is forced true in
1073 global.php
1074 - HTML Filter bugfixes and further strengthening in response to some
1075 findings reported by stardust.
1076 - Disabled Vietnamese and Ukrainian translations. They are done in different
1077 language.
1078 - Removed all translations. SquirrelMail translations are distributed as
1079 separate packages and kept in different cvs module.
1080 - New function: imap_general.php:create_imap_stream()
1081 - Updated src/login.php to detect, handle, and warn on LOGINDISABLED from IMAP server.
1082 - Fixed SquirrelMail to work under PHP5.
1083 - Reintroduce alternating row colors in addressbook, something that has
1084 accidentally disappeared in the past.
1085 - Disabled Quick-email-reporting feature in spamcop plugin. Bug.809452. Admin
1086 can enable it by setting variable in plugins/spamcop/setup.php
1087 - Fix again for Internet Explorer's stupidity of decoding characters, then
1088 executing it blindly. See http://www.securityfocus.com/archive/1/340118.
1089 - Replaced obsolete 2mbit.com RBL with ahbl.org RBL. Bug.No.829887
1090 - Added a sitewide override for authenticated SMTP - see authentication.txt.
1091 - Fixed sorting of sent_subfolders.
1092 Sent_subfolder plugin is hooked to special_mailbox hook.
1093 - Integration of delete_move_next plugin into core.
1094 - Compression of buttons/headers for message index and message body
1095 - New option to save replies in the same folder as the original message.
1096 - Remove possible unneeded IMAP call for NAMESPACE if it was saved in the
1097 session (suggestion by Michael Long).
1098
1099
1100 **************************************
1101 *** SquirrelMail Stable Series 1.4 ***
1102 **************************************
1103
1104 Version 1.4.0 -- 3 April 2003
1105 -----------------------------
1106 - Fixed mail_fetch plugin. Now folder edition defaults to actual value.
1107 All settings from other servers are preserved when deleting one.
1108 - Added Vietnamese translation.
1109 - Fixed the newmail plugin.
1110 - Added RECENT response to sqimap_get_status.
1111 - Fixed attachment filename resolving.
1112 - Added check for X-Confirm-Reading-To to make MDN work for messages sent by Pine.
1113 - sqextractGlobalVar removed (use sqgetGlobalVar instead).
1114 - Subfolders of Sent and Drafts show To field instead of From
1115 - Updates in conf.pl to infamous delete_folder setting, including
1116 addition of appropriate default value for courier and UW.
1117 - Fix for date/time display in certain timezones.
1118 - Fix some features of login.php that are used by some plugins and was broken
1119 by register_globals = off.
1120 - Added Greek locale. Thanks to George P. Kremmydas
1121 <george at kefalonia-ithaki.gr> and Alexandros Vellis <avel at noc.uoa.gr>
1122 - Added notes about PHP 4.3.x to documentation.
1123 - Fixed \Noselect mailbox detection.
1124 - Fixed charset decode of base64 encoded strings.
1125 - Fixed encoding of email addresses in our composed messages.
1126 - Fixed folder creation for Courier using Autoconfig options.
1127 - Fixed encoded string handling inside MDN notifications.
1128 - Fixed unfold header routine in imap_messages (for mailbox_display).
1129 - Fixed subject_line hook.
1130 - Fixed sqgetGlobalVar switching.
1131 - Fixed handling of encoding/decoding strings.
1132 - Fixed wrong array_slice call for a subset of the headers.
1133 - Allow encoded personal names in compose.php.
1134 - Improved address parsing of addresses coming from the compose form.
1135 - Fixed uninitialized indices when parsing attachments.
1136 - Support text/directory MIME-type for vCards (RFC 2425).
1137 - Added Arabic locale. Thanks to Asrar Abbasi <asrar at canasoft.net> and
1138 Naveed Saqib <naveed.saqib at biznas.com>.
1139 - Update required PHP version in documentation to 4.0.6.
1140 - Fixed delete_move_next plugin to remember where it moved mail to.
1141 - Fixed compose to remember attachments.
1142 - Security: Fixed possible XSS in compose when replying to malicious sources.
1143 - Add display of the maximum filesize for attachment uploads.
1144 - Do not add < and > if an identity doesn't contain a full name.
1145 - Fixed bug in parsing Content-Type properties part.
1146 - Added move_before_move hook to allow plugins to act upon the different buttons
1147 - Fixed bug in Forwarding of Emails (move_messages.php)
1148 - Fixed variable spelling error in filters.php
1149 - Fixed some operator bugs in compose.php, move_messages.php, and spamcop.php
1150
1151 Version 1.4.0 RC 2a
1152 -------------------
1153 - Fix broken themes box in display options.
1154 - Massive overhaul of administrator plugin.
1155 - Added new function sqgetGlobalVar to global.php to provide direct access
1156 to variables in $_GET, $_POST, $_SESSION, $_COOKIE and $_SERVER.
1157 - Patch from O'Shaughnessy Evans <shaug-sqm@wumpus.org> to allow disabled $org_logo
1158 - Lots of language/internationalization updates
1159 - conf.pl fixes for certain uses of SM_PATH, esp. $signout_page.
1160 - SMTP & IMAP auth method "plain" was a misnomer - now corrected to
1161 the more accurate name "login" (Plain to be implemented soon).
1162 - Fix for compose after search bug. (Closes #662346)
1163 - Improved error reporting when sending mail with SMTP.
1164 - Changed SquirrelMail identification to use User-Agent instead of X-Mailer.
1165 - Prevent endless loop when timezone config is not found. Thanks Joshua Colson.
1166 - Fix IMAP error when returning to message from viewing image attachment.
1167 - Do more trimming to indented subjects in threadview so they don't wrap.
1168 - Trash folder now displays purge link in all cases. (Closes #655943)
1169 - Fix typo in delete_move_next plugin which caused PHP file-handle errors.
1170 - Make vCard more liberal in what it accepts (thanks Kurt Pires).
1171 - Fix problem with subject encoding when using Japanse.
1172 - Move login_form hook to be actually in the login form.
1173 - Fix message_details plugin ability to save a raw message.
1174 - Try better to get the filename of an attachment.
1175 - Deliver_SMTP class now uses HTTP_HOST in SMTP HELO. Should fix DNS
1176 issues some people have reported. (Closes #560524)
1177 - Obsolete sqm_topdir(), which caused login trouble with installs that
1178 have open_basedir restrictions. Thanks Jimmy Connor.
1179 - Fix broken abook_take plugin.
1180 - Fix HTML errors that caused display problems in NS4.
1181 - Correctly fold encoded header lines.
1182 - Fix prefs caching not working correctly in PHP 4.3 caused by a stupid
1183 version checking mechanism.
1184 - Security: Fix XSS hole that allowed JavaScript execution by sending someone
1185 an email with specially crafted headers. Thanks Jason Munro, and
1186 Masato Higashiyama.
1187
1188
1189 Version 1.4.0 RC 1
1190 ------------------
1191 - Change the way highlighting rules are stored to make them more reliable and
1192 easier to manage.
1193 - Reorganization of conf.pl, menu #2
1194 - Added CRAM-MD5 and DIGEST-MD5 authentication support for IMAP and SMTP
1195 - Experimental TLS support for IMAP and SMTP (requires PHP 4.3.x)
1196 - Override settings with config_local.php
1197 - Compose form no longer shows attachment options if PHP file_uploads
1198 disabled
1199 - Improved bodystructure parsing.
1200 - Support for windows-1257 charset.
1201 - Optimizations to the number of IMAP calls.
1202 - Fix problem with IE6 + iso-8859-13.
1203 - Allow Mail Fetch to use a different POP3 server port number.
1204 - Force magic_quotes_runtime to be off to avoid problems with this setting.
1205 - Introduce check_sm_version function for plugins wanting to know
1206 which version of SquirrelMail this is.
1207 - Configurable session name to avoid conflicts with other PHP applications.
1208 - Miscellaneous fixes for systems with error_reporting set to E_ALL.
1209 - Many many other bugfixes and tweaks!
1210
1211
1212 *************************************
1213 *** SquirrelMail Devel Series 1.3 ***
1214 *************************************
1215
1216
1217 Version 1.3.2
1218 -------------
1219 - Rewrite of message delivery related functions.
1220 - User interface modifications.
1221 - Added Japanese support thanks to Masato HIGASHIYAMA <masato@yamaai-tech.com>
1222 - Remove NOOP checks in the POP3 client of mail_fetch to make things more
1223 compatible and not break things which don't need to be broken.
1224 - Fix src directory being moved on Windows systems, bugs #586518 #605256 #610676.
1225 - This release is compatible with installations that have register_globals set to off.
1226 - Do not lose user prefs/sigs/abooks when trying to save to a full disk.
1227 - Make the SquirrelMail link on the right top configurable so a provider can point
1228 to their own FAQ for example.
1229 - Enable TZ in safe_mode if safe_mode_allowed_env_vars permits this bug #612148.
1230 - Fix some bugs in folder management (create, delete,...) and add enhancements.
1231
1232 Version 1.3.1
1233 -------------
1234 - lots of fixes by Marc, including #596781 and #596930
1235
1236 Version 1.3.0
1237 -------------
1238 - allow_call_time_by_reference=off fixes.
1239 - Added forward as attachment in read_body.
1240 - Better clean-up of left attachments at login.
1241 - Restore compose sessions in case of a expired session.
1242 - Added "Display Message" / "Up" links in read_body to navigate in messages with
1243 attached messages (message/rfc822).
1244 - Don't activate the Send Receipt link when the folder is the Sent folder.
1245 - Moved view_header code out of read_body.php and put it in view_header.php.
1246 - Open message/rfc822 attachments in read_body what makes it possible to
1247 reply to attached messages.
1248 - Rewrite of the newMail function in compose.php. This simplifies the
1249 interface between read_body.php and compose.php.
1250 - Moved compose related code from read_body to compose.
1251 - Rewrite of mailbox-display to make it more modular (we use it in search.php).
1252 - Added support for displaying multiple entities.
1253 - Changed finding display entities.
1254 - Extract disposition and xmailer header information in the headerparser
1255 instead of request them individualy by an imap-call.
1256 - Store message objects in the current session. This saves a lot of imap-calls.
1257 - Added UID support.
1258 - Store addresses in an object instead of a string.
1259 - Rewrite of the bodystructureparser function. Now the message object contains
1260 all described parameters in RFC2060.
1261 - Introduction of the mime class where all mime related functions are situated
1262 - Fixed removing MDN attachments.
1263 - Fixed MDN problems with js confirmbox.
1264 - Speedimprovements in case we download mime-entities.
1265 - Added possibility to extract message/rfc822 attachments and store them as
1266 the original message in a folder.
1267 - Right to left languages implementation initiated
1268 - Enable people with file_uploads = off to still send mail. Patch from Seth
1269 E. Randall.
1270 - Moved the generic_header hook back to page_header.php. bug #554278
1271 - Make default theme work. Bug #557313, thanks Tyler Bannister.
1272
1273 Version 1.2.7 -- June 21 2002
1274 -----------------------------
1275 - fix for 'compose as new' link. bug #554886
1276 - fix charset format in the admin plugin. bug #550725
1277 - fix for errant '.' in default_folder_prefix. bug #551310
1278 - fix for folder names with '?' and '*'. bug # 559257, #552180
1279 - added the ability to search without the charset argument. #552288
1280 - Made /noselect node display optional. bug #554988, patch #452178
1281 - Improved support for macosx IMAP server thanks Brian Haun
1282 - Added macosx friendly search, thanks Brian Haun bug #553038
1283 - Fixed word wrap problems when sending mail. bug #552961, #556143
1284 - Added possibility to use multiple compose windows without loss
1285 of attachements.
1286 - Fixed forward message/rfc822 attachments from a search
1287 - Fix SpamCop plugin.
1288 - Fixed send MDN link.
1289 - Fixed dealing with \r\n and \n in smtp.php.
1290 - Fixed to, cc, bcc arrays in message->header
1291 - Speed optimizements in generating message-lists.
1292 - Fixed loss of attachment with html addressbook.
1293 - Fixed saving drafts with attachments
1294
1295 Version 1.2.6 -- April 29 2002
1296 ------------------------------
1297 - Security: A complete MagicHTML rewrite since the existing codebase was
1298 causing too many XSS problems. Hopefully now Nick Cleaton will
1299 leave us alone. :) Testing credits go to Nick.
1300 - Security: Fix for cross-site scripting vulnerability (bug #545933)
1301 Reported by Nick Cleaton.
1302 - Changing "emtpy" to "purge" for more clarity.
1303 - Security: Fix for cross-site scripting vulnerability (bug #544658)
1304 Reported by Nick Cleaton.
1305 - Fix for incorrect word wrap in Opera (bug #495073)
1306 - Workaround for older prefs: some of them contain "None" for
1307 left_refresh (bug #540108)
1308 - Fix for entities in cc and bcc fields on message display (bug #522493)
1309 - Fixes for quoted values in the addressbook by David Rees (bug #538389)
1310 - Fixed src/src problem (bug #538803)
1311 - Fixed so non-ascii searches no longer fail both when searching
1312 and when applying filters (bug #520918)
1313 - Added POP3 Before SMTP option (feature request: #498428)
1314 - Added a server-side thread sorting option per folder
1315 - Added a server-side sorting global option
1316 - Compose in new window size can be set in Display prefs.
1317 - Logout error system unified.
1318 - Security: Fix for a "theme passed as cookie" exploit. [CVE-2002-0516]
1319 - PostgreSQL is now supported for database backed use
1320 - Added user option to sort messages by internal date
1321 - Changed attachment handling now attachments are adressed to
1322 unique compose session.
1323 - Added forward messages as message/rfc822 attachment
1324 - Fixed handling message/rfc822 attachments
1325 - Fixed folder list display when special folders have subfolders
1326 - Added option to auto-append sig before reply/forward text (523853)
1327 - Fixed subfolders being "orphaned" when renaming parents (498167)
1328 - Filters can be applied to only new mail.
1329 - Filters are updated when renaming/deleting folders (512056)
1330 - Filtering now happens on login (filters plugin)
1331 - Added option for WIDTH and HEIGHT tags to Org. Logo. (patch #412754)
1332 - Fixed resume draft bug #513521, #514639
1333 - Newmail plugin: admin can disable the use of audio (patch #517698)
1334 - Fixed quoting problem in safe html (patch #516542)
1335 - SPAM folder no longer special folder (filters plugin)
1336 - Filtering now happens on folder list refresh (filters plugin)
1337 - Added checking of input of the folders page
1338 - Made erronous deleting of folders harder (patch #514208)
1339 - Made SquirrelMail display \Noselect nodes in Cyrus also made it
1340 impossible to try to delete \Noselect nodes. (patch #452178)
1341 - SquirrelSpell version 0.3.8 -- pretty configuration error reporting
1342 added by popular demand.
1343 - Improved the handling of IMAP [PARSE] messages to reduce retrieval error.
1344 - Fixed small bug in handeling timezone (bug #536149).
1345 - MDN message now RFC compatible (bug #537662).
1346 - Fixed html tables in printer_friendly_bottom.php (patch #542367), and
1347 make it so that printer friendly uses black-on-white colors in stead
1348 of the theme colors.
1349 - Fixed return address of MDN receipts when having multiple identities
1350 (patch #530139).
1351
1352 Version 1.2.5 -- 22 February 2002
1353 ---------------------------------
1354 - Multiple mailbox list calls cached.
1355 - Added 'View unsafe images' link to the bottom of pages which contain
1356 unsafe images.
1357 - Fixed 'too many close table tags' and various other issues
1358 which meant SM output didn't always validate as clean HTML.
1359 - Added the ability to add special folders through plugins.
1360 - Added an Always compose in a pop-up window option.
1361 - Search page update with ability to save searches and search
1362 all folders at once.
1363 - Made searching on multiple criteria possible, with thanks to Jason Munro
1364 - Fixed 'list all' in addressbook (#506624, thanks to Kurt Yoder)
1365 - Fixed small bugs in db_prefs
1366 - Allowed SquirrelMail to work from within a frame, eg. not using _top
1367 this is configureable. (thanks to Simon Dick)
1368 - Added options to conf.pl to enable automated plugin installation:
1369 ./conf.pl --install-plugin <pluginname>. This allows plugins to be
1370 distributed in packages. Conf.pl now also reports when saving fails.
1371 - Attachment hooks now also allow specification of generic rules like
1372 text/* which will be used when no specific rule is available.
1373 - conf.pl can now configure database backed address books and
1374 preferences.
1375 - Version 0.3.7 of SquirrelSpell. Fixes a potential privacy
1376 vulnerability (symlink attack), plus introduces formatting fixes
1377 and javadoc-style comments.
1378 - Bugfix in mailfetch reported by Mateusz Mazur
1379 - Administrator plugin. A web based conf.pl replacement.
1380 - Removed GLOBALS from conf.pl
1381 - HTML messages optimization.
1382 - Added support for requesting read receipts (MDN) and delivery receipts.
1383 - Added the ability to stop users changing their names and email addresses.
1384 - Added signature into multiple identities (Stefan Meier <Stefan.Meier@cimsource.com>)
1385 - Updated user help files to reflect UI chanegs and added functionality.
1386
1387 Version 1.2.4 -- 25 January 2002
1388 --------------------------------
1389 - Security: Fixes a nasty remote arbitrary command execution vulnerability
1390 in the spellchecker plugin.
1391
1392 Version 1.2.3 -- 21 January 2002
1393 --------------------------------
1394 - Fixed focus system on pages that contain forms.
1395 - Fixed IMAP code to send different command identifiers as per
1396 section 2.2.1 of RFC 2060.
1397 - Fixed 'sticky priority' so that replies are set to the same
1398 priority as the original message.
1399 - Fixed Printer Friendly to print HTML messages.
1400 - Fixed multiple receivers in Sent mailbox (#500910).
1401 - Disabled prefs caching under PHP 4.1
1402 - Added "Search Memory". Enabling to store up to
1403 9 predefined searchs.
1404 - Increased security in html message.
1405 - Added the possibility to specify system-defined css in order to
1406 allow users to change the font family and size of SM. Making possible to
1407 make it bigger or smaller depending on their screen size. Sysops may add
1408 or remove these system-defined css located in themes/css/
1409 - Fixed a bug appearing on some apache virtual hosts
1410 - Fixed javascript error (#505255)
1411 - Fixed the db_prefs so they work again (#499609, thanks to Simon Dick)
1412
1413 Version 1.2.2 -- 1 January 2002
1414 -------------------------------
1415
1416 - Fixed an infinite loop in printer friendly when wrapping option
1417 is not in the prefs.
1418 Bug reported by Boris Manojlovic <steki@verat.net>
1419 - Html cleanup, with patch from Dave Huang (#496712)
1420 - Fixed a problem saving prefs when using PHP 4.1
1421 - Russian, Thai, Swedish, Dutch and French update.
1422 - Changed configure invocation from bash to sh. (Bug #496752)
1423 - Changed conf.pl invocation from '#!/usr/bin/perl' to
1424 '#!/usr/bin/env perl' to help people who have perl somewhere
1425 else. (Bug #496753)
1426 - Fixed sorting of folder list, bug #497181
1427 - Fixed wrong behavior of non-javascript select all, bug #496681
1428 - Added "Show Pages" link to message list showing all messages
1429 (the resultant page of clicking "Show All")
1430 - i18n Fix. Because of different configurations in the gettext system,
1431 some installations could not manage correctly SM languages other than
1432 English. This has been corrected.
1433 - Miscellaneous rewrites and improvements.
1434 - Moved locale files into the ISO-conformant directories.
1435 - Moved help files into the ISO-conformant directories.
1436 - Moved compilepo and mergepo files from locale/ into po/
1437 - Slight i18n fixes and rewrites to accommodate for moved files.
1438 - Fixes for entities in the subject when replying.
1439 - Fixes for entities in the To: header. (Bug #489365)
1440 - Fix for incorrect javascript prefs handling (Bug #497688)
1441 - Added color 15 for themes to separate background and foreground colors.
1442 - Added several new themes.
1443
1444 Version 1.2.1 -- 25 December 2001
1445 ---------------------------------
1446
1447 - Fixed the bug that kept the create, delete, and rename sections
1448 from appearing in the folders page (#496604)
1449 - Fixed the motd bug not allowing ' (#496616)
1450 - Sorting of addressbook_search fixed, thanks to the patch of
1451 Cor Bosman (xs4all)
1452
1453 Version 1.2.0 -- 25 December 2001
1454 ---------------------------------
1455
1456 - Collapsible Folders
1457 - The Paginator!!!
1458 - Hundreds of UI Tweaks
1459 - Message Drafts
1460 - Rewrite of much of the options pages
1461 - Multiple identities
1462 - Reply Citations
1463 - Better Attachment Handling
1464 - Integration of Several Plugins into Core Code (including xmailer,
1465 attachment_common, paginator, priority, printer_friendly, sqclock)
1466 - Ability to mark messages as Read/Unread
1467 - New themes (including a Christmas theme, and several changing themes)
1468 - Rewrite of much of the options pages code
1469 - Improved support for newer versions of PHP
1470 - Message lists can be shown with alternating colors for easier reading
1471 - Can include/exclude yourself when using the "Reply All"
1472 - Message highlighting comes with dozens more easily accessable colors.
1473 - Option to set the "Priority" of the message(Normal/High/Low)
1474 - Now able to show all messages of an inbox at the same time.
1475 - Cleanup of the paginator code, improving display style
1476 - Cleanup of configuration file code, a bit
1477 - Introduction of sent_subfolders plugin as Official Plugin
1478 - Bugfixes..and more Bugfixes!
1479
1480
1481 ***************************************************************
1482 *** SquirrelMail Development Series 1.1 and 1.1 Pre-Releases ***
1483 ****************************************************************
1484
1485 Version 1.2.0-rc3 -- 2 December 2001
1486 ------------------------------------
1487 - Speed improvements and optimizations on much of the code
1488 - Comments added, formatting cleaned up for much of the code
1489 - Several plugins integrated into the SquirrelMail core
1490 (focus change, attachment common, printer friendly, etc)
1491 - Several plugins added as "Official Plugins" to the main
1492 SquirrelMail distribution
1493 - First half of a rewrite of the option pages code
1494 - The Paginator!!!
1495 - Other stuff that I don't recall (developers, please fill this in!)
1496
1497 Version 1.1.3 -- (never really released)
1498 ----------------------------------------
1499 - Added major speed improvements to IMAP functions by our
1500 friends at XS4ALL
1501 - Fixed MOTD
1502 - Fixed multipart/alternative messages
1503 - Updated Dutch translation
1504 - Added Indonesian translation
1505 - Added Portuguese (Portugal) translation
1506 - Added language aliasing
1507 - Added Turkish translation
1508
1509 Version 1.1.2 -- May 21, 2001
1510 -----------------------------
1511 - Many bugs squashed
1512 - Several UI tweaks and improvements
1513 - Added option (3 -> 14 in conf.pl) to auto create sent and trash folders.
1514 - Updated Czech translation
1515 - Support for multiple identities
1516 - Support for Russian Apache removed. It is now deemed easier to just
1517 turn off Charset Recoding in the Russian Apache config. See the file
1518 doc/README.russian_apache
1519
1520 Version 1.1.1 -- April 30, 2001
1521 -------------------------------
1522 - Added built-in support for gettext if compiled support isn't available
1523 - Made validate.php include a few more standard things
1524 - Corrected a bug when sending an email properly
1525
1526 Version 1.1.0 -- April 21, 2000
1527 -------------------------------
1528 - Added option to have signout page redirect to another page (patch from
1529 Scott Bronson) This can be configured in conf.pl (Org Prefs)
1530 - Much improved SMTP error handling (patch from Jeff Evans)
1531 - Preferences are now cached instead of read in every page load.
1532 - Improved URL parser
1533 - Added ability to read HTML messages by default instead of plain text
1534 (Display Options)
1535 - Added authenticated SMTP server support (configure in conf.pl)
1536 - Rewrote attachment handling code in compose.php
1537 - If aliases are typed in To, Cc, or Bcc, they are automatically looked up
1538 in the addressbook and converted to the associated addresses.
1539 - Added collapseable folder listing (an option that can be turned on in
1540 Folder Options)
1541 - Added alternating row colors to improve interface (Display Options)
1542
1543
1544 **************************************
1545 *** SquirrelMail Stable Series 1.0 ***
1546 **************************************
1547
1548 Version 1.0.6 -- April 19, 2001
1549 -------------------------------
1550 - Reworked validation for each page. It's now standardized in validate.php
1551 - Fixed login bug that resulted from 1.0.5 security updates
1552 - Fixed plugin incompatibilities that were introduced in 1.0.5
1553 - Added more security checking to preference saving/loading
1554 - Updated German translation (thanks to Ronald Bauerschmidt <rb@debian.org>)
1555 - Updated Finnish help files
1556
1557 Version 1.0.5 -- April 17, 2001
1558 -------------------------------
1559 - MAJOR security issues addressed. Please upgrade as soon as possible.
1560 [CVE-2001-1159]
1561 - Downloading attachments should work better due to a tip by Ray Black III.
1562 - Fixed bug with drop-down folder list not containing INBOX
1563 - Added Swedish help files Teemu Junnila <teejun@vallcom.com>
1564 - Added Italian help files Antonetti Roberto <antonr@piceniaweb.com>
1565
1566 Version 1.0.4 -- April 9, 2001
1567 ------------------------------
1568 - Fixed some bugs with folder creation
1569 - Security fix for UW IMAP server to disallow folder paths outside of
1570 $folder_prefix
1571 - Some problems with header encoding/decoding fixed
1572 - Made subject column take up whatever width is available
1573 - Added bcc to html addressbook search
1574
1575 Version 1.0.3 -- March 9, 2001
1576 ------------------------------
1577 - Many i18n enhancements/fixes
1578 - Fixed bug with default theme path being set incorrectly
1579 - Fixed problem when sending/forwarding multiple attachments
1580 - Made folder drop-down list consistant in look to the other drop-downs
1581 - Fixed problem where some attachment filenames would not be displayed
1582 - Added Finnish help files by Teemu Junnila <teejun@vallcom.com>
1583 - Updated Norwegian translation
1584 - Updated Brazillian Portuguise translation
1585
1586 Version 1.0.2 -- February 8, 2001
1587 ---------------------------------
1588 - Added a workaround for RedHat's 4.0.4pl1-3 binary package (It's also
1589 the same workaround for Konqueror and other PHP installations?)
1590 - Select All works through the search
1591 - Better escaped string handling from POST variables
1592 - Many more code cleanups and optimizations
1593 - Added Hungarian translation by Teemu Junnila <teejun@vallcom.com>
1594 - Added Icelandic translation by Karl Hei�r <karlh@macho.is>
1595 - Updated Taiwan translation
1596 - Updated Swedish translation
1597 - Updated Finnish translation
1598
1599 Version 1.0.1 -- February 1, 2001
1600 ---------------------------------
1601 - Improved the way sqimap_read_data() is handled
1602 - Sped up "no sorting" even more
1603 - Fixed problems with sending messages
1604 - Fixed some pass-by-reference calls that caused problems with newer
1605 PHP versions
1606 - Fixed bug that didn't display last folder subscribed to
1607 - Removed requirement of PHP 4.0.1 for array_unique() function
1608 - Removed unnecessary echo statements by breaking out of PHP
1609 - Changed evaluation method from using " to ' for speed improvements
1610 - If no plugin array set in config.php, now handled correctly
1611 - If subject is > 55 chars, trims it and puts "..." in message list
1612 - Hundreds of minor changes to remove all verbose PHP warning messages
1613
1614 Version 1.0 -- January 30, 2001
1615 -------------------------------
1616 - Updated config_default.php to include attachment_common plugin
1617 (now in distribution)
1618 - A few minor speed improvements
1619 - Fixed problems in sqimap_read_body(), made it more reliable
1620 - Added French translation of help files by gore K <gore_k@ymca-cepiere.org>
1621 - Added Finnish translation by Teemu Junnila <teejun@vallcom.com>
1622 - Updated Swedish translation
1623 - Updated Russian translation
1624
1625
1626 ********************************************************
1627 *** SquirrelMail Development Series 1.0 Pre-Releases ***
1628 ********************************************************
1629
1630 Version 1.0pre3 -- January 22, 2001
1631 -----------------------------------
1632 - Fixed some "Select All" bugs
1633 - Finally fixed the IE/SSL download problem!!
1634 - Added Danish translation by Claus Rasmussen <claus@webclaus.com>
1635 - Updated Spanish translation
1636 - Updated Polish translation
1637 - Updated Taiwan translation
1638 - Updated Czech translation
1639 - Updated Korean translation
1640
1641 Version 1.0pre2 -- January 15, 2001
1642 -----------------------------------
1643 - A number of security fixes
1644 - Replaced error messages with better, formatted, and meaningful messages.
1645 - Fixed "reply all" so that it works intelligently now
1646 - Made deleted (but not expunged) messages easier to detect (only if
1647 $auto_expunge = false)
1648 - Fixed bug that didn't display size correctly in search results
1649 - Major memory management and speed improvements with downloading of
1650 attachments
1651 - Made $auto_expunge variable actually do something
1652 - Fixed bug that didn't display login failure message
1653 - Fixed minor bug in sqimap_mailbox_list
1654 - Added sqimap_capability function to check capabilities of server.
1655 - Rewrote sqimap_get_delim to use NAMESPACE capability (if available) to
1656 get delimiter.
1657 - Added Catalan translation of Help documents by Josep Sanz <jsanz@fa.upc.es>
1658 - Added Taiwan translation by "ching" <ching@kiwa.com.tw>
1659
1660 Version 1.0pre1 -- December 14, 2000
1661 ------------------------------------
1662 - Fixed bug in sending messages with a blank line with a "."
1663 - Folder displays have been changed to be more readable in drop-down lists
1664 - For security, login verification happens, then we're redirected to
1665 webmail.php
1666 - Folder sorting now case insensative
1667 - added config option to set IMAP folder delimiter rather than always
1668 detecting it
1669 - Made session cookie parameter use PHP's settings rather than making
1670 assumptions
1671 - Select/Deselect all implemented using only HTML (not Javascript)
1672 - Fixed default charset that is sent with outbound messages (now user's
1673 preferred charset)
1674 - Sort method saving now transparent to user, and saves between sessions
1675 - Now replacing all \n with \r\n before sending the message.
1676 - Added sorting option for NO sorting.. 10000 times faster!
1677 - Using <pre> tags for viewing message body instead of <tt> and &nbsp;
1678 - Added redirection from subdirectories to login page
1679 - Attachments are shown in message index (shown as a "+")
1680 - Updated attachment plugin support and passing values to hooks (see
1681 plugins.txt)
1682 - Added file and message size in many locations
1683 - Made message index order customizable (from, subject, date) can be (date,
1684 from, subject)
1685 - Fixed some security problems with uploading attachments
1686 - When reading, attachments look better and have a better plugin interface
1687 - Some functions now pass values by reference to save on memory
1688 - Added Catalan translation from Josep Sanz <jsanz@fa.upc.es>
1689 - Added Serbian translation from Boris Manojlovic <steki@verat.net>
1690 - Added Polish translation of Help from Krystian Kanabrodzki
1691 <krys@voruta.eu.org>
1692
1693
1694 *****************************************
1695 *** SquirrelMail 0.5 and Pre-Releases ***
1696 *****************************************
1697
1698 Version 0.5 -- September 25, 2000
1699 ---------------------------------
1700 - Fixed some problems with downloading attachments in IE
1701 - If no date is set in header, we take internal date of the imap server
1702 - Fixed some lingering bugs in mime parsing
1703 - Searching specifies CHARSET option
1704 - Security fixes
1705 - Fixed hyperlink rendering problems
1706
1707 Version 0.5pre2 -- September 6, 2000
1708 ------------------------------------
1709 - Added quite a few new themes
1710 - Fixed double folder problem on some servers
1711 - Using encryption for passwords
1712 - Added a patch from Bill Thousand to allow easier virtual domains
1713 - Security updates with attachments
1714 - Added more hooks for plugins, updated plugin.txt
1715 - Improved HTML address book
1716 - Fixed bugs in parsing email addresses in smtp.php
1717 - Applied fixes for Courier IMAP server (by Andreas Dahl)
1718 - Fixed some buggy IMAP handling
1719 - Improved word wrapping
1720 - Fixed bugs with adding and not adding backslashes
1721 - Made message highlighting case insensative
1722 - Added Korean translation from Jong-II Kim <aporie@netian.com>
1723 - Added Italian translation from Aldo Moresco <moresco@idcm.it>
1724 - Added French translation from Ali Nedjimi <lrdfrx@club-internet.fr>
1725
1726 Version 0.5pre1 -- August 9, 2000
1727 ---------------------------------
1728 - Searching folders functionality added
1729 - Date display now is similar to Netscape Messenger
1730 - Many bugs have been reported to the list, and been squashed
1731 - Help system developed
1732 - Folder list now shows configurable details about messages
1733 - It is now possible to select multiple subscribes/unsubscribes
1734 - Removed a bunch of annoying "success" screens, improved navigation
1735 - Better IMAP session handling
1736 - Redid the options section and split it into different parts
1737 - Added "view all headers" option when reading a message
1738 - In-Reply-To and References headers are inserted when replying to a message.
1739 - Changed how attachments are displayed and handled
1740 - Rewrote MIME support from scratch, optomizing it an unbelievable amount
1741 - Added support for message highlighting
1742 - Moved Address and Send buttons on Compose form for easier access
1743 - Added Polish translation from Lukasz Klimek <casa@LO.Pila.PL>
1744 - Added Swedish translation from Tobias Ekbom
1745 - Added Brazilian Portuguse translation from Henrique Moura
1746 - Added Dutch translation from Arjen Halma
1747
1748
1749 *****************************************
1750 *** SquirrelMail 0.4 and Pre-Releases ***
1751 *****************************************
1752
1753 Version 0.4 -- May 15, 2000
1754 ---------------------------
1755 - If subject is blank, displays "(no subject)"
1756 - Fixed a few minor bugs and typos reported to list
1757 - Changed <? to <?php in a few places
1758
1759 Version 0.4pre2 -- May 5, 2000
1760 ------------------------------
1761 - Replying sets the "Answered" flag on the original message
1762 - When message is sent, it sends you to the folder you were looking at.
1763 - HTML based address book search
1764 - Made folder listing look first at subscribed folders, making it
1765 faster, even if you don't have $folder_prefix set.
1766 - Fixed some bugs with default sent and trash folders
1767 - Fixed some bugs with folder manipulating
1768
1769 Version 0.4pre1 -- April 29, 2000
1770 ---------------------------------
1771 - For speed's sake, unseen messages are only noted on INBOX in left
1772 folder list. This will change with 0.5.
1773 - Optomizations, fewer IMAP calls, more efficient sorting algorithms.
1774 - Fixed all bugs listed in BUG
1775 - When inside the Sent folder, it displays "To" instead of "From"
1776 - Added ability to go to Next and Previous message while reading a message
1777 - Caching of the message headers in mailbox (much faster)
1778 - Added a preference that allows users to customize how many messages
1779 they see when they index a mailbox
1780 - Added flag status showing on message list (Answered, Flagged, and Seen)
1781 - Now using PHP session management
1782 - Parsing the body for URLs and Email addrs
1783 - Added option to configure default folder directory. ie: ~/mail
1784 - Configuration script added: config/conf.pl
1785 - Addressbook with LDAP support
1786 - Big speed improvements with folder listing
1787 - Added Subscribe/Unsubscribe to folders
1788 - Fixed bug in UW that didn't mark unseen messages
1789 - Saving sent messages into $sent_folder
1790 - It doesn't bail out if PHP wasn't compiled with --with-gettext.
1791 It only uses english in this case.
1792 - Added support for Cyrillic (thanks to Artem Botchkov for help)
1793 - Included information on Russian Apache from Konstantin Riabitsev
1794 - Honoring charset parameter for the body.
1795 - Changed the way emptying of trash was done to work better
1796 across different IMAP servers
1797
1798
1799 *****************************************
1800 *** SquirrelMail 0.3 and Pre-Releases ***
1801 *****************************************
1802
1803 Version 0.3.1 -- March 13, 2000
1804 -------------------------------
1805 - Fixed a bug that didn't allow downloading of attachments
1806
1807 Version 0.3 (final) -- March 10, 2000
1808 -------------------------------------
1809 - Fixed bug in smtp.php and made sending RFC complient
1810 - Fixed a bug that wouldn't let you rename folders with UW server.
1811 - Other minor bugfixes
1812
1813 Version 0.3pre2 -- March 5, 2000
1814 --------------------------------
1815 - Rewrote folder deletion. It works much more flexably now.
1816 - Fixed message deletion that didn't always delete the right messages.
1817 - Removed font tags
1818 - Better character translation, especially for i18n
1819 - Added the choice of language as a user preference
1820 - Bug fixes, bug fixes, bug fixes
1821 - Fixed bugs in message moving and deleting
1822 - Rewrote all IMAP functions from scratch
1823
1824 Version 0.3pre1 -- February 17, 2000
1825 ------------------------------------
1826 - Added user-specific preferences including:
1827 Full Name (for outbound messages)
1828 Reply-to address
1829 Theme
1830 Move messages to trash option (true/false)
1831 Wrap incoming text at XX characters
1832 Editor window size (in characters)
1833 Time between reloads of the left folder list
1834 Signature
1835 - Rewrote SMTP functions. It now works and handles error correction.
1836 - Only folders that you're subscribed to will be listed
1837 - Fixed a bug in outbound messages that translated " into \"
1838 - Added themes in distribution (7 total)
1839 - Added option to send email via sendmail rather than SMTP
1840 - Increased speed of viewing folder by date about 25%, and viewing the
1841 folder by Subject or Sender by up to 100%.
1842 - Added internationalization
1843 - Added sending of attachments
1844 - Left folder refreshing at intervals (with META tags)
1845
1846
1847 *****************************************
1848 *** SquirrelMail 0.2 and Pre-Releases ***
1849 *****************************************
1850
1851 Version 0.2.1 -- January 05, 2000
1852 ---------------------------------
1853 - Rewrote how MULTIPART messages were handled and made it recursive
1854 - We now take into account the encoding type rather than guessing
1855 - Redesigned how attachments are displayed
1856 - Fixed the bug that wouldn't let you send messages (I hope)
1857 - Added a "download message" option
1858 - Added a plain text viewer for text messages
1859
1860 Version 0.2 -- January 02, 2000
1861 -------------------------------
1862 - Attachment support (much better MIME support in general)
1863 - Themeable support replaced Custom Colors. Themes are pluggable.
1864
1865
1866 *****************************************
1867 *** SquirrelMail 0.1 and Pre-Releases ***
1868 *****************************************
1869
1870 Version 0.1.2 -- December 20, 1999
1871 -----------------------------------
1872 - Date translation to local time
1873 - Rewrote folder fetching code universally
1874 - Added attachment detection (no downloads yet)
1875 - Fixed many minor bugs that were reported
1876
1877 Version 0.1.1 -- December 16, 1999
1878 -----------------------------------
1879 - Reworked all the IMAP functions to make them RFC 2060 compliant
1880 (should work with all IMAP servers)
1881 - Added color customization
1882 - Sorted folder list (on left bar)
1883 - Added MUCH better error correction and notification
1884
1885 Version 0.1 -- December 14, 1999
1886 --------------------------------
1887 - Message composing (with to, cc, bcc)
1888 - Message viewing, including HTML messages
1889 - Basic MIME support, no attachments...yet
1890 - Message sorting by Date, Name, or subject
1891 - Folder manipulation (deleting, creating, moving, and renaming)
1892 - IMAP email (currently only Cyrus IMAP server has been tested)
1893 - Many other features that are basic email functionality