Unsupported lookup 'slug' for ClusterTaggableManager or join on the field not permitted.
Request Method: | GET |
---|---|
Request URL: | http://www.cancercare.bg/blog/tag/skrining/?page=2 |
Django Version: | 4.2.1 |
Exception Type: | FieldError |
Exception Value: | Unsupported lookup 'slug' for ClusterTaggableManager or join on the field not permitted. |
Exception Location: | /app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py, line 1313, in try_transform |
Raised during: | wagtail.views.serve |
Python Executable: | /app/.heroku/python/bin/python |
Python Version: | 3.11.4 |
Python Path: | ['/app/.heroku/python/bin', '/app', '/app/.heroku/python/lib/python311.zip', '/app/.heroku/python/lib/python3.11', '/app/.heroku/python/lib/python3.11/lib-dynload', '/app/.heroku/python/lib/python3.11/site-packages'] |
Server time: | Fri, 29 Mar 2024 13:29:02 +0000 |
/app/.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 | FieldError("Unsupported lookup 'slug' for ClusterTaggableManager or join on the field not permitted.") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f52490a8990>> |
request | <WSGIRequest: GET '/blog/tag/skrining/?page=2'> |
/app/.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 serve at 0x7f52488f1080> |
callback_args | ('blog/tag/skrining/',) |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/blog/tag/skrining/?page=2'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f52490a8990> |
wrapped_callback | <function serve at 0x7f52488f1080> |
/app/.heroku/python/lib/python3.11/site-packages/wagtail/views.py
, line 28, in serve
)
for fn in hooks.get_hooks("before_serve_page"):
result = fn(page, request, args, kwargs)
if isinstance(result, HttpResponse):
return result
return page.serve(request, *args, **kwargs) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def authenticate_with_password(request, page_view_restriction_id, page_id):
"""
Handle a submission of PasswordViewRestrictionForm to grant view access over a
subtree that is protected by a PageViewRestriction
Variable | Value |
---|---|
args | (<bound method BlogRoutes.entries_by_tag of <BlogPage: Блог>>, (), {'tag': 'skrining'}) |
fn | <function check_view_restrictions at 0x7f5248be14e0> |
kwargs | {} |
page | <BlogPage: Блог> |
path | 'blog/tag/skrining/' |
path_components | ['blog', 'tag', 'skrining'] |
request | <WSGIRequest: GET '/blog/tag/skrining/?page=2'> |
result | None |
site | <Site: www.cancercare.bg [default]> |
/app/.heroku/python/lib/python3.11/site-packages/wagtail/contrib/routable_page/models.py
, line 171, in serve
def serve(self, request, view=None, args=None, kwargs=None):
if args is None:
args = []
if kwargs is None:
kwargs = {}
if view is None:
return super().serve(request, *args, **kwargs)
return view(request, *args, **kwargs) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def render(self, request, *args, template=None, context_overrides=None, **kwargs):
"""
This method replicates what ``Page.serve()`` usually does when ``RoutablePageMixin``
is not used. By default, ``Page.get_template()`` is called to derive the template
to use for rendering, and ``Page.get_context()`` is always called to gather the
Variable | Value |
---|---|
__class__ | <class 'wagtail.contrib.routable_page.models.RoutablePageMixin'> |
args | () |
kwargs | {'tag': 'skrining'} |
request | <WSGIRequest: GET '/blog/tag/skrining/?page=2'> |
self | <BlogPage: Блог> |
view | <bound method BlogRoutes.entries_by_tag of <BlogPage: Блог>> |
/app/puput/routes.py
, line 37, in entries_by_tag
self.search_term = date_format(date(int(year), int(month), int(day)))
return Page.serve(self, request, *args, **kwargs)
@route(r'^tag/(?P<tag>[-\w]+)/$')
def entries_by_tag(self, request, tag, *args, **kwargs):
self.search_type = _('tag')
self.search_term = tag
self.entries = self.get_entries().filter(tags__slug=tag) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
return Page.serve(self, request, *args, **kwargs)
@route(r'^category/(?P<category>[-\w]+)/$')
def entries_by_category(self, request, category, *args, **kwargs):
self.search_type = _('category')
self.search_term = category
Variable | Value |
---|---|
args | () |
kwargs | {} |
request | <WSGIRequest: GET '/blog/tag/skrining/?page=2'> |
self | <BlogPage: Блог> |
tag | 'skrining' |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 1436, in filter
def filter(self, *args, **kwargs):
"""
Return a new QuerySet instance with the args ANDed to the existing
set.
"""
self._not_support_combined_queries("filter")
return self._filter_or_exclude(False, args, kwargs) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def exclude(self, *args, **kwargs):
"""
Return a new QuerySet instance with NOT (args) ANDed to the existing
set.
"""
Variable | Value |
---|---|
args | () |
kwargs | {'tags__slug': 'skrining'} |
self | <PageQuerySet [<EntryPage: CancerCare.bg Media: Какво да очаквате?>, <EntryPage: НМ Дженомикс и новите им партньорства - тестове за наследствена обремененост>, <EntryPage: 🌟 Безплатни профилактични прегледи при уролог в Аджибадем Сити Клиник УМБАЛ Токуда! 🌟>, <EntryPage: Бионтех: Ваксината ни срещу рак успя да спре растежа на тумора>, <EntryPage: "АУБ Хелоуин Парти 2023: Изпити или чудовища в Борбата с рака на гърдата">, <EntryPage: Ново неоадювантно изпитване (MINT) потвърждава предсказуемата полезност на MammaPrint + BluePrint>, <EntryPage: Race for the Cure: Rock събира рок музиканти в подкрепа на женското здраве>, <EntryPage: Научен материал: Рискове от рак свързани с патогенни варианти на BRCA1 и BRCA2>, <EntryPage: Безплатна хормонална терапия и за мъже с карцином на гърда>, <EntryPage: OncoDEEP в помощ за определяне най-добрата възможност за лечение при рак на яйчниците.>, <EntryPage: Race for the Cure в България става на 5 години. Всички сте поканени.>, <EntryPage: Информация, подкрепа и иновации: CancerCare.bg и PrOPA by Shemha Health>, <EntryPage: 3400 жени получиха безплатни профилактични прегледи по програмата “За теб близо до теб” на CancerCare.bg>, <EntryPage: МammaPrint може да промени обичайната клинична практика>, <EntryPage: Уебинар: Общопрактикуващият лекар в опортюнистичния онкологичен скрининг>, <EntryPage: CancerCare.bg и NMGenomix с партньорство “В подкрепа на онкоболните”>, <EntryPage: Безплатни профилактични прегледи за рак на гърда от CancerCare.bg>, <EntryPage: Възможно ли е маникюрът да бъде опасен?>, <EntryPage: 8 топ отговора на въпроси за храненето от Кристина Вавура - клиничен диетолог>, <EntryPage: CancerCare.bg с нов CEO: Ивко Беновски поема поста Главен изпълнителен директор в CancerCare.bg>, '...(remaining elements truncated)...']> |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 1454, in _filter_or_exclude
if (args or kwargs) and self.query.is_sliced:
raise TypeError("Cannot filter a query once a slice has been taken.")
clone = self._chain()
if self._defer_next_filter:
self._defer_next_filter = False
clone._deferred_filter = negate, args, kwargs
else:
clone._filter_or_exclude_inplace(negate, args, kwargs) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
return clone
def _filter_or_exclude_inplace(self, negate, args, kwargs):
if negate:
self._query.add_q(~Q(*args, **kwargs))
else:
Variable | Value |
---|---|
args | () |
clone | <PageQuerySet [<EntryPage: CancerCare.bg Media: Какво да очаквате?>, <EntryPage: НМ Дженомикс и новите им партньорства - тестове за наследствена обремененост>, <EntryPage: 🌟 Безплатни профилактични прегледи при уролог в Аджибадем Сити Клиник УМБАЛ Токуда! 🌟>, <EntryPage: Бионтех: Ваксината ни срещу рак успя да спре растежа на тумора>, <EntryPage: "АУБ Хелоуин Парти 2023: Изпити или чудовища в Борбата с рака на гърдата">, <EntryPage: Ново неоадювантно изпитване (MINT) потвърждава предсказуемата полезност на MammaPrint + BluePrint>, <EntryPage: Race for the Cure: Rock събира рок музиканти в подкрепа на женското здраве>, <EntryPage: Научен материал: Рискове от рак свързани с патогенни варианти на BRCA1 и BRCA2>, <EntryPage: Безплатна хормонална терапия и за мъже с карцином на гърда>, <EntryPage: OncoDEEP в помощ за определяне най-добрата възможност за лечение при рак на яйчниците.>, <EntryPage: Race for the Cure в България става на 5 години. Всички сте поканени.>, <EntryPage: Информация, подкрепа и иновации: CancerCare.bg и PrOPA by Shemha Health>, <EntryPage: 3400 жени получиха безплатни профилактични прегледи по програмата “За теб близо до теб” на CancerCare.bg>, <EntryPage: МammaPrint може да промени обичайната клинична практика>, <EntryPage: Уебинар: Общопрактикуващият лекар в опортюнистичния онкологичен скрининг>, <EntryPage: CancerCare.bg и NMGenomix с партньорство “В подкрепа на онкоболните”>, <EntryPage: Безплатни профилактични прегледи за рак на гърда от CancerCare.bg>, <EntryPage: Възможно ли е маникюрът да бъде опасен?>, <EntryPage: 8 топ отговора на въпроси за храненето от Кристина Вавура - клиничен диетолог>, <EntryPage: CancerCare.bg с нов CEO: Ивко Беновски поема поста Главен изпълнителен директор в CancerCare.bg>, '...(remaining elements truncated)...']> |
kwargs | {'tags__slug': 'skrining'} |
negate | False |
self | <PageQuerySet [<EntryPage: CancerCare.bg Media: Какво да очаквате?>, <EntryPage: НМ Дженомикс и новите им партньорства - тестове за наследствена обремененост>, <EntryPage: 🌟 Безплатни профилактични прегледи при уролог в Аджибадем Сити Клиник УМБАЛ Токуда! 🌟>, <EntryPage: Бионтех: Ваксината ни срещу рак успя да спре растежа на тумора>, <EntryPage: "АУБ Хелоуин Парти 2023: Изпити или чудовища в Борбата с рака на гърдата">, <EntryPage: Ново неоадювантно изпитване (MINT) потвърждава предсказуемата полезност на MammaPrint + BluePrint>, <EntryPage: Race for the Cure: Rock събира рок музиканти в подкрепа на женското здраве>, <EntryPage: Научен материал: Рискове от рак свързани с патогенни варианти на BRCA1 и BRCA2>, <EntryPage: Безплатна хормонална терапия и за мъже с карцином на гърда>, <EntryPage: OncoDEEP в помощ за определяне най-добрата възможност за лечение при рак на яйчниците.>, <EntryPage: Race for the Cure в България става на 5 години. Всички сте поканени.>, <EntryPage: Информация, подкрепа и иновации: CancerCare.bg и PrOPA by Shemha Health>, <EntryPage: 3400 жени получиха безплатни профилактични прегледи по програмата “За теб близо до теб” на CancerCare.bg>, <EntryPage: МammaPrint може да промени обичайната клинична практика>, <EntryPage: Уебинар: Общопрактикуващият лекар в опортюнистичния онкологичен скрининг>, <EntryPage: CancerCare.bg и NMGenomix с партньорство “В подкрепа на онкоболните”>, <EntryPage: Безплатни профилактични прегледи за рак на гърда от CancerCare.bg>, <EntryPage: Възможно ли е маникюрът да бъде опасен?>, <EntryPage: 8 топ отговора на въпроси за храненето от Кристина Вавура - клиничен диетолог>, <EntryPage: CancerCare.bg с нов CEO: Ивко Беновски поема поста Главен изпълнителен директор в CancerCare.bg>, '...(remaining elements truncated)...']> |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/query.py
, line 1461, in _filter_or_exclude_inplace
clone._filter_or_exclude_inplace(negate, args, kwargs)
return clone
def _filter_or_exclude_inplace(self, negate, args, kwargs):
if negate:
self._query.add_q(~Q(*args, **kwargs))
else:
self._query.add_q(Q(*args, **kwargs)) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
def complex_filter(self, filter_obj):
"""
Return a new QuerySet instance with filter_obj added to the filters.
filter_obj can be a Q object or a dictionary of keyword lookup
Variable | Value |
---|---|
args | () |
kwargs | {'tags__slug': 'skrining'} |
negate | False |
self | <PageQuerySet [<EntryPage: CancerCare.bg Media: Какво да очаквате?>, <EntryPage: НМ Дженомикс и новите им партньорства - тестове за наследствена обремененост>, <EntryPage: 🌟 Безплатни профилактични прегледи при уролог в Аджибадем Сити Клиник УМБАЛ Токуда! 🌟>, <EntryPage: Бионтех: Ваксината ни срещу рак успя да спре растежа на тумора>, <EntryPage: "АУБ Хелоуин Парти 2023: Изпити или чудовища в Борбата с рака на гърдата">, <EntryPage: Ново неоадювантно изпитване (MINT) потвърждава предсказуемата полезност на MammaPrint + BluePrint>, <EntryPage: Race for the Cure: Rock събира рок музиканти в подкрепа на женското здраве>, <EntryPage: Научен материал: Рискове от рак свързани с патогенни варианти на BRCA1 и BRCA2>, <EntryPage: Безплатна хормонална терапия и за мъже с карцином на гърда>, <EntryPage: OncoDEEP в помощ за определяне най-добрата възможност за лечение при рак на яйчниците.>, <EntryPage: Race for the Cure в България става на 5 години. Всички сте поканени.>, <EntryPage: Информация, подкрепа и иновации: CancerCare.bg и PrOPA by Shemha Health>, <EntryPage: 3400 жени получиха безплатни профилактични прегледи по програмата “За теб близо до теб” на CancerCare.bg>, <EntryPage: МammaPrint може да промени обичайната клинична практика>, <EntryPage: Уебинар: Общопрактикуващият лекар в опортюнистичния онкологичен скрининг>, <EntryPage: CancerCare.bg и NMGenomix с партньорство “В подкрепа на онкоболните”>, <EntryPage: Безплатни профилактични прегледи за рак на гърда от CancerCare.bg>, <EntryPage: Възможно ли е маникюрът да бъде опасен?>, <EntryPage: 8 топ отговора на въпроси за храненето от Кристина Вавура - клиничен диетолог>, <EntryPage: CancerCare.bg с нов CEO: Ивко Беновски поема поста Главен изпълнителен директор в CancerCare.bg>, '...(remaining elements truncated)...']> |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py
, line 1502, in add_q
# type to remain inner. Existing outer joins can however be demoted.
# (Consider case where rel_a is LOUTER and rel_a__col=1 is added - if
# rel_a doesn't produce any rows, then the whole condition must fail.
# So, demotion is OK.
existing_inner = {
a for a in self.alias_map if self.alias_map[a].join_type == INNER
}
clause, _ = self._add_q(q_object, self.used_aliases) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
if clause:
self.where.add(clause, AND)
self.demote_joins(existing_inner)
def build_where(self, filter_expr):
return self.build_filter(filter_expr, allow_joins=False)[0]
Variable | Value |
---|---|
existing_inner | {'wagtailcore_page'} |
q_object | <Q: (AND: ('tags__slug', 'skrining'))> |
self | <django.db.models.sql.query.Query object at 0x7f52477fbb50> |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py
, line 1533, in _add_q
current_negated ^= q_object.negated
branch_negated = branch_negated or q_object.negated
target_clause = WhereNode(connector=connector, negated=q_object.negated)
joinpromoter = JoinPromoter(
q_object.connector, len(q_object.children), current_negated
)
for child in q_object.children:
child_clause, needed_inner = self.build_filter(…
child,
can_reuse=used_aliases,
branch_negated=branch_negated,
current_negated=current_negated,
allow_joins=allow_joins,
split_subq=split_subq,
Variable | Value |
---|---|
allow_joins | True |
branch_negated | False |
check_filterable | True |
child | ('tags__slug', 'skrining') |
connector | 'AND' |
current_negated | False |
joinpromoter | JoinPromoter(connector='AND', num_children=1, negated=False) |
q_object | <Q: (AND: ('tags__slug', 'skrining'))> |
self | <django.db.models.sql.query.Query object at 0x7f52477fbb50> |
split_subq | True |
summarize | False |
target_clause | <WhereNode: (AND: )> |
used_aliases | {'puput_entrypage'} |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py
, line 1448, in build_filter
else:
col = MultiColSource(
alias, targets, join_info.targets, join_info.final_field
)
else:
col = self._get_col(targets[0], join_info.final_field, alias)
condition = self.build_lookup(lookups, col, value) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
lookup_type = condition.lookup_name
clause = WhereNode([condition], connector=AND)
require_outer = (
lookup_type == "isnull" and condition.rhs is True and not current_negated
)
Variable | Value |
---|---|
alias | 'puput_entrypage' |
allow_joins | True |
allow_many | True |
arg | 'tags__slug' |
branch_negated | False |
can_reuse | {'puput_entrypage'} |
check_filterable | True |
col | Col(puput_entrypage, puput.EntryPage.tags) |
current_negated | False |
filter_expr | ('tags__slug', 'skrining') |
join_info | JoinInfo(final_field=<modelcluster.contrib.taggit.ClusterTaggableManager: tags>, targets=(<modelcluster.contrib.taggit.ClusterTaggableManager: tags>,), opts=<Options for EntryPage>, joins=['puput_entrypage'], path=[], transform_function=<function Query.setup_joins.<locals>.final_transformer at 0x7f5247858400>) |
join_list | ['puput_entrypage'] |
lookups | ['slug'] |
opts | <Options for EntryPage> |
parts | ['tags'] |
pre_joins | {'puput_entrypage': 4, 'wagtailcore_page': 3} |
reffed_expression | False |
reuse_with_filtered_relation | False |
self | <django.db.models.sql.query.Query object at 0x7f52477fbb50> |
split_subq | True |
summarize | False |
targets | (<modelcluster.contrib.taggit.ClusterTaggableManager: tags>,) |
used_joins | {'puput_entrypage'} |
value | 'skrining' |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py
, line 1269, in build_lookup
lhs = self.try_transform(lhs, name)
# First try get_lookup() so that the lookup takes precedence if the lhs
# supports both transform and lookup for the name.
lookup_class = lhs.get_lookup(lookup_name)
if not lookup_class:
# A lookup wasn't found. Try to interpret the name as a transform
# and do an Exact lookup against it.
lhs = self.try_transform(lhs, lookup_name) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^…
lookup_name = "exact"
lookup_class = lhs.get_lookup(lookup_name)
if not lookup_class:
return
lookup = lookup_class(lhs, rhs)
Variable | Value |
---|---|
lhs | Col(puput_entrypage, puput.EntryPage.tags) |
lookup_class | None |
lookup_name | 'slug' |
lookups | ['slug'] |
rhs | 'skrining' |
self | <django.db.models.sql.query.Query object at 0x7f52477fbb50> |
transforms | [] |
/app/.heroku/python/lib/python3.11/site-packages/django/db/models/sql/query.py
, line 1313, in try_transform
suggested_lookups = difflib.get_close_matches(
name, lhs.output_field.get_lookups()
)
if suggested_lookups:
suggestion = ", perhaps you meant %s?" % " or ".join(suggested_lookups)
else:
suggestion = "."
raise FieldError( ^…
"Unsupported lookup '%s' for %s or join on the field not "
"permitted%s" % (name, output_field.__name__, suggestion)
)
def build_filter(
self,
Variable | Value |
---|---|
lhs | Col(puput_entrypage, puput.EntryPage.tags) |
name | 'slug' |
output_field | <class 'modelcluster.contrib.taggit.ClusterTaggableManager'> |
self | <django.db.models.sql.query.Query object at 0x7f52477fbb50> |
suggested_lookups | [] |
suggestion | '.' |
transform_class | None |
AnonymousUser
Variable | Value |
---|---|
page | '2' |
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_ACCEPT_ENCODING | 'gzip, br' |
HTTP_CDN_LOOP | 'cloudflare' |
HTTP_CF_CONNECTING_IP | '54.204.117.206' |
HTTP_CF_IPCOUNTRY | 'US' |
HTTP_CF_RAY | '86c034e01d382034-IAD' |
HTTP_CF_VISITOR | '{"scheme":"https"}' |
HTTP_CONNECTION | 'close' |
HTTP_CONNECT_TIME | '0' |
HTTP_HOST | 'www.cancercare.bg' |
HTTP_TOTAL_ROUTE_TIME | '0' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_VIA | '1.1 vegur' |
HTTP_X_FORWARDED_FOR | '54.204.117.206, 172.71.222.193' |
HTTP_X_FORWARDED_PORT | '80' |
HTTP_X_FORWARDED_PROTO | 'http' |
HTTP_X_REQUEST_ID | '15a77839-0bee-4ed2-8eab-f6885a4305cf' |
HTTP_X_REQUEST_START | '1711718942753' |
PATH_INFO | '/blog/tag/skrining/' |
QUERY_STRING | 'page=2' |
RAW_URI | '/blog/tag/skrining/?page=2' |
REMOTE_ADDR | '10.1.24.187' |
REMOTE_PORT | '27387' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '56749' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/20.1.0' |
gunicorn.socket | <socket.socket fd=10, family=2, type=1, proto=0, laddr=('172.18.240.214', 56749), raddr=('10.1.24.187', 27387)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f524793cdc0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f5247c03ed0> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
Core.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | <generator object <genexpr> at 0x7f524e6dc200> |
ALLOWED_HOSTS | ['*'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AWS_ACCESS_KEY_ID | '********************' |
AWS_CALLING_FORMAT | 2 |
AWS_HEADERS | {'Cache-Control': 'max-age=94608000', 'Expires': 'Thu, 31 Dec 2099 20:00:00 GMT'} |
AWS_PRELOAD_METADATA | True |
AWS_QUERYSTRING_AUTH | False |
AWS_S3_REGION_NAME | 'eu-central-1' |
AWS_S3_SIGNATURE_VERSION | '********************' |
AWS_SECRET_ACCESS_KEY | '********************' |
AWS_STORAGE_BUCKET_NAME | 'cancercare-eu' |
AWS_STORAGE_URL | 'https://cancercare-eu.s3.eu-central-1.amazonaws.com/' |
BASE_DIR | '/app' |
BASE_HOST_URL | 'https://cancer-care.herokuapp.com' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CANCER_CARE_PRIMARY_CONTACTS | ['[email protected]'] |
COMPRESSORS | {'css': 'compressor.css.CssCompressor', 'js': 'compressor.js.JsCompressor'} |
COMPRESS_CACHEABLE_PRECOMPILERS | () |
COMPRESS_CACHE_BACKEND | 'default' |
COMPRESS_CACHE_KEY_FUNCTION | '********************' |
COMPRESS_CLEAN_CSS_ARGUMENTS | '' |
COMPRESS_CLEAN_CSS_BINARY | 'cleancss' |
COMPRESS_CLOSURE_COMPILER_ARGUMENTS | '' |
COMPRESS_CLOSURE_COMPILER_BINARY | 'java -jar compiler.jar' |
COMPRESS_CSS_HASHING_METHOD | 'mtime' |
COMPRESS_DATA_URI_MAX_SIZE | 1024 |
COMPRESS_DEBUG_TOGGLE | None |
COMPRESS_ENABLED | False |
COMPRESS_FILTERS | {'css': ['compressor.filters.css_default.CssAbsoluteFilter', 'compressor.filters.cssmin.rCSSMinFilter'], 'js': ['compressor.filters.jsmin.rJSMinFilter']} |
COMPRESS_JINJA2_GET_ENVIRONMENT | <function CompressorConf.JINJA2_GET_ENVIRONMENT at 0x7f5249867e20> |
COMPRESS_MINT_DELAY | 30 |
COMPRESS_MTIME_DELAY | 10 |
COMPRESS_OFFLINE | False |
COMPRESS_OFFLINE_CONTEXT | {'STATIC_URL': '/static/'} |
COMPRESS_OFFLINE_MANIFEST | 'manifest.json' |
COMPRESS_OFFLINE_MANIFEST_STORAGE | 'compressor.storage.OfflineManifestFileStorage' |
COMPRESS_OFFLINE_TIMEOUT | 31536000 |
COMPRESS_OUTPUT_DIR | 'CACHE' |
COMPRESS_PARSER | 'compressor.parser.AutoSelectParser' |
COMPRESS_PRECOMPILERS | () |
COMPRESS_REBUILD_TIMEOUT | 2592000 |
COMPRESS_ROOT | '/app/staticfiles' |
COMPRESS_STORAGE | 'compressor.storage.CompressorFileStorage' |
COMPRESS_TEMPLATE_FILTER_CONTEXT | {'STATIC_URL': '/static/'} |
COMPRESS_URL | '/static/' |
COMPRESS_URL_PLACEHOLDER | '/__compressor_url_placeholder__/' |
COMPRESS_VERBOSE | False |
COMPRESS_YUGLIFY_BINARY | 'yuglify' |
COMPRESS_YUGLIFY_CSS_ARGUMENTS | '--terminal' |
COMPRESS_YUGLIFY_JS_ARGUMENTS | '--terminal' |
COMPRESS_YUI_BINARY | 'java -jar yuicompressor.jar' |
COMPRESS_YUI_CSS_ARGUMENTS | '' |
COMPRESS_YUI_JS_ARGUMENTS | '' |
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 | ['https://cancercare.bg', 'https://www.cancercare.bg'] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_HEALTH_CHECKS': False, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'HOST': 'ec2-44-194-92-192.compute-1.amazonaws.com', 'NAME': 'd7p7b0qfbh9m8s', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': 5432, 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'nmlzdjfqetbbiu'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATA_UPLOAD_MAX_NUMBER_FILES | 100 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_AUTO_FIELD | 'django.db.models.BigAutoField' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_EXCEPTION_REPORTER | 'django.views.debug.ExceptionReporter' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'storages.backends.s3boto3.S3Boto3Storage' |
DEFAULT_FROM_EMAIL | 'CancerCare<[email protected]>' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_S3_PATH | 'media' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_API_KEY | '********************' |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.sendgrid.net' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'apikey' |
EMAIL_PORT | 587 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | True |
EPAY_API_AUTHORIZE_URL | '********************' |
EPAY_API_AUTHORIZE_URL_LOGIN | '********************' |
EPAY_APP_ID | '3756335525580131253232806512927156962007341258608761695223790690' |
EPAY_GET_TOKEN_CODE_URL | '********************' |
EPAY_GET_TOKEN_URL | '********************' |
EPAY_GET_USER_INFO_URL | 'https://www.epay.bg/v3/api/user/info' |
EPAY_KIN_NUMBER | '7164021798' |
EPAY_PAYMENT_CHECK_URL | 'https://www.epay.bg/v3/api/payment/check' |
EPAY_PAYMENT_INIT_URL | 'https://www.epay.bg/v3/api/payment/init' |
EPAY_PAYMENT_REQUEST_STATUS_URL | 'https://www.epay.bg/v3/api/payment/send/status' |
EPAY_PAYMENT_REQUEST_URL | 'https://www.epay.bg/v3/api/payment/send/user' |
EPAY_SECRET | '********************' |
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_ANALYTICS_TRACKING_ID | 'UA-114610825-1' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['whitenoise.runserver_nostatic', 'debug_toolbar', 'home', 'image', 'search', 'el_pagination', 'puput', 'compressor', 'wagtail.contrib.sitemaps', 'wagtail.contrib.routable_page', 'wagtail.contrib.legacy.richtext', 'wagtail.contrib.forms', 'wagtail.contrib.redirects', 'wagtail.embeds', 'wagtail.sites', 'wagtail.users', 'wagtail.snippets', 'wagtail.documents', 'wagtail.images', 'wagtail.search', 'wagtail.admin', 'wagtail', 'raven.contrib.django.raven_compat', 'modelcluster', 'taggit', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sites', 'django.contrib.sitemaps', 'storages'] |
INTERNAL_IPS | ['127.0.0.1'] |
LANGUAGES | [('en', 'English'), ('bg', 'Bulgarian')] |
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 | {'disable_existing_loggers': False, 'handlers': {'console': {'class': 'logging.StreamHandler'}}, 'root': {'handlers': ['console'], 'level': 'DEBUG'}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | <generator object <genexpr> at 0x7f524e6dc200> |
MEDIA_ROOT | '' |
MEDIA_URL | 'https://cancercare-eu.s3.eu-central-1.amazonaws.com/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['Core.middleware.force_default_language.ForceDefaultLanguageMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'debug_toolbar.middleware.DebugToolbarMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'django.middleware.security.SecurityMiddleware', 'wagtail.contrib.redirects.middleware.RedirectMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
PROJECT_DIR | '/app/Core' |
PUPUT_AS_PLUGIN | True |
RECAPTCHA_SECRET_KEY | '********************' |
RECAPTCHA_SITE_KEY | '********************' |
ROOT_URLCONF | 'Core.urls' |
S3_USE_SIGV4 | True |
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 | ('HTTP_X_FORWARDED_PROTO', 'https') |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SENDGRID_API_KEY | '********************' |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 315360000 |
SESSION_COOKIE_DOMAIN | None |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SAMESITE | 'Lax' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'Core.settings.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 |
STATICFILES_DIRS | ['/app/Core/static'] |
STATICFILES_FINDERS | ('django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder', 'compressor.finders.CompressorFinder') |
STATICFILES_STORAGE | 'whitenoise.storage.CompressedManifestStaticFilesStorage' |
STATIC_ROOT | '/app/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': ['/app/Core/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.custom_context_processors.more_template_variables']}}] |
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' |
USER_AGENTS_CACHE | 'default' |
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 |
WAGTAILADMIN_BASE_URL | 'https://cancercare.bg' |
WAGTAILADMIN_RICH_TEXT_EDITORS | {'default': {'WIDGET': 'wagtail.admin.rich_text.DraftailRichTextArea'}} |
WAGTAILEMBEDS_RESPONSIVE_HTML | True |
WAGTAILIMAGES_IMAGE_MODEL | 'image.CustomImage' |
WAGTAILSEARCH_BACKENDS | {'default': {'BACKEND': 'wagtail.search.backends.database'}} |
WAGTAIL_COMMENTS_RELATION_NAME | 'wagtail_admin_comments' |
WAGTAIL_FRONTEND_LOGIN_URL | '/donations/' |
WAGTAIL_SITE_NAME | 'Core' |
WSGI_APPLICATION | 'Core.wsgi.application' |
X_FRAME_OPTIONS | 'DENY' |
YEAR_MONTH_FORMAT | 'F Y' |
You’re seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.