Closed DJTB closed 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.
This was resolved in 2bd088ddd1daf1039ee065b70afc62db870a48fe
On Tadgh account on staging. Clicked lock levels 7, 6, 5, 4 in series. Clicked unlock level 4.