2007-08-16 08:38:29 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Extension for the Group object to add subsites support
|
2009-05-04 07:03:44 +02:00
|
|
|
*
|
2008-11-24 04:22:01 +01:00
|
|
|
* @package subsites
|
2007-08-16 08:38:29 +02:00
|
|
|
*/
|
|
|
|
class GroupSubsites extends DataObjectDecorator {
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2007-08-16 08:38:29 +02:00
|
|
|
function extraDBFields() {
|
|
|
|
// This is hard-coded to be applied to SiteTree, unfortunately
|
2009-05-04 07:03:44 +02:00
|
|
|
if($this->owner->class == 'Group') {
|
2007-08-16 08:38:29 +02:00
|
|
|
return array(
|
|
|
|
'has_one' => array(
|
|
|
|
'Subsite' => 'Subsite',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2008-11-24 05:04:55 +01:00
|
|
|
function updateCMSFields(&$fields) {
|
|
|
|
|
2009-05-04 07:03:44 +02:00
|
|
|
if( $this->owner->SubsiteID == 0 || $this->owner->canEdit() ){
|
|
|
|
$subsites = DataObject::get('Subsite');
|
|
|
|
if ( $subsites && $subsites->exists() ) {
|
|
|
|
$oldSubsiteID = Session::get('SubsiteID');
|
|
|
|
foreach( $subsites as $subsite ) {
|
|
|
|
Subsite::changeSubsite($subsite->ID);
|
|
|
|
if ( !Permission::check('CL_Admin') ) { $subsites->remove( $subsite ) ; }
|
|
|
|
}
|
|
|
|
Subsite::changeSubsite($oldSubsiteID);
|
|
|
|
|
|
|
|
$tab = $fields->findOrMakeTab(
|
|
|
|
'Root.Subsites',
|
|
|
|
_t('GroupSubsites.SECURITYTABTITLE', 'Subsites')
|
|
|
|
);
|
|
|
|
|
|
|
|
$dropdown = new DropdownField(
|
|
|
|
'SubsiteID',
|
|
|
|
_t('GroupSubsites.SECURITYACCESS', 'Limit CMS access to subsites', PR_MEDIUM, 'Dropdown listing existing subsites which this group has access to'),
|
|
|
|
$subsites->toDropDownMap(),
|
|
|
|
null,
|
|
|
|
null,
|
|
|
|
''
|
|
|
|
);
|
|
|
|
if ( $subsites->Count() == 1 ) $dropdown = $dropdown->transform(new ReadonlyTransformation()) ;
|
|
|
|
|
|
|
|
$tab->push($dropdown) ;
|
|
|
|
}
|
|
|
|
}
|
2008-11-24 05:04:55 +01:00
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2008-11-24 07:37:22 +01:00
|
|
|
/**
|
|
|
|
* If this group belongs to a subsite,
|
|
|
|
* append the subsites title to the group title
|
|
|
|
* to make it easy to distinguish in the tree-view
|
|
|
|
* of the security admin interface.
|
|
|
|
*/
|
2009-05-04 07:03:44 +02:00
|
|
|
function alternateTreeTitle() {
|
|
|
|
if($this->owner->SubsiteID == 0) {
|
2009-02-24 23:09:15 +01:00
|
|
|
return $this->owner->Title . ' <i>(global group)</i>';
|
2008-11-24 05:58:42 +01:00
|
|
|
} else {
|
2009-02-24 23:09:15 +01:00
|
|
|
return $this->owner->Title; // . ' <i>(' . $this->owner->Subsite()->Title . ')</i>';
|
2008-11-24 05:58:42 +01:00
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
}
|
|
|
|
|
2007-08-16 08:38:29 +02:00
|
|
|
/**
|
|
|
|
* Update any requests to limit the results to the current site
|
|
|
|
*/
|
|
|
|
function augmentSQL(SQLQuery &$query) {
|
2008-08-21 07:50:38 +02:00
|
|
|
if(Subsite::$disable_subsite_filter) return;
|
|
|
|
|
2007-08-31 02:29:25 +02:00
|
|
|
// If you're querying by ID, ignore the sub-site - this is a bit ugly...
|
2009-03-09 10:24:35 +01:00
|
|
|
if(!$query->where || (strpos($query->where[0], ".\"ID\" = ") === false && strpos($query->where[0], ".`ID` = ") === false && strpos($query->where[0], ".ID = ") === false)) {
|
2007-08-31 02:29:25 +02:00
|
|
|
|
|
|
|
if($context = DataObject::context_obj()) $subsiteID = (int)$context->SubsiteID;
|
|
|
|
else $subsiteID = (int)Subsite::currentSubsiteID();
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2007-08-31 02:29:25 +02:00
|
|
|
// The foreach is an ugly way of getting the first key :-)
|
|
|
|
foreach($query->from as $tableName => $info) {
|
|
|
|
$query->where[] = "`$tableName`.SubsiteID IN (0, $subsiteID)";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2009-05-04 07:03:44 +02:00
|
|
|
$query->orderby = 'SubsiteID' . ($query->orderby ? ', ' : '') . $query->orderby;
|
2007-08-16 08:38:29 +02:00
|
|
|
}
|
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2007-08-16 08:38:29 +02:00
|
|
|
function augmentBeforeWrite() {
|
2007-08-31 02:29:25 +02:00
|
|
|
if(!is_numeric($this->owner->ID) && !$this->owner->SubsiteID) $this->owner->SubsiteID = Subsite::currentSubsiteID();
|
2007-08-16 08:38:29 +02:00
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2007-11-27 05:46:27 +01:00
|
|
|
function alternateCanEdit() {
|
|
|
|
// Check the CMS_ACCESS_SecurityAdmin privileges on the subsite that owns this group
|
|
|
|
$oldSubsiteID = Session::get('SubsiteID');
|
|
|
|
|
2009-05-04 07:03:44 +02:00
|
|
|
Subsite::changeSubsite($this->owner->SubsiteID) ;
|
2007-11-27 05:46:27 +01:00
|
|
|
$access = Permission::check('CMS_ACCESS_SecurityAdmin');
|
2009-05-04 07:03:44 +02:00
|
|
|
Subsite::changeSubsite($oldSubsiteID) ;
|
|
|
|
|
2007-11-27 05:46:27 +01:00
|
|
|
return $access;
|
|
|
|
}
|
2009-02-24 23:09:15 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a duplicate of this group and save it to another subsite.
|
|
|
|
* The group and permissions will be duplicated, but not the members.
|
|
|
|
* @param $subsiteID int|Subsite The Subsite to copy to, or its ID
|
|
|
|
*/
|
|
|
|
public function duplicateToSubsite($subsiteID = null) {
|
|
|
|
if(is_object($subsiteID)) {
|
|
|
|
$subsite = $subsiteID;
|
|
|
|
$subsiteID = $subsite->ID;
|
|
|
|
} else {
|
|
|
|
$subsite = DataObject::get_by_id('Subsite', $subsiteID);
|
|
|
|
}
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2009-02-24 23:09:15 +01:00
|
|
|
$group = $this->owner->duplicate(false);
|
|
|
|
|
|
|
|
$subsiteID = ($subsiteID ? $subsiteID : Subsite::currentSubsiteID());
|
|
|
|
$group->SubsiteID = $subsiteID;
|
|
|
|
$group->write();
|
2009-05-04 07:03:44 +02:00
|
|
|
|
2009-02-24 23:09:15 +01:00
|
|
|
// Duplicate permissions
|
|
|
|
$permissions = $this->owner->Permissions();
|
|
|
|
foreach($permissions as $permission) {
|
|
|
|
$newPerm = $permission->duplicate(false);
|
|
|
|
$newPerm->GroupID = $group->ID;
|
|
|
|
$newPerm->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $group;
|
|
|
|
}
|
|
|
|
|
2007-08-16 08:38:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
?>
|