'NoneType' object has no attribute 'club'
Request Method: | GET |
---|---|
Request URL: | https://www.ligaprimera.com/players/player/francisco-javier-vallecillo-delgado |
Django Version: | 3.2.14 |
Exception Type: | AttributeError |
Exception Value: | 'NoneType' object has no attribute 'club' |
Exception Location: | /var/www/ligaprimera/web/web/views.py, line 556, in player |
Python Executable: | /var/www/ligaprimera/venv/bin/python3 |
Python Version: | 3.8.10 |
Python Path: | ['/var/www/ligaprimera/venv/bin', '/var/www/ligaprimera/web', '/usr/lib/python38.zip', '/usr/lib/python3.8', '/usr/lib/python3.8/lib-dynload', '/var/www/ligaprimera/venv/lib/python3.8/site-packages'] |
Server time: | Thu, 28 Mar 2024 23:58:06 -0600 |
/var/www/ligaprimera/venv/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 | AttributeError("'NoneType' object has no attribute 'club'") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f42e1fb30a0>> |
request | <WSGIRequest: GET '/players/player/francisco-javier-vallecillo-delgado'> |
/var/www/ligaprimera/venv/lib/python3.8/site-packages/django/core/handlers/base.py
, line 181, in _get_response
if response is None:
wrapped_callback = self.make_view_atomic(callback)
# If it is an asynchronous view, run it in a subthread.
if asyncio.iscoroutinefunction(wrapped_callback):
wrapped_callback = async_to_sync(wrapped_callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
# Complain if the view returned None (a common error).
Variable | Value |
---|---|
callback | <function player at 0x7f42e1aa7f70> |
callback_args | () |
callback_kwargs | {'slug': 'francisco-javier-vallecillo-delgado'} |
middleware_method | <bound method CorsMiddleware.process_view of <corsheaders.middleware.CorsMiddleware object at 0x7f42e1dd1e50>> |
request | <WSGIRequest: GET '/players/player/francisco-javier-vallecillo-delgado'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f42e1fb30a0> |
wrapped_callback | <function player at 0x7f42e1aa7f70> |
/var/www/ligaprimera/web/web/views.py
, line 556, in player
es_mobile = False
if user_agent.is_mobile:
es_mobile = True
player = Jugador.objects.filter(slug=slug).first()
proximos_part = proximos_partidos(club=player.club)…
posiciones = tabla_posiciones()
videos_destacados = YTVideo.objects.all().order_by('-publishedAt')[0:3]
return render(request, 'players/player.html', {
'title': _('Player'),
Variable | Value |
---|---|
es_mobile | False |
player | None |
request | <WSGIRequest: GET '/players/player/francisco-javier-vallecillo-delgado'> |
slug | 'francisco-javier-vallecillo-delgado' |
user_agent | <user_agents.parsers.UserAgent object at 0x7f42e1798610> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'www.ligaprimera.com' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '204.236.220.47' |
HTTP_X_FORWARDED_HOST | 'www.ligaprimera.com' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '204.236.220.47,204.236.220.47' |
PATH_INFO | '/players/player/francisco-javier-vallecillo-delgado' |
QUERY_STRING | '' |
RAW_URI | '/players/player/francisco-javier-vallecillo-delgado' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'www.ligaprimera.com' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/20.0.4' |
gunicorn.socket | <socket.socket fd=5, family=AddressFamily.AF_UNIX, type=SocketKind.SOCK_STREAM, proto=0, laddr=/run/ligaprimera.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f42e09e93a0> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f42e04005e0> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
nicaragua.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['127.0.0.1', '192.241.237.206', '*'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AWS_ACCESS_KEY_ID | '********************' |
AWS_DEFAULT_ACL | 'public-read' |
AWS_IS_GZIPPED | True |
AWS_PRELOAD_METADATA | True |
AWS_QUERYSTRING_AUTH | False |
AWS_S3_CUSTOM_DOMAIN | 'nicaragua.nyc3.cdn.digitaloceanspaces.com' |
AWS_S3_ENDPOINT_URL | 'https://nyc3.digitaloceanspaces.com' |
AWS_S3_FILE_OVERWRITE | False |
AWS_S3_OBJECT_PARAMETERS | {'CacheControl': 'max-age=31536000'} |
AWS_S3_REGION_NAME | 'nyc3' |
AWS_SECRET_ACCESS_KEY | '********************' |
AWS_STORAGE_BUCKET_NAME | 'nicaragua' |
BASE_DIR | '/var/www/ligaprimera/web/nicaragua' |
CACHES | {'collectfast': {'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache', 'LOCATION': '/var/tmp/nicaragua_django_cache'}, 'default': {'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache', 'LOCATION': '127.0.0.1:11211'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CKEDITOR_BROWSE_SHOW_DIRS | True |
CKEDITOR_UPLOAD_PATH | 'upload/' |
COLLECTFAST_CACHE | 'collectfast' |
CORS_ORIGIN_ALLOW_ALL | True |
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_SAMESITE | 'Lax' |
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': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 600, 'ENGINE': 'django.contrib.gis.db.backends.mysql', 'HOST': '10.136.80.144', 'NAME': 'nicaragua_web', 'OPTIONS': {'charset': 'utf8mb4', 'init_command': 'SET foreign_key_checks = 0; SET ' 'character_set_connection=utf8,collation_connection=utf8_bin'}, 'PASSWORD': '********************', 'PORT': '', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'soccer'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 96000 |
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_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | '179.43.127.88' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'contacto@fifprosudamerica.org' |
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 | True |
FANCY_REMEMBER_ALL_URLS | True |
FANCY_REMEMBER_STATS_ALL_URLS | True |
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' |
GEOIP_PATH | '/var/www/brasileirao/web/GeoLite2-Country.mmdb' |
GOOGLE_RECAPTCHA_SECRET_KEY | '********************' |
GZIP_CONTENT_TYPES | ('text/css', 'application/javascript', 'application/x-javascript', 'text/javascript', 'application/vnd.ms-fontobject', 'application/font-sfnt', 'application/font-woff') |
HOST_MIDDLEWARE_URLCONF_MAP | {'nicaragua.pixeles.club': 'web.urls', 'nicaragua.rimont.com': 'web.urls', 'www.ligaprimera.com': 'web.urls'} |
HTML_MINIFY | False |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'web.apps.WebConfig', 'storages', 'floppyforms', 'crispy_forms', 'django_admin_listfilter_dropdown', 'django_cleanup', 'versatileimagefield', 'admin_reorder', 'embed_video', 'ckeditor', 'ckeditor_uploader', 'dynamic_raw_id', 'corsheaders', 'colorfield', 'youtube_thumbnail', 'mailer', 'postman', 'ajax_select', 'dj_pagination', 'collectfast', 'django_user_agents', 'sorl.thumbnail', 'django_instagram', 'mapwidgets', 'django.contrib.gis'] |
INTERNAL_IPS | [] |
IP_GEOLOCATION_SETTINGS | {'BACKEND': 'django_ip_geolocation.backends.IPGeolocationAPI', 'BACKEND_API_KEY': '********************', 'BACKEND_EXTRA_PARAMS': {}, 'BACKEND_USERNAME': '', 'ENABLE_COOKIE': False, 'ENABLE_REQUEST_HOOK': True, 'ENABLE_RESPONSE_HOOK': True, 'FORCE_IP_ADDR': None, 'RESPONSE_HEADER': 'X-IP-Geolocation', 'USER_CONSENT_VALIDATOR': None} |
LANGUAGES | [('en', 'English'), ('es', 'Español')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', 'ur'] |
LANGUAGE_CODE | 'en' |
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 | ('/var/www/ligaprimera/web/locale',) |
LOGGING | {'disable_existing_loggers': False, 'handlers': {'file': {'backupCount': 10, 'class': 'logging.handlers.RotatingFileHandler', 'filename': '/var/www/ligaprimera/web/nicaragua/../django.log', 'level': 'INFO', 'maxBytes': 15728640}}, 'loggers': {'django': {'handlers': ['file'], 'level': 'INFO', 'propagate': True}}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/dashboard' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MAP_WIDGETS | {'GOOGLE_MAP_API_KEY': '********************'} |
MEDIAFILES_LOCATION | 'media/' |
MEDIA_ROOT | 'media/' |
MEDIA_URL | 'https://ligaprimera.b-cdn.net/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['nicaragua.middleware.MultiHostMiddleware', 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.locale.LocaleMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'dj_pagination.middleware.PaginationMiddleware', 'django_user_agents.middleware.UserAgentMiddleware'] |
MIGRATION_MODULES | {} |
MODELTRANSLATION_DEFAULT_LANGUAGE | 'es' |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
RECAPTCHA_SECRET_KEY | '********************' |
RECAPTCHA_SITE_KEY | '********************' |
ROOT_URLCONF | 'nicaragua.urls' |
S3_USE_SIGV4 | False |
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 | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.cached_db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | True |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'nicaragua.settings.production' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
STATICFILES_DIRS | [] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/var/www/ligaprimera/web/static' |
STATIC_URL | '/static/' |
TEMPLATES | [{'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/var/www/ligaprimera/web/nicaragua/templates'], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.contrib.auth.context_processors.auth', 'django.template.context_processors.i18n', 'django.template.context_processors.media', 'django.template.context_processors.request', 'django.contrib.messages.context_processors.messages', 'web.context_processors.clubes', 'web.context_processors.paginas', 'web.context_processors.competiciones', 'web.context_processors.tengo_compactos', 'web.context_processors.tengo_estadisticas', 'web.context_processors.temporada_actual', 'web.context_processors.social_wall'], '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' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'America/Managua' |
TINYMCE_DEFAULT_CONFIG | {'custom_undo_redo_levels': 10, 'height': '320px', 'language': 'es_ES', 'menubar': 'file edit view insert format tools table help', 'paste_as_text': True, 'plugins': 'advlist autolink lists link image charmap print preview anchor ' 'searchreplace visualblocks code fullscreen insertdatetime media ' 'table paste code help wordcount spellchecker', 'toolbar': 'undo redo | bold italic underline strikethrough | fontselect ' 'fontsizeselect formatselect | alignleftaligncenter alignright ' 'alignjustify | bullist numlist outdent indent | numlist bullist ' 'checklist | forecolor backcolor casechange permanentpen ' 'formatpainter removeformat | pagebreak | charmap emoticons | ' 'fullscreen preview save print | insertfile image media pageembed ' 'template link anchor codesample | a11ycheck ltr rtl | ' 'showcomments addcomment code', 'width': '960px'} |
TINYMCE_FILEBROWSER | True |
TINYMCE_SPELLCHECKER | True |
TRANSLATABLE_MODEL_MODULES | [] |
USER_AGENTS_CACHE | 'default' |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
VERSATILEIMAGEFIELD_RENDITION_KEY_SETS | '********************' |
VERSATILEIMAGEFIELD_SETTINGS | {'cache_length': 2592000, 'cache_name': 'versatileimagefield_cache', 'create_images_on_demand': True, 'filtered_directory_name': '__filtered__', 'image_key_post_processor': '********************', 'jpeg_resize_quality': 90, 'placeholder_directory_name': '__placeholder__', 'progressive_jpeg': False, 'sized_directory_name': '__sized__'} |
WSGI_APPLICATION | 'nicaragua.wsgi.application' |
X_FRAME_OPTIONS | 'ALLOW' |
YEAR_MONTH_FORMAT | 'F Y' |
YOUTUBE_API_KEY | '********************' |
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.