X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/e287d965f5ed6d72bb5e83fa655207f96e3257df..refs/pull/3210/head:/app/Http/Controllers/BookExportController.php diff --git a/app/Http/Controllers/BookExportController.php b/app/Http/Controllers/BookExportController.php index a92d94cc9..7f6dd8017 100644 --- a/app/Http/Controllers/BookExportController.php +++ b/app/Http/Controllers/BookExportController.php @@ -2,46 +2,48 @@ namespace BookStack\Http\Controllers; -use BookStack\Entities\Managers\BookContents; -use BookStack\Entities\ExportService; use BookStack\Entities\Repos\BookRepo; +use BookStack\Entities\Tools\ExportFormatter; use Throwable; class BookExportController extends Controller { - protected $bookRepo; - protected $exportService; + protected $exportFormatter; /** * BookExportController constructor. */ - public function __construct(BookRepo $bookRepo, ExportService $exportService) + public function __construct(BookRepo $bookRepo, ExportFormatter $exportFormatter) { $this->bookRepo = $bookRepo; - $this->exportService = $exportService; - parent::__construct(); + $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->exportService->bookToPdf($book); + $pdfContent = $this->exportFormatter->bookToPdf($book); + return $this->downloadResponse($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->exportService->bookToContainedHtml($book); + $htmlContent = $this->exportFormatter->bookToContainedHtml($book); + return $this->downloadResponse($htmlContent, $bookSlug . '.html'); } @@ -51,7 +53,8 @@ class BookExportController extends Controller public function plainText(string $bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); - $textContent = $this->exportService->bookToPlainText($book); + $textContent = $this->exportFormatter->bookToPlainText($book); + return $this->downloadResponse($textContent, $bookSlug . '.txt'); } @@ -61,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->downloadResponse($textContent, $bookSlug . '.md'); } }