2021-06-26 23:23:15 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace BookStack\Http\Controllers\Api;
|
2020-05-23 07:28:41 +08:00
|
|
|
|
2020-11-22 08:17:45 +08:00
|
|
|
use BookStack\Entities\Models\Chapter;
|
|
|
|
use BookStack\Entities\Tools\ExportFormatter;
|
2020-05-23 07:28:41 +08:00
|
|
|
use Throwable;
|
|
|
|
|
|
|
|
class ChapterExportApiController extends ApiController
|
|
|
|
{
|
2020-11-22 09:26:14 +08:00
|
|
|
protected $exportFormatter;
|
2020-05-23 07:28:41 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ChapterExportController constructor.
|
|
|
|
*/
|
2020-11-28 23:39:40 +08:00
|
|
|
public function __construct(ExportFormatter $exportFormatter)
|
2020-05-23 07:28:41 +08:00
|
|
|
{
|
2020-11-22 09:26:14 +08:00
|
|
|
$this->exportFormatter = $exportFormatter;
|
2021-08-29 04:48:17 +08:00
|
|
|
$this->middleware('can:content-export');
|
2020-05-23 07:28:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a chapter as a PDF file.
|
2021-06-26 23:23:15 +08:00
|
|
|
*
|
2020-05-23 07:28:41 +08:00
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
public function exportPdf(int $id)
|
|
|
|
{
|
|
|
|
$chapter = Chapter::visible()->findOrFail($id);
|
2020-11-22 09:26:14 +08:00
|
|
|
$pdfContent = $this->exportFormatter->chapterToPdf($chapter);
|
2021-06-26 23:23:15 +08:00
|
|
|
|
2022-06-09 06:50:42 +08:00
|
|
|
return $this->download()->directly($pdfContent, $chapter->slug . '.pdf');
|
2020-05-23 07:28:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a chapter as a contained HTML file.
|
2021-06-26 23:23:15 +08:00
|
|
|
*
|
2020-05-23 07:28:41 +08:00
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
public function exportHtml(int $id)
|
|
|
|
{
|
|
|
|
$chapter = Chapter::visible()->findOrFail($id);
|
2020-11-22 09:26:14 +08:00
|
|
|
$htmlContent = $this->exportFormatter->chapterToContainedHtml($chapter);
|
2021-06-26 23:23:15 +08:00
|
|
|
|
2022-06-09 06:50:42 +08:00
|
|
|
return $this->download()->directly($htmlContent, $chapter->slug . '.html');
|
2020-05-23 07:28:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a chapter as a plain text file.
|
|
|
|
*/
|
|
|
|
public function exportPlainText(int $id)
|
|
|
|
{
|
|
|
|
$chapter = Chapter::visible()->findOrFail($id);
|
2020-11-22 09:26:14 +08:00
|
|
|
$textContent = $this->exportFormatter->chapterToPlainText($chapter);
|
2021-06-26 23:23:15 +08:00
|
|
|
|
2022-06-09 06:50:42 +08:00
|
|
|
return $this->download()->directly($textContent, $chapter->slug . '.txt');
|
2020-05-23 07:28:41 +08:00
|
|
|
}
|
2021-06-23 04:32:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a chapter as a markdown file.
|
|
|
|
*/
|
|
|
|
public function exportMarkdown(int $id)
|
|
|
|
{
|
|
|
|
$chapter = Chapter::visible()->findOrFail($id);
|
|
|
|
$markdown = $this->exportFormatter->chapterToMarkdown($chapter);
|
2021-06-26 23:23:15 +08:00
|
|
|
|
2022-06-09 06:50:42 +08:00
|
|
|
return $this->download()->directly($markdown, $chapter->slug . '.md');
|
2021-06-23 04:32:55 +08:00
|
|
|
}
|
2020-05-23 07:28:41 +08:00
|
|
|
}
|