BookStack/app/Http/Controllers/ChapterController.php

249 lines
8.6 KiB
PHP
Raw Normal View History

<?php namespace BookStack\Http\Controllers;
2015-07-27 15:17:08 -04:00
use Activity;
2017-01-01 11:05:44 -05:00
use BookStack\Repos\EntityRepo;
use BookStack\Repos\UserRepo;
2015-07-27 15:17:08 -04:00
use Illuminate\Http\Request;
use BookStack\Repos\BookRepo;
use BookStack\Repos\ChapterRepo;
2016-12-04 11:51:39 -05:00
use Illuminate\Http\Response;
use Views;
2015-07-27 15:17:08 -04:00
class ChapterController extends Controller
{
protected $bookRepo;
protected $chapterRepo;
protected $userRepo;
2017-01-01 11:05:44 -05:00
protected $entityRepo;
2015-07-27 15:17:08 -04:00
/**
* ChapterController constructor.
2017-01-01 11:05:44 -05:00
* @param EntityRepo $entityRepo
* @param BookRepo $bookRepo
* @param ChapterRepo $chapterRepo
* @param UserRepo $userRepo
2015-07-27 15:17:08 -04:00
*/
2017-01-01 11:05:44 -05:00
public function __construct(EntityRepo $entityRepo, BookRepo $bookRepo, ChapterRepo $chapterRepo, UserRepo $userRepo)
2015-07-27 15:17:08 -04:00
{
2017-01-01 11:05:44 -05:00
$this->entityRepo = $entityRepo;
// TODO - Remove below
2015-07-27 15:17:08 -04:00
$this->bookRepo = $bookRepo;
$this->chapterRepo = $chapterRepo;
$this->userRepo = $userRepo;
2015-08-29 10:03:42 -04:00
parent::__construct();
2015-07-27 15:17:08 -04:00
}
2015-08-29 10:03:42 -04:00
2015-07-27 15:17:08 -04:00
/**
* Show the form for creating a new chapter.
2015-07-27 15:17:08 -04:00
* @param $bookSlug
* @return Response
*/
public function create($bookSlug)
{
2017-01-01 11:05:44 -05:00
$book = $this->entityRepo->getBySlug('book', $bookSlug);
$this->checkOwnablePermission('chapter-create', $book);
2016-12-04 11:51:39 -05:00
$this->setPageTitle(trans('entities.chapters_create'));
return view('chapters/create', ['book' => $book, 'current' => $book]);
2015-07-27 15:17:08 -04:00
}
/**
* Store a newly created chapter in storage.
2015-08-29 10:03:42 -04:00
* @param $bookSlug
2015-07-27 15:17:08 -04:00
* @param Request $request
* @return Response
*/
public function store($bookSlug, Request $request)
{
$this->validate($request, [
'name' => 'required|string|max:255'
]);
2017-01-01 11:05:44 -05:00
$book = $this->entityRepo->getBySlug('book', $bookSlug);
$this->checkOwnablePermission('chapter-create', $book);
$input = $request->all();
$input['priority'] = $this->bookRepo->getNewPriority($book);
$chapter = $this->chapterRepo->createFromInput($input, $book);
Activity::add($chapter, 'chapter_create', $book->id);
return redirect($chapter->getUrl());
2015-07-27 15:17:08 -04:00
}
/**
* Display the specified chapter.
* @param $bookSlug
* @param $chapterSlug
2015-07-27 15:17:08 -04:00
* @return Response
*/
public function show($bookSlug, $chapterSlug)
2015-07-27 15:17:08 -04:00
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('chapter-view', $chapter);
2017-01-01 11:05:44 -05:00
$sidebarTree = $this->bookRepo->getChildren($chapter->book);
Views::add($chapter);
$this->setPageTitle($chapter->getShortName());
$pages = $this->chapterRepo->getChildren($chapter);
return view('chapters/show', [
2017-01-01 11:05:44 -05:00
'book' => $chapter->book,
'chapter' => $chapter,
'current' => $chapter,
'sidebarTree' => $sidebarTree,
'pages' => $pages
]);
2015-07-27 15:17:08 -04:00
}
/**
* Show the form for editing the specified chapter.
* @param $bookSlug
* @param $chapterSlug
2015-07-27 15:17:08 -04:00
* @return Response
*/
public function edit($bookSlug, $chapterSlug)
2015-07-27 15:17:08 -04:00
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('chapter-update', $chapter);
2016-12-04 11:51:39 -05:00
$this->setPageTitle(trans('entities.chapters_edit_named', ['chapterName' => $chapter->getShortName()]));
2017-01-01 11:05:44 -05:00
return view('chapters/edit', ['book' => $chapter->book, 'chapter' => $chapter, 'current' => $chapter]);
2015-07-27 15:17:08 -04:00
}
/**
* Update the specified chapter in storage.
* @param Request $request
2015-08-29 10:03:42 -04:00
* @param $bookSlug
* @param $chapterSlug
2015-07-27 15:17:08 -04:00
* @return Response
*/
public function update(Request $request, $bookSlug, $chapterSlug)
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('chapter-update', $chapter);
if ($chapter->name !== $request->get('name')) {
$chapter->slug = $this->entityRepo->findSuitableSlug('chapter', $request->get('name'), $chapter->id, $chapter->book->id);
}
$chapter->fill($request->all());
$chapter->updated_by = user()->id;
$chapter->save();
2017-01-01 11:05:44 -05:00
Activity::add($chapter, 'chapter_update', $chapter->book->id);
return redirect($chapter->getUrl());
}
/**
* Shows the page to confirm deletion of this chapter.
* @param $bookSlug
* @param $chapterSlug
* @return \Illuminate\View\View
*/
public function showDelete($bookSlug, $chapterSlug)
2015-07-27 15:17:08 -04:00
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('chapter-delete', $chapter);
2016-12-04 11:51:39 -05:00
$this->setPageTitle(trans('entities.chapters_delete_named', ['chapterName' => $chapter->getShortName()]));
2017-01-01 11:05:44 -05:00
return view('chapters/delete', ['book' => $chapter->book, 'chapter' => $chapter, 'current' => $chapter]);
2015-07-27 15:17:08 -04:00
}
/**
* Remove the specified chapter from storage.
* @param $bookSlug
* @param $chapterSlug
2015-07-27 15:17:08 -04:00
* @return Response
*/
public function destroy($bookSlug, $chapterSlug)
2015-07-27 15:17:08 -04:00
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$book = $chapter->book;
$this->checkOwnablePermission('chapter-delete', $chapter);
Activity::addMessage('chapter_delete', $book->id, $chapter->name);
$this->chapterRepo->destroy($chapter);
return redirect($book->getUrl());
2015-07-27 15:17:08 -04:00
}
2016-06-25 10:31:38 -04:00
/**
* Show the page for moving a chapter.
* @param $bookSlug
* @param $chapterSlug
* @return mixed
* @throws \BookStack\Exceptions\NotFoundException
*/
public function showMove($bookSlug, $chapterSlug) {
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
2016-12-04 11:51:39 -05:00
$this->setPageTitle(trans('entities.chapters_move_named', ['chapterName' => $chapter->getShortName()]));
2016-06-25 10:31:38 -04:00
$this->checkOwnablePermission('chapter-update', $chapter);
return view('chapters/move', [
'chapter' => $chapter,
2017-01-01 11:05:44 -05:00
'book' => $chapter->book
2016-06-25 10:31:38 -04:00
]);
}
/**
* Perform the move action for a chapter.
* @param $bookSlug
* @param $chapterSlug
* @param Request $request
* @return mixed
* @throws \BookStack\Exceptions\NotFoundException
*/
2016-06-25 10:31:38 -04:00
public function move($bookSlug, $chapterSlug, Request $request) {
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
2016-06-25 10:31:38 -04:00
$this->checkOwnablePermission('chapter-update', $chapter);
$entitySelection = $request->get('entity_selection', null);
if ($entitySelection === null || $entitySelection === '') {
return redirect($chapter->getUrl());
}
$stringExploded = explode(':', $entitySelection);
$entityType = $stringExploded[0];
$entityId = intval($stringExploded[1]);
$parent = false;
if ($entityType == 'book') {
2017-01-01 11:05:44 -05:00
$parent = $this->entityRepo->getById('book', $entityId);
2016-06-25 10:31:38 -04:00
}
if ($parent === false || $parent === null) {
2016-12-04 11:51:39 -05:00
session()->flash('error', trans('errors.selected_book_not_found'));
2016-06-25 10:31:38 -04:00
return redirect()->back();
}
$this->chapterRepo->changeBook($parent->id, $chapter, true);
2016-06-25 10:31:38 -04:00
Activity::add($chapter, 'chapter_move', $chapter->book->id);
2016-12-04 11:51:39 -05:00
session()->flash('success', trans('entities.chapter_move_success', ['bookName' => $parent->name]));
2016-06-25 10:31:38 -04:00
return redirect($chapter->getUrl());
}
/**
* Show the Restrictions view.
* @param $bookSlug
* @param $chapterSlug
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function showRestrict($bookSlug, $chapterSlug)
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('restrictions-manage', $chapter);
$roles = $this->userRepo->getRestrictableRoles();
return view('chapters/restrictions', [
'chapter' => $chapter,
'roles' => $roles
]);
}
/**
* Set the restrictions for this chapter.
* @param $bookSlug
* @param $chapterSlug
* @param Request $request
* @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
*/
public function restrict($bookSlug, $chapterSlug, Request $request)
{
2017-01-01 11:05:44 -05:00
$chapter = $this->entityRepo->getBySlug('chapter', $chapterSlug, $bookSlug);
$this->checkOwnablePermission('restrictions-manage', $chapter);
$this->chapterRepo->updateEntityPermissionsFromRequest($request, $chapter);
2016-12-04 11:51:39 -05:00
session()->flash('success', trans('entities.chapters_permissions_success'));
return redirect($chapter->getUrl());
}
2015-07-27 15:17:08 -04:00
}