Bric::Changes - Bricolage Changes
$Revision: 1.256.2.261 $
$Date: 2004/05/02 22:25:51 $
This document lists the Changes to Bricolage introduced with each release.
make upgrade once again correctly creates postgres.db if the existing installation doesn't know the installed version of PostgreSQL. [David]
Adding notes to image, video, or audio media documents no longer causes an error. Reported by Christian Hauser. [David]
Errors in the PERL_LOADER bricolage.conf directive no longer silently fail. [David]
A successful login no longer redirects back to the login page, thus no longer forcing a second redirect in such cases. Reported by Marshall Roch. [David]
The $burner object is now available in Mason template <%once> blocks during the syntax check, although $story and $element are not. All three are in the <%once> block during previews and publishes. This means that they can all be used in a <%once> block like this:
<%once>;
unless ($burner->get_mode == SYNTAX_MODE) {
# Do stuff with $story or $element.
}
</%once>
Reported by Serge Sozonoff. [David]
Deactivated groups no longer affect permission checking. Discovered thanks to a bug report from Serge Sozonoff. [David]
Warnings are no longer fatal. This was only the case ouside of mod_perl, and so was probably quite rare, anyway. [David]
Upgrades no longer cause an error during the execution of inst/db_grant.pl. Reported by Abdul Halim Mazahar. [David]
Alerts once again properly check the attributes of the events that trigger them. Reported by Patrick Walsh. [David]
A checkbox that is unchecked in an element no longer reverts to checked when clicking "Save and Stay". Reported by Scott Lanning. [David]
Date parameters to the list() methods of the story, media, and template classes are now properly converted to UTC (and the database internal format) before being passed to the database. [David]
Elminated some warnings. Reported by Christian Hauser. [David]
Simplified error handling in the Bric base class and when running outside of mod_perl. [David]
Fixed issue with load order directives in Bricolage dynamic httpd.conf generation. This had caused the PREVIEW_MASON directive to not work in some cases. Incidentally, this change also allows dynamic configuration of mod_perl 1.26 and earlier. [David]
Added missing index to the workflow__id column of the story, media, and formatting (template) tables. [David]
Made index on the desk__id column of the story, media, and formatting (template) tables a partial index, since the column will usually be NULL. [David]
Added an index to the description column of the story_instance, media_instance, and formatting (template) tables to speed up simple searches. [David]
Added missing foreign key constraints for the desk_id column of the story, media, and formatting (template) tables. [David]
make clone no longer fails when it can't find httpd.conf, because it no longer looks for it. [David]
make clone no longer assumes that the conf directory is in $BRICOLAGE_ROOT, and prompts the user to find out. [David]
Bricolage once again works with Perl 5.6.x and Perl 5.8.1. [David]
Made bric_republish and bric_dev_sync safe to use with https://. [Geoff Richards]
The user object is no longer instantiated from the database every time a user sends a request to Bricolage. It appears that this bit of overhead has unfortunately been imposed on every request since Bricolage 1.0 due to a very stupid typo. [David]
The creation of the Bricolage PostgreSQL user and database during installation no longer complains about usernames or database names with dashes and other non-alphanumeric characters in them. Thanks to Marshall Roch for the spot! [David]
Fixed ancient bug revealed by the release of DBI 1.41. [David]
Photoshop-generated images no longer make Bricolage choke when they're uploaded to a Media profile that autopopulates fields. Reported by Paul Orrock. [David]
The lookup() method of the story, media, and template classes will now correctly return inactive objects. [David]
Fixed typo of CHECK_FREQUENCY in Bric::Config that made it always use the default of 1. [Scott]
The lookup() method of the story, media, and template classes once again attempt to retrieve objects from the per-request cache before looking them up in the database. [David]
Changed the name of the event logged when templates are checked out from "Template Checked Out Canceled" to the correct "Template Checked Out." [David]
Fixed installation and upgrade scripts to use the same perl binary as was used to execute Makefile.PL. This ensures that all necessary CPAN modules will be correctly installed and located. [Simon Wilcox]
Story profile JavaScript validation works again. Thanks to Simon Wilcox for the spot! [David]
Eliminated the need for the Apache::ConfigFile module, and thus some annoying problems with the CPAN indexer when trying to install it. [David]
Fixed order of SQL statement execution upon installation so that dependencies are properly handled. [Mark]
New file resources created for distribution are now created with the proper media type. [Mark]
The German localization module (Bric::Util::Language::de_de) had the wrong package name, which meant that attempts to use it failed with the error "Can't locate class method 'Bric::Util::Language::de_de::new' via package 'Bric::Util::Language::de_de'". [Dave Rolsky]
Added new path to find PostgreSQL installed by some Debian packages. [Cinly Ooi]
Workflows with special characters such as "+" and "&" now work properly in the side navigation. Thanks to Patrick Walsh for the spot! [David]
Start desks can no longer be removed from workflows. This prevents workflows from having no desks, thus avoiding problems adding desks to such workflows. Reported by Patrick Walsh. [David]
Pushing the cancel button in a desk profile and then in a workflow profile no longer redirects back to the desk profile. [David]
Made publish_date not be empty when publish is done through the SOAP API and no publish_date argument is passed. [Scott]
Fixed CPAN installer to correctly update the list of modules to be installed after a module has been successfully installed. Reported by Perrin Harkins. [David]
Checkout checkboxes no longer appear for assets that users don't have permission to check out. Thanks to Alexander Ling for the spot! [David]
Bric::Biz::AssetType::Parts::Data's lookup() method now returns deactivated objects, as it should. Thanks to Nuno Barreto for the spot. [David]
Events with attributes with the same name as attributes of the object the event was triggered on (a common occurrence) no longer confuses the two. Thanks to Todd Tyree for the spot. [David]
Users granted permission to access the members of a group via two user group associations now always get the highest priority permission, as it should be. Thanks to Patrick Walsh for the spot. [David]
Textarea fields in elements no longer lose some of their default data after editing the field in the element manager. Reported by Todd Tyree. [David]
Media assets now properly remember their class, which means that autopopulated fields (such as "height" and "width" for images) are autopopulated when a new image file is uploaded. Thanks to Patrick Walsh for the spot! [David]
Updated Chinese Traditional localization. [Kang-min Liu]
Custom select fields now correctly pay attention to the size attribute. Reported by Dave Rolsky. [David]
The element type manager now displays "Subelement" instead of "Story" for subelement element types. Suggested by Dave Rolsky. [David]
Updated to work with PostgreSQL 7.4. [David]
Improved error message in Bric::Util::Trans::SFTP. [David]
It's possible to create new stories again without running into errors saying that a URI is not unique because the cover date and slug were accidentally excluded from the URI. [David]
Mason story templates now inherit from all category templates, thus enabling the access of <%attr>s and calling of <%method>s in category templates from story templates. [David]
Permission to edit element fields is now based on the permissions granted to edit the elements they belong to. This means that users other Global Admin group members can now edit fields. [David]
Dates are no longer editable if a user doesn't have permission to edit them. [David]
Users without EDIT access to an element no longer see a link to Edit fields of that element, but a link to View them, instead. They will also no longer see an "Add Subelements" button. [David]
Fixed bug that triggered an invalid error message when a story URI is non-unique. Reported by Kevin Elliott. [David]
Assets with the same IDs but in different classes (media vs. stories vs. templates) no longer prevent each other from being added to a desk that can contain different classes of assets. Thanks to Scott for the spot and doing the research that lead to the replication of the problem. [David]
The Log page no longer improperly redirects to the preview page after a preview. Reported by Simon Wilcox. [David]
Fixed bric_soap to accept a --server argument starting with "https", which is more friendly to an SSI environment. [Geoff Richards]
The PostgreSQL admin username and password arguments were reversed during make upgrade. [Thorston Biel]
Fixed broken foreign key index on element table. [Dave Rolsky]
Added partial index to speed queries against the job table, and thus to speed distribution. [Mark]
Fixed upgrade module to properly grant the correct Bricolage database user permission to access new tables and sequences. [David]
An upgrade script failure will really now cause make upgrade to halt installation so that any issues are immediately identified and correctable. [David]
Updated slug RegExen. They were a bit too strict, and should be better now, allowing dots, dashes, and underscores. Spotted by Creighton Higgins. [David]
The $name variable no longer shows up twice in the list of available content variables for alert types on media documents. Thanks to Scott for the spot! [David]
Inactive alert types no longer trigger the sending of alerts. Thanks to Scott for the spot. [David]
Added tests for validity of the POD in *.pod files as well as *.pm files. Fixed a few POD typos found as a result. [David]
Fixed element_data_id parameter to Bric::Biz::Asset::Business::Parts::Tile::Data to actually work. Reported by Eldar Kononov. [David]
Added README.Solaris, with thanks to Oscar Sodani and Thorsten Biel.
When an asset is published or deployed directly from the asset profile, it is now properly removed from the publish or deploy desk. Reported by Andy Baio's coworker. [David]
The "desk_id" attribute of assets is now properly cleared when an asset is removed from workflow. [David]
Fixed 1.6.5 upgrade script to look for Bric::Config in the proper location. [David]
Templates now display their output channel associations instead of their element associations on desks. This seems to be more useful, since the element association is usually obvious from the name. [David]
The category URI is now displayed for assets on desks, rather than the name. This is consistent with the display of the category elsewhere. [David]
Elements to which no subelements can be added will no longer display an empty select list and "Add Element" button. [Geoff Richards]
Bric::Biz::Asset::Business::Story->get_secondary_categories() will no longer return categories deleted from the story. Thanks to Scott for the spot. [David]
Removed some unnecessary JavaScript validation. [David]
Bug fix when deploying to multiple output channels. If the output channel IDs matched each other partly, it could cause a file to be removed after it just had been uploaded. [Arthur/Fotango]
Users with CREATE access to a start desk can once again create stories on that desk even when they don't have CREATE access to "All Stories." Reported by Simon Wilcox. [David]
Each upgrade script is now run within the confines of a single database transaction. If any database changes within an upgrade script encounter an error, all of the changes in that script will be rolled back. Suggested by Arthur. [David]
An upgrade script failure will now cause make upgrade to halt installation so that any issues are immediately identified and correctable. [David]
An invalid date in a date element field no longer causes an error. Thanks to Arthur for the spot! [David]
With (STORY_URI_WITH_FILENAME enabled and when there is no defined file extension Bricolage now doesn't insert an ending '.' (dot). [Arthur/Fotango]
Slight fix to virtual FTP server to handle bad FTP clients that try and use directories as files. [Arthur]
Previewing stories with related media that have no associated file no longer causes an error. Reported by Kevin Elliott. [David]
Switched to using DBI->connect_cached() from using our own database connection caching. This change does bump up the minimum required version of DBI to 1.18, though the latest version is always recommended. It's also the right thing to do. Thanks to Perrin Harkins for the suggestion. [David]
Fixed issue that could cause Bric::Util::DBI to create inconsistent transaction states. Spotted by Rudy Lippan. [David]
Removed passing of DEBUG argument to prepare(), prepare_c() and prepare_ca(), since it hasn't actually worked in some time, and could potentially change the behavior of the prepare. [David]
Bric::SOAP::Workflow no longer throws an error when its publish_date parameter is undefined. Reported by Kevin Elliott. [David]
Passing an undef via the workflow__id parameters to the list() method of Story, Media, or Template really does again cause Bricolage to correctly return only those assets that are not in workflow. It wasn't as fixed in 1.6.3 as I had thought. Reported by Kevin Elliott. [David]
Vastly improved the speed of the query that lists events, and added an index to help it along, as well. [Mark]
The list of categories associated with a story is now presented in alphabetical order by URI in the story profile. Suggested by Geoff Richards. [David]
The FTP mover now properly deletes files rather than erroring out. [Clive Jones]
Fixed installer to use PostgreSQL 7.1 syntax to update statistics. [David]
Now setting $PGDATESTYLE environment variable so that PostgreSQL isn't confused about the date style Bricolage is using. Suggested by Chris Riddoch. [David]
Users without EDIT access to the start desk in a workflow can no longer create assets in that workflow. Nor can they check out assets from the library, as there's no start desk for them to check them in to. But they can still check them out from other desks that they have EDIT access to. Reported by Rachel Murray. [David]
Time zone issues have been fixed to be more portable. Some platforms that experienced Bricolage unexpectedly shifting cover dates and other dates and times by several hours should no longer see this problem. [David]
Non-existent methods no longer throw "permission denied" exceptions, but the standard Perl "Can't locate object method" exception. This is to eliminate confusion with permission to access Bricolage objects. [David]
Adding a new element type with the same name as an existing or deleted element type no longer causes an SQL error. Thanks to Gary Gilchrist for the spot. [David]
Preview works again. [David]
Document and contributor type field information (label, options) is no longer pushed through Locale::Maketext, thus preventing errors when element and contributor type administrators create field options with brackets in them. Reported by Kevin Elliott. [David]
Documents associated with categories that have been deleted will once again work properly. Even though a category may be deactivated, any documents previously put into that category should still work, and still treat the category as a working category. And so they do. Thanks to Kevin Elliott for the spot! [David]
Renamed events for adding fields to elements and contributor types. They were mentioning "attributes," and now they mention "fields," instead. [David]
Updated Bric::Admin (INSTALL) to instruct users encountering installation problems to first check the list archives and post to the mailing list before filing a bug. [Cinly Ooi]
Permissions granted on the "All" groups work again. Reported by Kevin Elliott. [David]
Resize now works in super bulk edit. Thanks to Michael G. Kaiser for the spot. [David]
Documented that the list_ids() methods in Bric::Biz::Asset's subclasses ignore the Order and OrderDiretion parameters and return an unordered list of IDs. Reported by Clive Jones. [David]
The "Add Element" select list in story, media profiles now lists the fields that can be added in the order specified in the element profile, and then the subelements that can be added, instead of mixing up fields and subelements in alphabetical order. Thanks to João Pedro for the spot! [David]
When a template is deployed, Bricolage now checks to see if its file name has changed since it was last deployed, and if it has, it deletes the old file. Reported by Kevin Elliott. [David]
Optimized performance of Bric::Dist::Resource queries and wrote lots of tests for them. [David]
When a story or media document is published, Bricolage now looks to see if any files distributed for previous versions of the document are no longer associated with the document, and expires them if they are. It does so on a per-output channel basis, so note that if output channel settings have changed since the document was last published, the expiration may miss some stale files. The same goes for when destinations are changed. But this should cover the vast majority of cases.
Fixed error looking up alert types in the database, which affected the alert type manager on some platforms. Reported by Radu Greab. [David]
Deactivated alert types are once again available via the UI. [David]
Text input fields no longer impose a default maximum field length. This is so that element fields that have their maximum length set to 0 can truly be unlimited in length. Reported by Kevin Elliott. [David]
Template output channel associations no longer trigger an error when importing templates via the SOAP interface. [Clive Jones]
Passing an undef via the workflow__id parameters to the list() method of Story, Media, or Template once again causes Bricolage to correctly return only those assets that are not in workflow. Reported by Kevin Elliott. [David]
Extra blank lines between subelement tags in super bulk edit no longer causes an error. Thanks to Kevin Elliott for the spot! [David]
Searches no longer return unexpected results or all objects when pagination is enabled. Thanks to Kevin Elliott for the spot! [David]
The searches for documents by beginning and ending cover dates were not inclusive of the end date. Now they are! Reported by Kevin Elliott. [David]
Fixed spelling of "contributor" in the description of the contributor type class in the database. Noticed by Radu Greab. [David]
German localization started. [Gerfried Fuchs]
New help pages for the destination, server, and action profiles. [Geoff Richards]
Fixed a bug in Bric::SOAP::Media which was causing all media files uploaded with that module to be placed in comp/data/media/$version/ rather than comp/data/media/$id/$version/. [Mark]
Fixed SQL bug that might in rare situations cause element output channel associations to become confused. [David]
Fixed issue where new output channels added to a document type element were not always actually saved as a part of that element. [David]
Fixed side navigation spacer graphic to the same width as other such graphics. Helps Chinese Traditional to display more nicely. [Kang-min Liu]
The media simple search now searches by URI again. [Mark]
Now HTML-escaping the contents of the context content displayed for subelements so as to prevent HTML in fields from messing up the display. [Mark]
Fixed installer to again work with versions of PostgreSQL prior to 7.3. Thanks to Marc Hawson for the spot. [David]
Fix for 'Can't call method "out_method" on an undefined value' generated during a burn. [Mark]
Many minor HTML corrections. [Gerfried Fuchs]
Fix for SQL error when searching for media by file name. [David]
Eliminated 'Can't locate object method "redirect" via package "HTML::Mason::Request"' error that caused Bricolage to actually display a generic error page, instead of its custom error page. [David]
Alert types can once again be deleted from the alert type profile. [David]
Users can now only add subelements to a story if they have at least READ permission to those subelements. Thanks to Mark for the spot. [David]
If the installer notices that you're attempting to install Bricolage in a directory with an existing installation, it will suggest that you consider running make upgrade, instead. Suggested by Bruce Albrecht. [David]
The list manager now sorts version numbers as numbers rather than strings. [João Pedro]
The media type profile again allows extensions to be added and removed. Reported by Tobias Kremer. [David]
Added the CHAR_SET directive's value to Bricolage's Apache configuration via the httpd.conf directive AddDefaultCharset. Might help with some Unicode issues. [David]
Distribution error handling is better now, with errors passed back to the client and an error when bric_dist_mon attempts to connect to a server or URL that's not a Bricolage distribution server. [David]
Eliminated installation error 'Failed to create database: parser: parse error at or near "template0"', which occurred with versions of PostgreSQL prior to 7.3. [Scott]
Enabled the PERL_LOADER bricolage.conf configuration directive and gave it a default value that's actually useful. [David]
Perl 5.8.0 or later is now strongly recommended for better Unicode support.
Fixed deleting an Alert Type Rule. Also fixed Editing Alert Type Recipients. [Scott]
Notes are once again saved with a document. Thanks to Scott for the spot! [David]
Fixed an issue with FTP distribution where the incorrect FTP root was used an invalid path. [Clive Jones]
The title and description of a story or media document are now properly reverted when the document is reverted to an earlier version. Thanks to Scott for the spot. [David]
Pagination now works properly when searching for groups by type in the group manager. [Scott]
Pagination now works properly when searching for elements by element type in the element manager and when searching for contributors by contributor type in the contributor manager. [David]
Creating a new story that has a URI that conflicts with an existing story no longer creates an extra story. Reported by Clive Jones. [David]
Changed "Cannot publish asset because there are no Destinations associated with its output channels" to instead include the name of the output channel missing Destination associations so that the user can tell which output channels need a Destination association. [Clive Jones]
When an document's primary output channel has been changed to something other than that defined by its document type element, preview will now correctly use the document's primary output channel instead of the element's primary output channel. [David]
Returning to a desk from editing an asset that was selected for editing from that desk no longer triggers an error. Thanks to Clive Jones for the spot! [David]
An attempt to preview a story where its templates output no content no longer results in an error. Reported by Eldar Kononov. [David]
Clicking "Cancel" in an element no longer saves the changes in that element before going up to the parent element. Thanks to Andrew Baio for the spot! [David]
Changes made to the default values of fields in the contributor type profile are now properly saved. Reported by Scott. [David]
Adding Extensions to a Bric::Util::MediaType object when creating it via that class' new() constructor works again. Reported by Clive Jones. [David]
Added Localization support to widgets that were missing it. Added pt_pt localized images. [João Pedro]
Documents are no longer distributed to deleted (deactivated) destinations. Reported by Mark. [David]
Eliminated several error log authentication message such as "No cookie found." Thes tended only to confuse users when they were just starting to use Bricolage. I've left in a few error messages, however, so that system administrators can see in the log when it looks like someone is trying to hack into Bricolage. The remaninging authentication error log messages are:
Invalid username or password. Please try again.
User does not exist or is disabled.
Malformed cookie.
Cookie hash mismatch from [IP address] (Hostname '[hostname]') for user '[username].'
Elements added with the same name as an existing, active or inactive element no longer trigger an SQL error to be displayed. Thanks to Clive Jones for the spot! [David]
Fixed issue where adding an output channel to a document type element removed that output channel from another document type element. Thanks to Clive Jones for the spot! [David]
Adding a server to a new destination before saving the destination or adding an action no longer causes an SQL error. [David]
make clone now properly clones bricolage.conf, httpd.conf, and all of the contents of conf/. [David]
Added bric_xfer_grps and bric_xfer_users to contrib/bric_xfer. They use the Bric API to transfer users and groups between Bricolage Installations. [Scott]
Added Traditional Chinese localization. [Kang-min Liu]
make clone now properly creates inst/Pg.sql instead of inst/bricolage.sql. It also once again properly resolves the circular dependency between the "usr" table and the login_avail() PostgreSQL function. [David]
The FTP distributor now deletes existing copies of files before renaming a temporary file when connecting to Win32 servers. This is because the IIS FTP server doesn't seem to support renaming a file to the same name as an existing file. [David]
Creating the database during make install no longer fails if someone is already connected to template1. [Scott]
A preview link is no longer in the "Find Media," "Active Media," desk, or "My Workspace" views for media that have no associated file. [David]
make upgrade now uses the correct PostgreSQL root username and password, instead of the default "postgres" username and empty password. Thanks to Paul Cory for the spot! [David]
Burn-time exceptions are once again properly displayed in the error page. [David]
When the STORY_URI_WITH_FILENAME bricolage.conf directive is enabled, stories are now written to the proper file when previewed or published. Thanks to Kevin White for the spot! [David]
Fix issue that came up with the release of Mason 1.20. Reported by Jeff Steele. [David]
Fixed typo in Media Type manager that broke it. Reported by Lari Huttunen. [Scott]
Fixed problem where an attempt to add new output channels to a new element before saving that element cause errors. Mainly noticeable when creating elements via SOAP. Thanks to Mark for the spot. [David]
Various localization fixes. [Scott]
Fixed event logging for element fields. [David]
Media assets that are based on "Image", "Audio", and "Video" element types now properly show up on desks. Note that existing media assets missing from desks should be checked out via "Active Media" and moved to a new desk. [David]
Documented the support for passing %ARGS to $burner->display_element() in templates. It was added to Bric::Util::Burner::Mason a while ago, but I forgot to document it! Thanks to Mike Slattery for the spot. [David]
Added Crypt::SSLeay to the list of optional modules to be installed. This module is required for SOAP communications over SSL. So if you use SSL and you use the SOAP server, you'll want to install it. [David]
Fixed alerts so that alerts are once again sent to the members of groups. Reported by Paul Cory. [David]
Deleted alert types are no longer displayed in the Alert Type Manager. Thanks to Paul Cory for the spot! [David]
Added more intelligent code using HTTP headers instead of HTML to prevent browsers [IE] from caching pages. [David]
Bricolage no correctly sets the HTTP headers for the content language and character set. Thanks to Nathan Ollerenshaw for the spot! [David]
make clone now changes the user and group ownership on the cloned files to the values for the current user (root). This is to avoid problems when taring up those files. [David]
Added code to Apache configuration to force JavaScript files to be served with the proper character set HTTP header. Those who use manual Apache configuration along with Bric::App::ApacheStartup will want to add the following configuration directive to your httpd.conf:
<Location /media/js>
ForceType => "application/x-javascript; charset=utf-8"
</Location>
The virtual FTP server no longer displays templates in subcategories of the current subcategory directory. Thanks to George Harrison for the spot! [David]
Output channel associations in story type and media type elements can now be deleted again. Thanks to Arthur Bergman for the spot! [David]
Added listing of emeritus developers. Otherwise Sam was simply listed as a patcher, which is hardly accurate. [David]
The element profile no longer displays deleted fields after clicking the "Save and Stay" button. [David]
The element profile now correctly issues a warning when a field is selected to be deleted. [David]
Made unlocalized JavaScript message localized. [David]
Added the STORY_URI_WITH_FILENAME bricolage.conf directive, which, when enabled, allows story URIs to include the file name. This is especially useful in output channels where "Use Slug as File name" is enabled, since it allows stories to essentially have identical URIs except for the file name. Off by default. [David]
Added bric_media_upload, a media file bulk import utility, into contrib. Thanks to Matt Vella for the contribution.
New help pages for the event log and the workflow trail. Thanks to Geoff Richards for the contribution.
Some unnecessary JavaScript was removed from the side navigation layer. Thanks to Eldar Kononov for the suggestion. [David]
Added keyword support for media assets to SOAP interface. [David]
Neatened the "Find Stories," "Active Stories," "Find Media," and "Active Media" screens and added the ability to preview stories and media by clicking their titles. [David]
Added Field Profile, so that element Fields can be edited. This is a marked improvement over the old interface, which required that fields be deleted and recreated if users wanted to change them. [Scott]
Granting of permission to database objects during installation has been moved to its own make target. This is to allow it to be run by make upgrade, too, thus ensuring that the Bricolage database user always has the appropriate permissions to access the database. [David]
Assets can once again be removed from workflow. [David]
The published version attribute is now set on templates when they're deployed. Thanks to Geoff Richards for the spot. [David]
The bricolage.conf and httpd.conf files are now created during make rather than make install so that make test can take advantage of them. [David]
Bric::App::Session and Bric::App::Cache no longer chown their files and directories during make test. [David]
Super Bulk Edit no longer joins lines together without a space, so that words should now be properly separated. [David]
Deleting a story or media subelement no longer results in an error. [David]
Help has been restored. [David]
A value of "0" (zero) can now be given to element fields. This bug has been in Bricolage since the beginning! Thanks to Mark for the spot. [David]
Stories with subelements containing no field elements no longer cause an error when the container profile is looking for contextual information to display about a a subelement. Thanks to Chris Jantzen for the spot. [David]
Bulk editing a field without first going through the element profile and without adding or removing or reordering field elements now preserves the data. This is another bug that has been in the code since the beginning of time, and was only recently identified. Thanks to Rachel Murray for the spot. [David]
Fixed an obscure bug where an element with a field element and a container element with the same ID could cause an error when one tries to edit the container element and Bricolage tries to load the field element, instead. Embarrassingly discovered in the middle of a presentation to the London Perl M[ou]ngers. [David]
Minor JavaScript fix for Opera users, thanks to Kevin White. [David]
The "multi" installation method now defaults the "Bricolage Root Directory" setting to /usr/local/bricolage instead of "NONE". This seems to be less annoying to people. [David]
The inst/upgrade/1.5.1/asset_desk.pl script, which is run by make upgrade, now correctly checks to see if the upgrade has already been performed. [David]
The inst/upgrade/1.5.1/webdav_mover.pl script, which is run by make upgrade, now correctly checks for the existence of the correct record in the "class" table before inserting a new record. [David]
During make upgrade, the upgrade scripts are now run before the new APIs are installed, so that there are no conflicts when using the existing API to make changes. [David]
Creation and installation of man pages can now be avoided during make upgrade as well as during make. [David]
Man pages will now be installed in the correct subdirectory of $BRICOLAGE_ROOT when using the "multi" install method. [David]
Fixed issue where asset groups and desk groups were conflated in workflow objects, leading to errors on the permissions page. Thanks to João Pedro for the spot. [David]
The URI of new stories is once again properly formed when the stories are created. [David]
The list of events no longer displays attributes for events that have no attributes. [David]
Attempting to add more keywords to the root category no longer results in the error "Cannot change the directory of the root category." [David]
In lists of objects a cell with a value of "0" (zero) will now be displayed. [David]
In "Find Templates," the list of templates in the search results will now be sorted by the file name, instead of not at all. [David]
make distclean now properly deletes inst/Pg.sql. [David]
Out of the box, the Story Editors, Media Producers, and Template Developers groups now have READ permission to access members of the "All Categories" and "All Elements" groups, which allow them to actually create assets based on elements and within categories. [David]
Workflow and Desk permissions are a little more sensible now. CREATE permission can be granted for the start desk in each workflow, instead of for the entire workflow. This allows a lower permission to be set on the workflow (e.g., READ), and then higher permissions on the individual desks in the workflow. [David]
New "Tuning" sections have been added to Bric::DBA. [Mark]
The default required length for usernames and passwords has been changed from 6 to 5. This is to make dealing with the default "admin" login easier.
It is once again possible to delete elements when they are not associated with any story or media asset. [David]
The output channel profile once again only complains that the name of an output channel is already in use if it happens to be true. [David]
Bric::Config now does its best to find a workable httpd.conf file during make test. [David]
Subclasses of Bric::Biz::Asset::Business::Media work again, and can have keywords associated with them, too. [David]
The "Access Denied" message is back for when someone tries to access an object to which they don't have adequate permission. [David]
Previews of assets that are not checked out work again. [David]
Workflow and desk permissions relative to the assets they contain are now restored to their previous behavior. Desks no longer simply inherit the permission granted on any of the workflows they're in. This issue was resolved by creating a new secret asset group ID for each workflow. [David]
The primary output channel is now always enabled by default in top-level elements. This is to make it much harder to create documents without output channel associations, an event that can lead to database exceptions. [David]
The root category now lists itself as being in the "All Categories" group only once in the category profile. [David]
Assets will no longer appear to randomly disappear from workflow. [David]
Added constraints to the "media_type_member" group that were inadvertently left out of 1.5.1. [David]
Permissions are now once again properly checked for assets in categories, workflows, and on desks. [Mark]
Lots of group-related optimizations. These should greatly improve the speed with which permissions are checked. [David]
Improved testing support with lots more tests. Many more remain to be written. See the new testing documentation in Bric::Hacker for details. [David]
Added ability to publish assets at a future time to Bric::SOAP::Workflow. Includes addition of new --publish-date option to bric_soap. [David]
Added WebDAV mover. [João Pedro]
FTP and File System movers now atomically copy files to their destination servers. [João Pedro]
Added "All Desks" group for managing the permission to access all desks. [David]
Refactored and optimized the code used in the lookup(), list(), list_ids(), and, where pertinent, href() methods in the following classes:
This work will allow permission checking to be much faster for objects of these classes, as the relevant group IDs are now looked up for each object when the object is looked up, rather than by a separate select for each object, one-at-a-time. The changes also include support for a grp_id parameter to be passed to the list() method of these classes as a way of allowing a group to return a list of the objects in the group en masse, rather than one-at-a-time from the member objects of each group. Once similar optimizations have been made to the Bric::Biz::Assest classes, the necessary change will be made to Bric::Util::Grp to allow this functionality. [David and Mark]
Added object caching to the base class, and calls to it from all classes with a lookup() method to take advantage of it. The caching is only for the duration of a request for now, but can be expanded later. [David]
Updated INSTALL.MacOSX to reflect changes thanks to the new Mac OS X support included in libapreq 1.1. [David]
Added "Super Bulk Edit", which is a bulk edit interface allowing users to edit all of the fields in an element at once using POD-like tags, rather than just a single repeatable field. [Garth]
Added help topic for new "Super Bulk Edit" feature. [David]
Localization and Internationalization support introduced, with a Portuguese library to complement the default English. Most message strings have been replaced with calls to the proper localization method. Still to be done are strings fetched from the database (e.g. events). [Cláudio Valente]
Localization of text images (buttons), Help, and JavaScript message added. These still need translation, however. [David]
Added Italian translation. [Marco Ghezzi]
Documented bric_dist_mon and bric_ftpd. [David]
Optimized and added tests for Bric::Util::Priv's get_acl() and get_acl_mtime() methods. These should make the looking up of a user's access control list faster. [David]
Added preview link to every element profile of a story profile. [Scott]
Pared down number of default User groups by eliminating those that relate to only a single admin menu item. [David]
Fixed code in Bric::Util::Grp where the has_member() method would fail to look up an object with an ID of 0. [João Pedro]
Switched exceptions from home-grown to using Exception::Class. [Scott]
The installer now offers a more meaningful message when it encounters an existing database and the user doesn't want to drop that existing database. [David]
Added category group association, including ability to cascade membership assignments into subcategories, to category profile. [João Pedro]
The installer will no longer try to load CPAN.pm if all modules are already installed. Thanks to Ilia Chipitsine for the prodding. [David]
The "Content" section of story, media, and subelement profiles now attempts to display a bit of text from the first text field in each listed subelement so that it's easier to see at a glance which subelement is which. [João Pedro]
Switched POD testing from Pod::Checker to Test::Pod (using Pod::Simple). Fixed the POD errors it found, too. [David]
Test suite now runs all tests with warnings enabled. [David]
Modified Grp->get_objects() to use use the grp_id parameter to list(), now that support for that parameter has been added to all groupable classes. Also went through all existing code to make sure that it uses this approach, rather than constructing the relevant objects one-at-a-time from each Member object. This should provide a dramatic speedup in many operations.
Bric::App::Session now has an instance() public class method to return the current %session hash. [Scott]
Subelements can now nest. That is, they can contain themselves. Not in a story, of course, but in the document model (element administration). [David]
Keywords can now be associated with media assets. [David]
Templates now have a published_version attribute that properly reflects the version of a template that was last deployed. This matches what Story and Media have done since around version 1.3.2, and eliminates some warnings from the error log. The UI has also been updated to properly show the deploy status of templates. [David]
The installer should now properly detect that the Apache "log_config" module is installed even when it's called "config_log". Thanks to Ilia Chipitsine for the spot and the diagnostics needed to solve the problem. [David]
The publish attribute of desks can now be unset. Thanks to Sean Greathouse for the catch! [David]
Fixed asset class date parameters to list(). The asset classes were neglecting to change the dates passed in to list() to database dates before querying the database. This lead to the wrong stories being returned for everyone not using UTC as their local time zone. Thanks to Bill Cappel for the spot! [David]
Fixed bug where expired cookie resulted in a Bric::App::Session error. [João Pedro]
A number of default groups where not properly added to the "All Groups" group. Now they are. [David]
Bricolage now does more to determine the media type of uploaded media by using both the Apache media type determination and, failing that, a file name extension. Thanks to Todd Tyree for the spot. [David]
Fixed the description of the root category in the permissions profile for user groups so that it properly displays its URI instead of its name. This only affects the display of the root category in the permissions profile for people who installed (rather than upgraded to) Bricolage 1.4.5 or later. [David]
An attempt to create a template with the same name and output channel as a deactivated template now properly tells the user that the template already exists. [David]
Fixed indexes for person objects so that they're case-insensitive. [David]
Fixed problem creating new business assets with SOAP where Bricolage was trying to associate them with output channels twice, resulting in an SQL Error. [David]
Fixed broken index on media type extensions. It was duplicating the index on the media type names. It has been changed to uniquely index the media type file name extensions. [David]
Bric::Biz::Category->get_children now properly returns the children for the root category. Thanks to Sam for the spot! [David]
Removed Bric::Biz::AssetType->remove. It shouldn't be used anywhere, and might be responsible for the mysterious disappearance of elements in general. Thanks to João Pedro for the spot. [David]
Assigned appropriate permissions to allow the default "Story Editors," "Media Producers," and "Template Developers" to access the default workflow and desks relevant to them. They hadn't had that access by default before. [David]
Changed the plural name of the "Category Group" class from "Category Group" to "Category Groups". [David]
Fixed bug introduced in 1.5.0 where stories where checked for duplicate URIs for output channels that they weren't actually in. Thanks to Bill Cappel for the spot. [David]
Fixed duplicate URI checking for media assets so that all output channels a media asset is in will be checked for duplicate URIs instead of just the primary URI. [David]
Fixed bug where all sources were being deactivated from their groups every time they were saved. [David]
Fixed bug where the SOAP server would throw an exception when it attempted to handle elements without subelements. Thanks to Sam Tregar for the report. [David]
It is no longer possible to create a story type or media type element without a primary output channel. [David]
Deleted output channels no longer show up in the list of output channels to associate with a destination. Thanks to Alex Epshteyn for the spot! [David]
The installer now collects Apache configuration data from any Included files, as well. Thanks to Alex Wheeler for the spot! [David]
Media types now can be added to groups. This means that permissions can be set so that users can administer media types. Previously, only members of the "Global Admins" group could administer media types. [David]
Added unit testing framework based on Test::Class and executed by Test::Harness. Tests can be run after make install by running make test or make devtest. The former runs tests that access database data but execute no INSERT, UPDATE, or DELETE commands. The latter runs tests that can make changes to the database, and are intended to be a full testing of Bricolage's API. Both make targets can be executed in verbose mode by passing TEST_VERBOSE=1 to the make command. From now on, all tests will be expected to pass before changes are committed to the repository. [David]
Added Makefile.PL. This is mainly a dummy script designed to mimic the usual way in which Perl modules are installed. It doesn't actually create a Makefile, but processes the existing one, setting it up to use whatever Perl was used to execute Makefile.PL itself. The advantage to this is that the Perl that executes Makefile.PL will be used throughout Bricolage. [David]
Migrated tests in lib/Bric/Util/Grp.pl to t/lib/Bric/Util/Grp/Test.pm and t/lib/Bric/Util/Grp/DevTest.pm. [David]
Added t/Bric/Test/PodTest.pm, which uses Pod::Checker to examine the POD in all the Bricolage modules, scripts, and test modules and report errors. Currently, all the errors are "TODO" tests, which means that, technically, they'll pass. But as soon as all existing POD errors are cleaned out, errors will turn into test failures. This will help us to keep all of our POD valid. These tests run as a part of make devtest. [David]
Removed all old-style test scripts. Their contents have been copied into new unit testing classes. These classes each execute a single test, and the old testing contents are at the end of the file, after the __END__ symbol. Thus we'll be able to use the old tests to write the new tests. [David]
Added documentation on merging CVS branches to Bric::Hacker. [David]
Removed the URI Format and URI Case preferences and put them into Output Channel objects, instead. They are now output channel-specific. [David]
URI format and URI case settings now properly format the URIs of media objects, too. [David]
The slug can now be used in the Fixed URI Format. [David]
The slug can now be used for story file names. The option is supported on an output channel basis, and will only work for stories that have a slug. [David]
Added a "and Shelve" option to the "Check In" select list in the button bar on story, media, and asset pages. When this option is selected, the asset is checked in and then removed from workflow without publishing. [David]
Removed the "Checkin/Publish" and "Checkin/Deploy" buttons in asset profiles and replaced them with new "and Publish" or "and Deploy" options in the "Check In" select list in the button bar. Doing this collects all the usual Check In actions in one place and saves us screen real estate! [David]
Changed the way the "Checkin and Publish" and "Checkin and Deploy" callbacks work to use existing code in the desk and publish widgets to do the dirty work. This greatly reduces code duplication. [David]
Created a new class, Bric::Biz::OutputChannel::Element, which is a subclass of Bric::Biz::OutputChannel. This new class better manages the mapping of output channels to elements than the old approach did. It also adds a new property, enabled, which will be put to use shortly. [David]
Replaced all the custom handling of output channel objects in Bric::Biz::AssetType with a new Bric::Util::Coll subclass that does it all. This is a lot more efficient in terms of programmer time (and probably performance, too). [David]
Modified Bric::Biz::Asset::Business to manage the association between business assets and output channels by making use of the Bric::Util::Coll::OutputChannel class. It also automatically adds all of the "enabled" output channels of the element object as initial output channel associations for new business assets. [David]
Added a new property to templates: template types. This property can have one of three value that correspond to different template types: "Element Templates" (those associated with elements); Category Templates" (autohandlers in Mason parlance, category templates to HTML::Template users, and until now "generic templates" in the UI); and "Utility Templates" (those not associated with anything, but can be used as includes). [David]
Templates are now guaranteed to have unique file name/output channel combinations at the API and database levels. [David]
For stories on My Workspace, replaced "Trail" with "Clone". Clicking this link will make an exact copy of the story with the words "Clone of " prepended to the story title. [David]
Got rid of the popup window. Now when the toolbar-less window isn't the current window, the browser will be redirected to a a Welcome page where users can click a link to open the new window with the Bricolage UI. [David]
Improved the interface for the association of output channels in Element Profile. It now uses a list of output channels rather than a double list, and a radio button to select the primary output channel. Also, each associated output channel can be marked as "Enabled" or not, indicating whether a new asset based on the element will by default be associated with that output channel for publishing. [David]
On a related note, Stories and Media can now select which output channels to be published to on a per-story basis as well as which is the primary output channel, and the selection sticks with each version of a an asset. The list of available output channels comes from the output channels associated with the element on which the story or media asset is based. [David]
Bric::Util::Burner objects have a new property, mode. This property contains an integer value indicating whether a burner object is currently publishing, previewing, or checking syntax. The value maps to the conveniently-named constants "PUBLISH_MODE", "PREVIEW_MODE", and "SYNTAX_MODE". [David]
The documentation in the Bric::Util::Burner class has been updated and improved. [David]
Arguments can now be passed to the display_pages(), display_element(), and chain_next() methods of the $burner object in Mason templates. These arguments are passed to the templates that are executed just as they are if you'd called $m->comp, meaning that you can access their values via the %ARGS global and in <%args> blocks in Mason templates. [David]
Changed the display_pages() method of Bric::Util::Burner::Mason so that its first argument can be an anonymous array of the names of different paginated elements, and then all of those different paginated elements will be burned in order. This allows a story to have more than one type of paginated element. [David]
Added the methods prev_page_file(), prev_page_uri(), next_page_file(), and next_page_uri() to Bric::Util::Burner. These methods return the strings representing the file names or URIs of the previous and next pages of a story, relative to the page that is currently being burned and, in the case of the *_uri() methods, appropriate to the currently-burning Output Channel. Also updated the Bric::Templates and Bric::AdvTemplates documents to reflect these additions. [David]
Added source__id to list of criteria by which stories can be searched via the Bric::Biz::Asset::Business::Story list() and list_ids() methods. [David]
The Bricolage CSS document is now a static file served by Apache rather than a Mason component processed by mod_perl. This allows the style sheet to be cached by the browser so that it doesn't have to request it for every page in Bricolage. It also cuts down on processing time, since it doesn't have to be managed dynamically as a Mason component anymore. Also, all font sizes are now specified in pixels instead of points, in order to maximize the consistency of cross-browser font rendering. [David]
Added a new style for the template profile, so that template code is now displayed in its textarea box in a monospaced font. [David]
The main Bricolage JavaScript library has had several other JavaScript libraries rolled into it, and is now a static file served by Apache rather than a Mason component processed by mod_perl. This allows the JS to be cached by the browser so that it doesn't have to request it for every page in Bricolage. It also cuts down on processing time, since it doesn't have to be managed dynamically as a Mason component anymore. [David]
Added bricolage.conf directive "ALLOW_WORKFLOW_TRANSFER" to allow assets on shared desks to be able to be transferred across workflows via that shared desk. [David]
Changed Bric::Util::Burner to set publish_status after publishing, rather than before. Thus it is only set if the publish is successful, while at the same time templates can check publish_status to determine if a story is being published for the first time. [David]
Added get_more_pages() method to Bric::Util::Burner::Mason. It returns true if more pages remain to be burned, and false if not. However it's only enumerated when display_pages() is being used to output pages. [David]
Optimized Bric::Biz::Category to get a list of Group IDs for each category as it is selected from the database. This prevents the get_grp_ids() method from having to query the database, which was happening for every category object for which permissions are checked. [Mark & David]
Added event logging for keywords. [David]
Changed the code in Bric::Util::Burner::Mason to allow for new Mason burners to be constructed and used to publish stories from within templates. This is useful for generating tables of contents and such. [David]
Added support for the association between business assets and output channels to the SOAP interface. [David]
Removed IO::String dependence. [Scott]
Added a FAQ. [Scott]
Added a preference for naming the Bricolage instance. [Scott]
Added search by Category URI to Find Stories. Although one could use the search by URI feature for this before, it didn't allow for search by secondary categories. Now stories can be searched for in both primary and secondary categories. [David]
Added the methods page_file() and page_uri() to Bric::Util::Burner. When passed a page number argument, these methods return the strings representing the file names or URIs of the given page in the currently-burning story and, in the case of the page_uri() method, appropriate to the currently-burning Output Channel. These methods are best used in burners that don't burn one page at a time, such as Burner::Template. [David]
Ported to HTML::Mason versions 1.15 and higher. [Scott]
Added make uninstall support to installation system. [Scott]
Added page_filepath() method to Bric::Util::Burner. This method allows burner subclasses to get the name of a file to write to the file system without needing to figure out the file name themselves. [David]
Optimized behavior of collections (internal API). Now when an object is deleted from a collection (for example, when a member is deleted from a group), all the existing objects in the collection won't first be looked up in the database. The upshot is that certain parts of Bricolage that rely on collections, such as desks, should be more responsive. [David]
Bric::SAOP::Handler now properly logs fatal errors that are strings rather than exceptions. [David]
Updated Bric::DBA documentation to better reflect PostgreSQL standards. [Neil Conway]
Minor documentation correction in Bric::Util::Grp::Parts::Member. [Mark]
Fixed bug in SOAP interface where container subelements added to a story or media asset were logged as if the story type element or media type element was added instead of the appropriate subelement. [David]
Fixed bug in publish code that was attempting to use the Apache request object as a media asset. Thanks to John Greene for the spot. [David]
Fixed bug where an empty or non-numeric <size> element in an imported media object would cause an SQL error. [Sam]
The bric_apachectl, bric_clean_tmp, bric_dist_mon, and bric_ftpd scripts are now smarter about loading Bricolage libraries and reporting relevant errors when they can't load Bricolage libraries. Thanks to Geoff Richards for the patch. [David]
Category permissions are now properly checked on assets when they're not in workflow as well as when they are in workflow. This means that if a group of users is granted permission to access stories in a category, they can now access those stories even if they're not in workflow. [David]
The search interface for locating media and story assets to relate to a story now checks the permissions of the assets found and only displays the assets for which the user has at least READ permission. Thanks to Sean Greathouse for the spot. [David]
Reverting a media asset now properly reverts the media file itself, as well. [David]
The "Last" field is now properly highlighted as the default order field when displaying a list of contributors in the Contributor Manager. [David]
Contributor Association now includes search options and only currently-associated contributors are displayed before searching. [David]
The ability to select different fields by which to sort a list of objects now works again. [David]
The installer now checks to make sure that mod_perl is statically compiled into Apache, since weird things tend to happen when Bricolage uses a DSO mod_perl. [David]
Fixed reordering code for subelements. The select list for subelements should now always have an appropriate value. [David]
The URI is now properly updated in media assets when some part of the URI is changed in the UI. Thanks to Sean Greathouse for the spot. [David]
The Add More widget no longer throws an exception when "Add More" is clicked and only one field currently exists. This had affected Keywords entry in stories. Thanks to Sam for the spot. [David]
Fixed bug where a user could create two assets with the same URI as long as they were both checked out by that user. Thanks to Shannon Brown for the spot! [David]
Date fields can now be unset. That is, if each of the select fields is set to its label, rather than a value, it'll stay that way. This was first noticed with the "Expire Date" in stories. Thanks to Philip Fibiger for the spot. [David]
Modified installation CREATE DATABASE command to always create the database with the encoding set to UTF-8 (UNICODE). [David]
Added instructions for installing readline library to README.MacOSX. [David]
Fixed some inaccurate image sizes. [Geoff Richards]
Added missing uri parameter to the possible search options in Bric::SOAP::Category->list_ids. [David]
Categories are now displayed by their URIs instead of their names wherever possible. [David]
Added "Order" and "OrderDirection" parameters to Bric::Util::Grp->list in order to be able to specify a different column and sort order for getting a list of groups. [David]
Improved error handling by the SOAP server. Full errors will now be printed to the Apache error log, error messages sent back to the client are properly escaped, and all database transactions for a single request will be rolled back in the event of an error. [David]
Fixed error message generated from Bric::SOAP::Template->update() to properly display the category name, rather than "ARRAY(0x9cf43bc)". [Sam]
The Bricolage SOAP interface will no longer allow the creation of stories and media with duplicate URIs. [Sam]
Fixed circular dependency issues when Bricolage modules are used in the PERL_LOADER bricolage.conf directive. [David]
Added the root category to the "All Categories" group. It should have been in that group all along. [David]
Documentation for Bric::Biz::Workflow->list has been improved, and the method used for finding workflows and desks to put imported assets on in Bric::SOAP has been simplified. [David]
Added printing of a message regarding the filenames being processed by bric_soap's create and update commands when its --verbose option is set. [David]
Setting a story's cover date to a date that causes one of its URIs to conflict with an existing story's URIs no longer causes an error. Thanks to Sam for the spot! [David]
Display of the source was missing from the view Story and Media profiles, but no longer. [David]
The correct source is now displayed in the Story and Media edit profiles. [David]
An attempt to install Bricolage to use an existing PostgreSQL user no longer causes an installation error when you decline drop the user. [David]
The burner no longer fails when it publishes an asset that's not on a desk. [David]
SOAP now does the proper thing when deleting assets, removing them from desks and workflow only if they're on desks and in workflow. [David]
Added support for the missing publish_status parameter to Bric::Biz::Asset::Business::Media->list. [David]
Setting permissions on the assets in a category works again. [David]
Fixed a bug where exporting a story via SOAP containing a date field would output the formatted date rather than the expected ISO 8601 format. Systems with a modified date format pref would then refuse to accept the story on import, producing an "Unable to unpack date" error. [Sam]
Stories, media, and templates created but not saved no longer disappear into the void. They are instead moved into workflow, put on a desk, and saved as soon as they were created. [David]
Permissions are now properly checked for category and workflow settings when new stories, media, and template assets are created. [David]
New templates are now active by default. [David]
Fixed bug where the "Checkin/Publish" (and "Checkin/Deploy") button wasn't provided to users who had EDIT access to a the assets on a desk. Permissions are now properly checked and the button displayed for those who can publish from a desk. [David]
Added missing debugging statement to Bric::Util::DBI. Thanks to Mark for the spot. [David]
The SOAP interface now properly logs events for its activities. [David]
Previewing a story while searching for a related story to link to an element no longer replaces the Bricolage UI with the preview, as was happening with some browsers. Instead, a separate preview window is opened. [David]
When publishing a media asset, its name will not be properly added to the UI message, without causing an error. [Petar Bojkov]
Fixed exception class name in Handler.pm. [Scott]
Fixed installation system bug caused by inst/conf.pl loading Bric::Config during "make install". Thanks to Louis Moore for the report. [Sam]
Added missing list_ids() method to Bric::Biz::Category. [David]
Empty listManager lists no longer have a gap in them. [David]
Made the table around the formBuilder radio buttons prettier. [David]
Fixed numbering of sections in Media profile so that the numbers don't skip. [David]
Updated display of existing contributors in the "Edit Contributors" screen of the story and media asset profiles to use listManager. This makes them look like they do everywhere else (and uses less code, to boot!). [David]
Improved error messages thrown in exceptions in Bric::Util::Trans::FTP. [David]
Removed code and documentation for PostgreSQL 7.3 compatibility. With the release of 7.3b2, it's no longer needed. [David]
Fixed "make clone" to properly include database contents in clone distribution. [Sam]
Added <meta http-equiv="Content-Type"> tag to the <head> to header.mc so that the browser knows to send text back to Bricolage in the expected character set. [Mark]
Changed the default character set from ISO-8859-1 to UTF-8. With this setting, Bricolage does no character set translation, so it's faster. Furthermore, most users should be outputting UTF-8 in their templates, anyway. If you're not, then you're likely finding doing charset translation in all of your templates to be a big PITA. And if you're not doing charset translation, then you really are outputting UTF-8 in your templates, and just haven't realized it. [David]
Fixed bug when reverting stories and media with no associated contributors. [Mark]
"Check In and Publish" now works again for Media assets. Thanks to Matt Vella for the spot. [David]
Deleting assets on My Workspace now prompts the user to make sure s/he really wants to do that. Not sure how we missed this all this time! Thanks to Andrew Baio for the spot. [David]
Assets on Desks and My Workspace that are checked out to the the user whose viewing them will now always preview the version as currently edited by the user, rather than the last checked-in version. Other users still can only preview the last checked-in version. [David]
Clicking the "Check In" or "Check In/Deploy" buttons in a template profile now properly updates the template with any new data entered into the template profile before attempting a syntax check. This ensures that the latest data you've entered gets its syntax checked before the template is checked in or deployed. [David]
Fixed a bug in Bric::Util::Class where classes couldn't be looked up by package name. This affected the "Access Denied" page. [David]
Made Bric::Util::Burner::Mason a little smarter handling exceptions. [David]
Fixed bug where Bric::SOAP::Category would fail to import ad strings. [David]
Fixed bug in Bric::Util::Grp->has_member where an already-added member wasn't always found. [Mark]
Conflicting URI messages for media assets no longer suggest changing the value of the slug, since media assets have no slug. [David]
The friendly messages confirming publishes are back. [David]
Fixed bug where selecting a large number of list options in the story profile would cause an SQL error. [Matt]
Fixed bug where Bric::SOAP would accept story element types for media and vice versa. Thanks to Evan Prodromou for the spot. [Sam]
Added code to installation scripts to delete existing Mason object files when upgrading. This hasn't been a problem thus far, but this step will help to ensure that users are always running the latest UI components. [David]
Fixed bug where deactivated element types weren't checked before creating a new element type with the same name as a deactivated element type. Thanks to Geoff Richards for the spot. [David]
Fixed inconsistency between container element methods and their convenience accessors in Bric::Biz::Asset::Business. Thanks to Philip Fibiger for the spot. [David]
Assets can once again be recalled from the library and put on a desk. [David]
The get_all_keywords() method of Bric::Biz::Asset::Business works again. [David]
Can once again check out multiple assets at once. Thanks to Andrew Baio for the spot. [David]
Templates once again behave themselves. There were some circumstances where they couldn't be checked in, generating "Cannot checkin non checked out versions" errors. These have been fixed. [David]
Some assets on My Workspace were getting "Cannot checkin non checked out versions" errors when they were checked in using the "Check in to" select list. This has been fixed. [David]
When templates are deployed, they now get a "Template removed from Workflow" event logged. [David]
Using the "Check in to" select list on My Workspace to check assets into the desk they're already on will no longer remove them from all desks altogether. [David]
Upgrading from from a version prior to 1.3.3 no longer tries to create an index that already exists (and that will be dropped, anyway). [David]
Removed documentation for installing mod_proxy with Apache. [David]
Improved documentation for upgrading from older versions of Bricolage that were not installed by make install. Thanks to Andrew Baio for helping to identify the problems. [David]
Added use Bric::Util::Grp::Keyword; back into Bric::Biz::Keyword. This prevents some upgraded Bricolage installations from breaking. [David]
Added Net::FTPServer and Net::SFTP to the list of optional modules. [David]
Fixed some SQL errors uncovered by the release of PostgreSQL 7.3b1. [David]
Added code and documentation for compatibility with PostgreSQL 7.3. [David]
Media assets can now be distributed to more than one output channel at a time. [David]
Files are now distributed on a per-output channel basis, to ensure that the proper file is distributed to the proper destinations. [David]
Assets are now properly removed from workflow when they're deactivated (deleted in the UI). [David]
Template syntax is now properly checked when using the "Checkin/Deploy" button. [João Pedro]
The example generic template (autohandler) included in the database is now included in the burn root, too, since it's marked as "Deployed" in the database. [David]
Deleted output channels no longer show up in the "New Template" output channel select list. Thanks to Daniel Fisher for the spot. [David]
The root category ("/") no longer returns itself as its own parent. [David]
Assets not in workflow are now properly logged as being checked out when someone checks them out. [David]
The "Or Pick a Type" menus in the Group manager, the Contributor manager, and the Element manager all work again. [David]
Changing category names now updates the name of the category asset group object, which appears in the user group permissions page. [David]
Hitting the "enter" key after filling in a search field now properly submits the search as if the "Search" button had been clicked. [David]
Changed libapreq requirement in Bric::Admin to read "Apache::Request 1.0". This should make the installer install the most recent version of libapreq, instead of relying on whatever the OS provides. [David]
Changed value of autopopulated media asset data fields to an empty string when the value returned by the autopopulation method is undef. [David]
Fixed bug where autopopulated media asset data fields weren't properly autopopulated. [David]
Fixed problem with category upgrade script failing on category data created with 1.3.2. [Sam]
During installation, entering a directory name when prompted for the "PID File Location" now results in Bricolage using a file called "httpd.pid" in that directory, rather than trying (and failing) to use the directory itself as the PID file. [David]
The side navigation layer is now better aware of its context, and changes the colors of some of its graphics depending on the context. Also recreated the "WORKFLOW" tab graphics. It looks like this has been broken for over a year, and I only just noticed it! [David]
Slightly improved handling of assets that have forgotten where they are. [David]
Checked-out templates are now displayed only once (instead of twice) in the "Find Templates" manager. [David]
Added get_new_objs() method to Bric::Util::Coll so that Bric::Util::Grp's has_member() method can see a member even if it hasn't been saved to the database. Also changed Bric::Util::Grp to check for members in this way, of course. [David]
Assets retrieved from the library now appear on the desk they're checked out into only once (instead of twice). This thanks to the above-noted changes to Bric::Util::Grp. [David]
Added upgrade script inst/upgrade/1.4.1/clean_desks.pl to clean up existing duplicate listings of assets on desks. [David]
Removed the checkin() method from Bric::Biz::Asset::Formatting and Bric::Biz::Asset::Business and put it into Bric::Biz::Asset, instead, since it's exactly the same for all assets. [David]
Fixed the display of permissions settings to be more consistent with the design and layout of the rest of the application. Also neatened listManager display a bit. [David]
Fixed misnamed database constraint. [David]
Templates can once again be retrieved from the library and checked out for revising. [David]
Assets on a desk now no longer have the current desk listed in the "Move to" select list. Even if they did, selecting the current desk would no longer remove an asset from workflow! Thanks to Andrew Baio for the spot. [David]
The installer is now much more intelligent about prompting for SSL information. It won't ask if you want to use SSL if it can't find mod_ssl or apache_ssl, and will only prompt you to pick one or the other if it can find both. [David]
Fetching objects from Bric::Biz::Asset::Business::Media has been optimized for greater speed. [João Pedro]
PostgreSQL "NOTICE" messages are now suppressed during installation. Instead, a series of dots will be displayed to indicate progress loading the database. [David]
Added README.MacOSX. [David]
You can now pass a date format string argument to the get_data() method of container elements in templates (and elsewhere, for that matter). This is useful if the data you're retrieving is of the "date" type, and you don't want the date to be formatted in the format specified in the "Date Format" preference. [David]
The Element Type manager now displays properly again without errors. [David]
Assets are now properly removed from desks when they are published or moved from one desk to another. More generally, any time a single object is removed from a group, it will be properly removed. [David]
Media profile now display the proper category in the Category select list. [David]
Media assets with no associated media file now generate a message indicating that no file will be distributed, and are properly removed from workflow when published. [David]
Some media asset events weren't getting logged properly Now they are. [David]
Database transactions are now properly maintained when publishing assets. Everything was working, but DBI AutoCommit was getting turned on, and this likely slowed some things down a bit. [David]
Assets can once again be found via the "Find" pages and recalled into a workflow without error. [David]
Module man pages are now properly installed under Perl 5.8.0. Thanks to Michael Schwern for helping to diagnose the problem and come up with a solution. [David]
The select list of desks to transfer an asset to on My Workspace now includes all possible desks, including the one for which there is a link. [João Pedro]
All Bricolage .pod files are now installed and converted to man pages along with all of the .pm files. [David]
Corrected a bunch of spelling errors in this file. [David]
Calling get_data() on a container element in templates (or elsewhere, for that matter) now properly ignores container subelements. Likewise for get_container(), which how properly ignores data subelements. [David]
All of the .pl and .tst files in lib/ no longer clutter up the distribution created by make dist. [David]
Much of the POD documentation in the API classes has been cleaned up, and converting them to man pages no longer generates any error messages. [David]
The install process will now find Apache modules in /usr/lib/apache/modules, which is where they are in OpenBSD. Thanks to Mark Johnson for his help tracking this one down. [Sam]
The install process will no longer install an incompatible version of HTML::Mason (>1.09). [Sam]
The bric_dist_mon program works again. [David]
Revised Bric::Biz::Keyword implementation to improve performance. The new implementation no longer relies on the Bric::Util::Grp system. Also implemented API and database support for Media keywords. [Sam]
Added support for search Media by category and file name through the SOAP interface and standard API. [Sam]
Added new --save-cookie-file and --use-cookie-file options to bric_soap to allow authentication to span bric_soap calls. This can result in significant time savings across multiple invocations. [Matt]
Added new --chunks option to the bric_soap tool to avoid problems with timeouts on large workloads. Currently only supports the workflow commands (publish, deploy, checkin, checkout, move), but it will be expanded to other long-running commands in the future. [Sam]
Improved performance of search paging. ListManager now only builds the output rows that will actually be shown on the screen. For large data sets this results in a huge gain in search speed. [Adam and Sam]
Revised category implementation to use explicit uri and parent_id fields rather than relying on the Bric::Util::Grp system. This improves performance tremendously for larger numbers of categories. [Jeff Pinyan]
Added new --continue-on-errors option to bric_soap to prevent non-fatal errors from ending the process. [Sam]
Beautified the list paging interface. [David]
Added new Media Type manager. [Scott]
Added list reverse feature. [Scott]
Added SFTP mover. [Scott]
Add support for Apache-SSL. This required a change to the context of the bricolage.conf ENABLE_SSL directive to indicate the type of SSL support: none, apache_ssl, or mod_ssl. [Michael Robinton]
Added support for manual httpd configuration. Split out dynamic configuration from ApacheConfig.pm and move to a new module, ApacheStartup.pm, that sets no Apache configuration directives. ApacheConfig.pm calls this module. [Michael Robinton]
Added bricolage.conf configuration directive to force the start up process to always write out a $TEMP_DIR/bricolage/bric_httpd.conf as an httpd.conf include file. [Michael Robinton]
Moved SSL key and certificate configuration from global httpd.conf settings to per virtual host via bricolage.conf configuration directives. [Michael Robinton]
Added a bricolage.conf directive to force the user to always use SSL. [Michael Robinton]
Added get_data() method to Bric::Util::Grp::Parts::Member::Contrib. This method takes a simpler scalar argument and returns the relevant attribute. This bit of syntactic sugar makes contributor objects behave a bit more like $element objects in templates, thus simplifying things for template developers. [David]
Categories now default to sorting by URI, and the URI is the searchable field, rather than name. [David]
Vastly improved the speed at which categories can be imported via SOAP. [David]
Makefile now confirms location of Apache and PostgreSQL to allow for systems with multiple versions of each available. [Sam]
Added "make clone" command to the installation system to create distributions based on existing Bricolage systems. [Sam]
Added bricolage.conf directive to enable/disable the browser toolbar for debugging and development. Documented in Bric::Hacker. [Michael Robinton]
Added support for running Bricolage with SSL support on arbitrary ports. Previous versions required https support to use only port 80 for http and port 443 for https. With this release, Bricolage fully supports http and https service on any ports. This allows the Apache daemon supporting Bricolage to be run with a minimum number of children while still allowing normal http and https service on the standard ports with a light-weight Apache daemon. See the INSTALL file (or Bric::Admin) for full details and an example installation procedure. [Michael Robinton]
Added new bric_apachectl command "single". This command will start Bricolage in single-process mode. This mode is principally useful for debugging. [Michael Robinton]
The size of the database column that stores custom field options (such as for select lists) has been changed to the TEXT PostgreSQL type, so that the number of options isn't arbitrarily limited. [Matt Vella]
The group API has been approximately 75% rewritten. The goal was to optimize its performance, since group activity proved to be a serious bottleneck to Bricolage performance. Those interested in the nitty-gritty details of the rewrite can read about them here: http://sourceforge.net/mailarchive/forum.php?thread_id=967943&forum_id=561.
Added constraint to the group table to keep a group from having itself as a parent. Thanks to João Pedro Gonçalves for the patch. [David]
Fixed bug in side navigation where an HTML table was opened but not closed. [Charles Albrecht]
Fixed bug where installation system would chown all of the chosen TEMP_DIR to SYS_USER. Thanks to Dave Rolsky for the report. [Sam]
Fixed a bug in the installation system that was creating empty comp/comp and data/data directories BRICOLAGE_ROOT. Thanks to Michael for the spot. [Sam]
Fixed remote previews to redirect to a better URL. [Mark]
Fixed a bug where trying to create a story through the SOAP interface containing a contributor with an empty middle name would fail. [Sam]
Changed strftime instances of '%G' to '%Y' in URI preference, as this seems to be more portable. [David]
Fixed bug that was preventing 'make upgrade' from running database upgrade scripts. [Sam]
Fixed broken "Log" link on Media Search results screen. [Sam]
Fixed bug where deleted output channels were showing up in list of available output channels in the element profile. [David]
Fixed conflict in list manager that prevented some lists from working properly. Probably never showed up before, as we only noticed it with the new Media Type manager. Thanks to Scott for the heads-up. [David]
The PREVIEW_MASON configuration directive no longer is no longer defaulting to on in one context and off in another. It is now off by default. Thanks to Michael Slattery for the spot! [David]
Eliminated the password field type from the formBuilder interface used for contributor types and elements. Its inclusion up to now may be considered a bug. [David]
Fixed cover date editing to repopulate correctly on the Story profile screens. [Matt]
Fixed bug where previewing a story assigned to multiple categories would preview to a random category. Now the primary category is always chosen. [Sam]
Fixed display and editing of dates more than one year in the past. [Matt]
Fixed bug where setting CHAR_SET to UTF-8 in bricolage.conf would result in blank output. [Sam]
Changed Category manager to display no categories by default, only display them after a search. This is because some folks have a lot of categories. [David]
Fixed bug where when SYS_USER and/or SYS_GROUP wasn't in bricolage.conf, Bric::Config would use the username "nobody" instead of the UID for the user "nobody". [David]
Adding a note to a story that has not yet been saved no longer causes an error. [David]
Fixed "make dist" to work on Mac OS/X and FreeBSD. [Sam]
Fixed a problem in Bric::Util::Burner::Template where a newly added template wouldn't be picked up by <tmpl_include>. This was due to caching being turned on. HTML::Template's cache doesn't know that a new compilation would turn up a difference <tmpl_include> so it continues to use the old one. [Sam]
Fixed installer to not require unneeded Apache modules (mod_proxy and mod_rewrite). [Sam]
Fixed installer to first ask whether SSL support is desired before asking for a specific SSL module. [Sam]
Fixed documentation bug in Bric::Admin concerning PostgreSQL paths. Thanks to Vicki Brown for the catch. [Sam]
Fixed installation system to fail if there are errors importing the database. Also added test for missing or empty bricolage.sql. [Sam]
Fixed installation system to support optional modules and not force users to install them. [Sam]
Fixed bug that prevented the contents of fields to be updated through Bric::SOAP. [Sam]
Fixed "Checkin and Publish" button to only appear if the user has permissions to publish. [Matt]
Fixed bug where text pasted into Bulk Edit textarea box was getting words smooshed together. Thanks to Rachel Murray for the spot. [David]
Fixed bug where date field elements weren't getting properly converted between the local time zone and UTC, which is the time zone of all the dates in the database. Thanks to Matt Vella for the spot. [David]
Fixed issue where Bric::Util::Grp was adding every member of a group whenever a new member was added. This was very wasteful, and slowed performance a great deal for groups with thousands of members. Thanks to Mark for the spot. [David]
Added check for Category "Directory" string to make sure that no non-URL characters are added. [Matt Vella]
Clicking "Cancel" when editing keywords in a new story now properly returns to the story profile, rather than to the last screen before the story was created. [David]
Deleting a a contributor immediately after adding one no longer causes all of the contributors to be deleted on check-in. [David]
Contributors are now properly reverted when stories and media are reverted. [David]
Added --chunks option to bric_republish to publish stories in batches. This is useful to avoid timing out on long runs. [Sam]
Added [Check In / Publish] button to Story Profile to checkin and publish in one step. [Matt]
Added needs_publish() method and associated published_version database field to Bric::Biz::Asset. This method is now used by the publisher to determine if something needs republishing. Added new graphics to display this information on the desks. [Matt]
Moved repeated publish and preview functionality into Bric::Util::Burner. Updated Mason code and Bric::SOAP::Workflow accordingly. [Matt]
Added DBI_PROFILE bricolage.conf option and bric_dbprof script to allow profiling of Bricolage database performance. [Sam]
Added bric_apachectl debug command to run Bricolage under the Perl debugger using Apache::DB. [Sam]
Added checks to make sure Story and Media URIs are unique within the system. [Matt]
Added search paging preference to break search results into multiple pages. [Adam]
Added support for running Bricolage under Devel::Profiler with the new PROFILE configuration option. [Sam]
Added support for Apache::SizeLimit to keep Apache process size under control. [Adam]
Revised Bric::App::Cache to improve performance. The new system is a two-level cache with Cache:Mmap and Cache::Cache. This results in a 2x speedup on some cache-sensitive operations. [Sam]
Clicking "Add More" when editing contributor contacts now retains any changes made to the contributor profile. This matches the functionality of the user profile. Thanks to João Pedro Gonçalves for the spot. [David]
Fixed bug in Bric::SOAP::Element where deleting an element or field could cause SQL errors due to overflowing the name field. [Sam]
Removed Bric::SOAP::Element->delete(force => 1) which could cause data corruption in existing stories. Also removed dependent options in bric_dev_sync (--delete-existing) and bric_soap (--force). [Sam]
Fixed bug in Bric::SOAP::Element where updating an element could cause Stories using that element to lose track of their field data. [Sam]
Fixed bug in Bric::Util::Burner::Template where <tmpl_include>s caused syntax errors. [Sam]
The Bric::Biz::Category class method get_attr() now returns attributes for category ID 0 as well as all other categories. [João Pedro Gonçalves]
Fixed bug in DBI_DEBUG and DBI_CALL_TRACE options where non-prepared queries (row_aref(), all_aref(), etc.) were not being logged. [Sam]
Fixed bug in Bric::Dist::Resource that was causing publish to run very slowly by executing a bad database query. [Sam]
Related to the last item, fixed a bug in Bric::Util::Coll that would call the href() method on a class and pass in undefined values as parameters. This will happen if a collection is created for a new object that does not yet have an ID. The fix thus prevents the "= NULL" SQL syntax, which always matches nothing. The new syntax for constructing a collection has been implemented across the API. [David]
Fixed bug where the root category wasn't able to be added to a category group. Actually, this fixes a problem where any object with an id of 0 couldn't be added to a group. Thanks to Mark for the spot. [David]
Changed mover list to be sorted in alphabetical order in the Destination profile. This has the benefit of forcing "FTP" to be listed before "File System" -- Hurray for case-sensitive ordering! Thanks to Sam for the complaint. [David]
The OS for a destination server now defaults to the OS of the server on which Bricolage is installed instead of "Mac". Thanks to Sam for the spot. [David]
Deleted destinations will now be dissociated from output channels when they're deleted. This prevents stories from being published to deleted destinations. Thanks to Mark for the heads-up. [David]
Fixed bug where attribute metadata wasn't getting deleted when it was supposed to. [João Pedro Gonçalves]
Fixed bug where some browsers submit an image button with a value stored in the image button's name as well as in the name with ".x" and ".y" appended to it. This caused callbacks to be triggered twice for a single field! I noticed this with Mozilla on Mac OS X, and presume it would happen elsewhere, too. [David]
Fixed bug in navigation bar HTML that caused the bar to disappear on certain browsers. [Rachel Murray]
Fixed bug in Bric::SOAP where Bricolage exceptions resulted in an uninformative "Application error" message. Now the full exception message is displayed. [Sam]
Fixed installation to work under Debian Linux 3.0 (testing). Thanks to Mark Jaroski for a helpful patch. [Sam]
Changed length of Bric::Dist::Job name attribute from 64 characters to 256. This allows long asset names to be used. Also added code to Bric::Dist::Job to ensure that the name property is truncated if it's longer than 256 characters. Thanks to Josh Cox for the spot. [David]
Fixed bug where dumber browsers would submit a new template without any Element selected. Thanks to Michael Robinton for reporting the bug. [David]
All stories and media are now required to be associated with a category. For stories, the primary category cannot be deleted. If you want to change the primary category, add a new category, change it to the primary, and then delete the old primary category. This fix prevents previews and publishes from breaking on stories and media that had no categories. Thanks to Mark for the heads-up. [David]
An overhaul of the burn system had regressed the Output Channel preview functionality. I've put it back now. [Mark]
Fixed button JavaScript to work correctly in Mozilla. [Matt]
Fixed bug in HTML::Template burner that prevented <tmpl_include>s from working in some cases. [Sam]
Numerous spelling errors were fixed by Scott Lanning. Thanks!
In the Element manager, doing a search after selecting an Element Type from which to display elements no longer causes an error. Thanks to Adam Robinson for the spot. [David]
Made the parent category field in the Category Profile a required field. [Mark]
Fix Bric::Util::FTP::FileHandle to work with a modified date-formatting preference. [Matt]
Fixed section numbering in the Contributor Type profile. [Scott Lanning]
Bricolage SOAP interface fully implemented. The command-line clients bric_soap, bric_dev_sync and bric_republish are all complete. [Sam]
Bricolage now comes with a configure script and a Makefile for easier installation and configuration. [Mark Jaroski]
Removed MD5 Perl module requirement by requiring Apache::Session 1.54 or higher. [David]
Added new FTP distribution move method. Now you can distribute files either via a file system copy or via FTP. [David]
Added a preference to change the way URIs are formatted. [Adam]
Added a URI case preference to force URIs to lowercase, uppercase, or allow mixed case URIs. [Adam]
Categories are now all listed and sorted by URI in select lists. [Sam]
The cache is now cleared when the Apache server is started or restarted. This avoids potential problems with stale data in the cache. [Sam]
Fixed numerous cases where user_ids were being used as booleans. Since user_id 0 is the Administrator's user_id this can cause problems. [Sam]
Fixed problem where deleting an asset would fail with the "cannot check-in non checked-out version" error. [Sam]
Fixed bug in HTML::Template burner when an element name had more than one space in it. [Sam]
Fixed bug in database that prevented element names over 32 characters from working properly. [Sam]
Fixed bug where trying to preview a story without a Preview destination and PREVIEW_LOCAL off would result in a Mason error. [Sam]
Fixed bug in Bric::SOAP::Story->create() where data element order was getting lost. Thanks to Mike Slattery for the spot. [Sam]
Fixed bug in HTML::Template burner where templates in non-root categories could not be found. Thanks to Marlon Bermas for the spot. [Sam]
Fixed Bric::Util::FTP::FileHandle to create new revisions on PUT. [Sam]
Deleting a contributor will no longer break stories with which the contributor is associated. Thanks to Rachel Murray for the spot. [David]
Invalid configuration directives in bricolage.conf will now be caught and keep Bricolage from starting. [Sam]
The view button in the element profile now works correctly. Thanks to João Pedro Gonçalves for the spot. [David]
Changed all strftime instances of '%G' to '%Y', as this seems to be more portable. [David]
Checking in a template from a template profile now performs a syntax check of the template just as saving the template does. [João Pedro Gonçalves]
Notes attached to stories and media are now once again editable from the desk and profile views if they're checked out to the current user, and only viewable otherwise. Thanks to Tracey Largay for the spot. [David]
Fixed a few poorly-named time zones in the time zone preference. More still needs to be done here, actually. [David]
Implemented the chk_syntax() method in Bric::Util::Burner::Template. [Sam]
Bricolage SOAP interface partially implemented. Bric::SOAP::Story and Bric::SOAP::Media are fully implemented and tested. The command-line client - bric_soap - is complete. [Sam]
Fixed numerous cases where user_ids were being used as booleans. Since user_id 0 is the Adminstrator's user_id this can cause problems. [Sam]
Fixed problem where deleting an asset would fail with the "cannot check-in non checked-out version" error. [Sam]
Fixed bug in HTML::Template burner when an element name had more than one space in it. [Sam]
Fixed bug in database that prevented element names over 32 characters from working properly. [Sam]
All fixes in the soon-to-be-released 1.2.1 version. See below for details.
Functionally equivalent to 1.2.2, but includes required files missing from the 1.2.2 distribution.
Added chk_syntax() methods to Bric::Util::Burner and its subclasses. This method will takes a template asset object and make sure that it compiles. Bric::Util::Burner::chk_syntax() delegates to the proper subclass.
Some misspellings were corrected in Bric::Admin. Thanks to Ask Bjoern Hansen for the spot. [David]
Fixed broken "Return" buttons on related media and related story pages. [David]
Fixed bug where assets weren't activated when they were created and then checked in without clicking the "Save" button. [David]
Fixed bug where a fixed story's slug was getting used in its URI. [David]
Fixed broken image autopopulation fields (compression, height, width, etc.) [David]
Fixed broken support for audio and video files. These can be set up by the Media Type menu in Element Types. Eventually these should arrange for some fields to be auto-populated (e.g., bit rate, frame size, length, encoding, etc.). [David]
Fixed bug where Categories with the same directory name could not be created. Thanks to Andrew Baio for the spot. [David]
Fixed a bug where a user couldn't look at her own event log if she didn't have permission. Thank to Michael Alan Dorman for the spot. [David]
Fixed a bug where permissions set to access workflows and desks had no affect on the display of workflows and desks. Thanks to Rachel Murray for the spot. [David]
Fixed bug where attempting to create a destination with the same name as an existing but deactivated destination triggered an SQL error. Thanks to Michael Alan Dorman for the spot. [David]
Fixed bug where Workflows with spaces in their names would not create proper submenus in the left navigation bar. Thanks to the WHO for the spot [David]
Fixed bug where the wrong story might be previewed when clicking the title of a story in My Workspace or on a desk. [David]
Changing the category a media asset is in now correctly updates the underlying category object and the URI without the media asset needing to be checked in. [Matt Vella]
Eliminated "Template compile failed" errors for templates with <%init> sections. [David]
Field elements now show up with their display names in the bulk edit select lists, instead of with their names (which are really keys). [David]
Eliminated "Use of uninitialized value in bitwise or (|)" warnings when checking permissions. Thanks to Sam Tregar for the spot. [David]
Custom fields in elements and contributor types now remember their "size" setting. Thanks to Sam Tregar for the spot. [David]
The Element select list on the new Template profile no longer lists media elements, since media assets don't use templates. [David]
Removed old XML::Writer stuff from Bric::Util::Burner, since I moved it to Bric::Util::Burner::Mason a while ago and it was causing some problems. Thanks to Michael Robinton for the spot. [David]
Fixed typo in Bric::Hacker spotted by Axel Beckert. [Sam]
The CREATE permission works properly now. Thanks to Rachel Murray for the spot. [David]
Created new method of configuring Bricolage in Apache. For mod_perl 1.26 and earlier, a custom config file will be written to the bricolage temp directory every time Bricolage is started or restarted. For mod_perl 1.27 and later, no temp file will be written. [David]
Added support for Mozilla (and there was much rejoicing!). [David]
Changed password for the default "admin" user to "change me now!" [David]
The slug is stored in the database for both fixed and non-fixed stories. This is in anticipation of adding the ability to use the slug for fixed story URIs later on. Thanks to Darren Graves for the patch.
Added DISABLE_NAV_LAYER directive. It's off by default, but if you turn it on in bricolage.conf, the side navigation layer will be rendered as plain HTML in every page instead of as a separate layer. [David]
Documented PERL_LOADER directive in Bric::AdvTemplates. [David]
Turned off the PREVIEW_MASON configuration directive in bricolage.conf. It should be off by default. [David]
Deleted Output Channels now properly don't show up in the Output Channel manager again. Thanks to Sara for the spot! [David]
All previews now preview assets in the primary Output Channel only. Previously, the previews were in the Output Channel whose name came first alphabetically. Thanks to Sara Wood for catching this bug. [David]
Fixed bug where templates often couldn't be found by the Mason burner if the output channel had a post_path. [David]
Fixed bug where templates often couldn't be found by the HTML::Template burner if the output channel had a post_path. [Sam]
Fixed some problems with the sideNav menus under Netscape. [David]
Fixed broken "Preview" button in Read-only story profile and in related story elements. [Matt Vella]
Updated debugging code to accommodate new syntax in Cache::Cache. Thanks to Sam Tregar for the spot. [David]
Fixed problem with Element names containing non-alphanumeric characters. [Sam]
Checking out media assets from "Find Media" now redirects you to the media profile if you've checked out one media asset, or My Workspace if you've checked out more than one. This puts it in line with how "Find Stories" and "Find Templates" work. Thanks to Sam for the report. [David]
Fixed bulk edit functionality for Media assets. Thanks to Sam for the spot. [David]
In Bric::Biz::Asset::Business, the source get_meth key in my_meths() now works properly. Also, get_all_keywords() now also returns the category keywords as well as the story keywords. Thanks to Darren Graves for the patch.
Removed quotation marks from DEF_MEDIA_TYPE setting in bricolage.conf. Thanks to Darren Graves for the spot. [David]
Sorting assets by ID in "Find X" and Workspace/Desk view now properly does a numeric sort rather than an alphanumeric sort. Thanks to Sam Tregar for the spot. [David]
Fixed an obscure bug where, for files uploaded as part of a Media file, Bricolage attempted to create a path on its own file system using path delimiters for another file system. Thanks to Mike Slattery for the spot. [David]
Required content fields in stories and elements are now displayed in the order specified in the Element profile. Thanks to Sam Tregar for the spot. [David]
All assets now start with the version number 0 until the first time they are checked in. Also, they will show up on desks and in the Find views after the first time they are saved. It was inconsistent before, and some items could not be seen in the desk and Find views until they were checked in. Thanks to Sam for spotting the inconsistency. [David]
The bric_clean_tmp script has been changed to avoid deleting the Bricolage cache file. [Sam]
Fixed typo that broke Bric::Dist::Client. [Mike Slattery]
Fixed multiple select custom fields for Elements and Contributors. Thanks to Mike Slattery for the spot. [David]
Fixed ugly bug where deleting a "Media Type" Element would delete all the media objects of that type. Thanks to Sam for the spot (though not for the bug!). [David]
Fixed bric_pgimport so that it uses DBI to drop and create the database, rather than relying on a hard-coded location for pgsql binaries. [David]
Fixed permission granting in bric_pgimport so that the Bricolage database use has DELETE permissions on all objects in the Bricolage database. It looks like this permission was ignored in PosgreSQL 7.1 and earlier, or problems would have shown up a long time ago! [David]
Fixed a bug where the time a distribution job is scheduled was not properly converted to UTC for storage in the database. Thanks to Mike Slattery for the great code archaeology! [David]
Fixed the spelling of "contributor" in several spots. [Andrew Baio]
Fixed bug where changing a story's primary category left it with no primary category. [Matt Vella]
Added Context-sensitive, online help. [Sam]
Added separate interface for editing templates (via FTP). [Sam]
Added the ability to use HTML::Template Templates. [Sam]
Added ability for different Output Channels to function as different component roots for in Mason templates. This will allow for templates that can't be found in the current Output Channel to be searched for in other Output Channels. [David]
Added link to Event log to Find Story, Find Template, and Find Media screens. [David]
Added true previewing for media assets. Now, when you click their URIs to preview them, they will be distributed to the preview server(s) before redirecting the user to them, rather than just serving them up from where they live on the Bricolage file system. The latter can still be accessed under "Download" in the Media Asset profile. This will continue to be the preferred way to grab media files for editing and such, as it will not incur the overhead of distributing the media file. [David]
Allow only one template with a given name for a given category, element, burner and output channel. [Sam]
Added a Maintainer section to the About page. [David]
Updated About page to mimic the layout of the help pages. [David]
Fixed a bug with local previews where a preview page could show up instead of the Bricolage UI. Thanks to Sara for the spot. [David]
Fixed a bug where Mason component calls failed in previews when the PREVIEW_MASON directive was enabled. [David]
Changed default value for text area fields added via the form builder (i.e., in Contributor Type and Element profiles) to 0. The values 0 and "" always make the the new field unlimited in length. [David]
Fixed a couple of buttons to be proper case rather than upper case. [David]
Separated the filesystem destinations for assets burned for publication and for assets burned for previewing. This will prevent someone previewing and stomping all over a published version of an asset before the published version is distributed. [David]
Removed hard-coding of the local preview directory in httpd.conf and httpd-ssl.conf. Now using the values stored in PREVIEW_LOCAL, instead, to determine the proper directory. [David]
Added the DEF_MEDIA_TYPE directive. Bricolage will use the value in this directive to assign a Media Type to all file resources if Bricolage can't figure it out from their file extensions. This fixes a bug where Bricolage would choke if it couldn't figure out the MediaType itself. [David]
Added "File Name" and "File Extension" properties to OutputChannels. These properties will now be used to name files burned to the file system on preview and publish. [David]
Added DEFAULT_FILENAME and DEFAULT_FILE_EXT configuration directives to set default values on the "File Name" and "File Extension" Output Channel properties. [David]
Changed Bric::Util::Burner->display_element() so that it doesn't paginate. All paginated pages are now treated instead as regular elements. This is useful for things like printer-friendly pages. Bric::Util::Burner->display_element() continues to work as before. Use this method to output a separate file for each paginated element. [David]
When errors occur while previewing stories, the leftNav is now turned off. [David]
Browser buttons and menus are now disabled. [David]
Added ability to set permissions on assets based on the categories they're in. [David]
Moved all session and session locking files into the "bricolage" subdirectory of the local file system's tmp directory. You'll want to rm -rf /tmp/bricolage_* upon upgrading. [David]
Moved the location of cache files to the "bricolage/cache" subdirectory of the local file system's tmp directory. You'll want to rm -rf /tmp/FileCache upon upgrading. Together with the above change, this means that all Bricolage temporary files are stored in the "bricolage" subdirectory of the local tmp, e.g., /tmp/bricolage. [David]
Added new program, bric_clean_tmp, that can be used in a cron job to delete stale temporary files. [Sam]
Added an "About" page, linked from the logo graphic, that explains the name "Bricolage" and offers the license and credits. [David]
Added PERL_LOADER configuration directive. Pass a line of Perl to this directive, and on startup, it'll execute it in the same namespace as your templates execute in. [David]
Added INCLUDE_XML_WRITER and XML_WRITER_ARGS configuration parameters. If INCLUDE_XML_WRITER is turned on, then all templates will include a new global, $writer, that is an XML::Writer object. This object is provided as a convenience for creating XML in your templates. XML_WRITER_ARGS allows certain arguments to be passed to the XML::Writer. [David]
Fixed bug where data fields deleted from Elements were deleting them from existing stories, too. [David]
Fixed bug where stories with related media associated with them were displaying the story as an Element rather than as a story after editing the related media. [David]
Removed all file system location dependencies for the operation of Bricolage. Bricolage will still assume that everything's in /usr/local/bricolage, but any location is fine as long as the BRICOLAGE_ROOT environment variable is set to the proper location. [David]
Added code to force all preview pages to be re-requested from the server every time they're viewed. This prevents the browser from loading older versions from its cache, and allows users to always see the most recently-burned output of a story. [David]
Removed debugging information from URLs for when debugging is turned off -- which should be always in production code (e.g., releases). [David]
Elements are now displayed with their display names rather than their attribute names. Thanks to Sam Tregar for the spot. [David]
Fixed bug where fields (attributes) added to an Element with the name of an existing but deactivated field triggered an error. Thanks to Sam for the heads-up. [David]
Fixed a bug where data fields sometimes were not properly retrieved from the database in Bric::Biz::AssetType. [David]
Fixed a bug where clicking "Save and Stay" in the Element profile wouldn't delete attributes (fields) marked as such, or even delete the Element itself, if the "Delete this profile" checkbox was checked.
Fixed a bug where, for Story and Media assets, editors were given Edit access to notes, even when they didn't have the asset checked out. [David]
Changed the misleading and inaccurate "Two blank lines" label in the Bulk Edit interface to the more accurate "One blank line". Thanks to Sam Tregar for the heads-up.
Initial public release.
David Wheeler <david@wheeler.net>