Metadata-Version: 2.4
Name: django-absoluteuri
Version: 2.0.0
Summary: Absolute URI functions and template tags for Django
Home-page: https://github.com/fusionbox/django-absoluteuri
Author: Fusionbox, Inc.
Author-email: programmers@fusionbox.com
License: Apache 2.0
Keywords: django-absoluteuri
Classifier: Development Status :: 5 - Production/Stable
Classifier: Framework :: Django
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
License-File: LICENSE
Requires-Dist: Django>=4.2
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: home-page
Dynamic: keywords
Dynamic: license
Dynamic: license-file
Dynamic: requires-dist
Dynamic: summary

django-absoluteuri
==================

.. image:: https://github.com/fusionbox/django-absoluteuri/actions/workflows/tests.yml/badge.svg
   :target: https://github.com/fusionbox/django-absoluteuri/actions/workflows/tests.yml
   :alt: Tests

Absolute URI functions and template tags for Django.


Why
---

There are times when you need to output an absolute URL (for example, inside an
email), but you don't always have access to the request. These utilities use
the Sites Framework if available in order to create absolute URIs.


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

Install django-absoluteuri::

    pip install django-absoluteuri

Then add it to your ``INSTALLED_APPS``::

    INSTALLED_APPS = (
        # ...
        'django.contrib.sites',
        'absoluteuri',
    )

django-absoluteuri requires the `Sites Framework
<https://docs.djangoproject.com/en/dev/ref/contrib/sites/>`_ to be in
``INSTALLED_APPS`` well and configured as well.


Settings
--------

The protocol of the uris returned by this library defaults to ``http``.  You
can specify the protocol with the ``ABSOLUTEURI_PROTOCOL`` setting.

.. code:: python

    # settings.py
    ABSOLUTEURI_PROTOCOL = 'https'

    # Elsewhere
    >>> absoluteuri.build_absolute_uri('/some/path/')
    'https://example.com/some/path/'


Template Tags
-------------

There are two template tags, ``absoluteuri`` and ``absolutize``.
``absoluteuri`` works just like the ``url`` tag, but that it outputs absolute
URLs.

.. code:: html+django

    {% load absoluteuri %}

    <a href="{% absoluteuri 'my_view' kwarg1='foo' kwarg2='bar' %}">click here</a>


``absolutize`` will take a relative URL and return an absolute URL.

.. code:: html+django

    {% load absoluteuri %}

    <a href="{% absolutize url_from_context %}">click here</a>


Filter
------

Sometimes instead of template tags, it's easier to use filters. You can do that
as well.

.. code:: html+django

   {% load absoluteuri %}

   <a href="{{ my_object.get_absolute_url|absolutize }}">click here</a>

But there are situations where tag can not be used but filter can.

.. code:: html+django

   {% load absoluteuri %}

   {% include "some-other-template.html" with url=my_object.get_absolute_url|absolutize %}


Functions
---------

There are also two functions that django-absoluteuri provides,
``build_absolute_uri`` and ``reverse``, which are equivalents of
``request.build_absolute_url`` and ``urlresolvers.reverse``.

.. code:: python

    >>> import absoluteuri

    >>> my_relative_url = '/path/to/somewhere/'
    >>> absoluteuri.build_absolute_uri(my_relative_url)
    'http://example.com/path/to/somewhere/'
    >>> absoluteuri.reverse('viewname', kwargs={'foo': 'bar'})
    'http://example.com/path/to/bar/'


.. :changelog:

Changelog
=========

2.0.0 (2026-02-18)
------------------

- Drop support for Python < 3.8
- Drop support for Django < 4.2.
- Add support for Django 4.2, 5.0, 5.1, 5.2, and 6.0.
- Add support for Python 3.10, 3.11, 3.12, 3.13, and 3.14.


1.3.0 (2018-09-04)
------------------

- Add support for Django 2.1. Remove support for Django < 1.11.


1.2.0 (2016-02-29)
------------------

- Add absolutize filter. This deprecates the absolutize tag. [#4]


1.1.0 (2015-03-23)
------------------

- Added ABSOLUTEURI_PROTOCOL settings. [#1]
- Documented sites framework requirement.


1.0.0 (2015-03-17)
------------------

- First release on PyPI.
