mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-19 05:43:16 +08:00
Updated page delete to handle inactive custom homepage correctly
Fixes #1447
This commit is contained in:
parent
2b7362fa94
commit
3ad1b42a74
|
@ -852,10 +852,13 @@ class EntityRepo
|
|||
*/
|
||||
public function destroyPage(Page $page)
|
||||
{
|
||||
// Check if set as custom homepage
|
||||
// Check if set as custom homepage & remove setting if not used or throw error if active
|
||||
$customHome = setting('app-homepage', '0:');
|
||||
if (intval($page->id) === intval(explode(':', $customHome)[0])) {
|
||||
throw new NotifyException(trans('errors.page_custom_home_deletion'), $page->getUrl());
|
||||
if (setting('app-homepage-type') === 'page') {
|
||||
throw new NotifyException(trans('errors.page_custom_home_deletion'), $page->getUrl());
|
||||
}
|
||||
setting()->remove('app-homepage');
|
||||
}
|
||||
|
||||
$this->destroyEntityCommonRelations($page);
|
||||
|
|
|
@ -38,10 +38,14 @@ class HomepageTest extends TestCase
|
|||
$name = 'My custom homepage';
|
||||
$content = str_repeat('This is the body content of my custom homepage.', 20);
|
||||
$customPage = $this->newPage(['name' => $name, 'html' => $content]);
|
||||
$this->setSettings(['app-homepage' => $customPage->id]);
|
||||
$this->setSettings([
|
||||
'app-homepage' => $customPage->id,
|
||||
'app-homepage-type' => 'page'
|
||||
]);
|
||||
|
||||
$homeVisit = $this->get('/');
|
||||
$homeVisit->assertSee($name);
|
||||
$homeVisit->assertElementNotExists('#home-default');
|
||||
|
||||
$pageDeleteReq = $this->delete($customPage->getUrl());
|
||||
$pageDeleteReq->assertStatus(302);
|
||||
|
@ -54,6 +58,23 @@ class HomepageTest extends TestCase
|
|||
$homeVisit->assertStatus(200);
|
||||
}
|
||||
|
||||
public function test_custom_homepage_can_be_deleted_once_custom_homepage_no_longer_used()
|
||||
{
|
||||
$this->asEditor();
|
||||
$name = 'My custom homepage';
|
||||
$content = str_repeat('This is the body content of my custom homepage.', 20);
|
||||
$customPage = $this->newPage(['name' => $name, 'html' => $content]);
|
||||
$this->setSettings([
|
||||
'app-homepage' => $customPage->id,
|
||||
'app-homepage-type' => 'default'
|
||||
]);
|
||||
|
||||
$pageDeleteReq = $this->delete($customPage->getUrl());
|
||||
$pageDeleteReq->assertStatus(302);
|
||||
$pageDeleteReq->assertSessionHas('success');
|
||||
$pageDeleteReq->assertSessionMissing('error');
|
||||
}
|
||||
|
||||
public function test_set_book_homepage()
|
||||
{
|
||||
$editor = $this->getEditor();
|
||||
|
|
Loading…
Reference in New Issue
Block a user