Invalid block tag on line 9: 'endblock', expected 'elif','else' or 'endif'. Did you forget to register or load this tag?
Request Method: | GET |
---|---|
Request URL: | http://aboutmovie.net/search/?tag=%E6%AD%A6%E4%BE%A0 |
Django Version: | 5.0 |
Exception Type: | TemplateSyntaxError |
Exception Value: | Invalid block tag on line 9: 'endblock', expected 'elif','else' or 'endif'. Did you forget to register or load this tag? |
Exception Location: | /usr/local/lib/python3.11/site-packages/django/template/base.py, line 555, in invalid_block_tag |
Raised during: | app.views.Search |
Python Executable: | /usr/local/bin/python |
Python Version: | 3.11.4 |
Python Path: | ['/code', '/usr/local/bin', '/usr/local/lib/python311.zip', '/usr/local/lib/python3.11', '/usr/local/lib/python3.11/lib-dynload', '/usr/local/lib/python3.11/site-packages', '/usr/src/app/'] |
Server time: | Fri, 29 Mar 2024 07:22:20 -0400 |
In template /code/templates/buscar.html
, error at line 9
1 | {% extends 'base.html' %} |
---|---|
2 | |
3 | {% block titulo %}Resultados de la busqueda "{{ query|escape }}" - {% endblock %} |
4 | {% block head %}{% endblock %} |
5 | |
6 | {% block css %}{% include 'listado_obras.css' %} {% include 'obra_fichas.css' %} .personas{ width: 100%;}.personas ul{width: 100%;list-style: none;margin: 0;padding: 0;display: inline-block;}.personas ul li{float:left;width: 100%;vertical-align: middle;}.personas ul li img{border-radius: 50%;vertical-align: middle;vertical-align: middle;}{% endblock %} |
7 | |
8 | |
9 | {% block contenido %}<div class="contenido"> {% if query %} <h1>Results of search "{{ query|escape }}":</h1>{% if obras %} <h2>Results of the works category</h2> <div class="lista" >{% for obra in obras %}{% include 'obra_en_lista.html' %}{% endfor %}</div> {% endif %} {% if personas %}<div class="personas"><h2>Results for peoples</h2><ul>{% for persona in personas %} <li itemtype='https://schema.org/Person' ><a href="https://aboutmovie.net/biography/{{ persona.url }}" title="{{ persona.nombre }}" itemprop="url" ><img class="lazyLoad" itemprop='image' alt="{{ persona.nombre }}" src="#" data-src="{{ persona.imagen }}" > <span itemprop="name">{{ persona.nombre }}</span></a></li>{% endfor %}</ul></div>{% endif %}{% if nota %}<h3>Results within the Notes category</h3> <ul> </div>{% endblock %} |
10 | |
11 | {% block JavaScript %}{% endblock %} |
12 | |
13 | |
14 | {% block Analytics %}{% include 'googletagmanager.html' %}{% endblock %} |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 502, in parse
# Add the token to the command stack. This is used for error
# messages if further parsing fails due to an unclosed block
# tag.
self.command_stack.append((command, token))
# Get the tag callback function from the ones registered with
# the parser.
try:
compile_func = self.tags[command] ^^^^^^^^^^^^^^^^^^…
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
Variable | Value |
---|---|
command | 'endblock' |
nodelist | [<TextNode: '<h3>Results within the No'>] |
parse_until | ('elif', 'else', 'endif') |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "endblock..."> |
token_type | 2 |
/usr/local/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 | TemplateSyntaxError("Invalid block tag on line 9: 'endblock', expected 'elif','else' or 'endif'. Did you forget to register or load this tag?") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f5374be3d90>> |
request | <WSGIRequest: GET '/search/?tag=%E6%AD%A6%E4%BE%A0'> |
/usr/local/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 Search at 0x7f5374c6fa60> |
callback_args | () |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/search/?tag=%E6%AD%A6%E4%BE%A0'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f5374be3d90> |
wrapped_callback | <function Search at 0x7f5374c6fa60> |
/code/app/views.py
, line 364, in Search
lista_id_obras.append(obraListada)
if obraListada not in listaJson:
listaJson.append(obraListada)
contenido["obras"] = lista_id_obras
contenido['listaJson'] = json.dumps(listaJson)
resp = render(request,"buscar.html", contenido) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
max_age = 0
patch_cache_control(resp, max_age=max_age)
return resp
Variable | Value |
---|---|
contenido | {'listaJson': '[]', 'personas': [], 'query': ''} |
listaJson | [] |
nota | [] |
obras | [] |
persona | [] |
personas | [] |
query | '' |
request | <WSGIRequest: GET '/search/?tag=%E6%AD%A6%E4%BE%A0'> |
/usr/local/lib/python3.11/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 | {'listaJson': '[]', 'personas': [], 'query': ''} |
request | <WSGIRequest: GET '/search/?tag=%E6%AD%A6%E4%BE%A0'> |
status | None |
template_name | 'buscar.html' |
using | None |
/usr/local/lib/python3.11/site-packages/django/template/loader.py
, line 61, in render_to_string
Load a template and render it with a context. Return a 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 | {'listaJson': '[]', 'personas': [], 'query': ''} |
request | <WSGIRequest: GET '/search/?tag=%E6%AD%A6%E4%BE%A0'> |
template_name | 'buscar.html' |
using | None |
/usr/local/lib/python3.11/site-packages/django/template/loader.py
, line 15, in get_template
Raise TemplateDoesNotExist if no such template exists.
"""
chain = []
engines = _engine_list(using)
for engine in engines:
try:
return engine.get_template(template_name) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
except TemplateDoesNotExist as e:
chain.append(e)
raise TemplateDoesNotExist(template_name, chain=chain)
Variable | Value |
---|---|
chain | [] |
engine | <django.template.backends.django.DjangoTemplates object at 0x7f5374af2c50> |
engines | [<django.template.backends.django.DjangoTemplates object at 0x7f5374af2c50>] |
template_name | 'buscar.html' |
using | None |
/usr/local/lib/python3.11/site-packages/django/template/backends/django.py
, line 33, in get_template
self.engine = Engine(self.dirs, self.app_dirs, **options)
def from_string(self, template_code):
return Template(self.engine.from_string(template_code), self)
def get_template(self, template_name):
try:
return Template(self.engine.get_template(template_name), self) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
except TemplateDoesNotExist as exc:
reraise(exc, self)
def get_templatetag_libraries(self, custom_libraries):
"""
Return a collation of template tag libraries from installed
Variable | Value |
---|---|
self | <django.template.backends.django.DjangoTemplates object at 0x7f5374af2c50> |
template_name | 'buscar.html' |
/usr/local/lib/python3.11/site-packages/django/template/engine.py
, line 175, in get_template
return Template(template_code, engine=self)
def get_template(self, template_name):
"""
Return a compiled Template object for the given template name,
handling template inheritance recursively.
"""
template, origin = self.find_template(template_name) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
if not hasattr(template, "render"):
# template needs to be compiled
template = Template(template, origin, template_name, engine=self)
return template
def render_to_string(self, template_name, context=None):
Variable | Value |
---|---|
self | <Engine: dirs=['/code/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=0 loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'sorl_thumbnail': 'sorl.thumbnail.templatetags.sorl_thumbnail', 'thumbnail': 'sorl.thumbnail.templatetags.thumbnail'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
template_name | 'buscar.html' |
/usr/local/lib/python3.11/site-packages/django/template/engine.py
, line 157, in find_template
"Invalid value in template loaders configuration: %r" % loader
)
def find_template(self, name, dirs=None, skip=None):
tried = []
for loader in self.template_loaders:
try:
template = loader.get_template(name, skip=skip) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
return template, template.origin
except TemplateDoesNotExist as e:
tried.extend(e.tried)
raise TemplateDoesNotExist(name, tried=tried)
def from_string(self, template_code):
Variable | Value |
---|---|
dirs | None |
loader | <django.template.loaders.cached.Loader object at 0x7f5374af2950> |
name | 'buscar.html' |
self | <Engine: dirs=['/code/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=0 loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'sorl_thumbnail': 'sorl.thumbnail.templatetags.sorl_thumbnail', 'thumbnail': 'sorl.thumbnail.templatetags.thumbnail'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
skip | None |
tried | [] |
/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py
, line 57, in get_template
if isinstance(cached, type) and issubclass(cached, TemplateDoesNotExist):
raise cached(template_name)
elif isinstance(cached, TemplateDoesNotExist):
raise copy_exception(cached)
return cached
try:
template = super().get_template(template_name, skip) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
except TemplateDoesNotExist as e:
self.get_template_cache[key] = (
copy_exception(e) if self.engine.debug else TemplateDoesNotExist
)
raise
else:
Variable | Value |
---|---|
__class__ | <class 'django.template.loaders.cached.Loader'> |
cached | None |
key | 'buscar.html' |
self | <django.template.loaders.cached.Loader object at 0x7f5374af2950> |
skip | None |
template_name | 'buscar.html' |
/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py
, line 28, in get_template
try:
contents = self.get_contents(origin)
except TemplateDoesNotExist:
tried.append((origin, "Source does not exist"))
continue
else:
return Template(…
contents,
origin,
origin.template_name,
self.engine,
)
Variable | Value |
---|---|
contents | ("{% extends 'base.html' %}\n" '\n' '{% block titulo %}Resultados de la busqueda "{{ query|escape }}" - {% ' 'endblock %}\n' '{% block head %}{% endblock %}\n' '\n' "{% block css %}{% include 'listado_obras.css' %} {% include " "'obra_fichas.css' %} .personas{ width: 100%;}.personas ul{width: " '100%;list-style: none;margin: 0;padding: 0;display: inline-block;}.personas ' 'ul li{float:left;width: 100%;vertical-align: middle;}.personas ul li ' 'img{border-radius: 50%;vertical-align: middle;vertical-align: middle;}{% ' 'endblock %}\n' '\n' '\n' '{% block contenido %}<div class="contenido">\t{% if query %} <h1>Results of ' 'search "{{ query|escape }}":</h1>{% if obras %} <h2>Results of the works ' 'category</h2> <div class="lista" >{% for obra in obras %}{% include ' "'obra_en_lista.html' %}{% endfor %}</div> {% endif %} {% if personas %}<div " 'class="personas"><h2>Results for peoples</h2><ul>{% for persona in personas ' "%} <li itemtype='https://schema.org/Person' ><a " 'href="https://aboutmovie.net/biography/{{ persona.url }}" title="{{ ' 'persona.nombre }}" itemprop="url" ><img class="lazyLoad" ' 'itemprop=\'image\' alt="{{ persona.nombre }}" src="#" data-src="{{ ' 'persona.imagen }}" > <span itemprop="name">{{ persona.nombre ' '}}</span></a></li>{% endfor %}</ul></div>{% endif %}{% if nota %}<h3>Results ' 'within the Notes category</h3> <ul> </div>{% endblock %}\n' '\n' '{% block JavaScript %}{% endblock %}\n' '\n' '\n' "\t{% block Analytics %}{% include 'googletagmanager.html' %}{% endblock %}") |
origin | <Origin name='/code/templates/buscar.html'> |
self | <django.template.loaders.cached.Loader object at 0x7f5374af2950> |
skip | None |
template_name | 'buscar.html' |
tried | [] |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 154, in __init__
engine = Engine.get_default()
if origin is None:
origin = Origin(UNKNOWN_SOURCE)
self.name = name
self.origin = origin
self.engine = engine
self.source = str(template_string) # May be lazy.
self.nodelist = self.compile_nodelist() ^^^^^^^^^^^^^^^^^^^^^^^…
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
Variable | Value |
---|---|
engine | <Engine: dirs=['/code/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=0 loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'sorl_thumbnail': 'sorl.thumbnail.templatetags.sorl_thumbnail', 'thumbnail': 'sorl.thumbnail.templatetags.thumbnail'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
name | 'buscar.html' |
origin | <Origin name='/code/templates/buscar.html'> |
self | <Template template_string="{% extends 'base.htm..."> |
template_string | ("{% extends 'base.html' %}\n" '\n' '{% block titulo %}Resultados de la busqueda "{{ query|escape }}" - {% ' 'endblock %}\n' '{% block head %}{% endblock %}\n' '\n' "{% block css %}{% include 'listado_obras.css' %} {% include " "'obra_fichas.css' %} .personas{ width: 100%;}.personas ul{width: " '100%;list-style: none;margin: 0;padding: 0;display: inline-block;}.personas ' 'ul li{float:left;width: 100%;vertical-align: middle;}.personas ul li ' 'img{border-radius: 50%;vertical-align: middle;vertical-align: middle;}{% ' 'endblock %}\n' '\n' '\n' '{% block contenido %}<div class="contenido">\t{% if query %} <h1>Results of ' 'search "{{ query|escape }}":</h1>{% if obras %} <h2>Results of the works ' 'category</h2> <div class="lista" >{% for obra in obras %}{% include ' "'obra_en_lista.html' %}{% endfor %}</div> {% endif %} {% if personas %}<div " 'class="personas"><h2>Results for peoples</h2><ul>{% for persona in personas ' "%} <li itemtype='https://schema.org/Person' ><a " 'href="https://aboutmovie.net/biography/{{ persona.url }}" title="{{ ' 'persona.nombre }}" itemprop="url" ><img class="lazyLoad" ' 'itemprop=\'image\' alt="{{ persona.nombre }}" src="#" data-src="{{ ' 'persona.imagen }}" > <span itemprop="name">{{ persona.nombre ' '}}</span></a></li>{% endfor %}</ul></div>{% endif %}{% if nota %}<h3>Results ' 'within the Notes category</h3> <ul> </div>{% endblock %}\n' '\n' '{% block JavaScript %}{% endblock %}\n' '\n' '\n' "\t{% block Analytics %}{% include 'googletagmanager.html' %}{% endblock %}") |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 196, in compile_nodelist
tokens,
self.engine.template_libraries,
self.engine.template_builtins,
self.origin,
)
try:
return parser.parse() ^^^^^^^^^^^^^^…
except Exception as e:
if self.engine.debug:
e.template_debug = self.get_exception_info(e, e.token)
raise
def get_exception_info(self, exception, token):
Variable | Value |
---|---|
lexer | <DebugLexer template_string="{% extends 'base.htm...", verbatim=False> |
parser | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
self | <Template template_string="{% extends 'base.htm..."> |
tokens | [<Block token: "extends 'base.html'...">, <Text token: "...">, <Block token: "block titulo...">, <Text token: "Resultados de la bus...">, <Var token: "query|escape...">, <Text token: "" - ...">, <Block token: "endblock...">, <Text token: "...">, <Block token: "block head...">, <Block token: "endblock...">, <Text token: "...">, <Block token: "block css...">, <Block token: "include 'listado_obr...">, <Text token: " ...">, <Block token: "include 'obra_fichas...">, <Text token: " .personas{ width: ...">, <Block token: "endblock...">, <Text token: "...">, <Block token: "block contenido...">, <Text token: "<div class="contenid...">, <Block token: "if query...">, <Text token: " <h1>Results of sear...">, <Var token: "query|escape...">, <Text token: "":</h1>...">, <Block token: "if obras...">, <Text token: " <h2>Results of the ...">, <Block token: "for obra in obras...">, <Block token: "include 'obra_en_lis...">, <Block token: "endfor...">, <Text token: "</div> ...">, <Block token: "endif...">, <Text token: " ...">, <Block token: "if personas...">, <Text token: "<div class="personas...">, <Block token: "for persona in perso...">, <Text token: " <li itemtype='http...">, <Var token: "persona.url...">, <Text token: "" title="...">, <Var token: "persona.nombre...">, <Text token: "" itemprop="url" ><i...">, <Var token: "persona.nombre...">, <Text token: "" src="#" data-src=...">, <Var token: "persona.imagen...">, <Text token: "" > <span itemprop="...">, <Var token: "persona.nombre...">, <Text token: "</span></a></li>...">, <Block token: "endfor...">, <Text token: "</ul></div>...">, <Block token: "endif...">, <Block token: "if nota...">, <Text token: "<h3>Results within t...">, <Block token: "endblock...">, <Text token: "...">, <Block token: "block JavaScript...">, <Block token: "endblock...">, <Text token: " ...">, <Block token: "block Analytics...">, <Block token: "include 'googletagma...">, <Block token: "endblock...">] |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e) ^^^^^^^^^^^^^^^^^^^^^^^^^^…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'extends' |
compile_func | <function do_extends at 0x7f53750e14e0> |
nodelist | [] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "extends 'base.html'..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token) ^^^^^^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'extends' |
compile_func | <function do_extends at 0x7f53750e14e0> |
nodelist | [] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "extends 'base.html'..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py
, line 295, in do_extends
the parent template itself (if it evaluates to a Template object).
"""
bits = token.split_contents()
if len(bits) != 2:
raise TemplateSyntaxError("'%s' takes one argument" % bits[0])
bits[1] = construct_relative_path(parser.origin.template_name, bits[1])
parent_name = parser.compile_filter(bits[1])
nodelist = parser.parse() ^^^^^^^^^^^^^^…
if nodelist.get_nodes_by_type(ExtendsNode):
raise TemplateSyntaxError(
"'%s' cannot appear more than once in the same template" % bits[0]
)
return ExtendsNode(nodelist, parent_name)
Variable | Value |
---|---|
bits | ['extends', "'base.html'"] |
parent_name | <FilterExpression "'base.html'"> |
parser | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "extends 'base.html'..."> |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e) ^^^^^^^^^^^^^^^^^^^^^^^^^^…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'block' |
compile_func | <function do_block at 0x7f53750e13a0> |
compiled_result | <Block Node: css. Contents: [<IncludeNode: template=<FilterExpression "'listado_obras.css'">>, <TextNode: ' '>, <IncludeNode: template=<FilterExpression "'obra_fichas.css'">>, <TextNode: ' .personas{ width: 100%;'>]> |
nodelist | [<TextNode: '\n\n'>, <Block Node: titulo. Contents: [<TextNode: 'Resultados de la busqueda'>, <Variable Node: query|escape>, <TextNode: '" - '>]>, <TextNode: '\n'>, <Block Node: head. Contents: []>, <TextNode: '\n\n'>, <Block Node: css. Contents: [<IncludeNode: template=<FilterExpression "'listado_obras.css'">>, <TextNode: ' '>, <IncludeNode: template=<FilterExpression "'obra_fichas.css'">>, <TextNode: ' .personas{ width: 100%;'>]>, <TextNode: '\n\n\n'>] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "block contenido..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token) ^^^^^^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'block' |
compile_func | <function do_block at 0x7f53750e13a0> |
compiled_result | <Block Node: css. Contents: [<IncludeNode: template=<FilterExpression "'listado_obras.css'">>, <TextNode: ' '>, <IncludeNode: template=<FilterExpression "'obra_fichas.css'">>, <TextNode: ' .personas{ width: 100%;'>]> |
nodelist | [<TextNode: '\n\n'>, <Block Node: titulo. Contents: [<TextNode: 'Resultados de la busqueda'>, <Variable Node: query|escape>, <TextNode: '" - '>]>, <TextNode: '\n'>, <Block Node: head. Contents: []>, <TextNode: '\n\n'>, <Block Node: css. Contents: [<IncludeNode: template=<FilterExpression "'listado_obras.css'">>, <TextNode: ' '>, <IncludeNode: template=<FilterExpression "'obra_fichas.css'">>, <TextNode: ' .personas{ width: 100%;'>]>, <TextNode: '\n\n\n'>] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "block contenido..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py
, line 234, in do_block
if block_name in parser.__loaded_blocks:
raise TemplateSyntaxError(
"'%s' tag with name '%s' appears more than once" % (bits[0], block_name)
)
parser.__loaded_blocks.append(block_name)
except AttributeError: # parser.__loaded_blocks isn't a list yet
parser.__loaded_blocks = [block_name]
nodelist = parser.parse(("endblock",)) ^^^^^^^^^^^^^^^^^^^^^^^^^^^…
# This check is kept for backwards-compatibility. See #3100.
endblock = parser.next_token()
acceptable_endblocks = ("endblock", "endblock %s" % block_name)
if endblock.contents not in acceptable_endblocks:
parser.invalid_block_tag(endblock, "endblock", acceptable_endblocks)
Variable | Value |
---|---|
bits | ['block', 'contenido'] |
block_name | 'contenido' |
parser | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "block contenido..."> |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e) ^^^^^^^^^^^^^^^^^^^^^^^^^^…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'if' |
compile_func | <function do_if at 0x7f53750daa20> |
nodelist | [<TextNode: '<div class="contenido">\t'>] |
parse_until | ('endblock',) |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if query..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token) ^^^^^^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'if' |
compile_func | <function do_if at 0x7f53750daa20> |
nodelist | [<TextNode: '<div class="contenido">\t'>] |
parse_until | ('endblock',) |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if query..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py
, line 960, in do_if
``==``, ``!=``, ``>``, ``>=``, ``<`` and ``<=``.
Operator precedence follows Python.
"""
# {% if ... %}
bits = token.split_contents()[1:]
condition = TemplateIfParser(parser, bits).parse()
nodelist = parser.parse(("elif", "else", "endif")) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
conditions_nodelists = [(condition, nodelist)]
token = parser.next_token()
# {% elif ... %} (repeatable)
while token.contents.startswith("elif"):
bits = token.split_contents()[1:]
Variable | Value |
---|---|
bits | ['query'] |
condition | (literal <FilterExpression 'query'>) |
parser | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if query..."> |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e) ^^^^^^^^^^^^^^^^^^^^^^^^^^…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'if' |
compile_func | <function do_if at 0x7f53750daa20> |
compiled_result | <IfNode> |
filter_expression | <FilterExpression 'query|escape'> |
nodelist | [<TextNode: ' <h1>Results of search "'>, <Variable Node: query|escape>, <TextNode: '":</h1>'>, <IfNode>, <TextNode: ' '>, <IfNode>] |
parse_until | ('elif', 'else', 'endif') |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if nota..."> |
token_type | 2 |
var_node | <Variable Node: query|escape> |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token) ^^^^^^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'if' |
compile_func | <function do_if at 0x7f53750daa20> |
compiled_result | <IfNode> |
filter_expression | <FilterExpression 'query|escape'> |
nodelist | [<TextNode: ' <h1>Results of search "'>, <Variable Node: query|escape>, <TextNode: '":</h1>'>, <IfNode>, <TextNode: ' '>, <IfNode>] |
parse_until | ('elif', 'else', 'endif') |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if nota..."> |
token_type | 2 |
var_node | <Variable Node: query|escape> |
/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py
, line 960, in do_if
``==``, ``!=``, ``>``, ``>=``, ``<`` and ``<=``.
Operator precedence follows Python.
"""
# {% if ... %}
bits = token.split_contents()[1:]
condition = TemplateIfParser(parser, bits).parse()
nodelist = parser.parse(("elif", "else", "endif")) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
conditions_nodelists = [(condition, nodelist)]
token = parser.next_token()
# {% elif ... %} (repeatable)
while token.contents.startswith("elif"):
bits = token.split_contents()[1:]
Variable | Value |
---|---|
bits | ['nota'] |
condition | (literal <FilterExpression 'nota'>) |
parser | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "if nota..."> |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 504, in parse
# tag.
self.command_stack.append((command, token))
# Get the tag callback function from the ones registered with
# the parser.
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e)
Variable | Value |
---|---|
command | 'endblock' |
nodelist | [<TextNode: '<h3>Results within the No'>] |
parse_until | ('elif', 'else', 'endif') |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "endblock..."> |
token_type | 2 |
/usr/local/lib/python3.11/site-packages/django/template/base.py
, line 555, in invalid_block_tag
e = TemplateSyntaxError(e)
if not hasattr(e, "token"):
e.token = token
return e
def invalid_block_tag(self, token, command, parse_until=None):
if parse_until:
raise self.error( ^…
token,
"Invalid block tag on line %d: '%s', expected %s. Did you "
"forget to register or load this tag?"
% (
token.lineno,
command,
Variable | Value |
---|---|
command | 'endblock' |
parse_until | ('elif', 'else', 'endif') |
self | <Parser tokens=[<Block token: "endblock...">, <Block token: "include 'googletagma...">, <Block token: "block Analytics...">, <Text token: " ...">, <Block token: "endblock...">, <Block token: "block JavaScript...">, <Text token: "...">]> |
token | <Block token: "endblock..."> |
AnonymousUser
Variable | Value |
---|---|
tag | '武侠' |
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'upgrade' |
HTTP_HOST | 'aboutmovie.net' |
HTTP_REFERER | 'https://aboutmovie.net/search?tag=%E6%AD%A6%E4%BE%A0' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '3.95.2.54' |
HTTP_X_FORWARDED_HOST | 'aboutmovie.net' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '3.95.2.54' |
HTTP_X_REQUEST_ID | '582539-1711711340.424-3.95.2.54-169' |
PATH_INFO | '/search/' |
QUERY_STRING | 'tag=%E6%AD%A6%E4%BE%A0' |
RAW_URI | '/search/?tag=%E6%AD%A6%E4%BE%A0' |
REMOTE_ADDR | '192.168.192.1' |
REMOTE_PORT | '33230' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '8000' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/21.2.0' |
gunicorn.socket | <socket.socket fd=9, family=2, type=1, proto=0, laddr=('192.168.192.4', 8000), raddr=('192.168.192.1', 33230)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f5371d378e0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f5371bb18d0> |
wsgi.input_terminated | True |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
core.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['aboutmovie.applikuapp.com', '143.198.161.65', 'aboutmovie.net'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AWS_DEFAULT_ACL | 'public-read' |
AWS_LOCATION | 'cache-s3' |
AWS_S3_CUSTOM_DOMAIN | 'cineyseries-net.s3.amazonaws.com' |
AWS_S3_REGION_NAME | 'us-east-1' |
AWS_STORAGE_BUCKET_NAME | 'cineyseries-net' |
BASE_DIR | PosixPath('/code') |
BUCKET_NAME | 'cineyseries-net' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.dummy.DummyCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CI_COLLATION | 'utf8mb4_unicode_ci' |
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.mysql', 'HOST': 'am-ocean-do-user-15990242-0.c.db.ondigitalocean.com', 'NAME': 'am_ocean', 'OPTIONS': {}, '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 | '0' |
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 | '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 |
FORMS_URLFIELD_ASSUME_HTTPS | False |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.sites', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.redirects', 'sorl.thumbnail', 'app', 'storages', 'pure_pagination'] |
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 | 'es-mx' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '' |
MEDIA_URL | '/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'core.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 | 'core.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 | ('/code/archivos',) |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'storages.backends.s3boto3.S3Boto3Storage' |
STATIC_ROOT | None |
STATIC_URL | '/static/' |
STORAGES | {'default': {'BACKEND': 'storages.backends.s3boto3.S3Boto3Storage'}, 'staticfiles': {'BACKEND': 'storages.backends.s3boto3.S3Boto3Storage'}} |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/code/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 | ',' |
THUMBNAIL_DEFAULT_STORAGE | 'storages.backends.s3boto3.S3Boto3Storage' |
THUMBNAIL_ENGINE | 'sorl.thumbnail.engines.pil_engine.Engine' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'America/New_York' |
USE_I18N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'core.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.