[<class 'decimal.DivisionByZero'>]
Request Method: | GET |
---|---|
Request URL: | https://subbox.pro/ru/b/1gaxxXmsG |
Django Version: | 2.2.27 |
Exception Type: | DivisionByZero |
Exception Value: | [<class 'decimal.DivisionByZero'>] |
Exception Location: | /opt/subbox/general/views.py in design, line 1058 |
Python Executable: | /opt/env/bin/python3 |
Python Version: | 3.6.5 |
Python Path: | ['/opt/subbox', '/opt/env/bin', '/opt/env/lib/python36.zip', '/opt/env/lib/python3.6', '/opt/env/lib/python3.6/lib-dynload', '/usr/lib/python3.6', '/opt/env/lib/python3.6/site-packages'] |
Server time: | Пт, 29 Мар 2024 11:47:36 +0000 |
/opt/env/lib/python3.6/site-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@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 | DivisionByZero([<class 'decimal.DivisionByZero'>],) |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f755b5620f0>> |
request | <WSGIRequest: GET '/ru/b/1gaxxXmsG'> |
/opt/env/lib/python3.6/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 |
---|---|
callback | <function design at 0x7f7554514b70> |
callback_args | () |
callback_kwargs | {'box_url': '1gaxxXmsG'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f7554628fd0>> |
request | <WSGIRequest: GET '/ru/b/1gaxxXmsG'> |
resolver | <URLResolver 'subbox.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=general.views.design, args=(), kwargs={'box_url': '1gaxxXmsG'}, url_name=box, app_names=[], namespaces=[], route=ru/b/<str:box_url>) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f755b5620f0> |
wrapped_callback | <function design at 0x7f7554514b70> |
/opt/env/lib/python3.6/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 |
---|---|
callback | <function design at 0x7f7554514b70> |
callback_args | () |
callback_kwargs | {'box_url': '1gaxxXmsG'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f7554628fd0>> |
request | <WSGIRequest: GET '/ru/b/1gaxxXmsG'> |
resolver | <URLResolver 'subbox.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=general.views.design, args=(), kwargs={'box_url': '1gaxxXmsG'}, url_name=box, app_names=[], namespaces=[], route=ru/b/<str:box_url>) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f755b5620f0> |
wrapped_callback | <function design at 0x7f7554514b70> |
/opt/subbox/general/views.py
in design
pipe_diameter = round(sqrt(port_area_user / Decimal(3.14)) * 2 * 10, 2)
k = Decimal(1.080)
# k = Decimal(0.850)
else:
k = Decimal(0.980)
# k = Decimal(0.732)
pipe_diameter_cm = Decimal(pipe_diameter) / 10
port_length_cm = (((Decimal(23562.5) * (pipe_diameter_cm * pipe_diameter_cm) * port_quantity) / ((resonant_frequency * resonant_frequency) * box_volume)) - (k * pipe_diameter_cm)) # Длина порта…
if box_type == 2 and (port_type == 3 or port_type == 4):
port_area = port_area_user
else:
port_area = round((pow(pipe_diameter_cm / 2, 2) * Decimal(3.14)), 2) # Площадь порта по диаметру трубы
if box_type == 2 and port_type == 1 and port_quantity == 2:
port_area *= 2
Variable | Value |
---|---|
box | <Box: Cvr> |
box_height | Decimal('1168.4') |
box_object | True |
box_type | 2 |
box_url | '1gaxxXmsG' |
box_volume | Decimal('0') |
box_width | Decimal('914.4') |
brand_list | <QuerySet [<Brand: accuton>, <Brand: Acoustic Elegance>, <Brand: ACV>, <Brand: Airtone>, <Brand: Alphard>, <Brand: Alpine>, <Brand: American Bass>, <Brand: Apocalypse>, <Brand: Aria>, <Brand: ATOHM>, <Brand: Audes>, <Brand: Audiobahn>, <Brand: Audison>, <Brand: Aura>, <Brand: Avatar Audio>, <Brand: AZ-13 SPL Power>, <Brand: B2 Audio>, <Brand: Bass Warrior>, <Brand: B&C Speakers>, <Brand: Beyma>, '...(remaining elements truncated)...']> |
cur_language | 'ru' |
cutout_dimension | Decimal('285') |
dimensions | 'none' |
front_panel | 1 |
k | Decimal('1.0800000000000000710542735760100185871124267578125') |
material_thickness | Decimal('19') |
model_background | '99bd91' |
model_ta | 'nothing' |
model_texture | 'plywood' |
model_wireframe | True |
mounting_depth | Decimal('1.6E+2') |
option_tab | 'box' |
pipe_diameter | 389.94 |
pipe_diameter_cm | Decimal('38.99399999999999977262632456') |
pipe_pull | Decimal('0') |
pipe_wall | Decimal('2') |
port_area_user | Decimal('1193.62') |
port_quantity | 1 |
port_type | 3 |
request | <WSGIRequest: GET '/ru/b/1gaxxXmsG'> |
resonant_frequency | Decimal('32') |
sub_brand | <Brand: Kicker> |
sub_distance | Decimal('2E+1') |
sub_name | 'Cvr' |
sub_offset_y | Decimal('0') |
sub_quantity | 3 |
sub_size | Decimal('15') |
sub_volume | Decimal('2') |
transparent | 'top' |
unit_measure | 'metric' |
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_CF_CONNECTING_IP | '44.211.188.101' |
HTTP_CF_IPCOUNTRY | 'US' |
HTTP_CF_RAY | '86bfa047f86281f3-IAD' |
HTTP_CF_VISITOR | '{"scheme":"https"}' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'subbox.pro' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '44.211.188.101, 172.70.175.132' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '172.70.175.132' |
PATH_INFO | '/ru/b/1gaxxXmsG' |
QUERY_STRING | '' |
RAW_URI | '/ru/b/1gaxxXmsG' |
REMOTE_ADDR | '127.0.0.1' |
REMOTE_PORT | '53768' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '127.0.0.1' |
SERVER_PORT | '8010' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/20.1.0' |
gunicorn.socket | <socket.socket fd=9, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 8010), raddr=('127.0.0.1', 53768)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f7554280da0> |
wsgi.file_wrapper | '' |
wsgi.input | <gunicorn.http.body.Body object at 0x7f7554280dd8> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
subbox.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['subbox.pro'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/opt/subbox' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CRONJOBS | [('0 4 * * *', 'django.core.management.call_command', ['clearsessions'])] |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'subbox_token' |
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.postgresql', 'HOST': '127.0.0.1', 'NAME': 'subbox', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'serenko'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%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'] |
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_CHARSET | 'utf-8' |
DEFAULT_CONTENT_TYPE | 'text/html' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'noreply@subbox.pro' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.yandex.ru' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'noreply@subbox.pro' |
EMAIL_PORT | 465 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | True |
EMAIL_USE_TLS | False |
FILE_CHARSET | 'utf-8' |
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 | None |
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_crontab', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'general'] |
INTERNAL_IPS | [] |
LANGUAGES | [('en', 'English'), ('ru', 'Russian')] |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
LANGUAGE_CODE | 'en' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_NAME | 'subbox_lang' |
LANGUAGE_COOKIE_PATH | '/' |
LOCALE_PATHS | ['/opt/subbox/locale/'] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | 'my' |
LOGIN_URL | '/login/' |
LOGOUT_REDIRECT_URL | 'home' |
MANAGERS | [] |
MEDIA_ROOT | '/opt/subbox/media/' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', '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', 'django.middleware.clickjacking.XFrameOptionsMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'subbox.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
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 | 'subbox.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 | [] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/opt/subbox/static/' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/opt/subbox/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 | False |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'subbox.wsgi.application' |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
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.