2019-09-15 17:33:27 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace BookStack\Http\Controllers;
|
|
|
|
|
2020-05-13 22:57:59 -04:00
|
|
|
use BookStack\Entities\Managers\BookContents;
|
2019-09-15 17:33:27 -04:00
|
|
|
use BookStack\Entities\ExportService;
|
2019-09-15 18:28:23 -04:00
|
|
|
use BookStack\Entities\Repos\BookRepo;
|
2019-09-15 17:33:27 -04:00
|
|
|
use Throwable;
|
2020-05-13 22:57:59 -04:00
|
|
|
use ZipArchive;
|
2019-09-15 17:33:27 -04:00
|
|
|
|
|
|
|
class BookExportController extends Controller
|
|
|
|
{
|
|
|
|
|
2019-10-05 07:55:01 -04:00
|
|
|
protected $bookRepo;
|
2019-09-15 17:33:27 -04:00
|
|
|
protected $exportService;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* BookExportController constructor.
|
|
|
|
*/
|
2019-09-15 18:28:23 -04:00
|
|
|
public function __construct(BookRepo $bookRepo, ExportService $exportService)
|
2019-09-15 17:33:27 -04:00
|
|
|
{
|
2019-09-15 18:28:23 -04:00
|
|
|
$this->bookRepo = $bookRepo;
|
2019-09-15 17:33:27 -04:00
|
|
|
$this->exportService = $exportService;
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a book as a PDF file.
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
public function pdf(string $bookSlug)
|
|
|
|
{
|
2019-09-15 18:28:23 -04:00
|
|
|
$book = $this->bookRepo->getBySlug($bookSlug);
|
2019-09-15 17:33:27 -04:00
|
|
|
$pdfContent = $this->exportService->bookToPdf($book);
|
|
|
|
return $this->downloadResponse($pdfContent, $bookSlug . '.pdf');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a book as a contained HTML file.
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
public function html(string $bookSlug)
|
|
|
|
{
|
2019-09-15 18:28:23 -04:00
|
|
|
$book = $this->bookRepo->getBySlug($bookSlug);
|
2019-09-15 17:33:27 -04:00
|
|
|
$htmlContent = $this->exportService->bookToContainedHtml($book);
|
|
|
|
return $this->downloadResponse($htmlContent, $bookSlug . '.html');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a book as a plain text file.
|
|
|
|
*/
|
|
|
|
public function plainText(string $bookSlug)
|
|
|
|
{
|
2019-09-15 18:28:23 -04:00
|
|
|
$book = $this->bookRepo->getBySlug($bookSlug);
|
2019-09-15 17:33:27 -04:00
|
|
|
$textContent = $this->exportService->bookToPlainText($book);
|
|
|
|
return $this->downloadResponse($textContent, $bookSlug . '.txt');
|
|
|
|
}
|
2020-05-13 00:12:26 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a book as a markdown file.
|
|
|
|
*/
|
|
|
|
public function markdown(string $bookSlug)
|
|
|
|
{
|
|
|
|
$book = $this->bookRepo->getBySlug($bookSlug);
|
|
|
|
$textContent = $this->exportService->bookToMarkdown($book);
|
|
|
|
return $this->downloadResponse($textContent, $bookSlug . '.md');
|
|
|
|
}
|
2020-05-13 22:57:59 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Export a book as a zip file, made of markdown files.
|
|
|
|
*/
|
|
|
|
public function zip(string $bookSlug)
|
|
|
|
{
|
|
|
|
$book = $this->bookRepo->getBySlug($bookSlug);
|
|
|
|
$z = new ZipArchive();
|
|
|
|
$z->open("book.zip", \ZipArchive::CREATE | \ZipArchive::OVERWRITE);
|
|
|
|
$bookTree = (new BookContents($book))->getTree(false, true);
|
|
|
|
foreach ($bookTree as $bookChild) {
|
|
|
|
if ($bookChild->isA('chapter')) {
|
|
|
|
$z->addEmptyDir($bookChild->name);
|
|
|
|
foreach ($bookChild->pages as $page) {
|
|
|
|
$z->addFromString($bookChild->name . "/" . $page->name . ".md", $this->exportService->pageToMarkdown($page));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$z->addFromString($bookChild->name . ".md", $this->exportService->pageToMarkdown($bookChild));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response()->download('book.zip');
|
|
|
|
// TODO: Is not unlinking it a security issue?
|
|
|
|
}
|
2019-09-15 17:33:27 -04:00
|
|
|
}
|