mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
fixing doArchive
for users who can delete, but not unpublish, they should be able to delete draft pages that they’ve created. Old code used to unpublish even if the page wasn’t published, which meant users who couldn’t publish, also could delete draft pages. They could create draft pages, but not delete them.
This commit is contained in:
parent
48a3152ee2
commit
1ff6f3f1b0
@ -2541,21 +2541,27 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes the page from both live and stage
|
* Removes the page from both live and stage, if it exists on both
|
||||||
|
* otherwise just removes from stage
|
||||||
*
|
*
|
||||||
* @return bool Success
|
* @return bool Success
|
||||||
*/
|
*/
|
||||||
public function doArchive() {
|
public function doArchive() {
|
||||||
$this->invokeWithExtensions('onBeforeArchive', $this);
|
$this->invokeWithExtensions('onBeforeArchive', $this);
|
||||||
|
$doDelete = false;
|
||||||
|
|
||||||
if($this->doUnpublish()) {
|
if($this->ExistsOnLive) {
|
||||||
$this->delete();
|
$doDelete = $this->doUnpublish();
|
||||||
$this->invokeWithExtensions('onAfterArchive', $this);
|
} else {
|
||||||
|
$doDelete = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
if ($doDelete) {
|
||||||
|
$this->delete();
|
||||||
|
$this->invokeWithExtensions('onAfterArchive', $this);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $doDelete;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user