blob: c2606f3f38ee5d6742176675eaa05afbb48f76de [file] [log] [blame]
Derek Jones8ede1a22011-10-05 13:34:52 -05001##########
2Change Log
3##########
4
Derek Jonesf4a4bd82011-10-20 12:18:42 -05005Version 3.0 (planned)
Derek Jones8ede1a22011-10-05 13:34:52 -05006=======================
7
8Release Date: Not Released
9
Derek Jonesf4a4bd82011-10-20 12:18:42 -050010- License
11
Andrey Andreev79922c02012-05-23 12:27:17 +030012 - CodeIgniter has been relicensed with the Open Software License (3.0), eliminating its old proprietary licensing.
Derek Jonesf4a4bd82011-10-20 12:18:42 -050013
14 - All system files are licensed with OSL 3.0.
15 - Config, error, and sample files shipped in the application folder are
16 licensed with the Academic Free License (3.0) to allow you to retain
17 all licensing authority over your own application code.
18
Derek Jones8ede1a22011-10-05 13:34:52 -050019- General Changes
Timothy Warrendeb65962011-10-17 12:26:02 -040020
Phil Sturgeon07c1ac82012-03-09 17:03:37 +000021 - PHP 5.1.6 is no longer supported. CodeIgniter now requires PHP 5.2.4.
Phil Sturgeondda21f62012-06-03 10:36:36 -050022 - ``$_SERVER['CI_ENV']`` can now be set to control the ``ENVIRONMENT`` constant.
Timothy Warren52aff712011-10-17 12:26:56 -040023 - Added an optional backtrace to php-error template.
Derek Jones8ede1a22011-10-05 13:34:52 -050024 - Added Android to the list of user agents.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010025 - Added Windows 7, Windows 8, Android, Blackberry, iOS and PlayStation 3 to the list of user platforms.
Andrey Andreevd4901392012-06-06 14:54:15 +030026 - Added Fennec (Firefox for mobile) to the list of mobile user agents.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +000027 - Ability to log certain error types, not all under a threshold.
28 - Added support for pem, p10, p12, p7a, p7c, p7m, p7r, p7s, crt, crl, der, kdb, rsa, cer, sst, csr Certs to mimes.php.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010029 - Added support for pgp, gpg, zsh and cdr files to mimes.php.
Andrey Andreev7c9766a2012-01-03 10:18:41 +020030 - Added support for 3gp, 3g2, mp4, wmv, f4v, vlc Video files to mimes.php.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010031 - Added support for m4a, aac, m4u, xspf, au, ac3, flac, ogg, wma Audio files to mimes.php.
Andrey Andreev7c9766a2012-01-03 10:18:41 +020032 - Added support for kmz and kml (Google Earth) files to mimes.php.
Andrey Andreevd1a075d2012-06-15 23:28:52 +030033 - Added support for ics Calendar files to mimes.php.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010034 - Added support for rar, jar and 7zip archives to mimes.php.
Andrey Andreevb2457b72012-06-07 23:36:56 +030035 - Updated support for xml ('application/xml') and xsl ('application/xml', 'text/xsl') files in mimes.php.
Michiel Vugteveenadcb8fd2012-02-29 14:20:33 +010036 - Updated support for doc files in mimes.php.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010037 - Updated support for docx files in mimes.php.
Andrey Andreevd1a075d2012-06-15 23:28:52 +030038 - Updated support for php files in mimes.php.
39 - Updated support for zip files in mimes.php.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010040 - Updated support for csv files in mimes.php.
Andrey Andreev079fbfc2012-06-12 02:26:58 +030041 - Added some more doctypes.
Andrey Andreevce1b02a2012-11-01 14:40:52 +020042 - Added Romanian, Greek, Vietnamese and Cyrilic characters in *application/config/foreign_characters.php*.
Eric Barnesf30da662011-12-04 10:35:58 -050043 - Changed logger to only chmod when file is first created.
Greg Akerd1af1852011-12-25 21:59:30 -060044 - Removed previously deprecated SHA1 Library.
Andrey Andreevce1b02a2012-11-01 14:40:52 +020045 - Removed previously deprecated use of ``$autoload['core']`` in *application/config/autoload.php*.
Andrey Andreev75f7c122012-01-08 03:49:25 +020046 Only entries in ``$autoload['libraries']`` are auto-loaded now.
Andrey Andreev079fbfc2012-06-12 02:26:58 +030047 - Removed previously deprecated EXT constant.
Andrey Andreevc6a68e02012-03-26 14:30:10 +030048 - Updated all classes to be written in PHP 5 style, with visibility declarations and no ``var`` usage for properties.
Andrey Andreev0aeee852012-11-09 17:43:11 +020049 - Moved error templates to *application/views/errors/*.
50 - Moved the Log class to *application/core/*
Andrey Andreev079fbfc2012-06-12 02:26:58 +030051 - Global config files are loaded first, then environment ones. Environment config keys overwrite base ones, allowing to only set the keys we want changed per environment.
52 - Changed detection of ``$view_folder`` so that if it's not found in the current path, it will now also be searched for under the application folder.
53 - Path constants BASEPATH, APPPATH and VIEWPATH are now (internally) defined as absolute paths.
Andrey Andreevcbb654d2012-07-10 11:36:32 +030054 - Updated email validation methods to use ``filter_var()`` instead of PCRE.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010055 - Changed environment defaults to report all errors in *development* and only fatal ones in *testing*, *production* but only display them in *development*.
56 - Updated *ip_address* database field lengths from 16 to 45 for supporting IPv6 address on :doc:`Trackback Library <libraries/trackback>` and :doc:`Captcha Helper <helpers/captcha_helper>`.
57 - Removed *cheatsheets* and *quick_reference* PDFs from the documentation.
Andrey Andreeve9d2dc82012-11-07 14:23:29 +020058 - Added availability checks where usage of dangerous functions like ``eval()`` and ``exec()`` is required.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +000059
60- Helpers
61
Andrey Andreevac570332012-07-04 13:04:10 +030062 - :doc:`Date Helper <helpers/date_helper>` changes include:
63 - ``now()`` now works with all timezone strings supported by PHP.
64 - Added an optional third parameter to ``timespan()`` that constrains the number of time units displayed.
65 - Added an optional parameter to ``timezone_menu()`` that allows more attributes to be added to the generated select tag.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010066 - Deprecated ``standard_date()``, which now just uses the native ``date()`` with `DateTime constants <http://www.php.net/manual/en/class.datetime.php#datetime.constants.types>`_.
67 - Added function ``date_range()`` that generates a list of dates between a specified period.
Andrey Andreev0f0b7692012-06-07 14:57:04 +030068 - ``create_captcha()`` accepts additional colors parameter, allowing for color customization.
Andrey Andreev81c32082012-06-16 21:21:46 +030069 - :doc:`URL Helper <helpers/url_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020070 - Deprecated *separator* options **dash** and **underscore** for function :php:func:`url_title()` (they are only aliases for '-' and '_' respectively).
71 - :php:func:`url_title()` will now trim extra dashes from beginning and end.
72 - :php:func:`anchor_popup()` will now fill the *href* attribute with the URL and its JS code will return FALSE instead.
73 - Added JS window name support to the :php:func:`anchor_popup()` function.
74 - Added support (auto-detection) for HTTP/1.1 response code 303 in :php:func:`redirect()`.
75 - Changed :php:func:`redirect()` to only choose the **refresh** method only on IIS servers, instead of all servers on Windows (when **auto** is used).
Phil Sturgeonf748ebc2011-11-13 19:24:16 +000076 - Added XHTML Basic 1.1 doctype to :doc:`HTML Helper <helpers/html_helper>`.
Andrey Andreevf7c39d62012-11-08 22:01:33 +020077 - :doc:`Inflector Helper <helpers/inflector_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020078 - Changed :php:func:`humanize()` to allow passing an input separator as its second parameter.
79 - Refactored :php:func:`plural()` and :php:func:`singular()` to avoid double pluralization and support more words.
Andrey Andreev53fff912012-11-22 16:57:23 +020080 - :doc:`Download Helper <helpers/download_helper>` changes include:
81 - Added an optional third parameter to :php:func:`force_download()` that enables/disables sending the actual file MIME type in the Content-Type header (disabled by default).
82 - Added a work-around in :php:func:`force_download()` for a bug Android <= 2.1, where the filename extension needs to be in uppercase.
83 - Added support for reading from an existing file path by passing NULL as the second parameter to :php:func:`force_download()` (useful for large files and/or safely transmitting binary data).
Andrey Andreev74ffd172012-10-27 00:41:03 +030084 - :doc:`Form Helper <helpers/form_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020085 - :php:func:`form_dropdown()` will now also take an array for unity with other form helpers.
86 - :php:func:`form_prep()`'s second argument now only accepts a boolean value, which determines whether the value is escaped for a <textarea> or a regular <input> element.
Andrey Andreevf7c39d62012-11-08 22:01:33 +020087 - :doc:`Security Helper <helpers/security_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020088 - :php:func:`do_hash()` now uses PHP's native ``hash()`` function (supporting more algorithms) and is deprecated.
89 - :php:func:`strip_image_tags()` is now an alias for the same method in the :doc:`Security Library <libraries/security>`.
Jonatas Miguel982a9f22012-10-24 18:34:40 +010090 - Removed previously deprecated helper function ``js_insert_smiley()`` from :doc:`Smiley Helper <helpers/smiley_helper>`.
Andrey Andreev0f0b7692012-06-07 14:57:04 +030091 - :doc:`File Helper <helpers/file_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020092 - :php:func:`set_realpath()` can now also handle file paths as opposed to just directories.
93 - Added an optional paramater to :php:func:`delete_files()` to enable it to skip deleting files such as *.htaccess* and *index.html*.
94 - Deprecated function ``read_file()`` - it's just an alias for PHP's native ``file_get_contents()``.
Andrey Andreevf7c39d62012-11-08 22:01:33 +020095 - :doc:`String Helper <helpers/string_helper>` changes include:
Andrey Andreev08f0f8b2012-11-09 10:27:43 +020096 - Deprecated function ``repeater()`` - it's just an alias for PHP's native ``str_repeat()``.
97 - Deprecated function ``trim_slashes()`` - it's just an alias for PHP's native ``trim()`` (with a slash as its second argument).
98 - Deprecated randomization type options **unique** and **encrypt** for funcion :php:func:`random_string()` (they are only aliases for **md5** and **sha1** respectively).
Andrey Andreev3b407062012-11-26 23:55:37 +020099 - :doc:`Directory Helper <helpers/directory_helper>` :php:func:`directory_map()` will now append ``DIRECTORY_SEPARATOR`` to directory names in the returned array.
100 - :doc:`Language Helper <helpers/language_helper>` :php:func:`lang()` now accepts an optional list of additional HTML attributes.
Andrey Andreev0898e232012-11-08 15:13:52 +0200101 - Deprecated the :doc:`Email Helper <helpers/email_helper>` as its ``valid_email()``, ``send_email()`` functions are now only aliases for PHP native functions ``filter_var()`` and ``mail()`` respectively.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000102
103- Database
104
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200105 - Added **dsn** configuration setting for drivers that support DSN strings (PDO, PostgreSQL, Oracle, ODBC, CUBRID).
106 - Added **schema** configuration setting (defaults to *public*) for drivers that might need it (currently used by PostgreSQL and ODBC).
107 - Added subdrivers support (currently only used by PDO).
108 - Added an optional database name parameter to ``db_select()``.
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200109 - Removed ``protect_identifiers()`` and renamed internal method ``_protect_identifiers()`` to it instead - it was just an alias.
110 - Renamed internal method ``_escape_identifiers()`` to ``escape_identifiers()``.
111 - Updated ``escape_identifiers()`` to accept an array of fields as well as strings.
112 - MySQL and MySQLi drivers now require at least MySQL version 5.1.
113 - ``db_set_charset()`` now only requires one parameter (collation was only needed due to legacy support for MySQL versions prior to 5.1).
114 - Replaced the ``_error_message()`` and ``_error_number()`` methods with ``error()``, which returns an array containing the last database error code and message.
115 - Improved ``version()`` implementation so that drivers that have a native function to get the version number don't have to be defined in the core ``DB_driver`` class.
Andrey Andreev69edc432012-12-04 13:32:16 +0200116 - Added capability for packages to hold *config/database.php* config files.
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200117 - Added MySQL client compression support.
118 - Added encrypted connections support (for *mysql*, *sqlsrv* and PDO with *sqlsrv*).
119 - Removed :doc:`Loader Class <libraries/loader>` from Database error tracing to better find the likely culprit.
120 - Added support for SQLite3 database driver.
121 - Added Interbase/Firebird database support via the *ibase* driver.
122 - Added ODBC support for ``create_database()``, ``drop_database()`` and ``drop_table()`` in :doc:`Database Forge <database/forge>`.
Andrey Andreev42870232012-06-12 01:30:20 +0300123 - :doc:`Query Builder <database/query_builder>` changes include:
124 - Renamed the Active Record class to Query Builder to remove confusion with the Active Record design pattern.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100125 - Added the ability to insert objects with ``insert_batch()``.
126 - Added new methods that return the SQL string of queries without executing them: ``get_compiled_select()``, ``get_compiled_insert()``, ``get_compiled_update()``, ``get_compiled_delete()``.
Andrey Andreevbdd9c112012-11-06 12:07:16 +0200127 - Added an optional parameter that allows to disable escaping (useful for custom fields) for methods ``join()``, ``order_by()``, ``where_in()``, ``or_where_in()``, ``where_not_in()``, ``or_where_not_in()``, ``insert()``, ``insert_batch()``.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100128 - Added support for ``join()`` with multiple conditions.
129 - Added support for *USING* in ``join()``.
Andrey Andreev98e46cf2012-11-13 03:01:42 +0200130 - Added seed values support for random ordering with ``order_by(seed, 'RANDOM')``.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100131 - Changed ``limit()`` to ignore NULL values instead of always casting to integer.
132 - Changed ``offset()`` to ignore empty values instead of always casting to integer.
133 - Methods ``insert_batch()`` and ``update_batch()`` now return an integer representing the number of rows affected by them.
Andrey Andreev69edc432012-12-04 13:32:16 +0200134 - :doc:`Database Results <database/results>` changes include:
135 - Added a constructor to the ``DB_result`` class and moved all driver-specific properties and logic out of the base ``DB_driver`` class to allow better abstraction.
136 - Added method ``unbuffered_row()`` for fetching a row without prefetching the whole result (consume less memory).
137 - Renamed former method ``_data_seek()`` to ``data_seek()`` and made it public.
Andrey Andreev13707202012-03-20 00:13:06 +0200138 - Improved support for the MySQLi driver, including:
Andrey Andreev42870232012-06-12 01:30:20 +0300139 - OOP style of the PHP extension is now used, instead of the procedural aliases.
140 - Server version checking is now done via ``mysqli::$server_info`` instead of running an SQL query.
141 - Added persistent connections support for PHP >= 5.3.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100142 - Added support for ``backup()`` in :doc:`Database Utilities <database/utilities>`.
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200143 - Improved support of the PDO driver, including:
144 - Added support for ``create_database()``, ``drop_database()`` and ``drop_table()`` in :doc:`Database Forge <database/forge>`.
145 - Added support for ``list_fields()`` in :doc:`Database Results <database/results>`.
146 - Subdrivers are now isolated from each other instead of being in one large class.
Andrey Andreev5fa72982012-03-03 04:13:20 +0200147 - Improved support of the PostgreSQL driver, including:
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100148 - ``pg_version()`` is now used to get the database version number, when possible.
149 - Added ``db_set_charset()`` support.
150 - Added support for ``optimize_table()`` in :doc:`Database Utilities <database/utilities>` (rebuilds table indexes).
151 - Added boolean data type support in ``escape()``.
152 - Added ``update_batch()`` support.
153 - Removed ``limit()`` and ``order_by()`` support for *UPDATE* and *DELETE* queries as PostgreSQL does not support those features.
154 - Added a work-around for dead persistent connections to be re-created after a database restart.
Andrey Andreev0259d122012-12-03 14:55:56 +0200155 - Changed ``db_connect()`` to include the (new) **schema** value into Postgre's **search_path** session variable.
Andrey Andreev082ee2b2012-06-08 15:26:34 +0300156 - Improved support of the CUBRID driver, including:
157 - Added DSN string support.
158 - Added persistent connections support.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100159 - Improved ``list_databases()`` in :doc:`Database Utility <database/utilities>` (until now only the currently used database was returned).
Andrey Andreev082ee2b2012-06-08 15:26:34 +0300160 - Improved support of the MSSQL and SQLSRV drivers, including:
161 - Added random ordering support.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100162 - Added support for ``optimize_table()`` in :doc:`Database Utility <database/utilities>`.
163 - Added escaping with *QUOTE_IDENTIFIER* setting detection.
Andrey Andreev082ee2b2012-06-08 15:26:34 +0300164 - Added port handling support for UNIX-based systems (MSSQL driver).
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100165 - Added *OFFSET* support for SQL Server 2005 and above.
Andrey Andreev4173fa02012-11-19 11:14:23 +0200166 - Added ``db_set_charset()`` support (MSSQL driver).
Andrey Andreev24abcb92012-01-05 20:40:15 +0200167 - Improved support of the Oracle (OCI8) driver, including:
Andrey Andreev42870232012-06-12 01:30:20 +0300168 - Added DSN string support (Easy Connect and TNS).
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100169 - Added support for ``drop_table()`` in :doc:`Database Forge <database/forge>`.
170 - Added support for ``list_databases()`` in :doc:`Database Utilities <database/utilities>`.
Andrey Andreev42870232012-06-12 01:30:20 +0300171 - Generally improved for speed and cleaned up all of its components.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100172 - ``num_rows()`` is now only called explicitly by the developer and no longer re-executes statements.
Andrey Andreev782de112012-06-12 03:04:50 +0300173 - Improved support of the SQLite driver, including:
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100174 - Added support for ``replace()`` in :doc:`Query Builder <database/query_builder>`.
175 - Added support for ``drop_table()`` in :doc:`Database Forge <database/forge>`.
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200176 - :doc:`Database Forge <database/forge>` changes include:
177 - Added an optional second parameter to ``drop_table()`` that allows adding the **IF EXISTS** condition, which is no longer the default.
178 - Added support for passing a custom database object to the loader.
Andrey Andreevb67277b2012-11-12 12:51:14 +0200179 - Deprecated ``add_column()``'s third method. *AFTER* clause should now be added to the field definition array instead.
180 - Added support for usage of the *FIRST* clause in ``add_column()`` for MySQL and CUBRID.
Andrey Andreeveaa60c72012-11-06 01:11:22 +0200181 - Overall improved support for all of the drivers.
182 - :doc:`Database Utility <database/utilities>` chages include:
183 - Added support for passing a custom database object to the loader.
184 - Modified the class to no longer extend :doc:`Database Forge <database/forge>`, which has been a deprecated behavior for awhile.
185 - Overall improved support for all of the drivers.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000186
187- Libraries
Derek Jonesbe3177f2012-07-04 07:02:55 -0700188
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100189 - :doc:`Session Library <libraries/sessions>` changes include:
190 - Library changed to :doc:`Driver <general/drivers>` with classic Cookie driver as default.
191 - Added Native PHP Session driver to work with ``$_SESSION``.
192 - Custom drivers can be added anywhere in package paths and be loaded with the library.
193 - Drivers interchangeable on the fly.
194 - New **tempdata** feature allows setting user data items with an expiration time.
195 - Added default ``$config['sess_driver']`` and ``$config['sess_valid_drivers']`` items to *config.php* file.
196 - Cookie driver now respects php.ini's *session.gc_probability* and *session.gc_divisor* settings.
197 - Cookie driver now uses HMAC authentication instead of the simple md5 checksum.
198 - The Cookie driver now also checks authentication on encrypted session data.
199 - Changed the Cookie driver to select only one row when using database sessions.
200 - Cookie driver now only writes to database at end of request when using database.
201 - Cookie driver now uses PHP functions for faster array manipulation when using database.
202 - Added ``all_flashdata()`` method to session class. Returns an associative array of only flashdata.
203 - Added ``has_userdata()`` method to verify existence of userdata item.
204 - Added ``tempdata()``, ``set_tempdata()``, and ``unset_tempdata()`` methods for manipulating tempdata.
Johnathan Croom38929952012-11-25 14:08:24 -0700205 - ``keep_flashdata()`` now accepts an array of keys.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100206 - :doc:`File Uploading Library <libraries/file_uploading>` changes include:
Andrey Andreev05aa2d62012-12-03 16:06:55 +0200207 - Added **max_filename_increment** config setting.
208 - Added an **index** parameter to the ``data()`` method.
209 - Added the **min_width** and **min_height** options for images.
Andrey Andreev79922c02012-05-23 12:27:17 +0300210 - :doc:`Cart library <libraries/cart>` changes include:
Andrey Andreev0f5f73a2012-10-25 17:35:04 +0300211 - ``insert()`` now auto-increments quantity for an item when inserted twice instead of resetting it, this is the default behaviour of large e-commerce sites.
Andrey Andreevcdeee662012-10-25 17:29:52 +0300212 - *Product Name* strictness can be disabled by switching the ``$product_name_safe`` property to FALSE.
213 - Added method ``remove()`` to remove a cart item, updating with quantity of 0 seemed like a hack but has remained to retain compatibility.
214 - Added method ``get_item()`` to enable retrieving data for a single cart item.
Andrey Andreev901573c2012-01-11 01:40:48 +0200215 - :doc:`Image Manipulation library <libraries/image_lib>` changes include:
Andrey Andreevcdac2482012-11-03 18:09:01 +0200216 - The ``initialize()`` method now only sets existing class properties.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100217 - Added support for 3-length hex color values for *wm_font_color* and *wm_shadow_color* properties, as well as validation for them.
218 - Class properties *wm_font_color*, *wm_shadow_color* and *wm_use_drop_shadow* are now protected, to avoid breaking the ``text_watermark()`` method if they are set manually after initialization.
219 - If property *maintain_ratio* is set to TRUE, ``image_reproportion()`` now doesn't need both width and height to be specified.
220 - Property *maintain_ratio* is now taken into account when resizing images using ImageMagick library.
221 - Added support for maintaining transparency for PNG images in method ``text_watermark()``.
Andrey Andreev901573c2012-01-11 01:40:48 +0200222 - :doc:`Form Validation library <libraries/form_validation>` changes include:
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100223 - Added method ``error_array()`` to return all error messages as an array.
224 - Added method ``set_data()`` to set an alternative data array to be validated instead of the default ``$_POST``.
225 - Added method ``reset_validation()`` which resets internal validation variables in case of multiple validation routines.
226 - Added support for setting error delimiters in the config file via ``$config['error_prefix']`` and ``$config['error_suffix']``.
227 - ``_execute()`` now considers input data to be invalid if a specified rule is not found.
Andrey Andreevdaaca882012-11-26 22:16:12 +0200228 - Removed method ``is_numeric()`` as it exists as a native PHP function and ``_execute()`` will find and use that (the **is_numeric** rule itself is deprecated since 1.6.1).
Andrey Andreevcde43682012-01-13 20:16:35 +0200229 - Native PHP functions used as rules can now accept an additional parameter, other than the data itself.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100230 - Updated ``set_rules()`` to accept an array of rules as well as a string.
Andrey Andreev3d9cec92012-07-08 21:50:19 +0300231 - Fields that have empty rules set no longer run through validation (and therefore are not considered erroneous).
Andrey Andreevdaaca882012-11-26 22:16:12 +0200232 - Added rule **differs* to check if the value of a field differs from the value of another field.
233 - Added rule **valid_url**.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100234 - Added support for setting :doc:`Table <libraries/table>` class defaults in a config file.
Andrey Andreev58c2b102012-10-26 14:42:29 +0300235 - :doc:`Caching Library <libraries/caching>` changes include:
236 - Added Wincache driver.
237 - Added Redis driver.
238 - Added a *key_prefix* option for cache IDs.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100239 - :doc:`Email library <libraries/email>` changes include:
240 - Added custom filename to ``Email::attach()`` as ``$this->email->attach($filename, $disposition, $newname)``.
241 - Added possibility to send attachment as buffer string in ``Email::attach()`` as ``$this->email->attach($buffer, $disposition, $newname, $mime)``.
242 - Added dsn (delivery status notification) option.
243 - Renamed method _set_header() to set_header() and made it public to enable adding custom headers in the :doc:`Email Library <libraries/email>`.
244 - Successfully sent emails will automatically clear the parameters.
245 - Added a *return_path* parameter to the ``from()`` method.
246 - Removed the second parameter (character limit) from internal method ``_prep_quoted_printable()`` as it is never used.
247 - Internal method ``_prep_quoted_printable()`` will now utilize the native ``quoted_printable_encode()``, ``imap_8bit()`` functions (if available) when CRLF is set to "\r\n".
248 - Default charset now relies on the global ``$config['charset']`` setting.
249 - Removed unused protected method ``_get_ip()`` (:doc:`Input Library <libraries/input>`'s ``ip_address()`` should be used anyway).
250 - Internal method ``_prep_q_encoding()`` now utilizes PHP's *mbstring* and *iconv* extensions (when available) and no longer has a second (``$from``) argument.
Andrey Andreev61797f62012-11-26 16:15:12 +0200251 - Added an optional parameter to ``print_debugger()`` to allow specifying which parts of the message should be printed ('headers', 'subject', 'body').
Andrey Andreev88c47272012-06-17 02:32:31 +0300252 - :doc:`Pagination Library <libraries/pagination>` changes include:
253 - Added support for the anchor "rel" attribute.
254 - Added support for setting custom attributes.
255 - Deprecated usage of the "anchor_class" setting (use the new "attributes" setting instead).
Phil Sturgeonf82b9292012-06-23 15:49:23 +0100256 - Added $config['reuse_query_string'] to allow automatic repopulation of query string arguments, combined with normal URI segments.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100257 - Removed the default ``&nbsp;`` from a number of the configuration variables.
Derek Jonesbe3177f2012-07-04 07:02:55 -0700258 - Added the ability to use a proxy with the :doc:`XML-RPC Library <libraries/xmlrpc>`.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100259 - :doc:`Encryption Library <libraries/encryption>` changes include:
260 - Added support for hashing algorithms other than SHA1 and MD5.
261 - Removed previously deprecated ``sha1()`` method.
Andrey Andreev55a8c622012-11-06 13:31:21 +0200262 - :doc:`Profiler Library <general/profiling>` now also displays database object names.
Jonathon Hill34c8b9c2012-10-31 14:02:35 -0400263 - :doc:`Migration Library <libraries/migration>` changes include:
Andrey Andreev39eb8062012-11-13 03:36:40 +0200264 - Added support for timestamp-based migrations (enabled by default).
265 - Added ``$config['migration_type']`` to allow switching between *sequential* and *timestamp* migrations.
Andrey Andreev324762b2012-11-13 04:42:38 +0200266 - :doc:`User Agent Library <libraries/user_agent>` will now check if robots are pretending to be mobile clients (helps with e.g. Google indexing mobile website versions).
RS710fc64092012-01-03 12:50:55 -0200267
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000268- Core
269
Andrey Andreevd4516e32012-10-31 14:44:38 +0200270 - :doc:`URI Library <libraries/uri>` changes include:
271 - Changed private methods to protected so that MY_URI can override them.
Andrey Andreevf2b19fe2012-10-31 16:16:24 +0200272 - Renamed internal method ``_parse_cli_args()`` to ``_parse_argv()``.
273 - Renamed internal method ``_detect_uri()`` to ``_parse_request_uri()``.
274 - Changed ``_parse_request_uri()`` to accept absolute URIs for compatibility with HTTP/1.1 as per `RFC2616 <http://www.ietf.org/rfc/rfc2616.txt>`.
275 - Added protected method ``_parse_query_string()`` to URI paths in the the **QUERY_STRING** value, like ``_parse_request_uri()`` does.
Andrey Andreev3b72eb52012-11-01 00:45:26 +0200276 - Changed ``_fetch_uri_string()`` to try the **PATH_INFO** variable first when auto-detecting.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100277 - Removed ``CI_CORE`` boolean constant from *CodeIgniter.php* (no longer Reactor and Core versions).
278 - :doc:`Loader Library <libraries/loader>` changes include:
279 - Added method ``get_vars()`` to the Loader to retrieve all variables loaded with ``$this->load->vars()``.
Andrey Andreeved4b2582012-10-27 17:46:52 +0300280 - ``_ci_autoloader()`` is now a protected method.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100281 - Added autoloading of drivers with ``$autoload['drivers']``.
Andrey Andreev5232ba02012-10-27 15:25:05 +0300282 - ``$config['rewrite_short_tags']`` now has no effect when using PHP 5.4 as ``<?=`` will always be available.
Andrey Andreeved4b2582012-10-27 17:46:52 +0300283 - Changed method ``config()`` to return whatever ``CI_Config::load()`` returns instead of always being void.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100284 - :doc:`Input Library <libraries/input>` changes include:
285 - Added ``method()`` to retrieve ``$_SERVER['REQUEST_METHOD']``.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100286 - Added support for arrays and network addresses (e.g. 192.168.1.1/24) for use with the *proxy_ips* setting.
Andrey Andreev303eef02012-11-06 14:55:48 +0200287 - Added method ``input_stream()`` to aid in using **php://input** stream data such as one passed via PUT, DELETE and PATCH requests.
Andrey Andreev1887ec62012-10-27 16:22:07 +0300288 - Changed method ``valid_ip()`` to use PHP's native ``filter_var()`` function.
289 - Changed internal method ``_sanitize_globals()`` to skip enforcing reversal of *register_globals* in PHP 5.4+, where this functionality no longer exists.
290 - Changed methods ``get()``, ``post()``, ``get_post()``, ``cookie()``, ``server()``, ``user_agent()`` to return NULL instead of FALSE when no value is found.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100291 - :doc:`Common functions <general/common_functions>` changes include:
Andrey Andreev1bc30262012-11-09 11:30:51 +0200292 - Added function :php:func:`get_mimes()` to return the *application/config/mimes.php* array.
293 - Added support for HTTP code 303 ("See Other") in :php:func:`set_status_header()`.
294 - Removed redundant conditional to determine HTTP server protocol in :php:func:`set_status_header()`.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100295 - Changed ``_exception_handler()`` to respect php.ini *display_errors* setting.
Andrey Andreev1bc30262012-11-09 11:30:51 +0200296 - Added function :php:func:`is_https()` to check if a secure connection is used.
297 - Added function :php:func:`function_usable()` to check if a function exists and is not disabled by `Suhosin <http://www.hardened-php.net/suhosin/>`.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100298 - Added support for HTTP-Only cookies with new config option *cookie_httponly* (default FALSE).
299 - Renamed method ``_call_hook()`` to ``call_hook()`` in the :doc:`Hooks Library <general/hooks>`.
300 - :doc:`Output Library <libraries/output>` changes include:
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100301 - Added a second argument to method ``set_content_type()`` that allows setting the document charset as well.
Andrey Andreevb37d2bc2012-11-30 02:19:35 +0200302 - Added methods ``get_content_type()`` and ``get_header()``.
303 - Added method ``delete_cache()``.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100304 - ``$config['time_reference']`` now supports all timezone strings supported by PHP.
Andrey Andreev5232ba02012-10-27 15:25:05 +0300305 - :doc:`Config Library <libraries/config>` changes include:
306 - Changed ``site_url()`` method to accept an array as well.
307 - Removed internal method ``_assign_to_config()`` and moved it's implementation in *CodeIgniter.php* instead.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100308 - :doc:`Security Library <libraries/security>` changes include:
309 - Added method ``strip_image_tags()``.
310 - Added ``$config['csrf_regeneration']``, which makes token regeneration optional.
311 - Added ``$config['csrf_exclude_uris']``, which allows you list URIs which will not have the CSRF validation methods run.
Andrey Andreevd1097a12012-11-01 19:55:42 +0200312 - :doc:`URI Routing <general/routing>` changes include:
313 - Added possibility to route requests using callbacks.
314 - Added possibility to use dashes in the controller and method URI segments (translated to underscores).
Andrey Andreevb11b9f32012-11-26 23:01:24 +0200315 - :doc:`Language Library <libraries/language>` changes include:
316 - Changed method ``load()`` to filter the language name with ``ctype_digit()``.
317 - Added an optional second parameter to method ``line()`` to disable error login for line keys that were not found.
318 - Language files are now loaded in a cascading style with the one in **system/** always loaded and overriden afterwards, if another one is found.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000319
320Bug fixes for 3.0
321------------------
322
Andrey Andreev79922c02012-05-23 12:27:17 +0300323- Fixed a bug where ``unlink()`` raised an error if cache file did not exist when you try to delete it.
Andrey Andreev601f8b22012-03-01 20:11:15 +0200324- Fixed a bug (#181) where a mis-spelling was in the form validation language file.
Andrey Andreev7b5eb732012-05-24 20:52:41 +0300325- Fixed a bug (#159, #163) that mishandled Query Builder nested transactions because _trans_depth was not getting incremented.
Andrey Andreev5a1e5e32012-06-12 11:28:26 +0300326- Fixed a bug (#737, #75) - :doc:`Pagination <libraries/pagination>` anchor class was not set properly when using initialize method.
Greg Akerf41c9cf2011-12-25 00:15:17 -0600327- Fixed a bug (#419) - auto_link() now recognizes URLs that come after a word boundary.
328- Fixed a bug (#724) - is_unique in form validation now checks that you are connected to a database.
Andrey Andreev79922c02012-05-23 12:27:17 +0300329- Fixed a bug (#647) - _get_mod_time() in Zip library no longer generates stat failed errors.
330- Fixed a bug (#608) - Fixes an issue with the Image_lib class not clearing properties completely.
331- Fixed a bug (#157, #174) - the Image_lib clear() function now resets all variables to their default values.
Tomasz T17bcd2b2011-12-06 12:36:16 +0100332- Fixed a bug where using $this->dbforge->create_table() with PostgreSQL database could lead to fetching whole table.
Greg Akerf41c9cf2011-12-25 00:15:17 -0600333- Fixed a bug (#795) - Fixed form method and accept-charset when passing an empty array.
Andrey Andreev79922c02012-05-23 12:27:17 +0300334- Fixed a bug (#797) - timespan() was using incorrect seconds for year and month.
Andrey Andreevbb248832011-12-21 16:42:51 +0200335- Fixed a bug in CI_Cart::contents() where if called without a TRUE (or equal) parameter, it would fail due to a typo.
Andrey Andreev79922c02012-05-23 12:27:17 +0300336- Fixed a bug (#696) - make oci_execute() calls inside num_rows() non-committing, since they are only there to reset which row is next in line for oci_fetch calls and thus don't need to be committed.
Andrey Andreev1f26edc2012-06-07 16:13:54 +0300337- Fixed a bug (#406) - SQLSRV DB driver not returning resource on ``db_pconnect()``.
Andrey Andreeva92b9032011-12-24 19:05:58 +0200338- Fixed a bug in CI_Image_lib::gd_loaded() where it was possible for the script execution to end or a PHP E_WARNING message to be emitted.
Andrey Andreev79922c02012-05-23 12:27:17 +0300339- Fixed a bug in the :doc:`Pagination library <libraries/pagination>` where when use_page_numbers=TRUE previous link and page 1 link did not have the same url.
Andrey Andreevd81150f2012-01-03 11:06:32 +0200340- Fixed a bug (#561) - Errors in :doc:`XML-RPC Library <libraries/xmlrpc>` were not properly escaped.
Andrey Andreevd47baab2012-01-09 16:56:46 +0200341- Fixed a bug (#904) - ``CI_Loader::initialize()`` caused a PHP Fatal error to be triggered if error level E_STRICT is used.
Andrey Andreev79922c02012-05-23 12:27:17 +0300342- Fixed a hosting edge case where an empty $_SERVER['HTTPS'] variable would evaluate to 'on'.
Andrey Andreeveea2ff52012-01-19 13:21:53 +0200343- Fixed a bug (#154) - ``CI_Session::sess_update()`` caused the session to be destroyed on pages where multiple AJAX requests were executed at once.
Andrey Andreev9448afb2012-02-08 19:49:19 +0200344- Fixed a possible bug in ``CI_Input::is_ajax_request()`` where some clients might not send the X-Requested-With HTTP header value exactly as 'XmlHttpRequest'.
Andrey Andreev93cac5c2012-02-14 14:45:02 +0200345- Fixed a bug (#1039) - MySQL's _backup() method failed due to a table name not being escaped.
Andrey Andreev82e8ac12012-02-22 19:35:34 +0200346- Fixed a bug (#1070) - CI_DB_driver::initialize() didn't set a character set if a database is not selected.
Andrey Andreev46ac8812012-02-28 14:32:54 +0200347- Fixed a bug (#177) - CI_Form_validation::set_value() didn't set the default value if POST data is NULL.
Andrey Andreevc2905f52012-03-01 14:39:26 +0200348- Fixed a bug (#68, #414) - Oracle's escape_str() didn't properly escape LIKE wild characters.
Andrey Andreev41e46a92012-03-01 14:58:17 +0200349- Fixed a bug (#81) - ODBC's list_fields() and field_data() methods skipped the first column due to odbc_field_*() functions' index starting at 1 instead of 0.
Andrey Andreevef795ac2012-03-01 15:15:31 +0200350- Fixed a bug (#129) - ODBC's num_rows() returned -1 in some cases, due to not all subdrivers supporting the odbc_num_rows() function.
Andrey Andreev850f6012012-03-01 15:58:25 +0200351- Fixed a bug (#153) - E_NOTICE being generated by getimagesize() in the :doc:`File Uploading Library <libraries/file_uploading>`.
Andrey Andreev4be5de12012-03-02 15:45:41 +0200352- Fixed a bug (#611) - SQLSRV's error handling methods used to issue warnings when there's no actual error.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100353- Fixed a bug (#1036) - ``is_write_type()`` method in the :doc:`Database Library <database/index>` didn't return TRUE for RENAME queries.
Andrey Andreeved740822012-03-01 16:37:08 +0200354- Fixed a bug in PDO's _version() method where it used to return the client version as opposed to the server one.
Andrey Andreeva39d6992012-03-01 19:11:39 +0200355- Fixed a bug in PDO's insert_id() method where it could've failed if it's used with Postgre versions prior to 8.1.
Andrey Andreevea3eec92012-03-01 19:16:23 +0200356- Fixed a bug in CUBRID's affected_rows() method where a connection resource was passed to cubrid_affected_rows() instead of a result.
Andrey Andreev95bd1d12012-03-12 16:22:28 +0200357- Fixed a bug (#638) - db_set_charset() ignored its arguments and always used the configured charset instead.
Andrey Andreev4be5de12012-03-02 15:45:41 +0200358- Fixed a bug (#413) - Oracle's error handling methods used to only return connection-related errors.
Andrey Andreeveffd0132012-03-02 12:34:54 +0200359- Fixed a bug (#1101) - MySQL/MySQLi result method field_data() was implemented as if it was handling a DESCRIBE result instead of the actual result set.
Andrey Andreev8f220572012-03-02 13:05:45 +0200360- Fixed a bug in Oracle's :doc:`Database Forge Class <database/forge>` method _create_table() where it failed with AUTO_INCREMENT as it's not supported.
Diogo Osório593f7982012-03-02 18:04:17 +0000361- Fixed a bug (#1080) - When using the SMTP protocol, the :doc:`Email Library <libraries/email>` send() method was returning TRUE even if the connection/authentication against the server failed.
Andrey Andreev8af76662012-03-05 14:33:41 +0200362- Fixed a bug (#306) - ODBC's insert_id() method was calling non-existent function odbc_insert_id(), which resulted in a fatal error.
Andrey Andreev57bdeb62012-03-05 15:59:16 +0200363- Fixed a bug in Oracle's DB_result class where the cursor id passed to it was always NULL.
Andrey Andreev7b5eb732012-05-24 20:52:41 +0300364- Fixed a bug (#64) - Regular expression in DB_query_builder.php failed to handle queries containing SQL bracket delimiters in the join condition.
Andrey Andreev6b831232012-03-06 11:16:57 +0200365- Fixed a bug in the :doc:`Session Library <libraries/sessions>` where a PHP E_NOTICE error was triggered by _unserialize() due to results from databases such as MSSQL and Oracle being space-padded on the right.
Andrey Andreev3b2c5082012-03-07 22:49:24 +0200366- Fixed a bug (#501) - set_rules() to check if the request method is not 'POST' before aborting, instead of depending on count($_POST) in the :doc:`Form Validation Library <libraries/form_validation>`.
Andrey Andreev21cb2d32012-05-25 01:01:06 +0300367- Fixed a bug (#136) - PostgreSQL, MySQL and MySQLi's escape_str() method didn't properly escape LIKE wild characters.
Andrey Andreeva11b16b2012-03-28 12:22:04 +0300368- Fixed a bug in the library loader where some PHP versions wouldn't execute the class constructor.
Andrey Andreev64bfa062012-03-29 18:54:09 +0300369- Fixed a bug (#88) - An unexisting property was used for configuration of the Memcache cache driver.
Andrey Andreevd6057482012-04-03 14:07:31 +0300370- Fixed a bug (#14) - create_database() method in the :doc:`Database Forge Library <database/forge>` didn't utilize the configured database character set.
Andrey Andreeve7bbb1d2012-04-24 21:11:21 +0300371- Fixed a bug (#23, #1238) - delete_all() in the `Database Caching Library <database/caching>` used to delete .htaccess and index.html files, which is a potential security risk.
Andrey Andreev426faa92012-04-03 19:03:58 +0300372- Fixed a bug in :doc:`Trackback Library <libraries/trackback>` method validate_url() where it didn't actually do anything, due to input not being passed by reference.
Andrey Andreev81c87cd2012-01-12 17:00:29 +0200373- Fixed a bug (#11, #183, #863) - CI_Form_validation::_execute() silently continued to the next rule, if a rule method/function is not found.
Andrey Andreev79922c02012-05-23 12:27:17 +0300374- Fixed a bug (#122) Where routed uri string was being reported incorrectly in sub-directories.
Andrey Andreeva396c3b2012-04-04 18:57:39 +0300375- Fixed a bug (#1242) - read_dir() in the :doc:`Zip Library <libraries/zip>` wasn't compatible with Windows.
Andrey Andreev97f36972012-04-05 12:44:36 +0300376- Fixed a bug (#306) - ODBC driver didn't have an _insert_batch() method, which resulted in fatal error being triggered when insert_batch() is used with it.
Andrey Andreev6d83cde2012-04-05 16:20:50 +0300377- Fixed a bug in MSSQL and SQLSrv's _truncate() where the TABLE keyword was missing.
Andrey Andreev80144bf2012-04-06 22:19:26 +0300378- Fixed a bug in PDO's trans_commit() method where it failed due to an erroneous property name.
Andrey Andreev00541ae2012-04-09 11:43:10 +0300379- Fixed a bug (#798) - update() used to ignore LIKE conditions that were set with like().
Andrey Andreev5c0e9fe2012-04-09 12:28:11 +0300380- Fixed a bug in Oracle's and MSSQL's delete() methods where an erroneous SQL statement was generated when used with limit().
381- Fixed a bug in SQLSRV's delete() method where like() and limit() conditions were ignored.
Andrey Andreevb3f774b2012-04-23 12:57:57 +0300382- Fixed a bug (#1265) - Database connections were always closed, regardless of the 'pconnect' option value.
Andrey Andreev8d5b24a2012-01-27 14:37:38 +0200383- Fixed a bug (#128) - :doc:`Language Library <libraries/language>` did not correctly keep track of loaded language files.
Andrey Andreev79922c02012-05-23 12:27:17 +0300384- Fixed a bug (#1242) - Added Windows path compatibility to function read_dir of ZIP library.
Andrey Andreev7b5eb732012-05-24 20:52:41 +0300385- Fixed a bug (#1349) - get_extension() in the :doc:`File Uploading Library <libraries/file_uploading>` returned the original filename when it didn't have an actual extension.
386- Fixed a bug (#1273) - E_NOTICE being generated by :doc:`Query Builder <database/query_builder>`'s set_update_batch() method.
Andrey Andreev470805b2012-05-24 21:57:21 +0300387- Fixed a bug (#44, #110) - :doc:`Upload library <libraries/file_uploading>`'s clean_file_name() method didn't clear '!' and '#' characters.
Andrey Andreev55d3ad42012-05-24 22:13:06 +0300388- Fixed a bug (#121) - ``CI_DB_result::row()`` returned an array when there's no actual result to be returned.
Andrey Andreev846acc72012-05-24 23:27:46 +0300389- Fixed a bug (#319) - SQLSRV's affected_rows() method failed due to a scrollable cursor being created for write-type queries.
Andrey Andreevd06acd82012-05-25 00:29:09 +0300390- Fixed a bug (#356) - PostgreSQL driver didn't have an _update_batch() method, which resulted in fatal error being triggered when update_batch() is used with it.
Andrey Andreevaf4d55d2012-06-07 16:22:35 +0300391- Fixed a bug (#784, #862) - :doc:`Database Forge <database/forge>` method ``create_table()`` failed on SQLSRV/MSSQL when used with 'IF NOT EXISTS'.
Michiel Vugteveen2fd05062012-06-04 20:49:03 +0200392- Fixed a bug (#1419) - libraries/Driver.php had a static variable that was causing an error.
Andrey Andreev6ef498b2012-06-05 22:01:58 +0300393- Fixed a bug (#1411) - the :doc:`Email library <libraries/email>` used its own short list of MIMEs instead the one from config/mimes.php.
Andrey Andreev24bd2302012-06-05 22:29:12 +0300394- Fixed a bug where the magic_quotes_runtime setting wasn't turned off for PHP 5.3 (where it is indeed deprecated, but not non-existent).
Andrey Andreev47b67332012-06-06 15:58:05 +0300395- Fixed a bug (#666) - :doc:`Output library <libraries/output>`'s set_content_type() method didn't set the document charset.
Andrey Andreevaf4d55d2012-06-07 16:22:35 +0300396- Fixed a bug (#784, #861) - :doc:`Database Forge <database/forge>` method ``create_table()`` used to accept constraints for MSSQL/SQLSRV integer-type columns.
Andrey Andreev082ee2b2012-06-08 15:26:34 +0300397- Fixed a bug (#706) - SQLSRV/MSSSQL didn't escape field names.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100398- Fixed a bug (#1452) - ``protect_identifiers()`` didn't properly detect identifiers with spaces in their names.
399- Fixed a bug where ``protect_identifiers()`` ignored it's extra arguments when the value passed to it is an array.
400- Fixed a bug where ``_has_operator()`` didn't detect BETWEEN.
401- Fixed a bug in :doc:`Query Builder <database/query_builder>`'s ``join()`` method where it failed with identifiers containing dashes.
Andrey Andreev5d281762012-06-11 22:05:40 +0300402- Fixed a bug (#1264) - :doc:`Database Forge <database/forge>` and :doc:`Database Utilities <database/utilities>` didn't update/reset the databases and tables list cache when a table or a database is created, dropped or renamed.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100403- Fixed a bug (#7) - :doc:`Query Builder <database/query_builder>`'s ``join()`` method only escaped one set of conditions.
Andrey Andreev079fbfc2012-06-12 02:26:58 +0300404- Fixed a bug (#1321) - Core Exceptions class couldn't find the errors/ folder in some cases.
Andrey Andreevf696c1f2012-06-12 12:14:51 +0300405- Fixed a bug (#1202) - :doc:`Encryption Library <libraries/encryption>` encode_from_legacy() didn't set back the encrypt mode on failure.
Andrey Andreev4e9538f2012-06-12 14:16:53 +0300406- Fixed a bug (#145) - compile_binds() failed when the bind marker was present in a literal string within the query.
Andrey Andreev6984d152012-06-13 10:10:17 +0300407- Fixed a bug in protect_identifiers() where if passed along with the field names, operators got escaped as well.
Andrey Andreevd4619342012-06-14 02:27:25 +0300408- Fixed a bug (#10) - :doc:`URI Library <libraries/uri>` internal method _detect_uri() failed with paths containing a colon.
Andrey Andreev19c83f62012-06-14 14:33:33 +0300409- Fixed a bug (#1387) - :doc:`Query Builder <database/query_builder>`'s from() method didn't escape table aliases.
Andrey Andreevd9b44be2012-06-15 16:07:08 +0300410- Fixed a bug (#520) - :doc:`Date Helper <helpers/date_helper>` function nice_date() failed when the optional second parameter is not passed.
Andrey Andreev58ae9712012-06-15 23:44:48 +0300411- Fixed a bug (#167) - ``$config['permitted_uri_chars']`` didn't affect URL-encoded characters.
Andrey Andreev0140ddd2012-06-16 01:12:56 +0300412- Fixed a bug (#318) - :doc:`Profiling <general/profiling>` setting *query_toggle_count* was not settable as described in the manual.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100413- Fixed a bug (#938) - :doc:`Config Library <libraries/config>` method ``site_url()`` added a question mark to the URL string when query strings are enabled even if it already existed.
414- Fixed a bug (#999) - :doc:`Config Library <libraries/config>` method ``site_url()`` always appended ``$config['url_suffix']`` to the end of the URL string, regardless of whether a query string exists in it.
415- Fixed a bug where :doc:`URL Helper <helpers/url_helper>` function ``anchor_popup()`` ignored the attributes argument if it is not an array.
Andrey Andreev6ac51442012-06-18 13:05:17 +0300416- Fixed a bug (#1328) - :doc:`Form Validation Library <libraries/form_validation>` didn't properly check the type of the form fields before processing them.
Andrey Andreev8d3099d2012-06-21 16:00:20 +0300417- Fixed a bug (#79) - :doc:`Form Validation Library <libraries/form_validation>` didn't properly validate array fields that use associative keys or have custom indexes.
Andrey Andreev1a24a9d2012-06-27 00:52:47 +0300418- Fixed a bug (#427) - :doc:`Form Validation Library <libraries/form_validation>` method ``strip_image_tags()`` was an alias to a non-existent method.
Andrey Andreevd5809992012-06-28 14:06:54 +0300419- Fixed a bug (#1545) - :doc:`Query Builder <database/query_builder>` method ``limit()`` wasn't executed properly under Oracle.
Andrey Andreeva6ea5722012-07-02 16:33:11 +0300420- Fixed a bug (#1551) - :doc:`Date Helper <helpers/date_helper>` function ``standard_date()`` didn't properly format *W3C* and *ATOM* standard dates.
Andrey Andreev49aa45b2012-07-06 16:22:21 +0300421- Fixed a bug in :doc:`Query Builder <database/query_builder>` method join() where literal values were escaped as if they were fields.
Andrey Andreevcbb654d2012-07-10 11:36:32 +0300422- Fixed a bug (#135) - PHP Error logging was impossible without the errors being displayed.
Andrey Andreev6b114ae2012-07-13 12:05:52 +0300423- Fixed a bug (#1613) - :doc:`Form Helper <helpers/form_helper>` functions ``form_multiselect()``, ``form_dropdown()`` didn't properly handle empty array option groups.
Andrey Andreev685cdd72012-07-13 20:11:13 +0300424- Fixed a bug (#1605) - :doc:`Pagination Library <libraries/pagination>` produced incorrect *previous* and *next* link values.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100425- Fixed a bug in SQLSRV's ``affected_rows()`` method where an erroneous function name was used.
426- Fixed a bug (#1000) - Change syntax of ``$view_file`` to ``$_ci_view_file`` to prevent being overwritten by application.
427- Fixed a bug (#1757) - :doc:`Directory Helper <helpers/directory_helper>` function ``directory_map()`` was skipping files and directories named *0*.
428- Fixed a bug (#1789) - :doc:`Database Library <database/index>` method ``escape_str()`` escaped quote characters in LIKE conditions twice under MySQL.
429- Fixed a bug (#395) - :doc:`Unit Testing Library <libraries/unit_testing>` method ``result()`` didn't properly check array result columns when called from ``report()``.
430- Fixed a bug (#1692) - :doc:`Database Library <database/index>` method ``display_error()`` didn't properly trace the possible error source on Windows systems.
431- Fixed a bug (#1745) - ``is_write_type()`` method in the :doc:`Database Library <database/index>` didn't return TRUE for LOAD queries.
432- Fixed a bug (#1765) - :doc:`Database Library <database/index>` didn't properly detect connection errors for MySQLi.
433- Fixed a bug (#1257) - :doc:`Query Builder <database/query_builder>` used to (unnecessarily) group FROM clause contents, which breaks certain queries and is invalid for some databases.
434- Fixed a bug (#1709) - :doc:`Email <libraries/email>` headers were broken when using long email subjects and \r\n as CRLF.
435- Fixed a bug where ``MB_ENABLED`` was only declared if ``UTF8_ENABLED`` was set to TRUE.
436- Fixed a bug where the :doc:`Session Library <libraries/sessions>` accepted cookies with *last_activity* values being in the future.
437- Fixed a bug (#1897) - :doc:`Email Library <libraries/email>` triggered PHP E_WARNING errors when *mail* protocol used and ``to()`` is never called.
438- Fixed a bug (#1409) - :doc:`Email Library <libraries/email>` didn't properly handle multibyte characters when applying Q-encoding to headers.
439- Fixed a bug where :doc:`Email Library <libraries/email>` didn't honor it's *wordwrap* setting while handling alternative messages.
440- Fixed a bug (#1476, #1909) - :doc:`Pagination Library <libraries/pagination>` didn't take into account actual routing when determining the current page.
441- Fixed a bug (#1766) - :doc:`Query Builder <database/query_builder>` didn't always take into account the *dbprefix* setting.
442- Fixed a bug (#779) - :doc:`URI Class <libraries/uri>` didn't always trim slashes from the *uri_string* as shown in the documentation.
443- Fixed a bug (#134) - :doc:`Database Caching <database/caching>` method ``delete_cache()`` didn't work in some cases due to *cachedir* not being initialized properly.
Andrey Andreev9d0ab042012-10-24 21:47:39 +0300444- Fixed a bug (#191) - :doc:`Loader Library <libraries/loader>` ignored attempts for (re)loading databases to ``get_instance()->db`` even when the old database connection is dead.
Andrey Andreeva0836b92012-10-24 22:03:42 +0300445- Fixed a bug (#1255) - :doc:`User Agent Library <libraries/user_agent>` method ``is_referral()`` only checked if ``$_SERVER['HTTP_REFERER']`` exists.
Andrey Andreevd87f6bf2012-10-24 22:12:53 +0300446- Fixed a bug (#1146) - :doc:`Download Helper <helpers/download_helper>` function ``force_download()`` incorrectly sent *Cache-Control* directives *pre-check* and *post-check* to Internet Explorer.
Andrey Andreev4a7cc762012-10-24 23:52:05 +0300447- Fixed a bug (#1811) - :doc:`URI Library <libraries/uri>` didn't properly cache segments for ``uri_to_assoc()`` and ``ruri_to_assoc()``.
Andrey Andreev60b97142012-10-25 16:59:17 +0300448- Fixed a bug (#1506) - :doc:`Form Helpers <helpers/form_helper>` set empty *name* attributes.
Andrey Andreevb05f5062012-10-26 12:01:02 +0300449- Fixed a bug (#59) - :doc:`Query Builder <database/query_builder>` method ``count_all_results()`` ignored the DISTINCT clause.
Andrey Andreeva779b2c2012-10-26 16:25:47 +0300450- Fixed a bug (#1624) - :doc:`Form Validation Library <libraries/form_validation>` rule **matches** didn't property handle array field names.
Andrey Andreev74ffd172012-10-27 00:41:03 +0300451- Fixed a bug (#1630) - :doc:`Form Helper <helpers/form_helper>` function ``set_value()`` didn't escape HTML entities.
Andrey Andreev582ebcb2012-10-27 00:52:15 +0300452- Fixed a bug (#142) - :doc:`Form Helper <helpers/form_helper>` function ``form_dropdown()`` didn't escape HTML entities in option values.
Andrey Andreevca20d842012-10-27 03:02:38 +0300453- Fixed a bug (#50) - :doc:`Session Library <libraries/sessions>` unnecessarily stripped slashed from serialized data, making it impossible to read objects in a namespace.
Andrey Andreeved174112012-10-30 13:42:01 +0200454- Fixed a bug (#658) - :doc:`Routing <general/routing>` wildcard **:any** didn't work as advertised and matched multiple URI segments instead of all characters within a single segment.
Andrey Andreev9dd2dbb2012-10-31 17:54:56 +0200455- Fixed a bug (#1938) - :doc:`Email Library <libraries/email>` removed multiple spaces inside a pre-formatted plain text message.
456- Fixed a bug (#388, #705) - :doc:`URI Library <libraries/uri>` didn't apply URL-decoding to URI segments that it got from **REQUEST_URI** and/or **QUERY_STRING**.
Andrey Andreev254735e2012-11-01 21:21:20 +0200457- Fixed a bug (#122) - :doc:`URI Library <libraries/uri>` method ``ruri_string()`` didn't include a directory if one is used.
Andrey Andreev28daade2012-11-03 02:13:48 +0200458- Fixed a bug - :doc:`Routing Library <general/routing>` didn't properly handle *default_controller* in a subdirectory when a method is also specified.
Andrey Andreev38e32f62012-11-03 00:16:47 +0200459- Fixed a bug (#953) - :doc:`post_controller_constructor hook <general/hooks>` wasn't called with a *404_override*.
Andrey Andreev55a8c622012-11-06 13:31:21 +0200460- Fixed a bug (#1220) - :doc:`Profiler Library <general/profiling>` didn't display information for database objects that are instantiated inside models.
Andrey Andreev12d7b462012-11-12 13:42:09 +0200461- Fixed a bug (#1978) - :doc:`Directory Helper <helpers/directory_helper>` function :php:func:`directory_map()`'s return array didn't make a distinction between directories and file indexes when a directory with a numeric name is present.
462- Fixed a bug (#777) - :doc:`Loader Library <libraries/loader>` didn't look for helper extensions in added package paths.
Andrey Andreeva2b06772012-11-20 15:09:46 +0200463- Fixed a bug (#18) - :doc:`APC Cache <libraries/caching>` driver didn't (un)serialize data, resulting in failure to store objects.
Andrey Andreevce0c9562012-11-22 17:26:29 +0200464- Fixed a bug (#188) - :doc:`Unit Testing Library <libraries/unit_testing>` filled up logs with error messages for non-existing language keys.
Andrey Andreev2d48b4f2012-11-23 17:33:21 +0200465- Fixed a bug (#113) - :doc:`Form Validation Library <libraries/form_validation>` didn't properly handle empty fields that were specified as an array.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100466
467Version 2.1.3
468=============
469
470Release Date: October 8, 2012
471
472- Core
473 - :doc:`Common function <general/common_functions>` ``is_loaded()`` now returns a reference.
474
475Bug fixes for 2.1.3
476-------------------
477
478- Fixed a bug (#1543) - File-based :doc:`Caching <libraries/caching>` method ``get_metadata()`` used a non-existent array key to look for the TTL value.
479- Fixed a bug (#1314) - :doc:`Session Library <libraries/sessions>` method ``sess_destroy()`` didn't destroy the userdata array.
Andrey Andreev759d3222012-10-30 11:30:47 +0200480- Fixed a bug (#804) - :doc:`Profiler library <general/profiling>` was trying to handle objects as strings in some cases, resulting in *E_WARNING* messages being issued by ``htmlspecialchars()``.
Jonatas Miguel982a9f22012-10-24 18:34:40 +0100481- Fixed a bug (#1699) - :doc:`Migration Library <libraries/migration>` ignored the ``$config['migration_path']`` setting.
482- Fixed a bug (#227) - :doc:`Input Library <libraries/input>` allowed unconditional spoofing of HTTP clients' IP addresses through the *HTTP_CLIENT_IP* header.
483- Fixed a bug (#907) - :doc:`Input Library <libraries/input>` ignored *HTTP_X_CLUSTER_CLIENT_IP* and *HTTP_X_CLIENT_IP* headers when checking for proxies.
484- Fixed a bug (#940) - ``csrf_verify()`` used to set the CSRF cookie while processing a POST request with no actual POST data, which resulted in validating a request that should be considered invalid.
485- Fixed a bug (#499) - :doc:`Security Library <libraries/security>` where a CSRF cookie was created even if ``$config['csrf_protection']`` is set tot FALSE.
486- Fixed a bug (#1715) - :doc:`Input Library <libraries/input>` triggered ``csrf_verify()`` on CLI requests.
Andrey Andreeveae17d12012-11-17 23:55:18 +0200487- Fixed a bug (#751) - :doc:`Query Builder <database/query_builder>` didn't properly handle cached field escaping overrides.
488- Fixed a bug (#2004) - :doc:`Query Builder <database/query_builder>` didn't properly merge cached calls with non-cache ones.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000489
Andrey Andreevec902162012-07-02 15:57:34 +0300490Version 2.1.2
491=============
492
493Release Date: June 29, 2012
494
495- General Changes
496 - Improved security in ``xss_clean()``.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000497
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000498Version 2.1.1
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000499=============
500
Andrey Andreevec902162012-07-02 15:57:34 +0300501Release Date: June 12, 2012
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000502
503- General Changes
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000504 - Fixed support for docx, xlsx files in mimes.php.
505
506- Libraries
507 - Further improved MIME type detection in the :doc:`File Uploading Library <libraries/file_uploading>`.
Andrey Andreev5a257182012-06-10 06:18:14 +0300508 - Added support for IPv6 to the :doc:`Input Library <libraries/input>`.
509 - Added support for the IP format parameter to the :doc:`Form Validation Library <libraries/form_validation>`.
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000510
Phil Sturgeona2bd3632012-03-04 15:32:58 +0000511- Helpers
Andrey Andreevec902162012-07-02 15:57:34 +0300512 - ``url_title()`` performance and output improved. You can now use any string as the word delimiter, but 'dash' and 'underscore' are still supported.
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000513
514Bug fixes for 2.1.1
515-------------------
516
Andrey Andreevec902162012-07-02 15:57:34 +0300517- Fixed a bug (#697) - A wrong array key was used in the :doc:`File Uploading Library <libraries/file_uploading>` to check for mime-types.
518- Fixed a bug - ``form_open()`` compared $action against ``site_url()`` instead of ``base_url()``.
519- Fixed a bug - ``CI_Upload::_file_mime_type()`` could've failed if ``mime_content_type()`` is used for the detection and returns FALSE.
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000520- Fixed a bug (#538) - Windows paths were ignored when using the :doc:`Image Manipulation Library <libraries/image_lib>` to create a new file.
Andrey Andreev67a08ed2012-05-19 13:35:40 +0300521- Fixed a bug - When database caching was enabled, $this->db->query() checked the cache before binding variables which resulted in cached queries never being found.
522- Fixed a bug - CSRF cookie value was allowed to be any (non-empty) string before being written to the output, making code injection a risk.
523- Fixed a bug (#726) - PDO put a 'dbname' argument in it's connection string regardless of the database platform in use, which made it impossible to use SQLite.
Andrey Andreevec902162012-07-02 15:57:34 +0300524- Fixed a bug - ``CI_DB_pdo_driver::num_rows()`` was not returning properly value with SELECT queries, cause it was relying on ``PDOStatement::rowCount()``.
525- Fixed a bug (#1059) - ``CI_Image_lib::clear()`` was not correctly clearing all necessary object properties, namely width and height.
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000526
Phil Sturgeon6b414d12012-02-29 11:59:35 +0000527Version 2.1.0
528=============
529
530Release Date: November 14, 2011
531
532- General Changes
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000533
Derek Jones8ede1a22011-10-05 13:34:52 -0500534 - Callback validation rules can now accept parameters like any other
535 validation rule.
Derek Jones8ede1a22011-10-05 13:34:52 -0500536 - Added html_escape() to :doc:`Common
537 functions <general/common_functions>` to escape HTML output
538 for preventing XSS.
Derek Jones8ede1a22011-10-05 13:34:52 -0500539
540- Helpers
541
542 - Added increment_string() to :doc:`String
543 Helper <helpers/string_helper>` to turn "foo" into "foo-1"
544 or "foo-1" into "foo-2".
545 - Altered form helper - made action on form_open_multipart helper
546 function call optional. Fixes (#65)
547 - url_title() will now trim extra dashes from beginning and end.
Timothy Warren74479272011-10-10 10:51:55 -0400548 - Improved speed of :doc:`String Helper <helpers/string_helper>`'s random_string() method
Derek Jones8ede1a22011-10-05 13:34:52 -0500549
550- Database
551
Timothy Warren01b56bc2011-10-10 10:45:45 -0400552 - Added a `CUBRID <http://www.cubrid.org/>`_ driver to the :doc:`Database
Derek Jones8ede1a22011-10-05 13:34:52 -0500553 Driver <database/index>`. Thanks to the CUBRID team for
554 supplying this patch.
Timothy Warren01b56bc2011-10-10 10:45:45 -0400555 - Added a PDO driver to the :doc:`Database Driver <database/index>`.
Derek Jones8ede1a22011-10-05 13:34:52 -0500556 - Typecast limit and offset in the :doc:`Database
557 Driver <database/queries>` to integers to avoid possible
558 injection.
559 - Added additional option 'none' for the optional third argument for
560 $this->db->like() in the :doc:`Database
Derek Jonesce79be02012-06-25 23:23:46 -0700561 Driver <database/query_builder>`.
Timothy Warren01b56bc2011-10-10 10:45:45 -0400562 - Added $this->db->insert_batch() support to the OCI8 (Oracle) driver.
Felix Balfoort85fe96d2011-11-29 16:27:53 +0100563 - Added failover if the main connections in the config should fail
Derek Jones8ede1a22011-10-05 13:34:52 -0500564
565- Libraries
566
567 - Changed $this->cart->insert() in the :doc:`Cart
568 Library <libraries/cart>` to return the Row ID if a single
569 item was inserted successfully.
570 - Added support to set an optional parameter in your callback rules
571 of validation using the :doc:`Form Validation
572 Library <libraries/form_validation>`.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000573 - Added a :doc:`Migration library <libraries/migration>` to assist with applying
kenjis68647362011-10-18 23:33:23 +0900574 incremental updates to your database schema.
Derek Jones8ede1a22011-10-05 13:34:52 -0500575 - Driver children can be located in any package path.
576 - Added max_filename_increment config setting for Upload library.
Derek Jones8ede1a22011-10-05 13:34:52 -0500577 - Added is_unique to the :doc:`Form Validation
578 library <libraries/form_validation>`.
Timothy Warren01b56bc2011-10-10 10:45:45 -0400579 - Added $config['use_page_numbers'] to the :doc:`Pagination library <libraries/pagination>`, which enables real page numbers in the URI.
Derek Jones8ede1a22011-10-05 13:34:52 -0500580 - Added TLS and SSL Encryption for SMTP.
581
582- Core
583
584 - Changed private functions in CI_URI to protected so MY_URI can
585 override them.
586 - Removed CI_CORE boolean constant from CodeIgniter.php (no longer Reactor and Core versions).
587
588Bug fixes for 2.1.0
589-------------------
590
Derek Jones8ede1a22011-10-05 13:34:52 -0500591- Fixed #378 Robots identified as regular browsers by the User Agent
592 class.
593- If a config class was loaded first then a library with the same name
594 is loaded, the config would be ignored.
595- Fixed a bug (Reactor #19) where 1) the 404_override route was being
596 ignored in some cases, and 2) auto-loaded libraries were not
597 available to the 404_override controller when a controller existed
598 but the requested method did not.
599- Fixed a bug (Reactor #89) where MySQL export would fail if the table
600 had hyphens or other non alphanumeric/underscore characters.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000601- Fixed a bug (#200) where MySQL queries would be malformed after calling $this->db->count_all() then $this->db->get()
602- Fixed a bug (#105) that stopped query errors from being logged unless database debugging was enabled
Derek Jones8ede1a22011-10-05 13:34:52 -0500603- Fixed a bug (#160) - Removed unneeded array copy in the file cache
604 driver.
605- Fixed a bug (#150) - field_data() now correctly returns column
606 length.
607- Fixed a bug (#8) - load_class() now looks for core classes in
608 APPPATH first, allowing them to be replaced.
Phil Sturgeonf748ebc2011-11-13 19:24:16 +0000609- Fixed a bug (#24) - ODBC database driver called incorrect parent in __construct().
610- Fixed a bug (#85) - OCI8 (Oracle) database escape_str() function did not escape correct.
kenjis087a7a82011-10-20 20:08:47 +0900611- Fixed a bug (#344) - Using schema found in :doc:`Saving Session Data to a Database <libraries/sessions>`, system would throw error "user_data does not have a default value" when deleting then creating a session.
Derek Jones8ede1a22011-10-05 13:34:52 -0500612- Fixed a bug (#112) - OCI8 (Oracle) driver didn't pass the configured database character set when connecting.
613- Fixed a bug (#182) - OCI8 (Oracle) driver used to re-execute the statement whenever num_rows() is called.
kenjis087a7a82011-10-20 20:08:47 +0900614- Fixed a bug (#82) - WHERE clause field names in the DB update_string() method were not escaped, resulting in failed queries in some cases.
615- Fixed a bug (#89) - Fix a variable type mismatch in DB display_error() where an array is expected, but a string could be set instead.
Derek Jones8ede1a22011-10-05 13:34:52 -0500616- Fixed a bug (#467) - Suppress warnings generated from get_magic_quotes_gpc() (deprecated in PHP 5.4)
617- Fixed a bug (#484) - First time _csrf_set_hash() is called, hash is never set to the cookie (in Security.php).
kenjis087a7a82011-10-20 20:08:47 +0900618- Fixed a bug (#60) - Added _file_mime_type() method to the :doc:`File Uploading Library <libraries/file_uploading>` in order to fix a possible MIME-type injection.
Bo-Yi Wud75e03a2011-10-07 14:44:35 +0800619- Fixed a bug (#537) - Support for all wav type in browser.
Bo-Yi Wu4d7c27e2011-10-15 12:02:32 +0800620- Fixed a bug (#576) - Using ini_get() function to detect if apc is enabled or not.
Phil Sturgeonc737c942011-11-21 11:23:15 +0000621- Fixed invalid date time format in :doc:`Date helper <helpers/date_helper>` and :doc:`XMLRPC library <libraries/xmlrpc>`.
Kyle Farris6f1fa5e2011-10-14 15:13:39 -0300622- Fixed a bug (#200) - MySQL queries would be malformed after calling count_all() then db->get().
Derek Jones8ede1a22011-10-05 13:34:52 -0500623
624Version 2.0.3
625=============
626
627Release Date: August 20, 2011
628
629- Security
630
631 - An improvement was made to the MySQL and MySQLi drivers to prevent
632 exposing a potential vector for SQL injection on sites using
633 multi-byte character sets in the database client connection.
634 An incompatibility in PHP versions < 5.2.3 and MySQL < 5.0.7 with
635 *mysql_set_charset()* creates a situation where using multi-byte
636 character sets on these environments may potentially expose a SQL
637 injection attack vector. Latin-1, UTF-8, and other "low ASCII"
638 character sets are unaffected on all environments.
639
640 If you are running or considering running a multi-byte character
641 set for your database connection, please pay close attention to
642 the server environment you are deploying on to ensure you are not
643 vulnerable.
644
645- General Changes
646
647 - Fixed a bug where there was a misspelling within a code comment in
648 the index.php file.
649 - Added Session Class userdata to the output profiler. Additionally,
650 added a show/hide toggle on HTTP Headers, Session Data and Config
651 Variables.
652 - Removed internal usage of the EXT constant.
653 - Visual updates to the welcome_message view file and default error
654 templates. Thanks to `danijelb <https://bitbucket.org/danijelb>`_
655 for the pull request.
656 - Added insert_batch() function to the PostgreSQL database driver.
657 Thanks to epallerols for the patch.
658 - Added "application/x-csv" to mimes.php.
Timothy Warren01b56bc2011-10-10 10:45:45 -0400659 - Fixed a bug where :doc:`Email library <libraries/email>`
Derek Jones8ede1a22011-10-05 13:34:52 -0500660 attachments with a "." in the name would using invalid MIME-types.
Derek Jones8ede1a22011-10-05 13:34:52 -0500661
662- Helpers
663
664 - Added an optional third parameter to heading() which allows adding
665 html attributes to the rendered heading tag.
666 - form_open() now only adds a hidden (Cross-site Reference Forgery)
667 protection field when the form's action is internal and is set to
668 the post method. (Reactor #165)
669 - Re-worked plural() and singular() functions in the :doc:`Inflector
670 helper <helpers/inflector_helper>` to support considerably
671 more words.
672
673- Libraries
674
675 - Altered Session to use a longer match against the user_agent
676 string. See upgrade notes if using database sessions.
677 - Added $this->db->set_dbprefix() to the :doc:`Database
678 Driver <database/queries>`.
679 - Changed $this->cart->insert() in the :doc:`Cart
680 Library <libraries/cart>` to return the Row ID if a single
681 item was inserted successfully.
682 - Added $this->load->get_var() to the :doc:`Loader
683 library <libraries/loader>` to retrieve global vars set with
684 $this->load->view() and $this->load->vars().
685 - Changed $this->db->having() to insert quotes using escape() rather
686 than escape_str().
687
688Bug fixes for 2.0.3
689-------------------
690
691- Added ENVIRONMENT to reserved constants. (Reactor #196)
692- Changed server check to ensure SCRIPT_NAME is defined. (Reactor #57)
693- Removed APPPATH.'third_party' from the packages autoloader to negate
694 needless file stats if no packages exist or if the developer does not
695 load any other packages by default.
696- Fixed a bug (Reactor #231) where Sessions Library database table
697 example SQL did not contain an index on last_activity. See :doc:`Upgrade
698 Notes <installation/upgrade_203>`.
699- Fixed a bug (Reactor #229) where the Sessions Library example SQL in
700 the documentation contained incorrect SQL.
701- Fixed a bug (Core #340) where when passing in the second parameter to
702 $this->db->select(), column names in subsequent queries would not be
703 properly escaped.
704- Fixed issue #199 - Attributes passed as string does not include a
705 space between it and the opening tag.
706- Fixed a bug where the method $this->cart->total_items() from :doc:`Cart
707 Library <libraries/cart>` now returns the sum of the quantity
708 of all items in the cart instead of your total count.
709- Fixed a bug where not setting 'null' when adding fields in db_forge
710 for mysql and mysqli drivers would default to NULL instead of NOT
711 NULL as the docs suggest.
712- Fixed a bug where using $this->db->select_max(),
713 $this->db->select_min(), etc could throw notices. Thanks to w43l for
714 the patch.
715- Replace checks for STDIN with php_sapi_name() == 'cli' which on the
716 whole is more reliable. This should get parameters in crontab
717 working.
718
719Version 2.0.2
720=============
721
722Release Date: April 7, 2011
723Hg Tag: v2.0.2
724
725- General changes
726
727 - The :doc:`Security library <./libraries/security>` was moved to
728 the core and is now loaded automatically. Please remove your
729 loading calls.
730 - The CI_SHA class is now deprecated. All supported versions of PHP
731 provide a sha1() function.
732 - constants.php will now be loaded from the environment folder if
733 available.
734 - Added language key error logging
735 - Made Environment Support optional. Comment out or delete the
736 constant to stop environment checks.
737 - Added Environment Support for Hooks.
738 - Added CI\_ Prefix to the :doc:`Cache driver <libraries/caching>`.
739 - Added :doc:`CLI usage <./general/cli>` documentation.
740
741- Helpers
742
743 - Removed the previously deprecated dohash() from the :doc:`Security
744 helper <./helpers/security_helper>`; use do_hash() instead.
745 - Changed the 'plural' function so that it doesn't ruin the
746 captalization of your string. It also take into consideration
747 acronyms which are all caps.
748
749- Database
750
751 - $this->db->count_all_results() will now return an integer
752 instead of a string.
753
754Bug fixes for 2.0.2
755-------------------
756
757- Fixed a bug (Reactor #145) where the Output Library had
758 parse_exec_vars set to protected.
759- Fixed a bug (Reactor #80) where is_really_writable would create an
760 empty file when on Windows or with safe_mode enabled.
761- Fixed various bugs with User Guide.
762- Added is_cli_request() method to documentation for :doc:`Input
763 class <libraries/input>`.
764- Added form_validation_lang entries for decimal, less_than and
765 greater_than.
766- `Fixed issue
767 #153 <https://bitbucket.org/ellislab/codeigniter-reactor/issue/153/escape-str-bug-in-mssql-driver>`_
768 Escape Str Bug in MSSQL driver.
769- `Fixed issue
770 #172 <https://bitbucket.org/ellislab/codeigniter-reactor/issue/172/bug-in-chrome-and-form_open-in-201>`_
771 Google Chrome 11 posts incorrectly when action is empty.
772
773Version 2.0.1
774=============
775
776Release Date: March 15, 2011
777Hg Tag: v2.0.1
778
779- General changes
780
781 - Added $config['cookie_secure'] to the config file to allow
782 requiring a secure (HTTPS) in order to set cookies.
783 - Added the constant CI_CORE to help differentiate between Core:
784 TRUE and Reactor: FALSE.
785 - Added an ENVIRONMENT constant in index.php, which affects PHP
786 error reporting settings, and optionally, which configuration
kenjis087a7a82011-10-20 20:08:47 +0900787 files are loaded (see below). Read more on the :doc:`Handling
Derek Jones8ede1a22011-10-05 13:34:52 -0500788 Environments <general/environments>` page.
789 - Added support for
790 :ref:`environment-specific <config-environments>`
791 configuration files.
792
793- Libraries
794
kenjis087a7a82011-10-20 20:08:47 +0900795 - Added decimal, less_than and greater_than rules to the :doc:`Form
Derek Jones8ede1a22011-10-05 13:34:52 -0500796 validation Class <libraries/form_validation>`.
797 - :doc:`Input Class <libraries/input>` methods post() and get()
798 will now return a full array if the first argument is not
799 provided.
800 - Secure cookies can now be made with the set_cookie() helper and
801 :doc:`Input Class <libraries/input>` method.
802 - Added set_content_type() to :doc:`Output
803 Class <libraries/output>` to set the output Content-Type
804 HTTP header based on a MIME Type or a config/mimes.php array key.
805 - :doc:`Output Class <libraries/output>` will now support method
806 chaining.
807
808- Helpers
809
810 - Changed the logic for form_open() in :doc:`Form
811 helper <helpers/form_helper>`. If no value is passed it will
812 submit to the current URL.
813
814Bug fixes for 2.0.1
815-------------------
816
817- CLI requests can now be run from any folder, not just when CD'ed next
818 to index.php.
819- Fixed issue #41: Added audio/mp3 mime type to mp3.
820- Fixed a bug (Core #329) where the file caching driver referenced the
821 incorrect cache directory.
822- Fixed a bug (Reactor #69) where the SHA1 library was named
823 incorrectly.
824
Derek Jonescaa1db62011-10-17 21:17:21 -0500825.. _2.0.0-changelog:
826
Derek Jones8ede1a22011-10-05 13:34:52 -0500827Version 2.0.0
828=============
829
830Release Date: January 28, 2011
831Hg Tag: v2.0.0
832
833- General changes
834
835 - PHP 4 support is removed. CodeIgniter now requires PHP 5.1.6.
836 - Scaffolding, having been deprecated for a number of versions, has
837 been removed.
838 - Plugins have been removed, in favor of Helpers. The CAPTCHA plugin
839 has been converted to a Helper and
840 :doc:`documented <./helpers/captcha_helper>`. The JavaScript
841 calendar plugin was removed due to the ready availability of great
842 JavaScript calendars, particularly with jQuery.
843 - Added new special Library type:
844 :doc:`Drivers <./general/drivers>`.
845 - Added full query-string support. See the config file for details.
846 - Moved the application folder outside of the system folder.
847 - Moved system/cache and system/logs directories to the application
848 directory.
849 - Added routing overrides to the main index.php file, enabling the
850 normal routing to be overridden on a per "index" file basis.
851 - Added the ability to set config values (or override config values)
852 directly from data set in the main index.php file. This allows a
853 single application to be used with multiple front controllers,
854 each having its own config values.
855 - Added $config['directory_trigger'] to the config file so that a
856 controller sub-directory can be specified when running _GET
857 strings instead of URI segments.
858 - Added ability to set "Package" paths - specific paths where the
859 Loader and Config classes should try to look first for a requested
860 file. This allows distribution of sub-applications with their own
861 libraries, models, config files, etc. in a single "package"
862 directory. See the :doc:`Loader class <libraries/loader>`
863 documentation for more details.
864 - In-development code is now hosted at
865 `BitBucket <http://bitbucket.org/ellislab/codeigniter-reactor/>`_.
866 - Removed the deprecated Validation Class.
867 - Added CI\_ Prefix to all core classes.
868 - Package paths can now be set in application/config/autoload.php.
kenjis087a7a82011-10-20 20:08:47 +0900869 - :doc:`Upload library <libraries/file_uploading>` file_name can
Derek Jones8ede1a22011-10-05 13:34:52 -0500870 now be set without an extension, the extension will be taken from
871 the uploaded file instead of the given name.
872 - In :doc:`Database Forge <database/forge>` the name can be omitted
873 from $this->dbforge->modify_column()'s 2nd param if you aren't
874 changing the name.
875 - $config['base_url'] is now empty by default and will guess what
876 it should be.
877 - Enabled full Command Line Interface compatibility with
878 config['uri_protocol'] = 'CLI';.
879
880- Libraries
881
882 - Added a :doc:`Cache driver <libraries/caching>` with APC,
883 memcached, and file-based support.
884 - Added $prefix, $suffix and $first_url properties to :doc:`Pagination
885 library <./libraries/pagination>`.
886 - Added the ability to suppress first, previous, next, last, and
887 page links by setting their values to FALSE in the :doc:`Pagination
888 library <./libraries/pagination>`.
889 - Added :doc:`Security library <./libraries/security>`, which now
890 contains the xss_clean function, filename_security function and
891 other security related functions.
892 - Added CSRF (Cross-site Reference Forgery) protection to the
893 :doc:`Security library <./libraries/security>`.
894 - Added $parse_exec_vars property to Output library.
895 - Added ability to enable / disable individual sections of the
896 :doc:`Profiler <general/profiling>`
897 - Added a wildcard option $config['allowed_types'] = '\*' to the
898 :doc:`File Uploading Class <./libraries/file_uploading>`.
899 - Added an 'object' config variable to the XML-RPC Server library so
900 that one can specify the object to look for requested methods,
901 instead of assuming it is in the $CI superobject.
902 - Added "is_object" into the list of unit tests capable of being
903 run.
904 - Table library will generate an empty cell with a blank string, or
905 NULL value.
906 - Added ability to set tag attributes for individual cells in the
907 Table library
908 - Added a parse_string() method to the :doc:`Parser
909 Class <libraries/parser>`.
910 - Added HTTP headers and Config information to the
911 :doc:`Profiler <general/profiling>` output.
912 - Added Chrome and Flock to the list of detectable browsers by
913 browser() in the :doc:`User Agent Class <libraries/user_agent>`.
914 - The :doc:`Unit Test Class <libraries/unit_testing>` now has an
915 optional "notes" field available to it, and allows for discrete
916 display of test result items using
917 $this->unit->set_test_items().
918 - Added a $xss_clean class variable to the XMLRPC library, enabling
919 control over the use of the Security library's xss_clean()
920 method.
921 - Added a download() method to the :doc:`FTP
922 library <libraries/ftp>`
923 - Changed do_xss_clean() to return FALSE if the uploaded file
924 fails XSS checks.
925 - Added stripslashes() and trim()ing of double quotes from $_FILES
926 type value to standardize input in Upload library.
927 - Added a second parameter (boolean) to
928 $this->zip->read_dir('/path/to/directory', FALSE) to remove the
929 preceding trail of empty folders when creating a Zip archive. This
930 example would contain a zip with "directory" and all of its
931 contents.
932 - Added ability in the Image Library to handle PNG transparency for
933 resize operations when using the GD lib.
934 - Modified the Session class to prevent use if no encryption key is
935 set in the config file.
936 - Added a new config item to the Session class
937 sess_expire_on_close to allow sessions to auto-expire when the
938 browser window is closed.
939 - Improved performance of the Encryption library on servers where
940 Mcrypt is available.
941 - Changed the default encryption mode in the Encryption library to
942 CBC.
943 - Added an encode_from_legacy() method to provide a way to
944 transition encrypted data from CodeIgniter 1.x to CodeIgniter 2.x.
945 Please see the :doc:`upgrade
946 instructions <./installation/upgrade_200>` for details.
947 - Altered Form_Validation library to allow for method chaining on
948 set_rules(), set_message() and set_error_delimiters()
949 functions.
950 - Altered Email Library to allow for method chaining.
951 - Added request_headers(), get_request_header() and
952 is_ajax_request() to the input class.
953 - Altered :doc:`User agent library <libraries/user_agent>` so that
954 is_browser(), is_mobile() and is_robot() can optionally check
955 for a specific browser or mobile device.
956 - Altered :doc:`Input library <libraries/input>` so that post() and
957 get() will return all POST and GET items (respectively) if there
958 are no parameters passed in.
959
960- Database
961
962 - :doc:`database configuration <./database/configuration>`.
963 - Added autoinit value to :doc:`database
964 configuration <./database/configuration>`.
965 - Added stricton value to :doc:`database
966 configuration <./database/configuration>`.
967 - Added database_exists() to the :doc:`Database Utilities
968 Class <database/utilities>`.
969 - Semantic change to db->version() function to allow a list of
970 exceptions for databases with functions to return version string
971 instead of specially formed SQL queries. Currently this list only
972 includes Oracle and SQLite.
973 - Fixed a bug where driver specific table identifier protection
974 could lead to malformed queries in the field_data() functions.
975 - Fixed a bug where an undefined class variable was referenced in
976 database drivers.
977 - Modified the database errors to show the filename and line number
978 of the problematic query.
979 - Removed the following deprecated functions: orwhere, orlike,
980 groupby, orhaving, orderby, getwhere.
981 - Removed deprecated _drop_database() and _create_database()
982 functions from the db utility drivers.
983 - Improved dbforge create_table() function for the Postgres driver.
984
985- Helpers
986
987 - Added convert_accented_characters() function to :doc:`text
988 helper <./helpers/text_helper>`.
989 - Added accept-charset to the list of inserted attributes of
990 form_open() in the :doc:`Form Helper <helpers/form_helper>`.
991 - Deprecated the dohash() function in favour of do_hash() for
992 naming consistency.
993 - Non-backwards compatible change made to get_dir_file_info() in
994 the :doc:`File Helper <helpers/file_helper>`. No longer recurses
995 by default so as to encourage responsible use (this function can
996 cause server performance issues when used without caution).
997 - Modified the second parameter of directory_map() in the
998 :doc:`Directory Helper <helpers/directory_helper>` to accept an
999 integer to specify recursion depth.
1000 - Modified delete_files() in the :doc:`File
1001 Helper <helpers/file_helper>` to return FALSE on failure.
1002 - Added an optional second parameter to byte_format() in the
1003 :doc:`Number Helper <helpers/number_helper>` to allow for decimal
1004 precision.
1005 - Added alpha, and sha1 string types to random_string() in the
1006 :doc:`String Helper <helpers/string_helper>`.
1007 - Modified prep_url() so as to not prepend http:// if the supplied
1008 string already has a scheme.
1009 - Modified get_file_info in the file helper, changing filectime()
1010 to filemtime() for dates.
1011 - Modified smiley_js() to add optional third parameter to return
1012 only the javascript with no script tags.
1013 - The img() function of the :doc:`HTML
1014 helper <./helpers/html_helper>` will now generate an empty
1015 string as an alt attribute if one is not provided.
1016 - If CSRF is enabled in the application config file, form_open()
1017 will automatically insert it as a hidden field.
1018 - Added sanitize_filename() into the :doc:`Security
1019 helper <./helpers/security_helper>`.
1020 - Added ellipsize() to the :doc:`Text
1021 Helper <./helpers/text_helper>`
1022 - Added elements() to the :doc:`Array
1023 Helper <./helpers/array_helper>`
1024
1025- Other Changes
1026
1027 - Added an optional second parameter to show_404() to disable
1028 logging.
1029 - Updated loader to automatically apply the sub-class prefix as an
1030 option when loading classes. Class names can be prefixed with the
1031 standard "CI\_" or the same prefix as the subclass prefix, or no
1032 prefix at all.
1033 - Increased randomness with is_really_writable() to avoid file
1034 collisions when hundreds or thousands of requests occur at once.
1035 - Switched some DIR_WRITE_MODE constant uses to FILE_WRITE_MODE
1036 where files and not directories are being operated on.
1037 - get_mime_by_extension() is now case insensitive.
1038 - Added "default" to the list :doc:`Reserved
1039 Names <general/reserved_names>`.
1040 - Added 'application/x-msdownload' for .exe files and
kenjis087a7a82011-10-20 20:08:47 +09001041 'application/x-gzip-compressed' for .tgz files to
Derek Jones8ede1a22011-10-05 13:34:52 -05001042 config/mimes.php.
1043 - Updated the output library to no longer compress output or send
1044 content-length headers if the server runs with
1045 zlib.output_compression enabled.
1046 - Eliminated a call to is_really_writable() on each request unless
1047 it is really needed (Output caching)
1048 - Documented append_output() in the :doc:`Output
1049 Class <libraries/output>`.
1050 - Documented a second argument in the decode() function for the
1051 :doc:`Encryption Class <libraries/encryption>`.
1052 - Documented db->close().
1053 - Updated the router to support a default route with any number of
1054 segments.
1055 - Moved _remove_invisible_characters() function from the
1056 :doc:`Security Library <libraries/security>` to :doc:`common
1057 functions. <general/common_functions>`
1058 - Added audio/mpeg3 as a valid mime type for MP3.
1059
1060Bug fixes for 2.0.0
1061-------------------
1062
1063- Fixed a bug where you could not change the User-Agent when sending
1064 email.
1065- Fixed a bug where the Output class would send incorrect cached output
1066 for controllers implementing their own _output() method.
1067- Fixed a bug where a failed query would not have a saved query
1068 execution time causing errors in the Profiler
1069- Fixed a bug that was writing log entries when multiple identical
1070 helpers and plugins were loaded.
1071- Fixed assorted user guide typos or examples (#10693, #8951, #7825,
1072 #8660, #7883, #6771, #10656).
1073- Fixed a language key in the profiler: "profiler_no_memory_usage"
1074 to "profiler_no_memory".
1075- Fixed an error in the Zip library that didn't allow downloading on
1076 PHP 4 servers.
1077- Fixed a bug in the Form Validation library where fields passed as
1078 rule parameters were not being translated (#9132)
1079- Modified inflector helper to properly pluralize words that end in
1080 'ch' or 'sh'
1081- Fixed a bug in xss_clean() that was not allowing hyphens in query
1082 strings of submitted URLs.
1083- Fixed bugs in get_dir_file_info() and get_file_info() in the
1084 File Helper with recursion, and file paths on Windows.
1085- Fixed a bug where Active Record override parameter would not let you
1086 disable Active Record if it was enabled in your database config file.
1087- Fixed a bug in reduce_double_slashes() in the String Helper to
1088 properly remove duplicate leading slashes (#7585)
1089- Fixed a bug in values_parsing() of the XML-RPC library which
1090 prevented NULL variables typed as 'string' from being handled
1091 properly.
1092- Fixed a bug were form_open_multipart() didn't accept string
1093 attribute arguments (#10930).
1094- Fixed a bug (#10470) where get_mime_by_extension() was case
1095 sensitive.
1096- Fixed a bug where some error messages for the SQLite and Oracle
1097 drivers would not display.
1098- Fixed a bug where files created with the Zip Library would result in
1099 file creation dates of 1980.
1100- Fixed a bug in the Session library that would result in PHP error
1101 when attempting to store values with objects.
1102- Fixed a bug where extending the Controller class would result in a
1103 fatal PHP error.
1104- Fixed a PHP Strict Standards Error in the index.php file.
1105- Fixed a bug where getimagesize() was being needlessly checked on
1106 non-image files in is_allowed_type().
1107- Fixed a bug in the Encryption library where an empty key was not
1108 triggering an error.
1109- Fixed a bug in the Email library where CC and BCC recipients were not
1110 reset when using the clear() method (#109).
1111- Fixed a bug in the URL Helper where prep_url() could cause a PHP
1112 error on PHP versions < 5.1.2.
1113- Added a log message in core/output if the cache directory config
1114 value was not found.
1115- Fixed a bug where multiple libraries could not be loaded by passing
1116 an array to load->library()
1117- Fixed a bug in the html helper where too much white space was
1118 rendered between the src and alt tags in the img() function.
1119- Fixed a bug in the profilers _compile_queries() function.
1120- Fixed a bug in the date helper where the DATE_ISO8601 variable was
1121 returning an incorrectly formatted date string.
1122
1123Version 1.7.2
1124=============
1125
1126Release Date: September 11, 2009
1127Hg Tag: v1.7.2
1128
1129- Libraries
1130
1131 - Added a new :doc:`Cart Class <libraries/cart>`.
1132 - Added the ability to pass $config['file_name'] for the :doc:`File
1133 Uploading Class <libraries/file_uploading>` and rename the
1134 uploaded file.
1135 - Changed order of listed user-agents so Safari would more
1136 accurately report itself. (#6844)
1137
1138- Database
1139
1140 - Switched from using gettype() in escape() to is\_* methods, since
1141 future PHP versions might change its output.
1142 - Updated all database drivers to handle arrays in escape_str()
1143 - Added escape_like_str() method for escaping strings to be used
1144 in LIKE conditions
1145 - Updated Active Record to utilize the new LIKE escaping mechanism.
1146 - Added reconnect() method to DB drivers to try to keep alive /
1147 reestablish a connection after a long idle.
1148 - Modified MSSQL driver to use mssql_get_last_message() for error
1149 messages.
1150
1151- Helpers
1152
1153 - Added form_multiselect() to the :doc:`Form
1154 helper <helpers/form_helper>`.
1155 - Modified form_hidden() in the :doc:`Form
1156 helper <helpers/form_helper>` to accept multi-dimensional
1157 arrays.
1158 - Modified form_prep() in the :doc:`Form
1159 helper <helpers/form_helper>` to keep track of prepped
1160 fields to avoid multiple prep/mutation from subsequent calls which
1161 can occur when using Form Validation and form helper functions to
1162 output form fields.
1163 - Modified directory_map() in the :doc:`Directory
1164 helper <helpers/directory_helper>` to allow the inclusion of
1165 hidden files, and to return FALSE on failure to read directory.
1166 - Modified the :doc:`Smiley helper <helpers/smiley_helper>` to work
1167 with multiple fields and insert the smiley at the last known
1168 cursor position.
1169
1170- General
1171
kenjis087a7a82011-10-20 20:08:47 +09001172 - Compatible with PHP 5.3.0.
Derek Jones8ede1a22011-10-05 13:34:52 -05001173 - Modified :doc:`show_error() <general/errors>` to allow sending
1174 of HTTP server response codes.
1175 - Modified :doc:`show_404() <general/errors>` to send 404 status
1176 code, removing non-CGI compatible header() statement from
1177 error_404.php template.
1178 - Added set_status_header() to the :doc:`Common
1179 functions <general/common_functions>` to allow use when the
1180 Output class is unavailable.
1181 - Added is_php() to :doc:`Common
1182 functions <general/common_functions>` to facilitate PHP
1183 version comparisons.
1184 - Added 2 CodeIgniter "cheatsheets" (thanks to DesignFellow.com for
1185 this contribution).
1186
1187Bug fixes for 1.7.2
1188-------------------
1189
1190- Fixed assorted user guide typos or examples (#6743, #7214, #7516,
1191 #7287, #7852, #8224, #8324, #8349).
1192- Fixed a bug in the Form Validation library where multiple callbacks
1193 weren't working (#6110)
1194- doctype helper default value was missing a "1".
1195- Fixed a bug in the language class when outputting an error for an
1196 unfound file.
1197- Fixed a bug in the Calendar library where the shortname was output
1198 for "May".
1199- Fixed a bug with ORIG_PATH_INFO that was allowing URIs of just a
1200 slash through.
1201- Fixed a fatal error in the Oracle and ODBC drivers (#6752)
1202- Fixed a bug where xml_from_result() was checking for a nonexistent
1203 method.
1204- Fixed a bug where Database Forge's add_column and modify_column
1205 were not looping through when sent multiple fields.
1206- Fixed a bug where the File Helper was using '/' instead of the
1207 DIRECTORY_SEPARATOR constant.
1208- Fixed a bug to prevent PHP errors when attempting to use sendmail on
1209 servers that have manually disabled the PHP popen() function.
1210- Fixed a bug that would cause PHP errors in XML-RPC data if the PHP
1211 data type did not match the specified XML-RPC type.
1212- Fixed a bug in the XML-RPC class with parsing dateTime.iso8601 data
1213 types.
1214- Fixed a case sensitive string replacement in xss_clean()
1215- Fixed a bug in form_textarea() where form data was not prepped
1216 correctly.
1217- Fixed a bug in form_prep() causing it to not preserve entities in
1218 the user's original input when called back into a form element
1219- Fixed a bug in _protect_identifiers() where the swap prefix
1220 ($swap_pre) was not being observed.
1221- Fixed a bug where the 400 status header sent with the 'disallowed URI
1222 characters' was not compatible with CGI environments.
1223- Fixed a bug in the typography class where heading tags could have
1224 paragraph tags inserted when using auto_typography().
1225
1226Version 1.7.1
1227=============
1228
1229Release Date: February 10, 2009
1230Hg Tag: 1.7.1
1231
1232- Libraries
1233
1234 - Fixed an arbitrary script execution security flaw (#6068) in the
1235 Form Validation library (thanks to hkk)
1236 - Changed default current page indicator in the Pagination library
1237 to use <strong> instead of <b>
1238 - A "HTTP/1.1 400 Bad Request" header is now sent when disallowed
1239 characters are encountered.
1240 - Added <big>, <small>, <q>, and <tt> to the Typography parser's
1241 inline elements.
1242 - Added more accurate error reporting for the Email library when
1243 using sendmail.
1244 - Removed a strict type check from the rotate() function of the
1245 :doc:`Image Manipulation Class <libraries/image_lib>`.
1246 - Added enhanced error checking in file saving in the Image library
1247 when using the GD lib.
1248 - Added an additional newline between multipart email headers and
1249 the MIME message text for better compatibility with a variety of
1250 MUAs.
1251 - Made modest improvements to efficiency and accuracy of
1252 explode_name() in the Image lib.
1253
1254- Database
1255
1256 - Added where_in to the list of expected arguments received by
1257 delete().
1258
1259- Helpers
1260
1261 - Added the ability to have optgroups in form_dropdown() within the
1262 :doc:`form helper <helpers/form_helper>`.
1263 - Added a doctype() function to the :doc:`HTML
1264 helper <helpers/html_helper>`.
1265 - Added ability to force lowercase for url_title() in the :doc:`URL
1266 helper <helpers/url_helper>`.
1267 - Changed the default "type" of form_button() to "button" from
1268 "submit" in the :doc:`form helper <helpers/form_helper>`.
1269 - Changed redirect() in the URL helper to allow redirections to URLs
1270 outside of the CI site.
1271 - Updated get_cookie() to try to fetch the cookie using the global
1272 cookie prefix if the requested cookie name doesn't exist.
1273
1274- Other Changes
1275
1276 - Improved security in xss_clean() to help prevent attacks
1277 targeting Internet Explorer.
1278 - Added 'application/msexcel' to config/mimes.php for .xls files.
1279 - Added 'proxy_ips' config item to whitelist reverse proxy servers
1280 from which to trust the HTTP_X_FORWARDED_FOR header to to
1281 determine the visitor's IP address.
1282 - Improved accuracy of Upload::is_allowed_filetype() for images
1283 (#6715)
1284
1285Bug fixes for 1.7.1
1286-------------------
1287
1288- Database
1289
1290 - Fixed a bug when doing 'random' on order_by() (#5706).
1291 - Fixed a bug where adding a primary key through Forge could fail
1292 (#5731).
1293 - Fixed a bug when using DB cache on multiple databases (#5737).
1294 - Fixed a bug where TRUNCATE was not considered a "write" query
1295 (#6619).
1296 - Fixed a bug where csv_from_result() was checking for a
1297 nonexistent method.
1298 - Fixed a bug _protect_identifiers() where it was improperly
1299 removing all pipe symbols from items
1300
1301- Fixed assorted user guide typos or examples (#5998, #6093, #6259,
1302 #6339, #6432, #6521).
1303- Fixed a bug in the MySQLi driver when no port is specified
1304- Fixed a bug (#5702), in which the field label was not being fetched
1305 properly, when "matching" one field to another.
1306- Fixed a bug in which identifers were not being escaped properly when
1307 reserved characters were used.
1308- Fixed a bug with the regular expression used to protect submitted
1309 paragraph tags in auto typography.
1310- Fixed a bug where double dashes within tag attributes were being
1311 converted to em dash entities.
1312- Fixed a bug where double spaces within tag attributes were being
1313 converted to non-breaking space entities.
1314- Fixed some accuracy issues with curly quotes in
1315 Typography::format_characters()
1316- Changed a few docblock comments to reflect actual return values.
1317- Fixed a bug with high ascii characters in subject and from email
1318 headers.
1319- Fixed a bug in xss_clean() where whitespace following a validated
1320 character entity would not be preserved.
1321- Fixed a bug where HTML comments and <pre> tags were being parsed in
1322 Typography::auto_typography().
1323- Fixed a bug with non-breaking space cleanup in
1324 Typography::auto_typography().
1325- Fixed a bug in database escaping where a compound statement (ie:
1326 SUM()) wasn't handled correctly with database prefixes.
1327- Fixed a bug when an opening quote is preceded by a paragraph tag and
1328 immediately followed by another tag.
1329- Fixed a bug in the Text Helper affecting some locales where
1330 word_censor() would not work on words beginning or ending with an
1331 accented character.
1332- Fixed a bug in the Text Helper character limiter where the provided
1333 limit intersects the last word of the string.
1334- Fixed a bug (#6342) with plural() in the Inflection helper with words
1335 ending in "y".
1336- Fixed bug (#6517) where Routed URI segments returned by
1337 URI::rsegment() method were incorrect for the default controller.
1338- Fixed a bug (#6706) in the Security Helper where xss_clean() was
1339 using a deprecated second argument.
1340- Fixed a bug in the URL helper url_title() function where trailing
1341 periods were allowed at the end of a URL.
1342- Fixed a bug (#6669) in the Email class when CRLF's are used for the
1343 newline character with headers when used with the "mail" protocol.
1344- Fixed a bug (#6500) where URI::A_filter_uri() was exit()ing an
1345 error instead of using show_error().
1346- Fixed a bug (#6592) in the File Helper where get_dir_file_info()
1347 where recursion was not occurring properly.
1348- Tweaked Typography::auto_typography() for some edge-cases.
1349
1350Version 1.7
1351===========
1352
1353Release Date: October 23, 2008
1354Hg Tag: 1.7.0
1355
1356- Libraries
1357
1358 - Added a new :doc:`Form Validation
1359 Class <libraries/form_validation>`. It simplifies setting
1360 rules and field names, supports arrays as field names, allows
1361 groups of validation rules to be saved in a config file, and adds
1362 some helper functions for use in view files. **Please note that
1363 the old Validation class is now deprecated**. We will leave it in
1364 the library folder for some time so that existing applications
1365 that use it will not break, but you are encouraged to migrate to
1366 the new version.
1367 - Updated the :doc:`Sessions class <libraries/sessions>` so that
1368 any custom data being saved gets stored to a database rather than
1369 the session cookie (assuming you are using a database to store
1370 session data), permitting much more data to be saved.
1371 - Added the ability to store libraries in subdirectories within
1372 either the main "libraries" or the local application "libraries"
1373 folder. Please see the :doc:`Loader class <libraries/loader>` for
1374 more info.
1375 - Added the ability to assign library objects to your own variable
1376 names when you use $this->load->library(). Please see the :doc:`Loader
1377 class <libraries/loader>` for more info.
1378 - Added controller class/method info to :doc:`Profiler
1379 class <general/profiling>` and support for multiple database
1380 connections.
1381 - Improved the "auto typography" feature and moved it out of the
1382 helper into its own :doc:`Typography
1383 Class <libraries/typography>`.
1384 - Improved performance and accuracy of xss_clean(), including
1385 reduction of false positives on image/file tests.
1386 - Improved :doc:`Parser class <./libraries/parser>` to allow
1387 multiple calls to the parse() function. The output of each is
1388 appended in the output.
1389 - Added max_filename option to set a file name length limit in the
1390 :doc:`File Upload Class <libraries/file_uploading>`.
1391 - Added set_status_header() function to :doc:`Output
1392 class <libraries/output>`.
1393 - Modified :doc:`Pagination <libraries/pagination>` class to only
1394 output the "First" link when the link for page one would not be
1395 shown.
1396 - Added support for mb_strlen in the :doc:`Form
1397 Validation <libraries/form_validation>` class so that
1398 multi-byte languages will calculate string lengths properly.
1399
1400- Database
1401
1402 - Improved Active Record class to allow full path column and table
1403 names: hostname.database.table.column. Also improved the alias
1404 handling.
1405 - Improved how table and column names are escaped and prefixed. It
1406 now honors full path names when adding prefixes and escaping.
1407 - Added Active Record caching feature to "update" and "delete"
1408 functions.
1409 - Added removal of non-printing control characters in escape_str()
1410 of DB drivers that do not have native PHP escaping mechanisms
1411 (mssql, oci8, odbc), to avoid potential SQL errors, and possible
1412 sources of SQL injection.
1413 - Added port support to MySQL, MySQLi, and MS SQL database drivers.
1414 - Added driver name variable in each DB driver, based on bug report
1415 #4436.
1416
1417- Helpers
1418
1419 - Added several new "setting" functions to the :doc:`Form
1420 helper <helpers/form_helper>` that allow POST data to be
1421 retrieved and set into forms. These are intended to be used on
1422 their own, or with the new :doc:`Form Validation
1423 Class <libraries/form_validation>`.
1424 - Added current_url() and uri_segments() to :doc:`URL
1425 helper <helpers/url_helper>`.
1426 - Altered auto_link() in the :doc:`URL
1427 helper <helpers/url_helper>` so that email addresses with
1428 "+" included will be linked.
1429 - Added meta() function to :doc:`HTML
1430 helper <helpers/html_helper>`.
1431 - Improved accuracy of calculations in :doc:`Number
1432 helper <helpers/number_helper>`.
1433 - Removed added newlines ("\\n") from most form and html helper
1434 functions.
1435 - Tightened up validation in the :doc:`Date
1436 helper <helpers/date_helper>` function human_to_unix(),
1437 and eliminated the POSIX regex.
1438 - Updated :doc:`Date helper <helpers/date_helper>` to match the
1439 world's current time zones and offsets.
1440 - Modified url_title() in the :doc:`URL
1441 helper <helpers/url_helper>` to remove characters and digits
1442 that are part of character entities, to allow dashes, underscores,
1443 and periods regardless of the $separator, and to allow uppercase
1444 characters.
1445 - Added support for arbitrary attributes in anchor_popup() of the
1446 :doc:`URL helper <helpers/url_helper>`.
1447
1448- Other Changes
1449
1450 - Added :doc:`PHP Style Guide <./general/styleguide>` to docs.
1451 - Added sanitization in xss_clean() for a deprecated HTML tag that
1452 could be abused in user input in Internet Explorer.
1453 - Added a few openxml document mime types, and an additional mobile
1454 agent to mimes.php and user_agents.php respectively.
1455 - Added a file lock check during caching, before trying to write to
1456 the file.
1457 - Modified Cookie key cleaning to unset a few troublesome key names
1458 that can be present in certain environments, preventing CI from
1459 halting execution.
1460 - Changed the output of the profiler to use style attribute rather
1461 than clear, and added the id "codeigniter_profiler" to the
1462 container div.
1463
1464Bug fixes for 1.7.0
1465-------------------
1466
1467- Fixed bug in xss_clean() that could remove some desirable tag
1468 attributes.
1469- Fixed assorted user guide typos or examples (#4807, #4812, #4840,
1470 #4862, #4864, #4899, #4930, #5006, #5071, #5158, #5229, #5254,
1471 #5351).
1472- Fixed an edit from 1.6.3 that made the $robots array in
1473 user_agents.php go poof.
1474- Fixed a bug in the :doc:`Email library <libraries/email>` with
1475 quoted-printable encoding improperly encoding space and tab
1476 characters.
1477- Modified XSS sanitization to no longer add semicolons after &[single
1478 letter], such as in M&M's, B&B, etc.
1479- Modified XSS sanitization to no longer strip XHTML image tags of
1480 closing slashes.
1481- Fixed a bug in the Session class when database sessions are used
1482 where upon session update all userdata would be errantly written to
1483 the session cookie.
1484- Fixed a bug (#4536) in backups with the MySQL driver where some
1485 legacy code was causing certain characters to be double escaped.
1486- Fixed a routing bug (#4661) that occurred when the default route
1487 pointed to a subfolder.
1488- Fixed the spelling of "Dhaka" in the timezone_menu() function of the
1489 :doc:`Date helper. <helpers/date_helper>`
1490- Fixed the spelling of "raspberry" in config/smileys.php.
1491- Fixed incorrect parenthesis in form_open() function (#5135).
1492- Fixed a bug that was ignoring case when comparing controller methods
1493 (#4560).
1494- Fixed a bug (#4615) that was not setting SMTP authorization settings
1495 when using the initialize function.
1496- Fixed a bug in highlight_code() in the :doc:`Text
1497 helper <helpers/text_helper>` that would leave a stray </span>
1498 in certain cases.
1499- Fixed Oracle bug (#3306) that was preventing multiple queries in one
1500 action.
1501- Fixed ODBC bug that was ignoring connection params due to its use of
1502 a constructor.
1503- Fixed a DB driver bug with num_rows() that would cause an error with
1504 the Oracle driver.
1505- Fixed MS SQL bug (#4915). Added brackets around database name in MS
1506 SQL driver when selecting the database, in the event that reserved
1507 characters are used in the name.
1508- Fixed a DB caching bug (4718) in which the path was incorrect when no
1509 URI segments were present.
1510- Fixed Image_lib class bug #4562. A path was not defined for NetPBM.
1511- Fixed Image_lib class bug #4532. When cropping an image with
1512 identical height/width settings on output, a copy is made.
1513- Fixed DB_driver bug (4900), in which a database error was not being
1514 logged correctly.
1515- Fixed DB backup bug in which field names were not being escaped.
1516- Fixed a DB Active Record caching bug in which multiple calls to
1517 cached data were not being honored.
1518- Fixed a bug in the Session class that was disallowing slashes in the
1519 serialized array.
1520- Fixed a Form Validation bug in which the "isset" error message was
1521 being trigged by the "required" rule.
1522- Fixed a spelling error in a Loader error message.
1523- Fixed a bug (5050) with IP validation with empty segments.
1524- Fixed a bug in which the parser was being greedy if multiple
1525 identical sets of tags were encountered.
1526
1527Version 1.6.3
1528=============
1529
1530Release Date: June 26, 2008
1531Hg Tag: v1.6.3
1532
1533Version 1.6.3 is a security and maintenance release and is recommended
1534for all users.
1535
1536- Database
1537
1538 - Modified MySQL/MySQLi Forge class to give explicit names to keys
1539 - Added ability to set multiple column non-primary keys to the
1540 :doc:`Forge class <database/forge>`
1541 - Added ability to set additional database config values in :doc:`DSN
1542 connections <database/connecting>` via the query string.
1543
1544- Libraries
1545
1546 - Set the mime type check in the :doc:`Upload
1547 class <libraries/file_uploading>` to reference the global
1548 mimes variable.
1549 - Added support for query strings to the :doc:`Pagination
1550 class <libraries/pagination>`, automatically detected or
1551 explicitly declared.
1552 - Added get_post() to the :doc:`Input class <libraries/input>`.
1553 - Documented get() in the :doc:`Input class <libraries/input>`.
1554 - Added the ability to automatically output language items as form
1555 labels in the :doc:`Language class <libraries/language>`.
1556
1557- Helpers
1558
1559 - Added a :doc:`Language helper <helpers/language_helper>`.
1560 - Added a :doc:`Number helper <helpers/number_helper>`.
1561 - :doc:`Form helper <helpers/form_helper>` refactored to allow
1562 form_open() and form_fieldset() to accept arrays or strings as
1563 arguments.
1564
1565- Other changes
1566
1567 - Improved security in xss_clean().
1568 - Removed an unused Router reference in _display_cache().
1569 - Added ability to :doc:`use xss_clean() to test
1570 images <libraries/input>` for XSS, useful for upload
1571 security.
1572 - Considerably expanded list of mobile user-agents in
1573 config/user_agents.php.
1574 - Charset information in the userguide has been moved above title
1575 for internationalization purposes (#4614).
1576 - Added "Using Associative Arrays In a Request Parameter" example to
1577 the :doc:`XMLRPC userguide page <libraries/xmlrpc>`.
1578 - Removed maxlength and size as automatically added attributes of
1579 form_input() in the :doc:`form helper <helpers/form_helper>`.
1580 - Documented the language file use of byte_format() in the :doc:`number
1581 helper <helpers/number_helper>`.
1582
1583Bug fixes for 1.6.3
1584-------------------
1585
1586- Added a language key for valid_emails in validation_lang.php.
1587- Amended fixes for bug (#3419) with parsing DSN database connections.
Andrey Andreev968bbbb2012-03-26 12:59:05 +03001588- Moved the _has_operator() function (#4535) into DB_driver from
Derek Jones8ede1a22011-10-05 13:34:52 -05001589 DB_active_rec.
1590- Fixed a syntax error in upload_lang.php.
1591- Fixed a bug (#4542) with a regular expression in the Image library.
1592- Fixed a bug (#4561) where orhaving() wasn't properly passing values.
1593- Removed some unused variables from the code (#4563).
1594- Fixed a bug where having() was not adding an = into the statement
1595 (#4568).
1596- Fixed assorted user guide typos or examples (#4574, #4706).
1597- Added quoted-printable headers to Email class when the multi-part
1598 override is used.
1599- Fixed a double opening <p> tag in the index pages of each system
1600 directory.
1601
1602Version 1.6.2
1603=============
1604
1605Release Date: May 13, 2008
1606Hg Tag: 1.6.2
1607
1608- Active Record
1609
1610 - Added the ability to prevent escaping in having() clauses.
1611 - Added rename_table() into :doc:`DBForge <./database/forge>`.
1612 - Fixed a bug that wasn't allowing escaping to be turned off if the
1613 value of a query was NULL.
1614 - DB Forge is now assigned to any models that exist after loading
1615 (#3457).
1616
1617- Database
1618
1619 - Added :doc:`Strict Mode <./database/transactions>` to database
1620 transactions.
1621 - Escape behaviour in where() clauses has changed; values in those
1622 with the "FALSE" argument are no longer escaped (ie: quoted).
1623
1624- Config
1625
1626 - Added 'application/vnd.ms-powerpoint' to list of mime types.
1627 - Added 'audio/mpg' to list of mime types.
1628 - Added new user-modifiable file constants.php containing file mode
1629 and fopen constants.
1630 - Added the ability to set CRLF settings via config in the
1631 :doc:`Email <libraries/email>` class.
1632
1633- Libraries
1634
1635 - Added increased security for filename handling in the Upload
1636 library.
1637 - Added increased security for sessions for client-side data
1638 tampering.
1639 - The MySQLi forge class is now in sync with MySQL forge.
1640 - Added the ability to set CRLF settings via config in the
1641 :doc:`Email <libraries/email>` class.
1642 - :doc:`Unit Testing <libraries/unit_testing>` results are now
1643 colour coded, and a change was made to the default template of
1644 results.
1645 - Added a valid_emails rule to the Validation class.
1646 - The :doc:`Zip class <libraries/zip>` now exits within download().
1647 - The :doc:`Zip class <libraries/zip>` has undergone a substantial
1648 re-write for speed and clarity (thanks stanleyxu for the hard work
1649 and code contribution in bug report #3425!)
1650
1651- Helpers
1652
1653 - Added a Compatibility
1654 Helper for using some common
1655 PHP 5 functions safely in applications that might run on PHP 4
1656 servers (thanks Seppo for the hard work and code contribution!)
1657 - Added form_button() in the :doc:`Form
1658 helper <helpers/form_helper>`.
1659 - Changed the radio() and checkbox() functions to default to not
1660 checked by default.
1661 - Added the ability to include an optional HTTP Response Code in the
1662 redirect() function of the :doc:`URL
1663 Helper <helpers/url_helper>`.
1664 - Modified img() in the :doc:`HTML Helper <helpers/html_helper>` to
1665 remove an unneeded space (#4208).
1666 - Modified anchor() in the :doc:`URL helper <helpers/url_helper>`
1667 to no longer add a default title= attribute (#4209).
1668 - The :doc:`Download helper <helpers/download_helper>` now exits
1669 within force_download().
1670 - Added get_dir_file_info(), get_file_info(), and
1671 get_mime_by_extension() to the :doc:`File
1672 Helper <helpers/file_helper>`.
1673 - Added symbolic_permissions() and octal_permissions() to the
1674 :doc:`File helper <helpers/file_helper>`.
1675
1676- Plugins
1677
1678 - Modified captcha generation to first look for the function
1679 imagecreatetruecolor, and fallback to imagecreate if it isn't
1680 available (#4226).
1681
1682- Other Changes
1683
1684 - Added ability for :doc:`xss_clean() <libraries/input>` to accept
1685 arrays.
1686 - Removed closing PHP tags from all PHP files to avoid accidental
1687 output and potential 'cannot modify headers' errors.
1688 - Removed "scripts" from the auto-load search path. Scripts were
1689 deprecated in Version 1.4.1 (September 21, 2006). If you still
1690 need to use them for legacy reasons, they must now be manually
1691 loaded in each Controller.
1692 - Added a :doc:`Reserved Names <general/reserved_names>` page to
1693 the userguide, and migrated reserved controller names into it.
1694 - Added a :doc:`Common Functions <general/common_functions>` page
1695 to the userguide for globally available functions.
1696 - Improved security and performance of xss_clean().
1697
1698Bugfixes for 1.6.2
1699------------------
1700
1701- Fixed a bug where SET queries were not being handled as "write"
1702 queries.
1703- Fixed a bug (#3191) with ORIG_PATH_INFO URI parsing.
1704- Fixed a bug in DB Forge, when inserting an id field (#3456).
1705- Fixed a bug in the table library that could cause identically
1706 constructed rows to be dropped (#3459).
1707- Fixed DB Driver and MySQLi result driver checking for resources
1708 instead of objects (#3461).
1709- Fixed an AR_caching error where it wasn't tracking table aliases
1710 (#3463).
1711- Fixed a bug in AR compiling, where select statements with arguments
1712 got incorrectly escaped (#3478).
1713- Fixed an incorrect documentation of $this->load->language (#3520).
1714- Fixed bugs (#3523, #4350) in get_filenames() with recursion and
1715 problems with Windows when $include_path is used.
1716- Fixed a bug (#4153) in the XML-RPC class preventing dateTime.iso8601
1717 from being used.
1718- Fixed an AR bug with or_where_not_in() (#4171).
1719- Fixed a bug with :doc:`xss_clean() <libraries/input>` that would
1720 add semicolons to GET URI variable strings.
1721- Fixed a bug (#4206) in the Directory Helper where the directory
1722 resource was not being closed, and minor improvements.
1723- Fixed a bug in the FTP library where delete_dir() was not working
1724 recursively (#4215).
1725- Fixed a Validation bug when set_rules() is used with a non-array
1726 field name and rule (#4220).
1727- Fixed a bug (#4223) where DB caching would not work for returned DB
1728 objects or multiple DB connections.
1729- Fixed a bug in the Upload library that might output the same error
1730 twice (#4390).
1731- Fixed an AR bug when joining with a table alias and table prefix
1732 (#4400).
1733- Fixed a bug in the DB class testing the $params argument.
1734- Fixed a bug in the Table library where the integer 0 in cell data
1735 would be displayed as a blank cell.
1736- Fixed a bug in link_tag() of the :doc:`URL
1737 helper <helpers/url_helper>` where a key was passed instead of
1738 a value.
1739- Fixed a bug in DB_result::row() that prevented it from returning
1740 individual fields with MySQL NULL values.
1741- Fixed a bug where SMTP emails were not having dot transformation
1742 performed on lines that begin with a dot.
1743- Fixed a bug in display_error() in the DB driver that was
1744 instantiating new Language and Exception objects, and not using the
1745 error heading.
1746- Fixed a bug (#4413) where a URI containing slashes only e.g.
1747 'http://example.com/index.php?//' would result in PHP errors
1748- Fixed an array to string conversion error in the Validation library
1749 (#4425)
1750- Fixed bug (#4451, #4299, #4339) where failed transactions will not
1751 rollback when debug mode is enabled.
1752- Fixed a bug (#4506) with overlay_watermark() in the Image library
1753 preventing support for PNG-24s with alpha transparency
1754- Fixed assorted user guide typos (#3453, #4364, #4379, #4399, #4408,
1755 #4412, #4448, #4488).
1756
1757Version 1.6.1
1758=============
1759
1760Release Date: February 12, 2008
1761Hg Tag: 1.6.1
1762
1763- Active Record
1764
1765 - Added :ref:`Active Record
1766 Caching <ar-caching>`.
1767 - Made Active Record fully database-prefix aware.
1768
1769- Database drivers
1770
1771 - Added support for setting client character set and collation for
1772 MySQLi.
1773
1774- Core Changes
1775
1776 - Modified xss_clean() to be more intelligent with its handling of
1777 URL encoded strings.
1778 - Added $_SERVER, $_FILES, $_ENV, and $_SESSION to sanitization
1779 of globals.
kenjis087a7a82011-10-20 20:08:47 +09001780 - Added a :doc:`Path Helper <./helpers/path_helper>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001781 - Simplified _reindex_segments() in the URI class.
1782 - Escaped the '-' in the default 'permitted_uri_chars' config
1783 item, to prevent errors if developers just try to add additional
1784 characters to the end of the default expression.
1785 - Modified method calling to controllers to show a 404 when a
1786 private or protected method is accessed via a URL.
1787 - Modified framework initiated 404s to log the controller and method
1788 for invalid requests.
1789
1790- Helpers
1791
1792 - Modified get_filenames() in the File Helper to return FALSE if
1793 the $source_dir is not readable.
1794
1795Bugfixes for 1.6.1
1796------------------
1797
1798- Deprecated is_numeric as a validation rule. Use of numeric and
1799 integer are preferred.
1800- Fixed bug (#3379) in DBForge with SQLite for table creation.
1801- Made Active Record fully database prefix aware (#3384).
1802- Fixed a bug where DBForge was outputting invalid SQL in Postgres by
1803 adding brackets around the tables in FROM.
1804- Changed the behaviour of Active Record's update() to make the WHERE
1805 clause optional (#3395).
1806- Fixed a bug (#3396) where certain POST variables would cause a PHP
1807 warning.
1808- Fixed a bug in query binding (#3402).
1809- Changed order of SQL keywords in the Profiler $highlight array so OR
1810 would not be highlighted before ORDER BY.
1811- Fixed a bug (#3404) where the MySQLi driver was testing if
1812 $this->conn_id was a resource instead of an object.
1813- Fixed a bug (#3419) connecting to a database via a DSN string.
1814- Fixed a bug (#3445) where the routed segment array was not re-indexed
1815 to begin with 1 when the default controller is used.
1816- Fixed assorted user guide typos.
1817
1818Version 1.6.0
1819=============
1820
1821Release Date: January 30, 2008
1822
1823- DBForge
1824
1825 - Added :doc:`DBForge <./database/forge>` to the database tools.
1826 - Moved create_database() and drop_database() into
1827 :doc:`DBForge <./database/forge>`.
1828 - Added add_field(), add_key(), create_table(), drop_table(),
1829 add_column(), drop_column(), modify_column() into
1830 :doc:`DBForge <./database/forge>`.
1831
1832- Active Record
1833
1834 - Added protect_identifiers() in :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001835 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001836 - All AR queries are backticked if appropriate to the database.
1837 - Added where_in(), or_where_in(), where_not_in(),
1838 or_where_not_in(), not_like() and or_not_like() to :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001839 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001840 - Added support for limit() into update() and delete() statements in
Derek Jonesce79be02012-06-25 23:23:46 -07001841 :doc:`Active Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001842 - Added empty_table() and truncate_table() to :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001843 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001844 - Added the ability to pass an array of tables to the delete()
Derek Jonesce79be02012-06-25 23:23:46 -07001845 statement in :doc:`Active Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001846 - Added count_all_results() function to :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001847 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001848 - Added select_max(), select_min(), select_avg() and
Derek Jonesce79be02012-06-25 23:23:46 -07001849 select_sum() to :doc:`Active Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001850 - Added the ability to use aliases with joins in :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001851 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001852 - Added a third parameter to Active Record's like() clause to
1853 control where the wildcard goes.
1854 - Added a third parameter to set() in :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001855 Record <./database/query_builder>` that withholds escaping
Derek Jones8ede1a22011-10-05 13:34:52 -05001856 data.
1857 - Changed the behaviour of variables submitted to the where() clause
1858 with no values to auto set "IS NULL"
1859
1860- Other Database Related
1861
1862 - MySQL driver now requires MySQL 4.1+
1863 - Added $this->DB->save_queries variable to DB driver, enabling
1864 queries to get saved or not. Previously they were always saved.
1865 - Added $this->db->dbprefix() to manually add database prefixes.
1866 - Added 'random' as an order_by() option , and removed "rand()" as
1867 a listed option as it was MySQL only.
1868 - Added a check for NULL fields in the MySQL database backup
1869 utility.
1870 - Added "constrain_by_prefix" parameter to db->list_table()
1871 function. If set to TRUE it will limit the result to only table
1872 names with the current prefix.
1873 - Deprecated from Active Record; getwhere() for get_where();
1874 groupby() for group_by(); havingor() for having_or(); orderby()
1875 for order_by; orwhere() for or_where(); and orlike() for
1876 or_like().
1877 - Modified csv_from_result() to output CSV data more in the spirit
1878 of basic rules of RFC 4180.
1879 - Added 'char_set' and 'dbcollat' database configuration settings,
1880 to explicitly set the client communication properly.
1881 - Removed 'active_r' configuration setting and replaced with a
1882 global $active_record setting, which is more in harmony with the
1883 global nature of the behavior (#1834).
1884
1885- Core changes
1886
1887 - Added ability to load multiple views, whose content will be
1888 appended to the output in the order loaded.
1889 - Added the ability to :doc:`auto-load <./general/autoloader>`
1890 :doc:`Models <./general/models>`.
1891 - Reorganized the URI and Routes classes for better clarity.
1892 - Added Compat.php to allow function overrides for older versions of
1893 PHP or PHP environments missing certain extensions / libraries
1894 - Added memory usage, GET, URI string data, and individual query
1895 execution time to Profiler output.
1896 - Deprecated Scaffolding.
1897 - Added is_really_writable() to Common.php to provide a
1898 cross-platform reliable method of testing file/folder writability.
1899
1900- Libraries
1901
1902 - Changed the load protocol of Models to allow for extension.
1903 - Strengthened the Encryption library to help protect against man in
1904 the middle attacks when MCRYPT_MODE_CBC mode is used.
1905 - Added Flashdata variables, session_id regeneration and
1906 configurable session update times to the :doc:`Session
1907 class. <./libraries/sessions>`
1908 - Removed 'last_visit' from the Session class.
1909 - Added a language entry for valid_ip validation error.
1910 - Modified prep_for_form() in the Validation class to accept
1911 arrays, adding support for POST array validation (via callbacks
1912 only)
1913 - Added an "integer" rule into the Validation library.
1914 - Added valid_base64() to the Validation library.
1915 - Documented clear() in the :doc:`Image
1916 Processing <../libraries/image_lib>` library.
1917 - Changed the behaviour of custom callbacks so that they no longer
1918 trigger the "required" rule.
1919 - Modified Upload class $_FILES error messages to be more precise.
1920 - Moved the safe mode and auth checks for the Email library into the
1921 constructor.
1922 - Modified variable names in _ci_load() method of Loader class to
1923 avoid conflicts with view variables.
1924 - Added a few additional mime type variations for CSV.
1925 - Enabled the 'system' methods for the XML-RPC Server library,
1926 except for 'system.multicall' which is still disabled.
1927
1928- Helpers & Plugins
1929
1930 - Added link_tag() to the :doc:`HTML
1931 helper. <./helpers/html_helper>`
1932 - Added img() to the :doc:`HTML helper. <./helpers/html_helper>`
1933 - Added ability to :doc:`"extend" Helpers <./general/helpers>`.
1934 - Added an :doc:`email helper <./helpers/email_helper>` into core
1935 helpers.
1936 - Added strip_quotes() function to :doc:`string
1937 helper <./helpers/string_helper>`.
1938 - Added reduce_multiples() function to :doc:`string
1939 helper <./helpers/string_helper>`.
1940 - Added quotes_to_entities() function to :doc:`string
1941 helper <./helpers/string_helper>`.
1942 - Added form_fieldset(), form_fieldset_close(), form_label(),
1943 and form_reset() function to :doc:`form
1944 helper <./helpers/form_helper>`.
1945 - Added support for external urls in form_open().
1946 - Removed support for db_backup in MySQLi due to incompatible
1947 functions.
1948 - Javascript Calendar plugin now uses the months and days from the
1949 calendar language file, instead of hard-coded values,
1950 internationalizing it.
1951
1952- Documentation Changes
1953
1954 - Added Writing Documentation section
1955 for the community to use in writing their own documentation.
1956 - Added titles to all user manual pages.
1957 - Added attributes into <html> of userguide for valid html.
1958 - Added `Zip Encoding
1959 Class <http://codeigniter.com/user_guide/libraries/zip>`_ to
1960 the table of contents of the userguide.
1961 - Moved part of the userguide menu javascript to an external file.
1962 - Documented distinct() in :doc:`Active
Derek Jonesce79be02012-06-25 23:23:46 -07001963 Record <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05001964 - Documented the timezones() function in the :doc:`Date
1965 Helper <./helpers/date_helper>`.
1966 - Documented unset_userdata in the :doc:`Session
1967 class <./libraries/sessions>`.
1968 - Documented 2 config options to the :doc:`Database
1969 configuration <./database/configuration>` page.
1970
1971Bug fixes for Version 1.6.0
1972---------------------------
1973
1974- Fixed a bug (#1813) preventing using $CI->db in the same application
1975 with returned database objects.
1976- Fixed a bug (#1842) where the $this->uri->rsegments array would not
1977 include the 'index' method if routed to the controller without an
1978 implicit method.
1979- Fixed a bug (#1872) where word_limiter() was not retaining
1980 whitespace.
1981- Fixed a bug (#1890) in csv_from_result() where content that
1982 included the delimiter would break the file.
1983- Fixed a bug (#2542)in the clean_email() method of the Email class to
1984 allow for non-numeric / non-sequential array keys.
1985- Fixed a bug (#2545) in _html_entity_decode_callback() when
1986 'global_xss_filtering' is enabled.
1987- Fixed a bug (#2668) in the :doc:`parser class <./libraries/parser>`
1988 where numeric data was ignored.
1989- Fixed a bug (#2679) where the "previous" pagination link would get
1990 drawn on the first page.
1991- Fixed a bug (#2702) in _object_to_array that broke some types of
1992 inserts and updates.
1993- Fixed a bug (#2732) in the SQLite driver for PHP 4.
1994- Fixed a bug (#2754) in Pagination to scan for non-positive
1995 num_links.
1996- Fixed a bug (#2762) in the :doc:`Session
1997 library <./libraries/sessions>` where user agent matching would
1998 fail on user agents ending with a space.
1999- Fixed a bug (#2784) $field_names[] vs $Ffield_names[] in postgres
2000 and sqlite drivers.
2001- Fixed a bug (#2810) in the typography helper causing extraneous
2002 paragraph tags when string contains tags.
2003- Fixed a bug (#2849) where arguments passed to a subfolder controller
2004 method would be incorrectly shifted, dropping the 3rd segment value.
2005- Fixed a bug (#2858) which referenced a wrong variable in the Image
2006 class.
2007- Fixed a bug (#2875)when loading plugin files as _plugin. and not
2008 _pi.
2009- Fixed a bug (#2912) in get_filenames() in the :doc:`File
2010 Helper <helpers/file_helper>` where the array wasn't cleared
2011 after each call.
2012- Fixed a bug (#2974) in highlight_phrase() that caused an error with
2013 slashes.
2014- Fixed a bug (#3003) in the Encryption Library to support modes other
2015 than MCRYPT_MODE_ECB
2016- Fixed a bug (#3015) in the :doc:`User Agent
2017 library <./libraries/user_agent>` where more then 2 languages
2018 where not reported with languages().
2019- Fixed a bug (#3017) in the :doc:`Email <./libraries/email>` library
2020 where some timezones were calculated incorrectly.
2021- Fixed a bug (#3024) in which master_dim wasn't getting reset by
2022 clear() in the Image library.
2023- Fixed a bug (#3156) in Text Helper highlight_code() causing PHP tags
2024 to be handled incorrectly.
2025- Fixed a bug (#3166) that prevented num_rows from working in Oracle.
2026- Fixed a bug (#3175) preventing certain libraries from working
2027 properly when autoloaded in PHP 4.
2028- Fixed a bug (#3267) in the Typography Helper where unordered list was
2029 listed "un.
2030- Fixed a bug (#3268) where the Router could leave '/' as the path.
2031- Fixed a bug (#3279) where the Email class was sending the wrong
2032 Content-Transfer-Encoding for some character sets.
2033- Fixed a bug (#3284) where the rsegment array would not be set
2034 properly if the requested URI contained more segments than the routed
2035 URI.
2036- Removed extraneous load of $CFG in _display_cache() of the Output
2037 class (#3285).
2038- Removed an extraneous call to loading models (#3286).
2039- Fixed a bug (#3310) with sanitization of globals in the Input class
2040 that could unset CI's global variables.
2041- Fixed a bug (#3314) which would cause the top level path to be
2042 deleted in delete_files() of the File helper.
2043- Fixed a bug (#3328) where the smiley helper might return an undefined
2044 variable.
2045- Fixed a bug (#3330) in the FTP class where a comparison wasn't
2046 getting made.
2047- Removed an unused parameter from Profiler (#3332).
2048- Fixed a bug in database driver where num_rows property wasn't
2049 getting updated.
2050- Fixed a bug in the :doc:`upload
2051 library <./libraries/file_uploading>` when allowed_files
2052 wasn't defined.
2053- Fixed a bug in word_wrap() of the Text Helper that incorrectly
2054 referenced an object.
2055- Fixed a bug in Validation where valid_ip() wasn't called properly.
2056- Fixed a bug in Validation where individual error messages for
2057 checkboxes wasn't supported.
2058- Fixed a bug in captcha calling an invalid PHP function.
2059- Fixed a bug in the cookie helper "set_cookie" function. It was not
2060 honoring the config settings.
2061- Fixed a bug that was making validation callbacks required even when
2062 not set as such.
2063- Fixed a bug in the XML-RPC library so if a type is specified, a more
2064 intelligent decision is made as to the default type.
2065- Fixed an example of comma-separated emails in the email library
2066 documentation.
2067- Fixed an example in the Calendar library for Showing Next/Previous
2068 Month Links.
2069- Fixed a typo in the database language file.
2070- Fixed a typo in the image language file "suppor" to "support".
2071- Fixed an example for XML RPC.
2072- Fixed an example of accept_charset() in the :doc:`User Agent
2073 Library <./libraries/user_agent>`.
2074- Fixed a typo in the docblock comments that had CodeIgniter spelled
2075 CodeIgnitor.
2076- Fixed a typo in the :doc:`String Helper <./helpers/string_helper>`
2077 (uniquid changed to uniqid).
2078- Fixed typos in the email Language class
2079 (email_attachment_unredable, email_filed_smtp_login), and FTP
2080 Class (ftp_unable_to_remame).
2081- Added a stripslashes() into the Upload Library.
2082- Fixed a series of grammatical and spelling errors in the language
2083 files.
2084- Fixed assorted user guide typos.
2085
2086Version 1.5.4
2087=============
2088
2089Release Date: July 12, 2007
2090
2091- Added :doc:`custom Language files <./libraries/language>` to the
2092 :doc:`autoload <./general/autoloader>` options.
2093- Added stripslashes() to the _clean_input_data() function in the
2094 :doc:`Input class <./libraries/input>` when magic quotes is on so
2095 that data will always be un-slashed within the framework.
2096- Added array to string into the :doc:`profiler <general/profiling>`.
2097- Added some additional mime types in application/config/mimes.php.
2098- Added filename_security() method to :doc:`Input
2099 library <./libraries/input>`.
2100- Added some additional arguments to the :doc:`Inflection
2101 helper <./helpers/inflector_helper>` singular() to compensate
2102 for words ending in "s". Also added a force parameter to pluralize().
2103- Added $config['charset'] to the config file. Default value is
2104 'UTF-8', used in some string handling functions.
2105- Fixed MSSQL insert_id().
2106- Fixed a logic error in the DB trans_status() function. It was
2107 incorrectly returning TRUE on failure and FALSE on success.
2108- Fixed a bug that was allowing multiple load attempts on extended
2109 classes.
2110- Fixed a bug in the bootstrap file that was incorrectly attempting to
2111 discern the full server path even when it was explicity set by the
2112 user.
2113- Fixed a bug in the escape_str() function in the MySQL driver.
2114- Fixed a typo in the :doc:`Calendar library <./libraries/calendar>`
2115- Fixed a typo in rpcs.php library
2116- Fixed a bug in the :doc:`Zip library <./libraries/zip>`, providing
2117 PC Zip file compatibility with Mac OS X
2118- Fixed a bug in router that was ignoring the scaffolding route for
2119 optimization
2120- Fixed an IP validation bug.
2121- Fixed a bug in display of POST keys in the
2122 :doc:`Profiler <./general/profiling>` output
2123- Fixed a bug in display of queries with characters that would be
2124 interpreted as HTML in the :doc:`Profiler <./general/profiling>`
2125 output
2126- Fixed a bug in display of Email class print debugger with characters
2127 that would be interpreted as HTML in the debugging output
2128- Fixed a bug in the Content-Transfer-Encoding of HTML emails with the
2129 quoted-printable MIME type
2130- Fixed a bug where one could unset certain PHP superglobals by setting
2131 them via GET or POST data
2132- Fixed an undefined function error in the insert_id() function of the
2133 PostgreSQL driver
2134- Fixed various doc typos.
2135- Documented two functions from the :doc:`String
2136 helper <./helpers/string_helper>` that were missing from the
2137 user guide: trim_slashes() and reduce_double_slashes().
2138- Docs now validate to XHTML 1 transitional
2139- Updated the XSS Filtering to take into account the IE expression()
2140 ability and improved certain deletions to prevent possible exploits
2141- Modified the Router so that when Query Strings are Enabled, the
2142 controller trigger and function trigger values are sanitized for
2143 filename include security.
2144- Modified the is_image() method in the Upload library to take into
2145 account Windows IE 6/7 eccentricities when dealing with MIMEs
2146- Modified XSS Cleaning routine to be more performance friendly and
2147 compatible with PHP 5.2's new PCRE backtrack and recursion limits.
2148- Modified the :doc:`URL Helper <./helpers/url_helper>` to type cast
2149 the $title as a string in case a numeric value is supplied
2150- Modified Form Helper form_dropdown() to type cast the keys and
2151 values of the options array as strings, allowing numeric values to be
2152 properly set as 'selected'
2153- Deprecated the use if is_numeric() in various places since it allows
2154 periods. Due to compatibility problems with ctype_digit(), making it
2155 unreliable in some installations, the following regular expression
2156 was used instead: preg_match("/[^0-9]/", $n)
2157- Deprecated: APPVER has been deprecated and replaced with CI_VERSION
2158 for clarity.
2159
2160Version 1.5.3
2161=============
2162
2163Release Date: April 15, 2007
2164
2165- Added array to string into the profiler
2166- Code Igniter references updated to CodeIgniter
2167- pMachine references updated to EllisLab
2168- Fixed a bug in the repeater function of :doc:`string
2169 helper <./helpers/string_helper>`.
2170- Fixed a bug in ODBC driver
2171- Fixed a bug in result_array() that was returning an empty array when
2172 no result is produced.
2173- Fixed a bug in the redirect function of the :doc:`url
2174 helper <./helpers/url_helper>`.
2175- Fixed an undefined variable in Loader
2176- Fixed a version bug in the Postgres driver
2177- Fixed a bug in the textarea function of the form helper for use with
2178 strings
2179- Fixed doc typos.
2180
2181Version 1.5.2
2182=============
2183
2184Release Date: February 13, 2007
2185
2186- Added subversion information
kenjis087a7a82011-10-20 20:08:47 +09002187 to the :doc:`downloads <installation/downloads>` page.
Derek Jones8ede1a22011-10-05 13:34:52 -05002188- Added support for captions in the :doc:`Table
2189 Library <./libraries/table>`
2190- Fixed a bug in the
2191 :doc:`download_helper <helpers/download_helper>` that was causing
2192 Internet Explorer to load rather than download
2193- Fixed a bug in the Active Record Join function that was not taking
2194 table prefixes into consideration.
2195- Removed unescaped variables in error messages of Input and Router
2196 classes
2197- Fixed a bug in the Loader that was causing errors on Libraries loaded
2198 twice. A debug message is now silently made in the log.
2199- Fixed a bug in the :doc:`form helper <helpers/form_helper>` that
2200 gave textarea a value attribute
2201- Fixed a bug in the :doc:`Image Library <libraries/image_lib>` that
2202 was ignoring resizing the same size image
2203- Fixed some doc typos.
2204
2205Version 1.5.1
2206=============
2207
2208Release Date: November 23, 2006
2209
2210- Added support for submitting arrays of libraries in the
2211 $this->load->library function.
2212- Added support for naming custom library files in lower or uppercase.
2213- Fixed a bug related to output buffering.
2214- Fixed a bug in the active record class that was not resetting query
2215 data after a completed query.
2216- Fixed a bug that was suppressing errors in controllers.
2217- Fixed a problem that can cause a loop to occur when the config file
2218 is missing.
2219- Fixed a bug that occurred when multiple models were loaded with the
2220 third parameter set to TRUE.
2221- Fixed an oversight that was not unsetting globals properly in the
2222 input sanitize function.
2223- Fixed some bugs in the Oracle DB driver.
2224- Fixed an incorrectly named variable in the MySQLi result driver.
2225- Fixed some doc typos.
2226
2227Version 1.5.0.1
2228===============
2229
2230Release Date: October 31, 2006
2231
2232- Fixed a problem in which duplicate attempts to load helpers and
2233 classes were not being stopped.
2234- Fixed a bug in the word_wrap() helper function.
2235- Fixed an invalid color Hex number in the Profiler class.
2236- Fixed a corrupted image in the user guide.
2237
2238Version 1.5.0
2239=============
2240
2241Release Date: October 30, 2006
2242
kenjis087a7a82011-10-20 20:08:47 +09002243- Added :doc:`DB utility class <./database/utilities>`, permitting DB
Derek Jones8ede1a22011-10-05 13:34:52 -05002244 backups, CVS or XML files from DB results, and various other
2245 functions.
2246- Added :doc:`Database Caching Class <./database/caching>`.
2247- Added :doc:`transaction support <./database/transactions>` to the
2248 database classes.
2249- Added :doc:`Profiler Class <./general/profiling>` which generates a
2250 report of Benchmark execution times, queries, and POST data at the
2251 bottom of your pages.
2252- Added :doc:`User Agent Library <./libraries/user_agent>` which
2253 allows browsers, robots, and mobile devises to be identified.
2254- Added :doc:`HTML Table Class <./libraries/table>` , enabling tables
2255 to be generated from arrays or database results.
2256- Added :doc:`Zip Encoding Library <./libraries/zip>`.
2257- Added :doc:`FTP Library <./libraries/ftp>`.
2258- Added the ability to :doc:`extend
2259 libraries <./general/creating_libraries>` and :doc:`extend core
2260 classes <./general/core_classes>`, in addition to being able to
2261 replace them.
2262- Added support for storing :doc:`models within
2263 sub-folders <./general/models>`.
2264- Added :doc:`Download Helper <./helpers/download_helper>`.
2265- Added :doc:`simple_query() <./database/queries>` function to the
2266 database classes
2267- Added :doc:`standard_date() <./helpers/date_helper>` function to
2268 the Date Helper.
2269- Added :doc:`$query->free_result() <./database/results>` to database
2270 class.
2271- Added :doc:`$query->list_fields() <./database/fields>` function to
2272 database class
2273- Added :doc:`$this->db->platform() <./database/helpers>` function
2274- Added new :doc:`File Helper <./helpers/file_helper>`:
2275 get_filenames()
2276- Added new helper: :doc:`Smiley Helper <./helpers/smiley_helper>`
2277- Added support for <ul> and <ol> lists in the :doc:`HTML
2278 Helper <./helpers/html_helper>`
2279- Added the ability to rewrite :doc:`short
2280 tags <./general/alternative_php>` on-the-fly, converting them
2281 to standard PHP statements, for those servers that do not support
2282 short tags. This allows the cleaner syntax to be used regardless of
2283 whether it's supported by the server.
2284- Added the ability to :doc:`rename or relocate the "application"
2285 folder <./general/managing_apps>`.
2286- Added more thorough initialization in the upload class so that all
2287 class variables are reset.
2288- Added "is_numeric" to validation, which uses the native PHP
2289 is_numeric function.
2290- Improved the URI handler to make it more reliable when the
2291 $config['uri_protocol'] item is set to AUTO.
2292- Moved most of the functions in the Controller class into the Loader
2293 class, allowing fewer reserved function names for controllers when
2294 running under PHP 5.
2295- Updated the DB Result class to return an empty array when
2296 $query->result() doesn't produce a result.
2297- Updated the input->cookie() and input->post() functions in :doc:`Input
2298 Class <./libraries/input>` to permit arrays contained cookies
2299 that are arrays to be run through the XSS filter.
2300- Documented three functions from the Validation
2301 class that were missing from the user
2302 guide: set_select(), set_radio(), and set_checkbox().
2303- Fixed a bug in the Email class related to SMTP Helo data.
2304- Fixed a bug in the word wrapping helper and function in the email
2305 class.
2306- Fixed a bug in the validation class.
2307- Fixed a bug in the typography helper that was incorrectly wrapping
2308 block level elements in paragraph tags.
2309- Fixed a problem in the form_prep() function that was double encoding
2310 entities.
2311- Fixed a bug that affects some versions of PHP when output buffering
2312 is nested.
2313- Fixed a bug that caused CI to stop working when the PHP magic
2314 __get() or __set() functions were used within models or
2315 controllers.
2316- Fixed a pagination bug that was permitting negative values in the
2317 URL.
2318- Fixed an oversight in which the Loader class was not allowed to be
2319 extended.
2320- Changed _get_config() to get_config() since the function is not a
2321 private one.
2322- **Deprecated "init" folder**. Initialization happens automatically
2323 now. :doc:`Please see documentation <./general/creating_libraries>`.
2324- **Deprecated** $this->db->field_names() USE
2325 $this->db->list_fields()
2326- **Deprecated** the $config['log_errors'] item from the config.php
2327 file. Instead, $config['log_threshold'] can be set to "0" to turn it
2328 off.
2329
2330Version 1.4.1
2331=============
2332
2333Release Date: September 21, 2006
2334
2335- Added a new feature that passes URI segments directly to your
2336 function calls as parameters. See the
2337 :doc:`Controllers <general/controllers>` page for more info.
2338- Added support for a function named _output(), which when used in
2339 your controllers will received the final rendered output from the
2340 output class. More info in the :doc:`Controllers <general/controllers>`
2341 page.
2342- Added several new functions in the :doc:`URI
2343 Class <./libraries/uri>` to let you retrieve and manipulate URI
2344 segments that have been re-routed using the :doc:`URI
2345 Routing <general/routing>` feature. Previously, the URI class did not
2346 permit you to access any re-routed URI segments, but now it does.
2347- Added :doc:`$this->output->set_header() <./libraries/output>`
2348 function, which allows you to set server headers.
2349- Updated plugins, helpers, and language classes to allow your
2350 application folder to contain its own plugins, helpers, and language
2351 folders. Previously they were always treated as global for your
2352 entire installation. If your application folder contains any of these
2353 resources they will be used *instead* the global ones.
2354- Added :doc:`Inflector helper <./helpers/inflector_helper>`.
2355- Added element() function in the :doc:`array
2356 helper <./helpers/array_helper>`.
2357- Added RAND() to active record orderby() function.
2358- Added delete_cookie() and get_cookie() to :doc:`Cookie
2359 helper <./helpers/cookie_helper>`, even though the input class
2360 has a cookie fetching function.
2361- Added Oracle database driver (still undergoing testing so it might
2362 have some bugs).
2363- Added the ability to combine pseudo-variables and php variables in
2364 the template parser class.
2365- Added output compression option to the config file.
2366- Removed the is_numeric test from the db->escape() function.
2367- Fixed a MySQLi bug that was causing error messages not to contain
2368 proper error data.
2369- Fixed a bug in the email class which was causing it to ignore
2370 explicitly set alternative headers.
2371- Fixed a bug that was causing a PHP error when the Exceptions class
2372 was called within the get_config() function since it was causing
2373 problems.
2374- Fixed an oversight in the cookie helper in which the config file
2375 cookie settings were not being honored.
2376- Fixed an oversight in the upload class. An item mentioned in the 1.4
2377 changelog was missing.
2378- Added some code to allow email attachments to be reset when sending
2379 batches of email.
2380- Deprecated the application/scripts folder. It will continue to work
2381 for legacy users, but it is recommended that you create your own
2382 :doc:`libraries <./general/libraries>` or
2383 :doc:`models <./general/models>` instead. It was originally added
2384 before CI had user libraries or models, but it's not needed anymore.
2385- Deprecated the $autoload['core'] item from the autoload.php file.
2386 Instead, please now use: $autoload['libraries']
2387- Deprecated the following database functions:
2388 $this->db->smart_escape_str() and $this->db->fields().
2389
2390Version 1.4.0
2391=============
2392
2393Release Date: September 17, 2006
2394
2395- Added :doc:`Hooks <./general/hooks>` feature, enabling you to tap
2396 into and modify the inner workings of the framework without hacking
2397 the core files.
2398- Added the ability to organize controller files :doc:`into
2399 sub-folders <general/controllers>`. Kudos to Marco for
2400 `suggesting <http://codeigniter.com/forums/viewthread/627/>`_ this
2401 (and the next two) feature.
kenjis087a7a82011-10-20 20:08:47 +09002402- Added regular expressions support for :doc:`routing
Derek Jones8ede1a22011-10-05 13:34:52 -05002403 rules <./general/routing>`.
2404- Added the ability to :doc:`remap function
2405 calls <./general/controllers>` within your controllers.
2406- Added the ability to :doc:`replace core system
2407 classes <./general/core_classes>` with your own classes.
2408- Added support for % character in URL.
2409- Added the ability to supply full URLs using the
2410 :doc:`anchor() <./helpers/url_helper>` helper function.
2411- Added mode parameter to :doc:`file_write() <./helpers/file_helper>`
2412 helper.
2413- Added support for changing the port number in the :doc:`Postgres
2414 driver <./database/configuration>`.
2415- Moved the list of "allowed URI characters" out of the Router class
2416 and into the config file.
2417- Moved the MIME type array out of the Upload class and into its own
Alan Jenkinsa51f8ec2012-11-19 10:29:52 +00002418 file in the application/config/ folder.
Derek Jones8ede1a22011-10-05 13:34:52 -05002419- Updated the Upload class to allow the upload field name to be set
2420 when calling :doc:`do_upload() <./libraries/file_uploading>`.
2421- Updated the :doc:`Config Library <./libraries/config>` to be able to
2422 load config files silently, and to be able to assign config files to
2423 their own index (to avoid collisions if you use multiple config
2424 files).
2425- Updated the URI Protocol code to allow more options so that URLs will
2426 work more reliably in different environments.
2427- Updated the form_open() helper to allow the GET method to be used.
2428- Updated the MySQLi execute() function with some code to help prevent
2429 lost connection errors.
2430- Updated the SQLite Driver to check for object support before
2431 attempting to return results as objects. If unsupported it returns an
2432 array.
2433- Updated the Models loader function to allow multiple loads of the
2434 same model.
2435- Updated the MS SQL driver so that single quotes are escaped.
2436- Updated the Postgres and ODBC drivers for better compatibility.
2437- Removed a strtolower() call that was changing URL segments to lower
2438 case.
2439- Removed some references that were interfering with PHP 4.4.1
2440 compatibility.
2441- Removed backticks from Postgres class since these are not needed.
2442- Renamed display() to _display() in the Output class to make it clear
2443 that it's a private function.
2444- Deprecated the hash() function due to a naming conflict with a native
2445 PHP function with the same name. Please use dohash() instead.
2446- Fixed an bug that was preventing the input class from unsetting GET
2447 variables.
2448- Fixed a router bug that was making it too greedy when matching end
2449 segments.
2450- Fixed a bug that was preventing multiple discrete database calls.
2451- Fixed a bug in which loading a language file was producing a "file
2452 contains no data" message.
2453- Fixed a session bug caused by the XSS Filtering feature inadvertently
2454 changing the case of certain words.
2455- Fixed some missing prefixes when using the database prefix feature.
2456- Fixed a typo in the Calendar class (cal_november).
2457- Fixed a bug in the form_checkbox() helper.
2458- Fixed a bug that was allowing the second segment of the URI to be
2459 identical to the class name.
2460- Fixed an evaluation bug in the database initialization function.
2461- Fixed a minor bug in one of the error messages in the language class.
2462- Fixed a bug in the date helper timespan function.
2463- Fixed an undefined variable in the DB Driver class.
2464- Fixed a bug in which dollar signs used as binding replacement values
2465 in the DB class would be treated as RegEx back-references.
2466- Fixed a bug in the set_hash() function which was preventing MD5 from
2467 being used.
2468- Fixed a couple bugs in the Unit Testing class.
2469- Fixed an incorrectly named variable in the Validation class.
2470- Fixed an incorrectly named variable in the URI class.
2471- Fixed a bug in the config class that was preventing the base URL from
2472 being called properly.
2473- Fixed a bug in the validation class that was not permitting callbacks
2474 if the form field was empty.
2475- Fixed a problem that was preventing scaffolding from working properly
2476 with MySQLi.
2477- Fixed some MS SQL bugs.
2478- Fixed some doc typos.
2479
2480Version 1.3.3
2481=============
2482
2483Release Date: June 1, 2006
2484
2485- Models do **not** connect automatically to the database as of this
2486 version. :doc:`More info here <./general/models>`.
2487- Updated the Sessions class to utilize the active record class when
2488 running session related queries. Previously the queries assumed MySQL
2489 syntax.
2490- Updated alternator() function to re-initialize when called with no
2491 arguments, allowing multiple calls.
2492- Fixed a bug in the active record "having" function.
2493- Fixed a problem in the validation class which was making checkboxes
2494 be ignored when required.
2495- Fixed a bug in the word_limiter() helper function. It was cutting
2496 off the fist word.
2497- Fixed a bug in the xss_clean function due to a PHP bug that affects
2498 some versions of html_entity_decode.
2499- Fixed a validation bug that was preventing rules from being set twice
2500 in one controller.
2501- Fixed a calendar bug that was not letting it use dynamically loaded
2502 languages.
2503- Fixed a bug in the active record class when using WHERE clauses with
2504 LIKE
2505- Fixed a bug in the hash() security helper.
2506- Fixed some typos.
2507
2508Version 1.3.2
2509=============
2510
2511Release Date: April 17, 2006
2512
2513- Changed the behavior of the validation class such that if a
2514 "required" rule is NOT explicitly stated for a field then all other
2515 tests get ignored.
2516- Fixed a bug in the Controller class that was causing it to look in
2517 the local "init" folder instead of the main system one.
2518- Fixed a bug in the init_pagination file. The $config item was not
2519 being set correctly.
2520- Fixed a bug in the auto typography helper that was causing
2521 inconsistent behavior.
2522- Fixed a couple bugs in the Model class.
2523- Fixed some documentation typos and errata.
2524
2525Version 1.3.1
2526=============
2527
2528Release Date: April 11, 2006
2529
2530- Added a :doc:`Unit Testing Library <./libraries/unit_testing>`.
2531- Added the ability to pass objects to the **insert()** and
2532 **update()** database functions. This feature enables you to (among
2533 other things) use your :doc:`Model class <./general/models>`
2534 variables to run queries with. See the Models page for details.
2535- Added the ability to pass objects to the :doc:`view loading
2536 function <./general/views>`: $this->load->view('my_view',
2537 $object);
2538- Added getwhere function to :doc:`Active Record
Derek Jonesce79be02012-06-25 23:23:46 -07002539 class <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05002540- Added count_all function to :doc:`Active Record
Derek Jonesce79be02012-06-25 23:23:46 -07002541 class <./database/query_builder>`.
Derek Jones8ede1a22011-10-05 13:34:52 -05002542- Added language file for scaffolding and fixed a scaffolding bug that
2543 occurs when there are no rows in the specified table.
2544- Added :doc:`$this->db->last_query() <./database/queries>`, which
2545 allows you to view your last query that was run.
2546- Added a new mime type to the upload class for better compatibility.
2547- Changed how cache files are read to prevent PHP errors if the cache
2548 file contains an XML tag, which PHP wants to interpret as a short
2549 tag.
2550- Fixed a bug in a couple of the active record functions (where and
2551 orderby).
2552- Fixed a bug in the image library when realpath() returns false.
2553- Fixed a bug in the Models that was preventing libraries from being
2554 used within them.
2555- Fixed a bug in the "exact_length" function of the validation class.
2556- Fixed some typos in the user guide
2557
2558Version 1.3
2559===========
2560
2561Release Date: April 3, 2006
2562
2563- Added support for :doc:`Models <general/models>`.
2564- Redesigned the database libraries to support additional RDBMs
2565 (Postgres, MySQLi, etc.).
Derek Jonesce79be02012-06-25 23:23:46 -07002566- Redesigned the :doc:`Active Record class <./database/query_builder>`
Derek Jones8ede1a22011-10-05 13:34:52 -05002567 to enable more varied types of queries with simpler syntax, and
2568 advanced features like JOINs.
2569- Added a feature to the database class that lets you run :doc:`custom
2570 function calls <./database/call_function>`.
2571- Added support for :doc:`private functions <general/controllers>` in your
2572 controllers. Any controller function name that starts with an
2573 underscore will not be served by a URI request.
2574- Added the ability to pass your own initialization parameters to your
2575 :doc:`custom core libraries <general/creating_libraries>` when using
2576 $this->load->library()
2577- Added support for running standard :doc:`query string URLs <general/urls>`.
2578 These can be optionally enabled in your config file.
2579- Added the ability to :doc:`specify a "suffix" <general/urls>`, which will be
2580 appended to your URLs. For example, you could add .html to your URLs,
2581 making them appear static. This feature is enabled in your config
2582 file.
2583- Added a new error template for use with native PHP errors.
2584- Added "alternator" function in the :doc:`string
2585 helpers <./helpers/string_helper>`.
2586- Removed slashing from the input class. After much debate we decided
2587 to kill this feature.
2588- Change the commenting style in the scripts to the PEAR standard so
2589 that IDEs and tools like phpDocumenter can harvest the comments.
2590- Added better class and function name-spacing to avoid collisions with
2591 user developed classes. All CodeIgniter classes are now prefixed with
2592 CI\_ and all controller methods are prefixed with _ci to avoid
2593 controller collisions. A list of reserved function names can be
2594 :doc:`found here <general/controllers>`.
2595- Redesigned how the "CI" super object is referenced, depending on
2596 whether PHP 4 or 5 is being run, since PHP 5 allows a more graceful
2597 way to manage objects that utilizes a bit less resources.
2598- Deprecated: $this->db->use_table() has been deprecated. Please read
Derek Jonesce79be02012-06-25 23:23:46 -07002599 the :doc:`Active Record <./database/query_builder>` page for
Derek Jones8ede1a22011-10-05 13:34:52 -05002600 information.
2601- Deprecated: $this->db->smart_escape_str() has been deprecated.
2602 Please use this instead: $this->db->escape()
2603- Fixed a bug in the exception handler which was preventing some PHP
2604 errors from showing up.
2605- Fixed a typo in the URI class. $this->total_segment() should be
2606 plural: $this->total_segments()
2607- Fixed some typos in the default calendar template
2608- Fixed some typos in the user guide
2609
2610Version 1.2
2611===========
2612
2613Release Date: March 21, 2006
2614
2615- Redesigned some internal aspects of the framework to resolve scoping
2616 problems that surfaced during the beta tests. The problem was most
2617 notable when instantiating classes in your constructors, particularly
2618 if those classes in turn did work in their constructors.
2619- Added a global function named
2620 :doc:`get_instance() <general/ancillary_classes>` allowing the main
2621 CodeIgniter object to be accessible throughout your own classes.
2622- Added new :doc:`File Helper <./helpers/file_helper>`:
2623 delete_files()
2624- Added new :doc:`URL Helpers <./helpers/url_helper>`: base_url(),
2625 index_page()
2626- Added the ability to create your own :doc:`core
2627 libraries <general/creating_libraries>` and store them in your local
2628 application directory.
2629- Added an overwrite option to the :doc:`Upload
2630 class <./libraries/file_uploading>`, enabling files to be
2631 overwritten rather than having the file name appended.
2632- Added Javascript Calendar plugin.
2633- Added search feature to user guide. Note: This is done using Google,
2634 which at the time of this writing has not crawled all the pages of
2635 the docs.
2636- Updated the parser class so that it allows tag pars within other tag
2637 pairs.
2638- Fixed a bug in the DB "where" function.
2639- Fixed a bug that was preventing custom config files to be
2640 auto-loaded.
2641- Fixed a bug in the mysql class bind feature that prevented question
2642 marks in the replacement data.
2643- Fixed some bugs in the xss_clean function
2644
2645Version Beta 1.1
2646================
2647
2648Release Date: March 10, 2006
2649
2650- Added a :doc:`Calendaring class <./libraries/calendar>`.
2651- Added support for running :doc:`multiple
2652 applications <general/managing_apps>` that share a common CodeIgniter
2653 backend.
2654- Moved the "uri protocol" variable from the index.php file into the
2655 config.php file
2656- Fixed a problem that was preventing certain function calls from
2657 working within constructors.
2658- Fixed a problem that was preventing the $this->load->library function
2659 from working in constructors.
2660- Fixed a bug that occurred when the session class was loaded using the
2661 auto-load routine.
2662- Fixed a bug that can happen with PHP versions that do not support the
2663 E_STRICT constant
2664- Fixed a data type error in the form_radio function (form helper)
2665- Fixed a bug that was preventing the xss_clean function from being
2666 called from the validation class.
2667- Fixed the cookie related config names, which were incorrectly
2668 specified as $conf rather than $config
2669- Fixed a pagination problem in the scaffolding.
2670- Fixed a bug in the mysql class "where" function.
2671- Fixed a regex problem in some code that trimmed duplicate slashes.
2672- Fixed a bug in the br() function in the HTML helper
2673- Fixed a syntax mistake in the form_dropdown function in the Form
2674 Helper.
2675- Removed the "style" attributes form the form helpers.
2676- Updated the documentation. Added "next/previous" links to each page
2677 and fixed various typos.
2678
2679Version Beta 1.0
2680================
2681
2682Release Date: February 28, 2006
2683
2684First publicly released version.