2008-11-03 16:27:25 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage tasks
|
|
|
|
*/
|
|
|
|
class UpgradeSiteTreePermissionSchemaTask extends BuildTask {
|
|
|
|
static $allowed_actions = array(
|
|
|
|
'*' => 'ADMIN'
|
|
|
|
);
|
|
|
|
|
|
|
|
protected $title = 'Upgrade SiteTree Permissions Schema';
|
|
|
|
|
|
|
|
protected $description = "Move data from legacy columns to new schema introduced in SilverStripe 2.1.<br />
|
|
|
|
SiteTree->Viewers to SiteTree->CanViewType<br />
|
|
|
|
SiteTree->Editors to SiteTree->CanEditType<br />
|
|
|
|
SiteTree->ViewersGroup to SiteTree->ViewerGroups (has_one to many_many)<br />
|
|
|
|
SiteTree->Editorsroup to SiteTree->EditorGroups (has_one to many_many)<br />
|
|
|
|
See http://open.silverstripe.com/ticket/2847
|
|
|
|
";
|
|
|
|
|
|
|
|
function run($request) {
|
|
|
|
// transfer values for changed column name
|
2008-11-10 00:58:48 +01:00
|
|
|
foreach(array('SiteTree','SiteTree_Live','SiteTree_versions') as $table) {
|
|
|
|
DB::query("UPDATE `{$table}` SET CanViewType = Viewers;");
|
|
|
|
DB::query("UPDATE `{$table}` SET CanEditType = Editors;");
|
|
|
|
}
|
|
|
|
//Debug::message('Moved SiteTree->Viewers to SiteTree->CanViewType');
|
|
|
|
//Debug::message('Moved SiteTree->Editors to SiteTree->CanEditType');
|
2008-11-03 16:27:25 +01:00
|
|
|
|
|
|
|
// convert has_many to many_many
|
|
|
|
$pageIDs = DB::query("SELECT ID FROM SiteTree")->column('ID');
|
|
|
|
foreach($pageIDs as $pageID) {
|
2008-11-10 19:59:01 +01:00
|
|
|
$page = DataObject::get_by_id('SiteTree', $pageID);
|
2008-11-18 02:28:37 +01:00
|
|
|
if($page->ViewersGroup && DataObject::get_by_id("Group", $page->ViewersGroup)) $page->ViewerGroups()->add($page->ViewersGroup);
|
|
|
|
if($page->EditorsGroup && DataObject::get_by_id("Group", $page->EditorsGroup)) $page->EditorGroups()->add($page->EditorsGroup);
|
2008-11-03 16:27:25 +01:00
|
|
|
|
|
|
|
$page->destroy();
|
|
|
|
unset($page);
|
|
|
|
}
|
2008-11-10 00:58:48 +01:00
|
|
|
//Debug::message('SiteTree->ViewersGroup to SiteTree->ViewerGroups (has_one to many_many)');
|
|
|
|
//Debug::message('SiteTree->EditorsGroup to SiteTree->EditorGroups (has_one to many_many)');
|
|
|
|
|
|
|
|
// rename legacy columns
|
|
|
|
foreach(array('SiteTree','SiteTree_Live','SiteTree_versions') as $table) {
|
|
|
|
foreach(array('Viewers','Editors','ViewersGroup','EditorsGroup') as $field) {
|
|
|
|
DB::getConn()->dontRequireField($table, $field);
|
|
|
|
}
|
|
|
|
}
|
2008-11-03 16:27:25 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|