Title : null; } public function changesubsite() { $id = $_REQUEST['SubsiteID']; Subsite::changeSubsite($id); if(Director::is_ajax()) { $tree = $this->owner->SiteTreeAsUL(); $tree = ereg_replace('^[ \t\r\n]*]*>','', $tree); $tree = ereg_replace(']*>[ \t\r\n]*$','', $tree); return $tree; } else return array(); } public function Subsites() { $siteList = new DataObjectSet(); $subsites = Subsite::accessible_sites('CMS_ACCESS_' . $this->owner->class); if(defined('DB::USE_ANSI_SQL')) $q="\""; else $q='`'; $mainSiteTitle = null; switch($this->owner->class) { case "AssetAdmin": $mainSiteTitle = "Shared files & images"; break; case "SecurityAdmin": $mainSiteTitle = "Groups accessing all sites"; break; case "CMSMain": // If there's a default site then main site has no meaning if(!DataObject::get_one('Subsite', "{$q}DefaultSite{$q} = 1 AND {$q}IsPublic{$q} = 1")) { $mainSiteTitle = "Main site"; } break; default: $mainSiteTitle = "Main site"; break; } if($mainSiteTitle && Subsite::hasMainSitePermission(Member::currentUser(), array('CMS_ACCESS_' . $this->owner->class, 'ADMIN'))) $siteList->push(new ArrayData(array('Title' => $mainSiteTitle, 'ID' => 0))); if($subsites) $siteList->merge($subsites); return $siteList; } public function SubsiteList() { $list = $this->Subsites(); if(Controller::curr()->hasMethod('getRequest')) $requestSubsiteID = Controller::curr()->getRequest()->getVar('SubsiteID'); else $requestSubsiteID = isset($_REQUEST['SubsiteID']) ? $_REQUEST['SubsiteID'] : null; $currentSubsiteID = ($requestSubsiteID) ? $requestSubsiteID : Session::get('SubsiteID'); if($list->Count() > 1) { $output = ''; return $output; } else if($list->Count() == 1) { return $list->First()->Title; } } public function CanAddSubsites() { return Permission::check("ADMIN", "any", null, "all"); } /** * Alternative security checker for LeftAndMain. * If security isn't found, then it will switch to a subsite where we do have access. */ public function alternateAccessCheck() { $className = $this->owner->class; if($result = Permission::check("CMS_ACCESS_$className")) { return $result; } else { $otherSites = Subsite::accessible_sites("CMS_ACCESS_$className"); if($otherSites && $otherSites->TotalItems() > 0) { $otherSites->First()->activate(); return Permission::check("CMS_ACCESS_$className"); } } return null; } function augmentNewSiteTreeItem(&$item) { $item->SubsiteID = Subsite::currentSubsiteID(); } function onAfterSave($record) { if($record->hasMethod('NormalRelated') && ($record->NormalRelated() || $record->ReverseRelated())) { FormResponse::status_message('Saved, please update related pages.', 'good'); } } } ?>