mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
Merge pull request #2940 from creative-commoners/pulls/6/remove-bulk-restore
FIX Remove deprecated restore batch action
This commit is contained in:
commit
0f0ac8e03f
@ -1,72 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace SilverStripe\CMS\BatchActions;
|
||||
|
||||
use SilverStripe\Admin\CMSBatchAction;
|
||||
use SilverStripe\CMS\Model\SiteTree;
|
||||
use SilverStripe\Control\HTTPResponse;
|
||||
use SilverStripe\ORM\ArrayList;
|
||||
use SilverStripe\ORM\SS_List;
|
||||
use SilverStripe\Versioned\Versioned;
|
||||
use SilverStripe\Security\Permission;
|
||||
use SilverStripe\Dev\Deprecation;
|
||||
|
||||
/**
|
||||
* Batch restore of pages
|
||||
*
|
||||
* @deprecated 5.3.0 Will be removed without equivalent functionality to replace it
|
||||
*/
|
||||
class CMSBatchAction_Restore extends CMSBatchAction
|
||||
{
|
||||
public function __construct()
|
||||
{
|
||||
Deprecation::withNoReplacement(function () {
|
||||
Deprecation::notice('5.3.0', 'Will be removed without equivalent functionality to replace it', Deprecation::SCOPE_CLASS);
|
||||
});
|
||||
}
|
||||
|
||||
public function getActionTitle()
|
||||
{
|
||||
return _t(__CLASS__ . '.RESTORE', 'Restore');
|
||||
}
|
||||
|
||||
public function run(SS_List $pages): HTTPResponse
|
||||
{
|
||||
// Sort pages by depth
|
||||
$pageArray = $pages->toArray();
|
||||
// because of https://bugs.php.net/bug.php?id=50688
|
||||
/** @var SiteTree $page */
|
||||
foreach ($pageArray as $page) {
|
||||
$page->getPageLevel();
|
||||
}
|
||||
usort($pageArray, function (SiteTree $a, SiteTree $b) {
|
||||
return $a->getPageLevel() - $b->getPageLevel();
|
||||
});
|
||||
$pages = new ArrayList($pageArray);
|
||||
|
||||
// Restore
|
||||
return $this->batchaction(
|
||||
$pages,
|
||||
'doRestoreToStage',
|
||||
_t(__CLASS__ . '.RESTORED_PAGES', 'Restored %d pages')
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@see SiteTree::canEdit()}
|
||||
*
|
||||
* @param array $ids
|
||||
* @return array
|
||||
*/
|
||||
public function applicablePages($ids)
|
||||
{
|
||||
// Basic permission check based on SiteTree::canEdit
|
||||
if (!Permission::check(["ADMIN", "SITETREE_EDIT_ALL"])) {
|
||||
return [];
|
||||
}
|
||||
|
||||
// Get pages that exist in stage and remove them from the restore-able set
|
||||
$stageIDs = Versioned::get_by_stage($this->managedClass, Versioned::DRAFT)->column('ID');
|
||||
return array_values(array_diff($ids ?? [], $stageIDs));
|
||||
}
|
||||
}
|
@ -4,7 +4,6 @@ namespace SilverStripe\CMS\Tests\Controllers;
|
||||
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Archive;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Restore;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
||||
use SilverStripe\CMS\Model\SiteTree;
|
||||
use SilverStripe\Core\Config\Config;
|
||||
@ -105,77 +104,4 @@ class CMSBatchActionsTest extends SapphireTest
|
||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'unpublished'), $applicable);
|
||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'modified'), $applicable);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test restore batch actions
|
||||
*/
|
||||
public function testBatchRestoreApplicable()
|
||||
{
|
||||
$this->logInWithPermission('ADMIN');
|
||||
$pages = Versioned::get_including_deleted(SiteTree::class);
|
||||
$ids = $pages->column('ID');
|
||||
$action = new CMSBatchAction_Restore();
|
||||
|
||||
// Test applicable pages
|
||||
$applicable = $action->applicablePages($ids);
|
||||
$this->assertNotContains($this->idFromFixture(SiteTree::class, 'published'), $applicable);
|
||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'archived'), $applicable);
|
||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'archivedx'), $applicable);
|
||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'archivedy'), $applicable);
|
||||
$this->assertNotContains($this->idFromFixture(SiteTree::class, 'unpublished'), $applicable);
|
||||
$this->assertNotContains($this->idFromFixture(SiteTree::class, 'modified'), $applicable);
|
||||
}
|
||||
|
||||
public function testBatchRestore()
|
||||
{
|
||||
$this->logInWithPermission('ADMIN');
|
||||
$pages = Versioned::get_including_deleted(SiteTree::class);
|
||||
$action = new CMSBatchAction_Restore();
|
||||
$archivedID = $this->idFromFixture(SiteTree::class, 'archived');
|
||||
$archivedxID = $this->idFromFixture(SiteTree::class, 'archivedx');
|
||||
$archivedyID = $this->idFromFixture(SiteTree::class, 'archivedy');
|
||||
|
||||
// Just restore one child
|
||||
$list = $pages->filter('ID', $archivedxID);
|
||||
$this->assertEquals(1, $list->count());
|
||||
$this->assertEquals($archivedID, $list->first()->ParentID);
|
||||
|
||||
// Run restore
|
||||
$result = json_decode($action->run($list)->getBody(), true);
|
||||
$this->assertEquals(
|
||||
[
|
||||
$archivedxID => $archivedxID,
|
||||
],
|
||||
$result['success']
|
||||
);
|
||||
$archivedx = SiteTree::get()->byID($archivedxID);
|
||||
$this->assertNotNull($archivedx);
|
||||
$this->assertEquals(0, $archivedx->ParentID); // Restore to root because parent is unrestored
|
||||
|
||||
// Restore both remaining pages
|
||||
$list = $pages
|
||||
->filter('ID', [$archivedID, $archivedyID])
|
||||
->sort('Title');
|
||||
$this->assertEquals(2, $list->count());
|
||||
$this->assertEquals($archivedID, $list->first()->ParentID); // archivedy
|
||||
$this->assertEquals(0, $list->last()->ParentID); // archived (parent)
|
||||
|
||||
// Run restore
|
||||
$result = json_decode($action->run($list)->getBody(), true);
|
||||
$this->assertEquals(
|
||||
[
|
||||
// Order of archived is opposite to order items are passed in, as
|
||||
// these are sorted by level first
|
||||
$archivedID => $archivedID,
|
||||
$archivedyID => $archivedyID,
|
||||
],
|
||||
$result['success']
|
||||
);
|
||||
$archived = SiteTree::get()->byID($archivedID);
|
||||
$archivedy = SiteTree::get()->byID($archivedyID);
|
||||
$this->assertNotNull($archived);
|
||||
$this->assertNotNull($archivedy);
|
||||
$this->assertEquals($archivedID, $archivedy->ParentID); // Not restored to root, but to the parent
|
||||
$this->assertEquals(0, $archived->ParentID); // Root stays root
|
||||
}
|
||||
}
|
||||
|
@ -4,7 +4,6 @@ namespace SilverStripe\CMS\Tests\Controllers;
|
||||
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Archive;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Restore;
|
||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
||||
use SilverStripe\CMS\Forms\SiteTreeURLSegmentField;
|
||||
use SilverStripe\CMS\Model\SiteTree;
|
||||
|
Loading…
Reference in New Issue
Block a user