Reverse for 'cat' with arguments '('',)' not found. 2 pattern(s) tried: ['category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\Z', 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\Z']
Request Method: | GET |
---|---|
Request URL: | https://tvgist.com/item/win-free-stuff-provided-by-victorinox/ |
Django Version: | 4.2.3 |
Exception Type: | NoReverseMatch |
Exception Value: | Reverse for 'cat' with arguments '('',)' not found. 2 pattern(s) tried: ['category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\Z', 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\Z'] |
Exception Location: | /home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/urls/resolvers.py, line 828, in _reverse_with_prefix |
Raised during: | website.views.item |
Python Executable: | /home/alex/tvgist-django/tvg/bin/python3 |
Python Version: | 3.10.12 |
Python Path: | ['/home/alex/tvgist-django/tvgist', '/home/alex/tvgist-django/tvg/bin', '/usr/lib/python310.zip', '/usr/lib/python3.10', '/usr/lib/python3.10/lib-dynload', '/home/alex/tvgist-django/tvg/lib/python3.10/site-packages'] |
Server time: | Thu, 28 Mar 2024 17:11:55 +0000 |
In template /home/alex/tvgist-django/tvgist/website/templates/website/item.html
, error at line 8
1 | {% extends 'website/base.html' %} |
---|---|
2 | {% load website_extras %} |
3 | {% block title %} |
4 | {% include 'website/item-head.html' %} |
5 | {% endblock title %} |
6 | {% block main %} |
7 | <nav class="breadcrumbs"><a rel="home" href="/">Home</a>{% if item.cats.count > 1 %} › <a rel="category" href="{% url 'cat' item.cats.first.slug %}">{{ item.cats.first.title }}</a>{% endif %} › |
8 | <a rel="category" href="{% url 'cat' item.cats.last.slug %}">{{ item.cats.last.title }}</a> › <b>{{item.title}}</b></nav> |
9 | <h1>{{ item.title }}</h1> |
10 | {% if item.date_upd == None %} |
11 | <div class="header-meta">Added On |
12 | <time datetime="{{item.date_publ|date:'c'}}" itemprop="datePublished" title="{{ item.date_publ }}">{{ item.date_publ|date:'r' }}</time> |
13 | {% else %} |
14 | <div class="header-meta">Updated On |
15 | <time datetime="{{item.date_upd|date:'c'}}" itemprop="dateUpdated" title="{{ item.date_upd }}">{{ item.date_upd|date:'r' }}</time> |
16 | {% endif %}</div> |
17 | <div class="item-top-ad">{% include 'website/top-ad.html' %}</div> |
18 | <section class="description"> |
/home/alex/tvgist-django/tvg/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 'cat' with arguments '('',)' not found. 2 pattern(s) tried: ['category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\\\Z', 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\\\Z']") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7fe7d4eb6080>> |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/handlers/base.py
, line 197, in _get_response
if response is None:
wrapped_callback = self.make_view_atomic(callback)
# If it is an asynchronous view, run it in a subthread.
if iscoroutinefunction(wrapped_callback):
wrapped_callback = async_to_sync(wrapped_callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
# Complain if the view returned None (a common error).
Variable | Value |
---|---|
callback | <function item at 0x7fe7d4589f30> |
callback_args | () |
callback_kwargs | {'slug': 'win-free-stuff-provided-by-victorinox'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7fe7d4eb6080> |
wrapped_callback | <function item at 0x7fe7d4589f30> |
/home/alex/tvgist-django/tvgist/website/views.py
, line 161, in item
'next': next,
'prev': prev,
'related_categories': related_categories,
}
sm(request)
return render(request, 'website/item.html', context)…
def brand(request, slug, page_num=1):
brand = get_object_or_404(Brand, slug=slug)
# Используйте select_related() для загрузки связанных объектов типа и страны
items = brand.item_set.select_related('type', 'country').order_by('-id')
Variable | Value |
---|---|
context | {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>} |
item | <Item: Win Free Stuff Provided by Victorinox> |
next | <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage> |
prev | <Item: Request an Aveda Hair Repair Shampoo for Free> |
related_categories | <QuerySet []> |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
slug | 'win-free-stuff-provided-by-victorinox' |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/shortcuts.py
, line 24, in render
def render(
request, template_name, context=None, content_type=None, status=None, using=None
):
"""
Return an HttpResponse whose content is filled with the result of calling
django.template.loader.render_to_string() with the passed arguments.
"""
content = loader.render_to_string(template_name, context, request, using=using)…
return HttpResponse(content, content_type, status)
def redirect(to, *args, permanent=False, **kwargs):
"""
Return an HttpResponseRedirect to the appropriate URL for the arguments
Variable | Value |
---|---|
content_type | None |
context | {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>} |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
status | None |
template_name | 'website/item.html' |
using | None |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/loader.py
, line 62, in render_to_string
template_name may be a string or a list of strings.
"""
if isinstance(template_name, (list, tuple)):
template = select_template(template_name, using=using)
else:
template = get_template(template_name, using=using)
return template.render(context, request)…
def _engine_list(using=None):
return engines.all() if using is None else [engines[using]]
Variable | Value |
---|---|
context | {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>} |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
template | <django.template.backends.django.Template object at 0x7fe7d19aac20> |
template_name | 'website/item.html' |
using | None |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/backends/django.py
, line 61, 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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
request | <WSGIRequest: GET '/item/win-free-stuff-provided-by-victorinox/'> |
self | <django.template.backends.django.Template object at 0x7fe7d19aac20> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <Template template_string="{% extends 'website/..."> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <Template template_string="{% extends 'website/..."> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | [<ExtendsNode: extends 'website/base.html'>] |
/home/alex/tvgist-django/tvg/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 0x7fe7d246d540> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
node | <ExtendsNode: extends 'website/base.html'> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <ExtendsNode: extends 'website/base.html'> |
/home/alex/tvgist-django/tvg/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'>, {'title': [<Block Node: title. Contents: []>, <Block Node: title. Contents: [<TextNode: '\n'>, <IncludeNode: template=<FilterExpression "'website/item-head.html'">>, <TextNode: '\n'>]>], 'main': [<Block Node: main. Contents: []>]})> |
blocks | {'main': <Block Node: main. Contents: []>, 'title': <Block Node: title. Contents: []>} |
compiled_parent | <Template template_string="{% load website_extr..."> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
node | <django.template.defaulttags.LoadNode object at 0x7fe7d3d6eec0> |
self | <ExtendsNode: extends 'website/base.html'> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <Template template_string="{% load website_extr..."> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | [<django.template.defaulttags.LoadNode object at 0x7fe7d3d6eec0>, <TextNode: '\n<!DOCTYPE html>\n<html la'>, <Block Node: title. Contents: []>, <TextNode: '\n'>, <django.template.defaulttags.SpacelessNode object at 0x7fe7d3d6f130>, <TextNode: '\n<link rel="dns-prefetch"'>, <IncludeNode: template=<FilterExpression "'website/header.html'">>, <TextNode: '</header>\n <div class='>, <Block Node: main. Contents: []>, <TextNode: '</main>\n <section clas'>, <IncludeNode: template=<FilterExpression "'website/subscribe.html'">>, <TextNode: '</section>\n <section c'>, <IncludeNode: template=<FilterExpression "'website/latest.html'">>, <TextNode: '</section>\n </div>\n '>, <IncludeNode: template=<FilterExpression "'website/footer.html'">>, <TextNode: '</footer>\n</body>\n</html>'>] |
/home/alex/tvgist-django/tvg/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 0x7fe7d2977040> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
node | <Block Node: main. Contents: []> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <Block Node: main. Contents: []> |
/home/alex/tvgist-django/tvg/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: main. Contents: [<TextNode: '\n<nav class="breadcrumbs"'>, <IfNode>, <TextNode: ' › \n <a rel="category"'>, <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None>, <TextNode: '">'>, <Variable Node: item.cats.last.title>, <TextNode: '</a> › <b>'>, <Variable Node: item.title>, <TextNode: '</b></nav>\n<h1>'>, <Variable Node: item.title>, <TextNode: '</h1>\n '>, <IfNode>, <TextNode: '</div>\n<div class="item-t'>, <IncludeNode: template=<FilterExpression "'website/top-ad.html'">>, <TextNode: '</div>\n<section class="de'>, <Variable Node: item.img_path>, <TextNode: '" alt="'>, <Variable Node: item.title|slice:'100'>, <TextNode: '">\n </p>\n <'>, <Variable Node: item.descr|safe|linebreaks>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n </article>\n <'>, <IncludeNode: template=<FilterExpression "'website/bottom-ad.html'">>, <TextNode: '</div>\n<p class="freebie-'>, <Variable Node: item.freebie_link>, <TextNode: '">Get FREEBIE</a>\n</p>\n<s'>, <IncludeNode: template=<FilterExpression "'website/suppl-desc.html'">>, <TextNode: '</section>\n<section class'>, <ForNode: for cat in item.cats.all, tail_len: 7>, <TextNode: '\n </p>\n '>, <IfNode>, <TextNode: '\n<div class="prev-next-fr'>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n</div>\n</section>\n<secti'>, <ForNode: for cat in related_categories, tail_len: 5>, <TextNode: '\n</section>\n'>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'title': [<Block Node: title. Contents: []>, <Block Node: title. Contents: [<TextNode: '\n'>, <IncludeNode: template=<FilterExpression "'website/item-head.html'">>, <TextNode: '\n'>]>], 'main': [<Block Node: main. Contents: []>]})> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
push | <Block Node: main. Contents: [<TextNode: '\n<nav class="breadcrumbs"'>, <IfNode>, <TextNode: ' › \n <a rel="category"'>, <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None>, <TextNode: '">'>, <Variable Node: item.cats.last.title>, <TextNode: '</a> › <b>'>, <Variable Node: item.title>, <TextNode: '</b></nav>\n<h1>'>, <Variable Node: item.title>, <TextNode: '</h1>\n '>, <IfNode>, <TextNode: '</div>\n<div class="item-t'>, <IncludeNode: template=<FilterExpression "'website/top-ad.html'">>, <TextNode: '</div>\n<section class="de'>, <Variable Node: item.img_path>, <TextNode: '" alt="'>, <Variable Node: item.title|slice:'100'>, <TextNode: '">\n </p>\n <'>, <Variable Node: item.descr|safe|linebreaks>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n </article>\n <'>, <IncludeNode: template=<FilterExpression "'website/bottom-ad.html'">>, <TextNode: '</div>\n<p class="freebie-'>, <Variable Node: item.freebie_link>, <TextNode: '">Get FREEBIE</a>\n</p>\n<s'>, <IncludeNode: template=<FilterExpression "'website/suppl-desc.html'">>, <TextNode: '</section>\n<section class'>, <ForNode: for cat in item.cats.all, tail_len: 7>, <TextNode: '\n </p>\n '>, <IfNode>, <TextNode: '\n<div class="prev-next-fr'>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n</div>\n</section>\n<secti'>, <ForNode: for cat in related_categories, tail_len: 5>, <TextNode: '\n</section>\n'>]> |
self | <Block Node: main. Contents: []> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | [<TextNode: '\n<nav class="breadcrumbs"'>, <IfNode>, <TextNode: ' › \n <a rel="category"'>, <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None>, <TextNode: '">'>, <Variable Node: item.cats.last.title>, <TextNode: '</a> › <b>'>, <Variable Node: item.title>, <TextNode: '</b></nav>\n<h1>'>, <Variable Node: item.title>, <TextNode: '</h1>\n '>, <IfNode>, <TextNode: '</div>\n<div class="item-t'>, <IncludeNode: template=<FilterExpression "'website/top-ad.html'">>, <TextNode: '</div>\n<section class="de'>, <Variable Node: item.img_path>, <TextNode: '" alt="'>, <Variable Node: item.title|slice:'100'>, <TextNode: '">\n </p>\n <'>, <Variable Node: item.descr|safe|linebreaks>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n </article>\n <'>, <IncludeNode: template=<FilterExpression "'website/bottom-ad.html'">>, <TextNode: '</div>\n<p class="freebie-'>, <Variable Node: item.freebie_link>, <TextNode: '">Get FREEBIE</a>\n</p>\n<s'>, <IncludeNode: template=<FilterExpression "'website/suppl-desc.html'">>, <TextNode: '</section>\n<section class'>, <ForNode: for cat in item.cats.all, tail_len: 7>, <TextNode: '\n </p>\n '>, <IfNode>, <TextNode: '\n<div class="prev-next-fr'>, <IfNode>, <TextNode: '\n '>, <IfNode>, <TextNode: '\n</div>\n</section>\n<secti'>, <ForNode: for cat in related_categories, tail_len: 5>, <TextNode: '\n</section>\n'>] |
/home/alex/tvgist-django/tvg/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 0x7fe7d29d2fe0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
node | <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None> |
/home/alex/tvgist-django/tvg/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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
self | <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/defaulttags.py
, line 471, 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}, {}, {}, {'item': <Item: Win Free Stuff Provided by Victorinox>, 'next': <Item: Request a Free Sample of QCAN Plus Fermented Soy Beverage>, 'prev': <Item: Request an Aveda Hair Repair Shampoo for Free>, 'related_categories': <QuerySet []>}] |
current_app | '' |
kwargs | {} |
reverse | <function reverse at 0x7fe7d53427a0> |
self | <URLNode view_name=''cat'' args=[<FilterExpression 'item.cats.last.slug'>] kwargs={} as=None> |
url | '' |
view_name | 'cat' |
/home/alex/tvgist-django/tvg/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 | {} |
ns_converters | {} |
ns_pattern | '' |
path | [] |
prefix | '/' |
resolved_path | [] |
resolver | <URLResolver 'tvgist.urls' (None:None) '^/'> |
urlconf | 'tvgist.urls' |
view | 'cat' |
viewname | 'cat' |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/urls/resolvers.py
, line 828, 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 | "arguments '('',)'" |
args | ('',) |
candidate_pat | '/category/%(slug)s/' |
candidate_subs | {'slug': ''} |
converters | {'slug': <django.urls.converters.SlugConverter object at 0x7fe7d531ae30>} |
defaults | {} |
k | 'slug' |
kwargs | {} |
lookup_view | 'cat' |
lookup_view_s | 'cat' |
m | None |
match | True |
msg | ("Reverse for 'cat' with arguments '('',)' not found. 2 pattern(s) tried: " "['category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\\\Z', " "'category/(?P<slug>[-a-zA-Z0-9_]+)/\\\\Z']") |
n | None |
params | ['slug'] |
pattern | 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\Z' |
patterns | ['category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\Z', 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\Z'] |
possibilities | [([('category/%(slug)s/page/%(page_num)s/', ['slug', 'page_num'])], 'category/(?P<slug>[-a-zA-Z0-9_]+)/page/(?P<page_num>[0-9]+)/\\Z', {}, {'page_num': <django.urls.converters.IntConverter object at 0x7fe7d531add0>, 'slug': <django.urls.converters.SlugConverter object at 0x7fe7d531ae30>}), ([('category/%(slug)s/', ['slug'])], 'category/(?P<slug>[-a-zA-Z0-9_]+)/\\Z', {}, {'slug': <django.urls.converters.SlugConverter object at 0x7fe7d531ae30>})] |
possibility | [('category/%(slug)s/', ['slug'])] |
result | 'category/%(slug)s/' |
self | <URLResolver 'tvgist.urls' (None:None) '^/'> |
text_candidate_subs | {'slug': ''} |
v | '' |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'tvgist.com' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '35.173.178.60' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '35.173.178.60' |
PATH_INFO | '/item/win-free-stuff-provided-by-victorinox/' |
QUERY_STRING | '' |
RAW_URI | '/item/win-free-stuff-provided-by-victorinox/' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'tvgist.com' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/21.2.0' |
gunicorn.socket | <socket.socket fd=9, family=AddressFamily.AF_UNIX, type=SocketKind.SOCK_STREAM, proto=0, laddr=/run/tvgist.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7fe7d19abd00> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7fe7d19a9750> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
tvgist.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['tvgist.com', '185.177.125.51', '0.0.0.0', 'localhost', '127.0.0.1'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | PosixPath('/home/alex/tvgist-django/tvgist') |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CRONJOBS | [('35 10 * * *', 'website.cron.send_mass_html_emails_job')] |
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', 'HOST': 'localhost', 'NAME': 'tvgist', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'alex'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATA_UPLOAD_MAX_NUMBER_FILES | 100 |
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 | ['website', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sitemaps', 'django_admin_search', 'django_crontab', 'django_recaptcha'] |
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'), ('ckb', 'Central Kurdish (Sorani)'), ('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', 'ckb', '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 | '/var/www/html/static/tvgist-img/' |
MEDIA_URL | '/img/' |
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 |
RECAPTCHA_PRIVATE_KEY | '********************' |
RECAPTCHA_PUBLIC_KEY | '********************' |
ROOT_URLCONF | 'tvgist.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 | 'tvgist.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 | ['/home/alex/tvgist-django/tvgist/website/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/var/www/html/static/tvgist-static/' |
STATIC_URL | '/static/' |
STORAGES | {'default': {'BACKEND': 'django.core.files.storage.FileSystemStorage'}, 'staticfiles': {'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage'}} |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], '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', 'website.context_processors.static_data', 'website.context_processors.latest_items_by_type', 'website.context_processors.brands', 'website.context_processors.inject_form']}}] |
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 | 'UTC' |
USE_DEPRECATED_PYTZ | False |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'tvgist.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.