Merged in Markus' changes from [37478].

Tidied up the permission checks in SiteTree->can() so they are easier to follow.

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@39189 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Hayden Smith 2007-07-24 03:43:21 +00:00
parent 940fc3fc65
commit b785d359fa
2 changed files with 119 additions and 12 deletions

View File

@ -39,7 +39,7 @@ class ContentController extends Controller {
if($action == "index") $action = ""; if($action == "index") $action = "";
// '&' in a URL is apparently naughty // '&' in a URL is apparently naughty
$action = preg_replace( '/&/', '&', $action ); $action = preg_replace('/&/', '&', $action);
return $this->URLSegment . "/$action"; return $this->URLSegment . "/$action";
}else{ }else{
user_error("ContentController::RelativeLink() No URLSegment given on a '$this->class' object. Perhaps you should overload it?", E_USER_WARNING); user_error("ContentController::RelativeLink() No URLSegment given on a '$this->class' object. Perhaps you should overload it?", E_USER_WARNING);
@ -48,7 +48,7 @@ class ContentController extends Controller {
//if($action == "index") $action = ""; //if($action == "index") $action = "";
// '&' in a URL is apparently naughty // '&' in a URL is apparently naughty
// $action = preg_replace( '/&/', '&', $action ); // $action = preg_replace('/&/', '&', $action);
//return $this->URLSegment . "/$action"; //return $this->URLSegment . "/$action";
} }
@ -126,16 +126,31 @@ class ContentController extends Controller {
*/ */
public function getMenu($level) { public function getMenu($level) {
if($level == 1) { if($level == 1) {
return DataObject::get("SiteTree", "ShowInMenus = 1 AND ParentID = 0"); $result = DataObject::get("SiteTree", "ShowInMenus = 1 AND ParentID = 0");
} else { } else {
$parent = $this->data(); $parent = $this->data();
$stack = array($parent); $stack = array($parent);
while($parent = $parent->Parent) array_unshift($stack, $parent); while($parent = $parent->Parent)
array_unshift($stack, $parent);
if(isset($stack[$level-2])) if(isset($stack[$level-2]))
return $stack[$level-2]->Children(); $result = $stack[$level-2]->Children();
} }
$visible = array();
// Remove all entries the can not be viewed by the current user
// We might need to create a show in menu permission
if($result) {
foreach($result as $page) {
if($page->can('view')) {
$visible[] = $page;
}
}
}
return new DataObjectSet($visible);
} }
/** /**
* Returns the page in the current page stack of the given level. * Returns the page in the current page stack of the given level.
@ -389,4 +404,6 @@ HTML
); );
} }
} }
?> ?>

View File

@ -256,8 +256,51 @@ class SiteTree extends DataObject {
} }
/** /**
* This function should return true if the current user can add children to this page. * Returns true if the member is allowed to do the given action.
* It can be overloaded to customise the security model for an application. *
* @param string $perm The permission to be checked, such as 'View'.
* @param Member $member The member whose permissions need checking.
* Defaults to the currently logged in user.
*
* @return boolean True if the the member is allowed to do the given
* action.
*
* @todo Check we get a endless recursion if we use parent::can()
*/
function can($perm, $member = null) {
if(!isset($member)) {
$member = Member::currentUser();
}
// Users with ADMIN permission can always do this
if($member && Permission::check('ADMIN')) {
return true;
}
switch(strtolower($perm)) {
case 'edit':
if($this->Editors == 'LoggedInUsers' && $member) return true;
if($member && $this->Editors == 'OnlyTheseUsers' && $member->isInGroup($this->EditorsGroup)) return true;
break;
case 'view':
case 'view_page':
if($this->Viewers == 'Anyone') return true;
if($member && $this->Viewers == 'LoggedInUsers') return true;
if($member && $this->Viewers == 'OnlyTheseUsers' && $member->isInGroup($this->ViewersGroup)) return true;
break;
}
return false;
}
/**
* This function should return true if the current user can add children
* to this page.
*
* It can be overloaded to customise the security model for an
* application.
*
* @return boolean True if the current user can add children. * @return boolean True if the current user can add children.
*/ */
public function canAddChildren() { public function canAddChildren() {
@ -288,7 +331,7 @@ class SiteTree extends DataObject {
* @return boolean True if the current user can edit this page. * @return boolean True if the current user can edit this page.
*/ */
public function canEdit() { public function canEdit() {
return true; return $this->can('Edit');
} }
/** /**
@ -503,6 +546,26 @@ class SiteTree extends DataObject {
//------------------------------------------------------------------------------------// //------------------------------------------------------------------------------------//
/**
* Holds callback functions to be called when getCMSFields() is called
*
* @var array
*/
static $cms_additions = array();
/**
* Allows modules to extend the cms editing form for all pages in the site
*
* @param mixed $function the name of your function, either as a string,
* or in the form array('class','function)
*/
static function ExtendCMS($function)
{
self::$cms_additions[] = $function;
}
/** /**
* Returns a FieldSet with which to create the CMS editing form. * Returns a FieldSet with which to create the CMS editing form.
* You can override this in your child classes to add extra fields - first * You can override this in your child classes to add extra fields - first
@ -512,6 +575,7 @@ class SiteTree extends DataObject {
*/ */
function getCMSFields() { function getCMSFields() {
require_once("forms/Form.php"); require_once("forms/Form.php");
Requirements::javascript("cms/javascript/SitetreeAccess.js");
// Backlink report // Backlink report
if($this->hasMethod('BackLinkTracking')) { if($this->hasMethod('BackLinkTracking')) {
@ -613,11 +677,29 @@ class SiteTree extends DataObject {
new Tab("BackLinks", new Tab("BackLinks",
new LiteralField("Backlinks", $backlinks) new LiteralField("Backlinks", $backlinks)
) )
),
new Tab("Access",
new HeaderField("Who can display this?", 2),
new OptionsetField("Viewers", "",
array("Anyone" => "Anyone",
"LoggedInUsers" => "Logged-in users",
"OnlyTheseUsers" => "Only these people (choose from list)")),
new DropdownField("ViewersGroup", "Group", Group::map()),
new HeaderField("Who can edit this?", 2),
new OptionsetField("Editors", "",
array("LoggedInUsers" => "Logged-in users",
"OnlyTheseUsers" => "Only these people (choose from list)")),
new DropdownField("EditorsGroup", "Group", Group::map())
) )
), ),
new NamedLabelField("Status", $message, "pageStatusMessage", true) new NamedLabelField("Status", $message, "pageStatusMessage", true)
); );
foreach(self::$cms_additions as $extension)
{
$fields = call_user_func($extension,$fields);
}
return $fields; return $fields;
} }
@ -634,9 +716,11 @@ class SiteTree extends DataObject {
if($this->isPublished() && $this->canEdit()) { if($this->isPublished() && $this->canEdit()) {
$actions[] = FormAction::create('rollback', 'Cancel draft changes')->describe("Delete your draft and revert to the currently published page"); $actions[] = FormAction::create('rollback', 'Cancel draft changes')->describe("Delete your draft and revert to the currently published page");
} }
if(!$this->isNew() && $this->canPublish()) $actions[] = new FormAction('publish', 'Publish');
} }
if($this->canPublish())
$actions[] = new FormAction('publish', 'Save & Publish');
return new DataObjectSet($actions); return new DataObjectSet($actions);
} }
@ -890,7 +974,11 @@ class SiteTree extends DataObject {
"HasBrokenFile" => "Boolean", "HasBrokenFile" => "Boolean",
"HasBrokenLink" => "Boolean", "HasBrokenLink" => "Boolean",
"Status" => "Varchar", "Status" => "Varchar",
"ReportClass" => "Varchar" "ReportClass" => "Varchar",
"Viewers" => "Enum('Anyone, LoggedInUsers, OnlyTheseUsers', 'Anyone')",
"Editors" => "Enum('LoggedInUsers, OnlyTheseUsers', 'LoggedInUsers')",
"ViewersGroup" => "Int",
"EditorsGroup" => "Int"
); );
static $indexes = array( static $indexes = array(
@ -926,7 +1014,9 @@ class SiteTree extends DataObject {
"ShowInMenus" => 1, "ShowInMenus" => 1,
"ShowInSearch" => 1, "ShowInSearch" => 1,
"Status" => "New page", "Status" => "New page",
"CanCreateChildren" => array(10) "CanCreateChildren" => array(10),
"Viewers" => "Anyone",
"Editors" => "LoggedInUsers"
); );
static $has_one = array( static $has_one = array(