width
height
clip
quality
omitBackground
optimizeForSpeed
waitDelay
waitForExpression
emulatedMediaType
cookies
setCookie
addCookies
userAgent
extraHttpHeaders
addExtraHttpHeaders
failOnHttpStatusCodes
failOnResourceHttpStatusCodes
failOnResourceLoadingFailed
failOnConsoleExceptions
skipNetworkIdleEvent
Default: 800 pixels
The device screen width in pixels.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->width(600)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: 600 pixels
The device screen height in pixels.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->height(600)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: false
Define whether to clip the screenshot according to the device dimensions.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->clip()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
Default: 100
The compression quality from range 0 to 100 (jpeg only).
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\ScreenshotFormat;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->quality(50)
->format(ScreenshotFormat::Jpeg)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: false
Hide the default white background and allow generating screenshots with transparency.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->omitBackground()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $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: false
Define whether to optimize image encoding for speed, not for resulting size.
namespace App\Controller;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg->html()
->content('twig_simple_pdf.html.twig', [
'my_var' => 'value'
])
->optimizeForSpeed(true)
->generate()
->stream()
;
}
}
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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->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\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->skipNetworkIdleEvent()
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.
default: png
The image compression format, either "png", "jpeg" or "webp".
namespace App\Controller;
use Sensiolabs\GotenbergBundle\Enumeration\ScreenshotFormat;
use Sensiolabs\GotenbergBundle\GotenbergScreenshotInterface;
class YourController
{
public function yourControllerMethod(GotenbergScreenshotInterface $gotenberg): Response
{
return $gotenberg
->html()
->format(ScreenshotFormat::Webp)
->generate()
->stream()
;
}
}
Tip
For more information go to Gotenberg documentations.