Substra / substra-backend

Backend of the Substra software
https://docs.substra.org
Apache License 2.0
57 stars 15 forks source link

Error 500 when trying to use /api-token-auth with a node-to-node login #97

Closed jmorel closed 4 years ago

jmorel commented 4 years ago

I tried login through the substra client using a node-to-node login with both valid and invalid password. This means using the /api-token-auth endpoint.

In both cases, I get this 500 response:

Requests error status 500: ValueError at /api-token-auth/
save() prohibited to prevent data loss due to unsaved related object 'user'.

Request Method: POST
Request URL: http://substra-backend.node-1.com/api-token-auth/
Django Version: 2.1.11
Python Executable: /usr/local/bin/python
Python Version: 3.6.10
Python Path: ['/usr/src/app', '/usr/local/lib/python36.zip', '/usr/local/lib/python3.6', '/usr/local/lib/python3.6/lib-dynload', '/usr/local/lib/python3.6/site-packages', '/usr/src/app', '/usr/src/app', '/usr/src/app/libs']
Server time: Tue, 7 Jan 2020 14:05:39 +0000
Installed Applications:
['django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django.contrib.sites',
 'django_celery_results',
 'rest_framework_swagger',
 'rest_framework',
 'rest_framework.authtoken',
 'rest_framework_simplejwt.token_blacklist',
 'substrapp',
 'node',
 'users',
 'corsheaders',
 'events',
 'node-register']
Installed Middleware:
['corsheaders.middleware.CorsMiddleware',
 'django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.auth.middleware.RemoteUserMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware',
 'libs.SQLPrintingMiddleware.SQLPrintingMiddleware',
 'libs.HealthCheckMiddleware.HealthCheckMiddleware']

Traceback:

File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in get_or_create
  486.             return self.get(**lookup), False

File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in get
  399.                 self.model._meta.object_name

During handling of the above exception (Token matching query does not exist.), another exception occurred:

File "/usr/local/lib/python3.6/site-packages/django/core/handlers/exception.py" in inner
  34.             response = get_response(request)

File "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  126.                 response = self.process_exception_by_middleware(e, request)

File "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  124.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/usr/local/lib/python3.6/site-packages/django/views/decorators/csrf.py" in wrapped_view
  54.         return view_func(*args, **kwargs)

File "/usr/local/lib/python3.6/site-packages/django/views/generic/base.py" in view
  68.             return self.dispatch(request, *args, **kwargs)

File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in dispatch
  483.             response = self.handle_exception(exc)

File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in handle_exception
  443.             self.raise_uncaught_exception(exc)

File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in dispatch
  480.             response = handler(request, *args, **kwargs)

File "/usr/src/app/backend/views.py" in post
  124.         token, created = Token.objects.get_or_create(user=user)

File "/usr/local/lib/python3.6/site-packages/django/db/models/manager.py" in manager_method
  82.                 return getattr(self.get_queryset(), name)(*args, **kwargs)

File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in get_or_create
  488.             return self._create_object_from_params(lookup, params)

File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in _create_object_from_params
  522.                 obj = self.create(**params)

File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in create
  413.         obj.save(force_insert=True, using=self.db)

File "/usr/local/lib/python3.6/site-packages/rest_framework/authtoken/models.py" in save
  35.         return super(Token, self).save(*args, **kwargs)

File "/usr/local/lib/python3.6/site-packages/django/db/models/base.py" in save
  670.                         "unsaved related object '%s'." % field.name

Exception Type: ValueError at /api-token-auth/
Exception Value: save() prohibited to prevent data loss due to unsaved related object 'user'.
Request information:
USER: AnonymousUser

GET: No GET data

POST:
username = 'MyOrg1MSP'
password = 'selfSecret1'

FILES: No FILES data

COOKIES: No cookie data

