xeurun / knp-snappy-bundle
Easily create PDF and images in Symfony2 by converting Twig/HTML templates.
Installs: 93
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 110
Type:symfony-bundle
Requires
- php: >=5.3.2
- knplabs/knp-snappy: *
- symfony/framework-bundle: >=2.0.0
This package is auto-updated.
Last update: 2020-02-07 20:53:15 UTC
README
Snappy is a PHP (5.3+) wrapper for the wkhtmltopdf conversion utility. It allows you to generate either pdf or image files from your html documents, using the webkit engine.
The KnpSnappyBundle provides a simple integration for your Symfony project.
Installation
With composer, add:
{ "require": { "xeurun/knp-snappy-bundle": "dev-master" } }
Then enable it in your kernel:
// app/AppKernel.php public function registerBundles() { $bundles = array( //... new Knp\Bundle\SnappyBundle\KnpSnappyBundle(), //...
Configuration
If you need to change the binaries, change the instance options or even disable one or both services, you can do it through the configuration.
# app/config/config.yml knp_snappy: pdf: enabled: true binary: /usr/local/bin/wkhtmltopdf #"\"C:\\Program Files\\wkhtmltopdf\\bin\\wkhtmltopdf.exe\"" for Windows users options: [] image: enabled: true binary: /usr/local/bin/wkhtmltoimage #"\"C:\\Program Files\\wkhtmltopdf\\bin\\wkhtmltoimage.exe\"" for Windows users options: []
If you want to change temporary folder which is sys_get_temp_dir()
by default, you can use
# app/config/config.yml knp_snappy: temporary_folder: %kernel.cache_dir%/snappy
Usage
The bundle registers two services:
- the
knp_snappy.image
service allows you to generate images; - the
knp_snappy.pdf
service allows you to generate pdf files.
Generate an image from an URL
$container->get('knp_snappy.image')->generate('http://www.google.fr', '/path/to/the/image.jpg');
Generate a pdf document from an URL
$container->get('knp_snappy.pdf')->generate('http://www.google.fr', '/path/to/the/file.pdf');
Generate a pdf document from multiple URLs
$container->get('knp_snappy.pdf')->generate(array('http://www.google.fr', 'http://www.knplabs.com', 'http://www.google.com'), '/path/to/the/file.pdf');
Generate a pdf document from a twig view
$this->get('knp_snappy.pdf')->generateFromHtml( $this->renderView( 'MyBundle:Foo:bar.html.twig', array( 'some' => $vars ) ), '/path/to/the/file.pdf' );
Render an image as response from a controller
$html = $this->renderView('MyBundle:Foo:bar.html.twig', array( 'some' => $vars )); return new Response( $this->get('knp_snappy.image')->getOutputFromHtml($html), 200, array( 'Content-Type' => 'image/jpg', 'Content-Disposition' => 'filename="image.jpg"' ) );
Render a pdf document as response from a controller
$html = $this->renderView('MyBundle:Foo:bar.html.twig', array( 'some' => $vars )); return new Response( $this->get('knp_snappy.pdf')->getOutputFromHtml($html), 200, array( 'Content-Type' => 'application/pdf', 'Content-Disposition' => 'attachment; filename="file.pdf"' ) );
Render a pdf document with a relative url inside like css files
$pageUrl = $this->generateUrl('homepage', array(), true); // use absolute path! return new Response( $this->get('knp_snappy.pdf')->getOutput($pageUrl), 200, array( 'Content-Type' => 'application/pdf', 'Content-Disposition' => 'attachment; filename="file.pdf"' ) );
Credits
SnappyBundle and Snappy are based on the awesome wkhtmltopdf. SnappyBundle has been developed by KnpLabs.