mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
FIX Remove deprecated restore batch action
This commit is contained in:
parent
d552396e77
commit
ef27e9954c
@ -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_Archive;
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Restore;
|
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
||||||
use SilverStripe\CMS\Model\SiteTree;
|
use SilverStripe\CMS\Model\SiteTree;
|
||||||
use SilverStripe\Core\Config\Config;
|
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, 'unpublished'), $applicable);
|
||||||
$this->assertContains($this->idFromFixture(SiteTree::class, 'modified'), $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_Archive;
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
use SilverStripe\CMS\BatchActions\CMSBatchAction_Publish;
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Restore;
|
|
||||||
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
use SilverStripe\CMS\BatchActions\CMSBatchAction_Unpublish;
|
||||||
use SilverStripe\CMS\Forms\SiteTreeURLSegmentField;
|
use SilverStripe\CMS\Forms\SiteTreeURLSegmentField;
|
||||||
use SilverStripe\CMS\Model\SiteTree;
|
use SilverStripe\CMS\Model\SiteTree;
|
||||||
|
Loading…
Reference in New Issue
Block a user