· 5 years ago · Sep 18, 2020, 08:58 AM
1AttributeError at /api/v1/cart/change/
2'NoneType' object has no attribute 'product'
3
4Request Method: POST
5Request URL: https://totis2.webcase-dev.com/api/v1/cart/change/
6Django Version: 2.2
7Python Executable: /home/totis/totis/totis/server/.venv/bin/python
8Python Version: 3.8.0
9Python Path: ['/home/totis/totis/totis/server', '/home/totis/totis/totis/server', '/home/totis/totis/totis/server/.venv/bin', '/usr/lib/python38.zip', '/usr/lib/python3.8', '/usr/lib/python3.8/lib-dynload', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages', '/home/totis/totis/totis', '/home/totis/totis/totis/server', '/home/totis/totis/totis/server/app', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf', '/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/odf']
10Server time: Пт, 18 Сен 2020 08:51:28 +0000
11Installed Applications:
12['markup',
13 'shared',
14 'apps.attribute',
15 'apps.blog',
16 'apps.cart',
17 'apps.core',
18 'apps.comparison',
19 'apps.currencies',
20 'apps.event',
21 'apps.external',
22 'apps.feedback',
23 'apps.logger',
24 'apps.menu',
25 'apps.monobank_payparts',
26 'apps.novaposhta',
27 'apps.old_site',
28 'apps.order',
29 'apps.pages',
30 'apps.payments',
31 'apps.privatbank_payparts',
32 'apps.recipe',
33 'apps.review',
34 'apps.slider',
35 'apps.sales',
36 'apps.staff',
37 'apps.store',
38 'apps.tilda_wrapper',
39 'apps.organization',
40 'adminsortable2',
41 'cities_light',
42 'ckeditor',
43 'ckeditor_uploader',
44 'constance',
45 'constance.backends.database',
46 'codemirror2',
47 'des',
48 'django_better_admin_arrayfield',
49 'django_jinja',
50 'django_json_widget',
51 'django_filters',
52 'django_mptt_admin',
53 'import_export',
54 'jet',
55 'parler',
56 'postie',
57 'postie.integrations.tilda',
58 'rest_framework',
59 'rest_framework.authtoken',
60 'rest_auth',
61 'drf_yasg',
62 'mptt',
63 'modeltranslation',
64 'nested_admin',
65 'polymorphic',
66 'ok_redirects',
67 'robots',
68 'rosetta',
69 'seo',
70 'solo',
71 'social_django',
72 'script_pattern',
73 'versatileimagefield',
74 'vuejs_translate',
75 'django.contrib.admin',
76 'django.contrib.auth',
77 'django.contrib.contenttypes',
78 'django.contrib.sessions',
79 'django.contrib.messages',
80 'django.contrib.staticfiles',
81 'django.contrib.sites']
82Installed Middleware:
83['django.middleware.security.SecurityMiddleware',
84 'django.contrib.sessions.middleware.SessionMiddleware',
85 'django.middleware.locale.LocaleMiddleware',
86 'django.middleware.common.CommonMiddleware',
87 'django.middleware.csrf.CsrfViewMiddleware',
88 'django.contrib.auth.middleware.AuthenticationMiddleware',
89 'django.contrib.messages.middleware.MessageMiddleware',
90 'django.middleware.clickjacking.XFrameOptionsMiddleware',
91 'ok_redirects.middleware.RedirectMiddleware',
92 'social_django.middleware.SocialAuthExceptionMiddleware',
93 'seo.middleware.url_seo_middleware']
94
95
96Traceback:
97
98File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/django/core/handlers/exception.py" in inner
99 34. response = get_response(request)
100
101File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/django/core/handlers/base.py" in _get_response
102 115. response = self.process_exception_by_middleware(e, request)
103
104File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/django/core/handlers/base.py" in _get_response
105 113. response = wrapped_callback(request, *callback_args, **callback_kwargs)
106
107File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/django/views/decorators/csrf.py" in wrapped_view
108 54. return view_func(*args, **kwargs)
109
110File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/django/views/generic/base.py" in view
111 71. return self.dispatch(request, *args, **kwargs)
112
113File "/home/totis/totis/totis/server/shared/rest/mixins.py" in dispatch
114 23. return super().dispatch(request, *args, **kwargs)
115
116File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/rest_framework/views.py" in dispatch
117 505. response = self.handle_exception(exc)
118
119File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/rest_framework/views.py" in handle_exception
120 465. self.raise_uncaught_exception(exc)
121
122File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/rest_framework/views.py" in raise_uncaught_exception
123 476. raise exc
124
125File "/home/totis/totis/totis/server/.venv/lib/python3.8/site-packages/rest_framework/views.py" in dispatch
126 502. response = handler(request, *args, **kwargs)
127
128File "/home/totis/totis/totis/server/shared/rest/views.py" in post
129 433. result = self.perform_action(self.serializer)
130
131File "/home/totis/totis/totis/server/api/rest/cart/views.py" in perform_action
132 44. add_item_to_cart(
133
134File "/home/totis/totis/totis/server/apps/cart/services/cart.py" in add_item_to_cart
135 111. apply_active_sale_campaigns(
136
137File "/home/totis/totis/totis/server/apps/cart/services/cart.py" in apply_active_sale_campaigns
138 61. descriptor.cart_helper.apply(cart=cart, cart_items=cart_items)
139
140File "/home/totis/totis/totis/server/apps/sales/cart_helpers.py" in apply
141 333. if self.is_condition_fulfilled(cart, cart_items):
142
143File "/home/totis/totis/totis/server/apps/sales/cart_helpers.py" in is_condition_fulfilled
144 165. descriptor_cart_items = [
145
146File "/home/totis/totis/totis/server/apps/sales/cart_helpers.py" in <listcomp>
147 167. if cart_item.content_object.product.brand in brands
148
149Exception Type: AttributeError at /api/v1/cart/change/
150Exception Value: 'NoneType' object has no attribute 'product'
151Request information:
152USER: admin
153
154GET: No GET data
155
156POST: No POST data
157
158FILES: No FILES data
159
160COOKIES:
161csrftoken = 'Qy8FOSazHm1MoghTcbpSqBk14e9UlZ9SKbN5UDRV50sH9HLxjCxl6EIwfdWNSMBh'
162sessionid = 'zyn5b5d1eism6usfa6w3zw5290p6qel5'
163TOTIS2.currency_code = 'EUR'
164TOTIS_VIEWED_PRODUCTS = '2022,2022,1493,2022,1173:1kJC6y:tjC4Ju7EHPl0B4xCSrVUQfJf26k'
165
166META:
167CONTENT_LENGTH = '81'
168CONTENT_TYPE = 'application/json'
169CSRF_COOKIE = 'Qy8FOSazHm1MoghTcbpSqBk14e9UlZ9SKbN5UDRV50sH9HLxjCxl6EIwfdWNSMBh'
170HTTP_ACCEPT = '*/*'
171HTTP_ACCEPT_ENCODING = 'gzip, deflate, br'
172HTTP_ACCEPT_LANGUAGE = 'ru'
173HTTP_CACHE_CONTROL = 'no-cache'
174HTTP_CONNECTION = 'close'
175HTTP_COOKIE = 'csrftoken=Qy8FOSazHm1MoghTcbpSqBk14e9UlZ9SKbN5UDRV50sH9HLxjCxl6EIwfdWNSMBh; sessionid=zyn5b5d1eism6usfa6w3zw5290p6qel5; TOTIS2.currency_code=EUR; TOTIS_VIEWED_PRODUCTS="2022\\0542022\\0541493\\0542022\\0541173:1kJC6y:tjC4Ju7EHPl0B4xCSrVUQfJf26k"'
176HTTP_HOST = 'totis2.webcase-dev.com'
177HTTP_ORIGIN = 'https://totis2.webcase-dev.com'
178HTTP_PRAGMA = 'no-cache'
179HTTP_REFERER = 'https://totis2.webcase-dev.com/product/summer-glow-sun-sensitive-emulsion-spf-30-1/client'
180HTTP_SEC_FETCH_DEST = 'empty'
181HTTP_SEC_FETCH_MODE = 'same-origin'
182HTTP_SEC_FETCH_SITE = 'same-origin'
183HTTP_USER_AGENT = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.102 Safari/537.36'
184HTTP_X_CSRFTOKEN = 'Qy8FOSazHm1MoghTcbpSqBk14e9UlZ9SKbN5UDRV50sH9HLxjCxl6EIwfdWNSMBh'
185HTTP_X_FORWARDED_FOR = '194.31.168.66'
186HTTP_X_FORWARDED_PROTO = 'https'
187HTTP_X_REQUESTED_WITH = 'XMLHttpRequest'
188PATH_INFO = '/api/v1/cart/change/'
189QUERY_STRING = ''
190RAW_URI = '/api/v1/cart/change/'
191REMOTE_ADDR = ''
192REQUEST_METHOD = 'POST'
193SCRIPT_NAME = ''
194SERVER_NAME = 'totis2.webcase-dev.com'
195SERVER_PORT = '443'
196SERVER_PROTOCOL = 'HTTP/1.0'
197SERVER_SOFTWARE = 'gunicorn/20.0.4'
198gunicorn.socket = <gevent._socket3.socket at 0x7f09b588bb20 object, fd=8, family=1, type=1, proto=0>
199wsgi.errors = <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f09b6b43ee0>
200wsgi.file_wrapper = ''
201wsgi.input = <gunicorn.http.body.Body object at 0x7f09b6af8bb0>
202wsgi.input_terminated = True
203wsgi.multiprocess = True
204wsgi.multithread = True
205wsgi.run_once = False
206wsgi.url_scheme = 'https'
207wsgi.version = '(1, 0)'
208
209Settings:
210Using settings module app.settings
211ABSOLUTE_URL_OVERRIDES = {}
212ADMINS = []
213ALLOWED_HOSTS = ['161.35.214.95', 'totis2.webcase-dev.com']
214APPEND_SLASH = True
215AUTHENTICATION_BACKENDS = "('social_core.backends.facebook.FacebookOAuth2', 'django.contrib.auth.backends.ModelBackend')"
216AUTH_PASSWORD_VALIDATORS = '********************'
217AUTH_USER_MODEL = 'staff.User'
218BASE_DIR = PosixPath('/home/totis/totis/totis/server/app/settings/default.py')
219BASE_ROOT = PosixPath('/home/totis/totis/totis/server/app')
220CACHES = {'default': {'BACKEND': 'django_redis.cache.RedisCache', 'LOCATION': 'redis://127.0.0.1:6379/1'}}
221CACHE_MIDDLEWARE_ALIAS = 'default'
222CACHE_MIDDLEWARE_KEY_PREFIX = '********************'
223CACHE_MIDDLEWARE_SECONDS = 600
224CELERY_ACCEPT_CONTENT = ['application/json']
225CELERY_BROKER_URL = 'redis://127.0.0.1:6379/0'
226CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/0'
227CELERY_RESULT_SERIALIZER = 'json'
228CELERY_TASK_ALWAYS_EAGER = False
229CELERY_TASK_SERIALIZER = 'json'
230CELERY_TIMEZONE = 'UTC'
231CITIES_LIGHT_INCLUDE_CITY_TYPES = ['PPL', 'PPLA', 'PPLA2', 'PPLA3', 'PPLA4', 'PPLC', 'PPLF', 'PPLG', 'PPLL', 'PPLR', 'PPLS', 'STLMT']
232CITIES_LIGHT_INCLUDE_COUNTRIES = ['UA']
233CITIES_LIGHT_TRANSLATION_LANGUAGES = ['ru', 'uk']
234CKEDITOR_CONFIGS = {'default': {'language': 'en', 'skin': 'office2013', 'toolbar_Basic': [['Source', '-', 'Bold', 'Italic']], 'toolbar_YourCustomToolbarConfig': [{'name': 'document', 'items': ['Source', '-', 'Save', 'NewPage', 'Preview', 'Print', '-', 'Templates']}, {'name': 'clipboard', 'items': ['Cut', 'Copy', 'Paste', 'PasteText', 'PasteFromWord', '-', 'Undo', 'Redo']}, {'name': 'editing', 'items': ['Find', 'Replace', '-', 'SelectAll']}, {'name': 'forms', 'items': ['Form', 'Checkbox', 'Radio', 'TextField', 'Textarea', 'Select', 'Button', 'ImageButton', 'HiddenField']}, '/', {'name': 'basicstyles', 'items': ['Bold', 'Italic', 'Underline', 'Strike', 'Subscript', 'Superscript', '-', 'RemoveFormat']}, {'name': 'paragraph', 'items': ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', '-', 'Blockquote', 'CreateDiv', '-', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock', '-', 'BidiLtr', 'BidiRtl', 'Language']}, {'name': 'links', 'items': ['Link', 'Unlink', 'Anchor']}, {'name': 'insert', 'items': ['Image', 'Flash', 'Table', 'HorizontalRule', 'Smiley', 'SpecialChar', 'PageBreak', 'Iframe']}, '/', {'name': 'styles', 'items': ['Styles', 'Format', 'Font', 'FontSize']}, {'name': 'colors', 'items': ['TextColor', 'BGColor']}, {'name': 'tools', 'items': ['Maximize', 'ShowBlocks']}, {'name': 'about', 'items': ['About', 'FilerImage', 'Youtube', 'Image']}, '/', {'name': 'yourcustomtools', 'items': ['Preview', 'Maximize']}], 'toolbar': 'YourCustomToolbarConfig', 'tabSpaces': 4, 'extraPlugins': 'uploadimage,div,autolink,autoembed,embedsemantic,widget,lineutils,clipboard,dialog,dialogui,elementspath,youtube,image2,wordcount', 'wordcount': {'showCharCount': True}, 'removePlugins': 'image', 'allowedContent': True}}
235CKEDITOR_UPLOAD_PATH = ''
236CONSTANCE_ADDITIONAL_FIELDS = {'email_field': [<class 'django.forms.fields.EmailField'>, {}], 'rich': [<class 'django.forms.fields.CharField'>, {'widget': <ckeditor.widgets.CKEditorWidget object at 0x7f09b7df4be0>}], 'image_field': [<class 'django.forms.fields.ImageField'>, {}]}
237CONSTANCE_BACKEND = 'constance.backends.database.DatabaseBackend'
238CONSTANCE_CONFIG = {'TINYPNG_KEY': '********************', 'ONE_CLICK_ENABLED': (True, 'Order one click enabled', <class 'bool'>), 'FILE_MAX_SIZE_UPLOAD': (8192, 'Max size of uploaded files in KB', <class 'int'>), 'USER_FACTOR': (1.0, 'User factor for A0, A1', <class 'float'>), 'ESPUTNIK_USER': ('', 'E-Sputnik user', <class 'str'>), 'ESPUTNIK_PASSWORD': '********************', 'SENDPULSE_PASSWORD_EVENT_URL': '********************', 'LIQPAY_EXPIRED_DAYS': (3, 'Expired days', <class 'int'>), 'LIQPAY_PUBLIC_KEY': '********************', 'LIQPAY_PRIVATE_KEY': '********************', 'LIQPAY_DEFAULT_CURRENCY': ('UAH', 'Default currency', <class 'str'>), 'LIQPAY_SANDBOX_MODE': (True, 'Sandbox mode enabled', <class 'bool'>), '_1C_USERNAME': ('username', 'Имя пользователя', <class 'str'>), '_1C_PASSWORD': '********************', 'ROZETKA_FEED_NAME': ('totis name', 'Название', <class 'str'>), 'ROZETKA_FEED_COMPANY': ('totis company', 'Company', <class 'str'>), 'ROZETKA_FEED_CURRENCY': ('UAH', 'Currency', <class 'str'>)}
239CONSTANCE_CONFIG_FIELDSETS = {'General': ('FILE_MAX_SIZE_UPLOAD', 'ONE_CLICK_ENABLED', 'USER_FACTOR'), 'TinyPNG': ('TINYPNG_KEY',), 'E-Sputnik': ('ESPUTNIK_USER', 'ESPUTNIK_PASSWORD'), 'Sendpulse': ('SENDPULSE_PASSWORD_EVENT_URL',), 'LiqPay Options': ('LIQPAY_EXPIRED_DAYS', 'LIQPAY_PUBLIC_KEY', 'LIQPAY_PRIVATE_KEY', 'LIQPAY_DEFAULT_CURRENCY', 'LIQPAY_SANDBOX_MODE'), 'Rozetka feed': ('ROZETKA_FEED_NAME', 'ROZETKA_FEED_COMPANY', 'ROZETKA_FEED_CURRENCY'), '1C Options': ('_1C_USERNAME', '_1C_PASSWORD')}
240CONSTANCE_DATABASE_CACHE_BACKEND = 'default'
241CSRF_COOKIE_AGE = 31449600
242CSRF_COOKIE_DOMAIN = None
243CSRF_COOKIE_HTTPONLY = False
244CSRF_COOKIE_NAME = 'csrftoken'
245CSRF_COOKIE_PATH = '/'
246CSRF_COOKIE_SAMESITE = 'Lax'
247CSRF_COOKIE_SECURE = True
248CSRF_FAILURE_VIEW = 'django.views.csrf.csrf_failure'
249CSRF_HEADER_NAME = 'HTTP_X_CSRFTOKEN'
250CSRF_TRUSTED_ORIGINS = []
251CSRF_USE_SESSIONS = False
252DATABASES = {'default': {'NAME': 'totis_2_db', 'USER': 'totis_2_db', 'PASSWORD': '********************', 'HOST': '127.0.0.1', 'PORT': 5432, 'ENGINE': 'django.db.backends.postgresql', 'CONN_MAX_AGE': 0, 'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'OPTIONS': {}, 'TIME_ZONE': None, 'TEST': {'CHARSET': None, 'COLLATION': None, 'NAME': None, 'MIRROR': None}}, 'old_site': {'NAME': 'totis_old_site_2', 'USER': 'totis_2_db', 'PASSWORD': '********************', 'HOST': '127.0.0.1', 'PORT': 5432, 'ENGINE': 'django.db.backends.postgresql', 'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'OPTIONS': {}, 'TIME_ZONE': None, 'TEST': {'CHARSET': None, 'COLLATION': None, 'NAME': None, 'MIRROR': None}}}
253DATABASE_ROUTERS = ['apps.old_site.router.OldSiteRouter', 'apps.old_site.router.DefaultRouter']
254DATA_UPLOAD_MAX_MEMORY_SIZE = 5242880999
255DATA_UPLOAD_MAX_NUMBER_FIELDS = 10000
256DATETIME_FORMAT = '%d.%m.%Y %H:%M:%S'
257DATETIME_INPUT_FORMATS = ['%d.%m.%Y %H:%M']
258DATE_FORMAT = '%d.%m.%Y'
259DATE_INPUT_FORMATS = ['%d.%m.%Y']
260DEBUG = True
261DEBUG_PROPAGATE_EXCEPTIONS = False
262DECIMAL_SEPARATOR = '.'
263DEFAULT_CHARSET = 'utf-8'
264DEFAULT_CONTENT_TYPE = 'text/html'
265DEFAULT_CURRENCY = 'EUR'
266DEFAULT_EXCEPTION_REPORTER_FILTER = 'django.views.debug.SafeExceptionReporterFilter'
267DEFAULT_EXTENSIONS = ['jinja2.ext.do', 'jinja2.ext.loopcontrols', 'jinja2.ext.with_', 'jinja2.ext.i18n', 'jinja2.ext.autoescape', 'django_jinja.builtins.extensions.DebugExtension', 'django_jinja.builtins.extensions.CsrfExtension', 'django_jinja.builtins.extensions.CacheExtension', 'django_jinja.builtins.extensions.TimezoneExtension', 'django_jinja.builtins.extensions.UrlsExtension', 'django_jinja.builtins.extensions.StaticFilesExtension', 'django_jinja.builtins.extensions.DjangoFiltersExtension']
268DEFAULT_FILE_STORAGE = 'django.core.files.storage.FileSystemStorage'
269DEFAULT_FROM_EMAIL = 'admin@admin.admin'
270DEFAULT_INDEX_TABLESPACE = ''
271DEFAULT_RENDERER_CLASSES = "('rest_framework.renderers.JSONRenderer', 'rest_framework.renderers.BrowsableAPIRenderer')"
272DEFAULT_TABLESPACE = ''
273DISALLOWED_USER_AGENTS = []
274EMAIL_BACKEND = 'des.backends.ConfiguredEmailBackend'
275EMAIL_CONFIG = {'EMAIL_FILE_PATH': '', 'EMAIL_HOST_USER': None, 'EMAIL_HOST_PASSWORD': '********************', 'EMAIL_HOST': '127.0.0.1', 'EMAIL_PORT': None, 'EMAIL_BACKEND': 'django.core.mail.backends.console.EmailBackend'}
276EMAIL_FILE_PATH = ''
277EMAIL_HOST = '127.0.0.1'
278EMAIL_HOST_PASSWORD = '********************'
279EMAIL_HOST_USER = None
280EMAIL_PORT = None
281EMAIL_SSL_CERTFILE = None
282EMAIL_SSL_KEYFILE = '********************'
283EMAIL_SUBJECT_PREFIX = '[Django] '
284EMAIL_TIMEOUT = None
285EMAIL_USE_LOCALTIME = False
286EMAIL_USE_SSL = False
287EMAIL_USE_TLS = False
288EXTERNAL_MAX_UPLOAD_SIZE = 5242880
289FILE_CHARSET = 'utf-8'
290FILE_UPLOAD_DIRECTORY_PERMISSIONS = None
291FILE_UPLOAD_HANDLERS = ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler']
292FILE_UPLOAD_MAX_MEMORY_SIZE = 2621440
293FILE_UPLOAD_PERMISSIONS = 493
294FILE_UPLOAD_TEMP_DIR = None
295FIRST_DAY_OF_WEEK = 0
296FIXTURE_DIRS = []
297FORCE_SCRIPT_NAME = None
298FORMAT_MODULE_PATH = None
299FORM_RENDERER = 'django.forms.renderers.DjangoTemplates'
300GUNICORN_PID = '/tmp/totis_2.pid'
301HOME_URL = '/'
302IGNORABLE_404_URLS = []
303INSTALLED_APPS = ['markup', 'shared', 'apps.attribute', 'apps.blog', 'apps.cart', 'apps.core', 'apps.comparison', 'apps.currencies', 'apps.event', 'apps.external', 'apps.feedback', 'apps.logger', 'apps.menu', 'apps.monobank_payparts', 'apps.novaposhta', 'apps.old_site', 'apps.order', 'apps.pages', 'apps.payments', 'apps.privatbank_payparts', 'apps.recipe', 'apps.review', 'apps.slider', 'apps.sales', 'apps.staff', 'apps.store', 'apps.tilda_wrapper', 'apps.organization', 'adminsortable2', 'cities_light', 'ckeditor', 'ckeditor_uploader', 'constance', 'constance.backends.database', 'codemirror2', 'des', 'django_better_admin_arrayfield', 'django_jinja', 'django_json_widget', 'django_filters', 'django_mptt_admin', 'import_export', 'jet', 'parler', 'postie', 'postie.integrations.tilda', 'rest_framework', 'rest_framework.authtoken', 'rest_auth', 'drf_yasg', 'mptt', 'modeltranslation', 'nested_admin', 'polymorphic', 'ok_redirects', 'robots', 'rosetta', 'seo', 'solo', 'social_django', 'script_pattern', 'versatileimagefield', 'vuejs_translate', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sites']
304INTERNAL_IPS = []
305JET_SIDE_MENU_COMPACT = True
306LANGUAGES = "(('ru', 'Русский'), ('uk', 'Украинский'))"
307LANGUAGES_BIDI = ['he', 'ar', 'fa', 'ur']
308LANGUAGE_CODE = 'ru'
309LANGUAGE_CODES = ['ru', 'uk']
310LANGUAGE_CODES_TRANSLATABLE = "(('ru', 'Ru'), ('uk', 'Uk'))"
311LANGUAGE_COOKIE_AGE = None
312LANGUAGE_COOKIE_DOMAIN = None
313LANGUAGE_COOKIE_NAME = 'django_language'
314LANGUAGE_COOKIE_PATH = '/'
315LOCALE_PATHS = "(PosixPath('/home/totis/totis/totis/server/app/locale'),)"
316LOGGING = {'version': 1, 'disable_existing_loggers': False, 'handlers': {'console': {'level': 'DEBUG', 'class': 'logging.StreamHandler'}, 'logfile': {'level': 'DEBUG', 'class': 'logging.FileHandler', 'filename': PosixPath('/home/totis/totis/totis/server/app/settings/default.py/../logfile.log')}}, 'root': {'level': 'INFO', 'handlers': ['console', 'logfile']}}
317LOGGING_CONFIG = 'logging.config.dictConfig'
318LOGIN_REDIRECT_URL = '/accounts/profile/'
319LOGIN_URL = '/accounts/login/'
320LOGOUT_REDIRECT_URL = None
321MANAGERS = []
322MEDIA_ROOT = PosixPath('/home/totis/totis/totis/server/app/uploads')
323MEDIA_URL = '/uploads/'
324MESSAGE_STORAGE = 'django.contrib.messages.storage.fallback.FallbackStorage'
325MIDDLEWARE = ['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', 'ok_redirects.middleware.RedirectMiddleware', 'social_django.middleware.SocialAuthExceptionMiddleware', 'seo.middleware.url_seo_middleware']
326MIGRATION_MODULES = {}
327MODELTRANSLATION_DEFAULT_LANGUAGE = 'ru'
328MODELTRANSLATION_ENABLE_FALLBACKS = True
329MODELTRANSLATION_FALLBACK_LANGUAGES = "('ru',)"
330MODELTRANSLATION_LANGUAGES = "('ru', 'uk')"
331MONTH_DAY_FORMAT = 'F j'
332NUMBER_GROUPING = 0
333OLD_PASSWORD_FIELD_ENABLED = '********************'
334PASSWORD_HASHERS = '********************'
335PASSWORD_RESET_TIMEOUT_DAYS = '********************'
336POSTIE_HTML_ADMIN_WIDGET = {'widget': 'CKEditorUploadingWidget', 'widget_module': 'ckeditor_uploader.widgets', 'attrs': {}}
337POSTIE_INSTANT_SEND = False
338POSTIE_TEMPLATE_CHOICES = Choices(('password_reset', 'password_reset', 'Восстановление пароля'), ('review_moderation', 'review_moderation', 'Review moderation'), ('review_approved', 'review_approved', 'Review approved'), ('catalog_sync_failed', 'catalog_sync_failed', 'Catalog sync failed'))
339POSTIE_TEMPLATE_CONTEXTS = {'password_reset': '********************', 'review_moderation': {'email': 'Адрес электронной почты', 'review': 'Review', 'url': 'Admin url'}, 'review_approved': {'review': 'Review'}, 'catalog_sync_failed': {'url': 'Task admin url'}}
340PREPEND_WWW = False
341PROJECT_APPS = ['markup', 'shared', 'apps.attribute', 'apps.blog', 'apps.cart', 'apps.core', 'apps.comparison', 'apps.currencies', 'apps.event', 'apps.external', 'apps.feedback', 'apps.logger', 'apps.menu', 'apps.monobank_payparts', 'apps.novaposhta', 'apps.old_site', 'apps.order', 'apps.pages', 'apps.payments', 'apps.privatbank_payparts', 'apps.recipe', 'apps.review', 'apps.slider', 'apps.sales', 'apps.staff', 'apps.store', 'apps.tilda_wrapper', 'apps.organization']
342REDIRECTS_IGNORE_PATH_PREFIXES = "('/api/v1/', '/uploads/', '/static/', '/vuejs-translate/', '/catalog/ajax/')"
343REDIRECTS_USE_PERMANENT_REDIRECT = False
344RESET_PASSWORD_EXPIRATION_DELTA = '********************'
345REST_AUTH_SERIALIZERS = {'PASSWORD_RESET_SERIALIZER': '********************'}
346REST_FRAMEWORK = {'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',), 'DEFAULT_PAGINATION_CLASS': 'shared.rest.pagination.LimitOffsetPagination', 'PAGE_SIZE': 12, 'DEFAULT_RENDERER_CLASSES': ('rest_framework.renderers.JSONRenderer', 'rest_framework.renderers.BrowsableAPIRenderer'), 'DEFAULT_PERMISSION_CLASSES': ['rest_framework.permissions.IsAuthenticated'], 'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema', 'EXCEPTION_HANDLER': 'shared.rest.exception_handler.custom_exception_handler3', 'DATE_FORMAT': '%d.%m.%Y', 'DATE_INPUT_FORMATS': ['%d.%m.%Y'], 'DATETIME_FORMAT': '%d.%m.%Y %H:%M:%S', 'DATETIME_INPUT_FORMATS': ['%d.%m.%Y %H:%M'], 'DEFAULT_METADATA_CLASS': 'shared.rest.metadata.RestMetadata', 'DEFAULT_VERSIONING_CLASS': 'rest_framework.versioning.URLPathVersioning'}
347REST_SESSION_LOGIN = True
348ROBOTS_SITEMAP_VIEW_NAME = 'sitemap'
349ROBOTS_USE_SCHEME_IN_HOST = True
350ROOT_URLCONF = 'app.urls'
351ROSETTA_LOGIN_URL = '/'
352ROSETTA_MESSAGES_PER_PAGE = 10
353ROSETTA_REQUIRES_AUTH = True
354ROSETTA_SHOW_AT_ADMIN_PANEL = True
355SECRET_KEY = '********************'
356SECURE_BROWSER_XSS_FILTER = False
357SECURE_CONTENT_TYPE_NOSNIFF = False
358SECURE_HSTS_INCLUDE_SUBDOMAINS = False
359SECURE_HSTS_PRELOAD = False
360SECURE_HSTS_SECONDS = 0
361SECURE_PROXY_SSL_HEADER = "('HTTP_X_FORWARDED_PROTO', 'https')"
362SECURE_REDIRECT_EXEMPT = []
363SECURE_SSL_HOST = None
364SECURE_SSL_REDIRECT = False
365SEO_DEBUG_MODE = True
366SEO_HTML_ADMIN_WIDGET = {'widget': 'CKEditorWidget', 'widget_path': 'ckeditor.widgets'}
367SEO_MODELS = ['staff.CompanyProfile', 'store.Product', 'store.Brand', 'store.ProductCategory', 'pages.Page', 'sales.Campaign', 'event.Event', 'blog.Post']
368SEO_USE_URL_SEO = True
369SERVER_EMAIL = 'root@localhost'
370SESSION_CACHE_ALIAS = 'default'
371SESSION_COOKIE_AGE = 1209600
372SESSION_COOKIE_DOMAIN = None
373SESSION_COOKIE_HTTPONLY = True
374SESSION_COOKIE_NAME = 'sessionid'
375SESSION_COOKIE_PATH = '/'
376SESSION_COOKIE_SAMESITE = 'Lax'
377SESSION_COOKIE_SECURE = True
378SESSION_ENGINE = 'django.contrib.sessions.backends.db'
379SESSION_EXPIRE_AT_BROWSER_CLOSE = False
380SESSION_FILE_PATH = None
381SESSION_SAVE_EVERY_REQUEST = False
382SESSION_SERIALIZER = 'django.contrib.sessions.serializers.JSONSerializer'
383SETTINGS_MODULE = 'app.settings'
384SHORT_DATETIME_FORMAT = 'm/d/Y P'
385SHORT_DATE_FORMAT = 'm/d/Y'
386SIGNING_BACKEND = 'django.core.signing.TimestampSigner'
387SILENCED_SYSTEM_CHECKS = []
388SITE_ID = 1
389SOCIAL_AUTH_FACEBOOK_EXTRA_DATA = [('name', 'name'), ('email', 'email'), ('picture', 'picture'), ('link', 'profile_url')]
390SOCIAL_AUTH_FACEBOOK_KEY = '********************'
391SOCIAL_AUTH_FACEBOOK_PROFILE_EXTRA_PARAMS = {'fields': 'id, name, email, picture.type(large), link'}
392SOCIAL_AUTH_FACEBOOK_SCOPE = ['email']
393SOCIAL_AUTH_FACEBOOK_SECRET = '********************'
394SOCIAL_AUTH_PIPELINE = "('social_core.pipeline.social_auth.social_details', 'social_core.pipeline.social_auth.social_uid', 'social_core.pipeline.social_auth.auth_allowed', 'social_core.pipeline.social_auth.social_user', 'social_core.pipeline.user.get_username', 'social_core.pipeline.social_auth.associate_by_email', 'social_core.pipeline.user.create_user', 'social_core.pipeline.social_auth.associate_user', 'social_core.pipeline.social_auth.load_extra_data')"
395SOLO_CACHE = 'default'
396STATICFILES_DIRS = []
397STATICFILES_FINDERS = ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder']
398STATICFILES_STORAGE = 'django.contrib.staticfiles.storage.StaticFilesStorage'
399STATIC_ROOT = PosixPath('/home/totis/totis/totis/server/app/static')
400STATIC_URL = '/static/'
401TEMPLATES = [{'BACKEND': 'django_jinja.backend.Jinja2', 'NAME': 'jinja2', 'APP_DIRS': True, 'DIRS': [], 'OPTIONS': {'environment': 'shared.env.jinja2.environment', 'match_extension': '.jinja', 'newstyle_gettext': True, 'auto_reload': True, 'undefined': <class 'jinja2.runtime.Undefined'>, 'debug': True, 'filters': {}, 'globals': {}, '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', 'social_django.context_processors.login_redirect', 'constance.context_processors.config'], 'extensions': ['jinja2.ext.do', 'jinja2.ext.loopcontrols', 'jinja2.ext.with_', 'jinja2.ext.i18n', 'jinja2.ext.autoescape', 'django_jinja.builtins.extensions.DebugExtension', 'django_jinja.builtins.extensions.CsrfExtension', 'django_jinja.builtins.extensions.CacheExtension', 'django_jinja.builtins.extensions.TimezoneExtension', 'django_jinja.builtins.extensions.UrlsExtension', 'django_jinja.builtins.extensions.StaticFilesExtension', 'django_jinja.builtins.extensions.DjangoFiltersExtension'], 'bytecode_cache': {'name': 'default', 'backend': 'django_jinja.cache.BytecodeCache', 'enabled': True}}}, {'DIRS': [], 'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'OPTIONS': {'context_processors': ['django.template.context_processors.media', 'django.template.context_processors.static', 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.messages.context_processors.messages', 'django.contrib.auth.context_processors.auth', 'social_django.context_processors.login_redirect']}}]
402TEST_NON_SERIALIZED_APPS = []
403TEST_RUNNER = 'django.test.runner.DiscoverRunner'
404THOUSAND_SEPARATOR = ','
405TIME_FORMAT = 'P'
406TIME_INPUT_FORMATS = ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M']
407TIME_ZONE = 'UTC'
408USE_I18N = True
409USE_L10N = True
410USE_THOUSAND_SEPARATOR = False
411USE_TZ = True
412USE_X_FORWARDED_HOST = False
413USE_X_FORWARDED_PORT = False
414VERSATILEIMAGEFIELD_RENDITION_KEY_SETS = '********************'
415VERSATILEIMAGEFIELD_SETTINGS = {'jpeg_resize_quality': 90, 'progressive_jpeg': True}
416WSGI_APPLICATION = 'app.wsgi.application'
417X_FRAME_OPTIONS = 'SAMEORIGIN'
418YEAR_MONTH_FORMAT = 'F Y'
419
420
421You're seeing this error because you have DEBUG = True in your
422Django settings file. Change that to False, and Django will
423display a standard page generated by the handler for this status code.
424
425