Metadata-Version: 2.1
Name: django-weasyprint
Version: 2.2.0
Summary: Django WeasyPrint CBV
Home-page: https://github.com/fdemmer/django-weasyprint
Download-URL: https://github.com/fdemmer/django-weasyprint/archive/v2.2.0.tar.gz
Author: Florian Demmer
Author-email: fdemmer@gmail.com
License: Apache-2.0
Project-URL: Changelog, https://github.com/fdemmer/django-weasyprint/blob/v2.2.0/CHANGELOG.md
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Framework :: Django :: 3.2
Classifier: Framework :: Django :: 4.0
Classifier: Framework :: Django :: 4.1
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.6
License-File: LICENSE

django-weasyprint
=================

A `Django`_ class-based view generating PDF responses using `WeasyPrint`_.

|TravisCI Build| |PyPI Download| |PyPI Python Versions| |PyPI License|

.. |PyPI Download| image:: https://img.shields.io/pypi/v/django-weasyprint.svg
   :target: https://pypi.python.org/pypi/django-weasyprint/

.. |PyPI Python Versions| image:: https://img.shields.io/pypi/pyversions/django-weasyprint.svg
   :target: https://pypi.python.org/pypi/django-weasyprint/

.. |PyPI License| image:: https://img.shields.io/pypi/l/django-weasyprint.svg
   :target: https://pypi.python.org/pypi/django-weasyprint/

.. |TravisCI Build| image:: https://app.travis-ci.com/fdemmer/django-weasyprint.svg?branch=main
    :target: https://app.travis-ci.com/github/fdemmer/django-weasyprint


Installation
------------

Install and update using `pip`_:

.. code-block:: text

    pip install -U django-weasyprint

`WeasyPrint`_ is automatically installed as a dependency of this package.
If you run into any problems be sure to check their `install instructions
<https://weasyprint.readthedocs.io/en/latest/install.html>`_ for help!

.. tip::

   In version 53 WeasyPrint switched to `pydyf`_ as PDF generator instead of Cairo.
   With that change PNG output was dropped and you might encounter other
   changes in the generated PDF.

   You can continue using WeasyPrint/Cairo by installing django-weasyprint 1.x!


Usage
-----

Use ``WeasyTemplateView`` as class based view base class or the just the
mixin ``WeasyTemplateResponseMixin`` on a ``TemplateView`` (or subclass
thereof).


Example
-------

.. code:: python

    # views.py
    import functools

    from django.conf import settings
    from django.views.generic import DetailView

    from django_weasyprint import WeasyTemplateResponseMixin
    from django_weasyprint.views import WeasyTemplateResponse
    from django_weasyprint.utils import django_url_fetcher


    class MyDetailView(DetailView):
        # vanilla Django DetailView
        template_name = 'mymodel.html'

    def custom_url_fetcher(url, *args, **kwargs):
        # rewrite requests for CDN URLs to file path in STATIC_ROOT to use local file
        cloud_storage_url = 'https://s3.amazonaws.com/django-weasyprint/static/'
        if url.startswith(cloud_storage_url):
            url = 'file://' + url.replace(cloud_storage_url, settings.STATIC_URL)
        return django_url_fetcher(url, *args, **kwargs)

    class CustomWeasyTemplateResponse(WeasyTemplateResponse):
        # customized response class to pass a kwarg to URL fetcher
        def get_url_fetcher(self):
            # disable host and certificate check
            context = ssl.create_default_context()
            context.check_hostname = False
            context.verify_mode = ssl.CERT_NONE
            return functools.partial(custom_url_fetcher, ssl_context=context)

    class PrintView(WeasyTemplateResponseMixin, MyDetailView):
        # output of MyDetailView rendered as PDF with hardcoded CSS
        pdf_stylesheets = [
            settings.STATIC_ROOT + 'css/app.css',
        ]
        # show pdf in-line (default: True, show download dialog)
        pdf_attachment = False
        # custom response class to configure url-fetcher
        response_class = CustomWeasyTemplateResponse

    class DownloadView(WeasyTemplateResponseMixin, MyDetailView):
        # suggested filename (is required for attachment/download!)
        pdf_filename = 'foo.pdf'

    class DynamicNameView(WeasyTemplateResponseMixin, MyDetailView):
        # dynamically generate filename
        def get_pdf_filename(self):
            return 'foo-{at}.pdf'.format(
                at=timezone.now().strftime('%Y%m%d-%H%M'),
            )

.. code:: html

    <!-- mymodel.html -->
    <!doctype html>
    <html>
        <head>
            <!-- Use "static" template tag and configure STATIC_URL as usual. -->
            <link rel="stylesheet" href="{% static 'css/app.css' %}" />
        </head>
        <body>
            Hello PDF-world!
        </body>
    </html>


Settings
--------

By default ``WeasyTemplateResponse`` determines the ``base_url`` for
`weasyprint.HTML`_ and `weasyprint.CSS`_ automatically using the request path.

To disable that set ``WEASYPRINT_BASEURL`` to a fixed value, e.g.:

.. code:: python

    # Disable prefixing relative URLs with request.path, handle as absolute file paths
    WEASYPRINT_BASEURL = '/'


Changelog
---------

See `CHANGELOG.md`_


Links
-----

* Releases: https://pypi.python.org/pypi/django-weasyprint
* Issue tracker: https://github.com/fdemmer/django-weasyprint/issues
* Code: https://github.com/fdemmer/django-weasyprint


.. _pip: https://pip.pypa.io/en/stable/quickstart
.. _Django: https://www.djangoproject.com
.. _WeasyPrint: http://weasyprint.org
.. _pydyf: https://doc.courtbouillon.org/pydyf/stable/

.. _weasyprint.HTML: https://doc.courtbouillon.org/weasyprint/stable/api_reference.html?highlight=base_url#weasyprint.HTML
.. _weasyprint.CSS: https://doc.courtbouillon.org/weasyprint/stable/api_reference.html?#weasyprint.CSS

.. _CHANGELOG.md: https://github.com/fdemmer/django-weasyprint/blob/main/CHANGELOG.md
