specify / specify7

Specify 7
https://www.specifysoftware.org/products/specify-7/
GNU General Public License v2.0
62 stars 36 forks source link

Confusing error message when attachment server is not available. #638

Closed yvonneekanim closed 1 year ago

yvonneekanim commented 4 years ago

I get this error when I try to delete loan number 09781 in Bishop ento on test server. So far, haven't been able to replicate it any where else

TypeError at /api/specify/loan/281/ unsupported operand type(s) for +: 'int' and 'NoneType'

Request Method: DELETE Request URL: http://db1.biwebdbtest.nhm.ku.edu/api/specify/loan/281/ Django Version: 1.10.2 Python Executable: /usr/bin/python Python Version: 2.7.15 Python Path: ['/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-x86_64-linux-gnu', '/usr/lib/python2.7/lib-tk', '/usr/lib/python2.7/lib-old', '/usr/lib/python2.7/lib-dynload', '/usr/local/lib/python2.7/dist-packages', '/usr/lib/python2.7/dist-packages', '/home/anhalt/servers/db1', '/home/anhalt/servers/db1/Specify7'] Server time: Thu, 19 Mar 2020 13:18:55 -0500 Installed Applications: ('django.contrib.sessions', 'django.contrib.staticfiles', 'django.contrib.contenttypes', 'django.contrib.auth', 'specifyweb.specify', 'specifyweb.stored_queries', 'specifyweb.businessrules', 'specifyweb.express_search', 'specifyweb.context', 'specifyweb.attachment_gw', 'specifyweb.frontend', 'specifyweb.barvis', 'specifyweb.report_runner', 'specifyweb.interactions', 'specifyweb.workbench', 'specifyweb.notifications', 'specifyweb.export', 'specifyweb.raven_placeholder') Installed Middleware: ('django.middleware.gzip.GZipMiddleware', 'django.middleware.common.CommonMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'specifyweb.context.middleware.ContextMiddleware')

Traceback:

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/core/handlers/exception.py" in inner

  1. response = get_response(request)

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/core/handlers/base.py" in _legacy_get_response

  1. response = self._get_response(request)

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response

  1. response = self.process_exception_by_middleware(e, request)

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response

  1. response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/views.py" in wrapped

  1. return view(request, *args, **kwargs)

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/views/decorators/cache.py" in _cache_controlled

  1. response = viewfunc(request, *args, **kw)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/views.py" in wrapped

  1. return view(request, *args, **kwargs)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/views.py" in view

  1. return dispatch_func(request, *args, **kwargs)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/api.py" in resource_dispatch

  1. delete_resource(request.specify_user_agent, model, id, version)

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/utils/decorators.py" in inner

  1. return func(*args, **kwargs)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/api.py" in delete_resource

  1. return delete_obj(agent, obj, version)

File "/home/anhalt/servers/db1/Specify7/specifyweb/specify/api.py" in delete_obj

  1. obj.delete()

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/db/models/base.py" in delete

  1. return collector.delete()

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/db/models/deletion.py" in delete

  1. sender=model, instance=obj, using=self.using

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/dispatch/dispatcher.py" in send

  1. response = receiver(signal=self, sender=sender, **named)

File "/home/anhalt/servers/db1/Specify7/specifyweb/businessrules/orm_signal_handler.py" in handler

  1. rule(sender, kwargs['instance'])

File "/home/anhalt/servers/db1/Specify7/specifyweb/businessrules/attachment_rules.py" in attachment_jointable_deletion

  1. obj.attachment.delete()

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/db/models/base.py" in delete

  1. return collector.delete()

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/db/models/deletion.py" in delete

  1. sender=model, instance=obj, using=self.using

File "/home/anhalt/servers/db1/Specify7/virtualenv/lib/python2.7/site-packages/django/dispatch/dispatcher.py" in send

  1. response = receiver(signal=self, sender=sender, **named)

File "/home/anhalt/servers/db1/Specify7/specifyweb/businessrules/orm_signal_handler.py" in handler

  1. rule(kwargs['instance'])

File "/home/anhalt/servers/db1/Specify7/specifyweb/businessrules/attachment_rules.py" in attachment_deletion

  1. delete_attachment_file(attachment.attachmentlocation)

File "/home/anhalt/servers/db1/Specify7/specifyweb/attachment_gw/views.py" in delete_attachment_file

  1. 'token': generate_token(get_timestamp(), attch_loc)

