django-sri


Namedjango-sri JSON
Version 0.8.0 PyPI version JSON
download
home_pagehttps://github.com/RealOrangeOne/django-sri
SummarySubresource Integrity for Django
upload_time2025-01-21 09:09:14
maintainerNone
docs_urlNone
authorJake Howard
requires_python>=3.9
licenseBSD
keywords django subresource integrity sri
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Django SRI

![CI](https://github.com/RealOrangeOne/django-sri/workflows/CI/badge.svg)
![PyPI](https://img.shields.io/pypi/v/django-sri.svg)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/django-sri.svg)
![PyPI - Status](https://img.shields.io/pypi/status/django-sri.svg)
![PyPI - License](https://img.shields.io/pypi/l/django-sri.svg)


[Subresource Integrity](https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity) for Django.


## Installation

```
pip install django-sri
```

And add `sri` to your `INSTALLED_APPS`.

## Usage

### Template Tags

__Note__: By default, integrity hashes are not output when `DEBUG` is `True`, as static files change a lot during local development. To override this, set `USE_SRI` to `True`.

`django-sri` is designed to primarily be used through template tags:

```html
{% load sri %}

{% sri_static "index.js" %} <!-- Will output "<script src='/static/index.js' integrity='sha256-...'></script>" -->
{% sri_static "index.css" %} <!-- Will output "<link rel='stylesheet' href='/static/index.css' integrity='sha256-...'/>" -->
```

For performance, the hashes of files are caches in Django's [caching framework](https://docs.djangoproject.com/en/dev/topics/cache/). It will attempt to use the "sri" cache, but fall back to "default" if it doesn't exist. The cache keys are the hash of the file path in the specified algorithm in hex. Caches are stored for as long as `DEFAULT_TIMEOUT` is set to.

#### Algorithms

The SRI standard supports 3 algorithms: sha256, sha384 and sha512. By default, SHA256 is used. To override this, supply an additional `algorithm` argument to the `sri` template tag (or the specific ones):

```html
{% load sri %}

{% sri_static "index.js" algorithm="sha512" %} <!-- Will output "<script src='/static/index.js' integrity='sha512-...'></script>" -->
```

The default algorithm can be changed by setting `SRI_ALGORITHM` to the required algorithm.

#### Additional attributes

To add additional attributes to the output tag (such as `async` / `defer`), specify them as additional arguments to the template tag:

```html
{% load sri %}

{% sri_static "index.js" 'defer' 'async'%}
{% sri_static "index.woff2" preload as="font" %}
```

#### Just the integrity value

To retrieve just the integrity hash (the contents of the `integrity` attribute), you can use the `{% sri_integrity_static %}` tag, which supports the same arguments as the other tags.

```html
{% load sri %}

{% sri_integrity_static "index.js" "sha512" %} <!-- Will output "sha512-..." -->
```

#### Supported Files

For automatic tag output, the following files are supported:

- `.js`
- `.css`

Unknown extensions will emit a `link` tag with the URL as the `href` attribute.

`sri_integrity_static` is unaffected by this limitation.

### API

```python
from pathlib import Path
from sri import calculate_integrity, calculate_integrity_of_static, Algorithm

calculate_integrity(Path("/path/to/myfile.txt"))  # "sha256-..."
calculate_integrity_of_static("index.js")  # "sha256-..."

calculate_integrity_of_static("index.js", Algorithm.SHA512)  # "sha512-..."
```

### _"Does this work with [whitenoise](https://whitenoise.evans.io/en/stable/) or alike?"_

Yes. `django-sri` outputs the static file URL in the same way the builtin `static` template tag does. This means the correct cachebusted URLs are output.

When using a manifest `STATICFILES_STORAGE`, `django-sri` will automatically retrieve the hashed and post-processed file as opposed to the original.

### `jinja2`

Support for `jinja2` templates is provided using the `sri.jinja2.sri` extension, which adds the documented Django template tags as global functions. These functions work identically to the Django template versions.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/RealOrangeOne/django-sri",
    "name": "django-sri",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "django subresource integrity sri",
    "author": "Jake Howard",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/72/4e/b2e78d217ba14982ae69e521d5a7ed6870d956fdabb561c429ee22e76d5d/django_sri-0.8.0.tar.gz",
    "platform": null,
    "description": "# Django SRI\n\n![CI](https://github.com/RealOrangeOne/django-sri/workflows/CI/badge.svg)\n![PyPI](https://img.shields.io/pypi/v/django-sri.svg)\n![PyPI - Python Version](https://img.shields.io/pypi/pyversions/django-sri.svg)\n![PyPI - Status](https://img.shields.io/pypi/status/django-sri.svg)\n![PyPI - License](https://img.shields.io/pypi/l/django-sri.svg)\n\n\n[Subresource Integrity](https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity) for Django.\n\n\n## Installation\n\n```\npip install django-sri\n```\n\nAnd add `sri` to your `INSTALLED_APPS`.\n\n## Usage\n\n### Template Tags\n\n__Note__: By default, integrity hashes are not output when `DEBUG` is `True`, as static files change a lot during local development. To override this, set `USE_SRI` to `True`.\n\n`django-sri` is designed to primarily be used through template tags:\n\n```html\n{% load sri %}\n\n{% sri_static \"index.js\" %} <!-- Will output \"<script src='/static/index.js' integrity='sha256-...'></script>\" -->\n{% sri_static \"index.css\" %} <!-- Will output \"<link rel='stylesheet' href='/static/index.css' integrity='sha256-...'/>\" -->\n```\n\nFor performance, the hashes of files are caches in Django's [caching framework](https://docs.djangoproject.com/en/dev/topics/cache/). It will attempt to use the \"sri\" cache, but fall back to \"default\" if it doesn't exist. The cache keys are the hash of the file path in the specified algorithm in hex. Caches are stored for as long as `DEFAULT_TIMEOUT` is set to.\n\n#### Algorithms\n\nThe SRI standard supports 3 algorithms: sha256, sha384 and sha512. By default, SHA256 is used. To override this, supply an additional `algorithm` argument to the `sri` template tag (or the specific ones):\n\n```html\n{% load sri %}\n\n{% sri_static \"index.js\" algorithm=\"sha512\" %} <!-- Will output \"<script src='/static/index.js' integrity='sha512-...'></script>\" -->\n```\n\nThe default algorithm can be changed by setting `SRI_ALGORITHM` to the required algorithm.\n\n#### Additional attributes\n\nTo add additional attributes to the output tag (such as `async` / `defer`), specify them as additional arguments to the template tag:\n\n```html\n{% load sri %}\n\n{% sri_static \"index.js\" 'defer' 'async'%}\n{% sri_static \"index.woff2\" preload as=\"font\" %}\n```\n\n#### Just the integrity value\n\nTo retrieve just the integrity hash (the contents of the `integrity` attribute), you can use the `{% sri_integrity_static %}` tag, which supports the same arguments as the other tags.\n\n```html\n{% load sri %}\n\n{% sri_integrity_static \"index.js\" \"sha512\" %} <!-- Will output \"sha512-...\" -->\n```\n\n#### Supported Files\n\nFor automatic tag output, the following files are supported:\n\n- `.js`\n- `.css`\n\nUnknown extensions will emit a `link` tag with the URL as the `href` attribute.\n\n`sri_integrity_static` is unaffected by this limitation.\n\n### API\n\n```python\nfrom pathlib import Path\nfrom sri import calculate_integrity, calculate_integrity_of_static, Algorithm\n\ncalculate_integrity(Path(\"/path/to/myfile.txt\"))  # \"sha256-...\"\ncalculate_integrity_of_static(\"index.js\")  # \"sha256-...\"\n\ncalculate_integrity_of_static(\"index.js\", Algorithm.SHA512)  # \"sha512-...\"\n```\n\n### _\"Does this work with [whitenoise](https://whitenoise.evans.io/en/stable/) or alike?\"_\n\nYes. `django-sri` outputs the static file URL in the same way the builtin `static` template tag does. This means the correct cachebusted URLs are output.\n\nWhen using a manifest `STATICFILES_STORAGE`, `django-sri` will automatically retrieve the hashed and post-processed file as opposed to the original.\n\n### `jinja2`\n\nSupport for `jinja2` templates is provided using the `sri.jinja2.sri` extension, which adds the documented Django template tags as global functions. These functions work identically to the Django template versions.\n",
    "bugtrack_url": null,
    "license": "BSD",
    "summary": "Subresource Integrity for Django",
    "version": "0.8.0",
    "project_urls": {
        "Homepage": "https://github.com/RealOrangeOne/django-sri"
    },
    "split_keywords": [
        "django",
        "subresource",
        "integrity",
        "sri"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "6d3eb2ab51629acf64d43f72bd9300d99d4819abe8b560d0508827008f474d6a",
                "md5": "b6b519fc81ecbf299af0425a81573880",
                "sha256": "88448529441bc2205dabc3c603bdef49762acd0371809fc8849a13a2242ceb08"
            },
            "downloads": -1,
            "filename": "django_sri-0.8.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "b6b519fc81ecbf299af0425a81573880",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 7842,
            "upload_time": "2025-01-21T09:09:13",
            "upload_time_iso_8601": "2025-01-21T09:09:13.421144Z",
            "url": "https://files.pythonhosted.org/packages/6d/3e/b2ab51629acf64d43f72bd9300d99d4819abe8b560d0508827008f474d6a/django_sri-0.8.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "724eb2e78d217ba14982ae69e521d5a7ed6870d956fdabb561c429ee22e76d5d",
                "md5": "4b276a01a6f32da792b57ac7b5d25981",
                "sha256": "acce5c4ac29d7355074acbd2807863baa42dbecffe2b23c0eedd6a5aa203ed5c"
            },
            "downloads": -1,
            "filename": "django_sri-0.8.0.tar.gz",
            "has_sig": false,
            "md5_digest": "4b276a01a6f32da792b57ac7b5d25981",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 8268,
            "upload_time": "2025-01-21T09:09:14",
            "upload_time_iso_8601": "2025-01-21T09:09:14.951138Z",
            "url": "https://files.pythonhosted.org/packages/72/4e/b2e78d217ba14982ae69e521d5a7ed6870d956fdabb561c429ee22e76d5d/django_sri-0.8.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-21 09:09:14",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "RealOrangeOne",
    "github_project": "django-sri",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "django-sri"
}
        
Elapsed time: 0.52281s