The 'upload' attribute has no file associated with it.
Request Method: | GET |
---|---|
Request URL: | https://campanha.org.br/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/ |
Django Version: | 5.0.2 |
Exception Type: | ValueError |
Exception Value: | The 'upload' attribute has no file associated with it. |
Exception Location: | /home/institutocampanha/env/lib/python3.11/site-packages/django/db/models/fields/files.py, line 41, in _require_file |
Raised during: | news.views.entry |
Python Executable: | /home/institutocampanha/env/bin/python3 |
Python Version: | 3.11.6 |
Python Path: | ['/home/institutocampanha/institutocampanha', '/home/institutocampanha/env/bin', '/usr/lib/python311.zip', '/usr/lib/python3.11', '/usr/lib/python3.11/lib-dynload', '/home/institutocampanha/env/lib/python3.11/site-packages'] |
Server time: | Fri, 29 Mar 2024 05:18:55 -0300 |
In template /home/institutocampanha/institutocampanha/templates/apps/google-schema-news.html
, error at line 6
1 | <script type="application/ld+json"> |
---|---|
2 | { |
3 | "@context": "https://schema.org", |
4 | "@type": "NewsArticle", |
5 | "headline": "{{ active }}", |
6 | "image": "{{ active.upload.url }}", |
7 | "datePublished": "{{ active.timestamp|date:'Y-m-d' }}", |
8 | "dateModified": "{{ active.updated|date:'Y-m-d' }}", |
9 | "author": [{ |
10 | "@type": "Organization", |
11 | "name": "Campanha nacional pelo direito à educação", |
12 | "url": "{{ request.build_absolute_uri }}" |
13 | }], |
14 | "publisher": { |
15 | "@type": "NGO", |
16 | "name": "Campanha nacional pelo direito à educação", |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 875, 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 | 'url' |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
current | <ImageFieldFile: None> |
self | <Variable: 'active.upload.url'> |
template_name | 'news/entry.html' |
/home/institutocampanha/env/lib/python3.11/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 | ValueError("The 'upload' attribute has no file associated with it.") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7b7b099c1b90>> |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
/home/institutocampanha/env/lib/python3.11/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 entry at 0x7b7b099fe340> |
callback_args | () |
callback_kwargs | {'day': 3, 'month': 8, 'slug': 'kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter', 'year': 2020} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7b7b099c1b90> |
wrapped_callback | <function entry at 0x7b7b099fe340> |
/home/institutocampanha/institutocampanha/news/views.py
, line 39, in entry
'SectionID': 'News',
'section_title': 'Notícias',
'active': active,
}
News.objects.filter(pk=active.pk).update(pageviews=F('pageviews') + 1)
return render(request, template, context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
Variable | Value |
---|---|
active | <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)> |
context | {'SectionID': 'News', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>, 'section_title': 'Notícias'} |
day | 3 |
month | 8 |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
slug | 'kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter' |
template | 'news/entry.html' |
year | 2020 |
/home/institutocampanha/env/lib/python3.11/site-packages/django/shortcuts.py
, line 25, 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 | {'SectionID': 'News', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>, 'section_title': 'Notícias'} |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
status | None |
template_name | 'news/entry.html' |
using | None |
/home/institutocampanha/env/lib/python3.11/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 | {'SectionID': 'News', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>, 'section_title': 'Notícias'} |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
template | <django.template.backends.django.Template object at 0x7b7b065891d0> |
template_name | 'news/entry.html' |
using | None |
/home/institutocampanha/env/lib/python3.11/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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
request | <WSGIRequest: GET '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/'> |
self | <django.template.backends.django.Template object at 0x7b7b065891d0> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 171, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Template template_string="{% extends "base.htm..."> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 163, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Template template_string="{% extends "base.htm..."> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | [<ExtendsNode: extends "base.html">] |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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 0x7b7b06cb75b0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
node | <ExtendsNode: extends "base.html"> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 961, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <ExtendsNode: extends "base.html"> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/loader_tags.py
, line 159, 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'>, {'Breadcrumb': [<Block Node: Breadcrumb. Contents: []>, <Block Node: Breadcrumb. Contents: [<TextNode: '<a href="'>, <URLNode view_name=''cnde:home'' args=[] kwargs={} as=None>, <TextNode: '">Início</a> » <a href="'>, <URLNode view_name=''news:index'' args=[] kwargs={} as=None>, <TextNode: '">Notícias</a> » '>, <Variable Node: active.category>]>], 'Content': [<Block Node: Content. Contents: [<TextNode: '\n'>]>, <Block Node: Content. Contents: [<TextNode: '\n\n<div class="D-F JC-FS A'>, <Variable Node: active.category.get_absolute_url>, <TextNode: '">'>, <Variable Node: active.category>, <TextNode: '</a></div>\n <h1>'>, <Variable Node: active>, <TextNode: '</h1>\n <div class="Exc'>, <Variable Node: active.excerpt>, <TextNode: '</div>\n <div class="D-'>, <Variable Node: active.timestamp>, <TextNode: '</time>\n '>, <IncludeNode: template=<FilterExpression '"assets/share.html"'>>, <TextNode: '\n </div>\n '>, <IfNode>, <TextNode: '\n <div class="Text">'>, <Variable Node: active.body|safe>, <TextNode: '</div>\n </section>\n\n <s'>, <IncludeNode: template=<FilterExpression '"assets/content-extra.html"'>>, <TextNode: '\n </section>\n\n</div>\n\n<s'>, <IncludeNode: template=<FilterExpression '"assets/content-related.html"'>>, <TextNode: '\n</section>\n\n'>]>], 'HeaderTitle': [<Block Node: HeaderTitle. Contents: [<IfNode>]>], 'HeaderDescription': [<Block Node: HeaderDescription. Contents: [<TextNode: 'Com mais de 20 anos de at'>]>], 'OGTitle': [<Block Node: OGTitle. Contents: [<IfNode>]>], 'OGDescription': [<Block Node: OGDescription. Contents: []>], 'OGImage': [<Block Node: OGImage. Contents: [<IfNode>]>], 'OGImageSecure': [<Block Node: OGImageSecure. Contents: [<IfNode>]>], 'JavaScript': [<Block Node: JavaScript. Contents: [<TextNode: '\n'>]>]})> |
blocks | {'Breadcrumb': <Block Node: Breadcrumb. Contents: []>, 'Content': <Block Node: Content. Contents: [<TextNode: '\n'>]>, 'HeaderDescription': <Block Node: HeaderDescription. Contents: [<TextNode: 'Com mais de 20 anos de at'>]>, 'HeaderTitle': <Block Node: HeaderTitle. Contents: [<IfNode>]>, 'JavaScript': <Block Node: JavaScript. Contents: [<TextNode: '\n'>]>, 'OGDescription': <Block Node: OGDescription. Contents: []>, 'OGImage': <Block Node: OGImage. Contents: [<IfNode>]>, 'OGImageSecure': <Block Node: OGImageSecure. Contents: [<IfNode>]>, 'OGTitle': <Block Node: OGTitle. Contents: [<IfNode>]>} |
compiled_parent | <Template template_string="{% load static %}<!..."> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
node | <django.template.defaulttags.LoadNode object at 0x7b7b08cd0f10> |
self | <ExtendsNode: extends "base.html"> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 163, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Template template_string="{% load static %}<!..."> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | [<django.template.defaulttags.LoadNode object at 0x7b7b08cd0f10>, <TextNode: '\n<!DOCTYPE html>\n<html>\n<'>, <IncludeNode: template=<FilterExpression '"apps/google-tagmanager-head.html"'>>, <TextNode: '\n <meta charset="utf-8">'>, <Block Node: HeaderTitle. Contents: [<IfNode>]>, <TextNode: '</title>\n <meta name="de'>, <Block Node: HeaderDescription. Contents: [<TextNode: 'Com mais de 20 anos de at'>]>, <TextNode: '" />\n <script defer src='>, StaticNode(varname=None, path=<FilterExpression "'js/nav.js'">), <TextNode: '"></script>\n <!-- Favico'>, StaticNode(varname=None, path=<FilterExpression "'img/favicon/apple-touch-icon.png'">), <TextNode: '">\n <link rel="icon" typ'>, StaticNode(varname=None, path=<FilterExpression "'img/favicon/favicon-32x32.png'">), <TextNode: '">\n <link rel="icon" typ'>, StaticNode(varname=None, path=<FilterExpression "'img/favicon/favicon-16x16.png'">), <TextNode: '">\n <!-- Style -->\n <l'>, StaticNode(varname=None, path=<FilterExpression "'css/base.css'">), <TextNode: '" />\n <script src="https'>, StaticNode(varname=None, path=<FilterExpression "'fontawesomefree/css/fontawesome.css'">), <TextNode: '" rel="stylesheet" type="'>, StaticNode(varname=None, path=<FilterExpression "'fontawesomefree/css/brands.css'">), <TextNode: '" rel="stylesheet" type="'>, StaticNode(varname=None, path=<FilterExpression "'fontawesomefree/css/solid.css'">), <TextNode: '" rel="stylesheet" type="'>, StaticNode(varname=None, path=<FilterExpression "'fontawesomefree/css/regular.css'">), <TextNode: '" rel="stylesheet" type="'>, <Variable Node: request.build_absolute_uri>, <TextNode: '"/>\n <meta property="og:'>, <Block Node: OGTitle. Contents: [<IfNode>]>, <TextNode: '"/>\n <meta property="og:'>, <Block Node: OGDescription. Contents: []>, <TextNode: '"/>\n <meta property="og:'>, <Block Node: OGImage. Contents: [<IfNode>]>, <TextNode: '"/>\n <meta property="og:'>, <Block Node: OGImageSecure. Contents: [<IfNode>]>, <TextNode: '"/>\n</head>\n\n\n\n<body'>, <IfNode>, <TextNode: '>\n'>, <IncludeNode: template=<FilterExpression '"apps/google-tagmanager-body.html"'>>, <TextNode: '\n'>, <IfNode>, <TextNode: '\n\n\n\n<div class="Header">\n'>, <URLNode view_name=''cnde:home'' args=[] kwargs={} as=None>, <TextNode: '"><img src="'>, StaticNode(varname=None, path=<FilterExpression "'img/CNDE.png'">), <TextNode: '" class="Logo"></a></figu'>, <IncludeNode: template=<FilterExpression "'assets/social-links.html'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'assets/nav-search.html'">>, <TextNode: '\n\n </header>\n \n '>, <URLNode view_name=''cnde:home'' args=[] kwargs={} as=None>, <TextNode: '">Início</a></li>\n <'>, <URLNode view_name=''podcasts:index'' args=[] kwargs={} as=None>, <TextNode: '">Podcasts</a></li>\n '>, <URLNode view_name=''news:index'' args=[] kwargs={} as=None>, <TextNode: '">Notícias</a></li>\n '>, <URLNode view_name=''collection:index'' args=[] kwargs={} as=None>, <TextNode: '">Acervo</a></li>\n '>, <URLNode view_name=''specials:index'' args=[] kwargs={} as=None>, <TextNode: '">Especiais</a></li>\n '>, <URLNode view_name=''assays:index'' args=[] kwargs={} as=None>, <TextNode: '">Análises</a></li>\n '>, <URLNode view_name=''support:contact'' args=[] kwargs={} as=None>, <TextNode: '">Contato</a></li>\n '>, <IfNode>, <TextNode: '\n\n\n\n'>, <IfNode>, <TextNode: '\n\n\n\n'>, <IfNode>, <TextNode: '\n\n\n\n<main class="Containe'>, <Block Node: Content. Contents: [<TextNode: '\n'>]>, <TextNode: '\n\n</main>\n\n\n\n<footer clas'>, <URLNode view_name=''cnde:home'' args=[] kwargs={} as=None>, <TextNode: '"><figure><img src="'>, StaticNode(varname=None, path=<FilterExpression "'img/CNDE-V.png'">), <TextNode: '"></figure></a></div>\n <'>, StaticNode(varname=None, path=<FilterExpression "'img/CC.png'">), <TextNode: '" loading="lazy" />\n '>, <IncludeNode: template=<FilterExpression "'assets/social-links.html'">>, <TextNode: '\n\n <div class="MT-1">\n'>, <Variable N… <trimmed 4461 bytes string> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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 0x7b7b06cb4c10> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
node | <IfNode> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 961, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <IfNode> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/defaulttags.py
, line 326, in render
match = condition.eval(context)
except VariableDoesNotExist:
match = None
else: # else clause
match = True
if match:
return nodelist.render(context) ^^^^^^^^^^^^^^^^^^^^^^^^…
return ""
class LoremNode(Node):
def __init__(self, count, method, common):
Variable | Value |
---|---|
condition | (and (in (literal <FilterExpression "'/noticias/'">) (literal <FilterExpression 'request.path'>)) (literal <FilterExpression 'active'>)) |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
match | <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)> |
nodelist | [<IncludeNode: template=<FilterExpression '"apps/google-schema-news.html"'>>] |
self | <IfNode> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | [<IncludeNode: template=<FilterExpression '"apps/google-schema-news.html"'>>] |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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 0x7b7b06b666b0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
node | <IncludeNode: template=<FilterExpression '"apps/google-schema-news.html"'>> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 961, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <IncludeNode: template=<FilterExpression '"apps/google-schema-news.html"'>> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/loader_tags.py
, line 210, 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 | {('apps/google-schema-news.html',): <Template template_string="<script type="applic...">} |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <IncludeNode: template=<FilterExpression '"apps/google-schema-news.html"'>> |
template | <Template template_string="<script type="applic..."> |
template_name | ('apps/google-schema-news.html',) |
values | {} |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 173, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Template template_string="<script type="applic..."> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 163, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Template template_string="<script type="applic..."> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | [<TextNode: '<script type="application'>, <Variable Node: active>, <TextNode: '",\n "image": "'>, <Variable Node: active.upload.url>, <TextNode: '",\n "datePublished": "'>, <Variable Node: active.timestamp|date:'Y-m-d'>, <TextNode: '",\n "dateModified": "'>, <Variable Node: active.updated|date:'Y-m-d'>, <TextNode: '",\n "author": [{\n "@t'>, <Variable Node: request.build_absolute_uri>, <TextNode: '"\n }],\n "publisher": {\n'>] |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1000, 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 0x7b7b06b66050> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
node | <Variable Node: active.upload.url> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 961, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Variable Node: active.upload.url> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 1059, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Variable Node: active.upload.url> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 710, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
ignore_failures | False |
self | <FilterExpression 'active.upload.url'> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 842, 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}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
self | <Variable: 'active.upload.url'> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/template/base.py
, line 885, 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 | 'url' |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'SectionID': 'News', 'section_title': 'Notícias', 'active': <News: Kit de mobilização #FundebPraValer #FundebComCAQ - Reta final do Senado Federal (PI - Twitter)>}] |
current | <ImageFieldFile: None> |
self | <Variable: 'active.upload.url'> |
template_name | 'news/entry.html' |
/home/institutocampanha/env/lib/python3.11/site-packages/django/db/models/fields/files.py
, line 66, in url
@property
def path(self):
self._require_file()
return self.storage.path(self.name)
@property
def url(self):
self._require_file() ^^^^^^^^^^^^^^^^^^^^…
return self.storage.url(self.name)
@property
def size(self):
self._require_file()
if not self._committed:
Variable | Value |
---|---|
self | <ImageFieldFile: None> |
/home/institutocampanha/env/lib/python3.11/site-packages/django/db/models/fields/files.py
, line 41, in _require_file
# The standard File contains most of the necessary properties, but
# FieldFiles can be instantiated without a name, so that needs to
# be checked for here.
def _require_file(self):
if not self:
raise ValueError( ^…
"The '%s' attribute has no file associated with it." % self.field.name
)
def _get_file(self):
self._require_file()
if getattr(self, "_file", None) is None:
Variable | Value |
---|---|
self | <ImageFieldFile: None> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'campanha.org.br' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '54.159.116.24' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '54.159.116.24' |
PATH_INFO | '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/' |
QUERY_STRING | '' |
RAW_URI | '/noticias/2020/08/03/kit-de-mobilizacao-fundebpravaler-fundebcomcaq-reta-final-do-senado-federal-pi-twitter/' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'campanha.org.br' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/21.2.0' |
gunicorn.socket | <socket.socket fd=9, family=1, type=1, proto=0, laddr=/run/gunicorn.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7b7b06cb7e80> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7b7b0658a290> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
institutocampanha.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['campanha.org.br', 'www.campanha.org.br', '64.23.218.181', 'localhost'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AWS_ACCESS_KEY_ID | '********************' |
AWS_S3_CUSTOM_DOMAIN | 'media.campanha.org.br' |
AWS_S3_ENDPOINT_URL | 'https://sfo3.digitaloceanspaces.com' |
AWS_S3_OBJECT_PARAMETERS | {'CacheControl': 'max-age=86400'} |
AWS_S3_REGION_NAME | 'sfo3' |
AWS_SECRET_ACCESS_KEY | '********************' |
AWS_STORAGE_BUCKET_NAME | 'institutocampanha' |
BASE_DIR | PosixPath('/home/institutocampanha/institutocampanha') |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CKEDITOR_CONFIGS | {'default': {'entities': False, 'entities_latin': False, 'extraPlugins': 'youtube', 'height': 300, 'removePlugins': 'iframe', 'toolbar': 'Custom', 'toolbar_Custom': [['Bold', 'Italic', 'Underline'], ['TextColor', 'BGColor'], ['Image', 'Youtube'], ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', '-', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock'], ['Link', 'Unlink'], ['Blockquote'], ['Styles', 'Format', 'Font', 'FontSize'], ['Undo', 'Redo'], ['Maximize', 'RemoveFormat', 'Source']], 'width': '100%'}} |
CKEDITOR_UPLOAD_PATH | 'uploads/' |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | 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': 'private-db-postgresql-sfo3-38686-do-user-15923450-0.c.db.ondigitalocean.com', 'NAME': 'institutocampanha', 'OPTIONS': {'sslmode': 'require'}, 'PASSWORD': '********************', 'PORT': 25060, 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'doadmin'}} |
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 | 'storages.backends.s3boto3.S3Boto3Storage' |
DEFAULT_FROM_EMAIL | 'comunicacao@campanhaeducacao.org.br' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DEFAULT_TO_EMAIL | 'comunicacao@campanhaeducacao.org.br' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.gmail.com' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'comunicacao@campanhaeducacao.org.br' |
EMAIL_PORT | 587 |
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 | True |
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 | 511 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORMS_URLFIELD_ASSUME_HTTPS | False |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['tags.apps.TagsConfig', 'search.apps.SearchConfig', 'logs.apps.LogsConfig', 'support.apps.SupportConfig', 'home.apps.HomeConfig', 'news.apps.NewsConfig', 'collection.apps.CollectionConfig', 'assays.apps.AssaysConfig', 'cnde.apps.CNDEConfig', 'sam.apps.SAMConfig', 'gremios.apps.GremiosConfig', 'podcasts.apps.PodcastsConfig', 'states.apps.StatesConfig', 'specials.apps.SpecialsConfig', 'fundeb.apps.FUNDEBConfig', 'caq.apps.CAQConfig', 'cc.apps.CCConfig', 'relus.apps.ReLusConfig', 'si.apps.SIConfig', 'covid19.apps.COVID19Config', 'cartacompromisso.apps.CartaCompromissoConfig', 'invisibilizadas.apps.InvisibilizadasConfig', 'chatbots.apps.ChatbotsConfig', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sitemaps', 'django.contrib.sites', 'django.contrib.redirects', 'ckeditor', 'ckeditor_uploader', 'fontawesomefree', 'django_htmx'] |
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'), ('ug', 'Uyghur'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'ckb', 'fa', 'ug', 'ur'] |
LANGUAGE_CODE | 'pt-br' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '' |
MEDIA_URL | 'https://media.campanha.org.br/' |
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', 'django.contrib.redirects.middleware.RedirectFallbackMiddleware', 'django_htmx.middleware.HtmxMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'institutocampanha.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 | 'comunicacao@campanhaeducacao.org.br' |
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 | 'institutocampanha.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SITE_ID | 1 |
STATICFILES_DIRS | (PosixPath('/home/institutocampanha/institutocampanha/static'),) |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | PosixPath('/home/institutocampanha/institutocampanha/../static') |
STATIC_URL | '/static/' |
STORAGES | {'default': {'BACKEND': 'storages.backends.s3boto3.S3Boto3Storage'}, 'staticfiles': {'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage'}} |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [PosixPath('/home/institutocampanha/institutocampanha/templates')], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'America/Sao_Paulo' |
USE_I18N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'institutocampanha.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.