Upgraded drupal core with security updates
[yaffs-website] / web / core / CHANGELOG.txt
1 Drupal 8.3.7, 2017-08-16
2 ------------------------
3 - Fixed security issues. See SA-CORE-2017-004.
4
5 Drupal 8.3.4, 2017-06-21
6 ------------------------
7 - Fixed security issues. See SA-CORE-2017-003.
8
9 Drupal 8.3.1, 2017-04-19
10 ------------------------
11 - Fixed security issues. See SA-CORE-2017-002.
12
13 Drupal 8.3.0, 2017-04-05
14 ------------------------
15 - Added modules:
16     * Added the Workflows module (experimental) which abstracts transitions and
17       states from Content Moderation into a separate component for reuse by
18       other modules implementing non-publishing workflows.
19     * Added the Layout Discovery module (experimental) which provides an API for
20       modules or themes to register layouts.
21     * Added the Field Layout module (experimental) which provides the ability
22       for site builders to rearrange fields on content types, block types, etc.
23       into new regions, for both the form and display, on the same forms
24       provided by the normal field user interface.
25 - Updated vendor libraries:
26     * Updated to Twig 1.25.
27     * Updated to jQuery 2.2.4.
28     * Updated to CKEditor 4.6.2 (with new Moono-Lisa skin).
29     * Updated Symfony components to 2.8.18.
30     * Updated PHPUnit to 4.8.35.
31     * Applied patch-level updates to the latest versions for all dependencies
32       wherever possible. Minor updates applied for Symfony PSR-7 Bridge and
33       Zend Stdlib, which Drupal does not depend on directly.
34 - Browser support:
35     * Advance notice: Internet Explore 9 and 10 will no longer supported from
36       8.4.x, scheduled for October 2017. Microsoft has now ended support for
37       these browsers. Drupal will still support Internet Explorer 11 and its
38       replacement, Edge.
39 - Raised stability levels of experimental modules:
40     * Updated the BigPipe module from beta to stable.
41     * Updated the Migrate module from alpha to beta.
42     * See https://www.drupal.org/core/experimental#versions for more
43       information about the stability levels of experimental modules.
44 - Improved authoring features:
45     * Can now drag and drop images into image fields in Quick Edit mode.
46     * Image fields are now limited to only accepting images, so that users on
47       mobile clients are not offered a confusing and non-functional video
48       upload option.
49     * CKEditor now utilizes the AutoGrow plugin to better take advantage of
50       larger screen sizes.
51 - Improved site building and administration:
52     * Redesigned status report.
53     * Standardized display of Views overview page to more closely match that of
54       other administrative overview pages.
55     * Views filter order now matches the table column order below in Content
56       and People overview pages.
57     * The "Allowed HTML tags" input has been converted to a textarea, which
58       significantly improves the usability of HTML filter configuration.
59     * Removed the 'disabled' region from block administration.
60     * Incoming paths are again case-insensitive for routing, similar to earlier
61       major Drupal versions.
62 - Content Moderation improvements (experimental):
63     * Refactored to use new experimental Workflows module.
64     * Now supports moderation of non-translatable entity types.
65     * When reverting a moderated revision, the moderation state is now
66       reverted too.
67     * Added an API to create and enforce default workflow states and
68       transitions.
69     * Allow moderation of entity types without bundles, as long as they have
70       revisions.
71     * Publishes any entity type that implements EntityPublishedInterface, not
72       just Nodes.
73 - Migration improvements (experimental):
74     * Drupal 7 core node translations are now migrated to Drupal 8.
75     * Configuration translation support is added to migrations in general and
76       implemented for Drupal 6 user profile fields.
77 - Improved REST API and decoupled site features:
78     * REST API now supports the registering of users.
79     * Anonymous REST API performance increased by 60% by utilizing the internal
80       page cache.
81     * Improved the response bodies and status codes for requests with incorrect
82       request headers or request bodies, in dozens of situations.
83     * Massive overhaul of the test coverage.
84     * 403 responses now return reason why access was denied.
85     * Serialized values for Booleans and integers are now returned as the
86       correct data type, rather than incorrectly typed as strings.
87 - Improved performance/scalability:
88     * Optimized class loader detection made more generic to support class
89       loaders other than ApcClassLoader.
90     * ViewsData and Token info cache now use the default cache bin to prevent
91       APCu memory from being filled too quickly.
92     * Improve statistics performance by adding a swappable backend.
93 - Improved developer APIs:
94     * Deprecated several routing services in favor of two more unified services.
95     * Replaced the deprecated Symfony ExecutionContextInterface by subclassing
96       from ConstraintValidator to prepare for an update to Symfony 3.
97     * EntityPublishedInterface and EntityPublishedTrait have been added to give
98       a generic publishing API, and are being used by Node and Comment entity
99       types.
100     * Added a collection label to EntityType. This is a plural uppercase label
101       for a collection of entities - e.g. "Workflows".
102 - Changed coding standards:
103     * Officially adopted short array syntax and updated all of core accordingly.
104     * PHP CodeSniffer and Drupal Coder have been added as composer dev
105       requirements, so they can be installed automatically with
106       `composer install --dev` rather than requiring separate installation. (Do
107       not use `composer install --dev` for production sites.)
108     * Most global constants in Drupal 8 have been deprecated in favor of class
109       constants. As a best practice, use appropriate class constants rather than
110       global constants.
111 - Testing improvements:
112     * Integrated PHPUnit verbose output in SimpleTest UI.
113     * Improved backward compatibility with WebTestBase.
114     * Improved backward compatibility between BrowserTestBase and WebTestBase.
115     * Many old WebTestBase tests have been moved to BrowserTestBase.
116     * Expanded automated test coverage for JavaScript.
117 - Package management:
118     * composer.json now uses the new official endpoint for modules and themes,
119       packages.drupal.org.
120     * Custom modules and themes can now be installed to correct locations using
121       composer.
122     * Added Package.json enabling new JavaScript language features.
123
124 Drupal 8.2.0, 2016-10-05
125 ------------------------
126 - Updated the git repository configuration to not normalize line endings for
127   files of unknown type.
128 - Added vendor libraries:
129     * Added Stack/Cors 1.0.0.
130 - Updated vendor libraries:
131     * Updated to jQuery 2.2.3.
132     * Updated to Twig 1.24.
133     * Updated to CKEditor 4.5.11.
134     * Updated to Symfony Routing 1.4.0.
135     * Updated to Stack/Builder 1.0.4.
136     * Updated to Guzzle 6.2.1.
137 - Added modules:
138     * Added the Place Block module (experimental) to place a block on any page
139       without having to navigate to the backend administration form.
140     * Added the Settings Tray module (experimental) to edit the configuration of
141       any block on the page. Its machine name in this release is "outside_in".
142     * Added the Content Moderation module (experimental) to define and use
143       workflow states such as Draft, Archived and Published. This functionality
144       was previously provided by the contributed module Workbench Moderation.
145     * Added the Datetime Range module (experimental) that provides a new field
146       type with support for start and end dates.
147 - Raised stability levels of experimental modules:
148     * Updated the BigPipe module from alpha to beta.
149     * See https://www.drupal.org/core/experimental#versions for more
150       information about the stability levels of experimental modules.
151 - Improved authoring features:
152     * Relative URLs are automatically converted to absolute ones when content
153       is output to an RSS feed.
154     * Enabled revisions by default on new node types.
155     * Added a redirect option to site-wide contact forms.
156     * Whenever a new entity is created, a link to it is now provided in a
157       status message, for easy access to it regardless of the form workflow.
158     * Styled CKEditor dialogs to match Drupal dialogs.
159 - Improved site administration experience:
160     * Numerous improvements to user interface text.
161 - Improved site building features:
162     * Added the ability to remove a module's content entities prior to
163       uninstallation.
164     * Made it possible to select the comment view mode in the formatter form.
165     * Fixed the Migrate module to skip over migration sources that require
166       code from uninstalled modules.
167 - Improved REST API and decoupled site features:
168     * Added support for reading (GET) configuration entities as REST resources.
169     * Added dedicated resources for user login, logout and registration.
170     * Added support for selecting an authentication provider as part of the
171       configuration of a REST Export Views Display.
172     * Added a cors.config service parameter for enabling and configuring
173       cross-origin resource sharing (CORS).
174     * Simplified REST configuration with per-resource configuration entities
175       and less verbose configuration structure. (The previous, advanced
176       configuration structure is also still supported.)
177     * Improved the response messages and status codes for requests with missing
178       or incorrect headers.
179     * Improved responses to PATCH requests to entity resources to contain the
180       updated entity in the response body.
181 - Improved developer APIs:
182     * Added support for specifying the field item delta as part of an entity
183       query condition. This was possible in Drupal 7 via
184       EntityFieldQuery::fieldDeltaCondition(), but missing from earlier
185       versions of Drupal 8.
186 - Improved performance/scalability:
187     * In the internal page cache, 404 responses are now cached for a shorter
188       time (1 hour by default), to consume less space.
189     * Breadcrumbs are now cached by the parent of the path rather than the full
190       path, for fewer cache entries and higher cache hit rates.
191 - Changed coding standards:
192     * Local variables and parameters can now use camelCase.
193     * A blank line is now required after the <?php opening tag.
194 - Testing improvements:
195     * Increased feature parity of BrowserTestBase with WebTestBase, including a
196       deprecated AssertLegacyTrait for easier conversions.
197     * Converted all kernel tests to the PHPUnit-based kernel test API.
198     * Improved error reporting for all PHPUnit tests (including unit, kernel,
199       browser, and JavaScript tests).
200
201 Drupal 8.1.0, 2016-04-20
202 ------------------------
203 - Removed Composer-managed vendor from the git repository:
204     * Drupal.org packager adds dependencies to zip and tar package. This can be
205       used without any further steps.
206     * When not using zip / tar files, e.g. when using a git clone, run composer
207       install to get dependencies.
208     * See https://www.drupal.org/documentation/install/download#git
209       for instructions.
210 - Added vendor libraries:
211     * Added Symfony Polyfill Iconv 1.1.0.
212     * Added paragonie/random_compat 1.4.1.
213 - Updated vendor libraries:
214     * Updated to the last 2.x minor version of Symfony: 2.8 (2.8.4).
215     * Updated to CKEditor 4.5.8.
216     * Updated to Modernizr 3.3.1.
217 - Added modules:
218     * Added the Migrate Drupal UI module (experimental) to provide a UI for
219       migrating content and configuration from Drupal 6 and Drupal 7.
220     * Added the BigPipe module (experimental) to improve perceived performance.
221 - Improved authoring features:
222     * Enabled browsers' (native) spell checker in CKEditor.
223     * Added language toolbar button in CKEditor for identifying the language of
224       text parts.
225 - Improved site administration experience:
226     * Improved admin/help page to be more flexible and list tours on it.
227 - Improved site building features:
228     * Added a "Rendered entity" field handler in Views.
229 - Improved distribution building features:
230     * Added support for distributions to specify an installation language.
231 - Improved developer APIs:
232     * Added local ID and revision fields to HAL web service output.
233     * Added support for image toolkits to be defined with plugin derivatives,
234       reducing the code needed to extend them.
235     * Simplified Migrate API by replacing migration configuration entities with
236       migration plugins.
237     * Various improvements for defining entity types:
238       * Added support for entity types to specify translatable plural labels.
239       * Added a revision log interface and trait for revisionable entity types.
240       * Added key field definitions to ContentEntityBase, reducing code from
241         child classes.
242       * Added generic route providers for add-page and add-form entity routes,
243         reducing the code needed to define an entity type.
244 - Testing improvements:
245     * Added support for automated JavaScript testing.
246     * Added verbose output for BrowserTestBase.
247     * Improved reporting of PHPUnit results.
248
249 Drupal 8.0.0, 2015-11-19
250 ------------------------
251 - Significantly improved the front end:
252     * Made all built-in themes responsive.
253     * Added support for responsive images.
254     * Made built-in tables responsive with three levels of column importance.
255     * Added Twig as the default template engine and converted all .tpl.php
256       templates and theme functions to .html.twig.
257     * Removed the PHPTemplate engine.
258     * Several large scale cleanups of the markup produced by Drupal.
259     * Added Classy as a base theme to maintain CSS classes and wrappers.
260     * Added Stable as the default base theme to maintain backwards compatibility
261       for core template and CSS changes, because templates and CSS outside
262       Stable can be improved in minor releases (8.1.0, 8.2.0, etc.).
263     * Redesigned several key elements of the Seven theme.
264     * Added support for HTML5 elements.
265     * Included Backbone.js and Underscore.js JavaScript frameworks.
266     * Updated to jQuery 2.1.4.
267     * Updated to jQuery UI 1.11.4.
268     * Removed jquery.bbq.
269     * Removed the Garland theme from core.
270     * Removed the Overlay module from core and replaced it with a simple,
271       dynamic "Back to site" link.
272     * Improved the asset library system to manage CSS and JavaScript files and
273       their dependencies. Allowing for smaller AJAX request payloads.
274     * jQuery is no longer loaded on all pages, only when another asset needs it.
275     * No JavaScript is loaded at all for anonymous users by default, for faster
276       page loads.
277     * Implemented SMACSS-style categorization for CSS files.
278     * Removed most support for Internet Explorer 8 and below.
279     * Added Modernizr for making styling changes based on browser support.
280     * All page template variables converted to blocks (title, breadcrumb,
281       branding, etc).
282     * Added the Breakpoint module to manage breakpoints of responsive designs.
283     * Introduced native Schema.org output in pages.
284     * Made use of semantic HTML 5 tags when possible. This also makes form input
285       on mobile devices much easier for users.
286     * Redesigned icons to look good on high resolution (retina) displays too.
287 - Made the site administration experience simpler:
288     * Redesigned the installer.
289     * Visually updated and extended the Seven (administration) theme.
290     * Made the administration toolbar responsive and touch friendly.
291     * Added search to the module listing and made the page easier to read.
292     * Added the tour module to provide highly contextual tips for UI elements.
293 - Improved the entity system:
294     * Added a full CRUD API for entities.
295     * Improved the field API and entity query API.
296     * Added support for widgets, formatters, and translation to base entity
297       fields (such as labels).
298     * Made view modes configurable for reusable display variants.
299     * Introduced form modes for reusable form variants.
300     * Added ability to handle a "default" revision that may not be the latest.
301     * All content entity types (custom blocks, terms, comments, etc.), not just
302       nodes, have support for revisions.
303     * Database schema of content entities is automatically generated based on
304       entity type and field definitions.
305 - Added the Typed Data system to manage complex types.
306 - Refactored routing system based on Symfony2 components.
307 - Made declarative information (libraries, permissions, routes etc.) use YAML
308   files for definitions instead of PHP.
309 - Improved the menu handling systems:
310     * Moved custom menu item handling to its own module.
311     * Reworked menu links, local actions, and local tasks based upon the new
312       routing system.
313 - Added plugin system to standardize implementation of several core APIs.
314 - Introduced a new configuration management system:
315     * Added a centralized configuration system with export and import
316       functionality.
317     * Allowed module authors to provide configuration in a YAML file format.
318     * Implemented functionality to get, set, add, and remove configuration.
319     * Provided the ability to override configuration values with language
320       variants and other runtime values.
321     * Added configuration schema, dependencies, and validation to maintain
322       data integrity between deployments and updates.
323     * Support added for both global configuration and configuration entities.
324 - Improved authoring experience:
325     * Redesigned the content creation and editing form.
326     * Content preview is now displayed on the frontend.
327     * Added the CKEditor WYSIWYG editor. Clean markup guaranteed thanks to tight
328       integration with the filter system.
329     * Made uploading, aligning, and captioning of images possible in the editor.
330     * Modernized the default text formats.
331     * Added a drag-and-drop configuration UI, which automatically updates the
332       HTML filter settings, making configuring text formats trivial for typical
333       use cases.
334     * Added align and caption filters that can be applied to any element:
335       images, blockquotes, code snippets, videos…
336     * Made possible to in-place edit any entity: nodes, blocks…
337     * Added the Text Editor module to help map other editors to text formats.
338 - Improved media management:
339     * Added ability to configure when unused files get deleted with the option
340       to keep them, useful for media libraries.
341     * Added a customizable view under the content administration screen that
342       lists all files uploaded on the system.
343     * Made uploads immediate when selecting files in file fields.
344     * Added ability to upload multiple files at once.
345     * Added local image input filter, to enable secure image posting.
346 - Included the following Symfony2 components:
347     * ClassLoader - PSR-0-compatible autoload routines.
348     * DependencyInjection - Flexible dependency injection container.
349     * EventDispatcher - Object-oriented lightweight event handling system.
350     * HttpFoundation - Abstraction objects for HTTP requests and responses.
351     * HttpKernel - Core system for managing incoming HTTP request and responses.
352     * Process - Allows for executing commands in a sub-process.
353     * Routing - Framework for mapping incoming requests to controller
354       information.
355     * Serialization - Serialize complex nested objects into JSON/XML etc.
356     * Validator - Ensure that an object is in a valid state based upon some
357       validation rules defined for it.
358     * Yaml - Parser for YAML files.
359 - Added routing component from Symfony CMF.
360 - Added Guzzle HTTP library.
361 - Added Zend Feed component.
362 - Removed modules from core.
363     * The following modules have been removed from core, because contributed
364       modules with similar functionality are available:
365       * Blog
366       * Dashboard
367       * OpenID
368       * Poll
369       * Profile
370       * Trigger
371 - Removed the Statistics module's accesslog functionality and reports.
372 - Removed XML-RPC functionality from core.
373 - Removed user signatures support from core.
374 - Added ability to generate and validate Universally Unique IDentifiers (UUIDs).
375 - Tremendously improved language support all around:
376     * Great language improvements for users:
377       * Improved language selection with user preference detection in the
378         installer based on browser settings.
379       * The installer is presented in the user's native language.
380       * Moved base language support to Language module.
381       * Greatly simplified the interface for setting up languages.
382       * Improved browser language detection considerably.
383       * Language domain and path prefix configuration simplified and
384         centralized; path prefix detection is now default.
385       * Added HTML 5 language markup; language information added in markup in
386         several more places.
387       * Made it possible to assign external language codes to local languages.
388       * Introduced the possibility of an administration-specific language
389         preference for users.
390       * Language selection fallback language is now independently configurable
391         without needing to change the site default language.
392     * Simplified and added new features in interface translation:
393       * Made interface translation directly accessible from the language list.
394       * Centralized interface translation import to one directory.
395       * Drupal can now be translated to English and English can be deleted.
396       * Much improved built-in translation interface.
397       * Added support for singular/plural discovery and translation.
398       * Customized translations are tracked so your modifications can
399         be identified and protected from translation update overwrites.
400       * All Gettext files are now imported in chunks, better for low resource
401         environments.
402       * Automated import and update of translations in the installer and later.
403     * Improved content language support:
404       * Made it possible to assign language to taxonomy terms, vocabularies,
405         menu items, and files.
406       * Added a field translation based content translation module that applies
407         to all content entities.
408       * Removed the old node-copy based content translation module.
409       * Introduced language defaults configuration for each entity type and
410         subtype.
411       * Added entity language variance support to search module.
412       * Search indexing and query preprocessors now get language information.
413       * Unified content translation permission granularity with content editing
414         permissions.
415       * Made the language selector freely orderable in entity forms.
416     * Better configuration language support
417       * Added language selectors to most configuration options (views, menus,
418         etc.)
419       * Added a configuration translation user interface that works with any
420         configuration with translatable values (blocks, views, fields, etc.).
421       * Added language options to block visibility.
422     * Much improved language APIs for developers:
423       * Made it possible for users to have a preferred language separate from
424         their user entity language.
425       * The text formatter from t() is now available as FormattableMarkup.
426       * Added support for interface translation contexts in Drupal.t(),
427         Drupal.formatPlural() as well as routing, tabs, actions, shipped
428         menu items and contextual links.
429       * Removed textgroups support from interface translation in favor of
430         native configuration language support.
431       * Added a transliteration API. (Only used for machine names in core.)
432       * Added a language fallback capability to the interface translation API.
433 - New field types added to core:
434     * Email
435     * Link
436     * Telephone number
437     * Entity reference
438     * Date
439 - Made commenting more flexible:
440     * Added the notion of comment types (for reviews, greetings, and so on),
441       each of which can be configured with a different set of fields.
442     * Made commenting a field to allow comment threads on entity types other
443       than nodes.
444 - Added Views and Views UI module to core:
445     * Added simple bulk operations functionality to Views.
446     * Converted various core listings to views, including /node,
447       /admin/content/node, /admin/people, and several blocks.
448     * Built in REST API support.
449     * Rewrote caching integration for better performance.
450     * Made it possible to configure responsive tables in Views.
451 - Greatly improved block management:
452     * Made custom blocks fieldable, revisionable, and translatable entities.
453     * Added the notion of custom block types.
454     * Added the ability to place the same block in multiple locations.
455     * Introduced a block library with categorized blocks.
456 - Introduced an accessible modal API based on improvements made in collaboration
457   with the jQuery UI team.
458 - Made it possible to add fields to contact forms allowing site-builders to
459   easily build custom forms for soliciting feedback from users.
460 - Added a Web Services module package.
461     * Added a RESTful web services provider module.
462     * Added a serialization module using the Symfony serialization component.
463     * Added a Hypertext Application Language (HAL) serialization module.
464     * Added a HTTP Basic authentication provider module.
465 - Improved performance/scalability significantly:
466     * Introduced cache tags, which allow content to be invalidated accurately
467       and instantly, including for reverse proxies and CDNs.
468     * Added cache contexts, which allow content to be cached correctly, and
469       placeholdered to improve cache hit rates.
470     * Implemented cacheability bubbling, which allows strict tracking of assets
471       and cacheability throughout page rendering.
472     * Factored out page caching to its own module and enabled it by default.
473     * Added the Dynamic Page Cache module for authenticated page caching and
474       enabled it by default.
475     * Added APCu, memory, and PHP file caching backends to core, alongside
476       support for a chained, consistent cache backend to support correctly using
477       fast local cache implementations with multiple web servers.
478 - Removed support for MyISAM, when using MySQL.
479 - Testing improvements
480     * Added PHPUnit for proper unit testing, see
481       https://phpunit.de/manual/4.8/en/index.html so you can run tests via
482       your IDE.
483     * Added BrowserTestBase as an alternative to simpletest for browser
484       testing (JavaScript support to be included in the future)
485     * Added KernelTestBase to provide a fast API testing of integration of
486       different components
487     * Core branch nightly tests include PHP 5.5, 5.6, 7, sqlite and PostgreSQL.
488 - Added the migrate module (experimental) with support for migrating content and
489   configuration from earlier Drupal versions.
490 - Introduced support for Composer.
491 - Moved the automated cron execution functionality to its own module.
492 - Refactored IP address based banning functionality to its own module.
493 - Security improvements:
494     * Removed PHP filter, including the ability to use PHP for block visibility.
495     * Managing fields for each entity type is now a separate permission.
496     * PDO drivers other than MySQL are now limited to executing single
497       statements to limit SQL injection vectors.
498     * Added an autoescape API to prevent cross-site scripting in many of the
499       places where Drupal outputs HTML.
500     * Hardened user session and session ID handling.
501     * Automated CSRF protection in route definitions.
502     * Clickjacking protection enabled by default.
503     * Made the core JavaScript API compatible with Content Security Policy
504       (CSP).
505     * Trusted host patterns enforced for requests preventing cache and link
506       poisoning.
507 - Switched to semantic versioning with significant updates planned every 6
508   months in 8.1, 8.2, etc.
509 - Numerous other important changes and additions. See
510   https://www.drupal.org/list-changes/drupal for a detailed list.
511 - Numerous bug fixes.
512 - Numerous API documentation improvements.
513 - Additional automated test coverage.
514
515 Drupal 7.0, 2011-01-05
516 ----------------------
517 - Database:
518     * Fully rewritten database layer using PHP 5's PDO abstraction layer.
519     * Drupal now requires MySQL >= 5.0.15 or PostgreSQL >= 8.3.
520     * Added query builders for INSERT, UPDATE, DELETE, MERGE, and SELECT queries.
521     * Support for primary/replica replication, transactions, multi-insert
522       queries, and other features.
523     * Added support for the SQLite database engine.
524     * Default to InnoDB engine, rather than MyISAM, on MySQL when available.
525       This offers increased scalability and data integrity.
526 - Security:
527     * Protected cron.php -- cron will only run if the proper key is provided.
528     * Implemented a pluggable password system and much stronger password hashes
529       that are compatible with the Portable PHP password hashing framework.
530     * Rate limited login attempts to prevent brute-force password guessing, and
531       improved the flood control API to allow variable time windows and
532       identifiers for limiting user access to resources.
533     * Transformed the "Update status" module into the "Update manager" which
534       can securely install or update modules and themes via a web interface.
535 - Usability:
536     * Added contextual links (a.k.a. local tasks) to page elements, such as
537       blocks, nodes, or comments, which allows to perform the most common tasks
538       with a single click only.
539     * Improved installer requirements check.
540     * Improved support for integration of WYSIWYG editors.
541     * Implemented drag-and-drop positioning for input format listings.
542     * Implemented drag-and-drop positioning for language listing.
543     * Implemented drag-and-drop positioning for poll options.
544     * Provided descriptions and human-readable names for user permissions.
545     * Removed comment controls for users.
546     * Removed display order settings for comment module. Comment display
547       order can now be customized using the Views module.
548     * Removed the 'related terms' feature from taxonomy module since this can
549       now be achieved with Field API.
550     * Added additional features to the default installation profile, and
551       implemented a "slimmed down" profile designed for developers.
552     * Added a built-in, automated cron run feature, which is triggered by site
553       visitors.
554     * Added an administrator role which is assigned all permissions for
555       installed modules automatically.
556     * Image toolkits are now provided by modules (rather than requiring a
557       manual file copy to the includes directory).
558     * Added an edit tab to taxonomy term pages.
559     * Redesigned password strength validator.
560     * Redesigned the add content type screen.
561     * Highlight duplicate URL aliases.
562     * Renamed "input formats" to "text formats".
563     * Moved text format permissions to the main permissions page.
564     * Added configurable ability for users to cancel their own accounts.
565     * Added "vertical tabs", a reusable interface component that features
566       automatic summaries and increases usability.
567     * Replaced fieldsets on node edit and add pages with vertical tabs.
568 - Performance:
569     * Improved performance on uncached page views by loading multiple core
570       objects in a single database query.
571     * Improved performance for logged-in users by reducing queries for path
572       alias lookups.
573     * Improved support for HTTP proxies (including reverse proxies), allowing
574       anonymous page views to be served entirely from the proxy.
575 - Documentation:
576     * Hook API documentation now included in Drupal core.
577 - News aggregator:
578     * Added OPML import functionality for RSS feeds.
579     * Optionally, RSS feeds may be configured to not automatically generate feed blocks.
580 - Search:
581     * Added support for language-aware searches.
582 - Aggregator:
583     * Introduced architecture that allows pluggable parsers and processors for
584       syndicating RSS and Atom feeds.
585     * Added options to suspend updating specific feeds and never discard feeds
586       items.
587 - Testing:
588     * Added test framework and tests.
589 - Improved time zone support:
590     * Drupal now uses PHP's time zone database when rendering dates in local
591       time. Site-wide and user-configured time zone offsets have been converted
592       to time zone names; for example, Africa/Abidjan.
593     * In some cases the upgrade and install scripts do not choose the preferred
594       site default time zone. The automatically-selected time zone can be
595       corrected at admin/config/regional/settings.
596     * If your site is being upgraded from Drupal 6 and you do not have the
597       contributed date or event modules installed, user time zone settings will
598       fallback to the system time zone and will have to be reconfigured by each user.
599     * User-configured time zones now serve as the default time zone for PHP
600       date/time functions.
601 - Filter system:
602     * Revamped the filter API and text format storage.
603     * Added support for default text formats to be assigned on a per-role basis.
604     * Refactored the HTML corrector to take advantage of PHP 5 features.
605 - User system:
606     * Added clean API functions for creating, loading, updating, and deleting
607       user roles and permissions.
608     * Refactored the "access rules" component of user module: The user module
609       now provides a simple interface for blocking single IP addresses. The
610       previous functionality in the user module for restricting certain email
611       addresses and usernames is now available as a contributed module. Further,
612       IP address range blocking is no longer supported and should be implemented
613       at the operating system level.
614     * Removed per-user themes: Contributed modules with similar functionality
615       are available.
616 - OpenID:
617     * Added support for Gmail and Google Apps for Domain identifiers. Users can
618       now log in with their user@example.com identifier when example.com is
619       powered by Google.
620     * Made the OpenID module more pluggable.
621 - Added code registry:
622     * Using the registry, modules declare their includable files via their .info file,
623       allowing Drupal to lazy-load classes and interfaces as needed.
624 - Theme system:
625     * Removed the Bluemarine, Chameleon and Pushbutton themes. These themes live
626       on as contributed themes (https://www.drupal.org/project/bluemarine,
627       https://www.drupal.org/project/chameleon and
628       https://www.drupal.org/project/pushbutton).
629     * Added Stark theme to make analyzing Drupal's default HTML and CSS easier.
630     * Added Seven as the default administration theme.
631     * Variable preprocessing of theme hooks prior to template rendering now goes
632       through two phases: a 'preprocess' phase and a new 'process' phase. See
633       http://api.drupal.org/api/function/theme/7 for details.
634     * Theme hooks implemented as functions (rather than as templates) can now
635       also have preprocess (and process) functions. See
636       http://api.drupal.org/api/function/theme/7 for details.
637     * Added Bartik as the default theme.
638 - File handling:
639     * Files are now first class Drupal objects with file_load(), file_save(),
640       and file_validate() functions and corresponding hooks.
641     * The file_move(), file_copy() and file_delete() functions now operate on
642       file objects and invoke file hooks so that modules are notified and can
643       respond to changes.
644     * For the occasions when only basic file manipulation are needed--such as
645       uploading a site logo--that don't require the overhead of databases and
646       hooks, the current unmanaged copy, move and delete operations have been
647       preserved but renamed to file_unmanaged_*().
648     * Rewrote file handling to use PHP stream wrappers to enable support for
649       both public and private files and to support pluggable storage mechanisms
650       and access to remote resources (for example, S3 storage or Flickr photos).
651     * The mime_extension_mapping variable has been removed. Modules that need to
652       alter the default MIME type extension mappings should implement
653       hook_file_mimetype_mapping_alter().
654     * Added the hook_file_url_alter() hook, which makes it possible to serve
655       files from a CDN.
656     * Added a field specifically for uploading files, previously provided by
657       the contributed module FileField.
658 - Image handling:
659     * Improved image handling, including better support for add-on image
660       libraries.
661     * Added API and interface for creating advanced image thumbnails.
662     * Inclusion of additional effects such as rotate and desaturate.
663     * Added a field specifically for uploading images, previously provided by
664       the contributed module ImageField.
665 - Added aliased multi-site support:
666     * Added support for mapping domain names to sites directories.
667 - Added RDF support:
668     * Modules can declare RDF namespaces which are serialized in the <html> tag
669       for RDFa support.
670     * Modules can specify how their data structure maps to RDF.
671     * Added support for RDFa export of nodes, comments, terms, users, etc. and
672       their fields.
673 - Search engine optimization and web linking:
674     * Added a rel="canonical" link on node and comment pages to prevent
675       duplicate content indexing by search engines.
676     * Added a default rel="shortlink" link on node and comment pages that
677       advertises a short link as an alternative URL to third-party services.
678     * Meta information is now alterable by all modules before rendering.
679 - Field API:
680     * Custom data fields may be attached to nodes, users, comments and taxonomy
681       terms.
682     * Node bodies and teasers are now Field API fields instead of
683       being a hard-coded property of node objects.
684     * In addition, any other object type may register with Field API
685       and allow custom data fields to be attached to itself.
686     * Provides most of the features of the former Content Construction
687       Kit (CCK) module.
688     * Taxonomy terms are now Field API fields that can be added to any fieldable
689       object.
690 - Installer:
691     * Refactored the installer into an API that allows Drupal to be installed
692       via a command line script.
693 - Page organization
694     * Made the help text area a full featured region with blocks.
695     * Site mission is replaced with the highlighted content block region and
696       separate RSS feed description settings.
697     * The footer message setting was removed in favor of custom blocks.
698     * Made the main page content a block which can be moved and ordered
699       with other blocks in the same region.
700     * Blocks can now return structured arrays for later rendering just
701       like page callbacks.
702 - Translation system
703     * The translation system now supports message context (msgctxt).
704     * Added support for translatable fields to Field API.
705 - JavaScript changes
706     * Upgraded the core JavaScript library to jQuery version 1.4.4.
707     * Upgraded the jQuery Forms library to 2.52.
708     * Added jQuery UI 1.8.7, which allows improvements to Drupal's user
709       experience.
710 - Better module version support
711     * Modules now can specify which version of another module they depend on.
712 - Removed modules from core
713     * The following modules have been removed from core, because contributed
714       modules with similar functionality are available:
715       * Blog API module
716       * Ping module
717       * Throttle module
718 - Improved node access control system.
719     * All modules may now influence the access to a node at runtime, not just
720       the module that defined a node.
721     * Users may now be allowed to bypass node access restrictions without giving
722       them complete access to the site.
723     * Access control affects both published and unpublished nodes.
724     * Numerous other improvements to the node access system.
725 - Actions system
726     * Simplified definitions of actions and triggers.
727     * Removed dependency on the combination of hooks and operations. Triggers
728       now directly map to module hooks.
729 - Task handling
730     * Added a queue API to process many or long-running tasks.
731     * Added queue API support to cron API.
732     * Added a locking framework to coordinate long-running operations across
733       requests.
734
735 Drupal 6.0, 2008-02-13
736 ----------------------
737 - New, faster and better menu system.
738 - New watchdog as a hook functionality.
739    * New hook_watchdog that can be implemented by any module to route log
740      messages to various destinations.
741    * Expands the severity levels from 3 (Error, Warning, Notice) to the 8
742      levels defined in RFC 3164.
743    * The watchdog module is now called dblog, and is optional, but enabled by
744      default in the default installation profile.
745    * Extended the database log module so log messages can be filtered.
746    * Added syslog module: useful for monitoring large Drupal installations.
747 - Added optional email notifications when users are approved, blocked, or
748   deleted.
749 - Drupal works with error reporting set to E_ALL.
750 - Added scripts/drupal.sh to execute Drupal code from the command line. Useful
751   to use Drupal as a framework to build command-line tools.
752 - Made signature support optional and made it possible to theme signatures.
753 - Made it possible to filter the URL aliases on the URL alias administration
754   screen.
755 - Language system improvements:
756     * Support for right to left languages.
757     * Language detection based on parts of the URL.
758     * Browser based language detection.
759     * Made it possible to specify a node's language.
760     * Support for translating posts on the site to different languages.
761     * Language dependent path aliases.
762     * Automatically import translations when adding a new language.
763     * JavaScript interface translation.
764     * Automatically import a module's translation upon enabling that module.
765 - Moved "PHP input filter" to a standalone module so it can be deleted for
766   security reasons.
767 - Usability:
768     * Improved handling of teasers in posts.
769     * Added sticky table headers.
770     * Check for clean URL support automatically with JavaScript.
771     * Removed default/settings.php. Instead the installer will create it from
772       default.settings.php.
773     * Made it possible to configure your own date formats.
774     * Remember anonymous comment posters.
775     * Only allow modules and themes to be enabled that have explicitly been
776       ported to the correct core API version.
777     * Can now specify the minimum PHP version required for a module within the
778       .info file.
779     * Drupal core no longer requires CREATE TEMPORARY TABLES or LOCK TABLES
780       database rights.
781     * Dynamically check password strength and confirmation.
782     * Refactored poll administration.
783     * Implemented drag-and-drop positioning for blocks, menu items, taxonomy
784       vocabularies and terms, forums, profile fields, and input format filters.
785 - Theme system:
786     * Added .info files to themes and made it easier to specify regions and
787       features.
788     * Added theme registry: modules can directly provide .tpl.php files for
789       their themes without having to create theme_ functions.
790     * Used the Garland theme for the installation and maintenance pages.
791     * Added theme preprocess functions for themes that are templates.
792     * Added support for themeable functions in JavaScript.
793 - Refactored update.php to a generic batch API to be able to run time-consuming
794   operations in multiple subsequent HTTP requests.
795 - Installer:
796     * Themed the installer with the Garland theme.
797     * Added form to provide initial site information during installation.
798     * Added ability to provide extra installation steps programmatically.
799     * Made it possible to import interface translations during installation.
800 - Added the HTML corrector filter:
801     * Fixes faulty and chopped off HTML in postings.
802     * Tags are now automatically closed at the end of the teaser.
803 - Performance:
804     * Made it easier to conditionally load .include files and split up many core
805       modules.
806     * Added a JavaScript aggregator.
807     * Added block-level caching, improving performance for both authenticated
808       and anonymous users.
809     * Made Drupal work correctly when running behind a reverse proxy like
810       Squid or Pound.
811 - File handling improvements:
812     * Entries in the files table are now keyed to a user instead of a node.
813     * Added reusable validation functions to check for uploaded file sizes,
814       extensions, and image resolution.
815     * Added ability to create and remove temporary files during a cron job.
816 - Forum improvements:
817     * Any node type may now be posted in a forum.
818 - Taxonomy improvements:
819     * Descriptions for terms are now shown on taxonomy/term pages as well
820       as RSS feeds.
821     * Added versioning support to categories by associating them with node
822       revisions.
823 - Added support for OpenID.
824 - Added support for triggering configurable actions.
825 - Added the Update status module to automatically check for available updates
826   and warn sites if they are missing security updates or newer versions.
827   Sites deploying from CVS should use https://www.drupal.org/project/cvs_deploy.
828   Advanced settings provided by https://www.drupal.org/project/update_advanced.
829 - Upgraded the core JavaScript library to jQuery version 1.2.3.
830 - Added a new Schema API, which provides built-in support for core and
831   contributed modules to work with databases other than MySQL.
832 - Removed drupal.module. The functionality lives on as the Site network
833   contributed module (https://www.drupal.org/project/site_network).
834 - Removed old system updates. Updates from Drupal versions prior to 5.x will
835   require upgrading to 5.x before upgrading to 6.x.
836
837 Drupal 5.7, 2008-01-28
838 ----------------------
839 - fixed the input format configuration page.
840 - fixed a variety of small bugs.
841
842 Drupal 5.6, 2008-01-10
843 ----------------------
844 - fixed a variety of small bugs.
845 - fixed a security issue (Cross site request forgery), see SA-2008-005
846 - fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
847 - fixed a security issue (Cross site scripting, register_globals), see SA-2008-007
848
849 Drupal 5.5, 2007-12-06
850 ----------------------
851 - fixed missing missing brackets in a query in the user module.
852 - fixed taxonomy feed bug introduced by SA-2007-031
853
854 Drupal 5.4, 2007-12-05
855 ----------------------
856 - fixed a variety of small bugs.
857 - fixed a security issue (SQL injection), see SA-2007-031
858
859 Drupal 5.3, 2007-10-17
860 ----------------------
861 - fixed a variety of small bugs.
862 - fixed a security issue (HTTP response splitting), see SA-2007-024
863 - fixed a security issue (Arbitrary code execution via installer), see SA-2007-025
864 - fixed a security issue (Cross site scripting via uploads), see SA-2007-026
865 - fixed a security issue (User deletion cross site request forgery), see SA-2007-029
866 - fixed a security issue (API handling of unpublished comment), see SA-2007-030
867
868 Drupal 5.2, 2007-07-26
869 ----------------------
870 - changed hook_link() $teaser argument to match documentation.
871 - fixed a variety of small bugs.
872 - fixed a security issue (cross-site request forgery), see SA-2007-017
873 - fixed a security issue (cross-site scripting), see SA-2007-018
874
875 Drupal 5.1, 2007-01-29
876 ----------------------
877 - fixed security issue (code execution), see SA-2007-005
878 - fixed a variety of small bugs.
879
880 Drupal 5.0, 2007-01-15
881 ----------------------
882 - Completely retooled the administration page
883     * /Admin now contains an administration page which may be themed
884     * Reorganised administration menu items by task and by module
885     * Added a status report page with detailed PHP/MySQL/Drupal information
886 - Added web-based installer which can:
887     * Check installation and run-time requirements
888     * Automatically generate the database configuration file
889     * Install pre-made installation profiles or distributions
890     * Import the database structure with automatic table prefixing
891     * Be localized
892 - Added new default Garland theme
893 - Added color module to change some themes' color schemes
894 - Included the jQuery JavaScript library 1.0.4 and converted all core JavaScript to use it
895 - Introduced the ability to alter mail sent from system
896 - Module system:
897     * Added .info files for module meta-data
898     * Added support for module dependencies
899     * Improved module installation screen
900     * Moved core modules to their own directories
901     * Added support for module uninstalling
902 - Added support for different cache backends
903 - Added support for a generic "sites/all" directory.
904 - Usability:
905     * Added support for auto-complete forms (AJAX) to user profiles.
906     * Made it possible to instantly assign roles to newly created user accounts.
907     * Improved configurability of the contact forms.
908     * Reorganized the settings pages.
909     * Made it easy to investigate popular search terms.
910     * Added a 'select all' checkbox and a range select feature to administration tables.
911     * Simplified the 'break' tag to split teasers from body.
912     * Use proper capitalization for titles, menu items and operations.
913 - Integrated urlfilter.module into filter.module
914 - Block system:
915     * Extended the block visibility settings with a role specific setting.
916     * Made it possible to customize all block titles.
917 - Poll module:
918     * Optionally allow people to inspect all votes.
919     * Optionally allow people to cancel their vote.
920 - Distributed authentication:
921     * Added default server option.
922 - Added default robots.txt to control crawlers.
923 - Database API:
924     * Added db_table_exists().
925 - Blogapi module:
926     * 'Blogapi new' and 'blogapi edit' nodeapi operations.
927 - User module:
928     * Added hook_profile_alter().
929     * Email verification is made optional.
930     * Added mass editing and filtering on admin/user/user.
931 - PHP Template engine:
932     * Add the ability to look for a series of suggested templates.
933     * Look for page templates based upon the path.
934     * Look for block templates based upon the region, module, and delta.
935 - Content system:
936     * Made it easier for node access modules to work well with each other.
937     * Added configurable content types.
938     * Changed node rendering to work with structured arrays.
939 - Performance:
940     * Improved session handling: reduces database overhead.
941     * Improved access checking: reduces database overhead.
942     * Made it possible to do memcached based session management.
943     * Omit sidebars when serving a '404 - Page not found': saves CPU cycles and bandwidth.
944     * Added an 'aggressive' caching policy.
945     * Added a CSS aggregator and compressor (up to 40% faster page loads).
946 - Removed the archive module.
947 - Upgrade system:
948     * Created space for update branches.
949 - Form API:
950     * Made it possible to programmatically submit forms.
951     * Improved api for multistep forms.
952 - Theme system:
953     * Split up and removed drupal.css.
954     * Added nested lists generation.
955     * Added a self-clearing block class.
956
957 Drupal 4.7.11, 2008-01-10
958 -------------------------
959 - fixed a security issue (Cross site request forgery), see SA-2008-005
960 - fixed a security issue (Cross site scripting, UTF8), see SA-2008-006
961 - fixed a security issue (Cross site scripting, register_globals), see SA-2008-007
962
963 Drupal 4.7.10, 2007-12-06
964 -------------------------
965 - fixed taxonomy feed bug introduced by SA-2007-031
966
967 Drupal 4.7.9, 2007-12-05
968 ------------------------
969 - fixed a security issue (SQL injection), see SA-2007-031
970
971 Drupal 4.7.8, 2007-10-17
972 ------------------------
973 - fixed a security issue (HTTP response splitting), see SA-2007-024
974 - fixed a security issue (Cross site scripting via uploads), see SA-2007-026
975 - fixed a security issue (API handling of unpublished comment), see SA-2007-030
976
977 Drupal 4.7.7, 2007-07-26
978 ------------------------
979 - fixed security issue (XSS), see SA-2007-018
980
981 Drupal 4.7.6, 2007-01-29
982 ------------------------
983 - fixed security issue (code execution), see SA-2007-005
984
985 Drupal 4.7.5, 2007-01-05
986 ------------------------
987 - Fixed security issue (XSS), see SA-2007-001
988 - Fixed security issue (DoS), see SA-2007-002
989
990 Drupal 4.7.4, 2006-10-18
991 ------------------------
992 - Fixed security issue (XSS), see SA-2006-024
993 - Fixed security issue (CSRF), see SA-2006-025
994 - Fixed security issue (Form action attribute injection), see SA-2006-026
995
996 Drupal 4.7.3, 2006-08-02
997 ------------------------
998 - Fixed security issue (XSS), see SA-2006-011
999
1000 Drupal 4.7.2, 2006-06-01
1001 ------------------------
1002 - Fixed critical upload issue, see SA-2006-007
1003 - Fixed taxonomy XSS issue, see SA-2006-008
1004 - Fixed a variety of small bugs.
1005
1006 Drupal 4.7.1, 2006-05-24
1007 ------------------------
1008 - Fixed critical SQL issue, see SA-2006-005
1009 - Fixed a serious upgrade related bug.
1010 - Fixed a variety of small bugs.
1011
1012 Drupal 4.7.0, 2006-05-01
1013 ------------------------
1014 - Added free tagging support.
1015 - Added a site-wide contact form.
1016 - Theme system:
1017     * Added the PHPTemplate theme engine and removed the Xtemplate engine.
1018     * Converted the bluemarine theme from XTemplate to PHPTemplate.
1019     * Converted the pushbutton theme from XTemplate to PHPTemplate.
1020 - Usability:
1021     * Reworked the 'request new password' functionality.
1022     * Reworked the node and comment edit forms.
1023     * Made it easy to add nodes to the navigation menu.
1024     * Added site 'offline for maintenance' feature.
1025     * Added support for auto-complete forms (AJAX).
1026     * Added support for collapsible page sections (JS).
1027     * Added support for resizable text fields (JS).
1028     * Improved file upload functionality (AJAX).
1029     * Reorganized some settings pages.
1030     * Added friendly database error screens.
1031     * Improved styling of update.php.
1032 - Refactored the forms API.
1033     * Made it possible to alter, extend or theme forms.
1034 - Comment system:
1035     * Added support for "mass comment operations" to ease repetitive tasks.
1036     * Comment moderation has been removed.
1037 - Node system:
1038     * Reworked the revision functionality.
1039     * Removed the bookmarklet code. Third-party modules can now handle
1040       This.
1041 - Upgrade system:
1042     * Allows contributed modules to plug into the upgrade system.
1043 - Profiles:
1044     * Added a block to display author information along with posts.
1045     * Added support for private profile fields.
1046 - Statistics module:
1047     * Added the ability to track page generation times.
1048     * Made it possible to block certain IPs/hostnames.
1049 - Block system:
1050     * Added support for theme-specific block regions.
1051 - Syndication:
1052     * Made the aggregator module parse Atom feeds.
1053     * Made the aggregator generate RSS feeds.
1054     * Added RSS feed settings.
1055 - XML-RPC:
1056     * Replaced the XML-RPC library by a better one.
1057 - Performance:
1058     * Added 'loose caching' option for high-traffic sites.
1059     * Improved performance of path aliasing.
1060     * Added the ability to track page generation times.
1061 - Internationalization:
1062     * Improved Unicode string handling API.
1063     * Added support for PHP's multibyte string module.
1064 - Added support for PHP5's 'mysqli' extension.
1065 - Search module:
1066     * Made indexer smarter and more robust.
1067     * Added advanced search operators (phrase, node type, etc.).
1068     * Added customizable result ranking.
1069 - PostgreSQL support:
1070     * Removed dependency on PL/pgSQL procedural language.
1071 - Menu system:
1072     * Added support for external URLs.
1073 - Queue module:
1074     * Removed from core.
1075 - HTTP handling:
1076     * Added support for a tolerant Base URL.
1077     * Output URIs relative to the root, without a base tag.
1078
1079 Drupal 4.6.11, 2007-01-05
1080 -------------------------
1081 - Fixed security issue (XSS), see SA-2007-001
1082 - Fixed security issue (DoS), see SA-2007-002
1083
1084 Drupal 4.6.10, 2006-10-18
1085 -------------------------
1086 - Fixed security issue (XSS), see SA-2006-024
1087 - Fixed security issue (CSRF), see SA-2006-025
1088 - Fixed security issue (Form action attribute injection), see SA-2006-026
1089
1090 Drupal 4.6.9, 2006-08-02
1091 ------------------------
1092 - Fixed security issue (XSS), see SA-2006-011
1093
1094 Drupal 4.6.8, 2006-06-01
1095 ------------------------
1096 - Fixed critical upload issue, see SA-2006-007
1097 - Fixed taxonomy XSS issue, see SA-2006-008
1098
1099 Drupal 4.6.7, 2006-05-24
1100 ------------------------
1101 - Fixed critical SQL issue, see SA-2006-005
1102
1103 Drupal 4.6.6, 2006-03-13
1104 ------------------------
1105 - Fixed bugs, including 4 security vulnerabilities.
1106
1107 Drupal 4.6.5, 2005-12-12
1108 ------------------------
1109 - Fixed bugs: no critical bugs were identified.
1110
1111 Drupal 4.6.4, 2005-11-30
1112 ------------------------
1113 - Fixed bugs, including 3 security vulnerabilities.
1114
1115 Drupal 4.6.3, 2005-08-15
1116 ------------------------
1117 - Fixed bugs, including a critical "arbitrary PHP code execution" bug.
1118
1119 Drupal 4.6.2, 2005-06-29
1120 ------------------------
1121 - Fixed bugs, including two critical "arbitrary PHP code execution" bugs.
1122
1123 Drupal 4.6.1, 2005-06-01
1124 ------------------------
1125 - Fixed bugs, including a critical input validation bug.
1126
1127 Drupal 4.6.0, 2005-04-15
1128 ------------------------
1129 - PHP5 compliance
1130 - Search:
1131     * Added UTF-8 support to make it work with all languages.
1132     * Improved search indexing algorithm.
1133     * Improved search output.
1134     * Impose a throttle on indexing of large sites.
1135     * Added search block.
1136 - Syndication:
1137     * Made the ping module ping pingomatic.com which, in turn, will ping all the major ping services.
1138     * Made Drupal generate RSS 2.0 feeds.
1139     * Made RSS feeds extensible.
1140     * Added categories to RSS feeds.
1141     * Added enclosures to RSS feeds.
1142 - Flood control mechanism:
1143     * Added a mechanism to throttle certain operations.
1144 - Usability:
1145     * Refactored the block configuration pages.
1146     * Refactored the statistics pages.
1147     * Refactored the watchdog pages.
1148     * Refactored the throttle module configuration.
1149     * Refactored the access rules page.
1150     * Refactored the content administration page.
1151     * Introduced forum configuration pages.
1152     * Added a 'add child page' link to book pages.
1153 - Contact module:
1154     * Added a simple contact module that allows users to contact each other using email.
1155 - Multi-site configuration:
1156     * Made it possible to run multiple sites from a single code base.
1157 - Added an image API: enables better image handling.
1158 - Block system:
1159     * Extended the block visibility settings.
1160 - Theme system:
1161     * Added new theme functions.
1162 - Database backend:
1163     * The PEAR database backend is no longer supported.
1164 - Performance:
1165     * Improved performance of the forum topics block.
1166     * Improved performance of the tracker module.
1167     * Improved performance of the node pages.
1168 - Documentation:
1169     * Improved and extended PHPDoc/Doxygen comments.
1170
1171 Drupal 4.5.8, 2006-03-13
1172 ------------------------
1173 - Fixed bugs, including 3 security vulnerabilities.
1174
1175 Drupal 4.5.7, 2005-12-12
1176 ------------------------
1177 - Fixed bugs: no critical bugs were identified.
1178
1179 Drupal 4.5.6, 2005-11-30
1180 ------------------------
1181 - Fixed bugs, including 3 security vulnerabilities.
1182
1183 Drupal 4.5.5, 2005-08-15
1184 ------------------------
1185 - Fixed bugs, including a critical "arbitrary PHP code execution" bug.
1186
1187 Drupal 4.5.4, 2005-06-29
1188 ------------------------
1189 - Fixed bugs, including two critical "arbitrary PHP code execution" bugs.
1190
1191 Drupal 4.5.3, 2005-06-01
1192 ------------------------
1193 - Fixed bugs, including a critical input validation bug.
1194
1195 Drupal 4.5.2, 2005-01-15
1196 ------------------------
1197 - Fixed bugs: a cross-site scripting (XSS) vulnerability has been fixed.
1198
1199 Drupal 4.5.1, 2004-12-01
1200 ------------------------
1201 - Fixed bugs: no critical bugs were identified.
1202
1203 Drupal 4.5.0, 2004-10-18
1204 ------------------------
1205 - Navigation:
1206     * Made it possible to add, delete, rename and move menu items.
1207     * Introduced tabs and subtabs for local tasks.
1208     * Reorganized the navigation menus.
1209 - User management:
1210     * Added support for multiple roles per user.
1211     * Made it possible to add custom profile fields.
1212     * Made it possible to browse user profiles by field.
1213 - Node system:
1214     * Added support for node-level permissions.
1215 - Comment module:
1216     * Made it possible to leave contact information without having to register.
1217 - Upload module:
1218     * Added support for uploading documents (includes images).
1219 - Forum module:
1220     * Added support for sticky forum topics.
1221     * Made it possible to track forum topics.
1222 - Syndication:
1223     * Added support for RSS ping-notifications of http://technorati.com/.
1224     * Refactored the categorization of syndicated news items.
1225     * Added a URL alias for 'rss.xml'.
1226     * Improved date parsing.
1227 - Database backend:
1228     * Added support for multiple database connections.
1229     * The PostgreSQL backend does no longer require PEAR.
1230 - Theme system:
1231     * Changed all GIFs to PNGs.
1232     * Reorganised the handling of themes, template engines, templates and styles.
1233     * Unified and extended the available theme settings.
1234     * Added theme screenshots.
1235 - Blocks:
1236     * Added 'recent comments' block.
1237     * Added 'categories' block.
1238 - Blogger API:
1239     * Added support for auto-discovery of blogger API via RSD.
1240 - Performance:
1241     * Added support for sending gzip compressed pages.
1242     * Improved performance of the forum module.
1243 - Accessibility:
1244     * Improved the accessibility of the archive module's calendar.
1245     * Improved form handling and error reporting.
1246     * Added HTTP redirects to prevent submitting twice when refreshing right after a form submission.
1247 - Refactored 403 (forbidden) handling and added support for custom 403 pages.
1248 - Documentation:
1249     * Added PHPDoc/Doxygen comments.
1250 - Filter system:
1251     * Added support for using multiple input formats on the site
1252     * Expanded the embedded PHP-code feature so it can be used everywhere
1253     * Added support for role-dependent filtering, through input formats
1254 - UI translation:
1255     * Managing translations is now completely done through the administration interface
1256     * Added support for importing/exporting gettext .po files
1257
1258 Drupal 4.4.3, 2005-06-01
1259 ------------------------
1260 - Fixed bugs, including a critical input validation bug.
1261
1262 Drupal 4.4.2, 2004-07-04
1263 ------------------------
1264 - Fixed bugs: no critical bugs were identified.
1265
1266 Drupal 4.4.1, 2004-05-01
1267 ------------------------
1268 - Fixed bugs: no critical bugs were identified.
1269
1270 Drupal 4.4.0, 2004-04-01
1271 ------------------------
1272 - Added support for the MetaWeblog API and MovableType extensions.
1273 - Added a file API: enables better document management.
1274 - Improved the watchdog and search module to log search keys.
1275 - News aggregator:
1276     * Added support for conditional GET.
1277     * Added OPML feed subscription list.
1278     * Added support for <image>, <pubDate>, <dc:date>, <dcterms:created>, <dcterms:issued> and <dcterms:modified>.
1279 - Comment module:
1280     * Made it possible to disable the "comment viewing controls".
1281 - Performance:
1282     * Improved module loading when serving cached pages.
1283     * Made it possible to automatically disable modules when under heavy load.
1284     * Made it possible to automatically disable blocks when under heavy load.
1285     * Improved performance and memory footprint of the locale module.
1286 - Theme system:
1287     * Made all theme functions start with 'theme_'.
1288     * Made all theme functions return their output.
1289     * Migrated away from using the BaseTheme class.
1290     * Added many new theme functions and refactored existing theme functions.
1291     * Added avatar support to 'Xtemplate'.
1292     * Replaced theme 'UnConeD' by 'Chameleon'.
1293     * Replaced theme 'Marvin' by 'Pushbutton'.
1294 - Usability:
1295     * Added breadcrumb navigation to all pages.
1296     * Made it possible to add context-sensitive help to all pages.
1297     * Replaced drop-down menus by radio buttons where appropriate.
1298     * Removed the 'magic_quotes_gpc = 0' requirement.
1299     * Added a 'book navigation' block.
1300 - Accessibility:
1301     * Made themes degrade gracefully in absence of CSS.
1302     * Grouped form elements using '<fieldset>' and '<legend>' tags.
1303     * Added '<label>' tags to form elements.
1304 - Refactored 404 (file not found) handling and added support for custom 404 pages.
1305 - Improved the filter system to prevent conflicts between filters:
1306     * Made it possible to change the order in which filters are applied.
1307 - Documentation:
1308     * Added PHPDoc/Doxygen comments.
1309
1310 Drupal 4.3.2, 2004-01-01
1311 ------------------------
1312 - Fixed bugs: no critical bugs were identified.
1313
1314 Drupal 4.3.1, 2003-12-01
1315 ------------------------
1316 - Fixed bugs: no critical bugs were identified.
1317
1318 Drupal 4.3.0, 2003-11-01
1319 ------------------------
1320 - Added support for configurable URLs.
1321 - Added support for sortable table columns.
1322 - Database backend:
1323     * Added support for selective database table prefixing.
1324 - Performance:
1325     * Optimized many SQL queries for speed by converting left joins to inner joins.
1326 - Comment module:
1327     * Rewrote the comment housekeeping code to be much more efficient and scalable.
1328     * Changed the comment module to use the standard pager.
1329 - User module:
1330     * Added support for multiple sessions per user.
1331     * Added support for anonymous user sessions.
1332 - Forum module:
1333     * Improved the forum views and the themability thereof.
1334 - Book module:
1335     * Improved integration of non-book nodes in the book outline.
1336 - Usability:
1337     * Added support for "mass node operations" to ease repetitive tasks.
1338     * Added support for breadcrumb navigation to several modules' user pages.
1339     * Integrated the administration pages with the normal user pages.
1340
1341 Drupal 4.2.0, 2003-08-01
1342 ------------------------
1343 - Added support for clean URLs.
1344 - Added textarea hook and support for onload attributes: enables integration of WYSIWYG editors.
1345 - Rewrote the RSS/RDF parser:
1346     * It will now use PHP's built-in XML parser to parse news feeds.
1347 - Rewrote the administration pages:
1348     * Improved the navigational elements and added breadcrumb navigation.
1349     * Improved the look and feel.
1350     * Added context-sensitive help.
1351 - Database backend:
1352     * Fixed numerous SQL queries to make Drupal ANSI compliant.
1353     * Added MSSQL database scheme.
1354 - Search module:
1355     * Changed the search module to use implicit AND'ing instead of implicit OR'ing.
1356 - Node system:
1357     * Replaced the "post content" permission by more fine-grained permissions.
1358     * Improved content submission:
1359         + 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.
1360         + Added the ability to preview both the short and the full version of your posts.
1361     * Extended the node API which allows for better integration.
1362     * Added default node settings to control the behavior for promotion, moderation and other options.
1363 - Themes:
1364     * Replaced theme "Goofy" by "Xtemplate", a template driven theme.
1365 - Removed the 'register_globals = on' requirement.
1366 - Added better installation instructions.
1367
1368 Drupal 4.1.0, 2003-02-01
1369 ------------------------
1370 - Collaboratively revised and expanded the Drupal documentation.
1371 - Rewrote comment.module:
1372     * Reintroduced comment rating/moderation.
1373     * Added support for comment paging.
1374     * Performance improvements: improved comment caching, faster SQL queries, etc.
1375 - Rewrote block.module:
1376     * Performance improvements: blocks are no longer rendered when not displayed.
1377 - Rewrote forum.module:
1378     * 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.
1379 - Rewrote statistics.module:
1380     * Collects access counts for each node, referrer logs, number of users/guests.
1381     * 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.
1382 - Added throttle.module:
1383     * Auto-throttle congestion control mechanism: Drupal can adapt itself based on the server load.
1384 - Added profile.module:
1385     * Enables to extend the user and registration page.
1386 - Added pager support to the main page.
1387 - Replaced weblogs.module by ping.module:
1388     * Added support for normal and RSS notifications of http://blo.gs/.
1389     * Added support for RSS ping-notifications of http://weblogs.com/.
1390 - Removed the rating module
1391 - Themes:
1392     * Removed a significant portion of hard-coded mark-up.
1393
1394 Drupal 4.0.0, 2002-06-15
1395 ------------------------
1396 - Added tracker.module:
1397     * Replaces the previous "your [site]" links (recent comments and nodes).
1398 - Added weblogs.module:
1399     * This will ping weblogs.com when new content is promoted.
1400 - Added taxonomy module which replaces the meta module.
1401     * Supports relations, hierarchies and synonyms.
1402 - Added a caching system:
1403     * Speeds up pages for anonymous users and reduces system load.
1404 - Added support for external SMTP libraries.
1405 - Added an archive extension to the calendar.
1406 - Added support for the Blogger API.
1407 - Themes:
1408     * Cleaned up the theme system.
1409     * Moved themes that are not maintained to contributions CVS repository.
1410 - Database backend:
1411     * Changed to PEAR database abstraction layer.
1412     * Using ANSI SQL queries to be more portable.
1413 - Rewrote the user system:
1414     * Added support for Drupal authentication through XML-RPC and through a Jabber server.
1415     * Added support for modules to add more user data.
1416     * Users may delete their own account.
1417     * Added who's new and who's online blocks.
1418 - Changed block system:
1419     * Various hard coded blocks are now dynamic.
1420     * Blocks can now be enabled and/or be set by the user.
1421     * Blocks can be set to only show up on some pages.
1422     * Merged box module with block module.
1423 - Node system:
1424     * Blogs can be updated.
1425     * Teasers (abstracts) on all node types.
1426     * Improved error checking.
1427     * Content versioning support.
1428     * Usability improvements.
1429 - Improved book module to support text, HTML and PHP pages.
1430 - Improved comment module to mark new comments.
1431 - Added a general outliner which will let any node type be linked to a book.
1432 - Added an update script that lets you upgrade from previous releases or on a day to day basis when using the development tree.
1433 - Search module:
1434     * Improved the search system by making it context sensitive.
1435     * Added indexing.
1436 - Various updates:
1437     * Changed output to valid XHTML.
1438     * Improved multiple sites using the same Drupal database support.
1439     * Added support for session IDs in URLs instead of cookies.
1440     * Made the type of content on the front page configurable.
1441     * Made each cloud site have its own settings.
1442     * Modules and themes can now be enabled/disabled using the administration pages.
1443     * Added URL abstraction for links.
1444     * Usability changes (renamed links, better UI, etc.).
1445 - Collaboratively revised and expanded the Drupal documentation.
1446
1447 Drupal 3.0.1, 2001-10-15
1448 ------------------------
1449 - Various updates:
1450     * Added missing translations
1451     * Updated the themes: tidied up some HTML code and added new Drupal logos.
1452
1453 Drupal 3.0.0, 2001-09-15
1454 ------------------------
1455 - Major overhaul of the entire underlying design:
1456     * 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.
1457 - Rewrote submission/moderation queue and renamed it to queue.module.
1458 - Removed FAQ and documentation module and merged them into a "book module".
1459 - Removed ban module and integrated it into account.module as "access control":
1460     * Access control is based on much more powerful regular expressions (regex) now rather than on MySQL pattern matching.
1461 - Rewrote watchdog and submission throttle:
1462     * Improved watchdog messages and added watchdog filter.
1463 - Rewrote headline code and renamed it to import.module and export.module:
1464     * Added various improvements, including a better parser, bundles and better control over individual feeds.
1465 - Rewrote section code and renamed it to meta.module:
1466     * Supports unlimited amount of nested topics. Topics can be nested to create a multi-level hierarchy.
1467 - Rewrote configuration file resolving:
1468     * 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.
1469 - Added caching support which makes Drupal extremely scalable.
1470 - Added access.module:
1471     * Allows you to set up 'roles' (groups) and to bind a set of permissions to each group.
1472 - Added blog.module.
1473 - Added poll.module.
1474 - Added system.module:
1475     * Moved most of the configuration options from hostname.conf to the new administration section.
1476     * Added support for custom "filters".
1477 - Added statistics.module
1478 - Added moderate.module:
1479     * Allows to assign users editorial/moderator rights to certain nodes or topics.
1480 - Added page.module:
1481     * Allows creation of static (and dynamic) pages through the administration interface.
1482 - Added help.module:
1483     * Groups all available module documentation on a single page.
1484 - Added forum.module:
1485     * Added an integrated forum.
1486 - Added cvs.module and cvs-to-sql.pl:
1487     * Allows to display and mail CVS log messages as daily digests.
1488 - Added book.module:
1489     * Allows collaborative handbook writing: primary used for Drupal documentation.
1490 - Removed cron.module and integrated it into conf.module.
1491 - Removed module.module as it was no longer needed.
1492 - Various updates:
1493     * Added "auto-post new submissions" feature versus "moderate new submissions".
1494     * Introduced links/Drupal tags: [[link]]
1495     * Added preview functionality when submitting new content (such as a story) from the administration pages.
1496     * Made the administration section only show those links a user has access to.
1497     * Made all modules use specific form_* functions to guarantee a rock-solid forms and more consistent layout.
1498     * Improved scheduler:
1499         + Content can be scheduled to be 'posted', 'queued' and 'hidden'.
1500     * Improved account module:
1501         + Added "access control" to allow/deny certain usernames/email addresses/hostnames.
1502     * Improved locale module:
1503         + Added new overview to easy the translation process.
1504     * Improved comment module:
1505         + Made it possible to permanently delete comments.
1506     * Improved rating module
1507     * Improved story module:
1508         + Added preview functionality for administrators.
1509         + Made it possible to permanently delete stories.
1510     * Improved themes:
1511         + W3C validation on a best effort basis.
1512         + Removed $theme->control() from themes.
1513         + Added theme "goofy".
1514 - Collaboratively revised and expanded the Drupal documentation.
1515
1516 Drupal 2.0.0, 2001-03-15
1517 ------------------------
1518 - Rewrote the comment/discussion code:
1519     * Comment navigation should be less confusing now.
1520     * Additional/alternative display and order methods have been added.
1521     * Modules can be extended with a "comment system": modules can embed the existing comment system without having to write their own, duplicate comment system.
1522 - Added sections and section manager:
1523     * Story sections can be maintained from the administration pages.
1524     * 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.
1525 - Multiple vhosts + multiple directories:
1526     * You can set up multiple Drupal sites on top of the same physical source tree either by using vhosts or sub-directories.
1527 - Added "user ratings" similar to SlashCode's Karma or Scoop's Mojo:
1528     * All rating logic is packed into a module to ease experimenting with different rating heuristics/algorithms.
1529 - Added "search infrastructure":
1530     * Improved search page and integrated search functionality in the administration pages.
1531 - Added translation / localization / internationalization support:
1532     * 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.
1533 - Added fine-grained user permission (or group) system:
1534     * 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.
1535 - Added FAQ module
1536 - Changed the "open submission queue" into a (optional) module.
1537 - Various updates:
1538     * Improved account module:
1539         + User accounts can be deleted.
1540         + Added fine-grained permission support.
1541     * Improved block module
1542     * Improved diary module:
1543         + Diary entries can be deleted
1544     * Improved headline module:
1545         + Improved parser to support more "generic" RDF/RSS/XML backend.
1546     * Improved module module
1547     * Improved watchdog module
1548     * Improved database abstraction layer
1549     * Improved themes:
1550         + W3C validation on a best effort basis
1551         + Added theme "example" (alias "Stone Age")
1552     * Added new scripts to directory "scripts"
1553     * Added directory "misc"
1554     * Added CREDITS file
1555 - Revised documentation
1556
1557 Drupal 1.0.0, 2001-01-15
1558 ------------------------
1559 - Initial release