ContactPerson matching query does not exist.
Request Method: | GET |
---|---|
Request URL: | https://www.m-e-v.ch/de/kontakt/kontaktformular/?recipient=13 |
Django Version: | 3.2.23 |
Exception Type: | DoesNotExist |
Exception Value: | ContactPerson matching query does not exist. |
Exception Location: | /var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/django/db/models/query.py, line 435, in get |
Python Executable: | /var/www/vhosts/m-e-v.ch/python-app-venv/bin/python |
Python Version: | 3.8.18 |
Python Path: | ['/var/www/vhosts/m-e-v.ch/python-app-venv/bin', '/var/www/vhosts/m-e-v.ch/httpdocs/web', '/var/www/vhosts/m-e-v.ch/httpdocs', '/var/www/vhosts/m-e-v.ch', '/usr/share/passenger/helper-scripts', '/var/www/vhosts/m-e-v.ch/python-app-venv/lib64/python38.zip', '/var/www/vhosts/m-e-v.ch/python-app-venv/lib64/python3.8', '/var/www/vhosts/m-e-v.ch/python-app-venv/lib64/python3.8/lib-dynload', '/opt/alt/python38/lib64/python3.8', '/opt/alt/python38/lib/python3.8', '/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages'] |
Server time: | Fri, 29 Mar 2024 13:09:00 +0000 |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/django/core/handlers/exception.py
, line 47, in inner
response = await sync_to_async(response_for_exception, thread_sensitive=False)(request, exc)
return response
return inner
else:
@wraps(get_response)
def inner(request):
try:
response = get_response(request)…
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | DoesNotExist('ContactPerson matching query does not exist.') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7fe67f8cc070>> |
request | <WSGIRequest: GET '/de/kontakt/kontaktformular/?recipient=13'> |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/django/core/handlers/base.py
, line 181, in _get_response
if response is None:
wrapped_callback = self.make_view_atomic(callback)
# If it is an asynchronous view, run it in a subthread.
if asyncio.iscoroutinefunction(wrapped_callback):
wrapped_callback = async_to_sync(wrapped_callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
# Complain if the view returned None (a common error).
Variable | Value |
---|---|
callback | <function serve at 0x7fe67f273280> |
callback_args | ('kontakt/kontaktformular/',) |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7fe67f902340>> |
request | <WSGIRequest: GET '/de/kontakt/kontaktformular/?recipient=13'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7fe67f8cc070> |
wrapped_callback | <function serve at 0x7fe67f273280> |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/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 | [] |
fn | <function check_view_restrictions at 0x7fe6835ce4c0> |
kwargs | {} |
page | <ContactFormPage: Kontaktformular> |
path | 'kontakt/kontaktformular/' |
path_components | ['kontakt', 'kontaktformular'] |
request | <WSGIRequest: GET '/de/kontakt/kontaktformular/?recipient=13'> |
result | None |
site | <Site: m-e-v.ch [Standard]> |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/wagtailcache/cache.py
, line 240, in _wrapped_view_func
"""
@wraps(view_func)
def _wrapped_view_func(
request: WSGIRequest, *args, **kwargs
) -> HttpResponse:
# Run the view.
response = view_func(request, *args, **kwargs)…
# Set cache-control if wagtail-cache is enabled.
if wagtailcache_settings.WAGTAIL_CACHE:
_patch_header(response, Status.SKIP)
return response
return _wrapped_view_func
Variable | Value |
---|---|
args | (<WSGIRequest: GET '/de/kontakt/kontaktformular/?recipient=13'>,) |
kwargs | {} |
request | <ContactFormPage: Kontaktformular> |
view_func | <function ContactFormPage.serve at 0x7fe67fac5670> |
/var/www/vhosts/m-e-v.ch/httpdocs/home/models.py
, line 283, in serve
if form.is_valid():
return self._process(request)
else:
form = ContactForm(request=request)
recipient = None
if request.GET.get('recipient', False):
recipient = ContactPerson.objects.get(id=request.GET['recipient'])…
ref = None
if request.GET.get('ref', False):
ref = request.GET['ref']
return render(request, 'forms/contact-form.html', {
Variable | Value |
---|---|
form | <ContactForm bound=False, valid=Unknown, fields=(firstname;lastname;company;street;zip;city;phone;email;reference;message;attachments)> |
recipient | None |
request | <WSGIRequest: GET '/de/kontakt/kontaktformular/?recipient=13'> |
self | <ContactFormPage: Kontaktformular> |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/django/db/models/manager.py
, line 85, in manager_method
def check(self, **kwargs):
return []
@classmethod
def _get_queryset_methods(cls, queryset_class):
def create_method(name, method):
def manager_method(self, *args, **kwargs):
return getattr(self.get_queryset(), name)(*args, **kwargs)…
manager_method.__name__ = method.__name__
manager_method.__doc__ = method.__doc__
return manager_method
new_methods = {}
for name, method in inspect.getmembers(queryset_class, predicate=inspect.isfunction):
Variable | Value |
---|---|
args | () |
kwargs | {'id': '13'} |
name | 'get' |
self | <django.db.models.manager.Manager object at 0x7fe67ef90850> |
/var/www/vhosts/m-e-v.ch/python-app-venv/lib/python3.8/site-packages/django/db/models/query.py
, line 435, in get
if not clone.query.select_for_update or connections[clone.db].features.supports_select_for_update_with_limit:
limit = MAX_GET_RESULTS
clone.query.set_limits(high=limit)
num = len(clone)
if num == 1:
return clone._result_cache[0]
if not num:
raise self.model.DoesNotExist(…
"%s matching query does not exist." %
self.model._meta.object_name
)
raise self.model.MultipleObjectsReturned(
'get() returned more than one %s -- it returned %s!' % (
self.model._meta.object_name,
Variable | Value |
---|---|
args | () |
clone | <QuerySet []> |
kwargs | {'id': '13'} |
limit | 21 |
num | 0 |
self | <QuerySet [<ContactPerson: Benoît Bernhard>, <ContactPerson: Salvatore Ciravolo>, <ContactPerson: Gabriele Marco D'Umas>, <ContactPerson: Tommaso di Benedetto>, <ContactPerson: Rico Erbe>, <ContactPerson: Michel Gerber>, <ContactPerson: Beat Jost>, <ContactPerson: Hagerina Kahsay>, <ContactPerson: Mayk Koal>, <ContactPerson: Torsten Lehmann>, <ContactPerson: Matthias Löser>, <ContactPerson: Adriana Manzari>, <ContactPerson: André Mattheus>, <ContactPerson: MEV Ausbildung>, <ContactPerson: MEV Sekretariat>, <ContactPerson: Ingo Möckel>, <ContactPerson: Thomas Naumann>, <ContactPerson: Emina Novak>, <ContactPerson: Andreas Obermayer>, <ContactPerson: Idris Oymak>, '...(remaining elements truncated)...']> |
AnonymousUser
Variable | Value |
---|---|
recipient | '13' |
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTPS | 'on' |
HTTP_ACCEPT | '*/*' |
HTTP_HOST | 'www.m-e-v.ch' |
HTTP_USER_AGENT | 'claudebot' |
PASSENGER_COMPILE_NATIVE_SUPPORT_BINARY | '********************' |
PASSENGER_CONNECT_PASSWORD | '********************' |
PASSENGER_DOWNLOAD_NATIVE_SUPPORT_BINARY | '********************' |
PATH_INFO | '/de/kontakt/kontaktformular/' |
QUERY_STRING | 'recipient=13' |
REMOTE_ADDR | '3.236.240.48' |
REMOTE_PORT | '36318' |
REQUEST_METHOD | 'GET' |
REQUEST_URI | '/de/kontakt/kontaktformular/?recipient=13' |
SCRIPT_NAME | '' |
SERVER_NAME | 'www.m-e-v.ch' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'nginx/1.24.0 Phusion_Passenger/6.0.20' |
passenger.hijack | '********************' |
wsgi.errors | <_io.TextIOWrapper name='<stderr>' mode='w' encoding='utf-8'> |
wsgi.input | <_io.BufferedReader name=11> |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
web.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['m-e-v.ch', 'www.m-e-v.ch'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/var/www/vhosts/m-e-v.ch/httpdocs' |
BASE_URL | 'http://localhost:8000' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.db.DatabaseCache', 'LOCATION': 'cache_default', 'TIMEOUT': 86400}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | 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_MAX_AGE': 0, 'ENGINE': 'django.db.backends.mysql', 'HOST': 'localhost', 'NAME': 'mevch0ztn3_mev_prod', 'OPTIONS': {'init_command': "SET sql_mode='STRICT_TRANS_TABLES'"}, 'PASSWORD': '********************', 'PORT': '3306', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'mevch0ztn3_mev_prod'}} |
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.AutoField' |
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 | 'webmaster@localhost' |
DEFAULT_HASHING_ALGORITHM | 'sha256' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
{'recipient_contact_form': 'info@m-e-v.ch', 'recipient_course_form': 'info@m-e-v.ch'} |
|
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
GOOGLE_ANALYTICS_ON | True |
GOOGLE_MAPS_APIKEY | '********************' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['home', 'blocks', 'search', 'snippets', 'bootstrap', 'formtools', 'wagtail.contrib.forms', 'wagtail.contrib.modeladmin', 'wagtail.contrib.redirects', 'wagtail.embeds', 'wagtail.sites', 'wagtail.users', 'wagtail.snippets', 'wagtail.documents', 'wagtail.images', 'wagtail.search', 'wagtail.admin', 'wagtail.core', 'modelcluster', 'taggit', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'wagtailcache', 'django_countries'] |
INTERNAL_IPS | [] |
LANGUAGES | [('de', 'Deutsch'), ('fr', 'Français'), ('it', 'Italiano'), ('en', 'English')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'de' |
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 | ('/var/www/vhosts/m-e-v.ch/httpdocs/locale',) |
LOGGING | {'disable_existing_loggers': False, 'formatters': {'simple': {'format': '{levelname} {message}', 'style': '{'}, 'verbose': {'format': '{levelname} {asctime} {module} ' '{process:d} {thread:d} {message}', 'style': '{'}}, 'handlers': {'file': {'class': 'logging.FileHandler', 'filename': '/var/www/vhosts/m-e-v.ch/httpdocs/logs/error.log', 'formatter': 'verbose', 'level': 'WARNING'}}, 'loggers': {'django': {'handlers': ['file'], 'level': 'INFO', 'propagate': True}}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/var/www/vhosts/m-e-v.ch/httpdocs/media' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['wagtailcache.cache.UpdateCacheMiddleware', '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.security.SecurityMiddleware', 'wagtail.contrib.redirects.middleware.RedirectMiddleware', 'django.middleware.locale.LocaleMiddleware', 'wagtailcache.cache.FetchFromCacheMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
PROD | True |
PROJECT_DIR | '/var/www/vhosts/m-e-v.ch/httpdocs/web' |
RECAPTCHA | {'PRIVATE': '6LfWPb0aAAAAADk4IipWyGxKzBUyU1YJ7bw4NEfQ', 'PUBLIC': '6LfWPb0aAAAAAFvz-ULooGdy-kgb8yqelEOcAKU9'} |
ROOT_URLCONF | 'web.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | True |
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 | 'web.settings.production' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SMTP | {'email': 'website@m-e-v.ch', 'host': 'smtp.office365.com', 'login': 'website@m-e-v.ch', 'password': '********************', 'port': 587} |
STATICFILES_DIRS | ['/var/www/vhosts/m-e-v.ch/httpdocs/web/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.ManifestStaticFilesStorage' |
STATIC_ROOT | '/var/www/vhosts/m-e-v.ch/httpdocs/static' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/var/www/vhosts/m-e-v.ch/httpdocs/web/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_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WAGTAILIMAGES_IMAGE_MODEL | 'home.CustomImage' |
WAGTAIL_CONTENT_LANGUAGES | [('de', 'Deutsch'), ('fr', 'Français'), ('it', 'Italiano'), ('en', 'English')] |
WAGTAIL_I18N_ENABLED | True |
WAGTAIL_SITE_NAME | 'web' |
WSGI_APPLICATION | 'web.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.