diff --git a/ChangeLog b/ChangeLog index e97c5b9..ce15d67 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,889 +1 @@ -SilverStripe ChangeLog - - -2.2.2 (In development) - -New Features - - Translations - - Added Translations for LOLCAT - - Added Translations for Esperanto - - Added Translations for Sinhalese - - Added Translations for Finnish - - Added Translations for Danish - - Ability to translate newsletter - -Developer Tools - - Added more unit tests - - Added Makefile so that you can execute 'make test' in sapphire - - Added SS_DEFAULT_ADMIN_USERNAME/PASSWORD defines to conf/ConfigureFromEnv.php - - Added missing ChangePasswordEmail.ss - - main.php: Moved _ss_environment.php include to very top - - ArrayLib - - Added in_array_recursive() for recursively checking an array with nested arrays - - Controller - - Improved allowed_actions support for subclassed controllers, such as CMSMain extends LeftAndMain - - Allow use of on controller extensions - - DataObject - - Added hasDatabaseField() - - DataObjectSet - - Implemented equal values - - Date - - Added TimeDiffIn() - - Email - - Changed email encoding from iso-8859-15 to utf-8, in compliance with other parts of SilverStripe and IMC recommendations - - ErrorPage - - Added all the types of error pages (ErrorPage.400,401,403 - 417,500 - 505) - - File - - Updated AssetAdmin to use TreeTitle() in place of Title for tree generation - - Updated TreeTitle() to allow use of alternateTreeTitle() in decorator - - Updated File to allow the insertion of extra columns by decorator - - FileUploadField - - Added ability to customise which folder a file is uploaded to - - Folder - - Moved folder admin form to Folder::getCMSFields() to let you more easily manipulate the form with a decorator - - Form - - Added added setFields()/setActions() - - Group - - Added canEdit(), which can be used to filter the SecurityAdmin group list - - HTMLEditorField - - Added paste plain text and paste from word buttons - - Added 'anchor' option to link inserter - - Image - - adding "delete" class to DeleteImageForm() - - Member - - Added $notify_password_change - now sends an email to the member - - Added BaseHref() to Member_ChangePasswordEmail so that the email shows the domain name of the current subsite - - Added Member->SetPassword, a field that lets you have a write-only password field - - Used Member->SetPassword to create a password column on the MemberTableField for SecurityAdmin - - Send 'changed password' emails when a user is first created as well as edited - - Added $searchable_fields in preparation for a more generic search implementation, currently limited to Member.php and MemberTableField.php - - RSSFeed - - Make RSS feed work with objects that don't support AbsoluteLink, such as the forum - - Security - - Added support for password and old_password encryption mechanisms if you're using MySQL - - SiteTree - - Made breadcrumbs delimiter configurable - - Added simple to-do list facility - - Don't let people create a page name that is the same as a class name - - Moved CMS page-disabled logic into SiteTree::CMSTreeClasses(), so that it can be more easily customised for specific sites - - Versioned - - Added database indexes for AuthorID and PublisherID - - ViewableData - - Added $SecurityID for templates - - Added escapeTypeForField() to determine if the record-field needs escaping (currently only 'xml' supported) - - Added title attributes to the SilverStripeNavigator messages - - Added $casting for BaseHref() - -Bug Fixes - - Sapphire - - Better handling of memory limit - - Fix locale files on Windows - - More solid ID-detection in Member::php() - - ComplexTableField: - - added $popupClass to avoid duplication, getting basedataclass for existing children in DetailForm() (in case we're dealing with different subclasses) - - fixed getParentIdName() call in DetailForm() - paramter-order was wrong - - better checking in saveComplexTableField() to avoid PHP-notice - - Fix title and description in RSS feeds - - Fix interface translations in CMS footer - - DataObject: - - fix for quering database for child elements when it hasnt been serialized - - Remove HAVING clause from methods where it doesn't make sense to have them - - Fix caching in DataObject::get_one() - - Take orderby clause into account when caching in DataObject::get_one() - - Removes having clause as it can't be used - - Fixed DataObjectSet::insertFirst() - it now uses a numeric key rather than null - - TestRunner: Ensured that the autoloader pulls in the test class - - Database::createDatabase() shouldn't need any arguments. Fixed this in the core class and MySQLDatabase - - Debug: Fix stack trace on objects that don't extend the Object class - - SapphireTest.php: Fix YAML many_many/has_many relationships - - HasManyComplexTableField: set $template and $itemClass to public (according to parent implementation) and fixed formatting - - Email: Fix attachments that could not be emailed from mac or windows systems - - Use lighter version of browscap.ini - - Added ArrayLib::is_associative() - - Allowing object-parameters in DataObjectSet and ArrayData, added ArrayData::object_to_array() - - Allow insertion of tags that refer to external domains and add alt= to any images that don't have alt tags - - Show the saved value of EditableEmailField.SendCopy - - ManifestBuilder: Fix building manifest before database is created - - HTMLText.Summary: Don't close img and br tags - - Don't fail in i18n::include_by_class if the module isn't translatable - - Database: When removing a value from an enum, set affected rows back to the default - - Fix DataObjectSet constructor breaking with associative arrays - - Make ContentNegotiator send XHTML to the W3C validator - - Image: Fix attaching an existing folder to an ImageField - - TableField: - - when no source items found, the table should still show and it should works as adding new records - - renamed $wantDefaultAddRow to $showAddRow - - Form: removed Form::dropDatalessFields() - - Refactored Member::session_regenerate_id to make it easier to disable in some circumstances. - - Deprecated use of DBField 'Text' for saving HTML-Content (added check in HTMLEditorField->saveInto()) - - Make Security::get_encryption_algorithms() a dynamic function again. - - Fix sorting in complextablefield - - Added sapphire/conf/ConfigureFromEnv.php for making use of _ss_environment.php - - SelectionGroup: Fix for bug that initialises with preloaded selected items with right hide/show - - Fixed fatal error due to browscap.ini capitalisation error - - Allow many-many complex table fields to be used on the reverse side of the join (belongs many many) - - Fix incorrect text boxes on many-many complex table fields and relational complex table fields being set on an ajax request - - BasicAuth: Fixed illegal reference to this - - Image: locking down URLs: image/iframe, image/flush, image/transferlegacycontent - - RelationComplexTableField: fixed "object not found" error in ie6 - - ImageField: compressed layout to fit in CTF-popup (removed "click here to remove" label), removed iframe-borders for IE - - RelationComplexTableField: added check if sitetree exists otherwise IE broken with all genericDataAdmin panel - - ComplexTableField: updating form in ctf-popup after saving (including validation-errors and fields that have may changed on the serverside, e.g. ImageField?) - - fix PageView's recording of referrers. - - File: fix upload folder - - Fixed seamonkey browser recognition in browscap.ini - - ComplexTableField: fix sql error on comments section - - fixed i18n::get_owner_module() calls on classes with _s - - Fixed ManifestBuilder execution in restrictive openbasedir environments - - Removed clone behaviour from Form::Fields() - - Object: Added object caching methods - - Make DataObject::write() call the recursive write on components, even when the dataobject itself hasn't changed - - fix ComplexTableField caching - - ManifestBuilder regex - - Debug: Supress disabled errors on live site - - Allowed subclasses in ComponentSet::add/remove - - added extra security on Controller ( checkAccessAction() ) - - Member: Used Object::create() to create email instances sent by the system. - - Object, Versioned, Hierarchy: Allow selection of folder when inserting files / images - - AjaxUniqueTextField: fixed sql-injection - - TableField: Removed use of deprecated TableField::setExtraClass() - - Group: Removed warning in group admin - - DataObject: fixed caching in getManyManyComponents - - DataObject: Fixed MySQL 4.1 support for situations where we are sorting by a group aggregation function and fixed notice level error - - Fixed bug with BasicAuth enabled on an old database, it was preventing you from visiting db/build - - DataObject: Fixed 4.1-sort-by-group-aggregate query rewriter for sort functions containing columns, eg, ORDER BY if(A,B,C), X - - Director: Small fix for session bugs on Lightspeed server - - DataObjectSets: cannot be iterated over multiple times concurrently - - fix to Installer: falsely claims modrewrite fails (mamp) - - Widget: fixed widget editor - - ComplexTableField: Fixed double-escaping of CTF popup page-navigation links - - ComponentSet: fixing bug with in-memory child objects not having their parent ID field updated via the ->add() method - - ComplexTableField: BUGFIX properly setting $childID in form for newly created items to avoid duplicates after subsequent saving (the form reloaded without the ID connection) - - TableListField: fixed csv export in MemberTableField by checking for valid database columns when building SELECT statement - - ComplexTableField: fix popup breaking after saving - - CMS - - cmsmain_left: You can't reorganise pages without creating pages - - MemberTableField: Patch for more i18n strings - - Fix i18n errors - - UserDefinedForm: Fixed notice level error - - Bug in PageComments class (Security) - - Fix autocompletion in Security Admin - - Fixed the $hide_ancestor static on SiteTree? subclasses - - Fixed bug: Page class wasn't shown in add-page dropdown - - More memory-efficient version of admin/publishall - - tinymce.template: Added paste plain text and paste from word buttons to the HtmlEditorField in the CMS - - SideReport: fixed bug in todo list report - - Fixed 404 on spacer.gif - - Fixed context menus in CMS - - CMSMain: Added 'duplicate page and children' context-item in addition to 'duplicate just this page' - - GenericDataAdmin: Recover ExportForm for genericDataAdmin Which is needed for CRM CreateCommunication - - Added default SubscribeForm.ss - - Added SubscribeSubmission template to get subscribeforms to work - - SubscribeForm: Fix newsletter subscription form - - AssetAdmin: Disabled unused files list, as it uses way too much memory - - CMSMain->getNewItem now calls $this->extend('augmentNewSiteTreeItem', $newItem); - - Changed call to ViewableData::castingHelperPair to fix sort not being set by getNewItem - - Used Member->SetPassword? to create a password column on the MemberTableField? for SecurityAdmin? - - Send 'changed password' emails when a user is first created as well as edited - - Updated core to allow for subsites restriction of filesystem: Folder::getCMSFields() is now responsible for generating the folder form. - - Folder::syncChildren() now exclusively uses DB::query() calls instead of DataObject::get(). - - CMSMain: Fixed CMS bottom-navigation after publish, when using the subsites module (or other alternateAbsoluteLink implementors) - - SideReport: Fixed newlines in to-do report - - Javascript - - Improved the Behaviour.addLoader() method to play more nicely with tools - - tree.js: Fix bug when duplicating pages with reorganise enabled - - tiny_mce_improvements.js: Improvement to link-insertion logic when selecting text that doesn't have a link - - tiny_mce_improvements.js: Fixed default-setting for link anchor - - -2.2.1 (21 Dec 2007) - -New Features - - Translations - - Added Italian translation - - Added Russian translation - - Added Slovak translation - - Added Turkish translation - - Added Bulgarian translation - - Added Czech translation - - Added Hungarian translation - - Added Portuguese (Brazil) translation - - Added Swedish translation - - Added Chinese (Taiwan) translation - - Added support for sapphire to Portuguese (Portugal) translation -Developer Tools - - Added augmentDefaultRecords(), so DataObjectDecorators can extend requireDefaultRecords -Bug fixes - - Sapphire - - Hardcoded array of encryption algorithims in Security::get_encryption_algorithms(), as a bug in MySQL causes corruption in dumps with enums with commas - - Fixed bug with google sitemap on translated sites - - Removed title from SecurityID fields, as some forms show labels on HiddenFields - - Fixed Object::uninherited() for PHP 5.1.2 - - Added empty array to member so that roles can add their own has_one relations - - CMS - - Added SecurityAdmin_rightbottom.ss - - Javascript - - Upgraded TinyMCE to 2.1.3 - -2.2.0 (28 Nov 2007) - -New Features - - New look for CMS - - Support for authentification by OpenID (auth_openid module included with installer) - - Google Sitemaps support - - Internationalisation support - - German translation - - Dutch translation - - Chinese (simplified) translation - - Spanish translation - - French translation - - Croatian translation - - Polish translation - - Portuguese (Portugal) translation - - Support for multilingual content - - Added a Statistics area showing the following reports - - Page views - - User activity - - Trends - - Operating Systems - - Browsers - - Added an image editor, allowing a user to rotate, crop and resize an image from within the CMS - - Added profile popup in CMS - - Added a 'Sent Status Report' tab to Newsletters with the following reports - - Sending to the following recipients failed - - Sending to the following recipients bounced - - The newsletter has never been sent to following subscribers - - Sending to the following recipients was successful - - Sending to the following recipients did not occur because they are blackListed - - Add 'Send to only people not previously sent to' option for sending newsletters - - Added SWFUpload library as default method of uploading files - - Added photo upload in from the Site Content section - - Added the ability to search the Site Content tree - - Added the ability to publish selected pages - - Added a list of unused assets in the Files & Images section, and the ability to delete unused thumbnails - - Usability improvements - - Move action buttons to bottom right of screen - - Moved insert image/flash/link to pane on right - - Removed right frame headers as the buttons have been moved and they only contain redundant information - - Use a javascript dialog box for confirming unsaved changes instead of the slow loading model one - - Reworked the tabs in the Newsletter section to be less confusing - - Cancel button added to Send Newsletter window - - External logo link opens in a new window - - Left sections in Site Content 'Site Tree', 'History' and 'Reports' now use expandable sections rather than tabs - - Relabeled 'Site Tree' to 'Site Content & Structure', 'History' to 'Page Version History' and 'Reports' to 'Site Reports' in left sections of Site Content - - Relabeled 'Files & Images' left frame to 'Folders' - - Added tooltips to site content tree, showing the page type - - In the 'Page Version History', use a checkbox lable 'Compare mode (click 2 below)' instead of a dropdown - - Renamed 'Save draft' button to 'Save' - - The 'Save' button text changes to 'Saving...', and the 'Publish' button text changes to 'Publishing...' when they are clicked - - Added save indicator to all 'Save' buttons, the 'Save & Publish' button and the 'Unpublish' button while they are being submitted - - Added a go button to the 'Site Reports' dropdown - - Relabeled 'Name' field to 'Folder Name' in Files & Images section - - Renamed the 'Save' button to 'Save folder name' in Files & Images section - - Relabeled 'Send newsletters from' field to 'From email address' in Newsletter section - - Removed the 'Move Files' button from Files & Images section, implemented multi-file drag & drop moving - - Add 'Newsletter Settings' tab to Newsletter type edit form for consistency with other forms - - Make the status message shown after sending a newsletter always include the # of emails sent - - Added delete confirmation for items in Newsletter left tree - - Added delete confirmation for items in Security left tree - - Make 'Add new draft' the default action for 'Create...' in the Newsletter section - - Replace the 'reorganise' button with 'Allowing drag & drog reordering' checkbox - - Delete and Unpublish buttons turn red on hover - - Added the ability to align images 'left on their own' - - -Developer Tools - - New classes - - Authenticator, allowing multiple authentification methods - - ConfirmPasswordField - - DropdownTimeField - - i18n, for internationalisation - - LanguageDropdownField - - LoginForm, base class for login forms for each authentification method - - MemberAuthenticator, providing username/password authentification - - MemberLoginForm, refactored from old LoginForm form - - PopupDateTimeField - - ToggleField - - OpenIDAuthenticatedRole, which is an extension to Member that adds OpenID authentification columns - - OpenIDAuthenticator, providing OpenID authentification - - OpenIDLoginForm, providing OpenID sign in - - PageView, which saves the details of each page view for statistics - - Statistics, which provides static methods for statistics - - Translatable, for multilingual content - - New third party libraries - - PHP OpenID (http://openidenabled.com/php-openid/) - - Browscap (http://garetjax.info/projects/browscap/) - - Plotr (http://www.solutoire.com/plotr/) - - SWFUpload (http://profandesign.se/swfupload/) - - Improved classes - - CalendarDateField - - Refactored part of Field() into HTMLField() so it can be used in PopupDateTimeField - - ComplexTableField - - Improved pagination in popup - - Better transformation of save-button (replaced indicator with "saving..." label) - - CompositeField - - Added SmallFieldHolder() to properly render fields in a FieldGroup - - Added insertBeforeRecursive() - - Allow empty children - - Added Field() - - Added linebreaks for HTML - - ConfirmedFormAction - - Respect $extraClass - - ContentController - - Save statistics on page views - - Added LangAttributes(), for use in XML header - - Draft/Archived content can only be viewed by users with permission to access the CMS - - Core - - Added _t() for internationalisation - - Check if TEMP_FOLDER is already defined before defining it, allowing the user to set the temporary folder themself - - DataObject - - Added merge() - - Director - - Added extend_site(), which allows modules to register a function that will be run on every page load - - redirectBack() now redirects to the base URL if neither the referrer nor the _REDIRECT_BACK_URL is set - - Added support for translatable URLs - - Added is_cli() - - Added set_status_code() and get_status_code() - - Email - - Define 'EMAIL_BOUNCEHANDLER_KEY' in sapphire/_config.php and require its value to be sent as 'Key' $_GET var in pings to /Email_BounceHandler to prevent fake email bounce pings - - Display an error on duplicate bounce logs instead of a blank screen - - If the contents of the X-SilverStripeMessageID header is sent to /Email_BounceHandler in the 'SilverStripeMessageID' _GET variable, then it will be logged in the Newsletter_SentRecipient table so that the bounce report will show up on the 'Sent Status Report' tab of the Newsletter - - Bounced newsletter recipient emails and blacklisted by default - - FieldSet - - Added insertBeforeRecursive() - - FileSystem - - Added $file_create_mask and $folder_create_mask, which are used whenever creating new files/folders in sapphire - - Form - - All Forms now have a hidden SecurityID field to prevent CSRF attacks - - Added disableSecurityToken() to disable the SecurityID field - - Added securityTokenEnabled() - - Changed