File "/home/anhalt/servers/db1/Specify7/specifyweb/attachment_gw/views.py" in get_timestamp

  1. return int(time.time()) + server_time_delta

Exception Type: TypeError at /api/specify/loan/281/ Exception Value: unsupported operand type(s) for +: 'int' and 'NoneType' Request information: USER: Specifyuser object

GET: No GET data

POST: No POST data

FILES: No FILES data

COOKIES: 2.taxon.1.default_initial_conformation = '~~1~2~16~91~30336~33750~33765~33766~33767~33768~44640-~44638------------' _cap = '1686113821547053371' __unam = '757257a-168a5177e57-1911c903-6' _ga = 'GA1.2.1938695282.1547053370' sessionid = '3y08cnxo69zxkulljnc6oc421ffj3eu4' collection = '32769' affiliation = 'undergraduate-student' https%3a%2f%2fhr.ku.edu%2fpsp%2fhrprd%2femployee%2fhrms%2frefresh = 'list:%20%3Ftab%3Dremoteunifieddashboard%7C%3Frp%3Dremoteunifieddashboard%7C' _gid = 'GA1.2.961742964.1584626339' csrftoken = 'iwUjLEm7FLVNvALXjnJlsybbFU39rhRwAu8SseOVOGcfVTw4kQmBhPsIAoGuqOEg' A-8080-PORTAL-PSJSESSIONID = 'gUvzdSmuoyeCVo7PRujDXpYuhiPcY0u9!1134786716'

META: CONTEXT_DOCUMENT_ROOT = '/var/www/html' CONTEXT_PREFIX = '' CSRF_COOKIE = 'iwUjLEm7FLVNvALXjnJlsybbFU39rhRwAu8SseOVOGcfVTw4kQmBhPsIAoGuqOEg' DOCUMENT_ROOT = '/var/www/html' GATEWAY_INTERFACE = 'CGI/1.1' HTTP_ACCEPT = 'application/json, text/javascript, /; q=0.01' HTTP_ACCEPT_ENCODING = 'gzip, deflate' HTTP_ACCEPT_LANGUAGE = 'en-US,en;q=0.9' HTTP_CACHE_CONTROL = 'max-age=0' HTTP_CONNECTION = 'keep-alive' HTTP_COOKIE = '_ga=GA1.2.1938695282.1547053370; _cap=1686113821547053371; affiliation=undergraduate-student; __unam=757257a-168a5177e57-1911c903-6; 2.taxon.1.default_initial_conformation=~~1~2~16~91~30336~33750~33765~33766~33767~33768~44640-~44638------------; _gid=GA1.2.961742964.1584626339; collection=32769; A-8080-PORTAL-PSJSESSIONID=gUvzdSmuoyeCVo7PRujDXpYuhiPcY0u9!1134786716; https%3a%2f%2fhr.ku.edu%2fpsp%2fhrprd%2femployee%2fhrms%2frefresh=list:%20%3Ftab%3Dremoteunifieddashboard%7C%3Frp%3Dremoteunifieddashboard%7C; csrftoken=iwUjLEm7FLVNvALXjnJlsybbFU39rhRwAu8SseOVOGcfVTw4kQmBhPsIAoGuqOEg; sessionid=3y08cnxo69zxkulljnc6oc421ffj3eu4' HTTP_HOST = 'db1.biwebdbtest.nhm.ku.edu' HTTP_IF_MATCH = '0' HTTP_ORIGIN = 'http://db1.biwebdbtest.nhm.ku.edu' HTTP_REFERER = 'http://db1.biwebdbtest.nhm.ku.edu/specify/view/loan/281/' HTTP_USER_AGENT = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36' HTTP_X_CSRFTOKEN = 'iwUjLEm7FLVNvALXjnJlsybbFU39rhRwAu8SseOVOGcfVTw4kQmBhPsIAoGuqOEg' HTTP_X_REQUESTED_WITH = 'XMLHttpRequest' PATH_INFO = u'/api/specify/loan/281/' PATH_TRANSLATED = '/home/anhalt/servers/db1/specify.wsgi/api/specify/loan/281/' QUERY_STRING = '' REMOTE_ADDR = '129.237.183.35' REMOTE_PORT = '61238' REQUEST_METHOD = 'DELETE' REQUEST_SCHEME = 'http' REQUEST_URI = '/api/specify/loan/281/' SCRIPT_FILENAME = '/home/anhalt/servers/db1/specify.wsgi' SCRIPT_NAME = u'' SERVER_ADDR = '10.101.225.56' SERVER_ADMIN = '[no address given]' SERVER_NAME = 'db1.biwebdbtest.nhm.ku.edu' SERVER_PORT = '80' SERVER_PROTOCOL = 'HTTP/1.1' SERVER_SIGNATURE = '

