no such table: core_gallery
Request Method: | GET |
---|---|
Request URL: | https://vipglass.ca/ |
Django Version: | 4.2.7 |
Exception Type: | OperationalError |
Exception Value: | no such table: core_gallery |
Exception Location: | /workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/sqlite3/base.py, line 328, in execute |
Raised during: | core.views.HomeView |
Python Executable: | /app/.heroku/python/bin/python |
Python Version: | 3.11.5 |
Python Path: | ['/workspace/.heroku/python/bin', '/workspace', '/workspace/.heroku/python/lib/python311.zip', '/workspace/.heroku/python/lib/python3.11', '/workspace/.heroku/python/lib/python3.11/lib-dynload', '/workspace/.heroku/python/lib/python3.11/site-packages'] |
Server time: | Fri, 29 Mar 2024 15:20:05 +0000 |
In template /workspace/templates/core/index.html
, error at line 260
250 | <!-- service-section end --> |
---|---|
251 | |
252 | |
253 | <!-- gallery-section --> |
254 | <section class="gallery-section"> |
255 | <div class="container-fluid"> |
256 | <div class="sec-title centred"> |
257 | <span class="top-text">Photo gallery</span> |
258 | </div> |
259 | <div class="four-item-carousel owl-carousel owl-theme owl-nav-none"> |
260 | {% for img in gallery_images %} |
261 | <div class="project-block-one small-image"> |
262 | <div class="inner-box"> |
263 | <figure class="image-box"><img src="{{ img.image.url }}" alt=""></figure> |
264 | <div class="content-box"> |
265 | <div class="view-btn"><a href="{{ img.image.url }}" class="lightbox-image" data-fancybox="gallery"><i class="fal fa-plus"></i></a></div> |
266 | <h3><a href="/">{{ img.description }}</a></h3> |
267 | </div> |
268 | </div> |
269 | </div> |
270 | {% endfor %} |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 89, in _execute
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
# params default might be backend specific.
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def _executemany(self, sql, param_list, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
return self.cursor.executemany(sql, param_list)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <DatabaseWrapper vendor='sqlite' alias='default'>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10>}) |
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/sqlite3/base.py
, line 328, in execute
def execute(self, query, params=None):
if params is None:
return super().execute(query)
# Extract names if params is a mapping, i.e. "pyformat" style is used.
param_names = list(params) if isinstance(params, Mapping) else None
query = self.convert_query(query, param_names=param_names)
return super().execute(query, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def executemany(self, query, param_list):
# Extract names if params is a mapping, i.e. "pyformat" style is used.
# Peek carefully as a generator can be passed instead of a list/tuple.
peekable, param_list = tee(iter(param_list))
if (params := next(peekable, None)) and isinstance(params, Mapping):
Variable | Value |
---|---|
__class__ | <class 'django.db.backends.sqlite3.base.SQLiteCursorWrapper'> |
param_names | None |
params | () |
query | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
self | <django.db.backends.sqlite3.base.SQLiteCursorWrapper object at 0x7ed23b3f7890> |
/workspace/.heroku/python/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 | OperationalError('no such table: core_gallery') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7ed23b342490>> |
request | <WSGIRequest: GET '/'> |
/workspace/.heroku/python/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 HomeView at 0x7ed23b38f060> |
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 0x7ed23b342490> |
wrapped_callback | <function HomeView at 0x7ed23b38f060> |
/workspace/core/views.py
, line 22, in HomeView
def HomeView(request):
staff_data = StaffMember.objects.all()
gallery_images = Gallery.objects.all()
context = {
'staff_data': staff_data,
'gallery_images': gallery_images
}
return render(request, 'core/index.html', context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def ContactUsView(request):
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_gallery |
gallery_images | Error in formatting: OperationalError: no such table: core_gallery |
request | <WSGIRequest: GET '/'> |
staff_data | Error in formatting: OperationalError: no such table: core_staffmember |
/workspace/.heroku/python/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 | Error in formatting: OperationalError: no such table: core_gallery |
request | <WSGIRequest: GET '/'> |
status | None |
template_name | 'core/index.html' |
using | None |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/loader.py
, line 62, in render_to_string
template_name may be a string or a list of strings.
"""
if isinstance(template_name, (list, tuple)):
template = select_template(template_name, using=using)
else:
template = get_template(template_name, using=using)
return template.render(context, request) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def _engine_list(using=None):
return engines.all() if using is None else [engines[using]]
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_gallery |
request | <WSGIRequest: GET '/'> |
template | <django.template.backends.django.Template object at 0x7ed23b153ed0> |
template_name | 'core/index.html' |
using | None |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/backends/django.py
, line 61, in render
return self.template.origin
def render(self, context=None, request=None):
context = make_context(
context, request, autoescape=self.backend.engine.autoescape
)
try:
return self.template.render(context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
except TemplateDoesNotExist as exc:
reraise(exc, self.backend)
def copy_exception(exc, backend=None):
"""
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
request | <WSGIRequest: GET '/'> |
self | <django.template.backends.django.Template object at 0x7ed23b153ed0> |
/workspace/.heroku/python/lib/python3.11/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 | Error in formatting: OperationalError: no such table: core_staffmember |
self | <Template template_string="{% extends 'base.ht..."> |
/workspace/.heroku/python/lib/python3.11/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 | Error in formatting: OperationalError: no such table: core_staffmember |
self | <Template template_string="{% extends 'base.ht..."> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | [<TextNode: '\n'>, <ExtendsNode: extends 'base.html'>] |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7ed23bb80df0> |
context | Error in formatting: OperationalError: no such table: core_staffmember |
node | <ExtendsNode: extends 'base.html'> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context) ^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | <ExtendsNode: extends 'base.html'> |
/workspace/.heroku/python/lib/python3.11/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'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]>], 'script': [<Block Node: script. Contents: []>]})> |
blocks | {'content': <Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]>, 'script': <Block Node: script. Contents: []>} |
compiled_parent | <Template template_string="{% load static %}<!..."> |
context | Error in formatting: OperationalError: no such table: core_staffmember |
node | <django.template.defaulttags.LoadNode object at 0x7ed23b238ed0> |
self | <ExtendsNode: extends 'base.html'> |
/workspace/.heroku/python/lib/python3.11/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 | Error in formatting: OperationalError: no such table: core_staffmember |
self | <Template template_string="{% load static %}<!..."> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | [<django.template.defaulttags.LoadNode object at 0x7ed23b238ed0>, <TextNode: '\n<!DOCTYPE html>\n<html la'>, StaticNode(varname=None, path=<FilterExpression "'css/font-awesome-all.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/flaticon.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/owl.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/bootstrap.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/jquery.fancybox.min.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/animate.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/nice-select.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/color.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/style.css'">), <TextNode: '" rel="stylesheet">\n<link'>, StaticNode(varname=None, path=<FilterExpression "'css/responsive.css'">), <TextNode: '" rel="stylesheet">\n\n<lin'>, StaticNode(varname=None, path=<FilterExpression "'images/favicon/apple-touch-icon.png'">), <TextNode: '">\n<link rel="icon" type='>, StaticNode(varname=None, path=<FilterExpression "'images/favicon/favicon-32x32.png'">), <TextNode: '">\n<link rel="icon" type='>, StaticNode(varname=None, path=<FilterExpression "'images/favicon/favicon-16x16.png'">), <TextNode: '">\n<link rel="manifest" h'>, StaticNode(varname=None, path=<FilterExpression "'site.webmanifest'">), <TextNode: '">\n<link rel="mask-icon" '>, StaticNode(varname=None, path=<FilterExpression "'images/favicon/safari-pinned-tab.svg'">), <TextNode: '" color="#5bbad5">\n<meta '>, StaticNode(varname=None, path=<FilterExpression "'images/vip_logo.png'">), <TextNode: '" alt="Logo"></a></figure'>, StaticNode(varname=None, path=<FilterExpression "'images/vip_logo.png'">), <TextNode: '" alt="Logo"></a></figure'>, StaticNode(varname=None, path=<FilterExpression "'images/vip_logo.png'">), <TextNode: '" alt="" title=""></a></d'>, <Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]>, <TextNode: '\n \n <!-- ma'>, StaticNode(varname=None, path=<FilterExpression "'images/vip_logo.png'">), <TextNode: '" alt="">\n '>, StaticNode(varname=None, path=<FilterExpression "'js/jquery.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/popper.min.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/bootstrap.min.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/owl.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/wow.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/validation.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/jquery.fancybox.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/appear.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/scrollbar.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/jquery.nice-select.min.js'">), <TextNode: '"></script>\n\n <!-- map'>, StaticNode(varname=None, path=<FilterExpression "'js/gmaps.js'">), <TextNode: '"></script>\n <script s'>, StaticNode(varname=None, path=<FilterExpression "'js/map-helper.js'">), <TextNode: '"></script>\n\n <!-- mai'>, StaticNode(varname=None, path=<FilterExpression "'js/script.js'">), <TextNode: '"></script>\n <script s'>, <Block Node: script. Contents: []>, <TextNode: '\n\n</body>\n\n</h… <trimmed 4105 bytes string> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7ed23bb82d10> |
context | Error in formatting: OperationalError: no such table: core_staffmember |
node | <Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context) ^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | <Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/loader_tags.py
, line 63, in render
push = block = block_context.pop(self.name)
if block is None:
block = self
# Create new block so we can store context without thread-safety issues.
block = type(self)(block.name, block.nodelist)
block.context = context
context["block"] = block
result = block.nodelist.render(context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
if push is not None:
block_context.push(self.name, push)
return result
def super(self):
if not hasattr(self, "context"):
Variable | Value |
---|---|
block | <Block Node: content. Contents: [<TextNode: '\n <!-- banner-section '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-04.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-02.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-03.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/banner-img-1.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/about-3.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/rockchip.png'">), <TextNode: '" alt=""></div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/tinting.png'">), <TextNode: '" alt=""></div>\n '>, <ForNode: for img in gallery_images, tail_len: 7>, <TextNode: '\n </div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-1.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-2.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-3.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/reviews.png'">), <TextNode: '" alt=""></figure>\n '>, <ForNode: for staff_member in staff_data, tail_len: 9>, <TextNode: '\n\n </div>\n '>]> |
block_context | <BlockContext: blocks=defaultdict(<class 'list'>, {'content': [<Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]>], 'script': [<Block Node: script. Contents: []>]})> |
context | Error in formatting: OperationalError: no such table: core_staffmember |
push | <Block Node: content. Contents: [<TextNode: '\n <!-- banner-section '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-04.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-02.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-03.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/banner-img-1.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/about-3.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/rockchip.png'">), <TextNode: '" alt=""></div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/tinting.png'">), <TextNode: '" alt=""></div>\n '>, <ForNode: for img in gallery_images, tail_len: 7>, <TextNode: '\n </div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-1.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-2.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-3.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/reviews.png'">), <TextNode: '" alt=""></figure>\n '>, <ForNode: for staff_member in staff_data, tail_len: 9>, <TextNode: '\n\n </div>\n '>]> |
self | <Block Node: content. Contents: [<TextNode: '\n <!-- Page Co'>]> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in render
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | [<TextNode: '\n <!-- banner-section '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-04.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-02.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/img-03.jpeg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/banner/banner-img-1.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/about-3.jpg'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/rockchip.png'">), <TextNode: '" alt=""></div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/tinting.png'">), <TextNode: '" alt=""></div>\n '>, <ForNode: for img in gallery_images, tail_len: 7>, <TextNode: '\n </div>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-1.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-2.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/resource/customer-3.png'">), <TextNode: '" alt=""></figure>\n '>, StaticNode(varname=None, path=<FilterExpression "'images/service/reviews.png'">), <TextNode: '" alt=""></figure>\n '>, <ForNode: for staff_member in staff_data, tail_len: 9>, <TextNode: '\n\n </div>\n '>] |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 1005, in <listcomp>
class NodeList(list):
# Set to True the first time a non-TextNode is inserted by
# extend_nodelist().
contains_nontext = False
def render(self, context):
return SafeString("".join([node.render_annotated(context) for node in self])) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def get_nodes_by_type(self, nodetype):
"Return a list of all nodes of the given type"
nodes = []
for node in self:
nodes.extend(node.get_nodes_by_type(nodetype))
Variable | Value |
---|---|
.0 | <list_iterator object at 0x7ed23bb828c0> |
context | Error in formatting: OperationalError: no such table: core_staffmember |
node | <ForNode: for img in gallery_images, tail_len: 7> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/template/base.py
, line 966, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context) ^^^^^^^^^^^^^^^^^^^^…
except Exception as e:
if context.template.engine.debug:
# Store the actual node that caused the exception.
if not hasattr(e, "_culprit_node"):
e._culprit_node = self
if (
Variable | Value |
---|---|
context | Error in formatting: OperationalError: no such table: core_staffmember |
self | <ForNode: for img in gallery_images, tail_len: 7> |
/workspace/.heroku/python/lib/python3.11/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 | Error in formatting: OperationalError: no such table: core_staffmember |
parentloop | {} |
self | <ForNode: for img in gallery_images, tail_len: 7> |
values | Error in formatting: OperationalError: no such table: core_gallery |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 380, 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: no such table: core_gallery |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 1881, 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: no such table: core_gallery |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 91, 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 | <SQLCompiler model=Gallery connection=<DatabaseWrapper vendor='sqlite' alias='default'> using='default'> |
db | 'default' |
queryset | Error in formatting: OperationalError: no such table: core_gallery |
self | <django.db.models.query.ModelIterable object at 0x7ed23b1520d0> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/compiler.py
, line 1562, in execute_sql
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
if result_type == CURSOR:
Variable | Value |
---|---|
chunk_size | 100 |
chunked_fetch | False |
cursor | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
params | () |
result_type | 'multi' |
self | <SQLCompiler model=Gallery connection=<DatabaseWrapper vendor='sqlite' alias='default'> using='default'> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 102, in execute
class CursorDebugWrapper(CursorWrapper):
# XXX callproc isn't instrumented at this time.
def execute(self, sql, params=None):
with self.debug_sql(sql, params, use_last_executed_query=True):
return super().execute(sql, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def executemany(self, sql, param_list):
with self.debug_sql(sql, param_list, many=True):
return super().executemany(sql, param_list)
@contextmanager
Variable | Value |
---|---|
__class__ | <class 'django.db.backends.utils.CursorDebugWrapper'> |
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 67, in execute
elif kparams is None:
return self.cursor.callproc(procname, params)
else:
params = params or ()
return self.cursor.callproc(procname, params, kparams)
def execute(self, sql, params=None):
return self._execute_with_wrappers(…
sql, params, many=False, executor=self._execute
)
def executemany(self, sql, param_list):
return self._execute_with_wrappers(
sql, param_list, many=True, executor=self._executemany
Variable | Value |
---|---|
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 80, in _execute_with_wrappers
sql, param_list, many=True, executor=self._executemany
)
def _execute_with_wrappers(self, sql, params, many, executor):
context = {"connection": self.db, "cursor": self}
for wrapper in reversed(self.db.execute_wrappers):
executor = functools.partial(wrapper, executor)
return executor(sql, params, many, context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
# params default might be backend specific.
Variable | Value |
---|---|
context | {'connection': <DatabaseWrapper vendor='sqlite' alias='default'>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10>} |
executor | <bound method CursorWrapper._execute of <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10>> |
many | False |
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 84, in _execute
context = {"connection": self.db, "cursor": self}
for wrapper in reversed(self.db.execute_wrappers):
executor = functools.partial(wrapper, executor)
return executor(sql, params, many, context)
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
if params is None:
# params default might be backend specific.
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <DatabaseWrapper vendor='sqlite' alias='default'>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10>}) |
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/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 'sqlite3.OperationalError'> |
dj_exc_type | <class 'django.db.utils.OperationalError'> |
dj_exc_value | OperationalError('no such table: core_gallery') |
exc_type | <class 'sqlite3.OperationalError'> |
exc_value | OperationalError('no such table: core_gallery') |
self | <django.db.utils.DatabaseErrorWrapper object at 0x7ed23b2ad0d0> |
traceback | <traceback object at 0x7ed23b2aedc0> |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/utils.py
, line 89, in _execute
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
# params default might be backend specific.
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def _executemany(self, sql, param_list, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
return self.cursor.executemany(sql, param_list)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <DatabaseWrapper vendor='sqlite' alias='default'>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10>}) |
params | () |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7ed23b2edd10> |
sql | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
/workspace/.heroku/python/lib/python3.11/site-packages/django/db/backends/sqlite3/base.py
, line 328, in execute
def execute(self, query, params=None):
if params is None:
return super().execute(query)
# Extract names if params is a mapping, i.e. "pyformat" style is used.
param_names = list(params) if isinstance(params, Mapping) else None
query = self.convert_query(query, param_names=param_names)
return super().execute(query, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def executemany(self, query, param_list):
# Extract names if params is a mapping, i.e. "pyformat" style is used.
# Peek carefully as a generator can be passed instead of a list/tuple.
peekable, param_list = tee(iter(param_list))
if (params := next(peekable, None)) and isinstance(params, Mapping):
Variable | Value |
---|---|
__class__ | <class 'django.db.backends.sqlite3.base.SQLiteCursorWrapper'> |
param_names | None |
params | () |
query | ('SELECT "core_gallery"."id", "core_gallery"."image", ' '"core_gallery"."description" FROM "core_gallery"') |
self | <django.db.backends.sqlite3.base.SQLiteCursorWrapper object at 0x7ed23b3f7890> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_ACCEPT_ENCODING | 'gzip, br' |
HTTP_CDN_LOOP | 'cloudflare' |
HTTP_DO_CONNECTING_IP | '3.239.208.72' |
HTTP_HOST | 'vipglass.ca' |
HTTP_REFERER | 'http://vipglass.ca/' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '3.239.208.72,172.70.42.90' |
HTTP_X_FORWARDED_PROTO | 'https' |
PATH_INFO | '/' |
QUERY_STRING | '' |
RAW_URI | '/' |
REMOTE_ADDR | '10.244.0.119' |
REMOTE_PORT | '40462' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '8080' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/21.2.0' |
gunicorn.socket | <socket.socket fd=9, family=2, type=1, proto=0, laddr=('10.244.45.103', 8080), raddr=('10.244.0.119', 40462)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7ed23bb81ea0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7ed23b40ea50> |
wsgi.input_terminated | True |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
VipGlass.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['*'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | PosixPath('/workspace') |
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_MASKED | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_HEALTH_CHECKS': False, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.sqlite3', 'HOST': '', 'NAME': PosixPath('/workspace/db.sqlite3'), 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': ''}} |
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 | '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 | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'noreply<[email protected]>' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.gmail.com' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '[email protected]' |
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' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'core'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ar-dz', 'Algerian Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('ckb', 'Central Kurdish (Sorani)'), ('cs', 'Czech'), ('cy', 'Welsh'), ('da', 'Danish'), ('de', 'German'), ('dsb', 'Lower Sorbian'), ('el', 'Greek'), ('en', 'English'), ('en-au', 'Australian English'), ('en-gb', 'British English'), ('eo', 'Esperanto'), ('es', 'Spanish'), ('es-ar', 'Argentinian Spanish'), ('es-co', 'Colombian Spanish'), ('es-mx', 'Mexican Spanish'), ('es-ni', 'Nicaraguan Spanish'), ('es-ve', 'Venezuelan Spanish'), ('et', 'Estonian'), ('eu', 'Basque'), ('fa', 'Persian'), ('fi', 'Finnish'), ('fr', 'French'), ('fy', 'Frisian'), ('ga', 'Irish'), ('gd', 'Scottish Gaelic'), ('gl', 'Galician'), ('he', 'Hebrew'), ('hi', 'Hindi'), ('hr', 'Croatian'), ('hsb', 'Upper Sorbian'), ('hu', 'Hungarian'), ('hy', 'Armenian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('ig', 'Igbo'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('ky', 'Kyrgyz'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('ms', 'Malay'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'ckb', 'fa', 'ur'] |
LANGUAGE_CODE | 'en-us' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/workspace/mediafiles/' |
MEDIA_URL | '/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'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'VipGlass.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 | 'VipGlass.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 | ['/workspace/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/workspace/staticfiles' |
STATIC_URL | '/static/' |
STORAGES | {'default': {'BACKEND': 'django.core.files.storage.FileSystemStorage'}, 'staticfiles': {'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage'}} |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [PosixPath('/workspace/templates')], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | '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 | 'VipGlass.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.