[Errno 2] No such file or directory: '/var/www/html/static/tvgist-img/Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg'
Request Method: | GET |
---|---|
Request URL: | https://tvgist.com/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/ |
Django Version: | 4.2.3 |
Exception Type: | FileNotFoundError |
Exception Value: | [Errno 2] No such file or directory: '/var/www/html/static/tvgist-img/Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg' |
Exception Location: | /home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/files/storage/filesystem.py, line 68, in _open |
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 23:10:42 +0000 |
In template /home/alex/tvgist-django/tvgist/website/templates/website/item-head.html
, error at line 12
2 | <link rel="canonical" href="{{ request.build_absolute_uri }}"> |
---|---|
3 | <meta name="description" content="{{ item.descr|remove_new_lines|replace_quote|striptags|slice:'280' }}"> |
4 | <meta property="og:locale" content="en_US" /> |
5 | <meta property="og:type" content="object" /> |
6 | <meta property="og:title" content="{{ item.title }}" /> |
7 | <meta property="og:description" content="{{ item.descr|striptags|remove_new_lines|replace_quote|slice:'280' }}" /> |
8 | <meta property="og:url" content="{{ request.build_absolute_uri }}" /> |
9 | <meta property="og:site_name" content="TVGIST: {{ motto }}" /> |
10 | <meta property="og:image" content="https://{{ domain }}/img/{{ item.img_path }}" /> |
11 | <meta property="og:image:secure_url" content="https://{{ domain }}/img/{{ item.img_path }}" /> |
12 | <meta property="og:image:width" content="{{item.img_path.width}}" /> |
13 | <meta property="og:image:height" content="{{item.img_path.height}}" /> |
14 | <meta property="og:image:alt" content="{{ item.title }}" /> |
15 | <meta property="og:image:type" content="image/webp" /> |
16 | <link rel="alternate" href="https://{{ domain }}/feed/" type="application/rss+xml" title="RSS"> |
17 | <link rel="alternate" href="https://{{ domain }}/feed/" type="application/atom+xml" title="Atom"> |
18 | <meta property="article:published_time" content="{{ item.date_publ|date:'c' }}" />{% if item.date_upd == None %}<meta property="article:modified_time" content="{{ item.date_publ|date:'c' }}" /> |
19 | <meta property="article:updated_time" content="{{ item.date_publ|date:'c' }}" />{% else %} |
20 | <meta property="article:modified_time" content="{{ item.date_upd|date:'c' }}" /> |
21 | <meta property="article:updated_time" content="{{ item.date_upd|date:'c' }}" />{% endif %} |
22 | <meta name="twitter:card" content="summary" /> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 880, in _resolve_lookup
detail and shouldn't be called by external code. Use Variable.resolve()
instead.
"""
current = context
try: # catch-all for silent variable failures
for bit in self.lookups:
try: # dictionary lookup
current = current[bit]…
# ValueError/IndexError are for numpy.array lookup on
# numpy < 1.9 and 1.9+ respectively
except (TypeError, AttributeError, KeyError, ValueError, IndexError):
try: # attribute lookup
# Don't return class attributes if the class is the context:
if isinstance(current, BaseContext) and getattr(
Variable | Value |
---|---|
bit | 'width' |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
current | <ImageFieldFile: Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg> |
self | <Variable: 'item.img_path.width'> |
template_name | 'website/item.html' |
/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 | FileNotFoundError(2, 'No such file or directory') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7fe7d4eb6080>> |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
/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': 'claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>} |
item | <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway> |
next | <Item: Request Your Free Zero Pore Cream By Medicube> |
prev | <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume> |
related_categories | <QuerySet [<Cat: Free Gadgets Tech and Electronics>]> |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
slug | 'claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker' |
/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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>} |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>} |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
template | <django.template.backends.django.Template object at 0x7fe7d35f1d20> |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
request | <WSGIRequest: GET '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/'> |
self | <django.template.backends.django.Template object at 0x7fe7d35f1d20> |
/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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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 0x7fe7d2d87eb0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: []>], 'main': [<Block Node: main. Contents: []>, <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'>]>]})> |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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 0x7fe7d24b72e0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
node | <Block Node: title. 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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <Block Node: title. 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: title. Contents: [<TextNode: '\n'>, <IncludeNode: template=<FilterExpression "'website/item-head.html'">>, <TextNode: '\n'>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'title': [<Block Node: title. Contents: []>], 'main': [<Block Node: main. Contents: []>, <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'>]>]})> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
push | <Block Node: title. Contents: [<TextNode: '\n'>, <IncludeNode: template=<FilterExpression "'website/item-head.html'">>, <TextNode: '\n'>]> |
self | <Block Node: title. 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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | [<TextNode: '\n'>, <IncludeNode: template=<FilterExpression "'website/item-head.html'">>, <TextNode: '\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 0x7fe7d24b7c70> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
node | <IncludeNode: template=<FilterExpression "'website/item-head.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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <IncludeNode: template=<FilterExpression "'website/item-head.html'">> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/loader_tags.py
, line 208, in render
template = template.template
values = {
name: var.resolve(context) for name, var in self.extra_context.items()
}
if self.isolated_context:
return template.render(context.new(values))
with context.push(**values):
return template.render(context)…
@register.tag("block")
def do_block(parser, token):
"""
Define a block that can be overridden by child templates.
Variable | Value |
---|---|
cache | {('website/item-head.html',): <Template template_string="{% load website_extr...">} |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <IncludeNode: template=<FilterExpression "'website/item-head.html'">> |
template | <Template template_string="{% load website_extr..."> |
template_name | ('website/item-head.html',) |
values | {} |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 177, in render
"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
is True and an exception occurs during parsing, the exception is
annotated with contextual line information where it occurred in the
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <Template template_string="{% load website_extr..."> |
/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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | [<django.template.defaulttags.LoadNode object at 0x7fe7d3554460>, <TextNode: '<title>'>, <Variable Node: item.title>, <TextNode: ' | '>, <Variable Node: motto>, <TextNode: '</title>\n<link rel="canon'>, <Variable Node: request.build_absolute_uri>, <TextNode: '">\n<meta name="descriptio'>, <Variable Node: item.descr|remove_new_lines|replace_quote|striptags|slice:'280'>, <TextNode: '">\n<meta property="og:loc'>, <Variable Node: item.title>, <TextNode: '" />\n<meta property="og:d'>, <Variable Node: item.descr|striptags|remove_new_lines|replace_quote|slice:'280'>, <TextNode: '" />\n<meta property="og:u'>, <Variable Node: request.build_absolute_uri>, <TextNode: '" />\n<meta property="og:s'>, <Variable Node: motto>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: domain>, <TextNode: '/img/'>, <Variable Node: item.img_path>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: domain>, <TextNode: '/img/'>, <Variable Node: item.img_path>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: item.img_path.width>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: item.img_path.height>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: item.title>, <TextNode: '" />\n<meta property="og:i'>, <Variable Node: domain>, <TextNode: '/feed/" type="application'>, <Variable Node: domain>, <TextNode: '/feed/" type="application'>, <Variable Node: item.date_publ|date:'c'>, <TextNode: '" />'>, <IfNode>, <TextNode: '\n<meta name="twitter:card'>, <Variable Node: item.title>, <TextNode: '" />\n<meta name="twitter:'>, <Variable Node: domain>, <TextNode: '/static/img/'>, <Variable Node: item.img_path>, <TextNode: '" />\n<meta name="twitter:'>, <Variable Node: item.descr|striptags|remove_new_lines|replace_quote|slice:'280'>, <TextNode: '" />\n<meta property="arti'>, <ForNode: for cat in item.cats.all, tail_len: 2>, <TextNode: '" />'>, <IncludeNode: template=<FilterExpression "'website/json-ld.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 0x7fe7d29a1c00> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
node | <Variable Node: item.img_path.width> |
/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: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <Variable Node: item.img_path.width> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 1064, in render
self.filter_expression = filter_expression
def __repr__(self):
return "<Variable Node: %s>" % self.filter_expression
def render(self, context):
try:
output = self.filter_expression.resolve(context)…
except UnicodeDecodeError:
# Unicode conversion can fail sometimes for reasons out of our
# control (e.g. exception rendering). In that case, we fail
# quietly.
return ""
return render_value_in_context(output, context)
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <Variable Node: item.img_path.width> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 715, in resolve
self.filters = filters
self.var = var_obj
self.is_var = isinstance(var_obj, Variable)
def resolve(self, context, ignore_failures=False):
if self.is_var:
try:
obj = self.var.resolve(context)…
except VariableDoesNotExist:
if ignore_failures:
obj = None
else:
string_if_invalid = context.template.engine.string_if_invalid
if string_if_invalid:
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
ignore_failures | False |
self | <FilterExpression 'item.img_path.width'> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 847, in resolve
)
self.lookups = tuple(var.split(VARIABLE_ATTRIBUTE_SEPARATOR))
def resolve(self, context):
"""Resolve this variable against a given context."""
if self.lookups is not None:
# We're dealing with a variable that needs to be resolved
value = self._resolve_lookup(context)…
else:
# We're dealing with a literal, so it's already been "resolved"
value = self.literal
if self.translate:
is_safe = isinstance(value, SafeData)
msgid = value.replace("%", "%%")
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
self | <Variable: 'item.img_path.width'> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/template/base.py
, line 890, in _resolve_lookup
except (TypeError, AttributeError, KeyError, ValueError, IndexError):
try: # attribute lookup
# Don't return class attributes if the class is the context:
if isinstance(current, BaseContext) and getattr(
type(current), bit
):
raise AttributeError
current = getattr(current, bit)…
except (TypeError, AttributeError):
# Reraise if the exception was raised by a @property
if not isinstance(current, BaseContext) and bit in dir(current):
raise
try: # list-index lookup
current = current[int(bit)]
Variable | Value |
---|---|
bit | 'width' |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'item': <Item: Free Cayman Jack Cinco De Mayo Marshall Speaker Giveaway>, 'next': <Item: Request Your Free Zero Pore Cream By Medicube>, 'prev': <Item: Play The Game For A Chance To Win New Paco Rabanne Perfume>, 'related_categories': <QuerySet [<Cat: Free Gadgets Tech and Electronics>]>}] |
current | <ImageFieldFile: Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg> |
self | <Variable: 'item.img_path.width'> |
template_name | 'website/item.html' |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/files/images.py
, line 20, in width
"""
A mixin for use alongside django.core.files.base.File, which provides
additional features for dealing with images.
"""
@property
def width(self):
return self._get_image_dimensions()[0]…
@property
def height(self):
return self._get_image_dimensions()[1]
def _get_image_dimensions(self):
Variable | Value |
---|---|
self | <ImageFieldFile: Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/files/images.py
, line 29, in _get_image_dimensions
@property
def height(self):
return self._get_image_dimensions()[1]
def _get_image_dimensions(self):
if not hasattr(self, "_dimensions_cache"):
close = self.closed
self.open()…
self._dimensions_cache = get_image_dimensions(self, close=close)
return self._dimensions_cache
def get_image_dimensions(file_or_path, close=False):
"""
Variable | Value |
---|---|
close | True |
self | <ImageFieldFile: Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/db/models/fields/files.py
, line 79, in open
if not self._committed:
return self.file.size
return self.storage.size(self.name)
def open(self, mode="rb"):
self._require_file()
if getattr(self, "_file", None) is None:
self.file = self.storage.open(self.name, mode)…
else:
self.file.open(mode)
return self
# open() doesn't alter the file's contents, but it does reset the pointer
open.alters_data = True
Variable | Value |
---|---|
mode | 'rb' |
self | <ImageFieldFile: Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/files/storage/base.py
, line 22, in open
"""
# The following methods represent a public interface to private methods.
# These shouldn't be overridden by subclasses unless absolutely necessary.
def open(self, name, mode="rb"):
"""Retrieve the specified file from storage."""
return self._open(name, mode)…
def save(self, name, content, max_length=None):
"""
Save new content to the file specified by name. The content should be
a proper File object or any Python file-like object, ready to be read
from the beginning.
Variable | Value |
---|---|
mode | 'rb' |
name | 'Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg' |
self | <django.core.files.storage.filesystem.FileSystemStorage object at 0x7fe7d3554340> |
/home/alex/tvgist-django/tvg/lib/python3.10/site-packages/django/core/files/storage/filesystem.py
, line 68, in _open
@cached_property
def directory_permissions_mode(self):
return self._value_or_setting(
self._directory_permissions_mode, settings.FILE_UPLOAD_DIRECTORY_PERMISSIONS
)
def _open(self, name, mode="rb"):
return File(open(self.path(name), mode))…
def _save(self, name, content):
full_path = self.path(name)
# Create any intermediate directories that do not exist.
directory = os.path.dirname(full_path)
Variable | Value |
---|---|
mode | 'rb' |
name | 'Claim-Your-Free-Cayman-Jack®-Cinco-De-Mayo-Marshall-Speaker.jpg' |
self | <django.core.files.storage.filesystem.FileSystemStorage object at 0x7fe7d3554340> |
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 | '44.222.104.49' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '44.222.104.49' |
PATH_INFO | '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/' |
QUERY_STRING | '' |
RAW_URI | '/item/claim-your-free-cayman-jack-cinco-de-mayo-marshall-speaker/' |
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 0x7fe7d3997850> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7fe7d35f3d60> |
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.