mirror of
https://github.com/silverstripe/silverstripe-subsites
synced 2024-10-22 09:05:55 +00:00
Merged from branches/0.1
This commit is contained in:
parent
6037ec56e5
commit
b646a104f1
@ -13,6 +13,7 @@ Object::add_extension('LeftAndMain', 'LeftAndMainSubsites');
|
|||||||
Object::add_extension('LeftAndMain', 'ControllerSubsites');
|
Object::add_extension('LeftAndMain', 'ControllerSubsites');
|
||||||
|
|
||||||
Object::add_extension('Group', 'GroupSubsites');
|
Object::add_extension('Group', 'GroupSubsites');
|
||||||
|
Object::add_extension('Member', 'MemberSubsites');
|
||||||
Object::add_extension('File', 'FileSubsites');
|
Object::add_extension('File', 'FileSubsites');
|
||||||
|
|
||||||
// Backwards compatibility with SilverStripe 2.2
|
// Backwards compatibility with SilverStripe 2.2
|
||||||
|
@ -34,9 +34,9 @@ class FileSubsites extends DataObjectDecorator {
|
|||||||
if($sites)$fields->addFieldToTab('Root.Details', new DropdownField("SubsiteID", "Subsite", $sites->toDropdownMap('ID', 'Title', "(Public)")));
|
if($sites)$fields->addFieldToTab('Root.Details', new DropdownField("SubsiteID", "Subsite", $sites->toDropdownMap('ID', 'Title', "(Public)")));
|
||||||
}
|
}
|
||||||
|
|
||||||
if($this->owner->SubsiteID == 0&&!Permission::check('EDIT_PERMISSIONS')){
|
if($this->owner->SubsiteID == 0 && !Permission::check('EDIT_PERMISSIONS') && !Permission::check('SUBSITE_ASSETS_EDIT')){
|
||||||
$fields->removeFieldFromTab("Root", "Upload");
|
$fields->removeFieldFromTab("Root", "Upload");
|
||||||
$fields->transform(new ReadonlyTransformation());
|
$fields = $fields->transform(new ReadonlyTransformation());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,6 +64,11 @@ class FileSubsites extends DataObjectDecorator {
|
|||||||
if(!$this->owner->ID && !$this->owner->SubsiteID) $this->owner->SubsiteID = Subsite::currentSubsiteID();
|
if(!$this->owner->ID && !$this->owner->SubsiteID) $this->owner->SubsiteID = Subsite::currentSubsiteID();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onAfterUpload() {
|
||||||
|
$this->owner->SubsiteID = Subsite::currentSubsiteID();
|
||||||
|
$this->owner->write();
|
||||||
|
}
|
||||||
|
|
||||||
function alternateCanEdit() {
|
function alternateCanEdit() {
|
||||||
// Check the CMS_ACCESS_SecurityAdmin privileges on the subsite that owns this group
|
// Check the CMS_ACCESS_SecurityAdmin privileges on the subsite that owns this group
|
||||||
$subsiteID = Session::get('SubsiteID');
|
$subsiteID = Session::get('SubsiteID');
|
||||||
|
@ -8,7 +8,7 @@ class GroupSubsites extends DataObjectDecorator {
|
|||||||
|
|
||||||
function extraDBFields() {
|
function extraDBFields() {
|
||||||
// This is hard-coded to be applied to SiteTree, unfortunately
|
// This is hard-coded to be applied to SiteTree, unfortunately
|
||||||
if($this->owner->class == 'Group') {
|
if($this->owner->class == 'Group') {
|
||||||
return array(
|
return array(
|
||||||
'has_one' => array(
|
'has_one' => array(
|
||||||
'Subsite' => 'Subsite',
|
'Subsite' => 'Subsite',
|
||||||
@ -18,20 +18,35 @@ class GroupSubsites extends DataObjectDecorator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function updateCMSFields(&$fields) {
|
function updateCMSFields(&$fields) {
|
||||||
$subsites = DataObject::get('Subsite');
|
|
||||||
$tab = $fields->findOrMakeTab(
|
|
||||||
'Root.Subsites',
|
|
||||||
_t('GroupSubsites.SECURITYTABTITLE', 'Subsites')
|
|
||||||
);
|
|
||||||
$tab->push(new DropdownField(
|
|
||||||
'SubsiteID',
|
|
||||||
_t('GroupSubsites.SECURITYACCESS', 'Limit CMS access to subsites', PR_MEDIUM, 'Dropdown listing existing subsites which this group has access to'),
|
|
||||||
($subsites) ? $subsites->toDropDownMap() : null,
|
|
||||||
null,
|
|
||||||
null,
|
|
||||||
''
|
|
||||||
));
|
|
||||||
|
|
||||||
|
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) ;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -40,13 +55,13 @@ class GroupSubsites extends DataObjectDecorator {
|
|||||||
* to make it easy to distinguish in the tree-view
|
* to make it easy to distinguish in the tree-view
|
||||||
* of the security admin interface.
|
* of the security admin interface.
|
||||||
*/
|
*/
|
||||||
function alternateTreeTitle() {
|
function alternateTreeTitle() {
|
||||||
if($this->owner->SubsiteID == 0) {
|
if($this->owner->SubsiteID == 0) {
|
||||||
return $this->owner->Title . ' <i>(global group)</i>';
|
return $this->owner->Title . ' <i>(global group)</i>';
|
||||||
} else {
|
} else {
|
||||||
return $this->owner->Title; // . ' <i>(' . $this->owner->Subsite()->Title . ')</i>';
|
return $this->owner->Title; // . ' <i>(' . $this->owner->Subsite()->Title . ')</i>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update any requests to limit the results to the current site
|
* Update any requests to limit the results to the current site
|
||||||
@ -66,7 +81,7 @@ class GroupSubsites extends DataObjectDecorator {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
$query->orderby = 'SubsiteID' . ($query->orderby ? ', ' : '') . $query->orderby;
|
$query->orderby = 'SubsiteID' . ($query->orderby ? ', ' : '') . $query->orderby;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,14 +93,13 @@ class GroupSubsites extends DataObjectDecorator {
|
|||||||
// Check the CMS_ACCESS_SecurityAdmin privileges on the subsite that owns this group
|
// Check the CMS_ACCESS_SecurityAdmin privileges on the subsite that owns this group
|
||||||
$oldSubsiteID = Session::get('SubsiteID');
|
$oldSubsiteID = Session::get('SubsiteID');
|
||||||
|
|
||||||
Session::set('SubsiteID', $this->owner->SubsiteID);
|
Subsite::changeSubsite($this->owner->SubsiteID) ;
|
||||||
$access = Permission::check('CMS_ACCESS_SecurityAdmin');
|
$access = Permission::check('CMS_ACCESS_SecurityAdmin');
|
||||||
Session::set('SubsiteID', $oldSubsiteID);
|
Subsite::changeSubsite($oldSubsiteID) ;
|
||||||
|
|
||||||
return $access;
|
return $access;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a duplicate of this group and save it to another subsite.
|
* Create a duplicate of this group and save it to another subsite.
|
||||||
* The group and permissions will be duplicated, but not the members.
|
* The group and permissions will be duplicated, but not the members.
|
||||||
|
@ -78,6 +78,9 @@ class LeftAndMainSubsites extends Extension {
|
|||||||
$mainSiteTitle = "Main site";
|
$mainSiteTitle = "Main site";
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
$mainSiteTitle = "Main site";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($mainSiteTitle && Subsite::hasMainSitePermission(Member::currentUser(), array('CMS_ACCESS_' . $this->owner->class, 'ADMIN')))
|
if($mainSiteTitle && Subsite::hasMainSitePermission(Member::currentUser(), array('CMS_ACCESS_' . $this->owner->class, 'ADMIN')))
|
||||||
|
20
code/MemberSubsites.php
Normal file
20
code/MemberSubsites.php
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Extension for the Group object to add subsites support
|
||||||
|
*
|
||||||
|
* @package subsites
|
||||||
|
*/
|
||||||
|
class MemberSubsites extends DataObjectDecorator {
|
||||||
|
|
||||||
|
/* Only allow adding to groups we can edit */
|
||||||
|
public function saveGroups( $groups ) {
|
||||||
|
$groups = explode( ',', $groups ) ;
|
||||||
|
$filtered = array() ;
|
||||||
|
foreach( $groups as $groupID ) {
|
||||||
|
$group = DataObject::get_by_id('Group', $groupID) ;
|
||||||
|
if ( $group && $group->canEdit() ) $filtered[] = $groupID ;
|
||||||
|
}
|
||||||
|
$this->owner->Groups()->setByIDList( $filtered ) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -282,6 +282,10 @@ JS;
|
|||||||
else $subsiteID = $subsite;
|
else $subsiteID = $subsite;
|
||||||
|
|
||||||
Session::set('SubsiteID', $subsiteID);
|
Session::set('SubsiteID', $subsiteID);
|
||||||
|
|
||||||
|
// And clear caches
|
||||||
|
self::$cached_subsite = NULL ;
|
||||||
|
Permission::flush_permission_cache() ;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -361,7 +365,7 @@ JS;
|
|||||||
} else {
|
} else {
|
||||||
return DataObject::get(
|
return DataObject::get(
|
||||||
'Subsite',
|
'Subsite',
|
||||||
"`MemberID` = {$member->ID}",
|
"`MemberID` = {$member->ID}",
|
||||||
'',
|
'',
|
||||||
"LEFT JOIN `Group` ON `Subsite`.`ID` = `SubsiteID`
|
"LEFT JOIN `Group` ON `Subsite`.`ID` = `SubsiteID`
|
||||||
LEFT JOIN `Group_Members` ON `Group`.`ID` = `Group_Members`.`GroupID`"
|
LEFT JOIN `Group_Members` ON `Group`.`ID` = `Group_Members`.`GroupID`"
|
||||||
@ -491,6 +495,7 @@ JS;
|
|||||||
return array(
|
return array(
|
||||||
'SUBSITE_EDIT' => 'Edit Sub-site Details',
|
'SUBSITE_EDIT' => 'Edit Sub-site Details',
|
||||||
'SUBSITE_ACCESS_ALL' => 'Access all subsites',
|
'SUBSITE_ACCESS_ALL' => 'Access all subsites',
|
||||||
|
'SUBSITE_ASSETS_EDIT' => 'Edit Sub-site Assets Admin'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -540,7 +545,7 @@ class Subsite_Template extends Subsite {
|
|||||||
while(count($stack) > 0) {
|
while(count($stack) > 0) {
|
||||||
list($sourceParentID, $destParentID) = array_pop($stack);
|
list($sourceParentID, $destParentID) = array_pop($stack);
|
||||||
|
|
||||||
$children = Versioned::get_by_stage('Page', 'Live', "`ParentID`=$sourceParentID", '');
|
$children = Versioned::get_by_stage('SiteTree', 'Live', "`ParentID`=$sourceParentID", '');
|
||||||
|
|
||||||
if($children) {
|
if($children) {
|
||||||
foreach($children as $child) {
|
foreach($children as $child) {
|
||||||
|
@ -79,7 +79,7 @@ class SubsiteAdmin extends GenericDataAdmin {
|
|||||||
'subsite' => 'New site',
|
'subsite' => 'New site',
|
||||||
'template' => 'New template',
|
'template' => 'New template',
|
||||||
)),
|
)),
|
||||||
new DropdownField('TemplateID', 'Use template:', $templateArray)//,
|
new DropdownField('TemplateID', 'Copy structure from:', $templateArray)//,
|
||||||
/*new TextField('AdminName', 'Admin name:'),
|
/*new TextField('AdminName', 'Admin name:'),
|
||||||
new EmailField('AdminEmail', 'Admin email:')*/
|
new EmailField('AdminEmail', 'Admin email:')*/
|
||||||
),
|
),
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
<div id="LeftPane">
|
<div id="LeftPane">
|
||||||
<h2>Create Intranet</h2>
|
<h2>Create Sub-site</h2>
|
||||||
<div id="AddIntranetForm_holder" style="overflow:auto">
|
<div id="AddIntranetForm_holder" style="overflow:auto">
|
||||||
$AddSubsiteForm
|
$AddSubsiteForm
|
||||||
</div>
|
</div>
|
||||||
<h2>Search for Intranets</h2>
|
<h2>Search for Sub-sites</h2>
|
||||||
<div id="Search_holder" style="overflow: auto;">
|
<div id="Search_holder" style="overflow: auto;">
|
||||||
<div id="SearchForm_holder" style="overflow:auto">
|
<div id="SearchForm_holder" style="overflow:auto">
|
||||||
$SearchForm
|
$SearchForm
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?
|
<?php
|
||||||
|
|
||||||
class SubsiteAdminTest extends SapphireTest {
|
class SubsiteAdminTest extends SapphireTest {
|
||||||
static $fixture_file = 'subsites/tests/SubsiteTest.yml';
|
static $fixture_file = 'subsites/tests/SubsiteTest.yml';
|
||||||
@ -99,7 +99,7 @@ class SubsiteAdminTest extends SapphireTest {
|
|||||||
*/
|
*/
|
||||||
function testMainsiteAdminCanAccessAllSubsites() {
|
function testMainsiteAdminCanAccessAllSubsites() {
|
||||||
$member = $this->objFromFixture('Member', 'admin');
|
$member = $this->objFromFixture('Member', 'admin');
|
||||||
$member->logIn();
|
Session::set("loggedInAs", $member->ID);
|
||||||
|
|
||||||
$cmsMain = new CMSMain();
|
$cmsMain = new CMSMain();
|
||||||
foreach($cmsMain->Subsites() as $subsite) {
|
foreach($cmsMain->Subsites() as $subsite) {
|
||||||
|
@ -43,7 +43,7 @@ class SubsiteTest extends SapphireTest {
|
|||||||
$this->assertEquals($siteHome->MasterPageID, $tmplHome->ID);
|
$this->assertEquals($siteHome->MasterPageID, $tmplHome->ID);
|
||||||
|
|
||||||
// Check linking of child pages
|
// Check linking of child pages
|
||||||
$tmplStaff = $this->objFromFixture('Page','staff');
|
$tmplStaff = $this->objFromFixture('SiteTree','staff');
|
||||||
$siteStaff = DataObject::get_one('SiteTree', "URLSegment = '" . Convert::raw2sql($tmplStaff->URLSegment) . "'");
|
$siteStaff = DataObject::get_one('SiteTree', "URLSegment = '" . Convert::raw2sql($tmplStaff->URLSegment) . "'");
|
||||||
$this->assertEquals($siteStaff->MasterPageID, $tmplStaff->ID);
|
$this->assertEquals($siteStaff->MasterPageID, $tmplStaff->ID);
|
||||||
|
|
||||||
@ -77,33 +77,37 @@ class SubsiteTest extends SapphireTest {
|
|||||||
$admin = $this->objFromFixture('Member', 'admin');
|
$admin = $this->objFromFixture('Member', 'admin');
|
||||||
$subsite1member = $this->objFromFixture('Member', 'subsite1member');
|
$subsite1member = $this->objFromFixture('Member', 'subsite1member');
|
||||||
$subsite2member = $this->objFromFixture('Member', 'subsite2member');
|
$subsite2member = $this->objFromFixture('Member', 'subsite2member');
|
||||||
$mainpage = $this->objFromFixture('Page', 'home');
|
$mainpage = $this->objFromFixture('SiteTree', 'home');
|
||||||
$subsite1page = $this->objFromFixture('Page', 'subsite1_home');
|
$subsite1page = $this->objFromFixture('SiteTree', 'subsite1_home');
|
||||||
$subsite2page = $this->objFromFixture('Page', 'subsite2_home');
|
$subsite2page = $this->objFromFixture('SiteTree', 'subsite2_home');
|
||||||
$subsite1 = $this->objFromFixture('Subsite_Template', 'subsite1');
|
$subsite1 = $this->objFromFixture('Subsite_Template', 'subsite1');
|
||||||
$subsite2 = $this->objFromFixture('Subsite_Template', 'subsite2');
|
$subsite2 = $this->objFromFixture('Subsite_Template', 'subsite2');
|
||||||
|
|
||||||
|
Session::set("loggedInAs", $admin->ID);
|
||||||
$this->assertTrue(
|
$this->assertTrue(
|
||||||
$subsite1page->canEdit($admin),
|
(bool)$subsite1page->canEdit(),
|
||||||
'Administrators can edit all subsites'
|
'Administrators can edit all subsites'
|
||||||
);
|
);
|
||||||
|
|
||||||
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
||||||
Subsite::changeSubsite($subsite1);
|
Subsite::changeSubsite($subsite1);
|
||||||
|
|
||||||
|
Session::set("loggedInAs", $subsite1member->ID);
|
||||||
$this->assertTrue(
|
$this->assertTrue(
|
||||||
$subsite1page->canEdit($subsite1member),
|
(bool)$subsite1page->canEdit(),
|
||||||
'Members can edit pages on a subsite if they are in a group belonging to this subsite'
|
'Members can edit pages on a subsite if they are in a group belonging to this subsite'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Session::set("loggedInAs", $subsite2member->ID);
|
||||||
$this->assertFalse(
|
$this->assertFalse(
|
||||||
$subsite1page->canEdit($subsite2member),
|
(bool)$subsite1page->canEdit(),
|
||||||
'Members cant edit pages on a subsite if they are not in a group belonging to this subsite'
|
'Members cant edit pages on a subsite if they are not in a group belonging to this subsite'
|
||||||
);
|
);
|
||||||
|
|
||||||
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
// @todo: Workaround because GroupSubsites->augmentSQL() is relying on session state
|
||||||
Subsite::changeSubsite($subsite2);
|
Subsite::changeSubsite($subsite2);
|
||||||
$this->assertFalse(
|
$this->assertFalse(
|
||||||
$mainpage->canEdit($subsite2member),
|
$mainpage->canEdit(),
|
||||||
'Members cant edit pages on the main site if they are not in a group allowing this'
|
'Members cant edit pages on the main site if they are not in a group allowing this'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ Subsite_Template:
|
|||||||
subsite2:
|
subsite2:
|
||||||
Title: Subsite2 Template
|
Title: Subsite2 Template
|
||||||
Subdomain: subsite2
|
Subdomain: subsite2
|
||||||
Page:
|
SiteTree:
|
||||||
home:
|
home:
|
||||||
Title: Home
|
Title: Home
|
||||||
SubsiteID: =>Subsite_Template.main
|
SubsiteID: =>Subsite_Template.main
|
||||||
@ -17,7 +17,7 @@ Page:
|
|||||||
SubsiteID: =>Subsite_Template.main
|
SubsiteID: =>Subsite_Template.main
|
||||||
staff:
|
staff:
|
||||||
Title: Staff
|
Title: Staff
|
||||||
ParentID: =>Page.about
|
ParentID: =>SiteTree.about
|
||||||
SubsiteID: =>Subsite_Template.main
|
SubsiteID: =>Subsite_Template.main
|
||||||
contact:
|
contact:
|
||||||
Title: Contact Us
|
Title: Contact Us
|
||||||
@ -34,28 +34,28 @@ Page:
|
|||||||
subsite2_contactus:
|
subsite2_contactus:
|
||||||
Title: Contact Us (Subsite 2)
|
Title: Contact Us (Subsite 2)
|
||||||
SubsiteID: =>Subsite_Template.subsite2
|
SubsiteID: =>Subsite_Template.subsite2
|
||||||
Permission:
|
|
||||||
admin:
|
|
||||||
Code: ADMIN
|
|
||||||
accesscmsmain1:
|
|
||||||
Code: CMS_ACCESS_CMSMain
|
|
||||||
accesscmsmain2:
|
|
||||||
Code: CMS_ACCESS_CMSMain
|
|
||||||
Group:
|
Group:
|
||||||
admin:
|
admin:
|
||||||
Title: Admin
|
Title: Admin
|
||||||
Code: admin
|
Code: admin
|
||||||
Permissions: =>Permission.admin
|
|
||||||
subsite1_group:
|
subsite1_group:
|
||||||
Title: subsite1_group
|
Title: subsite1_group
|
||||||
Code: subsite1_group
|
Code: subsite1_group
|
||||||
Subsite: =>Subsite_Template.subsite1
|
SubsiteID: =>Subsite_Template.subsite1
|
||||||
Permissions: =>Permission.accesscmsmain1
|
|
||||||
subsite2_group:
|
subsite2_group:
|
||||||
Title: subsite2_group
|
Title: subsite2_group
|
||||||
Code: subsite2_group
|
Code: subsite2_group
|
||||||
Subsite: =>Subsite_Template.subsite2
|
SubsiteID: =>Subsite_Template.subsite2
|
||||||
Permissions: =>Permission.accesscmsmain2
|
Permission:
|
||||||
|
admin:
|
||||||
|
Code: ADMIN
|
||||||
|
GroupID: =>Group.admin
|
||||||
|
accesscmsmain1:
|
||||||
|
Code: CMS_ACCESS_CMSMain
|
||||||
|
GroupID: =>Group.subsite1_group
|
||||||
|
accesscmsmain2:
|
||||||
|
Code: CMS_ACCESS_CMSMain
|
||||||
|
GroupID: =>Group.subsite2_group
|
||||||
Member:
|
Member:
|
||||||
admin:
|
admin:
|
||||||
FirstName: Admin
|
FirstName: Admin
|
||||||
|
Loading…
x
Reference in New Issue
Block a user