META:
BACKEND_DB_NAME = 'substra'
BACKEND_DB_PWD = 'postgres'
BACKEND_DB_USER = 'postgres'
BACKEND_DEFAULT_PORT = '8000'
BACKEND_ORG = 'MyOrg1'
BACKEND_ORG_1_POSTGRESQL_PORT = 'tcp://10.99.253.201:5432'
BACKEND_ORG_1_POSTGRESQL_PORT_5432_TCP = 'tcp://10.99.253.201:5432'
BACKEND_ORG_1_POSTGRESQL_PORT_5432_TCP_ADDR = '10.99.253.201'
BACKEND_ORG_1_POSTGRESQL_PORT_5432_TCP_PORT = '5432'
BACKEND_ORG_1_POSTGRESQL_PORT_5432_TCP_PROTO = 'tcp'
BACKEND_ORG_1_POSTGRESQL_SERVICE_HOST = '10.99.253.201'
BACKEND_ORG_1_POSTGRESQL_SERVICE_PORT = '5432'
BACKEND_ORG_1_POSTGRESQL_SERVICE_PORT_POSTGRESQL = '5432'
BACKEND_ORG_1_RABBITMQ_PORT = 'tcp://10.108.182.80:4369'
BACKEND_ORG_1_RABBITMQ_PORT_15672_TCP = 'tcp://10.108.182.80:15672'
BACKEND_ORG_1_RABBITMQ_PORT_15672_TCP_ADDR = '10.108.182.80'
BACKEND_ORG_1_RABBITMQ_PORT_15672_TCP_PORT = '15672'
BACKEND_ORG_1_RABBITMQ_PORT_15672_TCP_PROTO = 'tcp'
BACKEND_ORG_1_RABBITMQ_PORT_25672_TCP = 'tcp://10.108.182.80:25672'
BACKEND_ORG_1_RABBITMQ_PORT_25672_TCP_ADDR = '10.108.182.80'
BACKEND_ORG_1_RABBITMQ_PORT_25672_TCP_PORT = '25672'
BACKEND_ORG_1_RABBITMQ_PORT_25672_TCP_PROTO = 'tcp'
BACKEND_ORG_1_RABBITMQ_PORT_4369_TCP = 'tcp://10.108.182.80:4369'
BACKEND_ORG_1_RABBITMQ_PORT_4369_TCP_ADDR = '10.108.182.80'
BACKEND_ORG_1_RABBITMQ_PORT_4369_TCP_PORT = '4369'
BACKEND_ORG_1_RABBITMQ_PORT_4369_TCP_PROTO = 'tcp'
BACKEND_ORG_1_RABBITMQ_PORT_5672_TCP = 'tcp://10.108.182.80:5672'
BACKEND_ORG_1_RABBITMQ_PORT_5672_TCP_ADDR = '10.108.182.80'
BACKEND_ORG_1_RABBITMQ_PORT_5672_TCP_PORT = '5672'
BACKEND_ORG_1_RABBITMQ_PORT_5672_TCP_PROTO = 'tcp'
BACKEND_ORG_1_RABBITMQ_SERVICE_HOST = '10.108.182.80'
BACKEND_ORG_1_RABBITMQ_SERVICE_PORT = '4369'
BACKEND_ORG_1_RABBITMQ_SERVICE_PORT_AMQP = '5672'
BACKEND_ORG_1_RABBITMQ_SERVICE_PORT_DIST = '25672'
BACKEND_ORG_1_RABBITMQ_SERVICE_PORT_EPMD = '4369'
BACKEND_ORG_1_RABBITMQ_SERVICE_PORT_STATS = '15672'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_PORT = 'tcp://10.97.215.88:5555'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_PORT_5555_TCP = 'tcp://10.97.215.88:5555'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_PORT_5555_TCP_ADDR = '10.97.215.88'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_PORT_5555_TCP_PORT = '5555'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_PORT_5555_TCP_PROTO = 'tcp'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_SERVICE_HOST = '10.97.215.88'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_SERVICE_PORT = '5555'
BACKEND_ORG_1_SUBSTRA_BACKEND_FLOWER_SERVICE_PORT_HTTP = '5555'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_PORT = 'tcp://10.99.149.30:8000'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_PORT_8000_TCP = 'tcp://10.99.149.30:8000'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_PORT_8000_TCP_ADDR = '10.99.149.30'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_PORT_8000_TCP_PORT = '8000'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_PORT_8000_TCP_PROTO = 'tcp'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_SERVICE_HOST = '10.99.149.30'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_SERVICE_PORT = '8000'
BACKEND_ORG_1_SUBSTRA_BACKEND_SERVER_SERVICE_PORT_HTTP = '8000'
BACKEND_PEER_PORT = 'internal'
CELERY_BROKER_URL = 'amqp://rabbitmq:rabbitmq@backend-org-1-rabbitmq:5672//'
CONTENT_LENGTH = '39'
CONTENT_TYPE = 'application/x-www-form-urlencoded'
DATABASE_HOST = 'backend-org-1-postgresql'
DEFAULT_DOMAIN = 'http://substra-backend.node-1.com'
DJANGO_SETTINGS_MODULE = 'backend.settings.server.dev'
GATEWAY_INTERFACE = 'CGI/1.1'
GPG_KEY = '0D96DF4D4110E5C43FBFB17F2D347EA6AA65421D'
GRPC_MAX_RECEIVE_MESSAGE_LENGTH = '0'
GRPC_MAX_SEND_MESSAGE_LENGTH = '0'
GRPC_SSL_CIPHER_SUITES = 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384'
HOME = '/root'
HOSTNAME = 'backend-org-1-substra-backend-server-5f4bc85f8-2pz82'
HTTP_ACCEPT = 'application/json;version=0.0'
HTTP_ACCEPT_ENCODING = 'gzip, deflate'
HTTP_HOST = 'substra-backend.node-1.com'
HTTP_USER_AGENT = 'python-requests/2.22.0'
HTTP_X_FORWARDED_FOR = '192.168.65.3'
HTTP_X_FORWARDED_HOST = 'substra-backend.node-1.com'
HTTP_X_FORWARDED_PORT = '80'
HTTP_X_FORWARDED_PROTO = 'http'
HTTP_X_ORIGINAL_URI = '/api-token-auth/'
HTTP_X_REAL_IP = '192.168.65.3'
HTTP_X_REQUEST_ID = '29e880b1643d1386411caecab8207997'
HTTP_X_SCHEME = 'http'
KUBERNETES_PORT = 'tcp://10.96.0.1:443'
KUBERNETES_PORT_443_TCP = 'tcp://10.96.0.1:443'
KUBERNETES_PORT_443_TCP_ADDR = '10.96.0.1'
KUBERNETES_PORT_443_TCP_PORT = '443'
KUBERNETES_PORT_443_TCP_PROTO = 'tcp'
KUBERNETES_SERVICE_HOST = '10.96.0.1'
KUBERNETES_SERVICE_PORT = '443'
KUBERNETES_SERVICE_PORT_HTTPS = '443'
LANG = 'C.UTF-8'
LEDGER_CONFIG_FILE = '/conf/MyOrg1/substra-backend/conf.json'
MEDIA_ROOT = '/tmp/org-1/medias/'
NETWORK_ORG_1_PEER_1_CA_PORT = 'tcp://10.98.200.198:7054'
NETWORK_ORG_1_PEER_1_CA_PORT_7054_TCP = 'tcp://10.98.200.198:7054'
NETWORK_ORG_1_PEER_1_CA_PORT_7054_TCP_ADDR = '10.98.200.198'
NETWORK_ORG_1_PEER_1_CA_PORT_7054_TCP_PORT = '7054'
NETWORK_ORG_1_PEER_1_CA_PORT_7054_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_CA_SERVICE_HOST = '10.98.200.198'
NETWORK_ORG_1_PEER_1_CA_SERVICE_PORT = '7054'
NETWORK_ORG_1_PEER_1_CA_SERVICE_PORT_HTTP = '7054'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT = 'tcp://10.109.205.170:80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_443_TCP = 'tcp://10.109.205.170:443'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_443_TCP_ADDR = '10.109.205.170'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_443_TCP_PORT = '443'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_443_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_80_TCP = 'tcp://10.109.205.170:80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_80_TCP_ADDR = '10.109.205.170'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_80_TCP_PORT = '80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_PORT_80_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_SERVICE_HOST = '10.109.205.170'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_SERVICE_PORT = '80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_SERVICE_PORT_HTTP = '80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_CONTROLLER_SERVICE_PORT_HTTPS = '443'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_PORT = 'tcp://10.111.238.187:80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_PORT_80_TCP = 'tcp://10.111.238.187:80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_PORT_80_TCP_ADDR = '10.111.238.187'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_PORT_80_TCP_PORT = '80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_PORT_80_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_SERVICE_HOST = '10.111.238.187'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_SERVICE_PORT = '80'
NETWORK_ORG_1_PEER_1_NGINX_INGRESS_DEFAULT_BACKEND_SERVICE_PORT_HTTP = '80'
NETWORK_ORG_1_PEER_1_PORT = 'tcp://10.98.102.223:7051'
NETWORK_ORG_1_PEER_1_PORT_7051_TCP = 'tcp://10.98.102.223:7051'
NETWORK_ORG_1_PEER_1_PORT_7051_TCP_ADDR = '10.98.102.223'
NETWORK_ORG_1_PEER_1_PORT_7051_TCP_PORT = '7051'
NETWORK_ORG_1_PEER_1_PORT_7051_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_PORT_7053_TCP = 'tcp://10.98.102.223:7053'
NETWORK_ORG_1_PEER_1_PORT_7053_TCP_ADDR = '10.98.102.223'
NETWORK_ORG_1_PEER_1_PORT_7053_TCP_PORT = '7053'
NETWORK_ORG_1_PEER_1_PORT_7053_TCP_PROTO = 'tcp'
NETWORK_ORG_1_PEER_1_SERVICE_HOST = '10.98.102.223'
NETWORK_ORG_1_PEER_1_SERVICE_PORT = '7051'
NETWORK_ORG_1_PEER_1_SERVICE_PORT_EVENT = '7053'
NETWORK_ORG_1_PEER_1_SERVICE_PORT_REQUEST = '7051'
PATH = '/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin'
PATH_INFO = '/api-token-auth/'
PWD = '/usr/src/app'
PYTHONUNBUFFERED = '1'
PYTHON_GET_PIP_SHA256 = 'b86f36cc4345ae87bfd4f10ef6b2dbfa7a872fbff70608a1e43944d283fd0eee'
PYTHON_GET_PIP_URL = 'https://github.com/pypa/get-pip/raw/ffe826207a010164265d9cc807978e3604d18ca0/get-pip.py'
PYTHON_PIP_VERSION = '19.3.1'
PYTHON_VERSION = '3.6.10'
QUERY_STRING = ''
REMOTE_ADDR = '10.1.1.123'
REMOTE_HOST = ''
REQUEST_METHOD = 'POST'
SCRIPT_NAME = ''
SERVER_NAME = 'backend-org-1-substra-backend-server-5f4bc85f8-2pz82'
SERVER_PORT = '8000'
SERVER_PROTOCOL = 'HTTP/1.1'
SERVER_SOFTWARE = 'WSGIServer/0.2'
SHLVL = '0'
TZ = 'UTC'
_ = '/usr/local/bin/python'
wsgi.errors = <_io.TextIOWrapper name='<stderr>' mode='w' encoding='UTF-8'>
wsgi.file_wrapper = ''
wsgi.input = <django.core.handlers.wsgi.LimitedStream object at 0x7f3257f0e160>
wsgi.multiprocess = False
wsgi.multithread = True
wsgi.run_once = False
wsgi.url_scheme = 'http'
wsgi.version = '(1, 0)'

