unsupported operand type(s) for /: 'NoneType' and 'float'
Request Method: | GET |
---|---|
Request URL: | https://nuestropresupuesto.org/ingresos/make-detail-excel/2016/7/ |
Django Version: | 1.10.3 |
Exception Type: | TypeError |
Exception Value: | unsupported operand type(s) for /: 'NoneType' and 'float' |
Exception Location: | ./observatorio/revenue/queries.py in str_number, line 15 |
Python Executable: | /usr/local/bin/uwsgi |
Python Version: | 3.7.3 |
Python Path: | ['.', '', '/usr/lib/python37.zip', '/usr/lib/python3.7', '/usr/lib/python3.7/lib-dynload', '/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages', '/home/fitoria/observatorio'] |
Server time: | Vie, 29 Mar 2024 15:44:38 +0000 |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@wraps(get_response, assigned=available_attrs(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 | TypeError("unsupported operand type(s) for /: 'NoneType' and 'float'") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f821ffbc5f8>> |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/core/handlers/base.py
in _get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)...
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
callback | <function RevenueExcelDetail at 0x7f821ea59950> |
callback_args | () |
callback_kwargs | {'revenue_id': '7', 'year': '2016'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f821eac0550>> |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
resolver | <RegexURLResolver 'config.urls' (None:None) ^/> |
resolver_match | ResolverMatch(func=observatorio.revenue.views.RevenueExcelDetail, args=(), kwargs={'year': '2016', 'revenue_id': '7'}, url_name=excel_detail, app_names=[], namespaces=['revenues']) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f821ffbc5f8> |
wrapped_callback | <function RevenueExcelDetail at 0x7f821ea59950> |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/core/handlers/base.py
in _get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)...
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
callback | <function RevenueExcelDetail at 0x7f821ea59950> |
callback_args | () |
callback_kwargs | {'revenue_id': '7', 'year': '2016'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f821eac0550>> |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
resolver | <RegexURLResolver 'config.urls' (None:None) ^/> |
resolver_match | ResolverMatch(func=observatorio.revenue.views.RevenueExcelDetail, args=(), kwargs={'year': '2016', 'revenue_id': '7'}, url_name=excel_detail, app_names=[], namespaces=['revenues']) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f821ffbc5f8> |
wrapped_callback | <function RevenueExcelDetail at 0x7f821ea59950> |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/views/generic/base.py
in view
def view(request, *args, **kwargs):
self = cls(**initkwargs)
if hasattr(self, 'get') and not hasattr(self, 'head'):
self.head = self.get
self.request = request
self.args = args
self.kwargs = kwargs
return self.dispatch(request, *args, **kwargs)...
view.view_class = cls
view.view_initkwargs = initkwargs
# take name and docstring from class
update_wrapper(view, cls, updated=())
Variable | Value |
---|---|
args | () |
cls | <class 'observatorio.revenue.views.RevenueExcelDetail'> |
initkwargs | {} |
kwargs | {'revenue_id': '7', 'year': '2016'} |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
self | <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68> |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/views/generic/base.py
in dispatch
# Try to dispatch to the right method; if a method doesn't exist,
# defer to the error handler. Also defer to the error handler if the
# request method isn't on the approved list.
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)...
def http_method_not_allowed(self, request, *args, **kwargs):
logger.warning(
'Method Not Allowed (%s): %s', request.method, request.path,
extra={'status_code': 405, 'request': request}
)
Variable | Value |
---|---|
args | () |
handler | <bound method TemplateView.get of <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68>> |
kwargs | {'revenue_id': '7', 'year': '2016'} |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
self | <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68> |
/home/fitoria/.virtualenvs/observatorio/lib/python3.7/site-packages/django/views/generic/base.py
in get
class TemplateView(TemplateResponseMixin, ContextMixin, View):
"""
A view that renders a template. This view will also pass into the context
any keyword arguments passed by the URLconf.
"""
def get(self, request, *args, **kwargs):
context = self.get_context_data(**kwargs)
return self.render_to_response(context)...
class RedirectView(View):
"""
A view that provides a redirect on any GET request.
"""
Variable | Value |
---|---|
args | () |
context | {'budget': <Budget: Presupuesto de Ingresos - 2016>, 'budgets': <QuerySet [<Budget: Presupuesto de Ingresos - 2018>, <Budget: Presupuesto de Ingresos - 2017>, <Budget: Presupuesto de Ingresos - 2016>, <Budget: Presupuesto de Ingresos - 2015>, <Budget: Presupuesto de Ingresos - 2014>, <Budget: Presupuesto de Ingresos - 2013>, <Budget: Presupuesto de Ingresos - 2012>, <Budget: Presupuesto de Ingresos - 2011>, <Budget: Presupuesto de Ingresos - 2010>, <Budget: Presupuesto de Ingresos - 2009>, <Budget: Presupuesto de Ingresos - 2008>, <Budget: Presupuesto de Ingresos - 2007>]>, 'revenue': <Revenue: Venta de Bienes y Servicios>, 'revenue_id': '7', 'revenues_budgets': <QuerySet []>, 'view': <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68>, 'year': '2016'} |
kwargs | {'revenue_id': '7', 'year': '2016'} |
request | <WSGIRequest: GET '/ingresos/make-detail-excel/2016/7/'> |
self | <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68> |
./observatorio/revenue/views.py
in render_to_response
money_title = workbook.add_format({
'num_format': 'C$#,##0',
'bold': True}
)
# crete the title of the page
title_text = "{0} {1} - {2} Total: {3}".format(
budget.title, str(budget.year), revenue.title, get_revenue_total(
revenue.id, budget.year))...
worksheet.merge_range('A1:D1', title_text, title)
worksheet.set_column('A:B', 40)
worksheet.set_column('C:C', 20)
# add indicators
worksheet.write('A2', 'Ingresos', bold)
Variable | Value |
---|---|
bold | <xlsxwriter.format.Format object at 0x7f821e441c50> |
budget | <Budget: Presupuesto de Ingresos - 2016> |
context | {'budget': <Budget: Presupuesto de Ingresos - 2016>, 'budgets': <QuerySet [<Budget: Presupuesto de Ingresos - 2018>, <Budget: Presupuesto de Ingresos - 2017>, <Budget: Presupuesto de Ingresos - 2016>, <Budget: Presupuesto de Ingresos - 2015>, <Budget: Presupuesto de Ingresos - 2014>, <Budget: Presupuesto de Ingresos - 2013>, <Budget: Presupuesto de Ingresos - 2012>, <Budget: Presupuesto de Ingresos - 2011>, <Budget: Presupuesto de Ingresos - 2010>, <Budget: Presupuesto de Ingresos - 2009>, <Budget: Presupuesto de Ingresos - 2008>, <Budget: Presupuesto de Ingresos - 2007>]>, 'revenue': <Revenue: Venta de Bienes y Servicios>, 'revenue_id': '7', 'revenues_budgets': <QuerySet []>, 'view': <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68>, 'year': '2016'} |
money | <xlsxwriter.format.Format object at 0x7f821e40cb70> |
money_title | <xlsxwriter.format.Format object at 0x7f821e4c4860> |
output | <_io.BytesIO object at 0x7f821e5bc1a8> |
request_kwargs | {} |
revenue | <Revenue: Venta de Bienes y Servicios> |
revenues | <QuerySet []> |
self | <observatorio.revenue.views.RevenueExcelDetail object at 0x7f821e56fd68> |
title | <xlsxwriter.format.Format object at 0x7f821e40c860> |
workbook | <xlsxwriter.workbook.Workbook object at 0x7f821e4865c0> |
worksheet | <xlsxwriter.worksheet.Worksheet object at 0x7f821e40c048> |
./observatorio/revenue/queries.py
in get_revenue_total
'assignment').prefetch_related(
'sourcerevenue_set__source')
def get_revenue_total(id, year):
total = Revenue.objects.get(pk=id).revenuebudget_set.filter(
budget__year=year).aggregate(total=Sum('total')).get('total', 0)
return str_number(total)...
def children_ident(children):
return ' - {0}'.format(children)
Variable | Value |
---|---|
id | 7 |
total | None |
year | 2016 |
./observatorio/revenue/queries.py
in str_number
if year:
return year
else:
return Budget.objects.order_by('-year').values_list('year').first()[0]
def str_number(number):
''' Get a number and covert it into an human readable name '''
return '{:,.2f} millones'.format(number / 1000000.0)...
def get_budget(year):
return Budget.objects.get(year=get_year(year))
Variable | Value |
---|---|
number | 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_HOST | 'nuestropresupuesto.org' |
HTTP_USER_AGENT | 'claudebot' |
PATH_INFO | '/ingresos/make-detail-excel/2016/7/' |
QUERY_STRING | '' |
REMOTE_ADDR | '18.232.185.167' |
REMOTE_PORT | '34030' |
REQUEST_METHOD | 'GET' |
REQUEST_SCHEME | 'https' |
REQUEST_URI | '/ingresos/make-detail-excel/2016/7/' |
SCRIPT_NAME | '' |
SERVER_NAME | 'nuestropresupuesto.org' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.1' |
uwsgi.node | b'bourne' |
uwsgi.version | b'2.0.19.1' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.file_wrapper | '' |
wsgi.input | <uwsgi._Input object at 0x7f821e569048> |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
config.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | (('Kronoscode', 'lead@kronoscode.com'),) |
ADMIN_URL | '^admin/' |
ALLOWED_HOSTS | ['.nuestropresupuesto.org'] |
APPEND_SLASH | True |
APPS_DIR | <Path:/home/fitoria/observatorio/observatorio> |
AUTHENTICATION_BACKENDS | ('django.contrib.auth.backends.ModelBackend',) |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AUTOSLUG_SLUGIFY_FUNCTION | 'slugify.slugify' |
CACHES | {'default': {'BACKEND': 'django_redis.cache.RedisCache', 'LOCATION': 'redis://127.0.0.1:6379/0', 'OPTIONS': {'CLIENT_CLASS': 'django_redis.client.DefaultClient', 'IGNORE_EXCEPTIONS': True}}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CELERY_APP_NAME | 'celery_presupuesto' |
CELERY_BROKER_URL | 'redis://localhost:6379/0' |
CELERY_IGNORE_RESULT | False |
CELERY_RESULT_BACKEND | 'redis://localhost:6379/0' |
CRISPY_TEMPLATE_PACK | 'bootstrap4' |
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 | [] |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'HOST': 'localhost', 'NAME': 'observatorio', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': 5432, 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'observatorio'}} |
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 | 'observatorio <noreply@example.com>' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
DJANGO_APPS | ('django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.sites', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.humanize', 'django.contrib.admin') |
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 | '[observatorio] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_CHARSET | 'utf-8' |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | None |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | ('/home/fitoria/observatorio/observatorio/fixtures',) |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ('django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.sites', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.humanize', 'django.contrib.admin', 'nested_admin', 'django_select2', 'xlsxwriter', 'import_export', 'ckeditor', 'mptt', 'observatorio.budgets', 'observatorio.internal', 'observatorio.contract', 'observatorio.projects', 'observatorio.revenue') |
INTERNAL_IPS | [] |
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 | 'es-NI' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LOCALE_PATHS | ('/home/fitoria/observatorio/observatorio/locale',) |
LOCAL_APPS | ('observatorio.budgets', 'observatorio.internal', 'observatorio.contract', 'observatorio.projects', 'observatorio.revenue') |
LOGGING | {'disable_existing_loggers': False, 'filters': {'require_debug_false': {'()': 'django.utils.log.RequireDebugFalse'}}, 'formatters': {'verbose': {'format': '%(levelname)s %(asctime)s %(module)s ' '%(process)d %(thread)d %(message)s'}}, 'handlers': {'console': {'class': 'logging.StreamHandler', 'formatter': 'verbose', 'level': 'DEBUG'}, 'mail_admins': {'class': 'django.utils.log.AdminEmailHandler', 'filters': ['require_debug_false'], 'level': 'ERROR'}}, 'loggers': {'django.request': {'handlers': ['mail_admins'], 'level': 'ERROR', 'propagate': True}, 'django.security.DisallowedHost': {'handlers': ['console', 'mail_admins'], 'level': 'ERROR', 'propagate': True}}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | (('Kronoscode', 'lead@kronoscode.com'),) |
MEDIA_ROOT | '/home/fitoria/observatorio/observatorio/media' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ('django.middleware.security.SecurityMiddleware', '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.locale.LocaleMiddleware') |
MIDDLEWARE_CLASSES | ['django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware'] |
MIGRATION_MODULES | {'sites': 'observatorio.contrib.sites.migrations'} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
REDIS_LOCATION | 'redis://127.0.0.1:6379/0' |
ROOT_DIR | <Path:/home/fitoria/observatorio> |
ROOT_URLCONF | 'config.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SELECT2_CACHE_BACKEND | 'default' |
SELECT2_CACHE_PREFIX | 'select2_' |
SELECT2_CSS | '//cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.min.css' |
SELECT2_JS | '//cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/js/select2.min.js' |
SERVER_EMAIL | 'observatorio <noreply@example.com>' |
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 | 'config.settings.production' |
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 | ('/home/fitoria/observatorio/observatorio/static',) |
STATICFILES_FINDERS | ('django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder') |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/home/fitoria/observatorio/staticfiles' |
STATIC_URL | '/static/' |
TEMPLATES | [{'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/home/fitoria/observatorio/observatorio/templates'], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', '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'], 'debug': True, 'loaders': [('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])]}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THIRD_PARTY_APPS | ('nested_admin', 'django_select2', 'xlsxwriter', 'import_export', 'ckeditor', 'mptt') |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'UTC' |
USE_ETAGS | False |
USE_I18N | True |
USE_L10N | False |
USE_THOUSAND_SEPARATOR | True |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'config.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.