Same filename and directory in other branches
  1. 4.6.x CHANGELOG.txt
  2. 4.7.x CHANGELOG.txt
  3. 5.x CHANGELOG.txt
  4. 6.x CHANGELOG.txt
Drupal 7.xxx, xxxx-xx-xx (development version)
------------------------

Drupal 7.100, 2024-03-06
------------------------
- Security improvements
- Announcements module added

Drupal 7.99, 2023-12-06
-----------------------
- Various security improvements
- Various bug fixes, optimizations and improvements

Drupal 7.98, 2023-06-07
-----------------------
- Various security improvements
- Various bug fixes, optimizations and improvements

Drupal 7.97, 2023-04-21
-----------------------
- Fix PHP 5.x regression caused by SA-CORE-2023-005

Drupal 7.96, 2023-04-19
-----------------------
- Fixed security issues:
   - SA-CORE-2023-005

Drupal 7.95, 2023-03-15
-----------------------
- Fixed security issues:
   - SA-CORE-2023-004

Drupal 7.94, 2022-12-14
-----------------------
- Hotfix for book.module and Select query properties

Drupal 7.93, 2022-12-07
-----------------------
- Improved support for PHP 8.2
- Minimum PHP version changed to PHP 5.3
- Various security hardenings
- Various bug fixes, optimizations and improvements

Drupal 7.92, 2022-09-07
-----------------------
- Improved support for PHP 8.1
- Various security hardenings
- Various bug fixes, optimizations and improvements

Drupal 7.91, 2022-07-20
-----------------------
- Fixed security issues:
   - SA-CORE-2022-012

Drupal 7.90, 2022-06-01
-----------------------
- Improved support for PHP 8.1
- Improved support for PostgreSQL
- Various bug fixes, optimizations and improvements

Drupal 7.89, 2022-03-02
-----------------------
- Bug fixes for PHP 8.1
- Fix tests for PostgreSQL

Drupal 7.88, 2022-02-15
-----------------------
- Fixed security issues:
   - SA-CORE-2022-003

Drupal 7.87, 2022-01-19
-----------------------
- Fix regression caused by jQuery UI position() backport

Drupal 7.86, 2022-01-18
-----------------------
- Fixed security issues:
   - SA-CORE-2022-001
   - SA-CORE-2022-002

Drupal 7.85, 2022-01-12
-----------------------
- Fix session cookies for sites with different base_urls but a shared domain

Drupal 7.84, 2021-12-13
-----------------------
- Hotfix for session cookie domain on www subdomains

Drupal 7.83, 2021-12-01
-----------------------
- Initial support for PHP 8.1
- The has_js cookie has been removed (but can be re-enabled)
- The leading www. is no longer stripped from cookie domain by default
- The user entity now has a "changed" property
- Introduced a skip_permissions_hardening setting
- Changes to the password reset process to avoid email and username enumeration
- Various bug fixes, optimizations and improvements

Drupal 7.82, 2021-07-21
-----------------------
- Fixed security issues:
   - SA-CORE-2021-004

Drupal 7.81, 2021-06-02
-----------------------
- Block Google FLoC by default
- Testing and accessibility enhancements
- Various bug fixes, optimizations and improvements

Drupal 7.80, 2021-04-20
-----------------------
- Fixed security issues:
   - SA-CORE-2021-002

Drupal 7.79, 2021-04-07
-----------------------
- Initial support for PHP 8
- Support for SameSite cookie attribute
- Avoid write for unchanged fields (opt-in)

Drupal 7.78, 2021-01-19
-----------------------
- Fixed security issues:
   - SA-CORE-2021-001

Drupal 7.77, 2020-12-03
-----------------------
- Hotfix for schema.prefixed tables

Drupal 7.76, 2020-12-02
-----------------------
- Support for MySQL 8
- Core tests pass in SQLite
- Better user flood control logging

Drupal 7.75, 2020-11-26
-----------------------
- Fixed security issues:
   - SA-CORE-2020-013

Drupal 7.74, 2020-11-17
-----------------------
- Fixed security issues:
   - SA-CORE-2020-012

Drupal 7.73, 2020-09-16
-----------------------
- Fixed security issues:
   - SA-CORE-2020-007

Drupal 7.72, 2020-06-17
-----------------------
- Fixed security issues:
   - SA-CORE-2020-004

Drupal 7.71, 2020-06-03
-----------------------
- Fix for jQuery Form bug in Chromium-based browsers
- Full support for PHP 7.4

Drupal 7.70, 2020-05-19
-----------------------
- Fixed security issues:
   - SA-CORE-2020-002
   - SA-CORE-2020-003

Drupal 7.69, 2019-12-18
-----------------------
- Fixed security issues:
   - SA-CORE-2019-012

Drupal 7.68, 2019-12-04
-----------------------
- Fixed: Hide toolbar when printing
- Fixed: Settings returned via ajax are not run through hook_js_alter()
- Fixed: Use drupal_http_build_query() in drupal_http_request()
- Fixed: DrupalRequestSanitizer not found fatal error when bootstrap phase order is changed
- Fixed: Block web.config in .htaccess (and vice-versa)
- Fixed: Create "scripts" element to align rendering workflow to how "styles" are handled
- PHP 7.3: Fixed 'Cannot change session id when session is active'
- PHP 7.1: Fixed 'A non-numeric value encountered in theme_pager()'
- PHP 7.x: Fixed file.inc generated .htaccess does not cover PHP 7
- PHP 5.3: Fixed check_plain() 'Invalid multibyte sequence in argument' test failures
- Fixed: Allow passing data as array to drupal_http_request()
- Fixed: Skip module_invoke/module_hook in calling hook_watchdog (excessive function_exist)
- Fixed: HTTP status 200 returned for 'Additional uncaught exception thrown while handling exception'
- Fixed: theme_table() should take an optional footer variable and produce <tfoot>
- Fixed: 'uasort() expects parameter 1 to be array, null given in node_view_multiple()'
- [regression] Fix default.settings.php permission

Drupal 7.67, 2019-05-08
-----------------------
- Fixed security issues:
   - SA-CORE-2019-007

Drupal 7.66, 2019-04-17
-----------------------
- Fixed security issues:
   - SA-CORE-2019-006

Drupal 7.65, 2019-03-20
-----------------------
- Fixed security issues:
   - SA-CORE-2019-004

Drupal 7.64, 2019-02-06
-----------------------
- [regression] Unset the 'host' header in drupal_http_request() during redirect
- Fixed: 7.x does not have Phar protection and Phar tests are failing on Drupal 7
- Fixed: Notice: Undefined index: display_field in file_field_widget_value() (line 582 of /module/file/file.field.inc)
- Performance improvement: Registry rebuild should not parse the same file twice in the same request
- Fixed _registry_update() to clear caches after transaction is committed

Drupal 7.63, 2019-01-16
-----------------------
- Fixed a fatal error for some Drush users introduced by SA-CORE-2019-002.

Drupal 7.62, 2019-01-15
-----------------------
- Fixed security issues:
   - SA-CORE-2019-001
   - SA-CORE-2019-002

Drupal 7.61, 2018-11-07
-----------------------
- File upload validation functions and hook_file_validate() implementations are
  now always passed the correct file URI.