Settings:
Using settings module backend.settings.server.dev
ABSOLUTE_URL_OVERRIDES = {}
ADMINS = []
ALLOWED_HOSTS = ['*']
APPEND_SLASH = True
AUTHENTICATION_BACKENDS = ['django.contrib.auth.backends.ModelBackend', 'node.authentication.NodeBackend']
AUTH_PASSWORD_VALIDATORS = '********************'
AUTH_USER_MODEL = 'auth.User'
BASE_DIR = '/usr/src/app/backend'
CACHES = {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}}
CACHE_MIDDLEWARE_ALIAS = 'default'
CACHE_MIDDLEWARE_KEY_PREFIX = '********************'
CACHE_MIDDLEWARE_SECONDS = 600
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_BROKER_URL = "('amqp://rabbitmq:rabbitmq@backend-org-1-rabbitmq:5672//',)"
CELERY_RESULT_BACKEND = 'django-db'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TASK_MAX_RETRIES = 1
CELERY_TASK_RETRY_DELAY_SECONDS = 0
CELERY_TASK_SERIALIZER = 'json'
CELERY_TASK_TRACK_STARTED = True
CELERY_WORKER_CONCURRENCY = 1
CORS_ALLOW_CREDENTIALS = True
CORS_ALLOW_HEADERS = "('accept', 'accept-encoding', 'authorization', 'content-type', 'dnt', 'origin', 'user-agent', 'x-csrftoken', 'x-requested-with', 'token')"
CORS_ORIGIN_ALLOW_ALL = True
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': {'ENGINE': 'django.db.backends.postgresql_psycopg2', 'NAME': 'substra', 'USER': 'postgres', 'PASSWORD': '********************', 'HOST': 'backend-org-1-postgresql', 'PORT': 5432, 'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'OPTIONS': {}, 'TIME_ZONE': None, 'TEST': {'CHARSET': None, 'COLLATION': None, 'NAME': None, 'MIRROR': None}}}
DATABASE_ROUTERS = []
DATA_UPLOAD_MAX_MEMORY_SIZE = 2621440
DATA_UPLOAD_MAX_NUMBER_FIELDS = 10000
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_DOMAIN = 'http://substra-backend.node-1.com'
DEFAULT_EXCEPTION_REPORTER_FILTER = 'django.views.debug.SafeExceptionReporterFilter'
DEFAULT_FILE_STORAGE = 'django.core.files.storage.FileSystemStorage'
DEFAULT_FROM_EMAIL = 'webmaster@localhost'
DEFAULT_INDEX_TABLESPACE = ''
DEFAULT_PORT = '8000'
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
EXPIRY_TOKEN_LIFETIME = '********************'
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 = ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sites', 'django_celery_results', 'rest_framework_swagger', 'rest_framework', 'rest_framework.authtoken', 'rest_framework_simplejwt.token_blacklist', 'substrapp', 'node', 'users', 'corsheaders', 'events', 'node-register']
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'), ('kab', 'Kabyle'), ('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 = '/'
LEDGER = {'name': 'MyOrg1', 'core_peer_mspconfigpath': '/var/hyperledger/msp', 'channel_name': 'mychannel', 'chaincode_name': 'mycc', 'chaincode_version': '1.0', 'client': {'name': 'user', 'org': 'MyOrg1', 'state_store': '/tmp/hfc-cvs', 'key_path': '********************', 'cert_path': '/var/hyperledger/msp/signcerts/cert.pem', 'msp_id': 'MyOrg1MSP'}, 'peer': {'name': 'peer', 'host': 'network-org-1-peer-1.org-1', 'port': {'internal': 7051, 'external': 7051}, 'docker_core_dir': '/var/hyperledger/fabric_cfg', 'tlsCACerts': '/var/hyperledger/ca/cacert.pem', 'clientKey': '********************', 'clientCert': '/var/hyperledger/tls/client/pair/tls.crt', 'grpcOptions': {'grpc-max-send-message-length': 15, 'grpc.ssl_target_name_override': 'network-org-1-peer-1.org-1'}}, 'requestor': <hfc.fabric.user.User object at 0x7f327278e550>, 'hfc': <function get_hfc_client at 0x7f3276035598>}
LEDGER_CALL_RETRY = True
LEDGER_CONFIG_FILE = '/conf/MyOrg1/substra-backend/conf.json'
LEDGER_MAX_RETRY_TIMEOUT = 5
LEDGER_SYNC_ENABLED = True
LOCALE_PATHS = []
LOGGING = {'version': 1, 'disable_existing_loggers': False, 'formatters': {'verbose': {'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'}, 'simple': {'format': '%(levelname)s - %(asctime)s - %(name)s - %(message)s'}}, 'filters': {'require_debug_false': {'()': 'django.utils.log.RequireDebugFalse'}}, 'handlers': {'mail_admins': {'level': 'ERROR', 'filters': ['require_debug_false'], 'class': 'django.utils.log.AdminEmailHandler'}, 'console': {'level': 'DEBUG', 'class': 'logging.StreamHandler', 'formatter': 'simple'}, 'error_file': {'level': 'INFO', 'filename': '/usr/src/app/backend.log', 'class': 'logging.handlers.RotatingFileHandler', 'maxBytes': 1048576, 'backupCount': 2, 'formatter': 'verbose'}}, 'loggers': {'django.request': {'handlers': ['mail_admins', 'error_file'], 'level': 'INFO', 'propagate': False}, 'events': {'handlers': ['console'], 'level': 'DEBUG', 'propagate': True}}}
LOGGING_CONFIG = 'logging.config.dictConfig'
LOGIN_REDIRECT_URL = '/accounts/profile/'
LOGIN_URL = '/accounts/login/'
LOGOUT_REDIRECT_URL = None
MANAGERS = []
MEDIA_ROOT = '/tmp/org-1/medias/'
MEDIA_URL = '/media/'
MESSAGE_STORAGE = 'django.contrib.messages.storage.fallback.FallbackStorage'
MIDDLEWARE = ['corsheaders.middleware.CorsMiddleware', 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.auth.middleware.RemoteUserMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'libs.SQLPrintingMiddleware.SQLPrintingMiddleware', 'libs.HealthCheckMiddleware.HealthCheckMiddleware']
MIGRATION_MODULES = {}
MONTH_DAY_FORMAT = 'F j'
NUMBER_GROUPING = 0
ORG = 'MyOrg1'
ORG_NAME = 'MyOrg1'
PASSWORD_HASHERS = '********************'
PASSWORD_RESET_TIMEOUT_DAYS = '********************'
PEER_PORT = 7051
PREPEND_WWW = False
PROJECT_ROOT = '/usr/src/app'
REST_FRAMEWORK = {'TEST_REQUEST_DEFAULT_FORMAT': 'json', 'DEFAULT_RENDERER_CLASSES': ('rest_framework.renderers.JSONRenderer', 'rest_framework.renderers.BrowsableAPIRenderer'), 'DEFAULT_AUTHENTICATION_CLASSES': ['users.authentication.SecureJWTAuthentication', 'libs.expiryTokenAuthentication.ExpiryTokenAuthentication', 'libs.sessionAuthentication.CustomSessionAuthentication'], 'DEFAULT_PERMISSION_CLASSES': ['rest_framework.permissions.IsAuthenticated'], 'UNICODE_JSON': False, 'DEFAULT_VERSIONING_CLASS': 'libs.versioning.AcceptHeaderVersioningRequired', 'ALLOWED_VERSIONS': ('0.0',), 'DEFAULT_VERSION': '0.0'}
ROOT_URLCONF = 'backend.urls'
SECRET_FILE = '********************'
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_SAMESITE = 'Lax'
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 = 'backend.settings.server.dev'
SHORT_DATETIME_FORMAT = 'm/d/Y P'
SHORT_DATE_FORMAT = 'm/d/Y'
SIGNING_BACKEND = 'django.core.signing.TimestampSigner'
SILENCED_SYSTEM_CHECKS = []
SIMPLE_JWT = {'ACCESS_TOKEN_LIFETIME': '********************', 'AUTH_HEADER_TYPES': ('JWT',)}
SITE_HOST = 'substra-backend.MyOrg1.xyz'
SITE_ID = 1
SITE_PORT = '8000'
STATICFILES_DIRS = []
STATICFILES_FINDERS = ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder']
STATICFILES_STORAGE = 'django.contrib.staticfiles.storage.StaticFilesStorage'
STATIC_ROOT = None
STATIC_URL = '/static/'
SUBSTRA_FOLDER = '/substra'
TASK = {'CAPTURE_LOGS': True, 'CLEAN_EXECUTION_ENVIRONMENT': True, 'CACHE_DOCKER_IMAGES': False}
TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], 'APP_DIRS': True, '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']}}]
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 = 'UTC'
TRUE_VALUES = {'TRUE', 1, '1', 'on', 'yes', 'true', 'ON', 'YES', 'True', 'Y', 'On', 'y', 't', 'T'}
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 = 'backend.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.
Kelvin-M commented 4 years ago

Where are we on this one ? Maybe @GuillaumeCisco have an idea ?

jmorel commented 4 years ago

Following the merge of #11 I don't have the issue anymore, I now get an expected 400 saying Requests error status 400: {"non_field_errors":["Unable to log in with provided credentials."]}