mirror of
https://github.com/silverstripe/silverstripe-subsites
synced 2024-10-22 09:05:55 +00:00
BUG LeftAndMainSubsites::Subsites() fails with limited CMS access
Users with non-ADMIN permissions won't see the dropdown of available subsites, because LeftAndMainSubsites::Subsites() will check if the user has a non-existent code CMS_ACCESS_CMSPagesController. Fallback to checking required_permission_codes first, and failing that, check for CMS_ACCESS_LeftAndMain
This commit is contained in:
parent
69ace90bc1
commit
f35a42ec64
@ -48,23 +48,35 @@ class LeftAndMainSubsites extends Extension {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function Subsites() {
|
public function Subsites() {
|
||||||
$accessPerm = 'CMS_ACCESS_'. $this->owner->class;
|
// figure out what permission the controller needs
|
||||||
|
// Subsite::accessible_sites() expects something, so if there's no permission
|
||||||
|
// then fallback to using CMS_ACCESS_LeftAndMain.
|
||||||
|
$permission = 'CMS_ACCESS_' . $this->owner->class;
|
||||||
|
$available = Permission::get_codes(false);
|
||||||
|
if(!isset($available[$permission])) {
|
||||||
|
$permission = $this->owner->stat('required_permission_codes');
|
||||||
|
if(!$permission) {
|
||||||
|
$permission = 'CMS_ACCESS_LeftAndMain';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch($this->owner->class) {
|
switch($this->owner->class) {
|
||||||
case "AssetAdmin":
|
case "AssetAdmin":
|
||||||
$subsites = Subsite::accessible_sites($accessPerm, true, "Shared files & images");
|
$subsites = Subsite::accessible_sites($permission, true, "Shared files & images");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "SecurityAdmin":
|
case "SecurityAdmin":
|
||||||
$subsites = Subsite::accessible_sites($accessPerm, true, "Groups accessing all sites");
|
$subsites = Subsite::accessible_sites($permission, true, "Groups accessing all sites");
|
||||||
if($subsites->find('ID',0)) {
|
if($subsites->find('ID',0)) {
|
||||||
$subsites->push(new ArrayData(array('Title' => 'All groups', 'ID' => -1)));
|
$subsites->push(new ArrayData(array('Title' => 'All groups', 'ID' => -1)));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "CMSMain":
|
case "CMSMain":
|
||||||
|
case "CMSPagesController":
|
||||||
// If there's a default site then main site has no meaning
|
// If there's a default site then main site has no meaning
|
||||||
$showMainSite = !DataObject::get_one('Subsite',"\"DefaultSite\"=1");
|
$showMainSite = !DataObject::get_one('Subsite',"\"DefaultSite\"=1");
|
||||||
$subsites = Subsite::accessible_sites($accessPerm, $showMainSite);
|
$subsites = Subsite::accessible_sites($permission, $showMainSite);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "SubsiteAdmin":
|
case "SubsiteAdmin":
|
||||||
@ -72,7 +84,7 @@ class LeftAndMainSubsites extends Extension {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
$subsites = Subsite::accessible_sites($accessPerm);
|
$subsites = Subsite::accessible_sites($permission);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,7 +93,6 @@ class LeftAndMainSubsites extends Extension {
|
|||||||
|
|
||||||
public function SubsiteList() {
|
public function SubsiteList() {
|
||||||
$list = $this->Subsites();
|
$list = $this->Subsites();
|
||||||
|
|
||||||
$currentSubsiteID = Subsite::currentSubsiteID();
|
$currentSubsiteID = Subsite::currentSubsiteID();
|
||||||
|
|
||||||
if($list->Count() > 1) {
|
if($list->Count() > 1) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user