Reverse for 'songlist-pdf' with keyword arguments '{'band_slug': '', 'setlist_slug': ''}' not found. 1 pattern(s) tried: ['bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\Z']
Request Method: | GET |
---|---|
Request URL: | https://ritualspace.net/bands/motometer/setlists/ |
Django Version: | 4.1 |
Exception Type: | NoReverseMatch |
Exception Value: | Reverse for 'songlist-pdf' with keyword arguments '{'band_slug': '', 'setlist_slug': ''}' not found. 1 pattern(s) tried: ['bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\Z'] |
Exception Location: | /home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/urls/resolvers.py, line 803, in _reverse_with_prefix |
Raised during: | setlist.views.SetListDetail |
Python Executable: | /home/fhadmin/.virtualenvs/rsenv/bin/python |
Python Version: | 3.10.13 |
Python Path: | ['/var/www/django/rsta', '/home/fhadmin/.virtualenvs/rsenv/bin', '/usr/lib/python310.zip', '/usr/lib/python3.10', '/usr/lib/python3.10/lib-dynload', '/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages'] |
Server time: | Fri, 29 Mar 2024 06:52:40 -0400 |
In template /var/www/django/rsta/setlist/templates/setlist-admin.html
, error at line 246
236 | <div class="modal-content"> |
---|---|
237 | <div class="modal-header"> |
238 | <h1 class="modal-title fs-5" id="staticBackdropLabel">Modal title</h1> |
239 | <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> |
240 | </div> |
241 | <div class="modal-body"> |
242 | <textarea placeholder="Type your comment here" name="comment_text" id="modal-comment-text" ></textarea> |
243 | </div> |
244 | <div class="modal-footer"> |
245 | <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> |
246 | <button id="ajax-add-comment" class="btn btn-primary" data-href="{% url 'songlist-pdf' band_slug=kwargs.band_slug setlist_slug=kwargs.setlist_slug %}" data-xpct="" data-ypct="" data-commit="{{user.is_staff}}">Add Comment</button> |
247 | |
248 | |
249 | </div> |
250 | </div> |
251 | </div> |
252 | </div> |
253 | |
254 | |
255 | </div> |
256 | {% endblock %} |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/core/handlers/exception.py
, line 55, in inner
return inner
else:
@wraps(get_response)
def inner(request):
try:
response = get_response(request)…
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | NoReverseMatch("Reverse for 'songlist-pdf' with keyword arguments '{'band_slug': '', 'setlist_slug': ''}' not found. 1 pattern(s) tried: ['bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\\\Z']") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f703c7eeb00>> |
request | <WSGIRequest: GET '/bands/motometer/setlists/'> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/core/handlers/base.py
, line 220, in _get_response
self.check_response(
response,
middleware_method,
name="%s.process_template_response"
% (middleware_method.__self__.__class__.__name__,),
)
try:
response = response.render()…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
return response
Variable | Value |
---|---|
callback | <function View.as_view.<locals>.view at 0x7f70391639a0> |
callback_args | () |
callback_kwargs | {'band_slug': 'motometer'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/bands/motometer/setlists/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f703c7eeb00> |
wrapped_callback | <function View.as_view.<locals>.view at 0x7f70391639a0> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/response.py
, line 114, in render
If the content has already been rendered, this is a no-op.
Return the baked response instance.
"""
retval = self
if not self._is_rendered:
self.content = self.rendered_content…
for post_callback in self._post_render_callbacks:
newretval = post_callback(retval)
if newretval is not None:
retval = newretval
return retval
Variable | Value |
---|---|
retval | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
self | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/response.py
, line 92, in rendered_content
This *does not* set the final content of the response. To set the
response content, you must either call render(), or set the
content explicitly using the value of this property.
"""
template = self.resolve_template(self.template_name)
context = self.resolve_context(self.context_data)
return template.render(context, self._request)…
def add_post_render_callback(self, callback):
"""Add a new post-rendering callback.
If the response has already been rendered,
invoke the callback immediately.
Variable | Value |
---|---|
context | {'band': <Band: Motometer>, 'band_slug': 'motometer', 'set_select_err': 'No published set lists found for Motometer', 'setlist_error': 'Whatever error', 'setlists': <QuerySet []>, 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>} |
self | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
template | <django.template.backends.django.Template object at 0x7f7038e94a30> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/backends/django.py
, line 62, in render
return self.template.origin
def render(self, context=None, request=None):
context = make_context(
context, request, autoescape=self.backend.engine.autoescape
)
try:
return self.template.render(context)…
except TemplateDoesNotExist as exc:
reraise(exc, self.backend)
def copy_exception(exc, backend=None):
"""
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
request | <WSGIRequest: GET '/bands/motometer/setlists/'> |
self | <django.template.backends.django.Template object at 0x7f7038e94a30> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 175, in render
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
context.template_name = self.name
return self._render(context)…
else:
return self._render(context)
def compile_nodelist(self):
"""
Parse and compile the template source into a nodelist. If debug
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Template template_string="{% extends 'setlist-..."> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Template template_string="{% extends 'setlist-..."> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | [<ExtendsNode: extends 'setlist-base.html'>] |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7f7038e94520> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <ExtendsNode: extends 'setlist-base.html'> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <ExtendsNode: extends 'setlist-base.html'> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/loader_tags.py
, line 157, in render
}
block_context.add_blocks(blocks)
break
# Call Template._render explicitly so the parser context stays
# the same.
with context.render_context.push_state(compiled_parent, isolated_context=False):
return compiled_parent._render(context)…
class IncludeNode(Node):
context_key = "__include_context"
def __init__(
Variable | Value |
---|---|
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>], 'custom_js': [<Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <Block Node: custom_js. Contents: [<TextNode: '\n \n \n // if(naviga'>]>], 'html': [], 'head': [<Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>], 'headplus': [<Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>], 'body': [], 'vuebuilt': [<Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>], 'extra_js': [<Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>]})> |
blocks | {'body': <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, 'content': <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, 'custom_js': <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, 'extra_js': <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, 'head': <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, 'headplus': <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, 'html': <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]>, 'vuebuilt': <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>} |
compiled_parent | <Template template_string="{% load static %}{%..."> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <django.template.defaulttags.LoadNode object at 0x7f7038ecc580> |
self | <ExtendsNode: extends 'setlist-base.html'> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Template template_string="{% load static %}{%..."> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | [<django.template.defaulttags.LoadNode object at 0x7f7038ecc580>, <TextNode: '\n'>, <django.template.defaulttags.LoadNode object at 0x7f7038ecc670>, <TextNode: '\n'>, <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]>, <TextNode: '\n'>] |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7f7038e94eb0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/loader_tags.py
, line 63, in render
push = block = block_context.pop(self.name)
if block is None:
block = self
# Create new block so we can store context without thread-safety issues.
block = type(self)(block.name, block.nodelist)
block.context = context
context["block"] = block
result = block.nodelist.render(context)…
if push is not None:
block_context.push(self.name, push)
return result
def super(self):
if not hasattr(self, "context"):
Variable | Value |
---|---|
block | <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>], 'custom_js': [<Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <Block Node: custom_js. Contents: [<TextNode: '\n \n \n // if(naviga'>]>], 'html': [], 'head': [<Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>], 'headplus': [<Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>], 'body': [], 'vuebuilt': [<Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>], 'extra_js': [<Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>]})> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
push | <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]> |
self | <Block Node: html. Contents: [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | [<TextNode: '\n<!DOCTYPE html>\n<html la'>, <Variable Node: page_title | site_title>, <TextNode: '</title>\n\n '>, <Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>, <TextNode: '\n '>, <Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>, <TextNode: '\n \n</head>\n <body>\n '>, <django.template.defaulttags.CsrfTokenNode object at 0x7f7038eccbb0>, <TextNode: '\n <script>\n const'>, <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]>, <TextNode: '\n \n \n \n\n <script'>, <Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <TextNode: '\n </script>\n </div>\n '>] |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7f7038e94760> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/loader_tags.py
, line 63, in render
push = block = block_context.pop(self.name)
if block is None:
block = self
# Create new block so we can store context without thread-safety issues.
block = type(self)(block.name, block.nodelist)
block.context = context
context["block"] = block
result = block.nodelist.render(context)…
if push is not None:
block_context.push(self.name, push)
return result
def super(self):
if not hasattr(self, "context"):
Variable | Value |
---|---|
block | <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>], 'custom_js': [<Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <Block Node: custom_js. Contents: [<TextNode: '\n \n \n // if(naviga'>]>], 'html': [], 'head': [<Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>], 'headplus': [<Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>], 'body': [], 'vuebuilt': [<Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>], 'extra_js': [<Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>]})> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
push | <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]> |
self | <Block Node: body. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n '>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>, <TextNode: '\n '>, <Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>, <TextNode: '\n\n '>] |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7f7038e94af0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/loader_tags.py
, line 63, in render
push = block = block_context.pop(self.name)
if block is None:
block = self
# Create new block so we can store context without thread-safety issues.
block = type(self)(block.name, block.nodelist)
block.context = context
context["block"] = block
result = block.nodelist.render(context)…
if push is not None:
block_context.push(self.name, push)
return result
def super(self):
if not hasattr(self, "context"):
Variable | Value |
---|---|
block | <Block Node: content. Contents: [<TextNode: '\n<style>\n .accordion{\n'>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n<div class="top-space mt'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n <div id="pdf_contr'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n \n '>, <django.template.defaulttags.CommentNode object at 0x7f7038eb3df0>, <TextNode: '\n <div id="pdf_con'>, <Variable Node: song_part.part.get_part_type_display>, <TextNode: '<span class="ms-2 bg-info'>, <Variable Node: song_part.role>, <TextNode: '</span></span>\n '>, <django.template.defaulttags.CommentNode object at 0x7f7038ebc070>, <TextNode: '\n \n </div>\n</div>\n\n<d'>, <TextNode: '\n \n '>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n <!-- Button trigger '>, <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None>, <TextNode: '" data-xpct="" data-ypct='>, <Variable Node: user.is_staff>, <TextNode: '">Add Comment</button>\n\n '>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]>], 'custom_js': [<Block Node: custom_js. Contents: [<TextNode: "\n console.log('any c">]>, <Block Node: custom_js. Contents: [<TextNode: '\n \n \n // if(naviga'>]>], 'html': [], 'head': [<Block Node: head. Contents: [<TextNode: '\n\n '>, <TextNode: '\n <style>\n '>, <IncludeNode: template=<FilterExpression "'css/setlist-styles.css'">>, <TextNode: '\n </style>\n \n \n '>]>], 'headplus': [<Block Node: headplus. Contents: [<TextNode: '\n <!-- additional he'>]>], 'body': [], 'vuebuilt': [<Block Node: vuebuilt. Contents: [<TextNode: '\n <!-- built files w'>]>], 'extra_js': [<Block Node: extra_js. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/setlist-js.js'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'js/anyjax.js'">>, <TextNode: '\n '>]>]})> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
push | <Block Node: content. Contents: [<TextNode: '\n<style>\n .accordion{\n'>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n<div class="top-space mt'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n <div id="pdf_contr'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n \n '>, <django.template.defaulttags.CommentNode object at 0x7f7038eb3df0>, <TextNode: '\n <div id="pdf_con'>, <Variable Node: song_part.part.get_part_type_display>, <TextNode: '<span class="ms-2 bg-info'>, <Variable Node: song_part.role>, <TextNode: '</span></span>\n '>, <django.template.defaulttags.CommentNode object at 0x7f7038ebc070>, <TextNode: '\n \n </div>\n</div>\n\n<d'>, <TextNode: '\n \n '>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n <!-- Button trigger '>, <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None>, <TextNode: '" data-xpct="" data-ypct='>, <Variable Node: user.is_staff>, <TextNode: '">Add Comment</button>\n\n '>]> |
self | <Block Node: content. Contents: [<TextNode: '\n Has some content? '>, <Variable Node: block.super>, <TextNode: '\n '>]> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | [<TextNode: '\n<style>\n .accordion{\n'>, <IncludeNode: template=<FilterExpression "'navbar-band.html'">>, <TextNode: '\n<div class="top-space mt'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n <div id="pdf_contr'>, <IfNode>, <TextNode: '</h5>\n <button type="b'>, <IfNode>, <TextNode: '\n \n '>, <django.template.defaulttags.CommentNode object at 0x7f7038eb3df0>, <TextNode: '\n <div id="pdf_con'>, <Variable Node: song_part.part.get_part_type_display>, <TextNode: '<span class="ms-2 bg-info'>, <Variable Node: song_part.role>, <TextNode: '</span></span>\n '>, <django.template.defaulttags.CommentNode object at 0x7f7038ebc070>, <TextNode: '\n \n </div>\n</div>\n\n<d'>, <TextNode: '\n \n '>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n <!-- Button trigger '>, <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None>, <TextNode: '" data-xpct="" data-ypct='>, <Variable Node: user.is_staff>, <TextNode: '">Add Comment</button>\n\n '>] |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self]))…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7f7038e94190> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
node | <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
self | <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None> |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/template/defaulttags.py
, line 472, in render
current_app = context.request.resolver_match.namespace
except AttributeError:
current_app = None
# Try to look up the URL. If it fails, raise NoReverseMatch unless the
# {% url ... as var %} construct is used, in which case return nothing.
url = ""
try:
url = reverse(view_name, args=args, kwargs=kwargs, current_app=current_app)…
except NoReverseMatch:
if self.asvar is None:
raise
if self.asvar:
context[self.asvar] = url
Variable | Value |
---|---|
NoReverseMatch | <class 'django.urls.exceptions.NoReverseMatch'> |
args | [] |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'band_slug': 'motometer', 'view': <setlist.views.SetListDetail object at 0x7f7038da4850>, 'setlist_error': 'Whatever error', 'band': <Band: Motometer>, 'setlists': <QuerySet []>, 'set_select_err': 'No published set lists found for Motometer'}] |
current_app | '' |
kwargs | {'band_slug': '', 'setlist_slug': ''} |
reverse | <function reverse at 0x7f703b1bf0a0> |
self | <URLNode view_name=''songlist-pdf'' args=[] kwargs={'band_slug': <FilterExpression 'kwargs.band_slug'>, 'setlist_slug': <FilterExpression 'kwargs.setlist_slug'>} as=None> |
url | '' |
view_name | 'songlist-pdf' |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/urls/base.py
, line 88, in reverse
else:
raise NoReverseMatch("%s is not a registered namespace" % key)
if ns_pattern:
resolver = get_ns_resolver(
ns_pattern, resolver, tuple(ns_converters.items())
)
return resolver._reverse_with_prefix(view, prefix, *args, **kwargs)…
reverse_lazy = lazy(reverse, str)
def clear_url_caches():
Variable | Value |
---|---|
args | [] |
current_app | '' |
current_path | None |
kwargs | {'band_slug': '', 'setlist_slug': ''} |
ns_converters | {} |
ns_pattern | '' |
path | [] |
prefix | '/' |
resolved_path | [] |
resolver | <URLResolver 'rsta.urls' (None:None) '^/'> |
urlconf | 'rsta.urls' |
view | 'songlist-pdf' |
viewname | 'songlist-pdf' |
/home/fhadmin/.virtualenvs/rsenv/lib/python3.10/site-packages/django/urls/resolvers.py
, line 803, in _reverse_with_prefix
patterns,
)
else:
msg = (
"Reverse for '%(view)s' not found. '%(view)s' is not "
"a valid view function or pattern name." % {"view": lookup_view_s}
)
raise NoReverseMatch(msg)…
Variable | Value |
---|---|
_prefix | '/' |
arg_msg | "keyword arguments '{'band_slug': '', 'setlist_slug': ''}'" |
args | () |
candidate_pat | '/bands/%(band_slug)s/%(setlist_slug)s/pdf/' |
candidate_subs | {'band_slug': '', 'setlist_slug': ''} |
converters | {'band_slug': <django.urls.converters.StringConverter object at 0x7f703b1c4ac0>, 'setlist_slug': <django.urls.converters.StringConverter object at 0x7f703b1c4ac0>} |
defaults | {} |
k | 'setlist_slug' |
kwargs | {'band_slug': '', 'setlist_slug': ''} |
lookup_view | 'songlist-pdf' |
lookup_view_s | 'songlist-pdf' |
m | None |
match | True |
matches | True |
msg | ("Reverse for 'songlist-pdf' with keyword arguments '{'band_slug': '', " "'setlist_slug': ''}' not found. 1 pattern(s) tried: " "['bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\\\Z']") |
n | None |
params | ['band_slug', 'setlist_slug'] |
pattern | 'bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\Z' |
patterns | ['bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\Z'] |
possibilities | [([('bands/%(band_slug)s/%(setlist_slug)s/pdf/', ['band_slug', 'setlist_slug'])], 'bands/(?P<band_slug>[^/]+)/(?P<setlist_slug>[^/]+)/pdf/\\Z', {}, {'band_slug': <django.urls.converters.StringConverter object at 0x7f703b1c4ac0>, 'setlist_slug': <django.urls.converters.StringConverter object at 0x7f703b1c4ac0>})] |
possibility | [('bands/%(band_slug)s/%(setlist_slug)s/pdf/', ['band_slug', 'setlist_slug'])] |
result | 'bands/%(band_slug)s/%(setlist_slug)s/pdf/' |
self | <URLResolver 'rsta.urls' (None:None) '^/'> |
text_candidate_subs | {'band_slug': '', 'setlist_slug': ''} |
v | '' |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
CSRF_COOKIE | 'MtrtucI2cPMtDCJUC1y0gjrqiaU1SQ8s' |
CSRF_COOKIE_NEEDS_UPDATE | True |
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'ritualspace.net' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '54.147.30.127' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '54.147.30.127' |
PATH_INFO | '/bands/motometer/setlists/' |
QUERY_STRING | '' |
RAW_URI | '/bands/motometer/setlists/' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'ritualspace.net' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/20.1.0' |
gunicorn.socket | <socket.socket fd=4, family=AddressFamily.AF_UNIX, type=SocketKind.SOCK_STREAM, proto=0, laddr=/run/gunicorn-rs.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f7038da73d0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f7038da7e80> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
rsta.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['ritualspace.net', 'localhost'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | PosixPath('/var/www/django/rsta') |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_MASKED | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_HEALTH_CHECKS': False, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'HOST': 'localhost', 'NAME': 'rsdb', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'rsdjadmin'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_AUTO_FIELD | 'django.db.models.BigAutoField' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_EXCEPTION_REPORTER | 'django.views.debug.ExceptionReporter' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'jpmixins', 'setlist', 'charts', 'adminsortable2', 'timer'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ar-dz', 'Algerian Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('cs', 'Czech'), ('cy', 'Welsh'), ('da', 'Danish'), ('de', 'German'), ('dsb', 'Lower Sorbian'), ('el', 'Greek'), ('en', 'English'), ('en-au', 'Australian English'), ('en-gb', 'British English'), ('eo', 'Esperanto'), ('es', 'Spanish'), ('es-ar', 'Argentinian Spanish'), ('es-co', 'Colombian Spanish'), ('es-mx', 'Mexican Spanish'), ('es-ni', 'Nicaraguan Spanish'), ('es-ve', 'Venezuelan Spanish'), ('et', 'Estonian'), ('eu', 'Basque'), ('fa', 'Persian'), ('fi', 'Finnish'), ('fr', 'French'), ('fy', 'Frisian'), ('ga', 'Irish'), ('gd', 'Scottish Gaelic'), ('gl', 'Galician'), ('he', 'Hebrew'), ('hi', 'Hindi'), ('hr', 'Croatian'), ('hsb', 'Upper Sorbian'), ('hu', 'Hungarian'), ('hy', 'Armenian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('ig', 'Igbo'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('ky', 'Kyrgyz'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('ms', 'Malay'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'en-us' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '' |
MEDIA_URL | '/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'rsta.urls' |
SECRET_KEY | '********************' |
SECRET_KEY_FALLBACKS | '********************' |
SECURE_CONTENT_TYPE_NOSNIFF | True |
SECURE_CROSS_ORIGIN_OPENER_POLICY | 'same-origin' |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 1209600 |
SESSION_COOKIE_DOMAIN | None |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SAMESITE | 'Lax' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'rsta.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
STATICFILES_DIRS | [] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | 'static/' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/var/www/django/rsta/templates'], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages']}}] |
TEMPLATES_DIR | '/var/www/django/rsta/templates' |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'America/New_York' |
USE_DEPRECATED_PYTZ | False |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | False |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'rsta.wsgi.application' |
X_FRAME_OPTIONS | 'DENY' |
YEAR_MONTH_FORMAT | 'F Y' |
You’re seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.