BUGFIX Changed from implying "(all)" in group cmsfields for "limit subsite access" - if membership in a group with Group->SubsiteID = 0 implies "access all subsites", there is no distinction between explicit limitation and access to all subsites. Introduced a SUBSITE_ACCESS_ALL permission instead

This commit is contained in:
Ingo Schommer 2008-12-01 02:43:57 +00:00
parent 45798b065c
commit fd8c93be2d
3 changed files with 6 additions and 1 deletions

View File

@ -29,7 +29,7 @@ class GroupSubsites extends DataObjectDecorator {
($subsites) ? $subsites->toDropDownMap() : null,
null,
null,
'(' . _t('GroupSubsites.SECURITYACCESS_ALL', 'all', PR_MEDIUM, 'Default for dropdown selection: Group has access to all existingsubsites') . ')'
''
));
}

View File

@ -106,6 +106,8 @@ class SiteTreeSubsites extends DataObjectDecorator {
function canEdit($member = null) {
if(!$member && $member !== FALSE) $member = Member::currentUser();
if(Permission::checkMember($member, 'SUBSITE_ACCESS_ALL')) return true;
// if no subsites exist, member can edit from a subsites perspective
$allSubsites = DataObject::get('Subsite');
if(!$allSubsites) return true;

View File

@ -367,6 +367,8 @@ JS;
if(Permission::checkMember($member->ID, "ADMIN")) return true;
if(Permission::checkMember($member, "SUBSITE_ACCESS_ALL")) return true;
$SQLa_perm = Convert::raw2sql($permissionCodes);
$SQL_perms = join("','", $SQLa_perm);
$memberID = (int)$member->ID;
@ -471,6 +473,7 @@ JS;
function providePermissions() {
return array(
'SUBSITE_EDIT' => 'Edit Sub-site Details',
'SUBSITE_ACCESS_ALL' => 'Access all subsites',
);
}