connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5454:82a4:8209:20f8:a5c1), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support
Request Method: | GET |
---|---|
Request URL: | https://ili.ad/ |
Django Version: | 4.0.4 |
Exception Type: | OperationalError |
Exception Value: | connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5454:82a4:8209:20f8:a5c1), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support |
Exception Location: | /usr/local/lib/python3.8/site-packages/psycopg2/__init__.py, line 122, in connect |
Python Executable: | /usr/local/bin/python3 |
Python Version: | 3.8.10 |
Python Path: | ['/app', '/usr/local/bin', '/usr/local/lib/python38.zip', '/usr/local/lib/python3.8', '/usr/local/lib/python3.8/lib-dynload', '/usr/local/lib/python3.8/site-packages'] |
Server time: | Fri, 29 Mar 2024 07:05:50 +0000 |
In template /app/core/templates/core/headermobilemenu.html
, error at line 100
90 | </svg> |
---|---|
91 | </div> |
92 | <div class="ml-4 text-base font-small sm:font-medium text-stone-900 hidden mxs:inline flex-1">About</div> |
93 | </a> |
94 | </nav> |
95 | </div> |
96 | </div> |
97 | <div class="py-6 px-5"> |
98 | <div class="grid grid-cols-2 gap-4 "> |
99 | <!-- start image menu --> |
100 | {% for collection in collections %} |
101 | <div class="group relative text-base sm:text-sm"> |
102 | |
103 | <div |
104 | class="aspect-w-1 aspect-h-1 rounded-lg bg-gray-100 overflow-hidden group-hover:opacity-75 duration-500"> |
105 | <img src="{{collection.collection_cover_h}}" |
106 | alt="{{cover_alt_text}}" |
107 | class="object-center object-cover delay-300 duration-[3000ms] ease-in-out" |
108 | x-init="$watch('menuopen', value => value ? '' : $el.classList.remove('scale-105') )" |
109 | x-intersect="$el.classList.add('scale-105')" |
110 | > |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 244, in ensure_connection
)
@async_unsafe
def ensure_connection(self):
"""Guarantee that a connection to the database is established."""
if self.connection is None:
with self.wrap_database_errors:
self.connect()…
# ##### Backend-specific wrappers for PEP-249 connection methods #####
def _prepare_cursor(self, cursor):
"""
Validate the connection is usable and perform database cursor wrapping.
Variable | Value |
---|---|
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>,) |
func | <function BaseDatabaseWrapper.connect at 0x3e7828f33790> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 225, in connect
# Reset parameters defining when to close the connection
max_age = self.settings_dict["CONN_MAX_AGE"]
self.close_at = None if max_age is None else time.monotonic() + max_age
self.closed_in_transaction = False
self.errors_occurred = False
# Establish the connection
conn_params = self.get_connection_params()
self.connection = self.get_new_connection(conn_params)…
self.set_autocommit(self.settings_dict["AUTOCOMMIT"])
self.init_connection_state()
connection_created.send(sender=self.__class__, connection=self)
self.run_on_commit = []
Variable | Value |
---|---|
conn_params | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
max_age | 0 |
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>, {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'}) |
func | <function DatabaseWrapper.get_new_connection at 0x3e78285d0a60> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/postgresql/base.py
, line 203, in get_new_connection
conn_params["host"] = settings_dict["HOST"]
if settings_dict["PORT"]:
conn_params["port"] = settings_dict["PORT"]
return conn_params
@async_unsafe
def get_new_connection(self, conn_params):
connection = Database.connect(**conn_params)…
# self.isolation_level must be set:
# - after connecting to the database in order to obtain the database's
# default when no value is explicitly specified in options.
# - before calling _set_autocommit() because if autocommit is on, that
# will set connection.isolation_level to ISOLATION_LEVEL_AUTOCOMMIT.
Variable | Value |
---|---|
conn_params | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/psycopg2/__init__.py
, line 122, in connect
kwasync = {}
if 'async' in kwargs:
kwasync['async'] = kwargs.pop('async')
if 'async_' in kwargs:
kwasync['async_'] = kwargs.pop('async_')
dsn = _ext.make_dsn(dsn, **kwargs)
conn = _connect(dsn, connection_factory=connection_factory, **kwasync)…
if cursor_factory is not None:
conn.cursor_factory = cursor_factory
return conn
Variable | Value |
---|---|
connection_factory | None |
cursor_factory | None |
dsn | ('user=matthewsandryhoward password=GeOdY7kCPXQ2 ' 'host=ep-wispy-morning-729837.us-east-1.aws.neon.tech port=5432 dbname=iliad') |
kwargs | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
kwasync | {} |
/usr/local/lib/python3.8/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 | OperationalError('connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5454:82a4:8209:20f8:a5c1), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support\n') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x3e7828887550>> |
request | <WSGIRequest: GET '/'> |
/usr/local/lib/python3.8/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 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 frontpage at 0x3e78264584c0> |
callback_args | () |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x3e7828887550> |
wrapped_callback | <function frontpage at 0x3e78264584c0> |
/app/core/views.py
, line 24, in frontpage
return {
'products': Product.objects.order_by('order').all()[0:13],
'collections': Collection.objects.all().reverse(),
'form' : AnonMessageForm(),
}
def frontpage(request):
return render(request, 'core/frontpage.html')…
def about(request):
return render(request, 'core/aboutPage.html')
def message(request):
return render(HOME_PAGE_MSG)
Variable | Value |
---|---|
request | <WSGIRequest: GET '/'> |
/usr/local/lib/python3.8/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 | None |
request | <WSGIRequest: GET '/'> |
status | None |
template_name | 'core/frontpage.html' |
using | None |
/usr/local/lib/python3.8/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 | None |
request | <WSGIRequest: GET '/'> |
template | <django.template.backends.django.Template object at 0x3e782658d850> |
template_name | 'core/frontpage.html' |
using | None |
/usr/local/lib/python3.8/site-packages/django/template/backends/django.py
, line 62, 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}, {}, {}] |
request | <WSGIRequest: GET '/'> |
self | <django.template.backends.django.Template object at 0x3e782658d850> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 175, in render
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
context.template_name = self.name
return self._render(context)…
else:
return self._render(context)
def compile_nodelist(self):
"""
Parse and compile the template source into a nodelist. If debug
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% extends 'core/ba..."> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% extends 'core/ba..."> |
/usr/local/lib/python3.8/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}, {}, {}] |
self | [<TextNode: '\n'>, <ExtendsNode: extends 'core/base.html'>] |
/usr/local/lib/python3.8/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 0x3e78259ba190> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
node | <ExtendsNode: extends 'core/base.html'> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 958, 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}, {}, {}] |
self | <ExtendsNode: extends 'core/base.html'> |
/usr/local/lib/python3.8/site-packages/django/template/loader_tags.py
, line 157, in render
}
block_context.add_blocks(blocks)
break
# Call Template._render explicitly so the parser context stays
# the same.
with context.render_context.push_state(compiled_parent, isolated_context=False):
return compiled_parent._render(context)…
class IncludeNode(Node):
context_key = "__include_context"
def __init__(
Variable | Value |
---|---|
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'title': [<Block Node: title. Contents: []>, <Block Node: title. Contents: [<TextNode: 'Welcome'>]>], 'content': [<Block Node: content. Contents: [<TextNode: '\n '>]>, <Block Node: content. Contents: [<TextNode: '\n\n\n\n'>, <IncludeNode: template=<FilterExpression "'core/hero2.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/toc.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/announcing.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/productcarousel.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/press.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/about.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/blog.html'">>, <TextNode: '\n\n'>, <IncludeNode: template=<FilterExpression "'core/twoup.html'">>, <TextNode: '\n\n<script type="text/java'>]>], 'scripts': [<Block Node: scripts. Contents: [<TextNode: '\n '>]>]})> |
blocks | {'content': <Block Node: content. Contents: [<TextNode: '\n '>]>, 'scripts': <Block Node: scripts. Contents: [<TextNode: '\n '>]>, 'title': <Block Node: title. Contents: []>} |
compiled_parent | <Template template_string="{% load tailwind_tag..."> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
node | <django.template.defaulttags.LoadNode object at 0x3e78259d3e50> |
self | <ExtendsNode: extends 'core/base.html'> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% load tailwind_tag..."> |
/usr/local/lib/python3.8/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}, {}, {}] |
self | [<django.template.defaulttags.LoadNode object at 0x3e78259d3e50>, <TextNode: '\n'>, <django.template.defaulttags.LoadNode object at 0x3e78259d3f40>, <TextNode: '\n'>, <django.template.defaulttags.LoadNode object at 0x3e78259d7040>, <TextNode: '\n<!doctype html>\n\n<html c'>, <django.template.library.InclusionNode object at 0x3e78259d7100>, <TextNode: '\n <style>\n '>, <Block Node: title. Contents: []>, <TextNode: ' | Iliad</title>\n\n '>, StaticNode(varname=None, path=<FilterExpression "'media/favicon.png'">), <TextNode: '" sizes="any"><!-- 32×32 '>, StaticNode(varname=None, path=<FilterExpression "'media/favicon.svg'">), <TextNode: '" type="image/svg+xml">\n '>, StaticNode(varname=None, path=<FilterExpression "'media/faviconAppleTouch.png'">), <TextNode: '"><!-- 180×180 -->\n '>, StaticNode(varname=None, path=<FilterExpression "'media/manifest.webmanifest'">), <TextNode: '">\n \n\n <!--'>, <Variable Node: csrf_token>, <TextNode: '"}\' x-data>\n <div\n'>, <Variable Node: user.is_authenticated|lower>, <TextNode: '"\n @loginevent'>, <IncludeNode: template=<FilterExpression "'core/header.html'">>, <TextNode: '\n <main class="'>, <IfNode>, <TextNode: '">\n '>, <IfNode>, <TextNode: '\n '>, <Block Node: content. Contents: [<TextNode: '\n '>]>, <TextNode: '\n \n </m'>, <IncludeNode: template=<FilterExpression "'core/footer.html'">>, <TextNode: '\n '>, <IncludeNode: template=<FilterExpression "'core/notifications.html'">>, <TextNode: '\n\n <script src="ht'>, <django.template.library.SimpleNode object at 0x3e78259d9730>, <TextNode: '\n <script src="htt'>, <Block Node: scripts. Contents: [<TextNode: '\n '>]>, <TextNode: '\n </body>\n</html>'>] |
/usr/local/lib/python3.8/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 0x3e78259d3a00> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
node | <IncludeNode: template=<FilterExpression "'core/header.html'">> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 958, 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}, {}, {}] |
self | <IncludeNode: template=<FilterExpression "'core/header.html'">> |
/usr/local/lib/python3.8/site-packages/django/template/loader_tags.py
, line 208, in render
template = template.template
values = {
name: var.resolve(context) for name, var in self.extra_context.items()
}
if self.isolated_context:
return template.render(context.new(values))
with context.push(**values):
return template.render(context)…
@register.tag("block")
def do_block(parser, token):
"""
Define a block that can be overridden by child templates.
Variable | Value |
---|---|
cache | {('core/header.html',): <Template template_string="{% load static %}<h...">} |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <IncludeNode: template=<FilterExpression "'core/header.html'">> |
template | <Template template_string="{% load static %}<h..."> |
template_name | ('core/header.html',) |
values | {} |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 177, in render
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
context.template_name = self.name
return self._render(context)
else:
return self._render(context)…
def compile_nodelist(self):
"""
Parse and compile the template source into a nodelist. If debug
is True and an exception occurs during parsing, the exception is
annotated with contextual line information where it occurred in the
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% load static %}<h..."> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% load static %}<h..."> |
/usr/local/lib/python3.8/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}, {}, {}] |
self | [<django.template.defaulttags.LoadNode object at 0x3e78259e52e0>, <TextNode: '\n<header class="sticky to'>, <IncludeNode: template=<FilterExpression "'core/headermobilemenu.html'">>, <TextNode: '\n <!-- Log'>, StaticNode(varname=None, path=<FilterExpression "'media/iliad.svg'">), <TextNode: '" alt="Iliad Logo"><!-- s'>, <IncludeNode: template=<FilterExpression "'core/headerProductTab.html'">>, <TextNode: '\n\n '>, <URLNode view_name=''about'' args=[] kwargs={} as=None>, <TextNode: '"\n '>, <IncludeNode: template=<FilterExpression "'core/account.html'">>, <TextNode: '\n <!--'>, <IncludeNode: template=<FilterExpression "'cart/menu_cart2.html'">>, <TextNode: '\n\n </div>\n'>] |
/usr/local/lib/python3.8/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 0x3e78259ca790> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
node | <IncludeNode: template=<FilterExpression "'core/headermobilemenu.html'">> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 958, 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}, {}, {}] |
self | <IncludeNode: template=<FilterExpression "'core/headermobilemenu.html'">> |
/usr/local/lib/python3.8/site-packages/django/template/loader_tags.py
, line 208, in render
template = template.template
values = {
name: var.resolve(context) for name, var in self.extra_context.items()
}
if self.isolated_context:
return template.render(context.new(values))
with context.push(**values):
return template.render(context)…
@register.tag("block")
def do_block(parser, token):
"""
Define a block that can be overridden by child templates.
Variable | Value |
---|---|
cache | {('core/headermobilemenu.html',): <Template template_string="{% load static %}<!...">} |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <IncludeNode: template=<FilterExpression "'core/headermobilemenu.html'">> |
template | <Template template_string="{% load static %}<!..."> |
template_name | ('core/headermobilemenu.html',) |
values | {} |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 177, in render
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
context.template_name = self.name
return self._render(context)
else:
return self._render(context)…
def compile_nodelist(self):
"""
Parse and compile the template source into a nodelist. If debug
is True and an exception occurs during parsing, the exception is
annotated with contextual line information where it occurred in the
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% load static %}<!..."> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 167, in _render
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
self | <Template template_string="{% load static %}<!..."> |
/usr/local/lib/python3.8/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}, {}, {}] |
self | [<django.template.defaulttags.LoadNode object at 0x3e78259e7ac0>, <TextNode: '\n<!-- Flyout menus -->\n<d'>, <URLNode view_name=''about'' args=[] kwargs={} as=None>, <TextNode: '" class="-m-3 p-3 flex fl'>, <ForNode: for collection in collections, tail_len: 11>, <TextNode: '\n '>, <ForNode: for collection in collections, tail_len: 3>, <TextNode: ' '>] |
/usr/local/lib/python3.8/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 0x3e78259dcac0> |
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
node | <ForNode: for collection in collections, tail_len: 11> |
/usr/local/lib/python3.8/site-packages/django/template/base.py
, line 958, 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}, {}, {}] |
self | <ForNode: for collection in collections, tail_len: 11> |
/usr/local/lib/python3.8/site-packages/django/template/defaulttags.py
, line 194, in render
parentloop = {}
with context.push():
values = self.sequence.resolve(context, ignore_failures=True)
if values is None:
values = []
if not hasattr(values, "__len__"):
values = list(values)
len_values = len(values)…
if len_values < 1:
return self.nodelist_empty.render(context)
nodelist = []
if self.is_reversed:
values = reversed(values)
num_loopvars = len(self.loopvars)
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}] |
parentloop | {} |
self | <ForNode: for collection in collections, tail_len: 11> |
values | Error in formatting: OperationalError: connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:540b:c14a:4d57:1251:234d), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support |
/usr/local/lib/python3.8/site-packages/django/db/models/query.py
, line 302, in __len__
def __repr__(self):
data = list(self[: REPR_OUTPUT_SIZE + 1])
if len(data) > REPR_OUTPUT_SIZE:
data[-1] = "...(remaining elements truncated)..."
return "<%s %r>" % (self.__class__.__name__, data)
def __len__(self):
self._fetch_all()…
return len(self._result_cache)
def __iter__(self):
"""
The queryset iterator protocol uses three nested iterators in the
default case:
Variable | Value |
---|---|
self | Error in formatting: OperationalError: connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5419:4ecf:2a7c:cf52:31ae), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support |
/usr/local/lib/python3.8/site-packages/django/db/models/query.py
, line 1507, in _fetch_all
c._known_related_objects = self._known_related_objects
c._iterable_class = self._iterable_class
c._fields = self._fields
return c
def _fetch_all(self):
if self._result_cache is None:
self._result_cache = list(self._iterable_class(self))…
if self._prefetch_related_lookups and not self._prefetch_done:
self._prefetch_related_objects()
def _next_is_sticky(self):
"""
Indicate that the next filter call and the one following that should
Variable | Value |
---|---|
self | Error in formatting: OperationalError: connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:543b:a8aa:14fb:d008:11fe), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support |
/usr/local/lib/python3.8/site-packages/django/db/models/query.py
, line 57, in __iter__
def __iter__(self):
queryset = self.queryset
db = queryset.db
compiler = queryset.query.get_compiler(using=db)
# Execute the query. This will also fill compiler.select, klass_info,
# and annotations.
results = compiler.execute_sql(…
chunked_fetch=self.chunked_fetch, chunk_size=self.chunk_size
)
select, klass_info, annotation_col_map = (
compiler.select,
compiler.klass_info,
compiler.annotation_col_map,
Variable | Value |
---|---|
compiler | <django.db.models.sql.compiler.SQLCompiler object at 0x3e78259dcb20> |
db | 'default' |
queryset | Error in formatting: OperationalError: connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5421:acd1:6284:5a8a:d6e9), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support |
self | <django.db.models.query.ModelIterable object at 0x3e78259dcaf0> |
/usr/local/lib/python3.8/site-packages/django/db/models/sql/compiler.py
, line 1359, in execute_sql
if result_type == MULTI:
return iter([])
else:
return
if chunked_fetch:
cursor = self.connection.chunked_cursor()
else:
cursor = self.connection.cursor()…
try:
cursor.execute(sql, params)
except Exception:
# Might fail for server-side cursors (e.g. connection closed)
cursor.close()
raise
Variable | Value |
---|---|
chunk_size | 100 |
chunked_fetch | False |
params | () |
result_type | 'multi' |
self | <django.db.models.sql.compiler.SQLCompiler object at 0x3e78259dcb20> |
sql | ('SELECT "product_collection"."id", "product_collection"."name", ' '"product_collection"."slug", "product_collection"."description", ' '"product_collection"."cover_alt_text", ' '"product_collection"."collection_coverh", ' '"product_collection"."collection_coverv", ' '"product_collection"."collection_thumb" FROM "product_collection" ORDER BY ' '"product_collection"."name" DESC') |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>,) |
func | <function BaseDatabaseWrapper.cursor at 0x3e7828f33d30> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 284, in cursor
return self.connection.close()
# ##### Generic wrappers for PEP-249 connection methods #####
@async_unsafe
def cursor(self):
"""Create a cursor, opening a connection if necessary."""
return self._cursor()…
@async_unsafe
def commit(self):
"""Commit a transaction and reset the dirty flag."""
self.validate_thread_sharing()
self.validate_no_atomic_block()
Variable | Value |
---|---|
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 260, in _cursor
if self.queries_logged:
wrapped_cursor = self.make_debug_cursor(cursor)
else:
wrapped_cursor = self.make_cursor(cursor)
return wrapped_cursor
def _cursor(self, name=None):
self.ensure_connection()…
with self.wrap_database_errors:
return self._prepare_cursor(self.create_cursor(name))
def _commit(self):
if self.connection is not None:
with self.wrap_database_errors:
Variable | Value |
---|---|
name | None |
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>,) |
func | <function BaseDatabaseWrapper.ensure_connection at 0x3e7828f33940> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 244, in ensure_connection
)
@async_unsafe
def ensure_connection(self):
"""Guarantee that a connection to the database is established."""
if self.connection is None:
with self.wrap_database_errors:
self.connect()…
# ##### Backend-specific wrappers for PEP-249 connection methods #####
def _prepare_cursor(self, cursor):
"""
Validate the connection is usable and perform database cursor wrapping.
Variable | Value |
---|---|
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/db/utils.py
, line 91, in __exit__
db_exc_type = getattr(self.wrapper.Database, dj_exc_type.__name__)
if issubclass(exc_type, db_exc_type):
dj_exc_value = dj_exc_type(*exc_value.args)
# Only set the 'errors_occurred' flag for errors that may make
# the connection unusable.
if dj_exc_type not in (DataError, IntegrityError):
self.wrapper.errors_occurred = True
raise dj_exc_value.with_traceback(traceback) from exc_value…
def __call__(self, func):
# Note that we are intentionally not using @wraps here for performance
# reasons. Refs #21109.
def inner(*args, **kwargs):
with self:
Variable | Value |
---|---|
db_exc_type | <class 'psycopg2.OperationalError'> |
dj_exc_type | <class 'django.db.utils.OperationalError'> |
dj_exc_value | OperationalError('connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5454:82a4:8209:20f8:a5c1), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support\n') |
exc_type | <class 'psycopg2.OperationalError'> |
exc_value | OperationalError('connection to server at "ep-wispy-morning-729837.us-east-1.aws.neon.tech" (2600:1f18:240c:5454:82a4:8209:20f8:a5c1), port 5432 failed: ERROR: Console request failed: endpoint is temporary unavailable. check your quotas and/or contact our support\n') |
self | <django.db.utils.DatabaseErrorWrapper object at 0x3e78265761c0> |
traceback | <traceback object at 0x3e78259ed3c0> |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 244, in ensure_connection
)
@async_unsafe
def ensure_connection(self):
"""Guarantee that a connection to the database is established."""
if self.connection is None:
with self.wrap_database_errors:
self.connect()…
# ##### Backend-specific wrappers for PEP-249 connection methods #####
def _prepare_cursor(self, cursor):
"""
Validate the connection is usable and perform database cursor wrapping.
Variable | Value |
---|---|
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>,) |
func | <function BaseDatabaseWrapper.connect at 0x3e7828f33790> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/base/base.py
, line 225, in connect
# Reset parameters defining when to close the connection
max_age = self.settings_dict["CONN_MAX_AGE"]
self.close_at = None if max_age is None else time.monotonic() + max_age
self.closed_in_transaction = False
self.errors_occurred = False
# Establish the connection
conn_params = self.get_connection_params()
self.connection = self.get_new_connection(conn_params)…
self.set_autocommit(self.settings_dict["AUTOCOMMIT"])
self.init_connection_state()
connection_created.send(sender=self.__class__, connection=self)
self.run_on_commit = []
Variable | Value |
---|---|
conn_params | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
max_age | 0 |
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/django/utils/asyncio.py
, line 26, in inner
try:
asyncio.get_running_loop()
except RuntimeError:
pass
else:
raise SynchronousOnlyOperation(message)
# Pass onward.
return func(*args, **kwargs)…
return inner
# If the message is actually a function, then be a no-arguments decorator.
if callable(message):
func = message
Variable | Value |
---|---|
args | (<django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0>, {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'}) |
func | <function DatabaseWrapper.get_new_connection at 0x3e78285d0a60> |
kwargs | {} |
message | 'You cannot call this from an async context - use a thread or sync_to_async.' |
/usr/local/lib/python3.8/site-packages/django/db/backends/postgresql/base.py
, line 203, in get_new_connection
conn_params["host"] = settings_dict["HOST"]
if settings_dict["PORT"]:
conn_params["port"] = settings_dict["PORT"]
return conn_params
@async_unsafe
def get_new_connection(self, conn_params):
connection = Database.connect(**conn_params)…
# self.isolation_level must be set:
# - after connecting to the database in order to obtain the database's
# default when no value is explicitly specified in options.
# - before calling _set_autocommit() because if autocommit is on, that
# will set connection.isolation_level to ISOLATION_LEVEL_AUTOCOMMIT.
Variable | Value |
---|---|
conn_params | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
self | <django.db.backends.postgresql.base.DatabaseWrapper object at 0x3e7828f0bac0> |
/usr/local/lib/python3.8/site-packages/psycopg2/__init__.py
, line 122, in connect
kwasync = {}
if 'async' in kwargs:
kwasync['async'] = kwargs.pop('async')
if 'async_' in kwargs:
kwasync['async_'] = kwargs.pop('async_')
dsn = _ext.make_dsn(dsn, **kwargs)
conn = _connect(dsn, connection_factory=connection_factory, **kwasync)…
if cursor_factory is not None:
conn.cursor_factory = cursor_factory
return conn
Variable | Value |
---|---|
connection_factory | None |
cursor_factory | None |
dsn | ('user=matthewsandryhoward password=GeOdY7kCPXQ2 ' 'host=ep-wispy-morning-729837.us-east-1.aws.neon.tech port=5432 dbname=iliad') |
kwargs | {'database': 'iliad', 'host': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'password': 'GeOdY7kCPXQ2', 'port': '5432', 'user': 'matthewsandryhoward'} |
kwasync | {} |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
CSRF_COOKIE | 'OQiTZJRpQLQCNnv9jzW8zZEZfsq5P1cIDRcUtlUQDanVuxGOZAazDjqvR8W0TxDQ' |
CSRF_COOKIE_NEEDS_UPDATE | True |
HTTP_ACCEPT | '*/*' |
HTTP_FORWARDED | 'for="44.211.188.101";proto=https' |
HTTP_HOST | 'ili.ad' |
HTTP_REFERER | 'http://ili.ad/' |
HTTP_TRACEPARENT | '00-fcc3f48ab018b8573fb097c59053e415-4b6d79f59135cef3-00' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_CLOUD_TRACE_CONTEXT | 'fcc3f48ab018b8573fb097c59053e415/5435134420916227827' |
HTTP_X_FORWARDED_FOR | '44.211.188.101' |
HTTP_X_FORWARDED_PROTO | 'https' |
PATH_INFO | '/' |
QUERY_STRING | '' |
RAW_URI | '/' |
REMOTE_ADDR | '169.254.1.1' |
REMOTE_PORT | '39687' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '8080' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/20.1.0' |
gunicorn.socket | <socket.socket fd=9, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('192.168.1.1', 8080), raddr=('169.254.1.1', 39687)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x3e78265bd820> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x3e78265c0550> |
wsgi.input_terminated | True |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
iliad.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ACCOUNT_AUTHENTICATION_METHOD | 'email' |
ACCOUNT_EMAIL_CONFIRMATION_ANONYMOUS_REDIRECT_URL | '/profile/' |
ACCOUNT_EMAIL_CONFIRMATION_AUTHENTICATED_REDIRECT_URL | '/profile/' |
ACCOUNT_EMAIL_CONFIRMATION_EXPIRE_DAYS | 7 |
ACCOUNT_EMAIL_REQUIRED | True |
ACCOUNT_EMAIL_VERIFICATION | 'optional' |
ACCOUNT_FORMS | {'change_password': '********************', 'login': 'account.forms.MyCustomLoginForm', 'signup': 'account.forms.MyCustomSignupForm'} |
ACCOUNT_LOGOUT_REDIRECT_URL | '/account/hx_loggedout/' |
ACCOUNT_MAX_EMAIL_ADDRESSES | 3 |
ACCOUNT_SIGNUP_PASSWORD_ENTER_TWICE | '********************' |
ACCOUNT_SIGNUP_REDIRECT_URL | '/account/hx_signup_success/' |
ACCOUNT_UNIQUE_EMAIL | True |
ACCOUNT_USERNAME_REQUIRED | False |
ACCOUNT_USER_DISPLAY | <function <lambda> at 0x3e782aeebe50> |
ACCOUNT_USER_MODEL_USERNAME_FIELD | 'username' |
ADMINS | [] |
ALLOWED_HOSTS | ['.ili.ad', 'iliad-001-p2pbwjdokq-uk.a.run.app'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend', 'allauth.account.auth_backends.AuthenticationBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | PosixPath('/app') |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CAPTCHA_CHALLENGE_FUNCT | 'captcha.helpers.word_challenge' |
CAPTCHA_FONT_PATH | '/app/staticfiles/fonts/IBMPlexSans-Bold.ttf' |
CAPTCHA_IMAGE_SIZE | (181, 56) |
CAPTCHA_WORDS_DICTIONARY | PosixPath('/app/emails/templates/emails/partials/CaptchaDict.txt') |
CART_SESSION_ID | 'cart' |
CLOUDRUN_SERVICE_URL | 'https://iliad-001-p2pbwjdokq-uk.a.run.app' |
CRISPY_ALLOWED_TEMPLATE_PACKS | 'tailwind' |
CRISPY_TEMPLATE_PACK | 'tailwind' |
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 | ['https://ili.ad', 'https://iliad-001-p2pbwjdokq-uk.a.run.app'] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql', 'HOST': 'ep-wispy-morning-729837.us-east-1.aws.neon.tech', 'NAME': 'iliad', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'matthewsandryhoward'}} |
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:%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'] |
DB_NAME | 'iliad' |
DB_URI | 'ep-wispy-morning-729837.us-east-1.aws.neon.tech' |
DB_USER_PW | 'GeOdY7kCPXQ2' |
DB_USER_UN | 'matthewsandryhoward' |
DEBUG | 'False' |
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.gcloud.GoogleCloudStorage' |
DEFAULT_FROM_EMAIL | 'noreply@ili.ad' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'sendgrid_backend.SendgridBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
GOOGLE_API_KEY | '********************' |
GS_BUCKET_NAME | 'iliad-001-static' |
GS_CREDENTIALS | <google.oauth2.service_account.Credentials object at 0x3e782aee1a30> |
HOME_PAGE_MSG | 'This is production' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.humanize', 'django.contrib.messages', 'django.contrib.sessions', 'django.contrib.sites', 'django.contrib.staticfiles', 'allauth', 'allauth.account', 'allauth.socialaccount', 'allauth.socialaccount.providers.google', 'allauth.socialaccount.providers.instagram', 'allauth.socialaccount.providers.pinterest', 'adminsortable2', 'captcha', 'crispy_forms', 'crispy_tailwind', 'django_browser_reload', 'django_htmx', 'djmoney', 'phonenumber_field', 'tailwind', 'theme', 'address', 'cart', 'core', 'product', 'palette', 'order', 'emails', 'useraddress', 'userprofile'] |
INSTANCE_CONNECTION_NAME | 'iliad-001:us-east4:iliad-001' |
INTERNAL_IPS | ['127.0.0.1'] |
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'), ('ms', 'Malay'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'en-us' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/account/hx_login_success/' |
LOGIN_URL | '/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/app/staticfiles/media' |
MEDIA_URL | '/storages.backends.gcloud.GoogleCloudStorage/iliad-001-static/media/' |
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_browser_reload.middleware.BrowserReloadMiddleware', 'django_htmx.middleware.HtmxMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'iliad.urls' |
SECRET_KEY | '********************' |
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 | ('HTTP_X_FORWARDED_PROTO', 'https') |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | True |
SENDGRID_API_KEY | '********************' |
SENDGRID_ECHO_TO_STDOUT | True |
SENDGRID_SANDBOX_MODE_IN_DEBUG | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 86400 |
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 | 'iliad.settings.production' |
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': {'APP': {'client_id': '123', 'key': '********************', 'secret': '********************'}}} |
STATICFILES_DIRS | [] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'storages.backends.gcloud.GoogleCloudStorage' |
STATIC_ROOT | '/app/staticfiles' |
STATIC_URL | '/storages.backends.gcloud.GoogleCloudStorageiliad-001-static/static/' |
STRIPE_API_KEY_HIDDEN | '********************' |
STRIPE_API_KEY_PUBLISHABLE | '********************' |
TAILWIND_APP_NAME | 'theme' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [PosixPath('/app/templates'), PosixPath('/app/account/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', 'core.context_processors.global_context', 'cart.context_processors.cart', 'cart.context_processors.products_in_cart']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'UTC' |
USE_DEPRECATED_PYTZ | False |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'iliad.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.