Kaniwani / kw-backend

Server, Database, and Backend functionality for KaniWani
https://kaniwani.com
72 stars 10 forks source link

Unlock level = 500 error #341

Closed DJTB closed 6 years ago

DJTB commented 6 years ago

On Tadgh account on staging. Clicked lock levels 7, 6, 5, 4 in series. Clicked unlock level 4.

MultipleObjectsReturned at /api/v1/level/4/unlock/
get() returned more than one Vocabulary -- it returned 2!

Request Method: POST
Request URL: http://127.0.0.1:8001/api/v1/level/4/unlock/
Django Version: 1.11.3
Python Executable: /opt/venvs/KaniWaniEnv/bin/python3
Python Version: 3.4.3
Python Path: ['/opt/venvs/KaniWaniEnv/current', '/opt/venvs/KaniWaniEnv/bin', '/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/newrelic/bootstrap', '/opt/venvs/KaniWaniEnv/lib/python3.4', '/opt/venvs/KaniWaniEnv/lib/python3.4/plat-x86_64-linux-gnu', '/opt/venvs/KaniWaniEnv/lib/python3.4/lib-dynload', '/usr/lib/python3.4', '/usr/lib/python3.4/plat-x86_64-linux-gnu', '/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages', '/opt/venvs/KaniWaniEnv/releases/1511113994']
Server time: Sun, 19 Nov 2017 19:45:02 -0500
Installed Applications:
('django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.humanize',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.sites',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django_celery_beat',
 'crispy_forms',
 'rest_framework',
 'lineage',
 'kw_webapp.apps.KaniwaniConfig',
 'debug_toolbar',
 'rest_framework.authtoken',
 'corsheaders',
 'djoser')
Installed Middleware:
['corsheaders.middleware.CorsMiddleware',
 '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.clickjacking.XFrameOptionsMiddleware',
 'django.middleware.gzip.GZipMiddleware',
 'debug_toolbar.middleware.DebugToolbarMiddleware',
 'kw_webapp.middleware.SetLastVisitMiddleware',
 'KW.LoggingMiddleware.ExceptionLoggingMiddleware']