Apache/2.4.29 (Ubuntu) Server at db1.biwebdbtest.nhm.ku.edu Port 80
\n' SERVER_SOFTWARE = 'Apache/2.4.29 (Ubuntu)' apache.version = mod_wsgi.application_group = 'db1.biwebdbtest.nhm.ku.edu|' mod_wsgi.callable_object = 'application' mod_wsgi.daemon_connects = '1' mod_wsgi.daemon_restarts = '0' mod_wsgi.daemon_start = '1584641935611197' mod_wsgi.enable_sendfile = '0' mod_wsgi.handler_script = '' mod_wsgi.ignore_activity = '0' mod_wsgi.listener_host = '' mod_wsgi.listener_port = '80' mod_wsgi.path_info = '/api/specify/loan/281/' mod_wsgi.process_group = 'db1' mod_wsgi.queue_start = '1584641935610932' mod_wsgi.request_handler = 'wsgi-script' mod_wsgi.request_id = 'PxOrM5n+nt0' mod_wsgi.request_start = '1584641935610687' mod_wsgi.script_name = '' mod_wsgi.script_reloading = '1' mod_wsgi.script_start = '1584641935611243' mod_wsgi.thread_id = 2 mod_wsgi.thread_requests = 25L mod_wsgi.total_requests = 81L mod_wsgi.version = wsgi.errors = <mod_wsgi.Log object at 0x7f929aeba0d0> wsgi.file_wrapper = '' wsgi.input = <mod_wsgi.Input object at 0x7f929aea4ea0> wsgi.multiprocess = False wsgi.multithread = True wsgi.run_once = False wsgi.url_scheme = 'http' wsgi.version =

