local variable 'redirect' referenced before assignment
Request Method: | GET |
---|---|
Request URL: | http://rimmo/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/ |
Django Version: | 1.9 |
Exception Type: | UnboundLocalError |
Exception Value: | local variable 'redirect' referenced before assignment |
Exception Location: | ./rimmosite/views.py in immobilie_detail, line 283 |
Python Executable: | /usr/local/bin/uwsgi |
Python Version: | 3.5.10 |
Python Path: | ['.', '', '/usr/local/lib/python35.zip', '/usr/local/lib/python3.5', '/usr/local/lib/python3.5/plat-linux', '/usr/local/lib/python3.5/lib-dynload', '/usr/local/lib/python3.5/site-packages'] |
Server time: | Fri, 29 Mar 2024 10:58:09 +0000 |
./rimmosite/views.py
in immobilie_detail
immobilien = paginator.page(paginator.num_pages)
return render(request, "rimmosite/index.html", {'nr_objects': nr_objects, 'objects': immobilien, 'title': title, 'description': description, 'keywords': keywords, 'paginator': paginator, 'mietekauf': mietekauf, 'objektart': objektart, 'subobjektart': subobjektart, 'bezirk': provinz, 'subbezirk': ort, 'site': "home", 'search': True, 'page_id': int(page_id), 'canonical': canonical, 'prefix': mietekauf + "/" + objektart + "/" + subobjektart + "/" + provinz + "/" + ort + "/", 'provinces': provinces})
def immobilie_detail(request, immobilie_id):
try:
immobilie = Immobilie.objects.get(id=immobilie_id)...
except Exception:
# TODO: handle redirect better
return redirect('/')
# handle post request for sending email
if request.method == 'POST':
r = request.POST
Variable | Value |
---|---|
immobilie_id | '2805' |
request | <WSGIRequest: GET '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/'> |
/usr/local/lib/python3.5/site-packages/django/db/models/manager.py
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 = {}
# Refs http://bugs.python.org/issue1785.
Variable | Value |
---|---|
self | <modeltranslation.manager.MultilingualManager object at 0x7f104b4b3550> |
kwargs | {'id': '2805'} |
name | 'get' |
args | () |
/usr/local/lib/python3.5/site-packages/django/db/models/query.py
in get
clone = clone.order_by()
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, num)
)
Variable | Value |
---|---|
num | 0 |
clone | [] |
self | [<Immobilie: R00108BZHA>, <Immobilie: R00177KAGE>, <Immobilie: R00177KAGE>, <Immobilie: R00179KAGE>, <Immobilie: R00344BZHA>, <Immobilie: V00006HABZ>, <Immobilie: R00308RFBG>, <Immobilie: R00309RFBG>, <Immobilie: R01017BZBU>, <Immobilie: R01174BZGE>, <Immobilie: V00053BZBU>, <Immobilie: R01725BZ4Z>, <Immobilie: R01990BZGA>, <Immobilie: R02234SI3Z>, <Immobilie: R02235SI3Z>, <Immobilie: R02236SI2Z>, <Immobilie: R02237SI2Z>, <Immobilie: R02302NEVI>, <Immobilie: R02308ST3Z>, <Immobilie: R02445RIHF>, '...(remaining elements truncated)...'] |
kwargs | {'id': '2805'} |
args | () |
/usr/local/lib/python3.5/site-packages/django/core/handlers/base.py
in get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)...
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f104b3d9828>> |
callback_args | () |
response_is_rendered | False |
callback_kwargs | {'immobilie_id': '2805'} |
resolver_match | ResolverMatch(func=rimmosite.views.immobilie_detail, args=(), kwargs={'immobilie_id': '2805'}, url_name=detail, app_names=[], namespaces=[]) |
request | <WSGIRequest: GET '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/'> |
resolver | <RegexURLResolver 'rimmo.urls' (None:None) ^/> |
callback | <function immobilie_detail at 0x7f104b13a840> |
urlconf | 'rimmo.urls' |
wrapped_callback | <function immobilie_detail at 0x7f104b13a840> |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f104c9986a0> |
response | None |
/usr/local/lib/python3.5/site-packages/django/core/handlers/base.py
in get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)...
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f104b3d9828>> |
callback_args | () |
response_is_rendered | False |
callback_kwargs | {'immobilie_id': '2805'} |
resolver_match | ResolverMatch(func=rimmosite.views.immobilie_detail, args=(), kwargs={'immobilie_id': '2805'}, url_name=detail, app_names=[], namespaces=[]) |
request | <WSGIRequest: GET '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/'> |
resolver | <RegexURLResolver 'rimmo.urls' (None:None) ^/> |
callback | <function immobilie_detail at 0x7f104b13a840> |
urlconf | 'rimmo.urls' |
wrapped_callback | <function immobilie_detail at 0x7f104b13a840> |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f104c9986a0> |
response | None |
./rimmosite/views.py
in immobilie_detail
def immobilie_detail(request, immobilie_id):
try:
immobilie = Immobilie.objects.get(id=immobilie_id)
except Exception:
# TODO: handle redirect better
return redirect('/')...
# handle post request for sending email
if request.method == 'POST':
r = request.POST
if r["posttype"] == u"anfrage":
headers = {'Reply-To': r["email"]}
provinz = immobilie.ort.provinz.identifier
Variable | Value |
---|---|
immobilie_id | '2805' |
request | <WSGIRequest: GET '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/'> |
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
SCRIPT_NAME | '' |
SERVER_PROTOCOL | 'HTTP/1.1' |
HTTP_ACCEPT | '*/*' |
UWSGI_ROUTER | 'http' |
wsgi.version | (1, 0) |
HTTP_USER_AGENT | 'claudebot' |
wsgi.url_scheme | 'http' |
REQUEST_METHOD | 'GET' |
HTTP_HOST | 'rimmo' |
uwsgi.node | b'077aea88e90c' |
HTTP_CONNECTION | 'close' |
wsgi.run_once | False |
SERVER_NAME | '077aea88e90c' |
PATH_INFO | '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/' |
wsgi.multithread | False |
QUERY_STRING | '' |
REMOTE_PORT | '57510' |
SERVER_PORT | '8000' |
wsgi.input | <uwsgi._Input object at 0x7f104aea06c0> |
REQUEST_URI | '/en/vendita/appartamenti/trilocale/bolzano/bolzano-europa-novacella/detail/2805/' |
wsgi.file_wrapper | '' |
REMOTE_ADDR | '172.17.0.1' |
uwsgi.version | b'2.0.23' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.multiprocess | False |
rimmo.settings
Setting | Value |
---|---|
THOUSAND_SEPARATOR | ',' |
LOCALEURL_USE_SESSION | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
DEBUG_PROPAGATE_EXCEPTIONS | False |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': '/rimmosite/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']}}] |
SECURE_HSTS_SECONDS | 0 |
ADMINS | (('Krisitan Schwienbacher', 'kr3dde@gmail.com'),) |
IGNORABLE_404_URLS | [] |
LOGGING_CONFIG | 'logging.config.dictConfig' |
DEFAULT_CONTENT_TYPE | 'text/html' |
CSRF_COOKIE_NAME | 'csrftoken' |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
TIME_ZONE | 'Europe/Rome' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
LANGUAGE_COOKIE_DOMAIN | None |
DECIMAL_SEPARATOR | '.' |
DATETIME_FORMAT | 'N j, Y, P' |
TEMPLATE_DEBUG | False |
SESSION_COOKIE_HTTPONLY | True |
SECURE_SSL_HOST | None |
USE_X_FORWARDED_PORT | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
DATABASE_ROUTERS | [] |
LOCALE_PATHS | ('/srv/www/rimmo.tgummerer.com/locale', '/Users/kredde/dev/rimmosite/locale', '/rimmosite/locale') |
SILENCED_SYSTEM_CHECKS | [] |
STATICFILES_DIRS | '/rimmosite/static' |
TEST_NON_SERIALIZED_APPS | [] |
SERVER_EMAIL | 'root@localhost' |
SHORT_DATE_FORMAT | 'm/d/Y' |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
CACHE_MIDDLEWARE_SECONDS | 600 |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%Y-%m-%d', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%Y', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M', '%m/%d/%y'] |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
LANGUAGES | (('de', 'Deutsch'), ('it', 'Italiano'), ('en', 'English')) |
SECURE_REDIRECT_EXEMPT | [] |
SESSION_FILE_PATH | None |
MONTH_DAY_FORMAT | 'F j' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
EMAIL_USE_SSL | False |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
FORCE_SCRIPT_NAME | None |
TIME_FORMAT | 'P' |
AUTH_USER_MODEL | 'auth.User' |
MEDIA_URL | '/media/' |
MEDIA_ROOT | '/rimmosite/media/' |
ALLOWED_HOSTS | ['161.35.201.189'] |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
STATIC_URL | '/static/' |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.sqlite3', 'HOST': '', 'NAME': 'rimmo_production.db', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': ''}} |
LOGOUT_URL | '/accounts/logout/' |
DISALLOWED_USER_AGENTS | [] |
USE_I18N | True |
DEFAULT_INDEX_TABLESPACE | '' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
AUTH_PASSWORD_VALIDATORS | '********************' |
STATIC_ROOT | '' |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
ALLOWED_INCLUDE_ROOTS | [] |
SECURE_PROXY_SSL_HEADER | None |
MIDDLEWARE_CLASSES | ('django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.locale.LocaleMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware') |
CSRF_TRUSTED_ORIGINS | [] |
SESSION_SAVE_EVERY_REQUEST | False |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
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'] |
SITE_ID | 1 |
SECURE_BROWSER_XSS_FILTER | False |
MANAGERS | (('Krisitan Schwienbacher', 'kr3dde@gmail.com'),) |
EMAIL_USE_TLS | True |
EMAIL_TIMEOUT | None |
FORMAT_MODULE_PATH | None |
LOGGING | {'disable_existing_loggers': False, 'filters': {'require_debug_false': {'()': 'django.utils.log.RequireDebugFalse'}}, 'handlers': {'mail_admins': {'class': 'django.utils.log.AdminEmailHandler', 'filters': ['require_debug_false'], 'level': 'ERROR'}}, 'loggers': {'django.request': {'handlers': ['mail_admins'], 'level': 'ERROR', 'propagate': True}}, 'version': 1} |
FIRST_DAY_OF_WEEK | 0 |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
CSRF_COOKIE_SECURE | False |
EMAIL_SSL_KEYFILE | '********************' |
CSRF_COOKIE_PATH | '/' |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
NUMBER_GROUPING | 0 |
ROOT_URLCONF | 'rimmo.urls' |
EMAIL_HOST_USER | 'info@rimmo.it' |
SESSION_CACHE_ALIAS | 'default' |
DEFAULT_TABLESPACE | '' |
CSRF_COOKIE_AGE | 31449600 |
SESSION_COOKIE_NAME | 'sessionid' |
SETTINGS_MODULE | 'rimmo.settings' |
SECURE_SSL_REDIRECT | False |
USE_L10N | True |
FILE_CHARSET | 'utf-8' |
TEMPLATE_STRING_IF_INVALID | '' |
SESSION_COOKIE_PATH | '/' |
APPEND_SLASH | True |
EMAIL_HOST_PASSWORD | '********************' |
LANGUAGE_COOKIE_NAME | 'django_language' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_CHARSET | 'utf-8' |
CSRF_COOKIE_DOMAIN | None |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
PASSWORD_HASHERS | '********************' |
SECURE_CONTENT_TYPE_NOSNIFF | False |
CSRF_COOKIE_HTTPONLY | False |
INSTALLED_APPS | ('modeltranslation', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.admin', 'django.contrib.humanize', 'rimmosite', 'sorl.thumbnail', 'rosetta') |
SESSION_COOKIE_AGE | 1209600 |
WSGI_APPLICATION | 'rimmo.wsgi.application' |
SESSION_COOKIE_DOMAIN | None |
ABSOLUTE_URL_OVERRIDES | {} |
DATE_FORMAT | 'N j, Y' |
SECRET_KEY | '********************' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
SESSION_COOKIE_SECURE | False |
TEMPLATE_CONTEXT_PROCESSORS | ['django.contrib.auth.context_processors.auth', 'django.template.context_processors.debug', 'django.template.context_processors.i18n', 'django.template.context_processors.media', 'django.template.context_processors.static', 'django.template.context_processors.tz', 'django.contrib.messages.context_processors.messages'] |
USE_THOUSAND_SEPARATOR | False |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
TEMPLATE_DIRS | [] |
INTERNAL_IPS | [] |
CACHE_MIDDLEWARE_ALIAS | 'default' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
FILE_UPLOAD_PERMISSIONS | None |
EMAIL_PORT | 587 |
LANGUAGE_CODE | 'de-DE' |
EMAIL_SSL_CERTFILE | None |
USE_TZ | True |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_AGE | None |
FIXTURE_DIRS | [] |
USE_X_FORWARDED_HOST | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
MIGRATION_MODULES | {} |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
FILE_UPLOAD_TEMP_DIR | None |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
STATICFILES_FINDERS | ('django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder') |
TEMPLATE_LOADERS | ('django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader') |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
PREPEND_WWW | False |
EMAIL_HOST | 'smtp.gmail.com' |
LOGIN_URL | '/accounts/login/' |
YEAR_MONTH_FORMAT | 'F Y' |
USE_ETAGS | False |
DEBUG | True |
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.