X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/9af636bd48f5c7cec7f73746307800b9572d2644..refs/pull/3630/head:/app/Http/Controllers/BookExportController.php diff --git a/app/Http/Controllers/BookExportController.php b/app/Http/Controllers/BookExportController.php index 58868fa5c..cc8d48a35 100644 --- a/app/Http/Controllers/BookExportController.php +++ b/app/Http/Controllers/BookExportController.php @@ -2,13 +2,12 @@ namespace BookStack\Http\Controllers; -use BookStack\Entities\Tools\ExportFormatter; use BookStack\Entities\Repos\BookRepo; +use BookStack\Entities\Tools\ExportFormatter; use Throwable; class BookExportController extends Controller { - protected $bookRepo; protected $exportFormatter; @@ -19,28 +18,33 @@ class BookExportController extends Controller { $this->bookRepo = $bookRepo; $this->exportFormatter = $exportFormatter; + $this->middleware('can:content-export'); } /** * Export a book as a PDF file. + * * @throws Throwable */ public function pdf(string $bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $pdfContent = $this->exportFormatter->bookToPdf($book); - return $this->downloadResponse($pdfContent, $bookSlug . '.pdf'); + + return $this->download()->directly($pdfContent, $bookSlug . '.pdf'); } /** * Export a book as a contained HTML file. + * * @throws Throwable */ public function html(string $bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $htmlContent = $this->exportFormatter->bookToContainedHtml($book); - return $this->downloadResponse($htmlContent, $bookSlug . '.html'); + + return $this->download()->directly($htmlContent, $bookSlug . '.html'); } /** @@ -50,7 +54,8 @@ class BookExportController extends Controller { $book = $this->bookRepo->getBySlug($bookSlug); $textContent = $this->exportFormatter->bookToPlainText($book); - return $this->downloadResponse($textContent, $bookSlug . '.txt'); + + return $this->download()->directly($textContent, $bookSlug . '.txt'); } /** @@ -59,17 +64,8 @@ class BookExportController extends Controller public function markdown(string $bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); - $textContent = $this->exportService->bookToMarkdown($book); - return $this->downloadResponse($textContent, $bookSlug . '.md'); - } + $textContent = $this->exportFormatter->bookToMarkdown($book); - /** - * Export a book as a zip file, made of markdown files. - */ - public function zip(string $bookSlug) - { - $book = $this->bookRepo->getBySlug($bookSlug); - $filename = $this->exportService->bookToZip($book); - return response()->download($filename); + return $this->download()->directly($textContent, $bookSlug . '.md'); } }