Settings: Using settings module specifyweb.settings ABSOLUTE_URL_OVERRIDES = {} ADMINS = ADMIN_MEDIA_PREFIX = '/static/admin/' ALLOWED_HOSTS = ['*'] ALLOW_SPECIFY6_PASSWORDS = u'****' ALLOW_SUPPORT_LOGIN = True ANONYMOUS_USER = None APPEND_SLASH = True AUTHENTICATION_BACKENDS = ['specifyweb.specify.support_login.SupportLoginBackend', 'django.contrib.auth.backends.ModelBackend'] AUTH_LDAP_SERVER_URI = None AUTH_PASSWORD_VALIDATORS = u'****' AUTH_USER_MODEL = 'specify.Specifyuser' CACHES = {u'default': {u'BACKEND': u'django.core.cache.backends.locmem.LocMemCache'}} CACHE_MIDDLEWARE_ALIAS = u'default' CACHE_MIDDLEWARE_KEY_PREFIX = u'****' CACHE_MIDDLEWARE_SECONDS = 600 CSRF_COOKIE_AGE = 31449600 CSRF_COOKIE_DOMAIN = None CSRF_COOKIE_HTTPONLY = False CSRF_COOKIE_NAME = u'csrftoken' CSRF_COOKIE_PATH = u'/' CSRF_COOKIE_SECURE = False CSRF_FAILURE_VIEW = u'django.views.csrf.csrf_failure' CSRF_HEADER_NAME = u'HTTP_X_CSRFTOKEN' CSRF_TRUSTED_ORIGINS = [] DATABASES = {'default': {'ENGINE': 'specifyweb.hibernateboolsbackend.backends.mysql', 'AUTOCOMMIT': True, 'ATOMIC_REQUESTS': False, 'NAME': u'Bishop', 'CONN_MAX_AGE': 0, 'TIME_ZONE': None, 'PORT': '', 'HOST': 'localhost', 'USER': 'MasterUser', 'TEST': {'COLLATION': None, 'CHARSET': None, 'NAME': None, 'MIRROR': None}, 'PASSWORD': u'****', 'OPTIONS': {}}} DATABASE_HOST = 'localhost' DATABASE_NAME = u'Bishop' DATABASE_PORT = '' DATABASE_ROUTERS = [] DATA_UPLOAD_MAX_MEMORY_SIZE = 2621440 DATA_UPLOAD_MAX_NUMBER_FIELDS = 1000 DATETIME_FORMAT = u'N j, Y, P' DATETIME_INPUT_FORMATS = [u'%Y-%m-%d %H:%M:%S', u'%Y-%m-%d %H:%M:%S.%f', u'%Y-%m-%d %H:%M', u'%Y-%m-%d', u'%m/%d/%Y %H:%M:%S', u'%m/%d/%Y %H:%M:%S.%f', u'%m/%d/%Y %H:%M', u'%m/%d/%Y', u'%m/%d/%y %H:%M:%S', u'%m/%d/%y %H:%M:%S.%f', u'%m/%d/%y %H:%M', u'%m/%d/%y'] DATE_FORMAT = u'N j, Y' DATE_INPUT_FORMATS = [u'%Y-%m-%d', u'%m/%d/%Y', u'%m/%d/%y', u'%b %d %Y', u'%b %d, %Y', u'%d %b %Y', u'%d %b, %Y', u'%B %d %Y', u'%B %d, %Y', u'%d %B %Y', u'%d %B, %Y'] DEBUG = True DEBUG_PROPAGATE_EXCEPTIONS = False DECIMAL_SEPARATOR = u'.' DEFAULT_CHARSET = u'utf-8' DEFAULT_CONTENT_TYPE = u'text/html' DEFAULT_EXCEPTION_REPORTER_FILTER = u'django.views.debug.SafeExceptionReporterFilter' DEFAULT_FILE_STORAGE = u'django.core.files.storage.FileSystemStorage' DEFAULT_FROM_EMAIL = u'webmaster@localhost' DEFAULT_INDEX_TABLESPACE = u'' DEFAULT_TABLESPACE = u'' DEPOSITORY_DIR = '/home/anhalt/specify-depository' DISALLOWED_USER_AGENTS = [] EMAIL_BACKEND = u'django.core.mail.backends.smtp.EmailBackend' EMAIL_HOST = u'localhost' EMAIL_HOST_PASSWORD = u'****' EMAIL_HOST_USER = u'' EMAIL_PORT = 25 EMAIL_SSL_CERTFILE = None EMAIL_SSL_KEYFILE = u'****' EMAIL_SUBJECT_PREFIX = u'[Django] ' EMAIL_TIMEOUT = None EMAIL_USE_SSL = False EMAIL_USE_TLS = False FILE_CHARSET = u'utf-8' FILE_UPLOAD_DIRECTORY_PERMISSIONS = None FILE_UPLOAD_HANDLERS = [u'django.core.files.uploadhandler.MemoryFileUploadHandler', u'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 IGNORABLE_404_URLS = [] INSTALLED_APPS = INTERNAL_IPS = [] JAVA_PATH = '/usr/bin/java' LANGUAGES = [(u'af', u'Afrikaans'), (u'ar', u'Arabic'), (u'ast', u'Asturian'), (u'az', u'Azerbaijani'), (u'bg', u'Bulgarian'), (u'be', u'Belarusian'), (u'bn', u'Bengali'), (u'br', u'Breton'), (u'bs', u'Bosnian'), (u'ca', u'Catalan'), (u'cs', u'Czech'), (u'cy', u'Welsh'), (u'da', u'Danish'), (u'de', u'German'), (u'dsb', u'Lower Sorbian'), (u'el', u'Greek'), (u'en', u'English'), (u'en-au', u'Australian English'), (u'en-gb', u'British English'), (u'eo', u'Esperanto'), (u'es', u'Spanish'), (u'es-ar', u'Argentinian Spanish'), (u'es-co', u'Colombian Spanish'), (u'es-mx', u'Mexican Spanish'), (u'es-ni', u'Nicaraguan Spanish'), (u'es-ve', u'Venezuelan Spanish'), (u'et', u'Estonian'), (u'eu', u'Basque'), (u'fa', u'Persian'), (u'fi', u'Finnish'), (u'fr', u'French'), (u'fy', u'Frisian'), (u'ga', u'Irish'), (u'gd', u'Scottish Gaelic'), (u'gl', u'Galician'), (u'he', u'Hebrew'), (u'hi', u'Hindi'), (u'hr', u'Croatian'), (u'hsb', u'Upper Sorbian'), (u'hu', u'Hungarian'), (u'ia', u'Interlingua'), (u'id', u'Indonesian'), (u'io', u'Ido'), (u'is', u'Icelandic'), (u'it', u'Italian'), (u'ja', u'Japanese'), (u'ka', u'Georgian'), (u'kk', u'Kazakh'), (u'km', u'Khmer'), (u'kn', u'Kannada'), (u'ko', u'Korean'), (u'lb', u'Luxembourgish'), (u'lt', u'Lithuanian'), (u'lv', u'Latvian'), (u'mk', u'Macedonian'), (u'ml', u'Malayalam'), (u'mn', u'Mongolian'), (u'mr', u'Marathi'), (u'my', u'Burmese'), (u'nb', u'Norwegian Bokm\xe5l'), (u'ne', u'Nepali'), (u'nl', u'Dutch'), (u'nn', u'Norwegian Nynorsk'), (u'os', u'Ossetic'), (u'pa', u'Punjabi'), (u'pl', u'Polish'), (u'pt', u'Portuguese'), (u'pt-br', u'Brazilian Portuguese'), (u'ro', u'Romanian'), (u'ru', u'Russian'), (u'sk', u'Slovak'), (u'sl', u'Slovenian'), (u'sq', u'Albanian'), (u'sr', u'Serbian'), (u'sr-latn', u'Serbian Latin'), (u'sv', u'Swedish'), (u'sw', u'Swahili'), (u'ta', u'Tamil'), (u'te', u'Telugu'), (u'th', u'Thai'), (u'tr', u'Turkish'), (u'tt', u'Tatar'), (u'udm', u'Udmurt'), (u'uk', u'Ukrainian'), (u'ur', u'Urdu'), (u'vi', u'Vietnamese'), (u'zh-hans', u'Simplified Chinese'), (u'zh-hant', u'Traditional Chinese')] LANGUAGES_BIDI = [u'he', u'ar', u'fa', u'ur'] LANGUAGE_CODE = 'en-us' LANGUAGE_COOKIE_AGE = None LANGUAGE_COOKIE_DOMAIN = None LANGUAGE_COOKIE_NAME = u'django_language' LANGUAGE_COOKIE_PATH = u'/' LOCALE_PATHS = [] LOGGING = {'loggers': {'specifyweb': {'handlers': ['logfile'], 'propagate': True, 'level': 'DEBUG'}, 'django.request': {'handlers': ['mail_admins', 'logfile'], 'propagate': True, 'level': 'DEBUG'}}, 'disable_existing_loggers': True, 'handlers': {'logfile': {'backupCount': 10, 'level': 'DEBUG', 'filename': u'/home/anhalt/logs/Bishop.log', 'formatter': 'standard', 'class': 'logging.handlers.RotatingFileHandler', 'maxBytes': 1048576}, 'console': {'class': 'logging.StreamHandler', 'level': 'DEBUG'}, 'mail_admins': {'class': 'django.utils.log.AdminEmailHandler', 'filters': ['require_debug_false'], 'level': 'ERROR'}}, 'formatters': {'standard': {'datefmt': '%d/%b/%Y %H:%M:%S', 'format': '[%(asctime)s] [%(levelname)s] [%(name)s:%(lineno)s] %(message)s'}}, 'version': 1, 'filters': {'require_debug_false': {'()': 'django.utils.log.RequireDebugFalse'}}} LOGGING_CONFIG = u'logging.config.dictConfig' LOGIN_REDIRECT_URL = '/' LOGIN_URL = u'/accounts/login/' LOGOUT_REDIRECT_URL = None MANAGERS = MASTER_NAME = 'MasterUser' MASTER_PASSWORD = u'****' MEDIA_ROOT = '' MEDIA_URL = '' MESSAGE_STORAGE = u'django.contrib.messages.storage.fallback.FallbackStorage' MIDDLEWARE = None MIDDLEWARE_CLASSES = MIGRATION_MODULES = {} MONTH_DAY_FORMAT = u'F j' NOTIFICATION_TTL_DAYS = 7 NUMBER_GROUPING = 0 PASSWORD_HASHERS = u'****' PASSWORD_RESET_TIMEOUT_DAYS = u'****' PREPEND_WWW = False RAVEN_CONFIG = None REPORT_RUNNER_HOST = 'localhost' REPORT_RUNNER_PORT = '9999' ROOT_URLCONF = 'specifyweb.urls' RO_MODE = False SA_DATABASE_URL = u'mysql://MasterUser:MasterPassword@localhost:3306/Bishop?charset=utf8' SA_POOL_RECYCLE = 3600 SCHEMA_LANGUAGE = 'en' SECRET_KEY = u'****' 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 SERVER_EMAIL = u'root@localhost' SESSION_CACHE_ALIAS = u'default' SESSION_COOKIE_AGE = 1209600 SESSION_COOKIE_DOMAIN = None SESSION_COOKIE_HTTPONLY = True SESSION_COOKIE_NAME = u'sessionid' SESSION_COOKIE_PATH = u'/' SESSION_COOKIE_SECURE = False SESSION_ENGINE = 'django.contrib.sessions.backends.file' SESSION_EXPIRE_AT_BROWSER_CLOSE = True SESSION_FILE_PATH = None SESSION_SAVE_EVERY_REQUEST = False SESSION_SERIALIZER = u'django.contrib.sessions.serializers.JSONSerializer' SETTINGS_MODULE = 'specifyweb.settings' SHORT_DATETIME_FORMAT = u'm/d/Y P' SHORT_DATE_FORMAT = u'm/d/Y' SIGNING_BACKEND = u'django.core.signing.TimestampSigner' SILENCED_SYSTEM_CHECKS = [] SITE_ID = 1 SPECIFY_CONFIG_DIR = '/home/anhalt/servers/db1/Specify6/config' SPECIFY_THICK_CLIENT = '/home/anhalt/servers/db1/Specify6' STATICFILES_DIRS = ('config', '/home/anhalt/servers/db1/Specify6/config') STATICFILES_FINDERS = STATICFILES_STORAGE = u'django.contrib.staticfiles.storage.StaticFilesStorage' STATIC_ROOT = '' STATIC_URL = '/static/' STATS_URL = None SUPPORT_LOGIN_TTL = 300 TEMPLATES = [{'DIRS': [], 'APP_DIRS': True, 'OPTIONS': {'context_processors': ['django.contrib.auth.context_processors.auth', 'django.template.context_processors.debug', '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']}, 'BACKEND': 'django.template.backends.django.DjangoTemplates'}] TESTING = False TESTING_DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3', 'NAME': 'specifytest', 'HOST': '127.0.0.1', 'USER': 'Master', 'PASSWORD': u'****', 'PORT': '3307'}} TEST_NON_SERIALIZED_APPS = [] TEST_RUNNER = u'django.test.runner.DiscoverRunner' THICK_CLIENT_LOCATION = '/home/anhalt/servers/db1/Specify6' THOUSAND_SEPARATOR = u',' TIME_FORMAT = u'P' TIME_INPUT_FORMATS = [u'%H:%M:%S', u'%H:%M:%S.%f', u'%H:%M'] TIME_ZONE = 'America/Chicago' USE_ETAGS = False USE_I18N = True USE_L10N = True USE_THOUSAND_SEPARATOR = False USE_TZ = False USE_X_FORWARDED_HOST = False USE_X_FORWARDED_PORT = False VERSION = 'v7.3.1-75-g20a45c6e(debug)' WB_UPLOAD_LOG_DIR = '/home/anhalt/wbuploadlog' WEB_ATTACHMENT_COLLECTION = 'KUFishvoucher' WEB_ATTACHMENT_KEY = u'****' WEB_ATTACHMENT_REQUIRES_KEY_FOR_GET = u'****' WEB_ATTACHMENT_URL = None WSGI_APPLICATION = None X_FRAME_OPTIONS = u'SAMEORIGIN' YEAR_MONTH_FORMAT = u'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.

benanhalt commented 4 years ago

That is just bad error message, it seems. It is because that loan has an attachment that it tries to delete when you delete the loan. But the test server doesn't have an attachment server set up.

maxpatiiuk commented 4 years ago

I am still getting an error message on the python3 server. Seems like a CORS issue Screen Shot 2020-06-26 at 3 17 47 PM

Works well in Firefox 77.0 (Beta)

benanhalt commented 4 years ago

@maxpatiiuk You are getting the CORS error in Chrome?

maxpatiiuk commented 4 years ago

Same problem here: https://sp7demofish.specifycloud.org/specify/view/collectionobject/new/ Opened #696 for that since it seems like a different issue

maxpatiiuk commented 4 years ago
Screen Shot 2020-06-29 at 5 39 21 PM

Also, does db2 server (demodatabase) has attachments server configured?

melton-jason commented 1 year ago

Can this issue be closed?

maxpatiiuk commented 1 year ago

The exception on the last screenshot shows that not all cases are handled well yet (assuming that error is still reproducable - it's 3 years old, a lot of things changed since then).

Thus would be good to do testing of sp7 without asset server configured and make sure all cases are handled appropriately

maxpatiiuk commented 1 year ago

Looking at the code, the url mentioned in the exception is called by the backend when user tries to upload a file using the file picker in the attachments plugin - that plugin is no longer displayed when the asset server is not configured thus this exception would be prevented