X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/2c21850da728dce55cec2e84ec73ed474ba0bd0a..refs/pull/3247/head:/app/Entities/Tools/PdfGenerator.php diff --git a/app/Entities/Tools/PdfGenerator.php b/app/Entities/Tools/PdfGenerator.php index d606617a4..17a7da9f3 100644 --- a/app/Entities/Tools/PdfGenerator.php +++ b/app/Entities/Tools/PdfGenerator.php @@ -2,20 +2,20 @@ namespace BookStack\Entities\Tools; -use Barryvdh\Snappy\Facades\SnappyPdf; use Barryvdh\DomPDF\Facade as DomPDF; +use Barryvdh\Snappy\Facades\SnappyPdf; class PdfGenerator { + const ENGINE_DOMPDF = 'dompdf'; + const ENGINE_WKHTML = 'wkhtml'; /** * Generate PDF content from the given HTML content. */ public function fromHtml(string $html): string { - $useWKHTML = config('snappy.pdf.binary') !== false && config('app.allow_untrusted_server_fetching') === true; - - if ($useWKHTML) { + if ($this->getActiveEngine() === self::ENGINE_WKHTML) { $pdf = SnappyPDF::loadHTML($html); $pdf->setOption('print-media-type', true); } else { @@ -25,4 +25,14 @@ class PdfGenerator return $pdf->output(); } -} \ No newline at end of file + /** + * Get the currently active PDF engine. + * Returns the value of an `ENGINE_` const on this class. + */ + public function getActiveEngine(): string + { + $useWKHTML = config('snappy.pdf.binary') !== false && config('app.allow_untrusted_server_fetching') === true; + + return $useWKHTML ? self::ENGINE_WKHTML : self::ENGINE_DOMPDF; + } +}