Reverse for 'api-map' not found. 'api-map' is not a valid view function or pattern name.
Request Method: | GET |
---|---|
Request URL: | https://staff.queercraft.net/players/-map/ |
Django Version: | 3.2.8 |
Exception Type: | NoReverseMatch |
Exception Value: | Reverse for 'api-map' not found. 'api-map' is not a valid view function or pattern name. |
Exception Location: | /var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/urls/resolvers.py, line 694, in _reverse_with_prefix |
Python Executable: | /var/www/.conda/envs/staffapp/bin/uwsgi |
Python Version: | 3.8.8 |
Python Path: | ['.', '', '/var/www/.conda/envs/staffapp/lib/python38.zip', '/var/www/.conda/envs/staffapp/lib/python3.8', '/var/www/.conda/envs/staffapp/lib/python3.8/lib-dynload', '/var/www/.conda/envs/staffapp/lib/python3.8/site-packages'] |
Server time: | Fri, 29 Mar 2024 09:49:47 -0500 |
In template /var/www/qcmodapp/players/templates/players/map.html
, error at line 35
25 | </style> |
---|---|
26 | <script src="https://code.jquery.com/jquery-1.10.1.min.js"></script> |
27 | <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key=AIzaSyA5uXQvmB5bCjAWyk5Al_SZ2gF31q-z7fY"></script> |
28 | <script type="text/javascript" src="{% static 'scripts/markerclusterer.js' %}"></script> |
29 | <script type="text/javascript"> |
30 | var playerData; |
31 | function initialize() { |
32 | var map = new google.maps.Map(document.getElementById("map"), {center:new google.maps.LatLng(40, -75), zoom:3}); |
33 | var markers = []; |
34 | $.getJSON( |
35 | "{% url 'api-map' %}", {}, |
36 | function(data) { |
37 | playerData = data; |
38 | for (var i = 0; i < data.length; i++) { |
39 | var player = data[i]; |
40 | markers.push(new google.maps.Marker({ |
41 | map: map, |
42 | title: player.loc, |
43 | position: new google.maps.LatLng(player.lat, player.lon) |
44 | })); |
45 | google.maps.event.addListener(markers[i], "click", function() { |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/core/handlers/exception.py
, line 47, in inner
response = await sync_to_async(response_for_exception, thread_sensitive=False)(request, exc)
return response
return inner
else:
@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 | NoReverseMatch("Reverse for 'api-map' not found. 'api-map' is not a valid view function or pattern name.") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7fe024c57310>> |
request | <WSGIRequest: GET '/players/-map/'> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/core/handlers/base.py
, line 204, in _get_response
response,
middleware_method,
name='%s.process_template_response' % (
middleware_method.__self__.__class__.__name__,
)
)
try:
response = response.render()…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
return response
Variable | Value |
---|---|
callback | <function PlayerMap at 0x7fe024816ca0> |
callback_args | () |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7fe0249d19a0>> |
request | <WSGIRequest: GET '/players/-map/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7fe024c57310> |
wrapped_callback | <function PlayerMap at 0x7fe024816ca0> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/response.py
, line 105, in render
If the content has already been rendered, this is a no-op.
Return the baked response instance.
"""
retval = self
if not self._is_rendered:
self.content = self.rendered_content…
for post_callback in self._post_render_callbacks:
newretval = post_callback(retval)
if newretval is not None:
retval = newretval
return retval
Variable | Value |
---|---|
retval | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
self | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/response.py
, line 83, in rendered_content
This *does not* set the final content of the response. To set the
response content, you must either call render(), or set the
content explicitly using the value of this property.
"""
template = self.resolve_template(self.template_name)
context = self.resolve_context(self.context_data)
return template.render(context, self._request)…
def add_post_render_callback(self, callback):
"""Add a new post-rendering callback.
If the response has already been rendered,
invoke the callback immediately.
Variable | Value |
---|---|
context | {'view': <players.views.PlayerMap object at 0x7fe0241e3700>} |
self | <TemplateResponse status_code=200, "text/html; charset=utf-8"> |
template | <django.template.backends.django.Template object at 0x7fe0241e9550> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/backends/django.py
, line 61, in render
@property
def origin(self):
return self.template.origin
def render(self, context=None, request=None):
context = make_context(context, request, autoescape=self.backend.engine.autoescape)
try:
return self.template.render(context)…
except TemplateDoesNotExist as exc:
reraise(exc, self.backend)
def copy_exception(exc, backend=None):
"""
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
request | <WSGIRequest: GET '/players/-map/'> |
self | <django.template.backends.django.Template object at 0x7fe0241e9550> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/base.py
, line 170, in render
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
context.template_name = self.name
return self._render(context)…
else:
return self._render(context)
def compile_nodelist(self):
"""
Parse and compile the template source into a nodelist. If debug
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
self | <django.template.base.Template object at 0x7fe0241e9310> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/base.py
, line 162, in _render
self.nodelist = self.compile_nodelist()
def __iter__(self):
for node in self.nodelist:
yield from node
def _render(self, context):
return self.nodelist.render(context)…
def render(self, context):
"Display stage -- can be called many times"
with context.render_context.push_state(self):
if context.template is None:
with context.bind_template(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
self | <django.template.base.Template object at 0x7fe0241e9310> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/base.py
, line 938, in render
# extend_nodelist().
contains_nontext = False
def render(self, context):
bits = []
for node in self:
if isinstance(node, Node):
bit = node.render_annotated(context)…
else:
bit = node
bits.append(str(bit))
return mark_safe(''.join(bits))
def get_nodes_by_type(self, nodetype):
Variable | Value |
---|---|
bit | ('"></script>\n' '\t\t<script type="text/javascript">\n' '\t\t\tvar playerData;\n' '\t\t\tfunction initialize() {\n' '\t\t\t\tvar map = new google.maps.Map(document.getElementById("map"), ' '{center:new google.maps.LatLng(40, -75), zoom:3});\n' '\t\t\t\tvar markers = [];\n' '\t\t\t\t$.getJSON(\n' '\t\t\t\t\t"') |
bits | ['', '\n' '<!doctype html>\n' '\n' '<html>\n' '\t<head>\n' '\t\t<meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>\n' '\t\t<style type="text/css">\n' '\t\t\thtml, body {\n' '\t\t\t\theight: 100%;\n' '\t\t\t\tmargin: 0px;\n' '\t\t\t\tpadding: 0px;\n' '\t\t\t}\n' '\t\t\t\n' '\t\t\t#map {\n' '\t\t\t\twidth: 100%;\n' '\t\t\t\theight: 100%;\n' '\t\t\t}\n' '\t\t\t\n' '\t\t\t#search {\n' '\t\t\t\tposition: absolute;\n' '\t\t\t\tz-index: 1;\n' '\t\t\t\tbottom: 3px;\n' '\t\t\t\tleft: 70px;\n' '\t\t\t}\n' '\t\t</style>\n' '\t\t<script src="https://code.jquery.com/jquery-1.10.1.min.js"></script>\n' '\t\t<script type="text/javascript" ' 'src="https://maps.googleapis.com/maps/api/js?key=AIzaSyA5uXQvmB5bCjAWyk5Al_SZ2gF31q-z7fY"></script>\n' '\t\t<script type="text/javascript" src="', '/static/scripts/markerclusterer.js', '"></script>\n' '\t\t<script type="text/javascript">\n' '\t\t\tvar playerData;\n' '\t\t\tfunction initialize() {\n' '\t\t\t\tvar map = new google.maps.Map(document.getElementById("map"), ' '{center:new google.maps.LatLng(40, -75), zoom:3});\n' '\t\t\t\tvar markers = [];\n' '\t\t\t\t$.getJSON(\n' '\t\t\t\t\t"'] |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
node | <django.template.defaulttags.URLNode object at 0x7fe02413f6a0> |
self | [<django.template.defaulttags.LoadNode object at 0x7fe02413ff70>, <TextNode: '\n<!doctype html>\n\n<html>\n'>, <django.templatetags.static.StaticNode object at 0x7fe02413fac0>, <TextNode: '"></script>\n\t\t<script typ'>, <django.template.defaulttags.URLNode object at 0x7fe02413f6a0>, <TextNode: '", {},\n\t\t\t\t\tfunction(data'>, <django.templatetags.static.StaticNode object at 0x7fe02413f100>, <TextNode: '" + "m"});\n\t\t\t\t\t}\n\t\t\t\t);\n'>] |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/base.py
, line 905, in render_annotated
"""
Render the node. If debug is True and an exception occurs during
rendering, the exception is annotated with contextual line information
where it occurred in the template. For internal usage this method is
preferred over using the render method directly.
"""
try:
return self.render(context)…
except Exception as e:
if context.template.engine.debug and not hasattr(e, 'template_debug'):
e.template_debug = context.render_context.template.get_exception_info(e, self.token)
raise
def __iter__(self):
Variable | Value |
---|---|
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
self | <django.template.defaulttags.URLNode object at 0x7fe02413f6a0> |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/template/defaulttags.py
, line 446, in render
current_app = context.request.resolver_match.namespace
except AttributeError:
current_app = None
# Try to look up the URL. If it fails, raise NoReverseMatch unless the
# {% url ... as var %} construct is used, in which case return nothing.
url = ''
try:
url = reverse(view_name, args=args, kwargs=kwargs, current_app=current_app)…
except NoReverseMatch:
if self.asvar is None:
raise
if self.asvar:
context[self.asvar] = url
Variable | Value |
---|---|
NoReverseMatch | <class 'django.urls.exceptions.NoReverseMatch'> |
args | [] |
context | [{'True': True, 'False': False, 'None': None}, {}, {}, {'view': <players.views.PlayerMap object at 0x7fe0241e3700>}] |
current_app | 'players' |
kwargs | {} |
reverse | <function reverse at 0x7fe02661f1f0> |
self | <django.template.defaulttags.URLNode object at 0x7fe02413f6a0> |
url | '' |
view_name | 'api-map' |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/urls/base.py
, line 86, in reverse
(key, ':'.join(resolved_path))
)
else:
raise NoReverseMatch("%s is not a registered namespace" % key)
if ns_pattern:
resolver = get_ns_resolver(ns_pattern, resolver, tuple(ns_converters.items()))
return resolver._reverse_with_prefix(view, prefix, *args, **kwargs)…
reverse_lazy = lazy(reverse, str)
def clear_url_caches():
Variable | Value |
---|---|
args | [] |
current_app | 'players' |
current_path | ['players'] |
kwargs | {} |
ns_converters | {} |
ns_pattern | '' |
path | [] |
prefix | '/' |
resolved_path | [] |
resolver | <URLResolver 'qcmodapp.urls' (None:None) '^/'> |
urlconf | 'qcmodapp.urls' |
view | 'api-map' |
viewname | 'api-map' |
/var/www/.conda/envs/staffapp/lib/python3.8/site-packages/django/urls/resolvers.py
, line 694, in _reverse_with_prefix
(lookup_view_s, arg_msg, len(patterns), patterns)
)
else:
msg = (
"Reverse for '%(view)s' not found. '%(view)s' is not "
"a valid view function or pattern name." % {'view': lookup_view_s}
)
raise NoReverseMatch(msg)…
Variable | Value |
---|---|
_prefix | '/' |
args | () |
kwargs | {} |
lookup_view | 'api-map' |
lookup_view_s | 'api-map' |
m | None |
msg | ("Reverse for 'api-map' not found. 'api-map' is not a valid view function or " 'pattern name.') |
n | None |
patterns | [] |
possibilities | [] |
self | <URLResolver 'qcmodapp.urls' (None:None) '^/'> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
CONTENT_LENGTH | '' |
CONTENT_TYPE | '' |
DOCUMENT_ROOT | '/usr/share/nginx/html' |
HTTPS | 'on' |
HTTP_ACCEPT | '*/*' |
HTTP_ACCEPT_ENCODING | 'gzip, br' |
HTTP_CDN_LOOP | 'cloudflare' |
HTTP_CF_CONNECTING_IP | '3.231.3.140' |
HTTP_CF_IPCOUNTRY | 'US' |
HTTP_CF_RAY | '86c0ab296e6c0846-IAD' |
HTTP_CF_VISITOR | '{"scheme":"https"}' |
HTTP_CONNECTION | 'Keep-Alive' |
HTTP_HOST | 'staff.queercraft.net' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '3.231.3.140' |
HTTP_X_FORWARDED_PROTO | 'https' |
PATH_INFO | '/players/-map/' |
QUERY_STRING | '' |
REMOTE_ADDR | '172.70.38.123' |
REMOTE_PORT | '62938' |
REQUEST_METHOD | 'GET' |
REQUEST_SCHEME | 'https' |
REQUEST_URI | '/players/-map/' |
SCRIPT_NAME | '' |
SERVER_NAME | 'staff.queercraft.net' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.1' |
uwsgi.node | b'Queercraft-01' |
uwsgi.version | b'2.0.19.1' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.file_wrapper | <built-in function uwsgi_sendfile> |
wsgi.input | <uwsgi._Input object at 0x7fe0240ad970> |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
qcmodapp.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADAPTOR_INPLACEEDIT_EDIT | 'qcmodapp.permissions.ModelEditInline' |
ADMINS | [] |
ALLOWED_HOSTS | ['.queercraft.net', '.queercraft.net.', 'localhost'] |
ANONYMOUS_USER_ID | -1 |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ('django.contrib.auth.backends.ModelBackend', 'guardian.backends.ObjectPermissionBackend') |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '.' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'lax' |
CSRF_COOKIE_SECURE | True |
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.mysql', 'HOST': '127.0.0.1', 'NAME': 'modapp', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '3306', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'qcmodapp'}} |
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', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M'] |
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_AUTO_FIELD | 'django.db.models.AutoField' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_EXCEPTION_REPORTER | 'django.views.debug.ExceptionReporter' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_HASHING_ALGORITHM | 'sha256' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_INFO | 'Procedures' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
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 | False |
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 | 420 |
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 | [] |
INPLACEEDIT_EVENT | 'click' |
INSTALLED_APPS | ['players', 'discipline', 'staff', 'info', 'extras', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'rest_framework', 'guardian'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ar-dz', 'Algerian 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'), ('hy', 'Armenian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('ig', 'Igbo'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('ky', 'Kyrgyz'), ('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'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'en-us' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {'disable_existing_loggers': False, 'formatters': {'verbose': {'datefmt': '%d/%m/%Y %H:%M:%S', 'format': '[%(asctime)s][%(name)s][%(levelname)s] ' '%(user)s: %(message)s'}}, 'handlers': {'file': {'class': 'logging.handlers.TimedRotatingFileHandler', 'filename': './qcmodapp/logs/modapp.log', 'formatter': 'verbose', 'interval': 14, 'level': 'DEBUG', 'utc': True, 'when': 'D'}}, 'loggers': {'qcmodapp': {'handlers': ('file',), 'level': 'DEBUG'}}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_EXEMPT_URLS | ('/login/', '/census/', '/census_thanks/', '/debug/', '/players/-map/', '/api/players/-map/') |
LOGIN_REDIRECT_URL | '/' |
LOGIN_URL | '/login/' |
LOGOUT_REDIRECT_URL | None |
LOGOUT_URL | '/logout/' |
MANAGERS | [] |
MEDIA_ROOT | './qcmodapp/media' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['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', 'staff.middleware.LoginRequiredMiddleware', 'staff.middleware.ImpersonateMiddleware', 'api.middleware.APIMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
RANK_ORDER | ('Mod', 'Op', 'SrOp', 'Admin') |
RECAPTCHA_SECRET_KEY | '********************' |
RECAPTCHA_SITE_KEY | '********************' |
REST_FRAMEWORK | {'DEFAULT_PERMISSION_CLASSES': ('rest_framework.permissions.IsAuthenticated',), 'MAX_PAGINATE_BY': 50, 'PAGINATE_BY': 10, 'PAGINATE_BY_PARAM': 'page_size'} |
ROOT_URLCONF | 'qcmodapp.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | True |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
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 | True |
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 | 'qcmodapp.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SOUTH_DATABASE_ADAPTERS | {'default': 'south.db.mysql'} |
STATICFILES_DIRS | ('./qcmodapp/static',) |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | './static' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['qcmodapp/templates', 'extras/inplaceeditform/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']}}] |
TEMPLATE_CONTEXT_PROCESSORS | ('django.contrib.auth.context_processors.auth', 'django.core.context_processors.request', 'django.core.context_processors.debug', 'django.core.context_processors.i18n', 'django.core.context_processors.media', 'django.core.context_processors.static', 'django.core.context_processors.tz', 'django.contrib.messages.context_processors.messages') |
TEMPLATE_DEBUG | True |
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 | 'EST' |
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 | 'qcmodapp.wsgi.application' |
X_FRAME_OPTIONS | 'DENY' |
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.