File: csp.py

package info (click to toggle)
python-django-csp 3.8-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 300 kB
  • sloc: python: 935; makefile: 135; sh: 6
file content (42 lines) | stat: -rw-r--r-- 1,275 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
from django import template
from django.template.base import token_kwargs

from csp.utils import build_script_tag

register = template.Library()


def _unquote(s):
    """Helper func that strips single and double quotes from inside strings"""
    return s.replace('"', "").replace("'", "")


@register.tag(name="script")
def script(parser, token):
    # Parse out any keyword args
    token_args = token.split_contents()
    kwargs = token_kwargs(token_args[1:], parser)

    nodelist = parser.parse(("endscript",))
    parser.delete_first_token()

    return NonceScriptNode(nodelist, **kwargs)


class NonceScriptNode(template.Node):
    def __init__(self, nodelist, **kwargs):
        self.nodelist = nodelist
        self.script_attrs = {}
        for k, v in kwargs.items():
            self.script_attrs[k] = self._get_token_value(v)

    def _get_token_value(self, t):
        return _unquote(t.token) if getattr(t, "token", None) else None

    def render(self, context):
        output = self.nodelist.render(context).strip()
        request = context.get("request")
        nonce = request.csp_nonce if hasattr(request, "csp_nonce") else ""
        self.script_attrs.update({"nonce": nonce, "content": output})

        return build_script_tag(**self.script_attrs)