'ADMIN' ); protected $title = 'Upgrade SiteTree Permissions Schema'; protected $description = "Move data from legacy columns to new schema introduced in SilverStripe 2.1.
SiteTree->Viewers to SiteTree->CanViewType
SiteTree->Editors to SiteTree->CanEditType
SiteTree->ViewersGroup to SiteTree->ViewerGroups (has_one to many_many)
SiteTree->Editorsroup to SiteTree->EditorGroups (has_one to many_many)
See http://open.silverstripe.com/ticket/2847 "; function run($request) { // transfer values for changed column name DB::query("UPDATE SiteTree SET CanViewType = Viewers;"); DB::query("UPDATE SiteTree_Live SET CanViewType = Viewers;"); DB::query("UPDATE SiteTree_versions SET CanViewType = Viewers;"); Debug::message('Moved SiteTree->Viewers to SiteTree->CanViewType'); // transfer values for changed column name DB::query("UPDATE SiteTree SET CanEditType = Editors;"); DB::query("UPDATE SiteTree_Live SET CanEditType = Editors;"); DB::query("UPDATE SiteTree_versions SET CanEditType = Editors;"); Debug::message('Moved SiteTree->Editors to SiteTree->CanEditType'); // convert has_many to many_many $pageIDs = DB::query("SELECT ID FROM SiteTree")->column('ID'); foreach($pageIDs as $pageID) { $page = DataObject::get_by_id('Page', $pageID); if($page->ViewersGroup) $page->ViewerGroups()->add($page->ViewersGroup); if($page->EditorsGroup) $page->EditorGroups()->add($page->EditorsGroup); $page->destroy(); unset($page); } Debug::message('SiteTree->ViewersGroup to SiteTree->ViewerGroups (has_one to many_many)'); Debug::message('SiteTree->EditorsGroup to SiteTree->EditorGroups (has_one to many_many)'); } } ?>