'staticfiles' is not a registered tag library. Must be one of: account admin_list admin_modify admin_urls cache humanize i18n imagekit l10n log socialaccount static tz utils widget_tweaks
Request Method: | GET |
---|---|
Request URL: | https://www.novo.pet/public/animal/308/ |
Django Version: | 3.2.16 |
Exception Type: | TemplateSyntaxError |
Exception Value: | 'staticfiles' is not a registered tag library. Must be one of: account admin_list admin_modify admin_urls cache humanize i18n imagekit l10n log socialaccount static tz utils widget_tweaks |
Exception Location: | /app/.heroku/python/lib/python3.9/site-packages/django/template/defaulttags.py, line 1039, in find_library |
Python Executable: | /app/.heroku/python/bin/python |
Python Version: | 3.9.16 |
Python Path: | ['/app/.heroku/python/bin', '/app', '/app/.heroku/python/lib/python39.zip', '/app/.heroku/python/lib/python3.9', '/app/.heroku/python/lib/python3.9/lib-dynload', '/app/.heroku/python/lib/python3.9/site-packages'] |
Server time: | Fri, 29 Mar 2024 04:39:21 +0000 |
In template /app/common/templates/403.html
, error at line 3
1 | {% extends "base_errors.html" %} |
---|---|
2 | {% load i18n %} |
3 | {% load staticfiles %} |
4 | {% block headContent %} |
5 | <a href="/"><img src="{% static 'img/ban.png'%}" width="64" height="64"></a> |
6 | <h1 class="display-1 text-muted mb-7">Sem acesso</h1> |
7 | <p class="lead">Não tens acesso à página, associação ou animal a que estás a tentar aceder :(</p> |
8 | {% endblock %} |
9 | {% block mainBody %} |
10 | <!-- $MESSAGES =================================================================== --> |
11 | {% if messages %} |
12 | {% for message in messages %} |
13 | <div class="alert alert-{{ message.tags }} alert-dark"> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/defaulttags.py
, line 1037, in find_library
nodelist_false = NodeList()
values = [parser.compile_filter(bit) for bit in bits[1:]]
return IfChangedNode(nodelist_true, nodelist_false, *values)
def find_library(parser, name):
try:
return parser.libraries[name]…
except KeyError:
raise TemplateSyntaxError(
"'%s' is not a registered tag library. Must be one of:\n%s" % (
name, "\n".join(sorted(parser.libraries)),
),
)
Variable | Value |
---|---|
name | 'staticfiles' |
parser | <django.template.base.Parser object at 0x7f6aec7e9850> |
/app/.heroku/python/lib/python3.9/site-packages/django/core/handlers/exception.py
, line 47, in inner
response = await sync_to_async(response_for_exception, thread_sensitive=False)(request, exc)
return response
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("'staticfiles' is not a registered tag library. Must be one of:\naccount\nadmin_list\nadmin_modify\nadmin_urls\ncache\nhumanize\ni18n\nimagekit\nl10n\nlog\nsocialaccount\nstatic\ntz\nutils\nwidget_tweaks") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f6aed89aeb0>> |
request | <WSGIRequest: GET '/public/animal/308/'> |
/app/.heroku/python/lib/python3.9/site-packages/django/core/handlers/base.py
, line 181, 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 asyncio.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 animal_view at 0x7f6aed67d040> |
callback_args | () |
callback_kwargs | {'p_id': '308'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f6aed6a3100>> |
request | <WSGIRequest: GET '/public/animal/308/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f6aed89aeb0> |
wrapped_callback | <function animal_view at 0x7f6aed67d040> |
/app/public/views.py
, line 195, in animal_view
messages.success(request, 'O seu pedido de adoção foi enviado!')
# render page
context = {'record': record, 'record_entity': record_entity}
return render(request, 'animal_single.html', context)
else:
return render(request, '403.html')…
@csrf_protect
def entities_view(request, p_id):
#try:
#l_content = get_object_or_404(Entity, pk=p_id)
Variable | Value |
---|---|
l_content | <Animal: Farrusco> |
l_content_entity | <Entity: Munícipio de Viana do castelo> |
p_id | '308' |
record | <QuerySet []> |
record_entity | <QuerySet [<Entity: Munícipio de Viana do castelo>]> |
request | <WSGIRequest: GET '/public/animal/308/'> |
/app/.heroku/python/lib/python3.9/site-packages/django/shortcuts.py
, line 19, in render
def render(request, template_name, context=None, content_type=None, status=None, using=None):
"""
Return a 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 | None |
request | <WSGIRequest: GET '/public/animal/308/'> |
status | None |
template_name | '403.html' |
using | None |
/app/.heroku/python/lib/python3.9/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 | None |
request | <WSGIRequest: GET '/public/animal/308/'> |
template_name | '403.html' |
using | None |
/app/.heroku/python/lib/python3.9/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 0x7f6aec923430> |
engines | [<django.template.backends.django.DjangoTemplates object at 0x7f6aec923430>] |
template_name | '403.html' |
using | None |
/app/.heroku/python/lib/python3.9/site-packages/django/template/backends/django.py
, line 34, 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 0x7f6aec923430> |
template_name | '403.html' |
/app/.heroku/python/lib/python3.9/site-packages/django/template/engine.py
, line 143, 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 | <django.template.engine.Engine object at 0x7f6aec927d60> |
template_name | '403.html' |
/app/.heroku/python/lib/python3.9/site-packages/django/template/engine.py
, line 125, in find_template
raise ImproperlyConfigured(
"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.app_directories.Loader object at 0x7f6aec92eb20> |
name | '403.html' |
self | <django.template.engine.Engine object at 0x7f6aec927d60> |
skip | None |
tried | [(<django.template.base.Origin object at 0x7f6aec458970>, 'Source does not exist')] |
/app/.heroku/python/lib/python3.9/site-packages/django/template/loaders/base.py
, line 29, 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,
)
raise TemplateDoesNotExist(template_name, tried=tried)
def get_template_sources(self, template_name):
Variable | Value |
---|---|
contents | ('{% extends "base_errors.html" %}\n' '{% load i18n %}\n' '{% load staticfiles %}\n' '{% block headContent %}\n' ' <a href="/"><img src="{% static \'img/ban.png\'%}" width="64" ' 'height="64"></a>\n' ' <h1 class="display-1 text-muted mb-7">Sem acesso</h1>\n' ' <p class="lead">Não tens acesso à página, associação ou animal a que ' 'estás a tentar aceder :(</p>\n' '{% endblock %}\n' '{% block mainBody %}\n' ' <!-- $MESSAGES ' '=================================================================== -->\n' ' {% if messages %}\n' ' {% for message in messages %}\n' ' <div class="alert alert-{{ message.tags }} alert-dark">\n' ' <button type="button" class="close" ' 'data-dismiss="alert">×</button>\n' ' <strong>{{ message.tags }}</strong> {{ message }}\n' ' </div>\n' ' {% endfor %}\n' ' {% endif %}\n' '\n' '\n' '\n' '{% endblock %}\n' '\n') |
origin | <django.template.base.Origin object at 0x7f6aec7f55e0> |
self | <django.template.loaders.app_directories.Loader object at 0x7f6aec92eb20> |
skip | None |
template_name | '403.html' |
tried | [(<django.template.base.Origin object at 0x7f6aec458160>, 'Source does not exist'), (<django.template.base.Origin object at 0x7f6aec458490>, 'Source does not exist'), (<django.template.base.Origin object at 0x7f6aec458850>, 'Source does not exist'), (<django.template.base.Origin object at 0x7f6aec458b80>, 'Source does not exist')] |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 155, 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 __iter__(self):
for node in self.nodelist:
yield from node
def _render(self, context):
Variable | Value |
---|---|
engine | <django.template.engine.Engine object at 0x7f6aec927d60> |
name | '403.html' |
origin | <django.template.base.Origin object at 0x7f6aec7f55e0> |
self | <django.template.base.Template object at 0x7f6aec7f5c40> |
template_string | ('{% extends "base_errors.html" %}\n' '{% load i18n %}\n' '{% load staticfiles %}\n' '{% block headContent %}\n' ' <a href="/"><img src="{% static \'img/ban.png\'%}" width="64" ' 'height="64"></a>\n' ' <h1 class="display-1 text-muted mb-7">Sem acesso</h1>\n' ' <p class="lead">Não tens acesso à página, associação ou animal a que ' 'estás a tentar aceder :(</p>\n' '{% endblock %}\n' '{% block mainBody %}\n' ' <!-- $MESSAGES ' '=================================================================== -->\n' ' {% if messages %}\n' ' {% for message in messages %}\n' ' <div class="alert alert-{{ message.tags }} alert-dark">\n' ' <button type="button" class="close" ' 'data-dismiss="alert">×</button>\n' ' <strong>{{ message.tags }}</strong> {{ message }}\n' ' </div>\n' ' {% endfor %}\n' ' {% endif %}\n' '\n' '\n' '\n' '{% endblock %}\n' '\n') |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 193, in compile_nodelist
tokens = lexer.tokenize()
parser = Parser(
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 | <django.template.base.DebugLexer object at 0x7f6aec7f51c0> |
parser | <django.template.base.Parser object at 0x7f6aec7e9850> |
self | <django.template.base.Template object at 0x7f6aec7f5c40> |
tokens | [<django.template.base.Token object at 0x7f6aec7f5610>, <django.template.base.Token object at 0x7f6aec7f5160>, <django.template.base.Token object at 0x7f6aec7f59d0>, <django.template.base.Token object at 0x7f6aec7f5970>, <django.template.base.Token object at 0x7f6aec7f59a0>, <django.template.base.Token object at 0x7f6aec7f5760>, <django.template.base.Token object at 0x7f6aec7f5f40>, <django.template.base.Token object at 0x7f6aec7f5400>, <django.template.base.Token object at 0x7f6aec7f5e80>, <django.template.base.Token object at 0x7f6aec7f5040>, <django.template.base.Token object at 0x7f6aec7f5190>, <django.template.base.Token object at 0x7f6aec7f5a90>, <django.template.base.Token object at 0x7f6aec7f5250>, <django.template.base.Token object at 0x7f6aec7f54c0>, <django.template.base.Token object at 0x7f6aec7f5730>, <django.template.base.Token object at 0x7f6aec7f5d60>, <django.template.base.Token object at 0x7f6aec7f5bb0>, <django.template.base.Token object at 0x7f6aec7f5220>, <django.template.base.Token object at 0x7f6aec7f5cd0>, <django.template.base.Token object at 0x7f6aec7f5f10>, <django.template.base.Token object at 0x7f6aec7f5df0>, <django.template.base.Token object at 0x7f6aec7f58b0>, <django.template.base.Token object at 0x7f6aec7f5ca0>, <django.template.base.Token object at 0x7f6aec7f5520>, <django.template.base.Token object at 0x7f6aec7f5fd0>, <django.template.base.Token object at 0x7f6aec7e9be0>, <django.template.base.Token object at 0x7f6aec7e9040>, <django.template.base.Token object at 0x7f6aec7e9610>, <django.template.base.Token object at 0x7f6aec7e9910>, <django.template.base.Token object at 0x7f6aec7f54f0>] |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 478, 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 0x7f6af0dbb0d0> |
nodelist | [] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f5610> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 476, 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 0x7f6af0dbb0d0> |
nodelist | [] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f5610> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/loader_tags.py
, line 278, 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)
@register.tag('include')
Variable | Value |
---|---|
bits | ['extends', '"base_errors.html"'] |
parent_name | <django.template.base.FilterExpression object at 0x7f6aec7e9340> |
parser | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f5610> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 478, 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 | 'load' |
compile_func | <function load at 0x7f6af0db2d30> |
compiled_result | <django.template.defaulttags.LoadNode object at 0x7f6aec7e91c0> |
nodelist | [<TextNode: '\n'>, <django.template.defaulttags.LoadNode object at 0x7f6aec7e91c0>, <TextNode: '\n'>] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f59a0> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/base.py
, line 476, 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 | 'load' |
compile_func | <function load at 0x7f6af0db2d30> |
compiled_result | <django.template.defaulttags.LoadNode object at 0x7f6aec7e91c0> |
nodelist | [<TextNode: '\n'>, <django.template.defaulttags.LoadNode object at 0x7f6aec7e91c0>, <TextNode: '\n'>] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f59a0> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/defaulttags.py
, line 1094, in load
name = bits[-1]
lib = find_library(parser, name)
subset = load_from_library(lib, name, bits[1:-2])
parser.add_library(subset)
else:
# one or more libraries are specified; load and add them to the parser
for name in bits[1:]:
lib = find_library(parser, name)…
parser.add_library(lib)
return LoadNode()
@register.tag
def lorem(parser, token):
Variable | Value |
---|---|
bits | ['load', 'staticfiles'] |
name | 'staticfiles' |
parser | <django.template.base.Parser object at 0x7f6aec7e9850> |
token | <django.template.base.Token object at 0x7f6aec7f59a0> |
/app/.heroku/python/lib/python3.9/site-packages/django/template/defaulttags.py
, line 1039, in find_library
return IfChangedNode(nodelist_true, nodelist_false, *values)
def find_library(parser, name):
try:
return parser.libraries[name]
except KeyError:
raise TemplateSyntaxError(…
"'%s' is not a registered tag library. Must be one of:\n%s" % (
name, "\n".join(sorted(parser.libraries)),
),
)
Variable | Value |
---|---|
name | 'staticfiles' |
parser | <django.template.base.Parser object at 0x7f6aec7e9850> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_CONNECT_TIME | '0' |
HTTP_HOST | 'www.novo.pet' |
HTTP_REFERER | 'https://www.novo.pet/public/animal/308' |
HTTP_TOTAL_ROUTE_TIME | '0' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_VIA | '1.1 vegur' |
HTTP_X_FORWARDED_FOR | '54.80.11.160' |
HTTP_X_FORWARDED_PORT | '443' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REQUEST_ID | '811ab224-8850-49d9-9fde-7afe22c14b9d' |
HTTP_X_REQUEST_START | '1711687161002' |
PATH_INFO | '/public/animal/308/' |
QUERY_STRING | '' |
RAW_URI | '/public/animal/308/' |
REMOTE_ADDR | '10.1.11.198' |
REMOTE_PORT | '30633' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '37012' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/19.9.0' |
gunicorn.socket | <socket.socket fd=10, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('172.18.21.218', 37012), raddr=('10.1.11.198', 30633)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f6aec458eb0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f6aec458fa0> |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
baseapp.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['*'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend', 'allauth.account.auth_backends.AuthenticationBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'common.User' |
AWS_ACCESS_KEY_ID | '********************' |
AWS_LOCATION | 'static' |
AWS_S3_CUSTOM_DOMAIN | 'app-petmanager.s3.amazonaws.com' |
AWS_S3_OBJECT_PARAMETERS | {'CacheControl': 'max-age=86400'} |
AWS_SECRET_ACCESS_KEY | '********************' |
AWS_STORAGE_BUCKET_NAME | 'app-petmanager' |
BASE_DIR | '/app' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | True |
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_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'HOST': 'production01s.clda6tlsc9un.eu-west-3.rds.amazonaws.com', 'NAME': 'novopetprd', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': 5432, 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'sysdba'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_AUTO_FIELD | 'django.db.models.AutoField' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_EXCEPTION_REPORTER | 'django.views.debug.ExceptionReporter' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'common.storage_backends.MediaStorage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_HASHING_ALGORITHM | 'sha256' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.sendgrid.net' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'apikey' |
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 | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
GLOBAL_APP_NAME | 'Novo.pet' |
GLOBAL_APP_NAME_SHORT | 'PM' |
GLOBAL_APP_TAG_LINE | ('é uma aplicação para promover a adoção, a sanidade e o bem-estar animal nas ' 'instituições de abrigo') |
GLOBAL_BIRTHDAY | '022024' |
GLOBAL_COPYRIGHT | 'valuedate.io' |
GLOBAL_CUSTOMER | 'Public' |
GLOBAL_DJANGO_PORT | '80' |
GLOBAL_EMAIL_SUPPORT | 'app.novopet@valuedate.pt' |
GLOBAL_ENVIRONMENT | 'PRODUCTION' |
GLOBAL_FULL_URL | 'https://www.novo.pet/' |
GLOBAL_NUMBER_USERS | '99999' |
GLOBAL_PHONE_SUPPORT | '+351 964367684' |
GLOBAL_SITE_KEY | '********************' |
GLOBAL_URL | 'http://127.0.0.1:8001' |
GLOBAL_VERSION | 'v24.005.20240504' |
GLOBAL_YEAR | '2023' |
IGNORABLE_404_URLS | [] |
IMAGEKIT_CACHEFILE_DIR | 'CACHE/images' |
IMAGEKIT_CACHEFILE_NAMER | 'imagekit.cachefiles.namers.hash' |
IMAGEKIT_CACHE_BACKEND | 'default' |
IMAGEKIT_CACHE_PREFIX | 'imagekit:' |
IMAGEKIT_CACHE_TIMEOUT | 300 |
IMAGEKIT_DEFAULT_CACHEFILE_BACKEND | 'imagekit.cachefiles.backends.Simple' |
IMAGEKIT_DEFAULT_CACHEFILE_STRATEGY | 'imagekit.cachefiles.strategies.JustInTime' |
IMAGEKIT_DEFAULT_FILE_STORAGE | 'common.storage_backends.MediaStorage' |
IMAGEKIT_SPEC_CACHEFILE_NAMER | 'imagekit.cachefiles.namers.source_name_as_path' |
IMAGEKIT_USE_MEMCACHED_SAFE_CACHE_KEY | '********************' |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.humanize', 'django.contrib.sites', 'django.contrib.sitemaps', 'widget_tweaks', 'storages', 'imagekit', 'common', 'public', 'portal', 'captcha', 'allauth', 'allauth.account', 'allauth.socialaccount', 'allauth.socialaccount.providers.google'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ar-dz', 'Algerian Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('cs', 'Czech'), ('cy', 'Welsh'), ('da', 'Danish'), ('de', 'German'), ('dsb', 'Lower Sorbian'), ('el', 'Greek'), ('en', 'English'), ('en-au', 'Australian English'), ('en-gb', 'British English'), ('eo', 'Esperanto'), ('es', 'Spanish'), ('es-ar', 'Argentinian Spanish'), ('es-co', 'Colombian Spanish'), ('es-mx', 'Mexican Spanish'), ('es-ni', 'Nicaraguan Spanish'), ('es-ve', 'Venezuelan Spanish'), ('et', 'Estonian'), ('eu', 'Basque'), ('fa', 'Persian'), ('fi', 'Finnish'), ('fr', 'French'), ('fy', 'Frisian'), ('ga', 'Irish'), ('gd', 'Scottish Gaelic'), ('gl', 'Galician'), ('he', 'Hebrew'), ('hi', 'Hindi'), ('hr', 'Croatian'), ('hsb', 'Upper Sorbian'), ('hu', 'Hungarian'), ('hy', 'Armenian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('ig', 'Igbo'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('ky', 'Kyrgyz'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'pt-pt' |
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 | '/portal' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | '/accounts/signin' |
MANAGERS | [] |
MEDIA_ROOT | '' |
MEDIA_URL | '/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django_feature_policy.PermissionsPolicyMiddleware', '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', 'whitenoise.middleware.WhiteNoiseMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PERMISSIONS_POLICY | {'autoplay': '*', 'fullscreen': '*', 'geolocation': '*'} |
PREPEND_WWW | False |
PROJECT_ROOT | '/app/baseapp' |
RECAPTCHA_PRIVATE_KEY | '********************' |
RECAPTCHA_PUBLIC_KEY | '********************' |
ROOT_URLCONF | 'baseapp.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | True |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | True |
SECURE_HSTS_PRELOAD | True |
SECURE_HSTS_SECONDS | 31536000 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | 'True' |
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 | 'Strict' |
SESSION_COOKIE_SECURE | True |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | True |
SESSION_EXPIRE_SECONDS | 28800 |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'baseapp.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 |
SOCIALACCOUNT_PROVIDERS | {'google': {'AUTH_PARAMS': {'access_type': 'online'}, 'SCOPE': ['profile', 'email']}} |
STATICFILES_DIRS | ('/app/baseapp/static', 'https://app-petmanager.s3.amazonaws.com/static/') |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'whitenoise.storage.CompressedStaticFilesStorage' |
STATIC_ROOT | '/app/baseapp/staticfiles' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/app/baseapp/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', 'common.context_processors.globalsettings']}}] |
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 | 'GMT' |
URL_SERVER | '127.0.0.1:8001' |
USE_I18N | True |
USE_L10N | False |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | False |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'baseapp.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.