to

- - Renamed PureName() to Name() - - GD - - Added rotate() - - Added rotatePixelByPixel(), allowing rotation where the imagerotate function is unavailable - - Added crop() - - Added getWidth() - - Added getHeight() - - Hierachy - - Versioned now automatically add suffixes, so Hierachy no longer needs to - - HTTP - - Added register_modification_timestamp() - - Added register_etag() - - ImageField - - Improved layout - - Int - - Added support for default value - - ManifestBuilder - - Refactored getClassManifest() for clearer ignore rules - - Ignore i18n language files - - Ignore folders that have a '_manifest_exclude' file - - Member - - Automatically login user if the 'remember login' cookie is set - - Added createNewPassword(), which generates a random password, optionally using a word list - - Added support for password encryption - - Added Locale field to store user preferred language - - Added the ability for Member decorators to augment MemberFormFields() - - MemberLoginForm (refactored from old LoginForm) - - Save the email address in the session to reuse when the login fails - - ModelAsController - - Added support for translatable URLs - - Object - - Added require_developer_login(), which allows you to check if the user has permission to use URL debugging tools - - ?debugmethods=1 now requires developer login - - PageComment - - Added the ability to have BBCode in comments (disabled by default) - - PasswordField - - Always show five stars in performReadonlyTransformation(), so it is impossible to use the information of the password length for brute-force attacks - - Permission - - Added declare_permissions() - - Added get_declared_permissions_list() - - Added traverse_declared_permissions() - - Added Permission_Group class, used to group permissions together for showing on an interface - - Added $admin_implies_all, if this is false then the 'ADMIN' permission doesn't imply all permissions - - Refactored Permission::checkMember(), should be faster now because the non-strict checking is now only executed if the user doesn't has the permission - - Added deny(), giving the ability to define 'deny permissions' - - RecipientImportField - - Added default 'GenericEmail.ss' template - - RestfulService - - Added caching - - RSSFeed - - Added support for conditional GETs - - Security - - Added support for password encryption - - Added set_word_list() and get_word_list(), to set the location of the word list used in Member::generateNewPassword() - - Session - - Added save(), which copies the current controllers session to $_SESSION - - SiteTree - - Changed references to 'stage site' to 'draft site' in TreeTitle() - - Use Translatable interface by default - - Add content language in MetaTags() - - Add delete class to unpublish and rollback buttons - - SSViewer - - Added support for internationalisation in templates, using <% _t() %> - - Added $Iteration in templates, which keeps track of the number of iterations in a control block - - TableListField - - Prevent onclick event in td.markingcheckbox from showing the popup - - TabSet - - Remove tabset div to reduce wasted space on tabs - - Added insertBeforeRecursive() - - ToggleCompositeField - - Refactored from TogglePanel - - Added icons and used 'cursor: pointer' to make it obvious that it is clickable - - Versioned - - Added the ability to versionise suffixed tables that have names that are not DataObject descendants - - Added canBeVersioned() - - Added extendWithSuffix() - - Added hasVersionField() - -Bug Fixes - - Sapphire - - E_NOTICE fixes - - Fixed incorrect deprecated message in Convert::raw2xml() - - Don't show and error message and quit the script when @ is used to suppress the error - - Changed width of HTMLEditorFields to prevent horizontal scrollbars in IE7 - - Added checks in DataObjectSet::First() and DataObjectSet::Last() to prevent errors on an empty $items array - - Fixed incorrect treatment of Member::logout() as a static method in Security::logout() - - Ensure Priority is set in SiteTree::onBeforeWrite(), otherwise an invalid SQL statement will be generated when the page is published - - Only highlight broken links in HTMLEditorFields once, to prevent execution timeouts when there are lots of identical broken links - - Fixed bug "Fatal error: Access to undeclared static property: Controller::$db in ../sapphire/core/Object.php(282) : eval()'d code on line 1" - - Fixed DataObjectDecorators not supporting indexes and defaults - - Fixed ReportField generating invalid HTML - - In Member::setBlacklistedEmail() call this->write() so that the BlacklistedEmail field state will be saved to the Member database table - - Fix Email_BlackList::isBlocked() to check the BlockedEmail field instead of non-existant Email field so that it will actaully return true when an email is blocked - - Fix layout problems with search box in IE by only generating a label tag if TItle is set in FormField::FieldHolder() - - Fixed Permission::check() not p[assing $strict to Permission::checkMember() - - Fixed HTTP::gmt_date() - - Fix validation of Member extensions - - Removed DriversLicense references from LoginForm (project specific clutter) - - Added check for existence of #sitetree in RelationComplexTableField.js - - Fixed VirtualPage creation - - Fixed lighttpd flushing bug - - Fixed CustomRequiredFields - - Fix bugs with ComplexTableField when it is used outside of the CMS - - Fixed error saving when value is undefined in HasOneComplexTableField and HasManyComplexTableField - - Fixed saving error in FileIFrameField - - Added a security fix for Security::check_default_admin() - - Fixed caching in DataObject::getManyManyComponents() to take into account different SQL parameters - - Geop::ip2country() now throws an E_USER_NOTICE instead of an error when it cannot run geoiplookup - - Added if() check around a foreach loop that was causing errors when there were no entries in an RSS feed - - Fix inheritance in ManyManyComplexTableField - - Fixed FormField::setRightTitle() not showing because of a typo - - Create assets folder if doesn't eixts on ErrorPage publish - - Fixed submission of ImageField when no file was selected - - Catch errors in ContentController::deleteinstallfiles() - - Fix generation of group codes on creation of a Group - - Fix title on LabelledLiteralField - - Fix ImageField deleting the Image instead of unlinking it from the page - - Set TimeField value to null when a bad value is passed - - Don't return a span when the Title doesn't exist in DropdownField - - Fix bug where NumericField couldn't have 0 as a default value - - Call Page_Controller->init() when rendering Security/changepassword etc to respect any Requirements called in there - - Fixed an error when a CheckboxSetField is submitted with no checkboxes ticked - - Fixed exporting of TableListField to use commas for CSV files - - ?previewwrite no longer works on live sites - - Fixed incorrect CSS in TableListField.css - - Fixed incorrect namespacing in TableListField::BaseLink() - - If a CreditCardField is completely blank, then it's not invalid. Required-fields should be used to check for values. - - CMS - - E_NOTICE fixes - - New pages are created in the database straight away, which solves a number of issues - - Fixed Email link not working in page history - - Unsaved changes detection now works in Security section member tables - - Fix typo in LeftAndMain::addTreeNodeJS() by renaming 'select' parameter to 'selected' because 'selected' is what is used in the method body - - Delete image thumbnails after deleting an image - - Use 'html>body' instead of just 'html>' so that #sitetree correctly gets assigned width:auto on Mozilla browsers (prevents Folders being selected from 500px away on file drag and drop) - - Display a useful error message if getCMSFields() returns null - - When 'Duplicate this page' is clicked, first silently (without confirmation) save the page, then duplicate it so the new page is identical to the other page - - Fix errors when importing recipients to newsletter mailing list - - Fixed blocking during resize in IE6 - - Don't show a 'No template selected' error when sending a test Newsletter if no template has been selected since templates for Emails are optional - - Fixed bug 'for newly created newsletter drafts, content of newsletter sent is not what is shown on screen' - - Don't save new Newsletter drafts as soon as they are created to prevent TinyMCE Javascript errors in IE - - Add if((typeof tinyMCE != 'undefined')) statement around call to tinyMCE.init() to prevent "Error: 'tinyMCE' is undefined" error in IE7 on Newsletter Recipient import - - Don't allow a deleted draft to be edited in the Newsletter section - - Fix a bug where newsletter drafts will be added, but not show up in the left tree (because of a Javascript error), if no selection has been made - - If there are no newsletter types, and 'Add new draft' is chosen, create a newsletter type to prevent errors - - Fix changed icon only showing after Save button is clicked twice - - Fixed VirtualPage creation - - Fix 'Sort subpages' not working correctly - - Use classes instead of the align tag to align images - - -2.1.1 (2 Nov 2007) - -Bug Fixes - - CMS - - BBCode help link now works inside CMS - - Fixed invalid 'cursor: normal' CSS in cms_left.css - - Ensure ComplexTableField CSS is loaded in CMS - - Fixed blank comments showing in Comment Admin - - Ensure behaviour is applied correctly to new fields in a UserDefinedForm - - Fixed fatal error in Newsletter Admin on some servers - - Sapphire - - Fix infinite redirects when upgrading from 2.0.2 - - Use the hostname, not the ip address, in dev/test mode tests - - Changed the include of the BBCodeParser so it works on more systems - - Fixed saving of HasOneComplexTableField and HasManyComplexTableField when value is undefined - - Removed extra comma in TableListField.js - - Fixed redirection of login when login fails - - Fixed bug where removing a comment via ajax removed all comments from display - - Fix $_SESSION not saving correctly on some servers - - -2.1.0 (2 Oct 2007) - -New Features - - Comment administration section, and comment moderation - - Allow CMS users to limit view/edit access to a page - - Show an rss link for page comments on each page - -Developer Tools - - Theme support - - Widget support - - Better extension API - - Unit testing framework - - More API documentation - - Added support for __ss_environment.php files - - New classes - - BankAccountField - - BBCodeParser - - HasManyComplexTableField - - HasOneComplexTableField - - ManyManyComplexTableField - - NewsletterType - - RestfulService (from mashups module) - - Improved classes - - ComplexTableField - - Validation in popup - - ContentController - - Added project() - - Controller - - Added redirectedTo() - - Convert - - Added raw2htmlatt() - - Added raw2mailto() - - DatabaseAdmin - - Drastically improved database build performance - - DataObject - - Added ID,ID,ID syntax for populating many-many joins - - DataObjectDecorator - - Allow member CMS fields to be added - - DataObjectSet - - Added getRange() - - Date - - Added past_date() - - Director - - Added set_dev_servers() - - Added set_test_servers() - - Added redirected_to() - - Refactored CMS page-URL accessing to use ->AbsoluteLink(), which can be overridden by defining alternateAbsoluteLink() - - Debug - - Optionally hide backtrace-headers in message() and show() (applied in 'showqueries') - - Email - - MimeType-fallback (from /etc/mime.types) - - Improved validation in is_valid_address() - - FieldSet - - Added insertAfter() - - Form - - Automatic filesystem backup of POST-data - - FormField - - Support for right-aligned titles - - Custom CSS-classes by addExtraClass() and removeExtraClass() - - Group - - Added Description field - - HtmlEditorField - - Allow classes other than 'typography' to be set - - Image - - Added PaddedImage() - - ImageField - - Added readonly transformation - - PageCommentInterface - - Added anchors to page comments, and made rss feed link to them - - Permission - - Added $strict flag to check() - - Allow passing of an array of permission codes to get_members_by_permission() - - Added get_groups_by_permission() - - PhoneNumberField - - Improved validation - - Security - - Added basicauthlogin() - - SecurityAdmin - - Added EDIT_PERMISSIONS permission code - - TableField - - Validation and RequiredFields - - TableListField - - Added sorting, highlighting, formatting - - Improved styling - - TreeDropdownField - - Improved styling - - Varchar - - Added RTF() - - ViewableData - - Added '<% if HasPerm(PERM_CODE() %>' for templates - - Javascript - - Implemented showIndicator() and hideIndicator() - - Improved statusMessage() to clear manually instead of fixed interval - - Added hideStatusMessage() - -Bug Fixes - - CMS - - Fix specific newsletter bug - - Don't show classes user doesn't have permissions to change to in class dropdown - - Fix reading of Live pages in CMSMain - - Fix double page reading after changing the class - - Fix insert flash - - Fix version regex for release candidates - - Fix delete in Files and Images section - - Fixed saving root folder causes error - - Fixed "non-numeric ID" error that occurs when visiting newsletter section for a newsletter that doesn't exist (caused by session sometimes) - - Fixed CMS sort subpages bug - - Sapphire - - Improved spam detection - - Support for running SilverStripe in safe mode and under open_basedir restrictions - - PHP notice fixes - - Use normal authentification rather than basicauth for db/build - - Fix CSS of profiler pop-up - - Changed DropdownField $emptyString syntax from '0' to '' - - Fixed IE6 DOM-parsing bug caused by FormResponse::load_form() - - Triggering previewwrite for 'delete' and 'replace' SQL-actions - - Changed record-insertion in DataObject - - Boolean accepts database-default - - Fixed Permission::get_members_by_permission() - - Added memory_limit to publishall() - - Fix many-many component set relation setting - - The Link for a RedirectorPage points to its target - - Add SQL_ prefix in place it was missing in Email - - Added a check to make sure record exists before calling hasMethod on it in CheckboxSetField - - Fixed bug in DataObject::addStaticVars() - - Check for string 'true' as well as boolean in SiteTree::MetaTags() - - Fix AllNewsletters value not being passed to OptionSetField in SubscribeForm - - Improved the encapsulation of ErrorPage publication - - Fix redirect back after failing login - - Fixed renaming of .tar.gz and .tar.bz2 files - - Fixed validation of DateField, EmailField and NumericField - - Fix livesite bug for visibility handling difference between PHP5.2.0 and PHP5.1.6 - - Changed colouring of db/build to be more appropriate for the actual meaning of the messages - - Fixed redirection from /home/ to /./ in IE6 - - Use the homepage as a model for the security base-page, so that things like the current subsite are factored in - - Sorted permission codes in Permission::get_codes - - Changes to support gallery module - - Added missing has_many in DataObjectDecorator - - Replace empty strings in SQL queries with NULL - - JSParty - - TinyMCE has been updated to 2.1.1.1 - -Installer - - New installer look based on BlackCandy - - Use the new theme system - - Add first and last name fields - - Added ability to set servers that will be in dev mode - - When the posix module isn't present, throw a warning instead of dying - - Warn if PHP version is less that 5.2.0 in support of GoPHP5 (http://www.gophp5.org) - - Added favicon to installer and default template - - Optional reporting of version information to SilverStripe - - Installer now runs with short tags disabled - - open_basedir and safe mode fixes - - -2.0.2 (14 Jul 2007) - -New Features - - BlackCandy is the new default theme - - Added pagination for page comments - - Updated date field in CMS-edited forms to use CalendarDateField - - Added 'open in new window' checkbox to link inserter - - Added dimension fields when inserting images - -Developer Tools - - Much more API Documentation - - Modules must now have _config.php files in order to be loaded - - New Classes - - PermissionProvider - - Improved Classes - - CalendarDateField - - Added a calendar icon - - CheckboxSetField - - Prepared for use editing a many-many join in the CMS, popualted with a SQLMap object - - ClassInfo - - Added implementorsOf() - - ContentNegotiator - - Added set_encoding() to choose a character set other than utf-8 - - DatabaseAdmin - - Removed populate() as it was a security risk, the initial content is now loaded via requireDefaultRecords() - - DataObject - - Added add_extension() for adding decorators in _config.php - - DataObjectDecorator - - Added extraDBFields() for modifying the decorated data objects, adding extra database fields - - Email - - Added send_all_emails_to() - - Added cc_all_emails_to() - - Added bcc_all_emails_to() - - Replaced sentLiveErrorsTo() with send_errors_to(), for more flexibility - - Form - - Added current_action() - - Added single_field_required() - - FormField - - Added Required(), so that you can put asterisks into a form template if you wish - - GenericDataAdmin - - Updated to use new permission model - - LeftAndMain - - Added second argument to setApplicationName() so that the name in the top corner and the name shown elsewhere can be 2 different strings - - Permission - - Added get_codes() - - Profiler - - Added trace argument to show() - - Added profiling scaffolds - - Added ?profile_trace=1 url variable tool to show a trace on the profiler - - Sorted the output of profiler - - Improvements to profiling information - - TableField - - Added option to aid putting TableFields inside the ComplexTableField popup - - TreeDropdownField - - Added setTreeBaseID(), for showing a sub-tree in your field - - Javascript - - Added event.setStyle to prototype_improvements.js - - Add class text field to image properties dialog in TinyMCE - - Added ?debug_behaviour=1 URL option for debugging behaviour calls with Firebug - -Bug Fixes - - CMS - - Forms in newsletter & security section were incorrectly submitting when enter was pressed - - Fixed search in MemberTableField - - Don't show popup when validation fails in Security section - - Fixed bug where scrollbars aren't shown in the CMS - - Let CMSMain be used to manage objects without Sort - - The help button now redirects to http://userhelp.silverstripe.com - - Version displayed in CMS now works correctly - - Fixed CMS action button support when text size increases - - Added message when report is empty - - fixed (overrides) to CSS to avoid larger font-size due to em values - - Fixed tree scrolling and resizing issues - - Fixed sizing issues with CMS right content area - - Fixed bug with image insertion - - Fixed bug where new pages weren't being highlighted in the CMS - - Fixed bug where the last page in the site tree wasn't being highlighted in the CMS - - Fixed reordering of groups in security section - - Improvements to image inserter - - Sapphire - - Reduced warnings when E_NOTICE is enabled - - Fixed validation of date fields in a user defined form - - Fixed multiple security groups being created when logging in with default admin - - Fixed permissions for administrating page comments - - Fixed ContentController::PageComments() method to die if spammers are POSTing form data when comments are disabled - - Fixed permission checking on PHP 5.0.5 - - Fixed 'cannot access protected property' error in Security section on PHP 5.0.5 - - Fixed javascript validation of forms - - Fixed error when asp_tags = On - - Fixed bug where you have a non-required field with numeric validation - - Added a limit of 20 steps in Breadcrumbs generation - - Changed SiteTree.Title length from 100 to 255 - - Fixed random password generator in Member::createNewPassword() - - Fixed BatchProcess to not display an error if no objects could be processed - - Fixed a bug where a user is redirected incorrectly after logging in - - Changed temp-folder selection to not leave temp files lying around, and put silverstripe temp files into a silverstripe-cache folder - - Made guid of PageComments in rss feed unique - - Removed duplicate XML class - - Fixed bugs caused by missing html elements - - Fixed code to remove need for short_open_tag - - Fixed FileSize generation for sizes of just over 1 meg - - only show $messageBlock in FormField::FieldHolder() if $Message is existing - - fixed rightTitle and id in FormField::FieldHolder() - - Fixed ?isDev=1 mode - - Set default of sendWarnings on Debug::send_errors_to - - Fixed formatting of error emails sent from ajax requests - - Removed debug plumbing from the results of Debug::backtrace() - - Simplified return data of htmlEmail, an inconsequential internal optimisation - - Create assets folder if it doesn't exist when uploading a file - - Fixed bug in SiteTree::NestedTitle() - - Don't append /home to the home page URL - - Small fix for windows installations - - Fixed efficiency problems in Versioned::get_latest_version - - Fixed File::sync(), to let it recurse into new directories in a single execution - - Fixed bug with getting form action that was breaking form submission and complextablefield pop-up - - Fixed SQLMap iteration - - Simplified EmailField validation error message - - Fixed some bugs in the debug emailer - - Reduced amount of ajax-refetching that the TreeSelectorFields do - - Fix macron support in reports - - Improved debug message (remove big blocks of redundant data) - - Allow for the disabling of default buttons. Apply this to CMSMain and GenericDataAdmin in the administration, so that we don't default to clicking the *DELETE* button. - - Added default value to first arg of permissionFailure(); it's not actually used! - - Improved handling of EditableFormFields on new UserDefinedForms - - Improved search results message shown on first load - - Made calendar control register a date change when the calendar is used - - Set some good defaults in DataObjectSet::TotalPages() if they have not been set - - Changes to support forum - - Require authenficiation to do a db/build on live sites - - Close directories before trying to remove them - - Fixed a bug where CheckboxSetField wouldn't save if there was a method the same as the field name - - Fix multiple "broken" in class attribute of HTML Content - - Fixed bug with TreeDropdownField when you clicked the expand link 3 or more times, it wouldn't close - - Fixed bug when editing properties of new text fields - - Fixed duplicate of UserDefinedForm objects - - JSParty - - Fixed a bug where you couldn't always edit the bottom of an WYSIWYG editor field - - Ensure that WYSIWYG context menu always appears on the screen - - Javascript performance improvements - - Fix weird bug in behaviour to do with class.applyToChildren - - Improved console.log alternative - -Installer - - Added option of installing either the default template, or the tutorial template - - mod_rewrite check now works with http authentification - - Workaround for 'URL file-access is disabled in the server configuration' using curl for mod_rewrite test - - Better error message if the installer can't detect the web server - - Added an alternative .htaccess configuration - - Less file permissions required by the installer - - Made deleting the installer files more prominent, it now deletes all the installations files, not just php. - - MySQL password is now a hidden field. - - -2.0.1 (17 Apr 2007) - -New Features - - Improved layout of UserDefinedForm submissions in CMS - - Don't show name field on root folder in Assets section - -Developer Tools - - Mime types fallback for servers don't have /etc/mime.types - - mb_string module is now an optional dependency - - Added strong_create method to Object, as useCustomClass was not working correctly - -Bug Fixes - - Sapphire - - Text->FirstParagraph() now only shows the first paragraph - - Fixed HTMLText->Summary() - - Fixed layout issues on IE7 for TreeDropdownField - - Don't show Akismet errors to user - - Removed overloaded MemberTableField->sourceItems() that was causing problems - - Fixed UserDefinedForm submission emails - - Fixed UserDefinedForm permissions - - If a file extension doesn't have a maximum upload size associated with it, then allow uploads of any size - - Fixed a bug with the TreeMultiselectField that prevented it from displaying the checkboxes - - Made Scheduled tasks concrete so they can be instantiated - - TableField fixes - - Fixed security vunerability in search - - GD::color_web2gd() was using incorrect substr - - Fixed last link css - - Fixed duplicate checkbox fields in UserDefinedForm - - Fixed css in UserDefinedForm - - CMS - - Fixed sizing of tabs in CMS - - Fixed popup for single asset in Files & Images section - - Fixed link to CMS on default homepage - - Fixed permissions table in Security section - - Fixed el no properties error in IE - - Pressing the flash button a second time now hides the dropdown - -Installer - - Fixed MySQL version check - - Merge with existing .htaccess file - - Test that mod_rewrite is working - - Added option to delete installer files after successful install - - Fixed PHP4 parse error so installer loads and shows correct error message - - Apache test passes if apache is used but apache php functions are not available - - SilverStripe needs at least PHP version 5.0.4 - -2.0.0 (3 Feb 2007) - - Initial release +For a full change log, please visit http://open.silverstripe.org/wiki/ChangeLog.