- The default form cache expiration of 6 hours is now configurable (API
  addition: https://www.drupal.org/node/2857751).
- Allowed callers of drupal_http_request() to optionally specify an explicit
  Host header.
- Allowed the + character to appear in usernames.
- PHP 7.2: Fixed Archive_Tar incompatibility.
- PHP 7.2: Removed deprecated function each().
- PHP 7.2: Avoid count() calls on uncountable variables.
- PHP 7.2: Removed deprecated create_function() call.
- PHP 7.2: Make sure variables are arrays in theme_links().
- Fixed theme-settings.php not being loaded on cached forms
- Fixed problem with IE11 & Chrome(PointerEvents enabled) & some Firefox scroll to the top of the page after dragging the bottom item with jquery 1.5 <-> 1.11

Drupal 7.60, 2018-10-18
------------------------
- Fixed security issues. See SA-CORE-2018-006.

Drupal 7.59, 2018-04-25
-----------------------
- Fixed security issues (remote code execution). See SA-CORE-2018-004.

Drupal 7.58, 2018-03-28
-----------------------
- Fixed security issues (remote code execution). See SA-CORE-2018-002.

Drupal 7.57, 2018-02-21
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2018-001.

Drupal 7.56, 2017-06-21
-----------------------
- Fixed security issues (access bypass). See SA-CORE-2017-003.

Drupal 7.55, 2017-06-07
-----------------------
- Fixed incompatibility with PHP versions 7.0.19 and 7.1.5 due to duplicate
  DATE_RFC7231 definition.
- Made Drupal core pass all automated tests on PHP 7.1.
- Allowed services such as Let's Encrypt to work with Drupal on Apache, by
  making Drupal's .htaccess file allow access to the .well-known directory
  defined by RFC 5785.
- Made new Drupal sites work correctly on Apache 2.4 when the mod_access_compat
  Apache module is disabled.
- Fixed Drupal's URL-generating functions to always encode '[' and ']' so that
  the URLs will pass HTML5 validation.
- Various additional bug fixes.
- Various API documentation improvements.
- Additional automated test coverage.

Drupal 7.54, 2017-02-01
-----------------------
- Modules are now able to define theme engines (API addition:
  https://www.drupal.org/node/2826480).
- Logging of searches can now be disabled (new option in the administrative
  interface).
- Added menu tree render structure to (pre-)process hooks for theme_menu_tree()
  (API addition: https://www.drupal.org/node/2827134).
- Added new function for determining whether an HTTPS request is being served
  (API addition: https://www.drupal.org/node/2824590).
- Fixed incorrect default value for short and medium date formats on the date
  type configuration page.
- File validation error message is now removed after subsequent upload of valid
  file.
- Numerous bug fixes.
- Numerous API documentation improvements.
- Additional performance improvements.
- Additional automated test coverage.

Drupal 7.53, 2016-12-07
-----------------------
- Fixed drag and drop support on newer Chrome/IE 11+ versions after 7.51 update
  when jQuery is updated to 1.7-1.11.0.

Drupal 7.52, 2016-11-16
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2016-005.

Drupal 7.51, 2016-10-05
-----------------------
- The Update module now also checks for updates to a disabled theme that is
  used as an admin theme.
- Exceptions thrown in dblog_watchdog() are now caught and ignored.
- Clarified the warning that appears when modules are missing or have moved.
- Log messages are now XSS filtered on display.
- Draggable tables now work on touch screen devices.
- Added a setting for allowing double underscores in CSS identifiers
  (https://www.drupal.org/node/2810369).
- If a user navigates away from a page while an Ajax request is running they
  will no longer get an error message saying "An Ajax HTTP request terminated
  abnormally".
- The system_region_list() API function now takes an optional third parameter
  which allows region name translations to be skipped when they are not needed
  (API addition: https://www.drupal.org/node/2810365).
- Numerous performance improvements.
- Numerous bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.50, 2016-07-07 
-----------------------
- Added a new "administer fields" permission for trusted users, which is
  required in addition to other permissions to use the field UI
  (https://www.drupal.org/node/2483307).
- Added clickjacking protection to Drupal core by setting the X-Frame-Options
  header to SAMEORIGIN by default (https://www.drupal.org/node/2735873).
- Added support for full UTF-8 (emojis, Asian symbols, mathematical symbols) on
  MySQL and other database drivers when the site and database are configured to
  allow it (https://www.drupal.org/node/2761183).
- Improved performance by avoiding a re-scan of directories when a file is
  missing; instead, trigger a PHP warning (minor API change:
  https://www.drupal.org/node/2581445).
- Made it possible to use any PHP callable in Ajax form callbacks, form API
  form-building functions, and form API wrapper callbacks (API addition:
  https://www.drupal.org/node/2761169).
- Fixed that following a password reset link while logged in leaves users unable
  to change their password (minor user interface change:
  https://www.drupal.org/node/2759023).
- Implemented various fixes for automated test failures on PHP 5.4+ and PHP 7.
  Drupal core automated tests now pass in these environments.
- Improved support for PHP 7 by fixing various problems.
- Fixed various bugs with PHP 5.5+ imagerotate(), including when incorrect
  color indices are passed in.
- Fixed a regression introduced in Drupal 7.43 that allowed files uploaded by
  anonymous users to be lost after form validation errors, and that also caused
  regressions with certain contributed modules.
- Fixed a regression introduced in Drupal 7.36 which caused the default value
  of hidden textarea fields to be ignored.
- Fixed robots.txt to allow search engines to access CSS, JavaScript and image
  files.
- Changed wording on the Update Manager settings page to clarify that the
  option to check for disabled module updates also applies to uninstalled
  modules (administrative-facing translatable string change).
- Changed the help text when editing menu links and configuring URL redirect
  actions so that it does not reference "Drupal" or the drupal.org website
  (administrative-facing translatable string change).
- Fixed the locale safety check that is used to ensure that translations are
  safe to allow for tokens in the href/src attributes of translated strings.
- Fixed that URL generation only works on port 80 when using domain based
  language negotation.
- Made method="get" forms work inside the administrative overlay. The fix adds
  a new hidden field to these forms when they appear inside the overlay (minor
  data structure change).
- Increased maxlength of menu link title input fields in the node form and
  menu link form from 128 to 255 characters.
- Removed meaningless post-check=0 and pre-check=0 cache control headers from
  Drupal HTTP responses.
- Added a .editorconfig file to auto-configure editors that support it.
- Added --directory option to run-tests.sh for easier test discovery of all
  tests within a project.
- Made run-tests.sh exit with a failure code when there are test fails or
  problems running the script.
- Fixed that cookies from previous tests are still present when a new test
  starts in DrupalWebTestCase.
- Improved performance of queries on the {authmap} database table.
- Fixed handling of missing files and functions inside the registry.
- Fixed Ajax handling for tableselect form elements that use checkboxes.
- Fixed a bug which caused ip_address() to return nothing when the client IP
  address and proxy IP address are the same.
- Added a new option to format_xml_elements() to allow for already encoded
  values.
- Changed the {history} table's node ID field to be an unsigned integer, to
  match the same field in the {node} table and to prevent errors with very
  large node IDs.
- Added an explicit page callback to the "admin/people/create" menu item in the
  User module (minor data structure change). Previously this automatically
  inherited the page callback from the parent "admin/people" menu item, which
  broke contributed modules that override the "admin/people" page.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.44, 2016-06-15
-----------------------
- Fixed security issues (privilege escalation). See SA-CORE-2016-002.

Drupal 7.43, 2016-02-24
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2016-001.

Drupal 7.42, 2016-02-03
-----------------------
- Stopped invoking hook_flush_caches() on every cron run, since some modules
  use that hook for expensive operations that are only needed on cache clears.
- Changed the default .htaccess and web.config to block Composer-related files.
- Added static caching to module_load_include() to improve performance.
- Fixed double-encoding bugs in select field widgets provided by the Options
  module. The fix deprecates the 'strip_tags' property on option widgets and
  replaces it with a new 'strip_tags_and_unescape' property (minor data
  structure change).
- Improved MySQL 5.7 support by changing the MySQL database driver to stop
  using the ANSI SQL mode alias, which has different meanings for different
  MySQL versions.
- Fixed a regression introduced in Drupal 7.39 which prevented autocomplete
  functionality from working on servers that are not configured to
  automatically recognize index.php.
- Updated the Archive_Tar PEAR package to the latest 1.4.0 release, to fix bugs
  with tar file handling on various operating systems.
- Fixed fatal errors on node preview when a field is displayed in the node
  teaser but hidden in the full node view. The fix removes a
  field_attach_prepare_view() call from the node_preview() function since it is
  redundant with one in the node preview theme layer.
- Improved the description of the "Trimmed" format option on text fields
  (translatable string change, and minor UI and data structure change).
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.41, 2015-10-21
-----------------------
- Fixed security issues (open redirect). See SA-CORE-2015-004.

Drupal 7.40, 2015-10-14
-----------------------
- Made Drupal's code for parsing .info files run much faster and use much less
  memory.
- Prevented drupal_http_request() from returning an error when it receives a
  201 through 206 HTTP status code.
- Added support for autoloading traits via the registry on sites running PHP
  5.4 or higher.
- Allowed the user-picture.tpl.php theme template to have HTML classes besides
  the default "user-picture" class printed in it (markup change).
- Fixed the URL text filter to convert e-mail addresses with plus signs into
  mailto: links.
- Added alternate text to file icons displayed by the File module, to improve
  accessibility (string change, and minor API addition to theme_file_icon()).
- Changed one-time login link failure messages to be displayed as errors or
  warnings as appropriate, rather than as regular status messages (minor UI
  change and data structure change).
- Changed the default settings.php configuration to exclude private files from
  the "404_fast_paths" behavior.
- Changed the page that displays filter tips for a particular text format, for
  example filter/tips/full_html, to return "page not found" or "access denied"
  if the format does not exist or the user does not have access to it. This
  change adds a new menu item to the Filter module's hook_menu() entry (minor
  data structure change).
- Added a new hook, hook_block_cid_parts_alter(), to allow modules to alter the
  cache keys used for caching a particular block.
- Made drupal_set_message() display and return messages when "0" is passed in
  as the message to set.
- Fixed non-functional "Files displayed by default" setting on file fields.
- The "worker callback" provided in hook_cron_queue_info() and the "finished"
  callback specified during batch processing can now be any PHP callable
  instead of just functions.
- Prevented drupal_set_time_limit() from decreasing the time limit in the case
  where the PHP maximum execution time is already unlimited.
- Changed the default thousand marker for numeric fields from a space ("1 000")
  to nothing ("1000") (minor UI change: https://www.drupal.org/node/1388376).
- Prevented malformed theme .info files (without a "name" key) from causing
  exceptions during menu rebuilds. If an .info file without a "name" key is
  found in a module or theme directory, Drupal will now use the module or
  theme's machine name as the display name instead.
- Made the format column in the {date_format_locale} database table
  case-sensitive, to match the equivalent column in the {date_formats} table.
- Fixed a bug in the Statistics module that caused JavaScript files attached to
  a node while it is being viewed to be omitted from the page.
- Added an optional 'project:' prefix that can be added to dependencies in a
  module's .info file to indicate which project the dependency resides in (API
  addition: https://www.drupal.org/node/2299747).
- Fixed various bugs that occurred after hooks were invoked early in the Drupal
  bootstrap and that caused module_implements() and drupal_alter() to cache an
  incomplete set of hook implementations for later use.
- Set the X-Content-Type-Options header to "nosniff" when possible, to prevent
  certain web browsers from picking an unsafe MIME type.
- Prevented the database API from executing multiple queries at once on MySQL,
  if the site's PHP version is new enough to do so. This is a secondary defense
  against SQL injection (API change: https://www.drupal.org/node/2463973).
- Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused the upgrade
  to fail when there were multiple file records pointing to the same file.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.39, 2015-08-19
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-003.

Drupal 7.38, 2015-06-17
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-002.

Drupal 7.37, 2015-05-07
-----------------------
- Fixed a regression in Drupal 7.36 which caused certain kinds of content types
  to become disabled if they were defined by a no-longer-enabled module.
- Removed a confusing description regarding automatic time zone detection from
  the user account form (minor UI and data structure change).
- Allowed custom HTML tags with a dash in the name to pass through filter_xss()
  when specified in the list of allowed tags.
- Allowed hook_field_schema() implementations to specify indexes for fields
  based on a fixed-length column prefix (rather than the entire column), as was
  already allowed in hook_schema() implementations.
- Fixed PDO exceptions on PostgreSQL when accessing invalid entity URLs.
- Added a sites/all/libraries folder to the codebase, with instructions for
  using it.
- Added a description to the "Administer text formats and filters" permission
  on the Permissions page (string change).
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.36, 2015-04-01
-----------------------
- Added a 'file_public_schema' variable which allows modules that define
  publicly-accessible streams in hook_stream_wrappers() to bypass file download
  access checks when processing managed file upload fields.
- Fixed a bug that caused database query tags not to be added to search-related
  database queries under many circumstances, and which prevented the
  corresponding hook_query_TAG_alter() implementations from being called.
- Fixed the "for" attribute on managed file upload field labels to improve
  accessibility (minor markup change).
- Added a 'javascript_always_use_jquery' variable which can be set to FALSE by
  sites that may not need jQuery loaded on all pages, and a 'requires_jquery'
  option to drupal_add_js() which modules can set to FALSE when adding
  JavaScript files that have no dependency on jQuery (API addition:
  https://www.drupal.org/node/2462717).
- Fixed incorrect foreign keys in the User module's role_permission and
  users_roles database tables.
- Changed permission descriptions throughout Drupal core to consistently link
  to relevant administrative pages, regardless of whether the user viewing the
  Permissions page can view the page being linked to (minor UI change).
- Fixed the drupal_add_region_content() function so that it actually adds
  content to the page.
- Added an 'image_suppress_itok_output' variable to allow sites already using
  the existing 'image_allow_insecure_derivatives' variable to also prevent
  security tokens from appearing in image derivative URLs.
- Fixed double-escaping of theme names in the Block module administrative
  interface (minor string change).
- Added basic support for Xdebug when running automated tests.
- Fixed a bug which caused previewing a node to remove elements from the node
  being edited. With this fix, calling node_preview() will no longer modify the
  passed-in node object (minor API change).
- Added a user_has_role() function to check whether a user has a particular
  role (API addition: https://www.drupal.org/node/2462411).
- Fixed installation failures when an opcode cache is enabled.
- Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused private
  files to be inaccessible.
- Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused user
  pictures to be lost.
- Fixed missing language code in hook_field_attach_view_alter() when it is
  invoked from field_view_field().
- Stopped sending ETag and Last-Modified headers for uncached page requests,
  since they break caching for certain Varnish and Nginx configurations.
- Changed the Simpletest module to allow PSR-4 test classes to be used in
  Drupal 7.
- Fixed a fatal error that occurred when using the Comment module's "Unpublish
  comment containing keyword(s)" action.
- Changed the "lang" attribute on language links to "xml:lang" so it validates
  as XHTML (minor markup change).
- Prevented the form API from allowing arrays to be submitted for various form
  elements, such as textfields, textareas, and password fields (API change:
  https://www.drupal.org/node/2462723).
- Fixed a bug in the Contact module which caused the global user object to have
  the incorrect name and e-mail address during the remainder of the page
  request after the contact form is submitted.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.35, 2015-03-18
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-001.

Drupal 7.34, 2014-11-19
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-006.

Drupal 7.33, 2014-11-07
-----------------------
- Began storing the file modification time of each module and theme in the
  {system} database table so that contributed modules can use it to identify
  recently changed modules and themes (minor data structure change to the
  return value of system_get_info() and other related functions).
- Added a "Did you mean?" feature to the run-tests.sh script for running
  automated tests from the command line, to help developers who are attempting
  to run a particular test class or group.
- Changed the date format used in various HTTP headers output by Drupal core
  from RFC 1123 format to RFC 7231 format.
- Added a "block_cache_bypass_node_grants" variable to allow sites which have
  node access modules enabled to use the block cache if desired (API addition).
- Made image derivative generation HTTP requests return a 404 error (rather
  than a 500 error) when the source image does not exist.
- Fixed a bug which caused user pictures to be removed from the user object
  after saving, and resulted in data loss if the user account was subsequently
  re-saved.
- Fixed a bug in which field_has_data() did not return TRUE for fields that
  only had data in older entity revisions, leading to loss of the field's data
  when the field configuration was edited.
- Fixed a bug which caused the Ajax progress throbber to appear misaligned in
  many situatons (minor styling change).
- Prevented the Bartik theme from lower-casing the "Permalink" link on
  comments, for improved multilingual support (minor UI change).
- Added a "preferred_menu_links" tag to the database query that is used by
  menu_link_get_preferred() to find the preferred menu link for a given path,
  to make it easier to alter.
- Increased the maximum allowed length of block titles to 255 characters
  (database schema change to the {block} table).
- Removed the Field module's field_modules_uninstalled() function, since it did
  not do anything when it was invoked.
- Added a "theme_hook_original" variable to templates and theme functions and
  an optional sitewide theme debug mode, to provide contextual information in
  the page's HTML to theme developers. The theme debug mode is based on the one
  used with Twig in Drupal 8 and can be accessed by setting the "theme_debug"
  variable to TRUE (API addition).
- Added an entity_view_mode_prepare() API function to allow entity-defining
  modules to properly invoke hook_entity_view_mode_alter(), and used it
  throughout Drupal core to fix bugs with the invocation of that hook (API
  change: https://www.drupal.org/node/2369141).
- Security improvement: Made the database API's orderBy() method sanitize the
  sort direction ("ASC" or "DESC") for queries built with db_select(), so that
  calling code does not have to.
- Changed the RDF module to consistently output RDF metadata for nodes and
  comments near where the node is rendered in the HTML (minor markup and data
  structure change).
- Added an HTML class to RDFa metatags throughout Drupal to prevent them from
  accidentally affecting the site appearance (minor markup change).
- Fixed a bug in the Unicode requirements check which prevented installing
  Drupal on PHP 5.6.
- Fixed a bug which caused drupal_get_bootstrap_phase() to abort the bootstrap
  when called early in the page request.
- Renamed the "Search result" view mode to "Search result highlighting input"
  to better reflect how it is used (UI change).
- Improved database queries generated by EntityFieldQuery in the case where
  delta or language condition groups are used, to reduce the number of INNER
  JOINs (this is a minor data structure change affecting code which implements
  hook_query_alter() on these queries).
- Removed special-case behavior for file uploads which allowed user #1 to
  bypass maximum file size and user quota limits.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.32, 2014-10-15
-----------------------
- Fixed security issues (SQL injection). See SA-CORE-2014-005.

Drupal 7.31, 2014-08-06
-----------------------
- Fixed security issues (denial of service). See SA-CORE-2014-004.

Drupal 7.30, 2014-07-24
-----------------------
- Fixed a regression introduced in Drupal 7.29 that caused files or images
  attached to taxonomy terms to be deleted when the taxonomy term was edited
  and resaved (and other related bugs with contributed and custom modules).
- Added a warning on the permissions page to recommend restricting access to
  the "View site reports" permission to trusted administrators. See
  DRUPAL-PSA-2014-002.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.29, 2014-07-16
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-003.

Drupal 7.28, 2014-05-08
-----------------------
- Fixed a regression introduced in Drupal 7.27 that caused JavaScript to break
  on older browsers (such as Internet Explorer 8 and earlier) when Ajax was
  used.
- Increased the timeout used by the Update Manager module when it fetches data
  from drupal.org (from 5 seconds to 30 seconds), to work around a problem
  which causes incomplete information about security updates to be presented to
  site administrators. This fix may lead to a performance slowdown on the
  Update Manager administration pages, when installing Drupal distributions,
  and (for sites that use the automated cron feature) on occasional page loads
  by site visitors.
- Fixed the behavior of the token system's "[node:summary]" token when the body
  field does not have a manual summary.
- Changed the behavior of db_query_temporary() so that it works on SELECT
  queries even when they have leading comments/whitespace. A side effect of
  this fix is that db_query_temporary() will now fail with an error if it is
  ever used on non-SELECT queries.
- Added a "node_admin_filter" tag to the database query used to build the list
  of nodes on the content administration page, to make it easier to alter.
- Made the cron queue system log any exceptions that are thrown while an item
  in the queue is being processed, rather than stopping the entire PHP request.
- Improved screen reader support by adding an aria-live HTML attribute to file
  upload fields when there is an error uploading the file (minor markup
  change).
- Made the pager on the Tracker module listing pages show the same number of
  items as other pagers throughout Drupal core (minor UI change).
- Fixed a bug which caused caches not to be properly cleared when a file entity
  was saved or deleted.
- Added several missing countries to the default list returned by
  country_get_list() (string change).
- Replaced the term "weight" with "influence" in the content ranking settings
  for search, and added help text for administrators (string change).
- Fixed untranslatable text strings in the administrative interface for the
  "Crop" effect provided by the Image module (minor string change).
- Fixed a bug in the Taxonomy module update function introduced in Drupal 7.26
  that caused memory and CPU problems on sites with very large numbers of
  unpublished nodes.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.27, 2014-04-16
-----------------------
- Fixed security issues (information disclosure). See SA-CORE-2014-002.

Drupal 7.26, 2014-01-15
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-001.

Drupal 7.25, 2014-01-02
-----------------------
- Fixed a bug in node_save() which prevented the saved node from being updated
  in hook_node_insert() and other similar hooks.
- Added a meta tag to install.php to prevent it from being indexed by search
  engines even when Drupal is installed in a subfolder (minor markup change).
- Fixed a bug in the database API that caused frequent deadlock errors when
  running merge queries on some servers.
- Performance improvement: Prevented block rehashing from writing blocks to the
  database on every cache clear and cron run when the blocks have not changed.
  This fix results in an extra 'saved' key which is added and set to TRUE for
  each block returned by _block_rehash() that actually is saved to the database
  (data structure change).
- Added an optional 'skip on cron' parameter to hook_cron_queue_info() to allow
  queues to avoid being automatically processed on cron runs (API addition).
- Fixed a bug which caused hook_block_view_MODULE_DELTA_alter() to never be
  invoked if the block delta had a hyphen in it. To implement the hook when the
  block delta has a hyphen, modules should now replace hyphens with underscores
  when constructing the function name for the hook implementation.
- Fixed a bug which caused cached pages to sometimes be sent to the browser
  with incorrect compression. The fix adds a new 'page_compressed' key to the
  $cache->data array returned by drupal_page_get_cache() (minor data structure
  change).
- Fixed broken tests on PHP 5.5.
- Made the File and Image modules more robust when saving entities that have
  deleted files attached. The code in file_field_presave() will now remove the
  record of the deleted file from the entity before saving (minor data
  structure change).
- Standardized menu callback functions throughout Drupal core to return
  MENU_NOT_FOUND and MENU_ACCESS_DENIED rather than printing their own "page
  not found" or "access denied" pages (minor API change in the return value of
  these functions under some circumstances).
- Fixed a bug in which caches were not properly cleared when a node was deleted
  via the administrative interface.
- Changed the Bartik theme to render content contained in <pre>, <code> and
  similar tags in a larger font size, so it is easier to read.
- Fixed a bug in the Search module that caused exceptions to be thrown during
  searches if the server was not configured to represent decimal points as a
  period.
- Fixed a regression in the Image module that made image_style_url() not work
  when a relative path (rather than a complete file URI) was passed to it.
- Added an optional feature to the Statistics module to allow node views to be
  tracked by Ajax requests rather than during the server-side generation of the
  page. This allows the node counter to work on sites that use external page
  caches (string change and new administrative option:
  https://drupal.org/node/2164069).
- Added a link to the drupal.org documentation page for cron to the Cron
  settings page (string change).
- Added a 'drupal_anonymous_user_object' variable to allow the anonymous user
  object returned by drupal_anonymous_user() to be overridden with a classed
  object (API addition).
- Changed the database API to allow inserts based on a SELECT * query to work
  correctly.
- Changed the database schema of the {file_managed} table to allow Drupal to
  manage files larger than 4 GB.
- Changed the File module's hook_field_load() implementation to prevent file
  entity properties which have the same name as file or image field properties
  from overwriting the field properties (minor API change).
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.24, 2013-11-20
-----------------------
- Fixed security issues (multiple vulnerabilities), see SA-CORE-2013-003.

Drupal 7.23, 2013-08-07
-----------------------
- Fixed a fatal error on PostgreSQL databases when updating the Taxonomy module
  from Drupal 6 to Drupal 7.
- Fixed the default ordering of CSS files for sites using right-to-left
  languages, to consistently place the right-to-left override file immediately
  after the CSS it is overriding (API change: https://drupal.org/node/2058463).
- Added a drupal_check_memory_limit() API function to allow the memory limit to
  be checked consistently (API addition).
- Changed the default web.config file for IIS servers to allow favicon.ico
  files which are present in the filesystem to be accessed.
- Fixed inconsistent support for the 'tel' protocol in Drupal's URL filtering
  functions.
- Performance improvement: Allowed all hooks to be included in the
  module_implements() cache, even those that are only invoked on HTTP POST
  requests.
- Made the database system replace truncate queries with delete queries when
  inside a transaction, to fix issues with PostgreSQL and other databases.
- Fixed a bug which caused nested contextual links to display improperly.
- Fixed a bug which prevented cached image derivatives from being flushed for
  private files and other non-default file schemes.
- Fixed drupal_render() to always return an empty string when there is no
  output, rather than sometimes returning NULL (minor API change).
- Added protection to cache_clear_all() to ensure that non-cache tables cannot
  be truncated (API addition: a new isValidBin() method has been added to the
  default database cache implementation).
- Changed the default .htaccess file to support HTTP authorization in CGI
  environments.
- Changed the password reset form to pre-fill the username when requested via a
  URL query parameter, and used this in the error message that appears after a
  failed login attempt (minor data structure and behavior change).
- Fixed broken support for foreign keys in the field API.
- Fixed "No active batch" error when a user cancels their own account.
- Added a description to the "access content overview" permission on the
  permissions page (string change).
- Added a drupal_array_diff_assoc_recursive() function to allow associative
  arrays to be compared recursively (API addition).
- Added human-readable labels to image styles, in addition to the existing
  machine-readable name (API change: https://drupal.org/node/2058503).
- Moved the drupal_get_hash_salt() function to bootstrap.inc and used it in
  additional places in the code, for added security in the case where there is
  no hash salt in settings.php.
- Fixed a regression in Drupal 7.22 that caused internal server errors for
  sites running on very old Apache 1.x web servers.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.22, 2013-04-03
-----------------------
- Allowed the drupal_http_request() function to be overridden so that
  additional HTTP request capabilities can be added by contributed modules.
- Changed the Simpletest module to allow PSR-0 test classes to be used in
  Drupal 7.
- Removed an unnecessary "Content-Disposition" header from private file
  downloads; it prevented many private files from being viewed inline in a web
  browser.
- Changed various field API functions to allow them to optionally act on a
  single field within an entity (API addition: http://drupal.org/node/1825844).
- Fixed a bug which prevented Drupal's file transfer functionality from working
  on some PHP 5.4 systems.
- Fixed incorrect log message when theme() is called for a theme hook that does
  not exist (minor string change).
- Fixed Drupal's token-replacement system to allow spaces in the token value.
- Changed the default behavior after a user creates a node they do not have
  access to view. The user will now be redirected to the front page rather than
  an access denied page.
- Fixed a bug which prevented empty HTTP headers (such as "0") from being set.
  (Minor behavior change: Callers of drupal_add_http_header() must now set
  FALSE explicitly to prevent a header from being sent at all; this was already
  indicated in the function's documentation.)
- Fixed OpenID errors when more than one module implements hook_openid(). The
  behavior is now changed so that if more than one module tries to set the same
  parameter, the last module's change takes effect.
- Fixed a serious documentation bug: The $name variable in the
  taxonomy-term.tpl.php theme template was incorrectly documented as being
  sanitized when in fact it is not.
- Fixed a bug which prevented Drupal 6 to Drupal 7 upgrades on sites which had
  duplicate permission names in the User module's database tables.
- Added an empty "datatype" attribute to taxonomy term and username links to
  make the RDFa markup upward compatible with RDFa 1.1 (minor markup addition).
- Fixed a bug which caused the denial-of-service protection added in Drupal
  7.20 to break certain valid image URLs that had an extra slash in them.
- Fixed a bug with update queries in the SQLite database driver that prevented
  Drupal from being installed with SQLite on PHP 5.4.
- Fixed enforced dependencies errors updating to recent versions of Drupal 7 on
  certain non-MySQL databases.
- Refactored the Field module's caching behavior to obtain large improvements
  in memory usage for sites with many fields and instances (API addition:
  http://drupal.org/node/1915646).
- Fixed entity argument not being passed to implementations of
  hook_file_download_access_alter(). The fix adds an additional context
  parameter that can be passed when calling drupal_alter() for any hook (API
  change: http://drupal.org/node/1882722).
- Fixed broken support for translatable comment fields (API change:
  http://drupal.org/node/1874724).
- Added an assertThemeOutput() method to Simpletest to allow tests to check
  that themed output matches an expected HTML string (API addition).
- Added a link to "Install another module" after a module has been successfully
  downloaded via the Update Manager (UI change).
- Added an optional "exclusive" flag to installation profile .info files which
  allows Drupal distributions to force a profile to be selected during
  installation (API addition: http://drupal.org/node/1961012).
- Fixed a bug which caused the database API to not properly close database
  connections.
- Added a link to the URL for running cron from outside the site to the Cron
  settings page (UI change).
- Fixed a bug which prevented image styles from being reverted on PHP 5.4.
- Made the default .htaccess rules protocol sensitive to improve security for
  sites which use HTTPS and redirect between "www" and non-"www" versions of
  the page.
- Numerous small bug fixes.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.21, 2013-03-06
-----------------------
- Allowed sites using the 'image_allow_insecure_derivatives' variable to still
  have partial protection from the security issues fixed in Drupal 7.20.

Drupal 7.20, 2013-02-20
-----------------------
- Fixed security issues (denial of service). See SA-CORE-2013-002.

Drupal 7.19, 2013-01-16
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2013-001.

Drupal 7.18, 2012-12-19
-----------------------
- Fixed security issues (multiple vulnerabilities). See SA-CORE-2012-004.

Drupal 7.17, 2012-11-07
-----------------------
- Changed the default value of the '404_fast_html' variable to have a DOCTYPE
  declaration.
- Made it possible to use associative arrays for the 'items' variable in
  theme_item_list().
- Fixed a bug which prevented required form elements without a title from being
  given an "error" class when the form fails validation.
- Prevented duplicate HTML IDs from appearing when two forms are displayed on
  the same page and one of them is submitted with invalid data (minor markup
  change).
- Fixed a bug which prevented Drupal 6 to Drupal 7 upgrades on sites which had
  stale data in the Upload module's database tables.
- Fixed a bug in the States API which prevented certain types of form elements
  from being disabled when requested.
- Allowed aggregator feed items with author names longer than 255 characters to
  have a truncated version saved to the database (rather than causing a fatal
  error).
- Allowed aggregator feed items to have URLs longer than 255 characters
  (schema change which results in several columns in the Aggregator module's
  database tables changing from VARCHAR to TEXT fields).
- Added hook_taxonomy_term_view() and standardized the process for rendering
  taxonomy terms to invoke hook_entity_view() and otherwise make it consistent
  with other entities (API change: http://drupal.org/node/1808870).
- Added hook_entity_view_mode_alter() to allow modules to change entity view
  modes on display (API addition: http://drupal.org/node/1833086).
- Fixed a bug which made database queries running a "LIKE" query on blob fields
  fail on PostgreSQL databases. This caused errors during the Drupal 6 to
  Drupal 7 upgrade.
- Changed the hook_menu() entry for Drupal's rss.xml page to prevent extra path
  components from being accidentally passed to the page callback function (data
  structure change).
- Removed a non-standard "name" attribute from Drupal's default Content-Type
  header for file downloads.
- Fixed the theme settings form to properly clean up submitted values in
  $form_state['values'] when the form is submitted (data structure change).
- Fixed an inconsistency by removing the colon from the end of the label on
  multi-valued form fields (minor string change).
- Added support for 'weight' in hook_field_widget_info() to allow modules to
  control the order in which widgets are displayed in the Field UI.
- Updated various tables in the OpenID and Book modules to use the default
  "empty table" text pattern (string change).
- Added proxy server support to drupal_http_request().
- Added "lang" attributes to language links, to better support screen readers.
- Fixed double occurrence of a "ul" HTML tag on secondary local tasks in the
  Seven theme (markup change).
- Fixed bugs which caused taxonomy vocabulary and shortcut set titles to be
  double-escaped. The fix replaces the taxonomy vocabulary overview page and
  "Edit shortcuts" menu items' title callback entries in hook_menu() with new
  functions that do not escape HTML characters (data structure change).
- Modified the Update manager module to allow drupal.org to collect usage
  statistics for individual modules and themes, rather than only for entire
  projects.
- Modified the node listing database query on Drupal's default front page to
  add table aliases for better query altering (this is a data structure change
  affecting code which implements hook_query_alter() on this query).
- Improved the translatability of the "Field type(s) in use" message on the
  modules page (admin-facing string change).
- Fixed a regression which caused a "call to undefined function
  drupal_find_base_themes()" fatal error under rare circumstances.
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.16, 2012-10-17
-----------------------
- Fixed security issues (Arbitrary PHP code execution and information
  disclosure). See SA-CORE-2012-003.

Drupal 7.15, 2012-08-01
-----------------------
- Introduced a 'user_password_reset_timeout' variable to allow the 24-hour
  expiration for user password reset links to be adjusted (API addition).
- Fixed database errors due to ambiguous column names that occurred when
  EntityFieldQuery was used in certain situations.
- Changed the drupal_array_get_nested_value() function to return a reference
  (API addition).
- Changed the System module's hook_block_info() implementation to assign the
  "Main page content" and "System help" blocks to appropriate regions by
  default and prevent error messages on the block administration page (data
  structure change).
- Fixed regression: Non-node entities couldn't be accessed with
  EntityFieldQuery.
- Fixed regression: Optional radio buttons with an empty, non-NULL default
  value led to an illegal choice error when none were selected.
- Reorganized the testing framework to split setUp() into specific sub-methods
  and fix several regressions in the process.
- Fixed bug which made it impossible to search for strings that have not been
  translated into a particular language.
- Renamed the "Field" column on the Manage Fields screen to "Field type", since
  the former was confusing and inaccurate (UI change).
- Performance improvement: Removed needless call to system_rebuild_module_data()
  in field_sync_field_status(), greatly speeding up bulk module enable/disable.
- Fixed bug which prevented notifications from being sent when core, module, and
  theme updates are available.
- Fixed bug which prevented sub-themes from inheriting the default values of
  theme settings defined by the base theme.
- Fixed bug which prevented the jQuery UI Datepicker from being localized.
- Made Ajax alert dialogs respect error reporting settings.
- Fixed bug which prevented image styles from being deleted on PHP 5.4.
- Fixed bug: Language detection by domain only worked on port 80.
- Fixed regression: The first plural index on a page was not calculated
  correctly.
- Introduced generic entity language support. Entities may now declare their
  language property in hook_entity_info(), and modules working with entities
  may access the language using entity_language() (API change:
  http://drupal.org/node/1626346).
- Added EntityFieldQuery support for taxonomy bundles.
- Fixed issue where field form structure was incomplete if field_access()
  returned FALSE. Instead of being incomplete, the form structure now has
  #access set to FALSE and field form validation is skipped (data structure
  change: http://drupal.org/node/1663020).
- Fixed data loss issue due to field_has_data() returning inconsistent results.
  The fix adds an optional DANGEROUS_ACCESS_CHECK_OPT_OUT tag to entity field
  queries which field storage engines can respond to (API addition:
  http://drupal.org/node/1597378).
- Fixed notice: Undefined index: default_image in image_field_prepare_view()
- Numerous API documentation improvements.
- Additional automated test coverage.

Drupal 7.14, 2012-05-02
-----------------------
- Fixed "integrity constraint" fatal errors when rebuilding registry.
- Fixed custom logo and favicon functionality referencing incorrect paths.
- Fixed DB Case Sensitivity: Allow BINARY attribute in MySQL.
- Split field_bundle_settings out per bundle.
- Improve UX for machine names for fields (UI change).
- Fixed User pictures are not removed properly.
- Fixed HTTPS sessions not working in all cases.
- Fixed Regression: Required radios throw illegal choice error when none
  selected.
- Fixed allow autocompletion requests to include slashes.
- Eliminate $user->cache and {session}.cache in favor of
  $_SESSION['cache_expiration'][$bin] (Performance).
- Fixed focus jumps to tab when pressing enter on a form element within tab.
- Fixed race condition in locale() - duplicates in {locales_source}.
- Fixed Missing "Default image" per field instance.
- Quit clobbering people's work when they click the filter tips link
- Form API #states: Fix conditionals to allow OR and XOR constructions.
- Fixed Focus jumps to tab when pressing enter on a form element within tab.
  (Accessibility)
- Improved performance of node_access queries.
- Fixed Fieldsets inside vertical tabs have no title and can't be collapsed.
- Reduce size of cache_menu table (Performance).
- Fixed unnecessary aggregation of CSS/JS (Performance).
- Fixed taxonomy_autocomplete() produces SQL error for nonexistent field.
- Fixed HTML filter is not run first by default, despite default weight.
- Fixed Overlay does not work with prefixed URL paths.
- Better debug info for field errors (string change).
- Fixed Data corruption in comment IDs (results in broken threading on
  PostgreSQL).
- Fixed machine name not editable if every character is replaced.
- Fixed user picture not appearing in comment preview (Markup change).
- Added optional vid argument for taxonomy_get_term_by_name().
- Fixed Invalid Unicode code range in PREG_CLASS_UNICODE_WORD_BOUNDARY fails
  with PCRE 8.30.
- Fixed {trigger_assignments()}.hook has only 32 characters, is too short.
- Numerous fixes to run-tests.sh.
- Fixed Tests in profiles/[name]/modules cannot be run and cannot use a
  different profile for running tests.
- Numerous JavaScript performance fixes.
- Numerous documentation fixes.
- Fixed All pager links have an 'active' CSS class.
- Numerous upgrade path fixes; notably:
  - system_update_7061() fails on inserting files with same name but different
    case.
  - system_update_7061() converts filepaths too aggressively.
  - Trigger upgrade path: Node triggers removed when upgrading to 7-x from 6.25.

Drupal 7.13, 2012-05-02
-----------------------
- Fixed security issues (Multiple vulnerabilities), see SA-CORE-2012-002.

Drupal 7.12, 2012-02-01
-----------------------
- Fixed bug preventing custom menus from receiving an active trail.
- Fixed hook_field_delete() no longer invoked during field_purge_data().
- Fixed bug causing entity info cache to not be cleared with the rest of caches.
- Fixed file_unmanaged_copy() fails with Drupal 7.7+ and safe_mode() or
  open_basedir().
- Fixed Nested transactions throw exceptions when they got out of scope.
- Fixed bugs with the Return-Path when sending mail on both Windows and
  non-Windows systems.
- Fixed bug with DrupalCacheArray property visibility preventing others from
  extending it (API change: http://drupal.org/node/1422264).
- Fixed bug with handling of non-ASCII characters in file names (API change:
  http://drupal.org/node/1424840).
- Reconciled field maximum length with database column size in image and
  aggregator modules.
- Fixes to various core JavaScript files to allow for minification and
  aggregation.
- Fixed Prevent tests from deleting main installation's tables when
  parent::setUp() is not called.
- Fixed several Poll module bugs.
- Fixed several Shortcut module bugs.
- Added new hook_system_theme_info() to provide ability for contributed modules
  to test theme functionality.
- Added ability to cancel mail sending from hook_mail_alter().
- Added support for configurable PDO connection options, enabling master-master
  database replication.
- Numerous improvements to tests and test runner to pave the way for faster test
  runs.
- Expanded test coverage.
- Numerous API documentation improvements.
- Numerous performance improvements, including token replacement and render
  cache.

Drupal 7.11, 2012-02-01
-----------------------
- Fixed security issues (Multiple vulnerabilities), see SA-CORE-2012-001.

Drupal 7.10, 2011-12-05
-----------------------
- Fixed Content-Language HTTP header to not cause issues with Drush 5.x.
- Reduce memory usage of theme registry (performance).
- Fixed PECL upload progress bar for FileField
- Fixed running update.php doesn't always clear the cache.
- Fixed PDO exceptions on long titles.
- Fixed Overlay redirect does not include query string.
- Fixed D6 modules satisfy D7 module dependencies.
- Fixed the ordering of module hooks when using module_implements_alter().
- Fixed "floating" submit buttons during AJAX requests.
- Fixed timezone selected on install not propogating to admin account.
- Added msgctx context to JS translation functions, for feature parity with t().
- Profiles' .install files now available during hook_install_tasks().
- Added test coverage of 7.0 -> 7.x upgrade path.
- Numerous notice fixes.
- Numerous documentation improvements.
- Additional automated test coverage.

Drupal 7.9, 2011-10-26
----------------------
- Critical fixes to OpenID to spec violations that could allow for
  impersonation in certain scenarios. Existing OpenID users should see
  http://drupal.org/node/1120290#comment-5092796 for more information on
  transitioning.
- Fixed files getting lost when adding multiple files to multiple file fields
  at the same time.
- Improved usability of the clean URL test screens.
- Restored height/width attributes on images run through the theme system.
- Fixed usability bug with first password field being pre-filled by certain
  browser plugins.
- Fixed file_usage_list() so that it can return more than one result.
- Fixed bug preventing preview of private images on node form.
- Fixed PDO error when inserting an aggregator title longer than 255 characters.
- Spelled out what TRADITIONAL means in MySQL sql_mode.
- Deprecated "!=" operator for DBTNG; should be "<>".
- Added two new API functions (menu_tree_set_path()/menu_tree_get_path()) were
  added in order to enable setting the active menu trail for dynamically
  generated menu paths.
- Added new "fast 404" capability in settings.php to bypass Drupal bootstrap
  when serving 404 pages for certain file types.
- Added format_string() function which can perform string munging ala the t()
  function without the overhead of the translation system.
- Numerous #states system fixes.
- Numerous EntityFieldQuery, DBTNG, and SQLite fixes.
- Numerous Shortcut module fixes.
- Numerous language system fixes.
- Numerous token fixes.
- Numerous CSS fixes.
- Numerous upgrade path fixes.
- Numerous minor string fixes.
- Numerous notice fixes.

Drupal 7.8, 2011-08-31
----------------------
- Fixed critical upgrade path issue with multilingual sites, leading to lost
  content.
- Numerous fixes to upgrade path, preventing fatal errors due to incorrect
  dependencies.
- Fixed issue with saving files on hosts with open_basedir restrictions.
- Fixed Update manger error when used with Overlay.
- Fixed RTL support in Seven administration theme and Overlay.
- Fixes to nested transaction support.
- Introduced performance pattern to reduce Drupal core's RAM usage.
- Added support for HTML 5 tags to filter_xss_admin().
- Added exception handling to cron.
- Added new hook hook_field_widget_form_alter() for contribtued modules.
- element_validate_*() functions now available to contrib.
- Added new maintainers for several subsystems.
- Numerous testing system improvements.
- Numerous markup and CSS fixes.
- Numerous poll module fixes.
- Numerous notice/warning fixes.
- Numerous documentation fixes.
- Numerous token fixes.

Drupal 7.7, 2011-07-27
----------------------
- Fixed VERSION string.

Drupal 7.6, 2011-07-27
----------------------
- Fixed support for remote streamwrappers.
- AJAX now binds to 'click' instead of 'mousedown'.
- 'Translatable' flag on fields created in UI now defaults to FALSE, to match those created via the API.
- Performance enhancement to permissions page on large numbers of permissions.
- More secure password generation.
- Fix for temporary directory on Windows servers.
- run-tests.sh now uses proc_open() instead of pcntl_fork() for better Windows support.
- Numerous upgrade path fixes.
- Numerous documentation fixes.
- Numerous notice fixes.
- Numerous fixes to improve PHP 5.4 support.
- Numerous RTL improvements.

Drupal 7.5, 2011-07-27
----------------------
- Fixed security issue (Access bypass), see SA-CORE-2011-003.

Drupal 7.4, 2011-06-29
----------------------
- Rolled back patch that caused fatal errors in CTools, Feeds, and other modules using the class registry.
- Fixed critical bug with saving default images.
- Fixed fatal errors when uninstalling some modules.
- Added workaround for MySQL transaction support breaking on DDL statments.
- Improved page caching with external caching systems.
- Fix to Batch API, which was terminating too early.
- Numerous upgrade path fixes.
- Performance fixes.
- Additional test coverage.
- Numerous documentation fixes.

Drupal 7.3, 2011-06-29
----------------------
- Fixed security issue (Access bypass), see SA-CORE-2011-002.

Drupal 7.2, 2011-05-25
----------------------
- Added a default .gitignore file.
- Improved PostgreSQL and SQLite support.
- Numerous critical performance improvements.
- Numerous critical fixes to the upgrade path.
- Numerous fixes to language and translation systems.
- Numerous fixes to AJAX and #states systems.
- Improvements to the locking system.
- Numerous documentation fixes.
- Numerous styling and theme system fixes.
- Numerous fixes for schema mis-matches between Drupal 6 and 7.
- Minor internal API clean-ups.

Drupal 7.1, 2011-05-25
----------------------
- Fixed security issues (Cross site scripting, File access bypass), see SA-CORE-2011-001.

Drupal 7.0, 2011-01-05 
----------------------
- Database:
    * Fully rewritten database layer utilizing PHP 5's PDO abstraction layer.
    * Drupal now requires MySQL >= 5.0.15 or PostgreSQL >= 8.3.
    * Added query builders for INSERT, UPDATE, DELETE, MERGE, and SELECT queries.
    * Support for master/slave replication, transactions, multi-insert queries,
      and other features.
    * Added support for the SQLite database engine.
    * Default to InnoDB engine, rather than MyISAM, on MySQL when available.
      This offers increased scalability and data integrity.
- Security:
    * Protected cron.php -- cron will only run if the proper key is provided.
    * Implemented a pluggable password system and much stronger password hashes
      that are compatible with the Portable PHP password hashing framework.
    * Rate limited login attempts to prevent brute-force password guessing, and
      improved the flood control API to allow variable time windows and
      identifiers for limiting user access to resources.
    * Transformed the "Update status" module into the "Update manager" which
      can securely install or update modules and themes via a web interface.
- Usability:
    * Added contextual links (a.k.a. local tasks) to page elements, such as
      blocks, nodes, or comments, which allows to perform the most common tasks
      with a single click only.
    * Improved installer requirements check.
    * Improved support for integration of WYSIWYG editors.
    * Implemented drag-and-drop positioning for input format listings.
    * Implemented drag-and-drop positioning for language listing.
    * Implemented drag-and-drop positioning for poll options.
    * Provided descriptions and human-readable names for user permissions.
    * Removed comment controls for users.
    * Removed display order settings for comment module. Comment display
      order can now be customized using the Views module.
    * Removed the 'related terms' feature from taxonomy module since this can
      now be achieved with Field API.
    * Added additional features to the default installation profile, and
      implemented a "slimmed down" profile designed for developers.
    * Added a built-in, automated cron run feature, which is triggered by site
      visitors.
    * Added an administrator role which is assigned all permissions for
      installed modules automatically.
    * Image toolkits are now provided by modules (rather than requiring a
      manual file copy to the includes directory).
    * Added an edit tab to taxonomy term pages.
    * Redesigned password strength validator.
    * Redesigned the add content type screen.
    * Highlight duplicate URL aliases.
    * Renamed "input formats" to "text formats".
    * Moved text format permissions to the main permissions page.
    * Added configurable ability for users to cancel their own accounts.
    * Added "vertical tabs", a reusable interface component that features
      automatic summaries and increases usability.
    * Replaced fieldsets on node edit and add pages with vertical tabs.
- Performance:
    * Improved performance on uncached page views by loading multiple core
      objects in a single database query.
    * Improved performance for logged-in users by reducing queries for path
      alias lookups.
    * Improved support for HTTP proxies (including reverse proxies), allowing
      anonymous page views to be served entirely from the proxy.
- Documentation:
    * Hook API documentation now included in Drupal core.
- News aggregator:
    * Added OPML import functionality for RSS feeds.
    * Optionally, RSS feeds may be configured to not automatically generate feed blocks.
- Search:
    * Added support for language-aware searches.
- Aggregator:
    * Introduced architecture that allows pluggable parsers and processors for
      syndicating RSS and Atom feeds.
    * Added options to suspend updating specific feeds and never discard feeds
      items.
- Testing:
    * Added test framework and tests.
- Improved time zone support:
    * Drupal now uses PHP's time zone database when rendering dates in local
      time. Site-wide and user-configured time zone offsets have been converted
      to time zone names, e.g. Africa/Abidjan.
    * In some cases the upgrade and install scripts do not choose the preferred
      site default time zone. The automatically-selected time zone can be
      corrected at admin/config/regional/settings.
    * If your site is being upgraded from Drupal 6 and you do not have the
      contributed date or event modules installed, user time zone settings will
      fallback to the system time zone and will have to be reconfigured by each user.
    * User-configured time zones now serve as the default time zone for PHP
      date/time functions.
- Filter system:
    * Revamped the filter API and text format storage.
    * Added support for default text formats to be assigned on a per-role basis.
    * Refactored the HTML corrector to take advantage of PHP 5 features.
- User system:
    * Added clean API functions for creating, loading, updating, and deleting
      user roles and permissions.
    * Refactored the "access rules" component of user module: The user module
      now provides a simple interface for blocking single IP addresses. The
      previous functionality in the user module for restricting certain e-mail
      addresses and usernames is now available as a contributed module. Further,
      IP address range blocking is no longer supported and should be implemented
      at the operating system level.
    * Removed per-user themes: Contributed modules with similar functionality
      are available.
- OpenID:
    * Added support for Gmail and Google Apps for Domain identifiers. Users can
      now login with their user@example.com identifier when example.com is powered
      by Google.
    * Made the OpenID module more pluggable.
- Added code registry:
    * Using the registry, modules declare their includable files via their .info file,
      allowing Drupal to lazy-load classes and interfaces as needed.
- Theme system:
    * Removed the Bluemarine, Chameleon and Pushbutton themes. These themes live
      on as contributed themes (http://drupal.org/project/bluemarine,
      http://drupal.org/project/chameleon and http://drupal.org/project/pushbutton).
    * Added Stark theme to make analyzing Drupal's default HTML and CSS easier.
    * Added Seven as the default administration theme.
    * Variable preprocessing of theme hooks prior to template rendering now goes
      through two phases: a 'preprocess' phase and a new 'process' phase. See
      http://api.drupal.org/api/function/theme/7 for details.
    * Theme hooks implemented as functions (rather than as templates) can now
      also have preprocess (and process) functions. See
      http://api.drupal.org/api/function/theme/7 for details.
    * Added Bartik as the default theme.
- File handling:
    * Files are now first class Drupal objects with file_load(), file_save(),
      and file_validate() functions and corresponding hooks.
    * The file_move(), file_copy() and file_delete() functions now operate on
      file objects and invoke file hooks so that modules are notified and can
      respond to changes.
    * For the occasions when only basic file manipulation are needed--such as
      uploading a site logo--that don't require the overhead of databases and
      hooks, the current unmanaged copy, move and delete operations have been
      preserved but renamed to file_unmanaged_*().
    * Rewrote file handling to use PHP stream wrappers to enable support for
      both public and private files and to support pluggable storage mechanisms
      and access to remote resources (e.g. S3 storage or Flickr photos).
    * The mime_extension_mapping variable has been removed. Modules that need to
      alter the default MIME type extension mappings should implement
      hook_file_mimetype_mapping_alter().
    * Added the hook_file_url_alter() hook, which makes it possible to serve
      files from a CDN.
    * Added a field specifically for uploading files, previously provided by
      the contributed module FileField.
- Image handling:
    * Improved image handling, including better support for add-on image
      libraries.
    * Added API and interface for creating advanced image thumbnails.
    * Inclusion of additional effects such as rotate and desaturate.
    * Added a field specifically for uploading images, previously provided by
      the contributed module ImageField.
- Added aliased multi-site support:
    * Added support for mapping domain names to sites directories.
- Added RDF support:
    * Modules can declare RDF namespaces which are serialized in the <html> tag
      for RDFa support.
    * Modules can specify how their data structure maps to RDF.
    * Added support for RDFa export of nodes, comments, terms, users, etc. and
      their fields.
- Search engine optimization and web linking:
    * Added a rel="canonical" link on node and comment pages to prevent
      duplicate content indexing by search engines.
    * Added a default rel="shortlink" link on node and comment pages that
      advertises a short link as an alternative URL to third-party services.
    * Meta information is now alterable by all modules before rendering.
- Field API:
    * Custom data fields may be attached to nodes, users, comments and taxonomy
      terms.
    * Node bodies and teasers are now Field API fields instead of
      being a hard-coded property of node objects.
    * In addition, any other object type may register with Field API
      and allow custom data fields to be attached to itself.
    * Provides most of the features of the former Content Construction
      Kit (CCK) module.
    * Taxonomy terms are now Field API fields that can be added to any fieldable
      object.
- Installer:
    * Refactored the installer into an API that allows Drupal to be installed
      via a command line script.
- Page organization
    * Made the help text area a full featured region with blocks.
    * Site mission is replaced with the highlighted content block region and
      separate RSS feed description settings.
    * The footer message setting was removed in favor of custom blocks.
    * Made the main page content a block which can be moved and ordered
      with other blocks in the same region.
    * Blocks can now return structured arrays for later rendering just
      like page callbacks.
- Translation system
    * The translation system now supports message context (msgctxt).
    * Added support for translatable fields to Field API.
- JavaScript changes
    * Upgraded the core JavaScript library to jQuery version 1.4.4.
    * Upgraded the jQuery Forms library to 2.52.
    * Added jQuery UI 1.8.7, which allows improvements to Drupal's user
      experience.
- Better module version support
    * Modules now can specify which version of another module they depend on.
- Removed modules from core
    * The following modules have been removed from core, because contributed
      modules with similar functionality are available:
      * Blog API module
      * Ping module
      * Throttle module
- Improved node access control system.
    * All modules may now influence the access to a node at runtime, not just
      the module that defined a node.
    * Users may now be allowed to bypass node access restrictions without giving
      them complete access to the site.
    * Access control affects both published and unpublished nodes.
    * Numerous other improvements to the node access system.
- Actions system
    * Simplified definitions of actions and triggers.
    * Removed dependency on the combination of hooks and operations. Triggers
      now directly map to module hooks.
- Task handling
    * Added a queue API to process many or long-running tasks.
    * Added queue API support to cron API.
    * Added a locking framework to coordinate long-running operations across
      requests.

Drupal 6.23-dev, xxxx-xx-xx (development release)
---------------------------

Drupal 6.22, 2011-05-25
-----------------------
- Made Drupal 6 work better with IIS and Internet Explorer.
- Fixed .po file imports to work better with custom textgroups.
- Improved code documentation at various places.
- Fixed a variety of other bugs.

Drupal 6.21, 2011-05-25
-----------------------
- Fixed security issues (Cross site scripting), see SA-CORE-2011-001.

Drupal 6.20, 2010-12-15
-----------------------
- Fixed a variety of small bugs, improved code documentation.

Drupal 6.19, 2010-08-11
-----------------------
- Fixed a variety of small bugs, improved code documentation.

Drupal 6.18, 2010-08-11
-----------------------
- Fixed security issues (OpenID authentication bypass, File download access
  bypass, Comment unpublishing bypass, Actions cross site scripting),
  see SA-CORE-2010-002.

Drupal 6.17, 2010-06-02
-----------------------
- Improved PostgreSQL compatibility
- Better PHP 5.3 and PHP 4 compatibility
- Better browser compatibility of CSS and JS aggregation
- Improved logging for login failures
- Fixed an incompatibility with some contributed modules and the locking system
- Fixed a variety of other bugs.

Drupal 6.16, 2010-03-03
-----------------------
- Fixed security issues (Installation cross site scripting, Open redirection,
  Locale module cross site scripting, Blocked user session regeneration),
  see SA-CORE-2010-001.
- Better support for updated jQuery versions.
- Reduced resource usage of update.module.
- Fixed several issues relating to support of installation profiles and
  distributions.
- Added a locking framework to avoid data corruption on long operations.
- Fixed a variety of other bugs.

Drupal 6.15, 2009-12-16
-----------------------
- Fixed security issues (Cross site scripting), see SA-CORE-2009-009.
- Fixed a variety of other bugs.

Drupal 6.14, 2009-09-16
-----------------------
- Fixed security issues (OpenID association cross site request forgeries,
  OpenID impersonation and File upload), see SA-CORE-2009-008.
- Changed the system modules page to not run all cache rebuilds; use the
  button on the performance settings page to achieve the same effect.
- Added support for PHP 5.3.0 out of the box.
- Fixed a variety of small bugs.

Drupal 6.13, 2009-07-01
-----------------------
- Fixed security issues (Cross site scripting, Input format access bypass and
  Password leakage in URL), see SA-CORE-2009-007.
- Fixed a variety of small bugs.

Drupal 6.12, 2009-05-13
-----------------------
- Fixed security issues (Cross site scripting), see SA-CORE-2009-006.
- Fixed a variety of small bugs.

Drupal 6.11, 2009-04-29
-----------------------
- Fixed security issues (Cross site scripting and limited information
  disclosure), see SA-CORE-2009-005
- Fixed performance issues with the menu router cache, the update
  status cache and improved cache invalidation
- Fixed a variety of small bugs.

Drupal 6.10, 2009-02-25
-----------------------
- Fixed a security issue, (Local file inclusion on Windows),
  see SA-CORE-2009-003
- Fixed node_feed() so custom fields can show up in RSS feeds.
- Improved PostgreSQL compatibility.
- Fixed a variety of small bugs.

Drupal 6.9, 2009-01-14
----------------------
- Fixed security issues, (Access Bypass, Validation Bypass and Hardening
  against SQL injection), see SA-CORE-2009-001
- Made HTTP request checking more robust and informative.
- Fixed HTTP_HOST checking to work again with HTTP 1.0 clients and
  basic shell scripts.
- Removed t() calls from all schema documentation. Suggested best practice
  changed for contributed modules, see http://drupal.org/node/322731.
- Fixed a variety of small bugs.

Drupal 6.8, 2008-12-11
----------------------
- Removed a previous change incompatible with PHP 5.1.x and lower.

Drupal 6.7, 2008-12-10
----------------------
- Fixed security issues, (Cross site request forgery and Cross site scripting), see SA-2008-073
- Updated robots.txt and .htaccess to match current file use.
- Fixed a variety of small bugs.

Drupal 6.6, 2008-10-22
----------------------
- Fixed security issues, (File inclusion, Cross site scripting), see SA-2008-067
- Fixed a variety of small bugs.

Drupal 6.5, 2008-10-08
----------------------
- Fixed security issues, (File upload access bypass, Access rules bypass,
  BlogAPI access bypass), see SA-2008-060.
- Fixed a variety of small bugs.

Drupal 6.4, 2008-08-13
----------------------
- Fixed a security issue (Cross site scripting, Arbitrary file uploads via
  BlogAPI, Cross site request forgeries and Various Upload module
  vulnerabilities), see SA-2008-047.
- Improved error messages during installation.
- Fixed a bug that prevented AHAH handlers to be attached to radios widgets.
- Fixed a variety of small bugs.

Drupal 6.3, 2008-07-09
----------------------
- Fixed security issues, (Cross site scripting, cross site request forgery,
  session fixation and SQL injection), see SA-2008-044.
- Slightly modified installation process to prevent file ownership issues on
  shared hosts.
- Improved PostgreSQL compatibility (rewritten queries; custom blocks).
- Upgraded to jQuery 1.2.6.
- Performance improvements to search, menu handling and form API caches.
- Fixed Views compatibility issues (Views for Drupal 6 requires Drupal 6.3+).
- Fixed a variety of small bugs.

Drupal 6.2, 2008-04-09
----------------------
- Fixed a variety of small bugs.
- Fixed a security issue (Access bypasses), see SA-2008-026.

Drupal 6.1, 2008-02-27
----------------------
- Fixed a variety of small bugs.
- Fixed a security issue (Cross site scripting), see SA-2008-018.

Drupal 6.0, 2008-02-13
----------------------
- New, faster and better menu system.
- New watchdog as a hook functionality.
   * New hook_watchdog that can be implemented by any module to route log
     messages to various destinations.
   * Expands the severity levels from 3 (Error, Warning, Notice) to the 8
     levels defined in RFC 3164.
   * The watchdog module is now called dblog, and is optional, but enabled by
     default in the default installation profile.
   * Extended the database log module so log messages can be filtered.
   * Added syslog module: useful for monitoring large Drupal installations.
- Added optional e-mail notifications when users are approved, blocked, or
  deleted.
- Drupal works with error reporting set to E_ALL.
- Added scripts/drupal.sh to execute Drupal code from the command line. Useful
  to use Drupal as a framework to build command-line tools.
- Made signature support optional and made it possible to theme signatures.
- Made it possible to filter the URL aliases on the URL alias administration
  screen.
- Language system improvements:
    * Support for right to left languages.
    * Language detection based on parts of the URL.
    * Browser based language detection.
    * Made it possible to specify a node's language.
    * Support for translating posts on the site to different languages.
    * Language dependent path aliases.
    * Automatically import translations when adding a new language.
    * JavaScript interface translation.
    * Automatically import a module's translation upon enabling that module.
- Moved "PHP input filter" to a standalone module so it can be deleted for
  security reasons.
- Usability:
    * Improved handling of teasers in posts.
    * Added sticky table headers.
    * Check for clean URL support automatically with JavaScript.
    * Removed default/settings.php. Instead the installer will create it from
      default.settings.php.
    * Made it possible to configure your own date formats.
    * Remember anonymous comment posters.
    * Only allow modules and themes to be enabled that have explicitly been
      ported to the correct core API version.
    * Can now specify the minimum PHP version required for a module within the
      .info file.
    * Drupal core no longer requires CREATE TEMPORARY TABLES or LOCK TABLES
      database rights.
    * Dynamically check password strength and confirmation.
    * Refactored poll administration.
    * Implemented drag-and-drop positioning for blocks, menu items, taxonomy
      vocabularies and terms, forums, profile fields, and input format filters.
- Theme system:
    * Added .info files to themes and made it easier to specify regions and
      features.
    * Added theme registry: modules can directly provide .tpl.php files for
      their themes without having to create theme_ functions.
    * Used the Garland theme for the installation and maintenance pages.
    * Added theme preprocess functions for themes that are templates.
    * Added support for themeable functions in JavaScript.
- Refactored update.php to a generic batch API to be able to run time-consuming
  operations in multiple subsequent HTTP requests.
- Installer:
    * Themed the installer with the Garland theme.
    * Added form to provide initial site information during installation.
    * Added ability to provide extra installation steps programmatically.
    * Made it possible to import interface translations during installation.
- Added the HTML corrector filter:
    * Fixes faulty and chopped off HTML in postings.
    * Tags are now automatically closed at the end of the teaser.
- Performance:
    * Made it easier to conditionally load .include files and split up many core
      modules.
    * Added a JavaScript aggregator.
    * Added block-level caching, improving performance for both authenticated
      and anonymous users.
    * Made Drupal work correctly when running behind a reverse proxy like
      Squid or Pound.
- File handling improvements:
    * Entries in the files table are now keyed to a user instead of a node.
    * Added reusable validation functions to check for uploaded file sizes,
      extensions, and image resolution.
    * Added ability to create and remove temporary files during a cron job.
- Forum improvements:
    * Any node type may now be posted in a forum.
- Taxonomy improvements:
    * Descriptions for terms are now shown on taxonomy/term pages as well
      as RSS feeds.
    * Added versioning support to categories by associating them with node
      revisions.
- Added support for OpenID.
- Added support for triggering configurable actions.
- Added the Update status module to automatically check for available updates
  and warn sites if they are missing security updates or newer versions.
  Sites deploying from CVS should use http://drupal.org/project/cvs_deploy.
  Advanced settings provided by http://drupal.org/project/update_advanced.
- Upgraded the core JavaScript library to jQuery version 1.2.3.
- Added a new Schema API, which provides built-in support for core and
  contributed modules to work with databases other than MySQL.
- Removed drupal.module. The functionality lives on as the Site network
  contributed module (http://drupal.org/project/site_network).
- Removed old system updates. Updates from Drupal versions prior to 5.x will
  require upgrading to 5.x before upgrading to 6.x.

Drupal 5.23, 2010-08-11
-----------------------
- Fixed security issues (File download access bypass, Comment unpublishing
  bypass), see SA-CORE-2010-002.

Drupal 5.22, 2010-03-03
-----------------------
- Fixed security issues (Open redirection, Locale module cross site scripting,
  Blocked user session regeneration), see SA-CORE-2010-001.

Drupal 5.21, 2009-12-16
-----------------------
- Fixed a security issue (Cross site scripting), see SA-CORE-2009-009.
- Fixed a variety of small bugs.

Drupal 5.20, 2009-09-16
-----------------------
- Avoid security problems resulting from writing Drupal 6-style menu
  declarations.
- Fixed security issues (session fixation), see SA-CORE-2009-008.
- Fixed a variety of small bugs.

Drupal 5.19, 2009-07-01
-----------------------
- Fixed security issues (Cross site scripting and Password leakage in URL), see
  SA-CORE-2009-007.          
- Fixed a variety of small bugs.

Drupal 5.18, 2009-05-13
-----------------------
- Fixed security issues (Cross site scripting), see SA-CORE-2009-006.
- Fixed a variety of small bugs.

Drupal 5.17, 2009-04-29
-----------------------
- Fixed security issues (Cross site scripting and limited information
  disclosure) see SA-CORE-2009-005.
- Fixed a variety of small bugs.

Drupal 5.16, 2009-02-25
-----------------------
- Fixed a security issue, (Local file inclusion on Windows), see SA-CORE-2009-004.
- Fixed a variety of small bugs.

Drupal 5.15, 2009-01-14
-----------------------
- Fixed security issues, (Hardening against SQL injection), see
  SA-CORE-2009-001
- Fixed HTTP_HOST checking to work again with HTTP 1.0 clients and basic shell
  scripts.
- Fixed a variety of small bugs.

Drupal 5.14, 2008-12-11
-----------------------
- removed a previous change incompatible with PHP 5.1.x and lower.

Drupal 5.13, 2008-12-10
-----------------------
- fixed a variety of small bugs.
- fixed security issues, (Cross site request forgery and Cross site scripting), see SA-2008-073
- updated robots.txt and .htaccess to match current file use.

Drupal 5.12, 2008-10-22
-----------------------
- fixed security issues, (File inclusion), see SA-2008-067

Drupal 5.11, 2008-10-08
-----------------------
- fixed a variety of small bugs.
- fixed security issues, (File upload access bypass, Access rules bypass,
  BlogAPI access bypass, Node validation bypass), see SA-2008-060

Drupal 5.10, 2008-08-13
-----------------------
- fixed a variety of small bugs.
- fixed security issues, (Cross site scripting, Arbitrary file uploads via
  BlogAPI and Cross site request forgery), see SA-2008-047

Drupal 5.9, 2008-07-23
----------------------
- fixed a variety of small bugs.
- fixed security issues, (Session fixation), see SA-2008-046

Drupal 5.8, 2008-07-09
----------------------
- fixed a variety of small bugs.
- fixed security issues, (Cross site scripting, cross site request forgery, and
  session fixation), see SA-2008-044

Drupal 5.7, 2008-01-28
----------------------
- fixed the input format configuration page.
- fixed a variety of small bugs.

Drupal 5.6, 2008-01-10
----------------------
- fixed a variety of small bugs.
- fixed a security issue (Cross site request forgery), see SA-2008-005
- fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
- fixed a security issue (Cross site scripting, register_globals), see SA-2008-007

Drupal 5.5, 2007-12-06
----------------------
- fixed missing missing brackets in a query in the user module.
- fixed taxonomy feed bug introduced by SA-2007-031

Drupal 5.4, 2007-12-05
----------------------
- fixed a variety of small bugs.
- fixed a security issue (SQL injection), see SA-2007-031

Drupal 5.3, 2007-10-17
----------------------
- fixed a variety of small bugs.
- fixed a security issue (HTTP response splitting), see SA-2007-024
- fixed a security issue (Arbitrary code execution via installer), see SA-2007-025
- fixed a security issue (Cross site scripting via uploads), see SA-2007-026
- fixed a security issue (User deletion cross site request forgery), see SA-2007-029
- fixed a security issue (API handling of unpublished comment), see SA-2007-030

Drupal 5.2, 2007-07-26
----------------------
- changed hook_link() $teaser argument to match documentation.
- fixed a variety of small bugs.
- fixed a security issue (cross-site request forgery), see SA-2007-017
- fixed a security issue (cross-site scripting), see SA-2007-018

Drupal 5.1, 2007-01-29
----------------------
- fixed security issue (code execution), see SA-2007-005
- fixed a variety of small bugs.

Drupal 5.0, 2007-01-15
----------------------
- Completely retooled the administration page
    * /Admin now contains an administration page which may be themed
    * Reorganised administration menu items by task and by module
    * Added a status report page with detailed PHP/MySQL/Drupal information
- Added web-based installer which can:
    * Check installation and run-time requirements
    * Automatically generate the database configuration file
    * Install pre-made installation profiles or distributions
    * Import the database structure with automatic table prefixing
    * Be localized
- Added new default Garland theme
- Added color module to change some themes' color schemes
- Included the jQuery JavaScript library 1.0.4 and converted all core JavaScript to use it
- Introduced the ability to alter mail sent from system
- Module system:
    * Added .info files for module meta-data
    * Added support for module dependencies
    * Improved module installation screen
    * Moved core modules to their own directories
    * Added support for module uninstalling
- Added support for different cache backends
- Added support for a generic "sites/all" directory.
- Usability:
    * Added support for auto-complete forms (AJAX) to user profiles.
    * Made it possible to instantly assign roles to newly created user accounts.
    * Improved configurability of the contact forms.
    * Reorganized the settings pages.
    * Made it easy to investigate popular search terms.
    * Added a 'select all' checkbox and a range select feature to administration tables.
    * Simplified the 'break' tag to split teasers from body.
    * Use proper capitalization for titles, menu items and operations.
- Integrated urlfilter.module into filter.module
- Block system:
    * Extended the block visibility settings with a role specific setting.
    * Made it possible to customize all block titles.
- Poll module:
    * Optionally allow people to inspect all votes.
    * Optionally allow people to cancel their vote.
- Distributed authentication:
    * Added default server option.
- Added default robots.txt to control crawlers.
- Database API:
    * Added db_table_exists().
- Blogapi module:
    * 'Blogapi new' and 'blogapi edit' nodeapi operations.
- User module:
    * Added hook_profile_alter().
    * E-mail verification is made optional.
    * Added mass editing and filtering on admin/user/user.
- PHP Template engine:
    * Add the ability to look for a series of suggested templates.
    * Look for page templates based upon the path.
    * Look for block templates based upon the region, module, and delta.
- Content system:
    * Made it easier for node access modules to work well with each other.
    * Added configurable content types.
    * Changed node rendering to work with structured arrays.
- Performance:
    * Improved session handling: reduces database overhead.
    * Improved access checking: reduces database overhead.
    * Made it possible to do memcached based session management.
    * Omit sidebars when serving a '404 - Page not found': saves CPU cycles and bandwidth.
    * Added an 'aggressive' caching policy.
    * Added a CSS aggregator and compressor (up to 40% faster page loads).
- Removed the archive module.
- Upgrade system:
    * Created space for update branches.
- Form API:
    * Made it possible to programmatically submit forms.
    * Improved api for multistep forms.
- Theme system:
    * Split up and removed drupal.css.
    * Added nested lists generation.
    * Added a self-clearing block class.

Drupal 4.7.11, 2008-01-10
-------------------------
- fixed a security issue (Cross site request forgery), see SA-2008-005
- fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
- fixed a security issue (Cross site scripting, register_globals), see SA-2008-007

Drupal 4.7.10, 2007-12-06
-------------------------
- fixed taxonomy feed bug introduced by SA-2007-031

Drupal 4.7.9, 2007-12-05
------------------------
- fixed a security issue (SQL injection), see SA-2007-031

Drupal 4.7.8, 2007-10-17
------------------------
- fixed a security issue (HTTP response splitting), see SA-2007-024
- fixed a security issue (Cross site scripting via uploads), see SA-2007-026
- fixed a security issue (API handling of unpublished comment), see SA-2007-030

Drupal 4.7.7, 2007-07-26
------------------------
- fixed security issue (XSS), see SA-2007-018

Drupal 4.7.6, 2007-01-29
------------------------
- fixed security issue (code execution), see SA-2007-005

Drupal 4.7.5, 2007-01-05
------------------------
- Fixed security issue (XSS), see SA-2007-001
- Fixed security issue (DoS), see SA-2007-002

Drupal 4.7.4, 2006-10-18
------------------------
- Fixed security issue (XSS), see SA-2006-024
- Fixed security issue (CSRF), see SA-2006-025
- Fixed security issue (Form action attribute injection), see SA-2006-026

Drupal 4.7.3, 2006-08-02
------------------------
- Fixed security issue (XSS), see SA-2006-011

Drupal 4.7.2, 2006-06-01
------------------------
- Fixed critical upload issue, see SA-2006-007
- Fixed taxonomy XSS issue, see SA-2006-008
- Fixed a variety of small bugs.

Drupal 4.7.1, 2006-05-24
------------------------
- Fixed critical SQL issue, see SA-2006-005
- Fixed a serious upgrade related bug.
- Fixed a variety of small bugs.

Drupal 4.7.0, 2006-05-01
------------------------
- Added free tagging support.
- Added a site-wide contact form.
- Theme system:
    * Added the PHPTemplate theme engine and removed the Xtemplate engine.
    * Converted the bluemarine theme from XTemplate to PHPTemplate.
    * Converted the pushbutton theme from XTemplate to PHPTemplate.
- Usability:
    * Reworked the 'request new password' functionality.
    * Reworked the node and comment edit forms.
    * Made it easy to add nodes to the navigation menu.
    * Added site 'offline for maintenance' feature.
    * Added support for auto-complete forms (AJAX).
    * Added support for collapsible page sections (JS).
    * Added support for resizable text fields (JS).
    * Improved file upload functionality (AJAX).
    * Reorganized some settings pages.
    * Added friendly database error screens.
    * Improved styling of update.php.
- Refactored the forms API.
    * Made it possible to alter, extend or theme forms.
- Comment system:
    * Added support for "mass comment operations" to ease repetitive tasks.
    * Comment moderation has been removed.
- Node system:
    * Reworked the revision functionality.
    * Removed the bookmarklet code. Third-party modules can now handle
      This.
- Upgrade system:
    * Allows contributed modules to plug into the upgrade system.
- Profiles:
    * Added a block to display author information along with posts.
    * Added support for private profile fields.
- Statistics module:
    * Added the ability to track page generation times.
    * Made it possible to block certain IPs/hostnames.
- Block system:
    * Added support for theme-specific block regions.
- Syndication:
    * Made the aggregator module parse Atom feeds.
    * Made the aggregator generate RSS feeds.
    * Added RSS feed settings.
- XML-RPC:
    * Replaced the XML-RPC library by a better one.
- Performance:
    * Added 'loose caching' option for high-traffic sites.
    * Improved performance of path aliasing.
    * Added the ability to track page generation times.
- Internationalization:
    * Improved Unicode string handling API.
    * Added support for PHP's multibyte string module.
- Added support for PHP5's 'mysqli' extension.
- Search module:
    * Made indexer smarter and more robust.
    * Added advanced search operators (e.g. phrase, node type, ...).
    * Added customizable result ranking.
- PostgreSQL support:
    * Removed dependency on PL/pgSQL procedural language.
- Menu system:
    * Added support for external URLs.
- Queue module:
    * Removed from core.
- HTTP handling:
    * Added support for a tolerant Base URL.
    * Output URIs relative to the root, without a base tag.

Drupal 4.6.11, 2007-01-05
-------------------------
- Fixed security issue (XSS), see SA-2007-001
- Fixed security issue (DoS), see SA-2007-002

Drupal 4.6.10, 2006-10-18
-------------------------
- Fixed security issue (XSS), see SA-2006-024
- Fixed security issue (CSRF), see SA-2006-025
- Fixed security issue (Form action attribute injection), see SA-2006-026

Drupal 4.6.9, 2006-08-02
------------------------
- Fixed security issue (XSS), see SA-2006-011

Drupal 4.6.8, 2006-06-01
------------------------
- Fixed critical upload issue, see SA-2006-007
- Fixed taxonomy XSS issue, see SA-2006-008

Drupal 4.6.7, 2006-05-24
------------------------
- Fixed critical SQL issue, see SA-2006-005

Drupal 4.6.6, 2006-03-13
------------------------
- Fixed bugs, including 4 security vulnerabilities.

Drupal 4.6.5, 2005-12-12
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.6.4, 2005-11-30
------------------------
- Fixed bugs, including 3 security vulnerabilities.

Drupal 4.6.3, 2005-08-15
------------------------
- Fixed bugs, including a critical "arbitrary PHP code execution" bug.

Drupal 4.6.2, 2005-06-29
------------------------
- Fixed bugs, including two critical "arbitrary PHP code execution" bugs.

Drupal 4.6.1, 2005-06-01
------------------------
- Fixed bugs, including a critical input validation bug.

Drupal 4.6.0, 2005-04-15
------------------------
- PHP5 compliance
- Search:
    * Added UTF-8 support to make it work with all languages.
    * Improved search indexing algorithm.
    * Improved search output.
    * Impose a throttle on indexing of large sites.
    * Added search block.
- Syndication:
    * Made the ping module ping pingomatic.com which, in turn, will ping all the major ping services.
    * Made Drupal generate RSS 2.0 feeds.
    * Made RSS feeds extensible.
    * Added categories to RSS feeds.
    * Added enclosures to RSS feeds.
- Flood control mechanism:
    * Added a mechanism to throttle certain operations.
- Usability:
    * Refactored the block configuration pages.
    * Refactored the statistics pages.
    * Refactored the watchdog pages.
    * Refactored the throttle module configuration.
    * Refactored the access rules page.
    * Refactored the content administration page.
    * Introduced forum configuration pages.
    * Added a 'add child page' link to book pages.
- Contact module:
    * Added a simple contact module that allows users to contact each other using e-mail.
- Multi-site configuration:
    * Made it possible to run multiple sites from a single code base.
- Added an image API: enables better image handling.
- Block system:
    * Extended the block visibility settings.
- Theme system:
    * Added new theme functions.
- Database backend:
    * The PEAR database backend is no longer supported.
- Performance:
    * Improved performance of the forum topics block.
    * Improved performance of the tracker module.
    * Improved performance of the node pages.
- Documentation:
    * Improved and extended PHPDoc/Doxygen comments.

Drupal 4.5.8, 2006-03-13
------------------------
- Fixed bugs, including 3 security vulnerabilities.

Drupal 4.5.7, 2005-12-12
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.5.6, 2005-11-30
------------------------
- Fixed bugs, including 3 security vulnerabilities.

Drupal 4.5.5, 2005-08-15
------------------------
- Fixed bugs, including a critical "arbitrary PHP code execution" bug.

Drupal 4.5.4, 2005-06-29
------------------------
- Fixed bugs, including two critical "arbitrary PHP code execution" bugs.

Drupal 4.5.3, 2005-06-01
------------------------
- Fixed bugs, including a critical input validation bug.

Drupal 4.5.2, 2005-01-15
------------------------
- Fixed bugs: a cross-site scripting (XSS) vulnerability has been fixed.

Drupal 4.5.1, 2004-12-01
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.5.0, 2004-10-18
------------------------
- Navigation:
    * Made it possible to add, delete, rename and move menu items.
    * Introduced tabs and subtabs for local tasks.
    * Reorganized the navigation menus.
- User management:
    * Added support for multiple roles per user.
    * Made it possible to add custom profile fields.
    * Made it possible to browse user profiles by field.
- Node system:
    * Added support for node-level permissions.
- Comment module:
    * Made it possible to leave contact information without having to register.
- Upload module:
    * Added support for uploading documents (includes images).
- Forum module:
    * Added support for sticky forum topics.
    * Made it possible to track forum topics.
- Syndication:
    * Added support for RSS ping-notifications of http://technorati.com/.
    * Refactored the categorization of syndicated news items.
    * Added an URL alias for 'rss.xml'.
    * Improved date parsing.
- Database backend:
    * Added support for multiple database connections.
    * The PostgreSQL backend does no longer require PEAR.
- Theme system:
    * Changed all GIFs to PNGs.
    * Reorganised the handling of themes, template engines, templates and styles.
    * Unified and extended the available theme settings.
    * Added theme screenshots.
- Blocks:
    * Added 'recent comments' block.
    * Added 'categories' block.
- Blogger API:
    * Added support for auto-discovery of blogger API via RSD.
- Performance:
    * Added support for sending gzip compressed pages.
    * Improved performance of the forum module.
- Accessibility:
    * Improved the accessibility of the archive module's calendar.
    * Improved form handling and error reporting.
    * Added HTTP redirects to prevent submitting twice when refreshing right after a form submission.
- Refactored 403 (forbidden) handling and added support for custom 403 pages.
- Documentation:
    * Added PHPDoc/Doxygen comments.
- Filter system:
    * Added support for using multiple input formats on the site
    * Expanded the embedded PHP-code feature so it can be used everywhere
    * Added support for role-dependent filtering, through input formats
- UI translation:
    * Managing translations is now completely done through the administration interface
    * Added support for importing/exporting gettext .po files

Drupal 4.4.3, 2005-06-01
------------------------
- Fixed bugs, including a critical input validation bug.

Drupal 4.4.2, 2004-07-04
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.4.1, 2004-05-01
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.4.0, 2004-04-01
------------------------
- Added support for the MetaWeblog API and MovableType extensions.
- Added a file API: enables better document management.
- Improved the watchdog and search module to log search keys.
- News aggregator:
    * Added support for conditional GET.
    * Added OPML feed subscription list.
    * Added support for <image>, <pubDate>, <dc:date>, <dcterms:created>, <dcterms:issued> and <dcterms:modified>.
- Comment module:
    * Made it possible to disable the "comment viewing controls".
- Performance:
    * Improved module loading when serving cached pages.
    * Made it possible to automatically disable modules when under heavy load.
    * Made it possible to automatically disable blocks when under heavy load.
    * Improved performance and memory footprint of the locale module.
- Theme system:
    * Made all theme functions start with 'theme_'.
    * Made all theme functions return their output.
    * Migrated away from using the BaseTheme class.
    * Added many new theme functions and refactored existing theme functions.
    * Added avatar support to 'Xtemplate'.
    * Replaced theme 'UnConeD' by 'Chameleon'.
    * Replaced theme 'Marvin' by 'Pushbutton'.
- Usability:
    * Added breadcrumb navigation to all pages.
    * Made it possible to add context-sensitive help to all pages.
    * Replaced drop-down menus by radio buttons where appropriate.
    * Removed the 'magic_quotes_gpc = 0' requirement.
    * Added a 'book navigation' block.
- Accessibility:
    * Made themes degrade gracefully in absence of CSS.
    * Grouped form elements using '<fieldset>' and '<legend>' tags.
    * Added '<label>' tags to form elements.
- Refactored 404 (file not found) handling and added support for custom 404 pages.
- Improved the filter system to prevent conflicts between filters:
    * Made it possible to change the order in which filters are applied.
- Documentation:
    * Added PHPDoc/Doxygen comments.

Drupal 4.3.2, 2004-01-01
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.3.1, 2003-12-01
------------------------
- Fixed bugs: no critical bugs were identified.

Drupal 4.3.0, 2003-11-01
------------------------
- Added support for configurable URLs.
- Added support for sortable table columns.
- Database backend:
    * Added support for selective database table prefixing.
- Performance:
    * Optimized many SQL queries for speed by converting left joins to inner joins.
- Comment module:
    * Rewrote the comment housekeeping code to be much more efficient and scalable.
    * Changed the comment module to use the standard pager.
- User module:
    * Added support for multiple sessions per user.
    * Added support for anonymous user sessions.
- Forum module:
    * Improved the forum views and the themability thereof.
- Book module:
    * Improved integration of non-book nodes in the book outline.
- Usability:
    * Added support for "mass node operations" to ease repetitive tasks.
    * Added support for breadcrumb navigation to several modules' user pages.
    * Integrated the administration pages with the normal user pages.

Drupal 4.2.0, 2003-08-01
------------------------
- Added support for clean URLs.
- Added textarea hook and support for onload attributes: enables integration of WYSIWYG editors.
- Rewrote the RSS/RDF parser:
    * It will now use PHP's built-in XML parser to parse news feeds.
- Rewrote the administration pages:
    * Improved the navigational elements and added breadcrumb navigation.
    * Improved the look and feel.
    * Added context-sensitive help.
- Database backend:
    * Fixed numerous SQL queries to make Drupal ANSI compliant.
    * Added MSSQL database scheme.
- Search module:
    * Changed the search module to use implicit AND'ing instead of implicit OR'ing.
- Node system:
    * Replaced the "post content" permission by more fine-grained permissions.
    * Improved content submission:
        + Improved teasers: teasers are now optional, teaser length can be configured, teaser and body are edited in a single textarea, users will no longer be bothered with teasers when the post is too short for one.
        + Added the ability to preview both the short and the full version of your posts.
    * Extended the node API which allows for better integration.
    * Added default node settings to control the behavior for promotion, moderation and other options.
- Themes:
    * Replaced theme "Goofy" by "Xtemplate", a template driven theme.
- Removed the 'register_globals = on' requirement.
- Added better installation instructions.

Drupal 4.1.0, 2003-02-01
------------------------
- Collaboratively revised and expanded the Drupal documentation.
- Rewrote comment.module:
    * Reintroduced comment rating/moderation.
    * Added support for comment paging.
    * Performance improvements: improved comment caching, faster SQL queries, etc.
- Rewrote block.module:
    * Performance improvements: blocks are no longer rendered when not displayed.
- Rewrote forum.module:
    * Added a lot of features one can find in stand-alone forum software including but not limited to support for topic paging, added support for icons, rewrote the statistics module, etc.
- Rewrote statistics.module:
    * Collects access counts for each node, referrer logs, number of users/guests.
    * Export blocks displaying top viewed nodes over last 24 hour period, top viewed nodes over all time, last nodes viewed, how many users/guest online.
- Added throttle.module:
    * Auto-throttle congestion control mechanism: Drupal can adapt itself based on the server load.
- Added profile.module:
    * Enables to extend the user and registration page.
- Added pager support to the main page.
- Replaced weblogs.module by ping.module:
    * Added support for normal and RSS notifications of http://blo.gs/.
    * Added support for RSS ping-notifications of http://weblogs.com/.
- Removed the rating module
- Themes:
    * Removed a significant portion of hard-coded mark-up.

Drupal 4.0.0, 2002-06-15
------------------------
- Added tracker.module:
    * Replaces the previous "your [site]" links (recent comments and nodes).
- Added weblogs.module:
    * This will ping weblogs.com when new content is promoted.
- Added taxonomy module which replaces the meta module.
    * Supports relations, hierarchies and synonyms.
- Added a caching system:
    * Speeds up pages for anonymous users and reduces system load.
- Added support for external SMTP libraries.
- Added an archive extension to the calendar.
- Added support for the Blogger API.
- Themes:
    * Cleaned up the theme system.
    * Moved themes that are not maintained to contributions CVS repository.
- Database backend:
    * Changed to PEAR database abstraction layer.
    * Using ANSI SQL queries to be more portable.
- Rewrote the user system:
    * Added support for Drupal authentication through XML-RPC and through a Jabber server.
    * Added support for modules to add more user data.
    * Users may delete their own account.
    * Added who's new and who's online blocks.
- Changed block system:
    * Various hard coded blocks are now dynamic.
    * Blocks can now be enabled and/or be set by the user.
    * Blocks can be set to only show up on some pages.
    * Merged box module with block module.
- Node system:
    * Blogs can be updated.
    * Teasers (abstracts) on all node types.
    * Improved error checking.
    * Content versioning support.
    * Usability improvements.
- Improved book module to support text, HTML and PHP pages.
- Improved comment module to mark new comments.
- Added a general outliner which will let any node type be linked to a book.
- Added an update script that lets you upgrade from previous releases or on a day to day basis when using the development tree.
- Search module:
    * Improved the search system by making it context sensitive.
    * Added indexing.
- Various updates:
    * Changed output to valid XHTML.
    * Improved multiple sites using the same Drupal database support.
    * Added support for session IDs in URLs instead of cookies.
    * Made the type of content on the front page configurable.
    * Made each cloud site have its own settings.
    * Modules and themes can now be enabled/disabled using the administration pages.
    * Added URL abstraction for links.
    * Usability changes (renamed links, better UI, etc).
- Collaboratively revised and expanded the Drupal documentation.

Drupal 3.0.1, 2001-10-15
------------------------
- Various updates:
    * Added missing translations
    * Updated the themes: tidied up some HTML code and added new Drupal logos.

Drupal 3.0.0, 2001-09-15
------------------------
- Major overhaul of the entire underlying design:
    * Everything is based on nodes: nodes are a conceptual "black box" to couple and manage different types of content and that promotes reusing existing code, thus reducing the complexity and size of Drupal as well as improving long-term stability.
- Rewrote submission/moderation queue and renamed it to queue.module.
- Removed FAQ and documentation module and merged them into a "book module".
- Removed ban module and integrated it into account.module as "access control":
    * Access control is based on much more powerful regular expressions (regex) now rather than on MySQL pattern matching.
- Rewrote watchdog and submission throttle:
    * Improved watchdog messages and added watchdog filter.
- Rewrote headline code and renamed it to import.module and export.module:
    * Added various improvements, including a better parser, bundles and better control over individual feeds.
- Rewrote section code and renamed it to meta.module:
    * Supports unlimited amount of nested topics. Topics can be nested to create a multi-level hierarchy.
- Rewrote configuration file resolving:
    * Drupal tries to locate a configuration file that matches your domain name or uses conf.php if the former failed. Note also that the configuration files got renamed from .conf to .php for security's sake on mal-configured Drupal sites.
- Added caching support which makes Drupal extremely scalable.
- Added access.module:
    * Allows you to set up 'roles' (groups) and to bind a set of permissions to each group.
- Added blog.module.
- Added poll.module.
- Added system.module:
    * Moved most of the configuration options from hostname.conf to the new administration section.
    * Added support for custom "filters".
- Added statistics.module
- Added moderate.module:
    * Allows to assign users editorial/moderator rights to certain nodes or topics.
- Added page.module:
    * Allows creation of static (and dynamic) pages through the administration interface.
- Added help.module:
    * Groups all available module documentation on a single page.
- Added forum.module:
    * Added an integrated forum.
- Added cvs.module and cvs-to-sql.pl:
    * Allows to display and mail CVS log messages as daily digests.
- Added book.module:
    * Allows collaborative handbook writing: primary used for Drupal documentation.
- Removed cron.module and integrated it into conf.module.
- Removed module.module as it was no longer needed.
- Various updates:
    * Added "auto-post new submissions" feature versus "moderate new submissions".
    * Introduced links/Drupal tags: [[link]]
    * Added preview functionality when submitting new content (such as a story) from the administration pages.
    * Made the administration section only show those links a user has access to.
    * Made all modules use specific form_* functions to guarantee a rock-solid forms and more consistent layout.
    * Improved scheduler:
        + Content can be scheduled to be 'posted', 'queued' and 'hidden'.
    * Improved account module:
        + Added "access control" to allow/deny certain usernames/e-mail addresses/hostnames.
    * Improved locale module:
        + Added new overview to easy the translation process.
    * Improved comment module:
        + Made it possible to permanently delete comments.
    * Improved rating module
    * Improved story module:
        + Added preview functionality for administrators.
        + Made it possible to permanently delete stories.
    * Improved themes:
        + W3C validation on a best effort basis.
        + Removed $theme->control() from themes.
        + Added theme "goofy".
- Collaboratively revised and expanded the Drupal documentation.

Drupal 2.0.0, 2001-03-15
------------------------
- Rewrote the comment/discussion code:
    * Comment navigation should be less confusing now.
    * Additional/alternative display and order methods have been added.
    * Modules can be extended with a "comment system": modules can embed the existing comment system without having to write their own, duplicate comment system.
- Added sections and section manager:
    * Story sections can be maintained from the administration pages.
    * Story sections make the open submission more adaptive in that you can set individual post, dump and expiration thresholds for each section according to the story type and urgency level: stories in certain sections do not "expire" and might stay interesting and active as time passes by, whereas news-related stories are only considered "hot" over a short period of time.
- Multiple vhosts + multiple directories:
    * You can set up multiple Drupal sites on top of the same physical source tree either by using vhosts or sub-directories.
- Added "user ratings" similar to SlashCode's Karma or Scoop's Mojo:
    * All rating logic is packed into a module to ease experimenting with different rating heuristics/algorithms.
- Added "search infrastructure":
    * Improved search page and integrated search functionality in the administration pages.
- Added translation / localization / internationalization support:
    * Because many people would love to see their website showing a lot less of English, and far more of their own language, Drupal provides a framework to set up a multi-lingual website or to overwrite the default English text in English.
- Added fine-grained user permission (or group) system:
    * Users can be granted access to specific administration sections. Example: a FAQ maintainer can be given access to maintain the FAQ and translators can be given access to the translation pages.
- Added FAQ module
- Changed the "open submission queue" into a (optional) module.
- Various updates:
    * Improved account module:
        + User accounts can be deleted.
        + Added fine-grained permission support.
    * Improved block module
    * Improved diary module:
        + Diary entries can be deleted
    * Improved headline module:
        + Improved parser to support more "generic" RDF/RSS/XML backend.
    * Improved module module
    * Improved watchdog module
    * Improved database abstraction layer
    * Improved themes:
        + W3C validation on a best effort basis
        + Added theme "example" (alias "Stone Age")
    * Added new scripts to directory "scripts"
    * Added directory "misc"
    * Added CREDITS file
- Revised documentation

Drupal 1.0.0, 2001-01-15
------------------------
- Initial release

File

CHANGELOG.txt
View source
  1. Drupal 7.xxx, xxxx-xx-xx (development version)
  2. ------------------------
  3. Drupal 7.100, 2024-03-06
  4. ------------------------
  5. - Security improvements
  6. - Announcements module added
  7. Drupal 7.99, 2023-12-06
  8. -----------------------
  9. - Various security improvements
  10. - Various bug fixes, optimizations and improvements
  11. Drupal 7.98, 2023-06-07
  12. -----------------------
  13. - Various security improvements
  14. - Various bug fixes, optimizations and improvements
  15. Drupal 7.97, 2023-04-21
  16. -----------------------
  17. - Fix PHP 5.x regression caused by SA-CORE-2023-005
  18. Drupal 7.96, 2023-04-19
  19. -----------------------
  20. - Fixed security issues:
  21. - SA-CORE-2023-005
  22. Drupal 7.95, 2023-03-15
  23. -----------------------
  24. - Fixed security issues:
  25. - SA-CORE-2023-004
  26. Drupal 7.94, 2022-12-14
  27. -----------------------
  28. - Hotfix for book.module and Select query properties
  29. Drupal 7.93, 2022-12-07
  30. -----------------------
  31. - Improved support for PHP 8.2
  32. - Minimum PHP version changed to PHP 5.3
  33. - Various security hardenings
  34. - Various bug fixes, optimizations and improvements
  35. Drupal 7.92, 2022-09-07
  36. -----------------------
  37. - Improved support for PHP 8.1
  38. - Various security hardenings
  39. - Various bug fixes, optimizations and improvements
  40. Drupal 7.91, 2022-07-20
  41. -----------------------
  42. - Fixed security issues:
  43. - SA-CORE-2022-012
  44. Drupal 7.90, 2022-06-01
  45. -----------------------
  46. - Improved support for PHP 8.1
  47. - Improved support for PostgreSQL
  48. - Various bug fixes, optimizations and improvements
  49. Drupal 7.89, 2022-03-02
  50. -----------------------
  51. - Bug fixes for PHP 8.1
  52. - Fix tests for PostgreSQL
  53. Drupal 7.88, 2022-02-15
  54. -----------------------
  55. - Fixed security issues:
  56. - SA-CORE-2022-003
  57. Drupal 7.87, 2022-01-19
  58. -----------------------
  59. - Fix regression caused by jQuery UI position() backport
  60. Drupal 7.86, 2022-01-18
  61. -----------------------
  62. - Fixed security issues:
  63. - SA-CORE-2022-001
  64. - SA-CORE-2022-002
  65. Drupal 7.85, 2022-01-12
  66. -----------------------
  67. - Fix session cookies for sites with different base_urls but a shared domain
  68. Drupal 7.84, 2021-12-13
  69. -----------------------
  70. - Hotfix for session cookie domain on www subdomains
  71. Drupal 7.83, 2021-12-01
  72. -----------------------
  73. - Initial support for PHP 8.1
  74. - The has_js cookie has been removed (but can be re-enabled)
  75. - The leading www. is no longer stripped from cookie domain by default
  76. - The user entity now has a "changed" property
  77. - Introduced a skip_permissions_hardening setting
  78. - Changes to the password reset process to avoid email and username enumeration
  79. - Various bug fixes, optimizations and improvements
  80. Drupal 7.82, 2021-07-21
  81. -----------------------
  82. - Fixed security issues:
  83. - SA-CORE-2021-004
  84. Drupal 7.81, 2021-06-02
  85. -----------------------
  86. - Block Google FLoC by default
  87. - Testing and accessibility enhancements
  88. - Various bug fixes, optimizations and improvements
  89. Drupal 7.80, 2021-04-20
  90. -----------------------
  91. - Fixed security issues:
  92. - SA-CORE-2021-002
  93. Drupal 7.79, 2021-04-07
  94. -----------------------
  95. - Initial support for PHP 8
  96. - Support for SameSite cookie attribute
  97. - Avoid write for unchanged fields (opt-in)
  98. Drupal 7.78, 2021-01-19
  99. -----------------------
  100. - Fixed security issues:
  101. - SA-CORE-2021-001
  102. Drupal 7.77, 2020-12-03
  103. -----------------------
  104. - Hotfix for schema.prefixed tables
  105. Drupal 7.76, 2020-12-02
  106. -----------------------
  107. - Support for MySQL 8
  108. - Core tests pass in SQLite
  109. - Better user flood control logging
  110. Drupal 7.75, 2020-11-26
  111. -----------------------
  112. - Fixed security issues:
  113. - SA-CORE-2020-013
  114. Drupal 7.74, 2020-11-17
  115. -----------------------
  116. - Fixed security issues:
  117. - SA-CORE-2020-012
  118. Drupal 7.73, 2020-09-16
  119. -----------------------
  120. - Fixed security issues:
  121. - SA-CORE-2020-007
  122. Drupal 7.72, 2020-06-17
  123. -----------------------
  124. - Fixed security issues:
  125. - SA-CORE-2020-004
  126. Drupal 7.71, 2020-06-03
  127. -----------------------
  128. - Fix for jQuery Form bug in Chromium-based browsers
  129. - Full support for PHP 7.4
  130. Drupal 7.70, 2020-05-19
  131. -----------------------
  132. - Fixed security issues:
  133. - SA-CORE-2020-002
  134. - SA-CORE-2020-003
  135. Drupal 7.69, 2019-12-18
  136. -----------------------
  137. - Fixed security issues:
  138. - SA-CORE-2019-012
  139. Drupal 7.68, 2019-12-04
  140. -----------------------
  141. - Fixed: Hide toolbar when printing
  142. - Fixed: Settings returned via ajax are not run through hook_js_alter()
  143. - Fixed: Use drupal_http_build_query() in drupal_http_request()
  144. - Fixed: DrupalRequestSanitizer not found fatal error when bootstrap phase order is changed
  145. - Fixed: Block web.config in .htaccess (and vice-versa)
  146. - Fixed: Create "scripts" element to align rendering workflow to how "styles" are handled
  147. - PHP 7.3: Fixed 'Cannot change session id when session is active'
  148. - PHP 7.1: Fixed 'A non-numeric value encountered in theme_pager()'
  149. - PHP 7.x: Fixed file.inc generated .htaccess does not cover PHP 7
  150. - PHP 5.3: Fixed check_plain() 'Invalid multibyte sequence in argument' test failures
  151. - Fixed: Allow passing data as array to drupal_http_request()
  152. - Fixed: Skip module_invoke/module_hook in calling hook_watchdog (excessive function_exist)
  153. - Fixed: HTTP status 200 returned for 'Additional uncaught exception thrown while handling exception'
  154. - Fixed: theme_table() should take an optional footer variable and produce
  155. - Fixed: 'uasort() expects parameter 1 to be array, null given in node_view_multiple()'
  156. - [regression] Fix default.settings.php permission
  157. Drupal 7.67, 2019-05-08
  158. -----------------------
  159. - Fixed security issues:
  160. - SA-CORE-2019-007
  161. Drupal 7.66, 2019-04-17
  162. -----------------------
  163. - Fixed security issues:
  164. - SA-CORE-2019-006
  165. Drupal 7.65, 2019-03-20
  166. -----------------------
  167. - Fixed security issues:
  168. - SA-CORE-2019-004
  169. Drupal 7.64, 2019-02-06
  170. -----------------------
  171. - [regression] Unset the 'host' header in drupal_http_request() during redirect
  172. - Fixed: 7.x does not have Phar protection and Phar tests are failing on Drupal 7
  173. - Fixed: Notice: Undefined index: display_field in file_field_widget_value() (line 582 of /module/file/file.field.inc)
  174. - Performance improvement: Registry rebuild should not parse the same file twice in the same request
  175. - Fixed _registry_update() to clear caches after transaction is committed
  176. Drupal 7.63, 2019-01-16
  177. -----------------------
  178. - Fixed a fatal error for some Drush users introduced by SA-CORE-2019-002.
  179. Drupal 7.62, 2019-01-15
  180. -----------------------
  181. - Fixed security issues:
  182. - SA-CORE-2019-001
  183. - SA-CORE-2019-002
  184. Drupal 7.61, 2018-11-07
  185. -----------------------
  186. - File upload validation functions and hook_file_validate() implementations are
  187. now always passed the correct file URI.
  188. - The default form cache expiration of 6 hours is now configurable (API
  189. addition: https://www.drupal.org/node/2857751).
  190. - Allowed callers of drupal_http_request() to optionally specify an explicit
  191. Host header.
  192. - Allowed the + character to appear in usernames.
  193. - PHP 7.2: Fixed Archive_Tar incompatibility.
  194. - PHP 7.2: Removed deprecated function each().
  195. - PHP 7.2: Avoid count() calls on uncountable variables.
  196. - PHP 7.2: Removed deprecated create_function() call.
  197. - PHP 7.2: Make sure variables are arrays in theme_links().
  198. - Fixed theme-settings.php not being loaded on cached forms
  199. - Fixed problem with IE11 & Chrome(PointerEvents enabled) & some Firefox scroll to the top of the page after dragging the bottom item with jquery 1.5 <-> 1.11
  200. Drupal 7.60, 2018-10-18
  201. ------------------------
  202. - Fixed security issues. See SA-CORE-2018-006.
  203. Drupal 7.59, 2018-04-25
  204. -----------------------
  205. - Fixed security issues (remote code execution). See SA-CORE-2018-004.
  206. Drupal 7.58, 2018-03-28
  207. -----------------------
  208. - Fixed security issues (remote code execution). See SA-CORE-2018-002.
  209. Drupal 7.57, 2018-02-21
  210. -----------------------
  211. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2018-001.
  212. Drupal 7.56, 2017-06-21
  213. -----------------------
  214. - Fixed security issues (access bypass). See SA-CORE-2017-003.
  215. Drupal 7.55, 2017-06-07
  216. -----------------------
  217. - Fixed incompatibility with PHP versions 7.0.19 and 7.1.5 due to duplicate
  218. DATE_RFC7231 definition.
  219. - Made Drupal core pass all automated tests on PHP 7.1.
  220. - Allowed services such as Let's Encrypt to work with Drupal on Apache, by
  221. making Drupal's .htaccess file allow access to the .well-known directory
  222. defined by RFC 5785.
  223. - Made new Drupal sites work correctly on Apache 2.4 when the mod_access_compat
  224. Apache module is disabled.
  225. - Fixed Drupal's URL-generating functions to always encode '[' and ']' so that
  226. the URLs will pass HTML5 validation.
  227. - Various additional bug fixes.
  228. - Various API documentation improvements.
  229. - Additional automated test coverage.
  230. Drupal 7.54, 2017-02-01
  231. -----------------------
  232. - Modules are now able to define theme engines (API addition:
  233. https://www.drupal.org/node/2826480).
  234. - Logging of searches can now be disabled (new option in the administrative
  235. interface).
  236. - Added menu tree render structure to (pre-)process hooks for theme_menu_tree()
  237. (API addition: https://www.drupal.org/node/2827134).
  238. - Added new function for determining whether an HTTPS request is being served
  239. (API addition: https://www.drupal.org/node/2824590).
  240. - Fixed incorrect default value for short and medium date formats on the date
  241. type configuration page.
  242. - File validation error message is now removed after subsequent upload of valid
  243. file.
  244. - Numerous bug fixes.
  245. - Numerous API documentation improvements.
  246. - Additional performance improvements.
  247. - Additional automated test coverage.
  248. Drupal 7.53, 2016-12-07
  249. -----------------------
  250. - Fixed drag and drop support on newer Chrome/IE 11+ versions after 7.51 update
  251. when jQuery is updated to 1.7-1.11.0.
  252. Drupal 7.52, 2016-11-16
  253. -----------------------
  254. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2016-005.
  255. Drupal 7.51, 2016-10-05
  256. -----------------------
  257. - The Update module now also checks for updates to a disabled theme that is
  258. used as an admin theme.
  259. - Exceptions thrown in dblog_watchdog() are now caught and ignored.
  260. - Clarified the warning that appears when modules are missing or have moved.
  261. - Log messages are now XSS filtered on display.
  262. - Draggable tables now work on touch screen devices.
  263. - Added a setting for allowing double underscores in CSS identifiers
  264. (https://www.drupal.org/node/2810369).
  265. - If a user navigates away from a page while an Ajax request is running they
  266. will no longer get an error message saying "An Ajax HTTP request terminated
  267. abnormally".
  268. - The system_region_list() API function now takes an optional third parameter
  269. which allows region name translations to be skipped when they are not needed
  270. (API addition: https://www.drupal.org/node/2810365).
  271. - Numerous performance improvements.
  272. - Numerous bug fixes.
  273. - Numerous API documentation improvements.
  274. - Additional automated test coverage.
  275. Drupal 7.50, 2016-07-07
  276. -----------------------
  277. - Added a new "administer fields" permission for trusted users, which is
  278. required in addition to other permissions to use the field UI
  279. (https://www.drupal.org/node/2483307).
  280. - Added clickjacking protection to Drupal core by setting the X-Frame-Options
  281. header to SAMEORIGIN by default (https://www.drupal.org/node/2735873).
  282. - Added support for full UTF-8 (emojis, Asian symbols, mathematical symbols) on
  283. MySQL and other database drivers when the site and database are configured to
  284. allow it (https://www.drupal.org/node/2761183).
  285. - Improved performance by avoiding a re-scan of directories when a file is
  286. missing; instead, trigger a PHP warning (minor API change:
  287. https://www.drupal.org/node/2581445).
  288. - Made it possible to use any PHP callable in Ajax form callbacks, form API
  289. form-building functions, and form API wrapper callbacks (API addition:
  290. https://www.drupal.org/node/2761169).
  291. - Fixed that following a password reset link while logged in leaves users unable
  292. to change their password (minor user interface change:
  293. https://www.drupal.org/node/2759023).
  294. - Implemented various fixes for automated test failures on PHP 5.4+ and PHP 7.
  295. Drupal core automated tests now pass in these environments.
  296. - Improved support for PHP 7 by fixing various problems.
  297. - Fixed various bugs with PHP 5.5+ imagerotate(), including when incorrect
  298. color indices are passed in.
  299. - Fixed a regression introduced in Drupal 7.43 that allowed files uploaded by
  300. anonymous users to be lost after form validation errors, and that also caused
  301. regressions with certain contributed modules.
  302. - Fixed a regression introduced in Drupal 7.36 which caused the default value
  303. of hidden textarea fields to be ignored.
  304. - Fixed robots.txt to allow search engines to access CSS, JavaScript and image
  305. files.
  306. - Changed wording on the Update Manager settings page to clarify that the
  307. option to check for disabled module updates also applies to uninstalled
  308. modules (administrative-facing translatable string change).
  309. - Changed the help text when editing menu links and configuring URL redirect
  310. actions so that it does not reference "Drupal" or the drupal.org website
  311. (administrative-facing translatable string change).
  312. - Fixed the locale safety check that is used to ensure that translations are
  313. safe to allow for tokens in the href/src attributes of translated strings.
  314. - Fixed that URL generation only works on port 80 when using domain based
  315. language negotation.
  316. - Made method="get" forms work inside the administrative overlay. The fix adds
  317. a new hidden field to these forms when they appear inside the overlay (minor
  318. data structure change).
  319. - Increased maxlength of menu link title input fields in the node form and
  320. menu link form from 128 to 255 characters.
  321. - Removed meaningless post-check=0 and pre-check=0 cache control headers from
  322. Drupal HTTP responses.
  323. - Added a .editorconfig file to auto-configure editors that support it.
  324. - Added --directory option to run-tests.sh for easier test discovery of all
  325. tests within a project.
  326. - Made run-tests.sh exit with a failure code when there are test fails or
  327. problems running the script.
  328. - Fixed that cookies from previous tests are still present when a new test
  329. starts in DrupalWebTestCase.
  330. - Improved performance of queries on the {authmap} database table.
  331. - Fixed handling of missing files and functions inside the registry.
  332. - Fixed Ajax handling for tableselect form elements that use checkboxes.
  333. - Fixed a bug which caused ip_address() to return nothing when the client IP
  334. address and proxy IP address are the same.
  335. - Added a new option to format_xml_elements() to allow for already encoded
  336. values.
  337. - Changed the {history} table's node ID field to be an unsigned integer, to
  338. match the same field in the {node} table and to prevent errors with very
  339. large node IDs.
  340. - Added an explicit page callback to the "admin/people/create" menu item in the
  341. User module (minor data structure change). Previously this automatically
  342. inherited the page callback from the parent "admin/people" menu item, which
  343. broke contributed modules that override the "admin/people" page.
  344. - Numerous small bug fixes.
  345. - Numerous API documentation improvements.
  346. - Additional automated test coverage.
  347. Drupal 7.44, 2016-06-15
  348. -----------------------
  349. - Fixed security issues (privilege escalation). See SA-CORE-2016-002.
  350. Drupal 7.43, 2016-02-24
  351. -----------------------
  352. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2016-001.
  353. Drupal 7.42, 2016-02-03
  354. -----------------------
  355. - Stopped invoking hook_flush_caches() on every cron run, since some modules
  356. use that hook for expensive operations that are only needed on cache clears.
  357. - Changed the default .htaccess and web.config to block Composer-related files.
  358. - Added static caching to module_load_include() to improve performance.
  359. - Fixed double-encoding bugs in select field widgets provided by the Options
  360. module. The fix deprecates the 'strip_tags' property on option widgets and
  361. replaces it with a new 'strip_tags_and_unescape' property (minor data
  362. structure change).
  363. - Improved MySQL 5.7 support by changing the MySQL database driver to stop
  364. using the ANSI SQL mode alias, which has different meanings for different
  365. MySQL versions.
  366. - Fixed a regression introduced in Drupal 7.39 which prevented autocomplete
  367. functionality from working on servers that are not configured to
  368. automatically recognize index.php.
  369. - Updated the Archive_Tar PEAR package to the latest 1.4.0 release, to fix bugs
  370. with tar file handling on various operating systems.
  371. - Fixed fatal errors on node preview when a field is displayed in the node
  372. teaser but hidden in the full node view. The fix removes a
  373. field_attach_prepare_view() call from the node_preview() function since it is
  374. redundant with one in the node preview theme layer.
  375. - Improved the description of the "Trimmed" format option on text fields
  376. (translatable string change, and minor UI and data structure change).
  377. - Numerous small bug fixes.
  378. - Numerous API documentation improvements.
  379. - Additional automated test coverage.
  380. Drupal 7.41, 2015-10-21
  381. -----------------------
  382. - Fixed security issues (open redirect). See SA-CORE-2015-004.
  383. Drupal 7.40, 2015-10-14
  384. -----------------------
  385. - Made Drupal's code for parsing .info files run much faster and use much less
  386. memory.
  387. - Prevented drupal_http_request() from returning an error when it receives a
  388. 201 through 206 HTTP status code.
  389. - Added support for autoloading traits via the registry on sites running PHP
  390. 5.4 or higher.
  391. - Allowed the user-picture.tpl.php theme template to have HTML classes besides
  392. the default "user-picture" class printed in it (markup change).
  393. - Fixed the URL text filter to convert e-mail addresses with plus signs into
  394. mailto: links.
  395. - Added alternate text to file icons displayed by the File module, to improve
  396. accessibility (string change, and minor API addition to theme_file_icon()).
  397. - Changed one-time login link failure messages to be displayed as errors or
  398. warnings as appropriate, rather than as regular status messages (minor UI
  399. change and data structure change).
  400. - Changed the default settings.php configuration to exclude private files from
  401. the "404_fast_paths" behavior.
  402. - Changed the page that displays filter tips for a particular text format, for
  403. example filter/tips/full_html, to return "page not found" or "access denied"
  404. if the format does not exist or the user does not have access to it. This
  405. change adds a new menu item to the Filter module's hook_menu() entry (minor
  406. data structure change).
  407. - Added a new hook, hook_block_cid_parts_alter(), to allow modules to alter the
  408. cache keys used for caching a particular block.
  409. - Made drupal_set_message() display and return messages when "0" is passed in
  410. as the message to set.
  411. - Fixed non-functional "Files displayed by default" setting on file fields.
  412. - The "worker callback" provided in hook_cron_queue_info() and the "finished"
  413. callback specified during batch processing can now be any PHP callable
  414. instead of just functions.
  415. - Prevented drupal_set_time_limit() from decreasing the time limit in the case
  416. where the PHP maximum execution time is already unlimited.
  417. - Changed the default thousand marker for numeric fields from a space ("1 000")
  418. to nothing ("1000") (minor UI change: https://www.drupal.org/node/1388376).
  419. - Prevented malformed theme .info files (without a "name" key) from causing
  420. exceptions during menu rebuilds. If an .info file without a "name" key is
  421. found in a module or theme directory, Drupal will now use the module or
  422. theme's machine name as the display name instead.
  423. - Made the format column in the {date_format_locale} database table
  424. case-sensitive, to match the equivalent column in the {date_formats} table.
  425. - Fixed a bug in the Statistics module that caused JavaScript files attached to
  426. a node while it is being viewed to be omitted from the page.
  427. - Added an optional 'project:' prefix that can be added to dependencies in a
  428. module's .info file to indicate which project the dependency resides in (API
  429. addition: https://www.drupal.org/node/2299747).
  430. - Fixed various bugs that occurred after hooks were invoked early in the Drupal
  431. bootstrap and that caused module_implements() and drupal_alter() to cache an
  432. incomplete set of hook implementations for later use.
  433. - Set the X-Content-Type-Options header to "nosniff" when possible, to prevent
  434. certain web browsers from picking an unsafe MIME type.
  435. - Prevented the database API from executing multiple queries at once on MySQL,
  436. if the site's PHP version is new enough to do so. This is a secondary defense
  437. against SQL injection (API change: https://www.drupal.org/node/2463973).
  438. - Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused the upgrade
  439. to fail when there were multiple file records pointing to the same file.
  440. - Numerous small bug fixes.
  441. - Numerous API documentation improvements.
  442. - Additional automated test coverage.
  443. Drupal 7.39, 2015-08-19
  444. -----------------------
  445. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-003.
  446. Drupal 7.38, 2015-06-17
  447. -----------------------
  448. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-002.
  449. Drupal 7.37, 2015-05-07
  450. -----------------------
  451. - Fixed a regression in Drupal 7.36 which caused certain kinds of content types
  452. to become disabled if they were defined by a no-longer-enabled module.
  453. - Removed a confusing description regarding automatic time zone detection from
  454. the user account form (minor UI and data structure change).
  455. - Allowed custom HTML tags with a dash in the name to pass through filter_xss()
  456. when specified in the list of allowed tags.
  457. - Allowed hook_field_schema() implementations to specify indexes for fields
  458. based on a fixed-length column prefix (rather than the entire column), as was
  459. already allowed in hook_schema() implementations.
  460. - Fixed PDO exceptions on PostgreSQL when accessing invalid entity URLs.
  461. - Added a sites/all/libraries folder to the codebase, with instructions for
  462. using it.
  463. - Added a description to the "Administer text formats and filters" permission
  464. on the Permissions page (string change).
  465. - Numerous small bug fixes.
  466. - Numerous API documentation improvements.
  467. - Additional automated test coverage.
  468. Drupal 7.36, 2015-04-01
  469. -----------------------
  470. - Added a 'file_public_schema' variable which allows modules that define
  471. publicly-accessible streams in hook_stream_wrappers() to bypass file download
  472. access checks when processing managed file upload fields.
  473. - Fixed a bug that caused database query tags not to be added to search-related
  474. database queries under many circumstances, and which prevented the
  475. corresponding hook_query_TAG_alter() implementations from being called.
  476. - Fixed the "for" attribute on managed file upload field labels to improve
  477. accessibility (minor markup change).
  478. - Added a 'javascript_always_use_jquery' variable which can be set to FALSE by
  479. sites that may not need jQuery loaded on all pages, and a 'requires_jquery'
  480. option to drupal_add_js() which modules can set to FALSE when adding
  481. JavaScript files that have no dependency on jQuery (API addition:
  482. https://www.drupal.org/node/2462717).
  483. - Fixed incorrect foreign keys in the User module's role_permission and
  484. users_roles database tables.
  485. - Changed permission descriptions throughout Drupal core to consistently link
  486. to relevant administrative pages, regardless of whether the user viewing the
  487. Permissions page can view the page being linked to (minor UI change).
  488. - Fixed the drupal_add_region_content() function so that it actually adds
  489. content to the page.
  490. - Added an 'image_suppress_itok_output' variable to allow sites already using
  491. the existing 'image_allow_insecure_derivatives' variable to also prevent
  492. security tokens from appearing in image derivative URLs.
  493. - Fixed double-escaping of theme names in the Block module administrative
  494. interface (minor string change).
  495. - Added basic support for Xdebug when running automated tests.
  496. - Fixed a bug which caused previewing a node to remove elements from the node
  497. being edited. With this fix, calling node_preview() will no longer modify the
  498. passed-in node object (minor API change).
  499. - Added a user_has_role() function to check whether a user has a particular
  500. role (API addition: https://www.drupal.org/node/2462411).
  501. - Fixed installation failures when an opcode cache is enabled.
  502. - Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused private
  503. files to be inaccessible.
  504. - Fixed a bug in the Drupal 6 to Drupal 7 upgrade path which caused user
  505. pictures to be lost.
  506. - Fixed missing language code in hook_field_attach_view_alter() when it is
  507. invoked from field_view_field().
  508. - Stopped sending ETag and Last-Modified headers for uncached page requests,
  509. since they break caching for certain Varnish and Nginx configurations.
  510. - Changed the Simpletest module to allow PSR-4 test classes to be used in
  511. Drupal 7.
  512. - Fixed a fatal error that occurred when using the Comment module's "Unpublish
  513. comment containing keyword(s)" action.
  514. - Changed the "lang" attribute on language links to "xml:lang" so it validates
  515. as XHTML (minor markup change).
  516. - Prevented the form API from allowing arrays to be submitted for various form
  517. elements, such as textfields, textareas, and password fields (API change:
  518. https://www.drupal.org/node/2462723).
  519. - Fixed a bug in the Contact module which caused the global user object to have
  520. the incorrect name and e-mail address during the remainder of the page
  521. request after the contact form is submitted.
  522. - Numerous small bug fixes.
  523. - Numerous API documentation improvements.
  524. - Additional automated test coverage.
  525. Drupal 7.35, 2015-03-18
  526. -----------------------
  527. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2015-001.
  528. Drupal 7.34, 2014-11-19
  529. -----------------------
  530. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-006.
  531. Drupal 7.33, 2014-11-07
  532. -----------------------
  533. - Began storing the file modification time of each module and theme in the
  534. {system} database table so that contributed modules can use it to identify
  535. recently changed modules and themes (minor data structure change to the
  536. return value of system_get_info() and other related functions).
  537. - Added a "Did you mean?" feature to the run-tests.sh script for running
  538. automated tests from the command line, to help developers who are attempting
  539. to run a particular test class or group.
  540. - Changed the date format used in various HTTP headers output by Drupal core
  541. from RFC 1123 format to RFC 7231 format.
  542. - Added a "block_cache_bypass_node_grants" variable to allow sites which have
  543. node access modules enabled to use the block cache if desired (API addition).
  544. - Made image derivative generation HTTP requests return a 404 error (rather
  545. than a 500 error) when the source image does not exist.
  546. - Fixed a bug which caused user pictures to be removed from the user object
  547. after saving, and resulted in data loss if the user account was subsequently
  548. re-saved.
  549. - Fixed a bug in which field_has_data() did not return TRUE for fields that
  550. only had data in older entity revisions, leading to loss of the field's data
  551. when the field configuration was edited.
  552. - Fixed a bug which caused the Ajax progress throbber to appear misaligned in
  553. many situatons (minor styling change).
  554. - Prevented the Bartik theme from lower-casing the "Permalink" link on
  555. comments, for improved multilingual support (minor UI change).
  556. - Added a "preferred_menu_links" tag to the database query that is used by
  557. menu_link_get_preferred() to find the preferred menu link for a given path,
  558. to make it easier to alter.
  559. - Increased the maximum allowed length of block titles to 255 characters
  560. (database schema change to the {block} table).
  561. - Removed the Field module's field_modules_uninstalled() function, since it did
  562. not do anything when it was invoked.
  563. - Added a "theme_hook_original" variable to templates and theme functions and
  564. an optional sitewide theme debug mode, to provide contextual information in
  565. the page's HTML to theme developers. The theme debug mode is based on the one
  566. used with Twig in Drupal 8 and can be accessed by setting the "theme_debug"
  567. variable to TRUE (API addition).
  568. - Added an entity_view_mode_prepare() API function to allow entity-defining
  569. modules to properly invoke hook_entity_view_mode_alter(), and used it
  570. throughout Drupal core to fix bugs with the invocation of that hook (API
  571. change: https://www.drupal.org/node/2369141).
  572. - Security improvement: Made the database API's orderBy() method sanitize the
  573. sort direction ("ASC" or "DESC") for queries built with db_select(), so that
  574. calling code does not have to.
  575. - Changed the RDF module to consistently output RDF metadata for nodes and
  576. comments near where the node is rendered in the HTML (minor markup and data
  577. structure change).
  578. - Added an HTML class to RDFa metatags throughout Drupal to prevent them from
  579. accidentally affecting the site appearance (minor markup change).
  580. - Fixed a bug in the Unicode requirements check which prevented installing
  581. Drupal on PHP 5.6.
  582. - Fixed a bug which caused drupal_get_bootstrap_phase() to abort the bootstrap
  583. when called early in the page request.
  584. - Renamed the "Search result" view mode to "Search result highlighting input"
  585. to better reflect how it is used (UI change).
  586. - Improved database queries generated by EntityFieldQuery in the case where
  587. delta or language condition groups are used, to reduce the number of INNER
  588. JOINs (this is a minor data structure change affecting code which implements
  589. hook_query_alter() on these queries).
  590. - Removed special-case behavior for file uploads which allowed user #1 to
  591. bypass maximum file size and user quota limits.
  592. - Numerous small bug fixes.
  593. - Numerous API documentation improvements.
  594. - Additional automated test coverage.
  595. Drupal 7.32, 2014-10-15
  596. -----------------------
  597. - Fixed security issues (SQL injection). See SA-CORE-2014-005.
  598. Drupal 7.31, 2014-08-06
  599. -----------------------
  600. - Fixed security issues (denial of service). See SA-CORE-2014-004.
  601. Drupal 7.30, 2014-07-24
  602. -----------------------
  603. - Fixed a regression introduced in Drupal 7.29 that caused files or images
  604. attached to taxonomy terms to be deleted when the taxonomy term was edited
  605. and resaved (and other related bugs with contributed and custom modules).
  606. - Added a warning on the permissions page to recommend restricting access to
  607. the "View site reports" permission to trusted administrators. See
  608. DRUPAL-PSA-2014-002.
  609. - Numerous API documentation improvements.
  610. - Additional automated test coverage.
  611. Drupal 7.29, 2014-07-16
  612. -----------------------
  613. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-003.
  614. Drupal 7.28, 2014-05-08
  615. -----------------------
  616. - Fixed a regression introduced in Drupal 7.27 that caused JavaScript to break
  617. on older browsers (such as Internet Explorer 8 and earlier) when Ajax was
  618. used.
  619. - Increased the timeout used by the Update Manager module when it fetches data
  620. from drupal.org (from 5 seconds to 30 seconds), to work around a problem
  621. which causes incomplete information about security updates to be presented to
  622. site administrators. This fix may lead to a performance slowdown on the
  623. Update Manager administration pages, when installing Drupal distributions,
  624. and (for sites that use the automated cron feature) on occasional page loads
  625. by site visitors.
  626. - Fixed the behavior of the token system's "[node:summary]" token when the body
  627. field does not have a manual summary.
  628. - Changed the behavior of db_query_temporary() so that it works on SELECT
  629. queries even when they have leading comments/whitespace. A side effect of
  630. this fix is that db_query_temporary() will now fail with an error if it is
  631. ever used on non-SELECT queries.
  632. - Added a "node_admin_filter" tag to the database query used to build the list
  633. of nodes on the content administration page, to make it easier to alter.
  634. - Made the cron queue system log any exceptions that are thrown while an item
  635. in the queue is being processed, rather than stopping the entire PHP request.
  636. - Improved screen reader support by adding an aria-live HTML attribute to file
  637. upload fields when there is an error uploading the file (minor markup
  638. change).
  639. - Made the pager on the Tracker module listing pages show the same number of
  640. items as other pagers throughout Drupal core (minor UI change).
  641. - Fixed a bug which caused caches not to be properly cleared when a file entity
  642. was saved or deleted.
  643. - Added several missing countries to the default list returned by
  644. country_get_list() (string change).
  645. - Replaced the term "weight" with "influence" in the content ranking settings
  646. for search, and added help text for administrators (string change).
  647. - Fixed untranslatable text strings in the administrative interface for the
  648. "Crop" effect provided by the Image module (minor string change).
  649. - Fixed a bug in the Taxonomy module update function introduced in Drupal 7.26
  650. that caused memory and CPU problems on sites with very large numbers of
  651. unpublished nodes.
  652. - Numerous small bug fixes.
  653. - Numerous API documentation improvements.
  654. - Additional automated test coverage.
  655. Drupal 7.27, 2014-04-16
  656. -----------------------
  657. - Fixed security issues (information disclosure). See SA-CORE-2014-002.
  658. Drupal 7.26, 2014-01-15
  659. -----------------------
  660. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2014-001.
  661. Drupal 7.25, 2014-01-02
  662. -----------------------
  663. - Fixed a bug in node_save() which prevented the saved node from being updated
  664. in hook_node_insert() and other similar hooks.
  665. - Added a meta tag to install.php to prevent it from being indexed by search
  666. engines even when Drupal is installed in a subfolder (minor markup change).
  667. - Fixed a bug in the database API that caused frequent deadlock errors when
  668. running merge queries on some servers.
  669. - Performance improvement: Prevented block rehashing from writing blocks to the
  670. database on every cache clear and cron run when the blocks have not changed.
  671. This fix results in an extra 'saved' key which is added and set to TRUE for
  672. each block returned by _block_rehash() that actually is saved to the database
  673. (data structure change).
  674. - Added an optional 'skip on cron' parameter to hook_cron_queue_info() to allow
  675. queues to avoid being automatically processed on cron runs (API addition).
  676. - Fixed a bug which caused hook_block_view_MODULE_DELTA_alter() to never be
  677. invoked if the block delta had a hyphen in it. To implement the hook when the
  678. block delta has a hyphen, modules should now replace hyphens with underscores
  679. when constructing the function name for the hook implementation.
  680. - Fixed a bug which caused cached pages to sometimes be sent to the browser
  681. with incorrect compression. The fix adds a new 'page_compressed' key to the
  682. $cache->data array returned by drupal_page_get_cache() (minor data structure
  683. change).
  684. - Fixed broken tests on PHP 5.5.
  685. - Made the File and Image modules more robust when saving entities that have
  686. deleted files attached. The code in file_field_presave() will now remove the
  687. record of the deleted file from the entity before saving (minor data
  688. structure change).
  689. - Standardized menu callback functions throughout Drupal core to return
  690. MENU_NOT_FOUND and MENU_ACCESS_DENIED rather than printing their own "page
  691. not found" or "access denied" pages (minor API change in the return value of
  692. these functions under some circumstances).
  693. - Fixed a bug in which caches were not properly cleared when a node was deleted
  694. via the administrative interface.
  695. - Changed the Bartik theme to render content contained in
    ,  and
    
  696. similar tags in a larger font size, so it is easier to read.
  697. - Fixed a bug in the Search module that caused exceptions to be thrown during
  698. searches if the server was not configured to represent decimal points as a
  699. period.
  700. - Fixed a regression in the Image module that made image_style_url() not work
  701. when a relative path (rather than a complete file URI) was passed to it.
  702. - Added an optional feature to the Statistics module to allow node views to be
  703. tracked by Ajax requests rather than during the server-side generation of the
  704. page. This allows the node counter to work on sites that use external page
  705. caches (string change and new administrative option:
  706. https://drupal.org/node/2164069).
  707. - Added a link to the drupal.org documentation page for cron to the Cron
  708. settings page (string change).
  709. - Added a 'drupal_anonymous_user_object' variable to allow the anonymous user
  710. object returned by drupal_anonymous_user() to be overridden with a classed
  711. object (API addition).
  712. - Changed the database API to allow inserts based on a SELECT * query to work
  713. correctly.
  714. - Changed the database schema of the {file_managed} table to allow Drupal to
  715. manage files larger than 4 GB.
  716. - Changed the File module's hook_field_load() implementation to prevent file
  717. entity properties which have the same name as file or image field properties
  718. from overwriting the field properties (minor API change).
  719. - Numerous small bug fixes.
  720. - Numerous API documentation improvements.
  721. - Additional automated test coverage.
  722. Drupal 7.24, 2013-11-20
  723. -----------------------
  724. - Fixed security issues (multiple vulnerabilities), see SA-CORE-2013-003.
  725. Drupal 7.23, 2013-08-07
  726. -----------------------
  727. - Fixed a fatal error on PostgreSQL databases when updating the Taxonomy module
  728. from Drupal 6 to Drupal 7.
  729. - Fixed the default ordering of CSS files for sites using right-to-left
  730. languages, to consistently place the right-to-left override file immediately
  731. after the CSS it is overriding (API change: https://drupal.org/node/2058463).
  732. - Added a drupal_check_memory_limit() API function to allow the memory limit to
  733. be checked consistently (API addition).
  734. - Changed the default web.config file for IIS servers to allow favicon.ico
  735. files which are present in the filesystem to be accessed.
  736. - Fixed inconsistent support for the 'tel' protocol in Drupal's URL filtering
  737. functions.
  738. - Performance improvement: Allowed all hooks to be included in the
  739. module_implements() cache, even those that are only invoked on HTTP POST
  740. requests.
  741. - Made the database system replace truncate queries with delete queries when
  742. inside a transaction, to fix issues with PostgreSQL and other databases.
  743. - Fixed a bug which caused nested contextual links to display improperly.
  744. - Fixed a bug which prevented cached image derivatives from being flushed for
  745. private files and other non-default file schemes.
  746. - Fixed drupal_render() to always return an empty string when there is no
  747. output, rather than sometimes returning NULL (minor API change).
  748. - Added protection to cache_clear_all() to ensure that non-cache tables cannot
  749. be truncated (API addition: a new isValidBin() method has been added to the
  750. default database cache implementation).
  751. - Changed the default .htaccess file to support HTTP authorization in CGI
  752. environments.
  753. - Changed the password reset form to pre-fill the username when requested via a
  754. URL query parameter, and used this in the error message that appears after a
  755. failed login attempt (minor data structure and behavior change).
  756. - Fixed broken support for foreign keys in the field API.
  757. - Fixed "No active batch" error when a user cancels their own account.
  758. - Added a description to the "access content overview" permission on the
  759. permissions page (string change).
  760. - Added a drupal_array_diff_assoc_recursive() function to allow associative
  761. arrays to be compared recursively (API addition).
  762. - Added human-readable labels to image styles, in addition to the existing
  763. machine-readable name (API change: https://drupal.org/node/2058503).
  764. - Moved the drupal_get_hash_salt() function to bootstrap.inc and used it in
  765. additional places in the code, for added security in the case where there is
  766. no hash salt in settings.php.
  767. - Fixed a regression in Drupal 7.22 that caused internal server errors for
  768. sites running on very old Apache 1.x web servers.
  769. - Numerous small bug fixes.
  770. - Numerous API documentation improvements.
  771. - Additional automated test coverage.
  772. Drupal 7.22, 2013-04-03
  773. -----------------------
  774. - Allowed the drupal_http_request() function to be overridden so that
  775. additional HTTP request capabilities can be added by contributed modules.
  776. - Changed the Simpletest module to allow PSR-0 test classes to be used in
  777. Drupal 7.
  778. - Removed an unnecessary "Content-Disposition" header from private file
  779. downloads; it prevented many private files from being viewed inline in a web
  780. browser.
  781. - Changed various field API functions to allow them to optionally act on a
  782. single field within an entity (API addition: http://drupal.org/node/1825844).
  783. - Fixed a bug which prevented Drupal's file transfer functionality from working
  784. on some PHP 5.4 systems.
  785. - Fixed incorrect log message when theme() is called for a theme hook that does
  786. not exist (minor string change).
  787. - Fixed Drupal's token-replacement system to allow spaces in the token value.
  788. - Changed the default behavior after a user creates a node they do not have
  789. access to view. The user will now be redirected to the front page rather than
  790. an access denied page.
  791. - Fixed a bug which prevented empty HTTP headers (such as "0") from being set.
  792. (Minor behavior change: Callers of drupal_add_http_header() must now set
  793. FALSE explicitly to prevent a header from being sent at all; this was already
  794. indicated in the function's documentation.)
  795. - Fixed OpenID errors when more than one module implements hook_openid(). The
  796. behavior is now changed so that if more than one module tries to set the same
  797. parameter, the last module's change takes effect.
  798. - Fixed a serious documentation bug: The $name variable in the
  799. taxonomy-term.tpl.php theme template was incorrectly documented as being
  800. sanitized when in fact it is not.
  801. - Fixed a bug which prevented Drupal 6 to Drupal 7 upgrades on sites which had
  802. duplicate permission names in the User module's database tables.
  803. - Added an empty "datatype" attribute to taxonomy term and username links to
  804. make the RDFa markup upward compatible with RDFa 1.1 (minor markup addition).
  805. - Fixed a bug which caused the denial-of-service protection added in Drupal
  806. 7.20 to break certain valid image URLs that had an extra slash in them.
  807. - Fixed a bug with update queries in the SQLite database driver that prevented
  808. Drupal from being installed with SQLite on PHP 5.4.
  809. - Fixed enforced dependencies errors updating to recent versions of Drupal 7 on
  810. certain non-MySQL databases.
  811. - Refactored the Field module's caching behavior to obtain large improvements
  812. in memory usage for sites with many fields and instances (API addition:
  813. http://drupal.org/node/1915646).
  814. - Fixed entity argument not being passed to implementations of
  815. hook_file_download_access_alter(). The fix adds an additional context
  816. parameter that can be passed when calling drupal_alter() for any hook (API
  817. change: http://drupal.org/node/1882722).
  818. - Fixed broken support for translatable comment fields (API change:
  819. http://drupal.org/node/1874724).
  820. - Added an assertThemeOutput() method to Simpletest to allow tests to check
  821. that themed output matches an expected HTML string (API addition).
  822. - Added a link to "Install another module" after a module has been successfully
  823. downloaded via the Update Manager (UI change).
  824. - Added an optional "exclusive" flag to installation profile .info files which
  825. allows Drupal distributions to force a profile to be selected during
  826. installation (API addition: http://drupal.org/node/1961012).
  827. - Fixed a bug which caused the database API to not properly close database
  828. connections.
  829. - Added a link to the URL for running cron from outside the site to the Cron
  830. settings page (UI change).
  831. - Fixed a bug which prevented image styles from being reverted on PHP 5.4.
  832. - Made the default .htaccess rules protocol sensitive to improve security for
  833. sites which use HTTPS and redirect between "www" and non-"www" versions of
  834. the page.
  835. - Numerous small bug fixes.
  836. - Numerous API documentation improvements.
  837. - Additional automated test coverage.
  838. Drupal 7.21, 2013-03-06
  839. -----------------------
  840. - Allowed sites using the 'image_allow_insecure_derivatives' variable to still
  841. have partial protection from the security issues fixed in Drupal 7.20.
  842. Drupal 7.20, 2013-02-20
  843. -----------------------
  844. - Fixed security issues (denial of service). See SA-CORE-2013-002.
  845. Drupal 7.19, 2013-01-16
  846. -----------------------
  847. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2013-001.
  848. Drupal 7.18, 2012-12-19
  849. -----------------------
  850. - Fixed security issues (multiple vulnerabilities). See SA-CORE-2012-004.
  851. Drupal 7.17, 2012-11-07
  852. -----------------------
  853. - Changed the default value of the '404_fast_html' variable to have a DOCTYPE
  854. declaration.
  855. - Made it possible to use associative arrays for the 'items' variable in
  856. theme_item_list().
  857. - Fixed a bug which prevented required form elements without a title from being
  858. given an "error" class when the form fails validation.
  859. - Prevented duplicate HTML IDs from appearing when two forms are displayed on
  860. the same page and one of them is submitted with invalid data (minor markup
  861. change).
  862. - Fixed a bug which prevented Drupal 6 to Drupal 7 upgrades on sites which had
  863. stale data in the Upload module's database tables.
  864. - Fixed a bug in the States API which prevented certain types of form elements
  865. from being disabled when requested.
  866. - Allowed aggregator feed items with author names longer than 255 characters to
  867. have a truncated version saved to the database (rather than causing a fatal
  868. error).
  869. - Allowed aggregator feed items to have URLs longer than 255 characters
  870. (schema change which results in several columns in the Aggregator module's
  871. database tables changing from VARCHAR to TEXT fields).
  872. - Added hook_taxonomy_term_view() and standardized the process for rendering
  873. taxonomy terms to invoke hook_entity_view() and otherwise make it consistent
  874. with other entities (API change: http://drupal.org/node/1808870).
  875. - Added hook_entity_view_mode_alter() to allow modules to change entity view
  876. modes on display (API addition: http://drupal.org/node/1833086).
  877. - Fixed a bug which made database queries running a "LIKE" query on blob fields
  878. fail on PostgreSQL databases. This caused errors during the Drupal 6 to
  879. Drupal 7 upgrade.
  880. - Changed the hook_menu() entry for Drupal's rss.xml page to prevent extra path
  881. components from being accidentally passed to the page callback function (data
  882. structure change).
  883. - Removed a non-standard "name" attribute from Drupal's default Content-Type
  884. header for file downloads.
  885. - Fixed the theme settings form to properly clean up submitted values in
  886. $form_state['values'] when the form is submitted (data structure change).
  887. - Fixed an inconsistency by removing the colon from the end of the label on
  888. multi-valued form fields (minor string change).
  889. - Added support for 'weight' in hook_field_widget_info() to allow modules to
  890. control the order in which widgets are displayed in the Field UI.
  891. - Updated various tables in the OpenID and Book modules to use the default
  892. "empty table" text pattern (string change).
  893. - Added proxy server support to drupal_http_request().
  894. - Added "lang" attributes to language links, to better support screen readers.
  895. - Fixed double occurrence of a "ul" HTML tag on secondary local tasks in the
  896. Seven theme (markup change).
  897. - Fixed bugs which caused taxonomy vocabulary and shortcut set titles to be
  898. double-escaped. The fix replaces the taxonomy vocabulary overview page and
  899. "Edit shortcuts" menu items' title callback entries in hook_menu() with new
  900. functions that do not escape HTML characters (data structure change).
  901. - Modified the Update manager module to allow drupal.org to collect usage
  902. statistics for individual modules and themes, rather than only for entire
  903. projects.
  904. - Modified the node listing database query on Drupal's default front page to
  905. add table aliases for better query altering (this is a data structure change
  906. affecting code which implements hook_query_alter() on this query).
  907. - Improved the translatability of the "Field type(s) in use" message on the
  908. modules page (admin-facing string change).
  909. - Fixed a regression which caused a "call to undefined function
  910. drupal_find_base_themes()" fatal error under rare circumstances.
  911. - Numerous API documentation improvements.
  912. - Additional automated test coverage.
  913. Drupal 7.16, 2012-10-17
  914. -----------------------
  915. - Fixed security issues (Arbitrary PHP code execution and information
  916. disclosure). See SA-CORE-2012-003.
  917. Drupal 7.15, 2012-08-01
  918. -----------------------
  919. - Introduced a 'user_password_reset_timeout' variable to allow the 24-hour
  920. expiration for user password reset links to be adjusted (API addition).
  921. - Fixed database errors due to ambiguous column names that occurred when
  922. EntityFieldQuery was used in certain situations.
  923. - Changed the drupal_array_get_nested_value() function to return a reference
  924. (API addition).
  925. - Changed the System module's hook_block_info() implementation to assign the
  926. "Main page content" and "System help" blocks to appropriate regions by
  927. default and prevent error messages on the block administration page (data
  928. structure change).
  929. - Fixed regression: Non-node entities couldn't be accessed with
  930. EntityFieldQuery.
  931. - Fixed regression: Optional radio buttons with an empty, non-NULL default
  932. value led to an illegal choice error when none were selected.
  933. - Reorganized the testing framework to split setUp() into specific sub-methods
  934. and fix several regressions in the process.
  935. - Fixed bug which made it impossible to search for strings that have not been
  936. translated into a particular language.
  937. - Renamed the "Field" column on the Manage Fields screen to "Field type", since
  938. the former was confusing and inaccurate (UI change).
  939. - Performance improvement: Removed needless call to system_rebuild_module_data()
  940. in field_sync_field_status(), greatly speeding up bulk module enable/disable.
  941. - Fixed bug which prevented notifications from being sent when core, module, and
  942. theme updates are available.
  943. - Fixed bug which prevented sub-themes from inheriting the default values of
  944. theme settings defined by the base theme.
  945. - Fixed bug which prevented the jQuery UI Datepicker from being localized.
  946. - Made Ajax alert dialogs respect error reporting settings.
  947. - Fixed bug which prevented image styles from being deleted on PHP 5.4.
  948. - Fixed bug: Language detection by domain only worked on port 80.
  949. - Fixed regression: The first plural index on a page was not calculated
  950. correctly.
  951. - Introduced generic entity language support. Entities may now declare their
  952. language property in hook_entity_info(), and modules working with entities
  953. may access the language using entity_language() (API change:
  954. http://drupal.org/node/1626346).
  955. - Added EntityFieldQuery support for taxonomy bundles.
  956. - Fixed issue where field form structure was incomplete if field_access()
  957. returned FALSE. Instead of being incomplete, the form structure now has
  958. #access set to FALSE and field form validation is skipped (data structure
  959. change: http://drupal.org/node/1663020).
  960. - Fixed data loss issue due to field_has_data() returning inconsistent results.
  961. The fix adds an optional DANGEROUS_ACCESS_CHECK_OPT_OUT tag to entity field
  962. queries which field storage engines can respond to (API addition:
  963. http://drupal.org/node/1597378).
  964. - Fixed notice: Undefined index: default_image in image_field_prepare_view()
  965. - Numerous API documentation improvements.
  966. - Additional automated test coverage.
  967. Drupal 7.14, 2012-05-02
  968. -----------------------
  969. - Fixed "integrity constraint" fatal errors when rebuilding registry.
  970. - Fixed custom logo and favicon functionality referencing incorrect paths.
  971. - Fixed DB Case Sensitivity: Allow BINARY attribute in MySQL.
  972. - Split field_bundle_settings out per bundle.
  973. - Improve UX for machine names for fields (UI change).
  974. - Fixed User pictures are not removed properly.
  975. - Fixed HTTPS sessions not working in all cases.
  976. - Fixed Regression: Required radios throw illegal choice error when none
  977. selected.
  978. - Fixed allow autocompletion requests to include slashes.
  979. - Eliminate $user->cache and {session}.cache in favor of
  980. $_SESSION['cache_expiration'][$bin] (Performance).
  981. - Fixed focus jumps to tab when pressing enter on a form element within tab.
  982. - Fixed race condition in locale() - duplicates in {locales_source}.
  983. - Fixed Missing "Default image" per field instance.
  984. - Quit clobbering people's work when they click the filter tips link
  985. - Form API #states: Fix conditionals to allow OR and XOR constructions.
  986. - Fixed Focus jumps to tab when pressing enter on a form element within tab.
  987. (Accessibility)
  988. - Improved performance of node_access queries.
  989. - Fixed Fieldsets inside vertical tabs have no title and can't be collapsed.
  990. - Reduce size of cache_menu table (Performance).
  991. - Fixed unnecessary aggregation of CSS/JS (Performance).
  992. - Fixed taxonomy_autocomplete() produces SQL error for nonexistent field.
  993. - Fixed HTML filter is not run first by default, despite default weight.
  994. - Fixed Overlay does not work with prefixed URL paths.
  995. - Better debug info for field errors (string change).
  996. - Fixed Data corruption in comment IDs (results in broken threading on
  997. PostgreSQL).
  998. - Fixed machine name not editable if every character is replaced.
  999. - Fixed user picture not appearing in comment preview (Markup change).
  1000. - Added optional vid argument for taxonomy_get_term_by_name().
  1001. - Fixed Invalid Unicode code range in PREG_CLASS_UNICODE_WORD_BOUNDARY fails
  1002. with PCRE 8.30.
  1003. - Fixed {trigger_assignments()}.hook has only 32 characters, is too short.
  1004. - Numerous fixes to run-tests.sh.
  1005. - Fixed Tests in profiles/[name]/modules cannot be run and cannot use a
  1006. different profile for running tests.
  1007. - Numerous JavaScript performance fixes.
  1008. - Numerous documentation fixes.
  1009. - Fixed All pager links have an 'active' CSS class.
  1010. - Numerous upgrade path fixes; notably:
  1011. - system_update_7061() fails on inserting files with same name but different
  1012. case.
  1013. - system_update_7061() converts filepaths too aggressively.
  1014. - Trigger upgrade path: Node triggers removed when upgrading to 7-x from 6.25.
  1015. Drupal 7.13, 2012-05-02
  1016. -----------------------
  1017. - Fixed security issues (Multiple vulnerabilities), see SA-CORE-2012-002.
  1018. Drupal 7.12, 2012-02-01
  1019. -----------------------
  1020. - Fixed bug preventing custom menus from receiving an active trail.
  1021. - Fixed hook_field_delete() no longer invoked during field_purge_data().
  1022. - Fixed bug causing entity info cache to not be cleared with the rest of caches.
  1023. - Fixed file_unmanaged_copy() fails with Drupal 7.7+ and safe_mode() or
  1024. open_basedir().
  1025. - Fixed Nested transactions throw exceptions when they got out of scope.
  1026. - Fixed bugs with the Return-Path when sending mail on both Windows and
  1027. non-Windows systems.
  1028. - Fixed bug with DrupalCacheArray property visibility preventing others from
  1029. extending it (API change: http://drupal.org/node/1422264).
  1030. - Fixed bug with handling of non-ASCII characters in file names (API change:
  1031. http://drupal.org/node/1424840).
  1032. - Reconciled field maximum length with database column size in image and
  1033. aggregator modules.
  1034. - Fixes to various core JavaScript files to allow for minification and
  1035. aggregation.
  1036. - Fixed Prevent tests from deleting main installation's tables when
  1037. parent::setUp() is not called.
  1038. - Fixed several Poll module bugs.
  1039. - Fixed several Shortcut module bugs.
  1040. - Added new hook_system_theme_info() to provide ability for contributed modules
  1041. to test theme functionality.
  1042. - Added ability to cancel mail sending from hook_mail_alter().
  1043. - Added support for configurable PDO connection options, enabling master-master
  1044. database replication.
  1045. - Numerous improvements to tests and test runner to pave the way for faster test
  1046. runs.
  1047. - Expanded test coverage.
  1048. - Numerous API documentation improvements.
  1049. - Numerous performance improvements, including token replacement and render
  1050. cache.
  1051. Drupal 7.11, 2012-02-01
  1052. -----------------------
  1053. - Fixed security issues (Multiple vulnerabilities), see SA-CORE-2012-001.
  1054. Drupal 7.10, 2011-12-05
  1055. -----------------------
  1056. - Fixed Content-Language HTTP header to not cause issues with Drush 5.x.
  1057. - Reduce memory usage of theme registry (performance).
  1058. - Fixed PECL upload progress bar for FileField
  1059. - Fixed running update.php doesn't always clear the cache.
  1060. - Fixed PDO exceptions on long titles.
  1061. - Fixed Overlay redirect does not include query string.
  1062. - Fixed D6 modules satisfy D7 module dependencies.
  1063. - Fixed the ordering of module hooks when using module_implements_alter().
  1064. - Fixed "floating" submit buttons during AJAX requests.
  1065. - Fixed timezone selected on install not propogating to admin account.
  1066. - Added msgctx context to JS translation functions, for feature parity with t().
  1067. - Profiles' .install files now available during hook_install_tasks().
  1068. - Added test coverage of 7.0 -> 7.x upgrade path.
  1069. - Numerous notice fixes.
  1070. - Numerous documentation improvements.
  1071. - Additional automated test coverage.
  1072. Drupal 7.9, 2011-10-26
  1073. ----------------------
  1074. - Critical fixes to OpenID to spec violations that could allow for
  1075. impersonation in certain scenarios. Existing OpenID users should see
  1076. http://drupal.org/node/1120290#comment-5092796 for more information on
  1077. transitioning.
  1078. - Fixed files getting lost when adding multiple files to multiple file fields
  1079. at the same time.
  1080. - Improved usability of the clean URL test screens.
  1081. - Restored height/width attributes on images run through the theme system.
  1082. - Fixed usability bug with first password field being pre-filled by certain
  1083. browser plugins.
  1084. - Fixed file_usage_list() so that it can return more than one result.
  1085. - Fixed bug preventing preview of private images on node form.
  1086. - Fixed PDO error when inserting an aggregator title longer than 255 characters.
  1087. - Spelled out what TRADITIONAL means in MySQL sql_mode.
  1088. - Deprecated "!=" operator for DBTNG; should be "<>".
  1089. - Added two new API functions (menu_tree_set_path()/menu_tree_get_path()) were
  1090. added in order to enable setting the active menu trail for dynamically
  1091. generated menu paths.
  1092. - Added new "fast 404" capability in settings.php to bypass Drupal bootstrap
  1093. when serving 404 pages for certain file types.
  1094. - Added format_string() function which can perform string munging ala the t()
  1095. function without the overhead of the translation system.
  1096. - Numerous #states system fixes.
  1097. - Numerous EntityFieldQuery, DBTNG, and SQLite fixes.
  1098. - Numerous Shortcut module fixes.
  1099. - Numerous language system fixes.
  1100. - Numerous token fixes.
  1101. - Numerous CSS fixes.
  1102. - Numerous upgrade path fixes.
  1103. - Numerous minor string fixes.
  1104. - Numerous notice fixes.
  1105. Drupal 7.8, 2011-08-31
  1106. ----------------------
  1107. - Fixed critical upgrade path issue with multilingual sites, leading to lost
  1108. content.
  1109. - Numerous fixes to upgrade path, preventing fatal errors due to incorrect
  1110. dependencies.
  1111. - Fixed issue with saving files on hosts with open_basedir restrictions.
  1112. - Fixed Update manger error when used with Overlay.
  1113. - Fixed RTL support in Seven administration theme and Overlay.
  1114. - Fixes to nested transaction support.
  1115. - Introduced performance pattern to reduce Drupal core's RAM usage.
  1116. - Added support for HTML 5 tags to filter_xss_admin().
  1117. - Added exception handling to cron.
  1118. - Added new hook hook_field_widget_form_alter() for contribtued modules.
  1119. - element_validate_*() functions now available to contrib.
  1120. - Added new maintainers for several subsystems.
  1121. - Numerous testing system improvements.
  1122. - Numerous markup and CSS fixes.
  1123. - Numerous poll module fixes.
  1124. - Numerous notice/warning fixes.
  1125. - Numerous documentation fixes.
  1126. - Numerous token fixes.
  1127. Drupal 7.7, 2011-07-27
  1128. ----------------------
  1129. - Fixed VERSION string.
  1130. Drupal 7.6, 2011-07-27
  1131. ----------------------
  1132. - Fixed support for remote streamwrappers.
  1133. - AJAX now binds to 'click' instead of 'mousedown'.
  1134. - 'Translatable' flag on fields created in UI now defaults to FALSE, to match those created via the API.
  1135. - Performance enhancement to permissions page on large numbers of permissions.
  1136. - More secure password generation.
  1137. - Fix for temporary directory on Windows servers.
  1138. - run-tests.sh now uses proc_open() instead of pcntl_fork() for better Windows support.
  1139. - Numerous upgrade path fixes.
  1140. - Numerous documentation fixes.
  1141. - Numerous notice fixes.
  1142. - Numerous fixes to improve PHP 5.4 support.
  1143. - Numerous RTL improvements.
  1144. Drupal 7.5, 2011-07-27
  1145. ----------------------
  1146. - Fixed security issue (Access bypass), see SA-CORE-2011-003.
  1147. Drupal 7.4, 2011-06-29
  1148. ----------------------
  1149. - Rolled back patch that caused fatal errors in CTools, Feeds, and other modules using the class registry.
  1150. - Fixed critical bug with saving default images.
  1151. - Fixed fatal errors when uninstalling some modules.
  1152. - Added workaround for MySQL transaction support breaking on DDL statments.
  1153. - Improved page caching with external caching systems.
  1154. - Fix to Batch API, which was terminating too early.
  1155. - Numerous upgrade path fixes.
  1156. - Performance fixes.
  1157. - Additional test coverage.
  1158. - Numerous documentation fixes.
  1159. Drupal 7.3, 2011-06-29
  1160. ----------------------
  1161. - Fixed security issue (Access bypass), see SA-CORE-2011-002.
  1162. Drupal 7.2, 2011-05-25
  1163. ----------------------
  1164. - Added a default .gitignore file.
  1165. - Improved PostgreSQL and SQLite support.
  1166. - Numerous critical performance improvements.
  1167. - Numerous critical fixes to the upgrade path.
  1168. - Numerous fixes to language and translation systems.
  1169. - Numerous fixes to AJAX and #states systems.
  1170. - Improvements to the locking system.
  1171. - Numerous documentation fixes.
  1172. - Numerous styling and theme system fixes.
  1173. - Numerous fixes for schema mis-matches between Drupal 6 and 7.
  1174. - Minor internal API clean-ups.
  1175. Drupal 7.1, 2011-05-25
  1176. ----------------------
  1177. - Fixed security issues (Cross site scripting, File access bypass), see SA-CORE-2011-001.
  1178. Drupal 7.0, 2011-01-05
  1179. ----------------------
  1180. - Database:
  1181. * Fully rewritten database layer utilizing PHP 5's PDO abstraction layer.
  1182. * Drupal now requires MySQL >= 5.0.15 or PostgreSQL >= 8.3.
  1183. * Added query builders for INSERT, UPDATE, DELETE, MERGE, and SELECT queries.
  1184. * Support for master/slave replication, transactions, multi-insert queries,
  1185. and other features.
  1186. * Added support for the SQLite database engine.
  1187. * Default to InnoDB engine, rather than MyISAM, on MySQL when available.
  1188. This offers increased scalability and data integrity.
  1189. - Security:
  1190. * Protected cron.php -- cron will only run if the proper key is provided.
  1191. * Implemented a pluggable password system and much stronger password hashes
  1192. that are compatible with the Portable PHP password hashing framework.
  1193. * Rate limited login attempts to prevent brute-force password guessing, and
  1194. improved the flood control API to allow variable time windows and
  1195. identifiers for limiting user access to resources.
  1196. * Transformed the "Update status" module into the "Update manager" which
  1197. can securely install or update modules and themes via a web interface.
  1198. - Usability:
  1199. * Added contextual links (a.k.a. local tasks) to page elements, such as
  1200. blocks, nodes, or comments, which allows to perform the most common tasks
  1201. with a single click only.
  1202. * Improved installer requirements check.
  1203. * Improved support for integration of WYSIWYG editors.
  1204. * Implemented drag-and-drop positioning for input format listings.
  1205. * Implemented drag-and-drop positioning for language listing.
  1206. * Implemented drag-and-drop positioning for poll options.
  1207. * Provided descriptions and human-readable names for user permissions.
  1208. * Removed comment controls for users.
  1209. * Removed display order settings for comment module. Comment display
  1210. order can now be customized using the Views module.
  1211. * Removed the 'related terms' feature from taxonomy module since this can
  1212. now be achieved with Field API.
  1213. * Added additional features to the default installation profile, and
  1214. implemented a "slimmed down" profile designed for developers.
  1215. * Added a built-in, automated cron run feature, which is triggered by site
  1216. visitors.
  1217. * Added an administrator role which is assigned all permissions for
  1218. installed modules automatically.
  1219. * Image toolkits are now provided by modules (rather than requiring a
  1220. manual file copy to the includes directory).
  1221. * Added an edit tab to taxonomy term pages.
  1222. * Redesigned password strength validator.
  1223. * Redesigned the add content type screen.
  1224. * Highlight duplicate URL aliases.
  1225. * Renamed "input formats" to "text formats".
  1226. * Moved text format permissions to the main permissions page.
  1227. * Added configurable ability for users to cancel their own accounts.
  1228. * Added "vertical tabs", a reusable interface component that features
  1229. automatic summaries and increases usability.
  1230. * Replaced fieldsets on node edit and add pages with vertical tabs.
  1231. - Performance:
  1232. * Improved performance on uncached page views by loading multiple core
  1233. objects in a single database query.
  1234. * Improved performance for logged-in users by reducing queries for path
  1235. alias lookups.
  1236. * Improved support for HTTP proxies (including reverse proxies), allowing
  1237. anonymous page views to be served entirely from the proxy.
  1238. - Documentation:
  1239. * Hook API documentation now included in Drupal core.
  1240. - News aggregator:
  1241. * Added OPML import functionality for RSS feeds.
  1242. * Optionally, RSS feeds may be configured to not automatically generate feed blocks.
  1243. - Search:
  1244. * Added support for language-aware searches.
  1245. - Aggregator:
  1246. * Introduced architecture that allows pluggable parsers and processors for
  1247. syndicating RSS and Atom feeds.
  1248. * Added options to suspend updating specific feeds and never discard feeds
  1249. items.
  1250. - Testing:
  1251. * Added test framework and tests.
  1252. - Improved time zone support:
  1253. * Drupal now uses PHP's time zone database when rendering dates in local
  1254. time. Site-wide and user-configured time zone offsets have been converted
  1255. to time zone names, e.g. Africa/Abidjan.
  1256. * In some cases the upgrade and install scripts do not choose the preferred
  1257. site default time zone. The automatically-selected time zone can be
  1258. corrected at admin/config/regional/settings.
  1259. * If your site is being upgraded from Drupal 6 and you do not have the
  1260. contributed date or event modules installed, user time zone settings will
  1261. fallback to the system time zone and will have to be reconfigured by each user.
  1262. * User-configured time zones now serve as the default time zone for PHP
  1263. date/time functions.
  1264. - Filter system:
  1265. * Revamped the filter API and text format storage.
  1266. * Added support for default text formats to be assigned on a per-role basis.
  1267. * Refactored the HTML corrector to take advantage of PHP 5 features.
  1268. - User system:
  1269. * Added clean API functions for creating, loading, updating, and deleting
  1270. user roles and permissions.
  1271. * Refactored the "access rules" component of user module: The user module
  1272. now provides a simple interface for blocking single IP addresses. The
  1273. previous functionality in the user module for restricting certain e-mail
  1274. addresses and usernames is now available as a contributed module. Further,
  1275. IP address range blocking is no longer supported and should be implemented
  1276. at the operating system level.
  1277. * Removed per-user themes: Contributed modules with similar functionality
  1278. are available.
  1279. - OpenID:
  1280. * Added support for Gmail and Google Apps for Domain identifiers. Users can
  1281. now login with their user@example.com identifier when example.com is powered
  1282. by Google.
  1283. * Made the OpenID module more pluggable.
  1284. - Added code registry:
  1285. * Using the registry, modules declare their includable files via their .info file,
  1286. allowing Drupal to lazy-load classes and interfaces as needed.
  1287. - Theme system:
  1288. * Removed the Bluemarine, Chameleon and Pushbutton themes. These themes live
  1289. on as contributed themes (http://drupal.org/project/bluemarine,
  1290. http://drupal.org/project/chameleon and http://drupal.org/project/pushbutton).
  1291. * Added Stark theme to make analyzing Drupal's default HTML and CSS easier.
  1292. * Added Seven as the default administration theme.
  1293. * Variable preprocessing of theme hooks prior to template rendering now goes
  1294. through two phases: a 'preprocess' phase and a new 'process' phase. See
  1295. http://api.drupal.org/api/function/theme/7 for details.
  1296. * Theme hooks implemented as functions (rather than as templates) can now
  1297. also have preprocess (and process) functions. See
  1298. http://api.drupal.org/api/function/theme/7 for details.
  1299. * Added Bartik as the default theme.
  1300. - File handling:
  1301. * Files are now first class Drupal objects with file_load(), file_save(),
  1302. and file_validate() functions and corresponding hooks.
  1303. * The file_move(), file_copy() and file_delete() functions now operate on
  1304. file objects and invoke file hooks so that modules are notified and can
  1305. respond to changes.
  1306. * For the occasions when only basic file manipulation are needed--such as
  1307. uploading a site logo--that don't require the overhead of databases and
  1308. hooks, the current unmanaged copy, move and delete operations have been
  1309. preserved but renamed to file_unmanaged_*().
  1310. * Rewrote file handling to use PHP stream wrappers to enable support for
  1311. both public and private files and to support pluggable storage mechanisms
  1312. and access to remote resources (e.g. S3 storage or Flickr photos).
  1313. * The mime_extension_mapping variable has been removed. Modules that need to
  1314. alter the default MIME type extension mappings should implement
  1315. hook_file_mimetype_mapping_alter().
  1316. * Added the hook_file_url_alter() hook, which makes it possible to serve
  1317. files from a CDN.
  1318. * Added a field specifically for uploading files, previously provided by
  1319. the contributed module FileField.
  1320. - Image handling:
  1321. * Improved image handling, including better support for add-on image
  1322. libraries.
  1323. * Added API and interface for creating advanced image thumbnails.
  1324. * Inclusion of additional effects such as rotate and desaturate.
  1325. * Added a field specifically for uploading images, previously provided by
  1326. the contributed module ImageField.
  1327. - Added aliased multi-site support:
  1328. * Added support for mapping domain names to sites directories.
  1329. - Added RDF support:
  1330. * Modules can declare RDF namespaces which are serialized in the tag
  1331. for RDFa support.
  1332. * Modules can specify how their data structure maps to RDF.
  1333. * Added support for RDFa export of nodes, comments, terms, users, etc. and
  1334. their fields.
  1335. - Search engine optimization and web linking:
  1336. * Added a rel="canonical" link on node and comment pages to prevent
  1337. duplicate content indexing by search engines.
  1338. * Added a default rel="shortlink" link on node and comment pages that
  1339. advertises a short link as an alternative URL to third-party services.
  1340. * Meta information is now alterable by all modules before rendering.
  1341. - Field API:
  1342. * Custom data fields may be attached to nodes, users, comments and taxonomy
  1343. terms.
  1344. * Node bodies and teasers are now Field API fields instead of
  1345. being a hard-coded property of node objects.
  1346. * In addition, any other object type may register with Field API
  1347. and allow custom data fields to be attached to itself.
  1348. * Provides most of the features of the former Content Construction
  1349. Kit (CCK) module.
  1350. * Taxonomy terms are now Field API fields that can be added to any fieldable
  1351. object.
  1352. - Installer:
  1353. * Refactored the installer into an API that allows Drupal to be installed
  1354. via a command line script.
  1355. - Page organization
  1356. * Made the help text area a full featured region with blocks.
  1357. * Site mission is replaced with the highlighted content block region and
  1358. separate RSS feed description settings.
  1359. * The footer message setting was removed in favor of custom blocks.
  1360. * Made the main page content a block which can be moved and ordered
  1361. with other blocks in the same region.
  1362. * Blocks can now return structured arrays for later rendering just
  1363. like page callbacks.
  1364. - Translation system
  1365. * The translation system now supports message context (msgctxt).
  1366. * Added support for translatable fields to Field API.
  1367. - JavaScript changes
  1368. * Upgraded the core JavaScript library to jQuery version 1.4.4.
  1369. * Upgraded the jQuery Forms library to 2.52.
  1370. * Added jQuery UI 1.8.7, which allows improvements to Drupal's user
  1371. experience.
  1372. - Better module version support
  1373. * Modules now can specify which version of another module they depend on.
  1374. - Removed modules from core
  1375. * The following modules have been removed from core, because contributed
  1376. modules with similar functionality are available:
  1377. * Blog API module
  1378. * Ping module
  1379. * Throttle module
  1380. - Improved node access control system.
  1381. * All modules may now influence the access to a node at runtime, not just
  1382. the module that defined a node.
  1383. * Users may now be allowed to bypass node access restrictions without giving
  1384. them complete access to the site.
  1385. * Access control affects both published and unpublished nodes.
  1386. * Numerous other improvements to the node access system.
  1387. - Actions system
  1388. * Simplified definitions of actions and triggers.
  1389. * Removed dependency on the combination of hooks and operations. Triggers
  1390. now directly map to module hooks.
  1391. - Task handling
  1392. * Added a queue API to process many or long-running tasks.
  1393. * Added queue API support to cron API.
  1394. * Added a locking framework to coordinate long-running operations across
  1395. requests.
  1396. Drupal 6.23-dev, xxxx-xx-xx (development release)
  1397. ---------------------------
  1398. Drupal 6.22, 2011-05-25
  1399. -----------------------
  1400. - Made Drupal 6 work better with IIS and Internet Explorer.
  1401. - Fixed .po file imports to work better with custom textgroups.
  1402. - Improved code documentation at various places.
  1403. - Fixed a variety of other bugs.
  1404. Drupal 6.21, 2011-05-25
  1405. -----------------------
  1406. - Fixed security issues (Cross site scripting), see SA-CORE-2011-001.
  1407. Drupal 6.20, 2010-12-15
  1408. -----------------------
  1409. - Fixed a variety of small bugs, improved code documentation.
  1410. Drupal 6.19, 2010-08-11
  1411. -----------------------
  1412. - Fixed a variety of small bugs, improved code documentation.
  1413. Drupal 6.18, 2010-08-11
  1414. -----------------------
  1415. - Fixed security issues (OpenID authentication bypass, File download access
  1416. bypass, Comment unpublishing bypass, Actions cross site scripting),
  1417. see SA-CORE-2010-002.
  1418. Drupal 6.17, 2010-06-02
  1419. -----------------------
  1420. - Improved PostgreSQL compatibility
  1421. - Better PHP 5.3 and PHP 4 compatibility
  1422. - Better browser compatibility of CSS and JS aggregation
  1423. - Improved logging for login failures
  1424. - Fixed an incompatibility with some contributed modules and the locking system
  1425. - Fixed a variety of other bugs.
  1426. Drupal 6.16, 2010-03-03
  1427. -----------------------
  1428. - Fixed security issues (Installation cross site scripting, Open redirection,
  1429. Locale module cross site scripting, Blocked user session regeneration),
  1430. see SA-CORE-2010-001.
  1431. - Better support for updated jQuery versions.
  1432. - Reduced resource usage of update.module.
  1433. - Fixed several issues relating to support of installation profiles and
  1434. distributions.
  1435. - Added a locking framework to avoid data corruption on long operations.
  1436. - Fixed a variety of other bugs.
  1437. Drupal 6.15, 2009-12-16
  1438. -----------------------
  1439. - Fixed security issues (Cross site scripting), see SA-CORE-2009-009.
  1440. - Fixed a variety of other bugs.
  1441. Drupal 6.14, 2009-09-16
  1442. -----------------------
  1443. - Fixed security issues (OpenID association cross site request forgeries,
  1444. OpenID impersonation and File upload), see SA-CORE-2009-008.
  1445. - Changed the system modules page to not run all cache rebuilds; use the
  1446. button on the performance settings page to achieve the same effect.
  1447. - Added support for PHP 5.3.0 out of the box.
  1448. - Fixed a variety of small bugs.
  1449. Drupal 6.13, 2009-07-01
  1450. -----------------------
  1451. - Fixed security issues (Cross site scripting, Input format access bypass and
  1452. Password leakage in URL), see SA-CORE-2009-007.
  1453. - Fixed a variety of small bugs.
  1454. Drupal 6.12, 2009-05-13
  1455. -----------------------
  1456. - Fixed security issues (Cross site scripting), see SA-CORE-2009-006.
  1457. - Fixed a variety of small bugs.
  1458. Drupal 6.11, 2009-04-29
  1459. -----------------------
  1460. - Fixed security issues (Cross site scripting and limited information
  1461. disclosure), see SA-CORE-2009-005
  1462. - Fixed performance issues with the menu router cache, the update
  1463. status cache and improved cache invalidation
  1464. - Fixed a variety of small bugs.
  1465. Drupal 6.10, 2009-02-25
  1466. -----------------------
  1467. - Fixed a security issue, (Local file inclusion on Windows),
  1468. see SA-CORE-2009-003
  1469. - Fixed node_feed() so custom fields can show up in RSS feeds.
  1470. - Improved PostgreSQL compatibility.
  1471. - Fixed a variety of small bugs.
  1472. Drupal 6.9, 2009-01-14
  1473. ----------------------
  1474. - Fixed security issues, (Access Bypass, Validation Bypass and Hardening
  1475. against SQL injection), see SA-CORE-2009-001
  1476. - Made HTTP request checking more robust and informative.
  1477. - Fixed HTTP_HOST checking to work again with HTTP 1.0 clients and
  1478. basic shell scripts.
  1479. - Removed t() calls from all schema documentation. Suggested best practice
  1480. changed for contributed modules, see http://drupal.org/node/322731.
  1481. - Fixed a variety of small bugs.
  1482. Drupal 6.8, 2008-12-11
  1483. ----------------------
  1484. - Removed a previous change incompatible with PHP 5.1.x and lower.
  1485. Drupal 6.7, 2008-12-10
  1486. ----------------------
  1487. - Fixed security issues, (Cross site request forgery and Cross site scripting), see SA-2008-073
  1488. - Updated robots.txt and .htaccess to match current file use.
  1489. - Fixed a variety of small bugs.
  1490. Drupal 6.6, 2008-10-22
  1491. ----------------------
  1492. - Fixed security issues, (File inclusion, Cross site scripting), see SA-2008-067
  1493. - Fixed a variety of small bugs.
  1494. Drupal 6.5, 2008-10-08
  1495. ----------------------
  1496. - Fixed security issues, (File upload access bypass, Access rules bypass,
  1497. BlogAPI access bypass), see SA-2008-060.
  1498. - Fixed a variety of small bugs.
  1499. Drupal 6.4, 2008-08-13
  1500. ----------------------
  1501. - Fixed a security issue (Cross site scripting, Arbitrary file uploads via
  1502. BlogAPI, Cross site request forgeries and Various Upload module
  1503. vulnerabilities), see SA-2008-047.
  1504. - Improved error messages during installation.
  1505. - Fixed a bug that prevented AHAH handlers to be attached to radios widgets.
  1506. - Fixed a variety of small bugs.
  1507. Drupal 6.3, 2008-07-09
  1508. ----------------------
  1509. - Fixed security issues, (Cross site scripting, cross site request forgery,
  1510. session fixation and SQL injection), see SA-2008-044.
  1511. - Slightly modified installation process to prevent file ownership issues on
  1512. shared hosts.
  1513. - Improved PostgreSQL compatibility (rewritten queries; custom blocks).
  1514. - Upgraded to jQuery 1.2.6.
  1515. - Performance improvements to search, menu handling and form API caches.
  1516. - Fixed Views compatibility issues (Views for Drupal 6 requires Drupal 6.3+).
  1517. - Fixed a variety of small bugs.
  1518. Drupal 6.2, 2008-04-09
  1519. ----------------------
  1520. - Fixed a variety of small bugs.
  1521. - Fixed a security issue (Access bypasses), see SA-2008-026.
  1522. Drupal 6.1, 2008-02-27
  1523. ----------------------
  1524. - Fixed a variety of small bugs.
  1525. - Fixed a security issue (Cross site scripting), see SA-2008-018.
  1526. Drupal 6.0, 2008-02-13
  1527. ----------------------
  1528. - New, faster and better menu system.
  1529. - New watchdog as a hook functionality.
  1530. * New hook_watchdog that can be implemented by any module to route log
  1531. messages to various destinations.
  1532. * Expands the severity levels from 3 (Error, Warning, Notice) to the 8
  1533. levels defined in RFC 3164.
  1534. * The watchdog module is now called dblog, and is optional, but enabled by
  1535. default in the default installation profile.
  1536. * Extended the database log module so log messages can be filtered.
  1537. * Added syslog module: useful for monitoring large Drupal installations.
  1538. - Added optional e-mail notifications when users are approved, blocked, or
  1539. deleted.
  1540. - Drupal works with error reporting set to E_ALL.
  1541. - Added scripts/drupal.sh to execute Drupal code from the command line. Useful
  1542. to use Drupal as a framework to build command-line tools.
  1543. - Made signature support optional and made it possible to theme signatures.
  1544. - Made it possible to filter the URL aliases on the URL alias administration
  1545. screen.
  1546. - Language system improvements:
  1547. * Support for right to left languages.
  1548. * Language detection based on parts of the URL.
  1549. * Browser based language detection.
  1550. * Made it possible to specify a node's language.
  1551. * Support for translating posts on the site to different languages.
  1552. * Language dependent path aliases.
  1553. * Automatically import translations when adding a new language.
  1554. * JavaScript interface translation.
  1555. * Automatically import a module's translation upon enabling that module.
  1556. - Moved "PHP input filter" to a standalone module so it can be deleted for
  1557. security reasons.
  1558. - Usability:
  1559. * Improved handling of teasers in posts.
  1560. * Added sticky table headers.
  1561. * Check for clean URL support automatically with JavaScript.
  1562. * Removed default/settings.php. Instead the installer will create it from
  1563. default.settings.php.
  1564. * Made it possible to configure your own date formats.
  1565. * Remember anonymous comment posters.
  1566. * Only allow modules and themes to be enabled that have explicitly been
  1567. ported to the correct core API version.
  1568. * Can now specify the minimum PHP version required for a module within the
  1569. .info file.
  1570. * Drupal core no longer requires CREATE TEMPORARY TABLES or LOCK TABLES
  1571. database rights.
  1572. * Dynamically check password strength and confirmation.
  1573. * Refactored poll administration.
  1574. * Implemented drag-and-drop positioning for blocks, menu items, taxonomy
  1575. vocabularies and terms, forums, profile fields, and input format filters.
  1576. - Theme system:
  1577. * Added .info files to themes and made it easier to specify regions and
  1578. features.
  1579. * Added theme registry: modules can directly provide .tpl.php files for
  1580. their themes without having to create theme_ functions.
  1581. * Used the Garland theme for the installation and maintenance pages.
  1582. * Added theme preprocess functions for themes that are templates.
  1583. * Added support for themeable functions in JavaScript.
  1584. - Refactored update.php to a generic batch API to be able to run time-consuming
  1585. operations in multiple subsequent HTTP requests.
  1586. - Installer:
  1587. * Themed the installer with the Garland theme.
  1588. * Added form to provide initial site information during installation.
  1589. * Added ability to provide extra installation steps programmatically.
  1590. * Made it possible to import interface translations during installation.
  1591. - Added the HTML corrector filter:
  1592. * Fixes faulty and chopped off HTML in postings.
  1593. * Tags are now automatically closed at the end of the teaser.
  1594. - Performance:
  1595. * Made it easier to conditionally load .include files and split up many core
  1596. modules.
  1597. * Added a JavaScript aggregator.
  1598. * Added block-level caching, improving performance for both authenticated
  1599. and anonymous users.
  1600. * Made Drupal work correctly when running behind a reverse proxy like
  1601. Squid or Pound.
  1602. - File handling improvements:
  1603. * Entries in the files table are now keyed to a user instead of a node.
  1604. * Added reusable validation functions to check for uploaded file sizes,
  1605. extensions, and image resolution.
  1606. * Added ability to create and remove temporary files during a cron job.
  1607. - Forum improvements:
  1608. * Any node type may now be posted in a forum.
  1609. - Taxonomy improvements:
  1610. * Descriptions for terms are now shown on taxonomy/term pages as well
  1611. as RSS feeds.
  1612. * Added versioning support to categories by associating them with node
  1613. revisions.
  1614. - Added support for OpenID.
  1615. - Added support for triggering configurable actions.
  1616. - Added the Update status module to automatically check for available updates
  1617. and warn sites if they are missing security updates or newer versions.
  1618. Sites deploying from CVS should use http://drupal.org/project/cvs_deploy.
  1619. Advanced settings provided by http://drupal.org/project/update_advanced.
  1620. - Upgraded the core JavaScript library to jQuery version 1.2.3.
  1621. - Added a new Schema API, which provides built-in support for core and
  1622. contributed modules to work with databases other than MySQL.
  1623. - Removed drupal.module. The functionality lives on as the Site network
  1624. contributed module (http://drupal.org/project/site_network).
  1625. - Removed old system updates. Updates from Drupal versions prior to 5.x will
  1626. require upgrading to 5.x before upgrading to 6.x.
  1627. Drupal 5.23, 2010-08-11
  1628. -----------------------
  1629. - Fixed security issues (File download access bypass, Comment unpublishing
  1630. bypass), see SA-CORE-2010-002.
  1631. Drupal 5.22, 2010-03-03
  1632. -----------------------
  1633. - Fixed security issues (Open redirection, Locale module cross site scripting,
  1634. Blocked user session regeneration), see SA-CORE-2010-001.
  1635. Drupal 5.21, 2009-12-16
  1636. -----------------------
  1637. - Fixed a security issue (Cross site scripting), see SA-CORE-2009-009.
  1638. - Fixed a variety of small bugs.
  1639. Drupal 5.20, 2009-09-16
  1640. -----------------------
  1641. - Avoid security problems resulting from writing Drupal 6-style menu
  1642. declarations.
  1643. - Fixed security issues (session fixation), see SA-CORE-2009-008.
  1644. - Fixed a variety of small bugs.
  1645. Drupal 5.19, 2009-07-01
  1646. -----------------------
  1647. - Fixed security issues (Cross site scripting and Password leakage in URL), see
  1648. SA-CORE-2009-007.
  1649. - Fixed a variety of small bugs.
  1650. Drupal 5.18, 2009-05-13
  1651. -----------------------
  1652. - Fixed security issues (Cross site scripting), see SA-CORE-2009-006.
  1653. - Fixed a variety of small bugs.
  1654. Drupal 5.17, 2009-04-29
  1655. -----------------------
  1656. - Fixed security issues (Cross site scripting and limited information
  1657. disclosure) see SA-CORE-2009-005.
  1658. - Fixed a variety of small bugs.
  1659. Drupal 5.16, 2009-02-25
  1660. -----------------------
  1661. - Fixed a security issue, (Local file inclusion on Windows), see SA-CORE-2009-004.
  1662. - Fixed a variety of small bugs.
  1663. Drupal 5.15, 2009-01-14
  1664. -----------------------
  1665. - Fixed security issues, (Hardening against SQL injection), see
  1666. SA-CORE-2009-001
  1667. - Fixed HTTP_HOST checking to work again with HTTP 1.0 clients and basic shell
  1668. scripts.
  1669. - Fixed a variety of small bugs.
  1670. Drupal 5.14, 2008-12-11
  1671. -----------------------
  1672. - removed a previous change incompatible with PHP 5.1.x and lower.
  1673. Drupal 5.13, 2008-12-10
  1674. -----------------------
  1675. - fixed a variety of small bugs.
  1676. - fixed security issues, (Cross site request forgery and Cross site scripting), see SA-2008-073
  1677. - updated robots.txt and .htaccess to match current file use.
  1678. Drupal 5.12, 2008-10-22
  1679. -----------------------
  1680. - fixed security issues, (File inclusion), see SA-2008-067
  1681. Drupal 5.11, 2008-10-08
  1682. -----------------------
  1683. - fixed a variety of small bugs.
  1684. - fixed security issues, (File upload access bypass, Access rules bypass,
  1685. BlogAPI access bypass, Node validation bypass), see SA-2008-060
  1686. Drupal 5.10, 2008-08-13
  1687. -----------------------
  1688. - fixed a variety of small bugs.
  1689. - fixed security issues, (Cross site scripting, Arbitrary file uploads via
  1690. BlogAPI and Cross site request forgery), see SA-2008-047
  1691. Drupal 5.9, 2008-07-23
  1692. ----------------------
  1693. - fixed a variety of small bugs.
  1694. - fixed security issues, (Session fixation), see SA-2008-046
  1695. Drupal 5.8, 2008-07-09
  1696. ----------------------
  1697. - fixed a variety of small bugs.
  1698. - fixed security issues, (Cross site scripting, cross site request forgery, and
  1699. session fixation), see SA-2008-044
  1700. Drupal 5.7, 2008-01-28
  1701. ----------------------
  1702. - fixed the input format configuration page.
  1703. - fixed a variety of small bugs.
  1704. Drupal 5.6, 2008-01-10
  1705. ----------------------
  1706. - fixed a variety of small bugs.
  1707. - fixed a security issue (Cross site request forgery), see SA-2008-005
  1708. - fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
  1709. - fixed a security issue (Cross site scripting, register_globals), see SA-2008-007
  1710. Drupal 5.5, 2007-12-06
  1711. ----------------------
  1712. - fixed missing missing brackets in a query in the user module.
  1713. - fixed taxonomy feed bug introduced by SA-2007-031
  1714. Drupal 5.4, 2007-12-05
  1715. ----------------------
  1716. - fixed a variety of small bugs.
  1717. - fixed a security issue (SQL injection), see SA-2007-031
  1718. Drupal 5.3, 2007-10-17
  1719. ----------------------
  1720. - fixed a variety of small bugs.
  1721. - fixed a security issue (HTTP response splitting), see SA-2007-024
  1722. - fixed a security issue (Arbitrary code execution via installer), see SA-2007-025
  1723. - fixed a security issue (Cross site scripting via uploads), see SA-2007-026
  1724. - fixed a security issue (User deletion cross site request forgery), see SA-2007-029
  1725. - fixed a security issue (API handling of unpublished comment), see SA-2007-030
  1726. Drupal 5.2, 2007-07-26
  1727. ----------------------
  1728. - changed hook_link() $teaser argument to match documentation.
  1729. - fixed a variety of small bugs.
  1730. - fixed a security issue (cross-site request forgery), see SA-2007-017
  1731. - fixed a security issue (cross-site scripting), see SA-2007-018
  1732. Drupal 5.1, 2007-01-29
  1733. ----------------------
  1734. - fixed security issue (code execution), see SA-2007-005
  1735. - fixed a variety of small bugs.
  1736. Drupal 5.0, 2007-01-15
  1737. ----------------------
  1738. - Completely retooled the administration page
  1739. * /Admin now contains an administration page which may be themed
  1740. * Reorganised administration menu items by task and by module
  1741. * Added a status report page with detailed PHP/MySQL/Drupal information
  1742. - Added web-based installer which can:
  1743. * Check installation and run-time requirements
  1744. * Automatically generate the database configuration file
  1745. * Install pre-made installation profiles or distributions
  1746. * Import the database structure with automatic table prefixing
  1747. * Be localized
  1748. - Added new default Garland theme
  1749. - Added color module to change some themes' color schemes
  1750. - Included the jQuery JavaScript library 1.0.4 and converted all core JavaScript to use it
  1751. - Introduced the ability to alter mail sent from system
  1752. - Module system:
  1753. * Added .info files for module meta-data
  1754. * Added support for module dependencies
  1755. * Improved module installation screen
  1756. * Moved core modules to their own directories
  1757. * Added support for module uninstalling
  1758. - Added support for different cache backends
  1759. - Added support for a generic "sites/all" directory.
  1760. - Usability:
  1761. * Added support for auto-complete forms (AJAX) to user profiles.
  1762. * Made it possible to instantly assign roles to newly created user accounts.
  1763. * Improved configurability of the contact forms.
  1764. * Reorganized the settings pages.
  1765. * Made it easy to investigate popular search terms.
  1766. * Added a 'select all' checkbox and a range select feature to administration tables.
  1767. * Simplified the 'break' tag to split teasers from body.
  1768. * Use proper capitalization for titles, menu items and operations.
  1769. - Integrated urlfilter.module into filter.module
  1770. - Block system:
  1771. * Extended the block visibility settings with a role specific setting.
  1772. * Made it possible to customize all block titles.
  1773. - Poll module:
  1774. * Optionally allow people to inspect all votes.
  1775. * Optionally allow people to cancel their vote.
  1776. - Distributed authentication:
  1777. * Added default server option.
  1778. - Added default robots.txt to control crawlers.
  1779. - Database API:
  1780. * Added db_table_exists().
  1781. - Blogapi module:
  1782. * 'Blogapi new' and 'blogapi edit' nodeapi operations.
  1783. - User module:
  1784. * Added hook_profile_alter().
  1785. * E-mail verification is made optional.
  1786. * Added mass editing and filtering on admin/user/user.
  1787. - PHP Template engine:
  1788. * Add the ability to look for a series of suggested templates.
  1789. * Look for page templates based upon the path.
  1790. * Look for block templates based upon the region, module, and delta.
  1791. - Content system:
  1792. * Made it easier for node access modules to work well with each other.
  1793. * Added configurable content types.
  1794. * Changed node rendering to work with structured arrays.
  1795. - Performance:
  1796. * Improved session handling: reduces database overhead.
  1797. * Improved access checking: reduces database overhead.
  1798. * Made it possible to do memcached based session management.
  1799. * Omit sidebars when serving a '404 - Page not found': saves CPU cycles and bandwidth.
  1800. * Added an 'aggressive' caching policy.
  1801. * Added a CSS aggregator and compressor (up to 40% faster page loads).
  1802. - Removed the archive module.
  1803. - Upgrade system:
  1804. * Created space for update branches.
  1805. - Form API:
  1806. * Made it possible to programmatically submit forms.
  1807. * Improved api for multistep forms.
  1808. - Theme system:
  1809. * Split up and removed drupal.css.
  1810. * Added nested lists generation.
  1811. * Added a self-clearing block class.
  1812. Drupal 4.7.11, 2008-01-10
  1813. -------------------------
  1814. - fixed a security issue (Cross site request forgery), see SA-2008-005
  1815. - fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
  1816. - fixed a security issue (Cross site scripting, register_globals), see SA-2008-007
  1817. Drupal 4.7.10, 2007-12-06
  1818. -------------------------
  1819. - fixed taxonomy feed bug introduced by SA-2007-031
  1820. Drupal 4.7.9, 2007-12-05
  1821. ------------------------
  1822. - fixed a security issue (SQL injection), see SA-2007-031
  1823. Drupal 4.7.8, 2007-10-17
  1824. ------------------------
  1825. - fixed a security issue (HTTP response splitting), see SA-2007-024
  1826. - fixed a security issue (Cross site scripting via uploads), see SA-2007-026
  1827. - fixed a security issue (API handling of unpublished comment), see SA-2007-030
  1828. Drupal 4.7.7, 2007-07-26
  1829. ------------------------
  1830. - fixed security issue (XSS), see SA-2007-018
  1831. Drupal 4.7.6, 2007-01-29
  1832. ------------------------
  1833. - fixed security issue (code execution), see SA-2007-005
  1834. Drupal 4.7.5, 2007-01-05
  1835. ------------------------
  1836. - Fixed security issue (XSS), see SA-2007-001
  1837. - Fixed security issue (DoS), see SA-2007-002
  1838. Drupal 4.7.4, 2006-10-18
  1839. ------------------------
  1840. - Fixed security issue (XSS), see SA-2006-024
  1841. - Fixed security issue (CSRF), see SA-2006-025
  1842. - Fixed security issue (Form action attribute injection), see SA-2006-026
  1843. Drupal 4.7.3, 2006-08-02
  1844. ------------------------
  1845. - Fixed security issue (XSS), see SA-2006-011
  1846. Drupal 4.7.2, 2006-06-01
  1847. ------------------------
  1848. - Fixed critical upload issue, see SA-2006-007
  1849. - Fixed taxonomy XSS issue, see SA-2006-008
  1850. - Fixed a variety of small bugs.
  1851. Drupal 4.7.1, 2006-05-24
  1852. ------------------------
  1853. - Fixed critical SQL issue, see SA-2006-005
  1854. - Fixed a serious upgrade related bug.
  1855. - Fixed a variety of small bugs.
  1856. Drupal 4.7.0, 2006-05-01
  1857. ------------------------
  1858. - Added free tagging support.
  1859. - Added a site-wide contact form.
  1860. - Theme system:
  1861. * Added the PHPTemplate theme engine and removed the Xtemplate engine.
  1862. * Converted the bluemarine theme from XTemplate to PHPTemplate.
  1863. * Converted the pushbutton theme from XTemplate to PHPTemplate.
  1864. - Usability:
  1865. * Reworked the 'request new password' functionality.
  1866. * Reworked the node and comment edit forms.
  1867. * Made it easy to add nodes to the navigation menu.
  1868. * Added site 'offline for maintenance' feature.
  1869. * Added support for auto-complete forms (AJAX).
  1870. * Added support for collapsible page sections (JS).
  1871. * Added support for resizable text fields (JS).
  1872. * Improved file upload functionality (AJAX).
  1873. * Reorganized some settings pages.
  1874. * Added friendly database error screens.
  1875. * Improved styling of update.php.
  1876. - Refactored the forms API.
  1877. * Made it possible to alter, extend or theme forms.
  1878. - Comment system:
  1879. * Added support for "mass comment operations" to ease repetitive tasks.
  1880. * Comment moderation has been removed.
  1881. - Node system:
  1882. * Reworked the revision functionality.
  1883. * Removed the bookmarklet code. Third-party modules can now handle
  1884. This.
  1885. - Upgrade system:
  1886. * Allows contributed modules to plug into the upgrade system.
  1887. - Profiles:
  1888. * Added a block to display author information along with posts.
  1889. * Added support for private profile fields.
  1890. - Statistics module:
  1891. * Added the ability to track page generation times.
  1892. * Made it possible to block certain IPs/hostnames.
  1893. - Block system:
  1894. * Added support for theme-specific block regions.
  1895. - Syndication:
  1896. * Made the aggregator module parse Atom feeds.
  1897. * Made the aggregator generate RSS feeds.
  1898. * Added RSS feed settings.
  1899. - XML-RPC:
  1900. * Replaced the XML-RPC library by a better one.
  1901. - Performance:
  1902. * Added 'loose caching' option for high-traffic sites.
  1903. * Improved performance of path aliasing.
  1904. * Added the ability to track page generation times.
  1905. - Internationalization:
  1906. * Improved Unicode string handling API.
  1907. * Added support for PHP's multibyte string module.
  1908. - Added support for PHP5's 'mysqli' extension.
  1909. - Search module:
  1910. * Made indexer smarter and more robust.
  1911. * Added advanced search operators (e.g. phrase, node type, ...).
  1912. * Added customizable result ranking.
  1913. - PostgreSQL support:
  1914. * Removed dependency on PL/pgSQL procedural language.
  1915. - Menu system:
  1916. * Added support for external URLs.
  1917. - Queue module:
  1918. * Removed from core.
  1919. - HTTP handling:
  1920. * Added support for a tolerant Base URL.
  1921. * Output URIs relative to the root, without a base tag.
  1922. Drupal 4.6.11, 2007-01-05
  1923. -------------------------
  1924. - Fixed security issue (XSS), see SA-2007-001
  1925. - Fixed security issue (DoS), see SA-2007-002
  1926. Drupal 4.6.10, 2006-10-18
  1927. -------------------------
  1928. - Fixed security issue (XSS), see SA-2006-024
  1929. - Fixed security issue (CSRF), see SA-2006-025
  1930. - Fixed security issue (Form action attribute injection), see SA-2006-026
  1931. Drupal 4.6.9, 2006-08-02
  1932. ------------------------
  1933. - Fixed security issue (XSS), see SA-2006-011
  1934. Drupal 4.6.8, 2006-06-01
  1935. ------------------------
  1936. - Fixed critical upload issue, see SA-2006-007
  1937. - Fixed taxonomy XSS issue, see SA-2006-008
  1938. Drupal 4.6.7, 2006-05-24
  1939. ------------------------
  1940. - Fixed critical SQL issue, see SA-2006-005
  1941. Drupal 4.6.6, 2006-03-13
  1942. ------------------------
  1943. - Fixed bugs, including 4 security vulnerabilities.
  1944. Drupal 4.6.5, 2005-12-12
  1945. ------------------------
  1946. - Fixed bugs: no critical bugs were identified.
  1947. Drupal 4.6.4, 2005-11-30
  1948. ------------------------
  1949. - Fixed bugs, including 3 security vulnerabilities.
  1950. Drupal 4.6.3, 2005-08-15
  1951. ------------------------
  1952. - Fixed bugs, including a critical "arbitrary PHP code execution" bug.
  1953. Drupal 4.6.2, 2005-06-29
  1954. ------------------------
  1955. - Fixed bugs, including two critical "arbitrary PHP code execution" bugs.
  1956. Drupal 4.6.1, 2005-06-01
  1957. ------------------------
  1958. - Fixed bugs, including a critical input validation bug.
  1959. Drupal 4.6.0, 2005-04-15
  1960. ------------------------
  1961. - PHP5 compliance
  1962. - Search:
  1963. * Added UTF-8 support to make it work with all languages.
  1964. * Improved search indexing algorithm.
  1965. * Improved search output.
  1966. * Impose a throttle on indexing of large sites.
  1967. * Added search block.
  1968. - Syndication:
  1969. * Made the ping module ping pingomatic.com which, in turn, will ping all the major ping services.
  1970. * Made Drupal generate RSS 2.0 feeds.
  1971. * Made RSS feeds extensible.
  1972. * Added categories to RSS feeds.
  1973. * Added enclosures to RSS feeds.
  1974. - Flood control mechanism:
  1975. * Added a mechanism to throttle certain operations.
  1976. - Usability:
  1977. * Refactored the block configuration pages.
  1978. * Refactored the statistics pages.
  1979. * Refactored the watchdog pages.
  1980. * Refactored the throttle module configuration.
  1981. * Refactored the access rules page.
  1982. * Refactored the content administration page.
  1983. * Introduced forum configuration pages.
  1984. * Added a 'add child page' link to book pages.
  1985. - Contact module:
  1986. * Added a simple contact module that allows users to contact each other using e-mail.
  1987. - Multi-site configuration:
  1988. * Made it possible to run multiple sites from a single code base.
  1989. - Added an image API: enables better image handling.
  1990. - Block system:
  1991. * Extended the block visibility settings.
  1992. - Theme system:
  1993. * Added new theme functions.
  1994. - Database backend:
  1995. * The PEAR database backend is no longer supported.
  1996. - Performance:
  1997. * Improved performance of the forum topics block.
  1998. * Improved performance of the tracker module.
  1999. * Improved performance of the node pages.
  2000. - Documentation:
  2001. * Improved and extended PHPDoc/Doxygen comments.
  2002. Drupal 4.5.8, 2006-03-13
  2003. ------------------------
  2004. - Fixed bugs, including 3 security vulnerabilities.
  2005. Drupal 4.5.7, 2005-12-12
  2006. ------------------------
  2007. - Fixed bugs: no critical bugs were identified.
  2008. Drupal 4.5.6, 2005-11-30
  2009. ------------------------
  2010. - Fixed bugs, including 3 security vulnerabilities.
  2011. Drupal 4.5.5, 2005-08-15
  2012. ------------------------
  2013. - Fixed bugs, including a critical "arbitrary PHP code execution" bug.
  2014. Drupal 4.5.4, 2005-06-29
  2015. ------------------------
  2016. - Fixed bugs, including two critical "arbitrary PHP code execution" bugs.
  2017. Drupal 4.5.3, 2005-06-01
  2018. ------------------------
  2019. - Fixed bugs, including a critical input validation bug.
  2020. Drupal 4.5.2, 2005-01-15
  2021. ------------------------
  2022. - Fixed bugs: a cross-site scripting (XSS) vulnerability has been fixed.
  2023. Drupal 4.5.1, 2004-12-01
  2024. ------------------------
  2025. - Fixed bugs: no critical bugs were identified.
  2026. Drupal 4.5.0, 2004-10-18
  2027. ------------------------
  2028. - Navigation:
  2029. * Made it possible to add, delete, rename and move menu items.
  2030. * Introduced tabs and subtabs for local tasks.
  2031. * Reorganized the navigation menus.
  2032. - User management:
  2033. * Added support for multiple roles per user.
  2034. * Made it possible to add custom profile fields.
  2035. * Made it possible to browse user profiles by field.
  2036. - Node system:
  2037. * Added support for node-level permissions.
  2038. - Comment module:
  2039. * Made it possible to leave contact information without having to register.
  2040. - Upload module:
  2041. * Added support for uploading documents (includes images).
  2042. - Forum module:
  2043. * Added support for sticky forum topics.
  2044. * Made it possible to track forum topics.
  2045. - Syndication:
  2046. * Added support for RSS ping-notifications of http://technorati.com/.
  2047. * Refactored the categorization of syndicated news items.
  2048. * Added an URL alias for 'rss.xml'.
  2049. * Improved date parsing.
  2050. - Database backend:
  2051. * Added support for multiple database connections.
  2052. * The PostgreSQL backend does no longer require PEAR.
  2053. - Theme system:
  2054. * Changed all GIFs to PNGs.
  2055. * Reorganised the handling of themes, template engines, templates and styles.
  2056. * Unified and extended the available theme settings.
  2057. * Added theme screenshots.
  2058. - Blocks:
  2059. * Added 'recent comments' block.
  2060. * Added 'categories' block.
  2061. - Blogger API:
  2062. * Added support for auto-discovery of blogger API via RSD.
  2063. - Performance:
  2064. * Added support for sending gzip compressed pages.
  2065. * Improved performance of the forum module.
  2066. - Accessibility:
  2067. * Improved the accessibility of the archive module's calendar.
  2068. * Improved form handling and error reporting.
  2069. * Added HTTP redirects to prevent submitting twice when refreshing right after a form submission.
  2070. - Refactored 403 (forbidden) handling and added support for custom 403 pages.
  2071. - Documentation:
  2072. * Added PHPDoc/Doxygen comments.
  2073. - Filter system:
  2074. * Added support for using multiple input formats on the site
  2075. * Expanded the embedded PHP-code feature so it can be used everywhere
  2076. * Added support for role-dependent filtering, through input formats
  2077. - UI translation:
  2078. * Managing translations is now completely done through the administration interface
  2079. * Added support for importing/exporting gettext .po files
  2080. Drupal 4.4.3, 2005-06-01
  2081. ------------------------
  2082. - Fixed bugs, including a critical input validation bug.
  2083. Drupal 4.4.2, 2004-07-04
  2084. ------------------------
  2085. - Fixed bugs: no critical bugs were identified.
  2086. Drupal 4.4.1, 2004-05-01
  2087. ------------------------
  2088. - Fixed bugs: no critical bugs were identified.
  2089. Drupal 4.4.0, 2004-04-01
  2090. ------------------------
  2091. - Added support for the MetaWeblog API and MovableType extensions.
  2092. - Added a file API: enables better document management.
  2093. - Improved the watchdog and search module to log search keys.
  2094. - News aggregator:
  2095. * Added support for conditional GET.
  2096. * Added OPML feed subscription list.
  2097. * Added support for , , , , and .
  2098. - Comment module:
  2099. * Made it possible to disable the "comment viewing controls".
  2100. - Performance:
  2101. * Improved module loading when serving cached pages.
  2102. * Made it possible to automatically disable modules when under heavy load.
  2103. * Made it possible to automatically disable blocks when under heavy load.
  2104. * Improved performance and memory footprint of the locale module.
  2105. - Theme system:
  2106. * Made all theme functions start with 'theme_'.
  2107. * Made all theme functions return their output.
  2108. * Migrated away from using the BaseTheme class.
  2109. * Added many new theme functions and refactored existing theme functions.
  2110. * Added avatar support to 'Xtemplate'.
  2111. * Replaced theme 'UnConeD' by 'Chameleon'.
  2112. * Replaced theme 'Marvin' by 'Pushbutton'.
  2113. - Usability:
  2114. * Added breadcrumb navigation to all pages.
  2115. * Made it possible to add context-sensitive help to all pages.
  2116. * Replaced drop-down menus by radio buttons where appropriate.
  2117. * Removed the 'magic_quotes_gpc = 0' requirement.
  2118. * Added a 'book navigation' block.
  2119. - Accessibility:
  2120. * Made themes degrade gracefully in absence of CSS.
  2121. * Grouped form elements using '
    ' and '' tags.
  2122. * Added '
  2123. - Refactored 404 (file not found) handling and added support for custom 404 pages.
  2124. - Improved the filter system to prevent conflicts between filters:
  2125. * Made it possible to change the order in which filters are applied.
  2126. - Documentation:
  2127. * Added PHPDoc/Doxygen comments.
  2128. Drupal 4.3.2, 2004-01-01
  2129. ------------------------
  2130. - Fixed bugs: no critical bugs were identified.
  2131. Drupal 4.3.1, 2003-12-01
  2132. ------------------------
  2133. - Fixed bugs: no critical bugs were identified.
  2134. Drupal 4.3.0, 2003-11-01
  2135. ------------------------
  2136. - Added support for configurable URLs.
  2137. - Added support for sortable table columns.
  2138. - Database backend:
  2139. * Added support for selective database table prefixing.
  2140. - Performance:
  2141. * Optimized many SQL queries for speed by converting left joins to inner joins.
  2142. - Comment module:
  2143. * Rewrote the comment housekeeping code to be much more efficient and scalable.
  2144. * Changed the comment module to use the standard pager.
  2145. - User module:
  2146. * Added support for multiple sessions per user.
  2147. * Added support for anonymous user sessions.
  2148. - Forum module:
  2149. * Improved the forum views and the themability thereof.
  2150. - Book module:
  2151. * Improved integration of non-book nodes in the book outline.
  2152. - Usability:
  2153. * Added support for "mass node operations" to ease repetitive tasks.
  2154. * Added support for breadcrumb navigation to several modules' user pages.
  2155. * Integrated the administration pages with the normal user pages.
  2156. Drupal 4.2.0, 2003-08-01
  2157. ------------------------
  2158. - Added support for clean URLs.
  2159. - Added textarea hook and support for onload attributes: enables integration of WYSIWYG editors.
  2160. - Rewrote the RSS/RDF parser:
  2161. * It will now use PHP's built-in XML parser to parse news feeds.
  2162. - Rewrote the administration pages:
  2163. * Improved the navigational elements and added breadcrumb navigation.
  2164. * Improved the look and feel.
  2165. * Added context-sensitive help.
  2166. - Database backend:
  2167. * Fixed numerous SQL queries to make Drupal ANSI compliant.
  2168. * Added MSSQL database scheme.
  2169. - Search module:
  2170. * Changed the search module to use implicit AND'ing instead of implicit OR'ing.
  2171. - Node system:
  2172. * Replaced the "post content" permission by more fine-grained permissions.
  2173. * Improved content submission:
  2174. + Improved teasers: teasers are now optional, teaser length can be configured, teaser and body are edited in a single textarea, users will no longer be bothered with teasers when the post is too short for one.
  2175. + Added the ability to preview both the short and the full version of your posts.
  2176. * Extended the node API which allows for better integration.
  2177. * Added default node settings to control the behavior for promotion, moderation and other options.
  2178. - Themes:
  2179. * Replaced theme "Goofy" by "Xtemplate", a template driven theme.
  2180. - Removed the 'register_globals = on' requirement.
  2181. - Added better installation instructions.
  2182. Drupal 4.1.0, 2003-02-01
  2183. ------------------------
  2184. - Collaboratively revised and expanded the Drupal documentation.
  2185. - Rewrote comment.module:
  2186. * Reintroduced comment rating/moderation.
  2187. * Added support for comment paging.
  2188. * Performance improvements: improved comment caching, faster SQL queries, etc.
  2189. - Rewrote block.module:
  2190. * Performance improvements: blocks are no longer rendered when not displayed.
  2191. - Rewrote forum.module:
  2192. * Added a lot of features one can find in stand-alone forum software including but not limited to support for topic paging, added support for icons, rewrote the statistics module, etc.
  2193. - Rewrote statistics.module:
  2194. * Collects access counts for each node, referrer logs, number of users/guests.
  2195. * Export blocks displaying top viewed nodes over last 24 hour period, top viewed nodes over all time, last nodes viewed, how many users/guest online.
  2196. - Added throttle.module:
  2197. * Auto-throttle congestion control mechanism: Drupal can adapt itself based on the server load.
  2198. - Added profile.module:
  2199. * Enables to extend the user and registration page.
  2200. - Added pager support to the main page.
  2201. - Replaced weblogs.module by ping.module:
  2202. * Added support for normal and RSS notifications of http://blo.gs/.
  2203. * Added support for RSS ping-notifications of http://weblogs.com/.
  2204. - Removed the rating module
  2205. - Themes:
  2206. * Removed a significant portion of hard-coded mark-up.
  2207. Drupal 4.0.0, 2002-06-15
  2208. ------------------------
  2209. - Added tracker.module:
  2210. * Replaces the previous "your [site]" links (recent comments and nodes).
  2211. - Added weblogs.module:
  2212. * This will ping weblogs.com when new content is promoted.
  2213. - Added taxonomy module which replaces the meta module.
  2214. * Supports relations, hierarchies and synonyms.
  2215. - Added a caching system:
  2216. * Speeds up pages for anonymous users and reduces system load.
  2217. - Added support for external SMTP libraries.
  2218. - Added an archive extension to the calendar.
  2219. - Added support for the Blogger API.
  2220. - Themes:
  2221. * Cleaned up the theme system.
  2222. * Moved themes that are not maintained to contributions CVS repository.
  2223. - Database backend:
  2224. * Changed to PEAR database abstraction layer.
  2225. * Using ANSI SQL queries to be more portable.
  2226. - Rewrote the user system:
  2227. * Added support for Drupal authentication through XML-RPC and through a Jabber server.
  2228. * Added support for modules to add more user data.
  2229. * Users may delete their own account.
  2230. * Added who's new and who's online blocks.
  2231. - Changed block system:
  2232. * Various hard coded blocks are now dynamic.
  2233. * Blocks can now be enabled and/or be set by the user.
  2234. * Blocks can be set to only show up on some pages.
  2235. * Merged box module with block module.
  2236. - Node system:
  2237. * Blogs can be updated.
  2238. * Teasers (abstracts) on all node types.
  2239. * Improved error checking.
  2240. * Content versioning support.
  2241. * Usability improvements.
  2242. - Improved book module to support text, HTML and PHP pages.
  2243. - Improved comment module to mark new comments.
  2244. - Added a general outliner which will let any node type be linked to a book.
  2245. - Added an update script that lets you upgrade from previous releases or on a day to day basis when using the development tree.
  2246. - Search module:
  2247. * Improved the search system by making it context sensitive.
  2248. * Added indexing.
  2249. - Various updates:
  2250. * Changed output to valid XHTML.
  2251. * Improved multiple sites using the same Drupal database support.
  2252. * Added support for session IDs in URLs instead of cookies.
  2253. * Made the type of content on the front page configurable.
  2254. * Made each cloud site have its own settings.
  2255. * Modules and themes can now be enabled/disabled using the administration pages.
  2256. * Added URL abstraction for links.
  2257. * Usability changes (renamed links, better UI, etc).
  2258. - Collaboratively revised and expanded the Drupal documentation.
  2259. Drupal 3.0.1, 2001-10-15
  2260. ------------------------
  2261. - Various updates:
  2262. * Added missing translations
  2263. * Updated the themes: tidied up some HTML code and added new Drupal logos.
  2264. Drupal 3.0.0, 2001-09-15
  2265. ------------------------
  2266. - Major overhaul of the entire underlying design:
  2267. * Everything is based on nodes: nodes are a conceptual "black box" to couple and manage different types of content and that promotes reusing existing code, thus reducing the complexity and size of Drupal as well as improving long-term stability.
  2268. - Rewrote submission/moderation queue and renamed it to queue.module.
  2269. - Removed FAQ and documentation module and merged them into a "book module".
  2270. - Removed ban module and integrated it into account.module as "access control":
  2271. * Access control is based on much more powerful regular expressions (regex) now rather than on MySQL pattern matching.
  2272. - Rewrote watchdog and submission throttle:
  2273. * Improved watchdog messages and added watchdog filter.
  2274. - Rewrote headline code and renamed it to import.module and export.module:
  2275. * Added various improvements, including a better parser, bundles and better control over individual feeds.
  2276. - Rewrote section code and renamed it to meta.module:
  2277. * Supports unlimited amount of nested topics. Topics can be nested to create a multi-level hierarchy.
  2278. - Rewrote configuration file resolving:
  2279. * Drupal tries to locate a configuration file that matches your domain name or uses conf.php if the former failed. Note also that the configuration files got renamed from .conf to .php for security's sake on mal-configured Drupal sites.
  2280. - Added caching support which makes Drupal extremely scalable.
  2281. - Added access.module:
  2282. * Allows you to set up 'roles' (groups) and to bind a set of permissions to each group.
  2283. - Added blog.module.
  2284. - Added poll.module.
  2285. - Added system.module:
  2286. * Moved most of the configuration options from hostname.conf to the new administration section.
  2287. * Added support for custom "filters".
  2288. - Added statistics.module
  2289. - Added moderate.module:
  2290. * Allows to assign users editorial/moderator rights to certain nodes or topics.
  2291. - Added page.module:
  2292. * Allows creation of static (and dynamic) pages through the administration interface.
  2293. - Added help.module:
  2294. * Groups all available module documentation on a single page.
  2295. - Added forum.module:
  2296. * Added an integrated forum.
  2297. - Added cvs.module and cvs-to-sql.pl:
  2298. * Allows to display and mail CVS log messages as daily digests.
  2299. - Added book.module:
  2300. * Allows collaborative handbook writing: primary used for Drupal documentation.
  2301. - Removed cron.module and integrated it into conf.module.
  2302. - Removed module.module as it was no longer needed.
  2303. - Various updates:
  2304. * Added "auto-post new submissions" feature versus "moderate new submissions".
  2305. * Introduced links/Drupal tags: [[link]]
  2306. * Added preview functionality when submitting new content (such as a story) from the administration pages.
  2307. * Made the administration section only show those links a user has access to.
  2308. * Made all modules use specific form_* functions to guarantee a rock-solid forms and more consistent layout.
  2309. * Improved scheduler:
  2310. + Content can be scheduled to be 'posted', 'queued' and 'hidden'.
  2311. * Improved account module:
  2312. + Added "access control" to allow/deny certain usernames/e-mail addresses/hostnames.
  2313. * Improved locale module:
  2314. + Added new overview to easy the translation process.
  2315. * Improved comment module:
  2316. + Made it possible to permanently delete comments.
  2317. * Improved rating module
  2318. * Improved story module:
  2319. + Added preview functionality for administrators.
  2320. + Made it possible to permanently delete stories.
  2321. * Improved themes:
  2322. + W3C validation on a best effort basis.
  2323. + Removed $theme->control() from themes.
  2324. + Added theme "goofy".
  2325. - Collaboratively revised and expanded the Drupal documentation.
  2326. Drupal 2.0.0, 2001-03-15
  2327. ------------------------
  2328. - Rewrote the comment/discussion code:
  2329. * Comment navigation should be less confusing now.
  2330. * Additional/alternative display and order methods have been added.
  2331. * Modules can be extended with a "comment system": modules can embed the existing comment system without having to write their own, duplicate comment system.
  2332. - Added sections and section manager:
  2333. * Story sections can be maintained from the administration pages.
  2334. * Story sections make the open submission more adaptive in that you can set individual post, dump and expiration thresholds for each section according to the story type and urgency level: stories in certain sections do not "expire" and might stay interesting and active as time passes by, whereas news-related stories are only considered "hot" over a short period of time.
  2335. - Multiple vhosts + multiple directories:
  2336. * You can set up multiple Drupal sites on top of the same physical source tree either by using vhosts or sub-directories.
  2337. - Added "user ratings" similar to SlashCode's Karma or Scoop's Mojo:
  2338. * All rating logic is packed into a module to ease experimenting with different rating heuristics/algorithms.
  2339. - Added "search infrastructure":
  2340. * Improved search page and integrated search functionality in the administration pages.
  2341. - Added translation / localization / internationalization support:
  2342. * Because many people would love to see their website showing a lot less of English, and far more of their own language, Drupal provides a framework to set up a multi-lingual website or to overwrite the default English text in English.
  2343. - Added fine-grained user permission (or group) system:
  2344. * Users can be granted access to specific administration sections. Example: a FAQ maintainer can be given access to maintain the FAQ and translators can be given access to the translation pages.
  2345. - Added FAQ module
  2346. - Changed the "open submission queue" into a (optional) module.
  2347. - Various updates:
  2348. * Improved account module:
  2349. + User accounts can be deleted.
  2350. + Added fine-grained permission support.
  2351. * Improved block module
  2352. * Improved diary module:
  2353. + Diary entries can be deleted
  2354. * Improved headline module:
  2355. + Improved parser to support more "generic" RDF/RSS/XML backend.
  2356. * Improved module module
  2357. * Improved watchdog module
  2358. * Improved database abstraction layer
  2359. * Improved themes:
  2360. + W3C validation on a best effort basis
  2361. + Added theme "example" (alias "Stone Age")
  2362. * Added new scripts to directory "scripts"
  2363. * Added directory "misc"
  2364. * Added CREDITS file
  2365. - Revised documentation
  2366. Drupal 1.0.0, 2001-01-15
  2367. ------------------------
  2368. - Initial release