Note
All of these functions are available for HtmlPdfBuilder
, UrlPdfBuilder
and
MarkdownPdfBuilder
.
To customize LibreOfficePdfBuilder
see the related documentation.
paperSize
paperStandardSize
paperWidth
paperHeight
margins
marginTop
marginBottom
marginLeft
marginRight
preferCssPageSize
printBackground
omitBackground
landscape
scale
nativePageRanges
splitMode
splitSpan
splitUnify
header and footer
headerFile and footerFile
download from
waitDelay
waitForExpression
emulatedMediaType
cookies
setCookie
addCookies
userAgent
extraHttpHeaders
addExtraHttpHeaders
failOnHttpStatusCodes
failOnResourceHttpStatusCodes
failOnResourceLoadingFailed
failOnConsoleExceptions
skipNetworkIdleEvent
metadata
addMetadata
pdfFormat
pdfUniversalAccess
Default: 8.5 inches x 11 inches
You can override the default paper size with height
, width
and unit
.
unit
is optional but by default in inches.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\Unit;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->paperSize(21, 29.7, Unit::Centimeters)
->generate()
->stream()
;
}
}
Default: 8.5 inches x 11 inches
You can override the default paper size with standard paper size.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\PaperSize;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->paperStandardSize(PaperSize::A4)
->generate()
->stream()
;
}
}
Or if you want you can create your own paper size values, you just need to
implement PaperSizeInterface
.
use Sensiolabs\GotenbergBundle\Enum\PaperSizeInterface;
class MyInvoiceSize implements PaperSizeInterface
{
public function width(): float
{
return 12;
}
public function height(): float
{
return 200;
}
public function unit(): Unit
{
return Unit::Inches;
}
}
Default: 8.5 inches
You can override the default width
and unit
.
unit
is optional but by default in inches.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\Unit;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->paperWidth(15, Unit::Inches)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: 11 inches
You can override the default height
and unit
.
unit
is optional but by default in inches.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\Unit;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->paperHeight(15, Unit::Inches)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: 0.39 inches
on all four sides
You can override the default margins, with the arguments top
, bottom
, right
,
left
and unit
.
unit
is optional but by default in inches.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\Unit;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->margins(1, 2, 3, 4, Unit::Inches)
->generate()
->stream()
;
}
}
Or you can override all margins individually with respective unit
.
unit
is always optional but by default in inches.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\Unit;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->marginTop(4, Unit::Points)
->marginBottom(4, Unit::Pixels)
->marginLeft(4, Unit::Picas)
->marginRight(4, Unit::Millimeters)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Define whether to prefer page size as defined by CSS.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->preferCssPageSize()
->generate()
->stream()
;
}
}
default: false
Print the background graphics.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->printBackground()
->generate()
->stream()
;
}
}
default: false
Hide the default white background and allow generating PDFs with transparency.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->omitBackground()
->generate()
->stream()
;
}
}
default: false
Set the paper orientation to landscape.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->landscape()
->generate()
->stream()
;
}
}
default: 1.0
The scale of the page rendering.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->scale(2.5)
->generate()
->stream()
;
}
}
default: All pages
Page ranges to print, e.g., '1-5, 8, 11-13' - empty means all pages.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->nativePageRanges('1-5')
->generate()
->stream()
;
}
}
default: None
Either intervals
or pages
.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enum\SplitMode;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->splitMode(SplitMode::Intervals)
->splitSpan('1')
->generate()
->stream()
;
}
}
default: None
Either the intervals or the page ranges to extract, depending on the selected splitMode
.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\SplitMode;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
]))
->splitMode(SplitMode::Intervals)
->splitSpan('1')
->generate()
->stream()
;
}
}
Default: false
Specify whether to put extracted pages into a single file or as many files as
there are page ranges. Only works with pages
mode.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enum\SplitMode;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->splitMode(SplitMode::Pages)
->splitSpan('1-2')
->splitUnify() // is same as ->splitUnify(true)
->generate()
->stream()
;
}
}
Warning
Every Header or Footer templates you pass to Gotenberg need to have the following structure.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>My PDF</title>
</head>
<body>
<!-- Your code goes here -->
</body>
</html>
Some other limitations exist about header and footer.
For more information about Header and Footer.
You may have the possibility to add header or footer Twig templates to your generated PDF.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->header('header.html.twig', [
'my_var' => 'value'
])
->content('content.html.twig', [
'my_var' => 'value'
])
->footer('footer.html.twig', [
'my_var' => 'value'
])
->generate()
->stream()
;
}
}
Warning
As assets files, by default the HTML files are fetch in the assets folder of
your application.
If your HTML files are in another folder, you can override the default value
of assets_directory in your configuration file config/sensiolabs_gotenberg.yml.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->headerFile('header.html')
->contentFile('content.html')
->footerFile('footer.html')
->generate()
->stream()
;
}
}
Relative path work as well.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->headerFile('../templates/html/header.html')
->contentFile('../templates/html/content.html')
->footerFile('../templates/html/footer.html')
->generate()
->stream()
;
}
}
Warning
URL of the file. It MUST return a Content-Disposition
header with a filename parameter.
To download files resource from URLs.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->downloadFrom([
[
'url' => 'http://example.com/url/to/file',
'extraHttpHeaders' =>
[
'MyHeader' => 'MyValue',
],
],
[
'url' => 'http://example.com/url/to/file',
'extraHttpHeaders' =>
[
'MyHeaderOne' => 'MyValue',
'MyHeaderTwo' => 'MyValue',
],
],
])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: None
When the page relies on JavaScript for rendering, and you don't have access to the page's code, you may want to wait a certain amount of time to make sure Chromium has fully rendered the page you're trying to generate.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->waitDelay('5s')
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
You may also wait until a given JavaScript expression.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->waitForExpression("window.globalVar === 'ready'")
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: print
Some websites have dedicated CSS rules for print. Using screen
allows
you to force the "standard" CSS rules.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\EmulatedMediaType;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->emulatedMediaType(EmulatedMediaType::Screen)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: None
Cookies to store in the Chromium cookie jar.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->cookies([[
'name' => 'my_cookie',
'value' => 'symfony',
'domain' => 'symfony.com',
'secure' => true,
'httpOnly' => true,
'sameSite' => 'Lax',
]])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
If you want to add cookies and delete the ones already loaded in the configuration .
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->setCookie([
'name' => 'my_cookie',
'value' => 'symfony',
'domain' => 'symfony.com',
'secure' => true,
'httpOnly' => true,
'sameSite' => 'Lax',
])
->generate()
->stream()
;
}
}
If you want to add cookies from the ones already loaded in the configuration.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->addCookies([[
'name' => 'my_cookie',
'value' => 'symfony',
'domain' => 'symfony.com',
'secure' => true,
'httpOnly' => true,
'sameSite' => 'Lax',
]])
->generate()
->stream()
;
}
}
default: None
Override the default User-Agent HTTP header.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\UserAgent;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->userAgent(UserAgent::AndroidChrome) // You can pass any string. This class is just a helper.
->generate()
;
}
}
default: None
HTTP headers to send by Chromium while loading the HTML document.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->extraHttpHeaders([
'MyHeader' => 'MyValue'
])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: None
If you want to add headers from the ones already loaded in the configuration.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->addExtraHttpHeaders([
'MyHeader' => 'MyValue'
])
->generate()
->stream()
;
}
}
default: [499,599]
To return a 409 Conflict response if the HTTP status code from the main page is not acceptable.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->failOnHttpStatusCodes([401, 403])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: None
Return a 409 Conflict response if the HTTP status code from at least one resource is not acceptable.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->failOnResourceHttpStatusCodes([401, 403])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Return a 409 Conflict response if there are exceptions to load at least one resource in the Chromium.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->failOnResourceLoadingFailed()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Return a 409 Conflict response if there are exceptions in the Chromium console.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->failOnConsoleExceptions()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Gotenberg, by default, waits for the network idle event to ensure that the majority of the page is rendered during conversion. However, this often significantly slows down the conversion process. Setting this form field to true can greatly enhance the conversion speed.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->skipNetworkIdleEvent()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: None
Resets the configuration metadata and add new ones to write.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enum\PdfFormat;use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->metadata(['Author' => 'SensioLabs', 'Subject' => 'Gotenberg'])
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: None
If you want to add metadata from the ones already loaded in the configuration.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enum\PdfFormat;use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->addMetadata('key', 'value')
->generate()
->stream()
;
}
}
default: None
Convert the resulting PDF into the given PDF/A format.
If set to null
, remove format from the ones already loaded in the
configuration.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\PdfFormat;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->pdfFormat(PdfFormat::Pdf1b)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Enable PDF for Universal Access for optimal accessibility.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergPdfInterface;
class YourController
{
public function yourControllerMethod(GotenbergPdfInterface $gotenberg): Response
{
return $gotenberg
->html()
->content('content.html.twig', [
'my_var' => 'value'
])
->pdfUniversalAccess()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.