X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/c7a2d568bf693add30c8402d68d1f46f09a44c5b..refs/pull/3850/head:/app/Http/Controllers/PageExportController.php diff --git a/app/Http/Controllers/PageExportController.php b/app/Http/Controllers/PageExportController.php index 92898dc61..62101d339 100644 --- a/app/Http/Controllers/PageExportController.php +++ b/app/Http/Controllers/PageExportController.php @@ -2,30 +2,31 @@ namespace BookStack\Http\Controllers; -use BookStack\Entities\ExportService; -use BookStack\Entities\Tools\PageContent; use BookStack\Entities\Repos\PageRepo; +use BookStack\Entities\Tools\ExportFormatter; +use BookStack\Entities\Tools\PageContent; use BookStack\Exceptions\NotFoundException; use Throwable; class PageExportController extends Controller { - protected $pageRepo; - protected $exportService; + protected $exportFormatter; /** * PageExportController constructor. */ - public function __construct(PageRepo $pageRepo, ExportService $exportService) + public function __construct(PageRepo $pageRepo, ExportFormatter $exportFormatter) { $this->pageRepo = $pageRepo; - $this->exportService = $exportService; + $this->exportFormatter = $exportFormatter; + $this->middleware('can:content-export'); } /** * Exports a page to a PDF. - * https://github.com/barryvdh/laravel-dompdf + * https://github.com/barryvdh/laravel-dompdf. + * * @throws NotFoundException * @throws Throwable */ @@ -33,12 +34,14 @@ class PageExportController extends Controller { $page = $this->pageRepo->getBySlug($bookSlug, $pageSlug); $page->html = (new PageContent($page))->render(); - $pdfContent = $this->exportService->pageToPdf($page); - return $this->downloadResponse($pdfContent, $pageSlug . '.pdf'); + $pdfContent = $this->exportFormatter->pageToPdf($page); + + return $this->download()->directly($pdfContent, $pageSlug . '.pdf'); } /** * Export a page to a self-contained HTML file. + * * @throws NotFoundException * @throws Throwable */ @@ -46,18 +49,34 @@ class PageExportController extends Controller { $page = $this->pageRepo->getBySlug($bookSlug, $pageSlug); $page->html = (new PageContent($page))->render(); - $containedHtml = $this->exportService->pageToContainedHtml($page); - return $this->downloadResponse($containedHtml, $pageSlug . '.html'); + $containedHtml = $this->exportFormatter->pageToContainedHtml($page); + + return $this->download()->directly($containedHtml, $pageSlug . '.html'); } /** * Export a page to a simple plaintext .txt file. + * * @throws NotFoundException */ public function plainText(string $bookSlug, string $pageSlug) { $page = $this->pageRepo->getBySlug($bookSlug, $pageSlug); - $pageText = $this->exportService->pageToPlainText($page); - return $this->downloadResponse($pageText, $pageSlug . '.txt'); + $pageText = $this->exportFormatter->pageToPlainText($page); + + return $this->download()->directly($pageText, $pageSlug . '.txt'); + } + + /** + * Export a page to a simple markdown .md file. + * + * @throws NotFoundException + */ + public function markdown(string $bookSlug, string $pageSlug) + { + $page = $this->pageRepo->getBySlug($bookSlug, $pageSlug); + $pageText = $this->exportFormatter->pageToMarkdown($page); + + return $this->download()->directly($pageText, $pageSlug . '.md'); } }