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 Updated several translations in cms/auth_openid/sapphire Added package names for i18n files - CMS - HtmlEditorField: Added paste plain text and paste from word buttons - Added simple to-do list facility to SiteTree - Added MenuTitle in the CMS LHS tree instead of Title Developer Tools - CompositeField - - SiteTree - Made breadcrumbs delimiter configurable - adding more unit tests - Added better handling of memory limit - Added $SecurityID for templates - Added ViewableData?->escapeFlagForField() to determine if the record-field needs escaping (currently only 'xml' supported) + changed name to escapeTypeForField - Added Makefile so that you can execute 'make test' in sapphire - Added title attributes to the SilverStripeNavigator messages - Added ArrayLib::in_array_recursive() for recursively checking an array with nested arrays - Improvements to RestfulService - DataObjectSet: Implemented equal values - Added ability to choose which file to upload in a FileField - adding "delete" class to Image::DeleteImageForm - 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) - SiteTree: Don't let people create a page name that is the same as a class name - Added SS_DEFAULT_ADMIN_USERNAME/PASSWORD defines to conf/ConfigureFromEnv.php - Form: added setFields()/setActions() - Added Date:TimeDiffIn() - Added missing ChangePasswordEmail.ss - Added Member::$notify_password_change - now sends an email to the member - Member: Added BaseHref() to Member_ChangePasswordEmail so that the email shows the domain name of the current subsite. - Tidyied up lost password form - Create Group::canEdit(), which can be used to filter the SecurityAdmin group list - Fixed DataObjectSet::insertFirst() - it now uses a numeric key rather than null - 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 - Moved CMS page-disabled logic into SiteTree::CMSTreeClasses(), so that it can be more easily customised for specific sites - Moved folder admin form to Folder::getCMSFields() to let you more easily manipulate the form with a decorator - 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 - ViewableData: added $casting for BaseHref?() - main.php: Moved _ss_environment.php include to very top - Controller: Improved allowed_actions support for subclassed controllers, such as CMSMain extends LeftAndMain - Controller: Allow use of on controller extensions - Security: Added support for password and old_password encryption mechanisms if you're using MySQL - Versioned: added database indexes for AuthorID and PublisherID - HTMLEditorField: Added 'anchor' option to link inserter - Member: 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 - Added DataObject::hasDatabaseField() CMS - Added LeftAndMainSubsites?->augmentNewSiteTreeItem that allows extensions of LeftAndMain? to provide the current SubsiteID for the new item - MemberTableField: Added Member->SetPassword?, a field that lets you have a write-only password field - Removed redundant Add Member button at the top-right - Moved CMS page-disabled logic into SiteTree::CMSTreeClasses(), so that it can be more easily customised for specific sites Bug Fixes - Sapphire - 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 - 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