Traceback:  

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/core/handlers/exception.py" in inner
  41.             response = get_response(request)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/core/handlers/base.py" in _get_response
  187.                 response = self.process_exception_by_middleware(e, request)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/core/handlers/base.py" in _get_response
  185.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/newrelic/hooks/framework_django.py" in wrapper
  527.                 return wrapped(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/views/decorators/csrf.py" in wrapped_view
  58.         return view_func(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/rest_framework/viewsets.py" in view
  86.             return self.dispatch(request, *args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/newrelic/hooks/component_djangorestframework.py" in _nr_wrapper_APIView_dispatch_
  38.         return wrapped(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/rest_framework/views.py" in dispatch
  489.             response = self.handle_exception(exc)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/rest_framework/views.py" in handle_exception
  449.             self.raise_uncaught_exception(exc)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/rest_framework/views.py" in dispatch
  486.             response = handler(request, *args, **kwargs)

File "/opt/venvs/KaniWaniEnv/current/api/views.py" in unlock
  108.         unlocked_this_request, total_unlocked, locked = unlock_eligible_vocab_from_levels(user, requested_level)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/celery/local.py" in __call__
  191.         return self._get_current_object()(*a, **kw)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/newrelic/hooks/application_celery.py" in wrapper
  80.                 return wrapped(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/celery/app/task.py" in __call__
  380.             return self.run(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/current/kw_webapp/tasks.py" in unlock_eligible_vocab_from_levels
  201.         unlocked_this_request, total_unlocked, locked = process_vocabulary_response_for_unlock(user, response)

File "/opt/venvs/KaniWaniEnv/current/kw_webapp/tasks.py" in process_vocabulary_response_for_unlock
  425.         vocab, is_new = get_or_create_vocab_by_json(vocabulary_json)

File "/opt/venvs/KaniWaniEnv/current/kw_webapp/tasks.py" in get_or_create_vocab_by_json
  325.         vocab = get_vocab_by_kanji(vocab_json['character'])

File "/opt/venvs/KaniWaniEnv/current/kw_webapp/tasks.py" in get_vocab_by_kanji
  92.         v = Vocabulary.objects.get(readings__character=kanji)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/db/models/manager.py" in manager_method
  85.                 return getattr(self.get_queryset(), name)(*args, **kwargs)

File "/opt/venvs/KaniWaniEnv/lib/python3.4/site-packages/django/db/models/query.py" in get
  384.             (self.model._meta.object_name, num)

Exception Type: MultipleObjectsReturned at /api/v1/level/4/unlock/
Exception Value: get() returned more than one Vocabulary -- it returned 2!
Request information:
USER: Tadgh

GET: No GET data

POST: No POST data

FILES: No FILES data

COOKIES: No cookie data

META:
CONTENT_LENGTH = '2'
CONTENT_TYPE = 'application/json'
HTTP_ACCEPT = 'application/json'
HTTP_ACCEPT_ENCODING = 'gzip, deflate, br'
HTTP_ACCEPT_LANGUAGE = 'en-US,en;q=0.9,ja;q=0.8,fr;q=0.7'
HTTP_AUTHORIZATION = 'JWT eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoyLCJlbWFpbCI6ImdnZ0BnbWFpbC5jb20iLCJleHAiOjE1MTExMzgzMTQsInVzZXJuYW1lIjoiVGFkZ2gifQ.uUTmMB3lgJjjUqGZhB_0wzeMCQBdZaEulkA_VG_WMXw'
HTTP_CONNECTION = 'close'
HTTP_DNT = '1'
HTTP_HOST = '127.0.0.1:8001'
HTTP_ORIGIN = 'http://localhost:3000'
HTTP_REFERER = 'http://localhost:3000/vocabulary/levels'
HTTP_USER_AGENT = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36'
HTTP_X_FORWARDED_HOST = 'staging.kaniwani.com'
HTTP_X_REAL_IP = '110.33.161.161'
PATH_INFO = '/api/v1/level/4/unlock/'
QUERY_STRING = ''
RAW_URI = '/api/v1/level/4/unlock/'
REMOTE_ADDR = '127.0.0.1'
REMOTE_PORT = '43992'
REQUEST_METHOD = 'POST'
SCRIPT_NAME = ''
SERVER_NAME = '127.0.0.1'
SERVER_PORT = '8001'
SERVER_PROTOCOL = 'HTTP/1.0'
SERVER_SOFTWARE = 'gunicorn/19.7.1'
gunicorn.socket = <socket.socket fd=21, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 8001), raddr=('127.0.0.1', 43992)>
wsgi.errors = <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f8fbdc49ba8>
wsgi.file_wrapper = ''
wsgi.input = <newrelic.api.web_transaction._WSGIInputWrapper object at 0x7f8fbd850ba8>
wsgi.multiprocess = True
wsgi.multithread = False
wsgi.run_once = False
wsgi.url_scheme = 'http'
wsgi.version = 

Settings:
Using settings module KW.settings
ABSOLUTE_URL_OVERRIDES = {}
ADMINS = []
ALLOWED_HOSTS = ['127.0.0.1', 'localhost', 'www.kaniwani.com', '.kaniwani.com']
APPEND_SLASH = True
AUTHENTICATION_BACKENDS = ['kw_webapp.backends.EmailOrUsernameAuthenticationBackend', 'django.contrib.auth.backends.ModelBackend']
AUTH_PASSWORD_VALIDATORS = '********************'
AUTH_USER_MODEL = 'auth.User'
BASE_DIR = '/opt/venvs/KaniWaniEnv/current'
CACHES = {'default': {'LOCATION': 'localhost:6379', 'BACKEND': 'redis_cache.RedisCache'}}
CACHE_MIDDLEWARE_ALIAS = 'default'
CACHE_MIDDLEWARE_KEY_PREFIX = '********************'
CACHE_MIDDLEWARE_SECONDS = 600
CELERY_ACCEPT_CONTENT = ['json']
CELERY_BEAT_SCHEDULE = {'sync_vocab_db_with_wk': {'schedule': datetime.timedelta(0, 10800), 'task': 'kw_webapp.tasks.repopulate'}, 'update_users_unlocked_vocab': {'schedule': datetime.timedelta(0, 43200), 'task': 'kw_webapp.tasks.sync_all_users_to_wk'}, 'all_user_srs_every_hour': {'schedule': datetime.timedelta(0, 900), 'task': 'kw_webapp.tasks.all_srs'}}
CELERY_BROKER_URL = 'redis://localhost:6379/0'
CELERY_RESULTS_BACKEND = 'redis://localhost:6379/0'
CELERY_RESULTS_SERIALIZER = 'json'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'
CELERY_TASK_SERIALIZER = 'json'
CELERY_TIMEZONE = 'America/New_York'
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_WHITELIST = 
CRISPY_TEMPLATE_PACK = 'bootstrap3'
CSRF_COOKIE_AGE = 31449600
CSRF_COOKIE_DOMAIN = None
CSRF_COOKIE_HTTPONLY = False
CSRF_COOKIE_NAME = 'csrftoken'
CSRF_COOKIE_PATH = '/'
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': {'ENGINE': 'django.db.backends.postgresql', 'AUTOCOMMIT': True, 'OPTIONS': {}, 'CONN_MAX_AGE': 0, 'PASSWORD': '********************', 'TIME_ZONE': None, 'ATOMIC_REQUESTS': False, 'HOST': 'localhost', 'USER': 'kwadmin', 'TEST': {'COLLATION': None, 'CHARSET': None, 'NAME': None, 'MIRROR': None}, 'NAME': 'KaniWaniDB', 'PORT': ''}}
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 = 'gary@kaniwani.com'
DEFAULT_INDEX_TABLESPACE = ''
DEFAULT_TABLESPACE = ''
DISALLOWED_USER_AGENTS = []
DJOSER = {'SERIALIZERS': {'user_registration': 'api.serializers.RegistrationSerializer'}, 'PASSWORD_RESET_CONFIRM_URL': '********************'}
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_HOST_PASSWORD = '********************'
EMAIL_HOST_USER = 'gary@kaniwani.com'
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
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 = 
INTERNAL_IPS = '127.0.0.1'
JWT_AUTH = {'JWT_VERIFY_EXPIRATION': False}
LANGUAGES = [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('cs', 'Czech'), ('cy', 'Welsh'), ('da', 'Danish'), ('de', 'German'), ('dsb', 'Lower Sorbian'), ('el', 'Greek'), ('en', 'English'), ('en-au', 'Australian English'), ('en-gb', 'British English'), ('eo', 'Esperanto'), ('es', 'Spanish'), ('es-ar', 'Argentinian Spanish'), ('es-co', 'Colombian Spanish'), ('es-mx', 'Mexican Spanish'), ('es-ni', 'Nicaraguan Spanish'), ('es-ve', 'Venezuelan Spanish'), ('et', 'Estonian'), ('eu', 'Basque'), ('fa', 'Persian'), ('fi', 'Finnish'), ('fr', 'French'), ('fy', 'Frisian'), ('ga', 'Irish'), ('gd', 'Scottish Gaelic'), ('gl', 'Galician'), ('he', 'Hebrew'), ('hi', 'Hindi'), ('hr', 'Croatian'), ('hsb', 'Upper Sorbian'), ('hu', 'Hungarian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('th', 'Thai'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')]
LANGUAGES_BIDI = ['he', 'ar', 'fa', 'ur']
LANGUAGE_CODE = 'en-us'
LANGUAGE_COOKIE_AGE = None
LANGUAGE_COOKIE_DOMAIN = None
LANGUAGE_COOKIE_NAME = 'django_language'
LANGUAGE_COOKIE_PATH = '/'
LINEAGE_ANCESTOR_PHRASE = '-active'
LOCALE_PATHS = []
LOGGING = {'filters': {'require_debug_true': {'()': 'django.utils.log.RequireDebugTrue'}}, 'handlers': {'console': {'class': 'logging.StreamHandler', 'level': 'INFO', 'filters': ['require_debug_true'], 'formatter': 'simple'}, 'review_data': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'INFO', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/review_data.log', 'when': 'midnight', 'formatter': 'time_only'}, 'models': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'DEBUG', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/models.log', 'when': 'midnight', 'formatter': 'verbose'}, 'sporadic_tasks': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'INFO', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/sporadic_tasks.log', 'when': 'midnight', 'formatter': 'verbose'}, 'errors': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'ERROR', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/errors.log', 'when': 'midnight', 'formatter': 'verbose'}, 'views': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'DEBUG', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/views.log', 'when': 'midnight', 'formatter': 'verbose'}, 'tasks': {'class': 'logging.handlers.TimedRotatingFileHandler', 'level': 'INFO', 'filename': '/opt/venvs/KaniWaniEnv/current/logs/tasks.log', 'when': 'midnight', 'formatter': 'verbose'}}, 'loggers': {'kw.review_data': {'handlers': ['review_data', 'console'], 'level': 'DEBUG', 'propagate': True}, 'kw.views': {'handlers': ['views', 'errors', 'console'], 'level': 'DEBUG', 'propagate': True}, 'kw.models': {'handlers': ['models', 'errors', 'console'], 'level': 'DEBUG', 'propagate': True}, 'kw.tasks': {'handlers': ['tasks', 'errors', 'console'], 'level': 'DEBUG', 'propagate': True}, 'kw.db_repopulator': {'handlers': ['sporadic_tasks', 'errors', 'console'], 'level': 'DEBUG', 'propagate': True}}, 'disable_existing_loggers': True, 'formatters': {'verbose': {'format': '%(levelname)s---%(asctime)s---%(module)s : %(message)s'}, 'simple': {'format': '%(levelname)s %(message)s'}, 'time_only': {'format': '%(asctime)s---%(message)s'}}, 'version': 1}
LOGGING_CONFIG = 'logging.config.dictConfig'
LOGIN_REDIRECT_URL = '/kw/'
LOGIN_URL = '/auth/login/'
LOGOUT_REDIRECT_URL = None
MANAGERS = [('Gary', 'tadgh@cs.toronto.edu'), ('Duncan', 'duncan.bay@gmail.com')]
MEDIA_ROOT = ''
MEDIA_URL = ''
MESSAGE_STORAGE = 'django.contrib.messages.storage.fallback.FallbackStorage'
MIDDLEWARE = ['corsheaders.middleware.CorsMiddleware', '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.clickjacking.XFrameOptionsMiddleware', 'django.middleware.gzip.GZipMiddleware', 'debug_toolbar.middleware.DebugToolbarMiddleware', 'kw_webapp.middleware.SetLastVisitMiddleware', 'KW.LoggingMiddleware.ExceptionLoggingMiddleware']
MIDDLEWARE_CLASSES = ['django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware']
MIGRATION_MODULES = {}
MONTH_DAY_FORMAT = 'F j'
MY_TIME_ZONE = 'America/New_York'
NUMBER_GROUPING = 0
PASSWORD_HASHERS = '********************'
PASSWORD_RESET_TIMEOUT_DAYS = '********************'
PREPEND_WWW = False
REST_FRAMEWORK = {'DEFAULT_AUTHENTICATION_CLASSES': ['rest_framework_jwt.authentication.JSONWebTokenAuthentication', 'rest_framework.authentication.SessionAuthentication'], 'PAGE_SIZE': 100, 'DEFAULT_PERMISSION_CLASSES': ['rest_framework.permissions.IsAuthenticatedOrReadOnly'], 'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',), 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.LimitOffsetPagination'}
ROOT_URLCONF = 'KW.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_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 = 'KW.settings'
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 = '/opt/venvs/KaniWaniEnv/current/_front-end/dist/assets'
STATICFILES_FINDERS = ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder']
STATICFILES_STORAGE = 'django.contrib.staticfiles.storage.StaticFilesStorage'
STATIC_ROOT = '/var/www/kaniwani.com/static'
STATIC_URL = '/static/'
TEMPLATES = [{'APP_DIRS': True, 'OPTIONS': {'context_processors': ['django.contrib.auth.context_processors.auth', 'KW.preprocessors.review_count_preprocessor', 'django.template.context_processors.request', 'django.contrib.messages.context_processors.messages'], 'debug': True}, 'DIRS': ['/opt/venvs/KaniWaniEnv/current/templates', '/opt/venvs/KaniWaniEnv/current/kw_webapp/templates/kw_webapp'], 'BACKEND': 'django.template.backends.django.DjangoTemplates'}]
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 = 'America/New_York'
USE_ETAGS = False
USE_I18N = True
USE_L10N = True
USE_THOUSAND_SEPARATOR = False
USE_TZ = True
USE_X_FORWARDED_HOST = False
USE_X_FORWARDED_PORT = False
WSGI_APPLICATION = 'KW.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.
tadgh commented 6 years ago

This was resolved in 2bd088ddd1daf1039ee065b70afc62db870a48fe