Hello.
I have issues getting virtual machine interfaces using the API, is
there anyone that know about a solution/workaround?
- netbox-docker 0.26.2
- netbox 2.9.9
- Python 3.8.6
- psql image: postgres:10-alpine, psql (PostgreSQL) 10.14
- apache2 terminating HTTPS and proxying into docker instance
- LDAP auth against OpenLDAD
- Docker version 19.03.12, build 48a66213fe
- Description: Ubuntu 18.04.5 LTS
This works, so token and apache2/https works
# curl -X GET -H "Authorization: Token
<hidden>" -H "Accept: application/json; indent=4"
https://netbox.net.example.com/api/virtualization/virtual-machines/
{
"count": 3,
"next": null,
"previous": null,
"results": [
{
"id": 7,
This does NOT work
# curl -X GET -H "Authorization: Token
<secret>" -H "Accept: application/json; indent=4"
https://netbox.net.example.com/api/virtualization/interfaces/
{"error": "'Access'", "exception":
"KeyError", "netbox_version": "2.9.9", "python_version":
"3.8.6"}
I tried to access the docker instance directly, bypassing https
and apache2, no difference
# curl -X GET -H "Authorization: Token
<hidden>" -H "Accept: application/json; indent=4"
http://127.0.0.1:8080/api/virtualization/interfaces/
{"error": "'Access'", "exception":
"KeyError", "netbox_version": "2.9.9", "python_version":
"3.8.6"}
DEBUG=True
curl -X GET -H "Authorization: Token
<hidden>" -H "Accept: application/json; indent=4"
http://127.0.0.1:8080/api/virtualization/interfaces/
KeyError at /api/virtualization/interfaces/
'Access'
Request Method: GET
Request URL:
http://127.0.0.1:8080/api/virtualization/interfaces/
Django Version: 3.1
Python Executable: /usr/local/bin/python
Python Version: 3.8.6
Python Path: ['/opt/netbox/netbox', '/usr/local/bin',
'/usr/local/lib/python38.zip', '/usr/local/lib/python3.8',
'/usr/local/lib/python3.8/lib-dynload',
'/usr/local/lib/python3.8/site-packages']
Server time: Wed, 11 Nov 2020 14:43:10 +0000
Installed Applications:
['django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.humanize',
'cacheops',
'corsheaders',
'debug_toolbar',
'django_filters',
'django_tables2',
'django_prometheus',
'mptt',
'rest_framework',
'taggit',
'timezone_field',
'circuits',
'dcim',
'ipam',
'extras',
'secrets',
'tenancy',
'users',
'utilities',
'virtualization',
'django_rq',
'drf_yasg']
Installed Middleware:
['debug_toolbar.middleware.DebugToolbarMiddleware',
'django_prometheus.middleware.PrometheusBeforeMiddleware',
'corsheaders.middleware.CorsMiddleware',
'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.security.SecurityMiddleware',
'utilities.middleware.ExceptionHandlingMiddleware',
'utilities.middleware.RemoteUserMiddleware',
'utilities.middleware.LoginRequiredMiddleware',
'utilities.middleware.APIVersionMiddleware',
'extras.middleware.ObjectChangeMiddleware',
'django_prometheus.middleware.PrometheusAfterMiddleware']
Traceback (most recent call last):
File
"/usr/local/lib/python3.8/site-packages/django/core/handlers/exception.py",
line 47, in inner
response = get_response(request)
File
"/usr/local/lib/python3.8/site-packages/django/core/handlers/base.py",
line 179, in _get_response
response = wrapped_callback(request, *callback_args,
**callback_kwargs)
File
"/usr/local/lib/python3.8/site-packages/django/views/decorators/csrf.py",
line 54, in wrapped_view
return view_func(*args, **kwargs)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/viewsets.py",
line 114, in view
return self.dispatch(request, *args, **kwargs)
File "/opt/netbox/netbox/utilities/api.py", line 344, in dispatch
return super().dispatch(request, *args, **kwargs)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/views.py",
line 505, in dispatch
response = self.handle_exception(exc)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/views.py",
line 465, in handle_exception
self.raise_uncaught_exception(exc)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/views.py",
line 476, in raise_uncaught_exception
raise exc
File
"/usr/local/lib/python3.8/site-packages/rest_framework/views.py",
line 502, in dispatch
response = handler(request, *args, **kwargs)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/mixins.py",
line 43, in list
return self.get_paginated_response(serializer.data)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/serializers.py",
line 760, in data
ret = super().data
File
"/usr/local/lib/python3.8/site-packages/rest_framework/serializers.py",
line 260, in data
self._data = self.to_representation(self.instance)
File
"/usr/local/lib/python3.8/site-packages/rest_framework/serializers.py",
line 677, in to_representation
return [
File
"/usr/local/lib/python3.8/site-packages/rest_framework/serializers.py",
line 678, in <listcomp>
self.child.to_representation(item) for item in iterable
File
"/usr/local/lib/python3.8/site-packages/rest_framework/serializers.py",
line 529, in to_representation
ret[field.field_name] = field.to_representation(attribute)
File "/opt/netbox/netbox/utilities/api.py", line 120, in
to_representation
('label', self._choices[obj])
Exception Type: KeyError at /api/virtualization/interfaces/
Exception Value: 'Access'
Request information:
USER: anders2
GET: No GET data
POST: No POST data
FILES: No FILES data
COOKIES: No cookie data
META:
HTTP_ACCEPT = 'application/json; indent=4'
HTTP_AUTHORIZATION = 'Token
cdb65147c23915453b34b3e49a24178c29c53db3'
HTTP_CONNECTION = 'close'
HTTP_HOST = 'netbox:8001'
HTTP_USER_AGENT = 'curl/7.58.0'
HTTP_X_FORWARDED_HOST = '
127.0.0.1:8080'
HTTP_X_FORWARDED_PROTO = 'http'
HTTP_X_REAL_IP = '172.17.8.1'
PATH_INFO = '/api/virtualization/interfaces/'
QUERY_STRING = ''
RAW_URI = '/api/virtualization/interfaces/'
REMOTE_ADDR = '172.17.8.7'
REMOTE_PORT = '48960'
REQUEST_METHOD = 'GET'
SCRIPT_NAME = ''
SERVER_NAME = '0.0.0.0'
SERVER_PORT = '8001'
SERVER_PROTOCOL = 'HTTP/1.0'
SERVER_SOFTWARE = 'gunicorn/20.0.4'
gunicorn.socket = <socket.socket fd=9,
family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0,
laddr=('172.17.8.6', 8001), raddr=('172.17.8.7', 48960)>
wsgi.errors = <gunicorn.http.wsgi.WSGIErrorsWrapper object at
0x7fc0a0fbb700>
wsgi.file_wrapper = <class 'gunicorn.http.wsgi.FileWrapper'>
wsgi.input = <gunicorn.http.body.Body object at
0x7fc0a0fbbb80>
wsgi.input_terminated = True
wsgi.multiprocess = True
wsgi.multithread = False
wsgi.run_once = False
wsgi.url_scheme = 'http'
wsgi.version = '(1, 0)'
Settings:
Using settings module netbox.settings
ABSOLUTE_URL_OVERRIDES = {}
ADMINS = []
ALLOWED_HOSTS = ['*']
ALLOWED_URL_SCHEMES = "('file', 'ftp', 'ftps', 'http', 'https',
'irc', 'mailto', 'sftp', 'ssh', 'tel', 'telnet', 'tftp', 'vnc',
'xmpp')"
APPEND_SLASH = True
AUTHENTICATION_BACKENDS = ['netbox.authentication.LDAPBackend',
'netbox.authentication.ObjectPermissionBackend']
AUTH_PASSWORD_VALIDATORS = '********************'
AUTH_USER_MODEL = 'auth.User'
BANNER_BOTTOM = ''
BANNER_LOGIN = ''
BANNER_TOP = ''
BASE_DIR = '/opt/netbox/netbox'
BASE_PATH = ''
CACHEOPS = {'auth.user': {'ops': 'get', 'timeout': 900}, 'auth.*':
{'ops': ('fetch', 'get')}, 'auth.permission': {'ops': 'all'},
'circuits.*': {'ops': 'all'}, 'dcim.region': None, 'dcim.rackgroup':
None, 'dcim.*': {'ops': 'all'}, 'ipam.*': {'ops': 'all'},
'extras.*': {'ops': 'all'}, 'secrets.*': '********************',
'users.*': {'ops': 'all'}, 'tenancy.tenantgroup': None, 'tenancy.*':
{'ops': 'all'}, 'virtualization.*': {'ops': 'all'}}
CACHEOPS_DEFAULTS = {'timeout': 900}
CACHEOPS_DEGRADE_ON_FAILURE = True
CACHEOPS_ENABLED = True
CACHEOPS_REDIS = 'redis://:t4Ph722qJ5QHeQ1qfu36@redis-cache:6379/1'
CACHES = {'default': {'BACKEND':
'django.core.cache.backends.locmem.LocMemCache'}}
CACHE_MIDDLEWARE_ALIAS = 'default'
CACHE_MIDDLEWARE_KEY_PREFIX = '********************'
CACHE_MIDDLEWARE_SECONDS = 600
CACHE_TIMEOUT = 900
CACHING_REDIS = {'HOST': 'redis-cache', 'PORT': 6379, 'PASSWORD':
'********************', 'DATABASE': 1, 'SSL': False}
CACHING_REDIS_DATABASE = 1
CACHING_REDIS_HOST = 'redis-cache'
CACHING_REDIS_PASSWORD = '********************'
CACHING_REDIS_PORT = 6379
CACHING_REDIS_SENTINELS = []
CACHING_REDIS_SENTINEL_SERVICE = 'default'
CACHING_REDIS_SSL = False
CACHING_REDIS_USING_SENTINEL = False
CHANGELOG_RETENTION = 90
CORS_ORIGIN_ALLOW_ALL = True
CORS_ORIGIN_REGEX_WHITELIST = []
CORS_ORIGIN_WHITELIST = ['
https://localhost']
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
DATABASE = {'NAME': 'netbox', 'USER': 'netbox', 'PASSWORD':
'********************', 'HOST': 'postgres', 'PORT': '', 'OPTIONS':
{'sslmode': 'prefer'}, 'CONN_MAX_AGE': 300, 'ENGINE':
'django.db.backends.postgresql', 'ATOMIC_REQUESTS': False,
'AUTOCOMMIT': True, 'TIME_ZONE': None, 'TEST': {'CHARSET': None,
'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}}
DATABASES = {'default': {'NAME': 'netbox', 'USER': 'netbox',
'PASSWORD': '********************', 'HOST': 'postgres', 'PORT': '',
'OPTIONS': {'sslmode': 'prefer'}, 'CONN_MAX_AGE': 300, 'ENGINE':
'django.db.backends.postgresql', 'ATOMIC_REQUESTS': False,
'AUTOCOMMIT': True, 'TIME_ZONE': None, 'TEST': {'CHARSET': None,
'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}}}
DATABASE_ROUTERS = []
DATA_UPLOAD_MAX_MEMORY_SIZE = 2621440
DATA_UPLOAD_MAX_NUMBER_FIELDS = None
DATETIME_FORMAT = 'N j, Y g:i a'
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_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 = ''
DEVELOPER = False
DISALLOWED_USER_AGENTS = []
DOCS_ROOT = '/opt/netbox/docs'
EMAIL = {'SERVER': 'localhost', 'PORT': 25, 'USERNAME': '',
'PASSWORD': '********************', 'USE_SSL': False, 'USE_TLS':
False, 'SSL_CERTFILE': '', 'SSL_KEYFILE': '********************',
'TIMEOUT': 5, 'FROM_EMAIL': '
net...@net.example.com'}
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'localhost'
EMAIL_HOST_PASSWORD = '********************'
EMAIL_HOST_USER = ''
EMAIL_PORT = 25
EMAIL_SSL_CERTFILE = ''
EMAIL_SSL_KEYFILE = '********************'
EMAIL_SUBJECT_PREFIX = '[NetBox] '
EMAIL_TIMEOUT = 5
EMAIL_USE_LOCALTIME = False
EMAIL_USE_SSL = False
EMAIL_USE_TLS = False
ENFORCE_GLOBAL_UNIQUE = True
EXEMPT_EXCLUDE_MODELS = "(('auth', 'group'), ('auth', 'user'),
('users', 'objectpermission'))"
EXEMPT_VIEW_PERMISSIONS = []
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
FILTERS_NULL_CHOICE_LABEL = 'None'
FILTERS_NULL_CHOICE_VALUE = 'null'
FIRST_DAY_OF_WEEK = 0
FIXTURE_DIRS = []
FORCE_SCRIPT_NAME = None
FORMAT_MODULE_PATH = None
FORM_RENDERER = 'django.forms.renderers.DjangoTemplates'
HOSTNAME = '8ac7933f46c8'
HTTP_PROXIES = None
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.humanize', 'cacheops', 'corsheaders',
'debug_toolbar', 'django_filters', 'django_tables2',
'django_prometheus', 'mptt', 'rest_framework', 'taggit',
'timezone_field', 'circuits', 'dcim', 'ipam', 'extras', 'secrets',
'tenancy', 'users', 'utilities', 'virtualization', 'django_rq',
'drf_yasg']
INTERNAL_IPS = "('127.0.0.1', '::1')"
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 = {}
LOGGING_CONFIG = 'logging.config.dictConfig'
LOGIN_REDIRECT_URL = '/accounts/profile/'
LOGIN_REQUIRED = True
LOGIN_TIMEOUT = None
LOGIN_URL = '/login/'
LOGOUT_REDIRECT_URL = None
MAINTENANCE_MODE = False
MANAGERS = []
MAX_PAGE_SIZE = 1000
MEDIA_ROOT = '/opt/netbox/netbox/media'
MEDIA_URL = '/media/'
MESSAGE_STORAGE =
'django.contrib.messages.storage.fallback.FallbackStorage'
MESSAGE_TAGS = {40: 'danger'}
METRICS_ENABLED = False
MIDDLEWARE = ['debug_toolbar.middleware.DebugToolbarMiddleware',
'django_prometheus.middleware.PrometheusBeforeMiddleware',
'corsheaders.middleware.CorsMiddleware',
'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.security.SecurityMiddleware',
'utilities.middleware.ExceptionHandlingMiddleware',
'utilities.middleware.RemoteUserMiddleware',
'utilities.middleware.LoginRequiredMiddleware',
'utilities.middleware.APIVersionMiddleware',
'extras.middleware.ObjectChangeMiddleware',
'django_prometheus.middleware.PrometheusAfterMiddleware']
MIGRATION_MODULES = {}
MONTH_DAY_FORMAT = 'F j'
NAPALM_ARGS = {}
NAPALM_PASSWORD = '********************'
NAPALM_TIMEOUT = 10
NAPALM_USERNAME = ''
NUMBER_GROUPING = 0
PAGINATE_COUNT = 50
PASSWORD_HASHERS = '********************'
PASSWORD_RESET_TIMEOUT = '********************'
PASSWORD_RESET_TIMEOUT_DAYS = '********************'
PER_PAGE_DEFAULTS = [25, 50, 100, 250, 500, 1000]
PLUGINS = []
PLUGINS_CONFIG = {}
PREFER_IPV4 = False
PREPEND_WWW = False
PROMETHEUS_EXPORT_MIGRATIONS = False
RACK_ELEVATION_DEFAULT_UNIT_HEIGHT = 22
RACK_ELEVATION_DEFAULT_UNIT_WIDTH = 220
REDIS = {'tasks': {'HOST': 'redis', 'PORT': 6379, 'PASSWORD':
'********************', 'DATABASE': 0, 'SSL': False}, 'caching':
{'HOST': 'redis-cache', 'PORT': 6379, 'PASSWORD':
'********************', 'DATABASE': 1, 'SSL': False}}
REDIS_CACHE_CON_STRING =
'redis://:t4Ph722qJ5QHeQ1qfu36@redis-cache:6379/1'
RELEASE_CHECK_TIMEOUT = 86400
RELEASE_CHECK_URL =
'
https://api.github.com/repos/netbox-community/netbox/releases'
REMOTE_AUTH_AUTO_CREATE_USER = True
REMOTE_AUTH_BACKEND = 'netbox.authentication.LDAPBackend'
REMOTE_AUTH_DEFAULT_GROUPS = []
REMOTE_AUTH_DEFAULT_PERMISSIONS = {}
REMOTE_AUTH_ENABLED = True
REMOTE_AUTH_HEADER = 'HTTP_REMOTE_USER'
REPORTS_ROOT = '/etc/netbox/reports'
REST_FRAMEWORK = {'ALLOWED_VERSIONS': ['2.9'],
'DEFAULT_AUTHENTICATION_CLASSES':
('rest_framework.authentication.SessionAuthentication',
'netbox.api.TokenAuthentication'), 'DEFAULT_FILTER_BACKENDS':
('django_filters.rest_framework.DjangoFilterBackend',),
'DEFAULT_PAGINATION_CLASS':
'netbox.api.OptionalLimitOffsetPagination',
'DEFAULT_PERMISSION_CLASSES': ('netbox.api.TokenPermissions',),
'DEFAULT_RENDERER_CLASSES':
('rest_framework.renderers.JSONRenderer',
'netbox.api.FormlessBrowsableAPIRenderer'), 'DEFAULT_VERSION':
'2.9', 'DEFAULT_VERSIONING_CLASS':
'rest_framework.versioning.AcceptHeaderVersioning', 'PAGE_SIZE': 50,
'VIEW_NAME_FUNCTION': 'netbox.api.get_view_name'}
REST_FRAMEWORK_VERSION = '2.9'
ROOT_URLCONF = 'netbox.urls'
RQ_DEFAULT_TIMEOUT = 300
RQ_PARAMS = {'HOST': 'redis', 'PORT': 6379, 'DB': 0, 'PASSWORD':
'********************', 'SSL': False, 'DEFAULT_TIMEOUT': 300}
RQ_QUEUES = {'default': {'HOST': 'redis', 'PORT': 6379, 'DB': 0,
'PASSWORD': '********************', 'SSL': False, 'DEFAULT_TIMEOUT':
300}, 'check_releases': {'HOST': 'redis', 'PORT': 6379, 'DB': 0,
'PASSWORD': '********************', 'SSL': False, 'DEFAULT_TIMEOUT':
300}}
SCRIPTS_ROOT = '/etc/netbox/scripts'
SECRETS_MIN_PUBKEY_SIZE = '********************'
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 = "('HTTP_X_FORWARDED_PROTO', 'https')"
SECURE_REDIRECT_EXEMPT = []
SECURE_REFERRER_POLICY = 'same-origin'
SECURE_SSL_HOST = None
SECURE_SSL_REDIRECT = False
SERVER_EMAIL = '
net...@net.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_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 = 'netbox.settings'
SHORT_DATETIME_FORMAT = 'Y-m-d H:i'
SHORT_DATE_FORMAT = 'Y-m-d'
SHORT_TIME_FORMAT = 'H:i:s'
SIGNING_BACKEND = 'django.core.signing.TimestampSigner'
SILENCED_SYSTEM_CHECKS = []
STATICFILES_DIRS = "('/opt/netbox/netbox/project-static',)"
STATICFILES_FINDERS =
['django.contrib.staticfiles.finders.FileSystemFinder',
'django.contrib.staticfiles.finders.AppDirectoriesFinder']
STATICFILES_STORAGE =
'django.contrib.staticfiles.storage.StaticFilesStorage'
STATIC_ROOT = '/opt/netbox/netbox/static'
STATIC_URL = '/static/'
STORAGE_BACKEND = None
STORAGE_CONFIG = {}
SWAGGER_SETTINGS = {'DEFAULT_AUTO_SCHEMA_CLASS':
'utilities.custom_inspectors.NetBoxSwaggerAutoSchema',
'DEFAULT_FIELD_INSPECTORS':
['utilities.custom_inspectors.JSONFieldInspector',
'utilities.custom_inspectors.NullableBooleanFieldInspector',
'utilities.custom_inspectors.CustomChoiceFieldInspector',
'utilities.custom_inspectors.SerializedPKRelatedFieldInspector',
'drf_yasg.inspectors.CamelCaseJSONFilter',
'drf_yasg.inspectors.ReferencingSerializerInspector',
'drf_yasg.inspectors.RelatedFieldInspector',
'drf_yasg.inspectors.ChoiceFieldInspector',
'drf_yasg.inspectors.FileFieldInspector',
'drf_yasg.inspectors.DictFieldInspector',
'drf_yasg.inspectors.SerializerMethodFieldInspector',
'drf_yasg.inspectors.SimpleFieldInspector',
'drf_yasg.inspectors.StringDefaultFieldInspector'],
'DEFAULT_FILTER_INSPECTORS':
['drf_yasg.inspectors.CoreAPICompatInspector'], 'DEFAULT_INFO':
'netbox.urls.openapi_info', 'DEFAULT_MODEL_DEPTH': 1,
'DEFAULT_PAGINATOR_INSPECTORS':
['utilities.custom_inspectors.NullablePaginatorInspector',
'drf_yasg.inspectors.DjangoRestResponsePagination',
'drf_yasg.inspectors.CoreAPICompatInspector'],
'SECURITY_DEFINITIONS': {'Bearer': {'type': 'apiKey', 'name':
'Authorization', 'in': 'header'}}, 'VALIDATOR_URL': None}
TASKS_REDIS = {'HOST': 'redis', 'PORT': 6379, 'PASSWORD':
'********************', 'DATABASE': 0, 'SSL': False}
TASKS_REDIS_DATABASE = 0
TASKS_REDIS_HOST = 'redis'
TASKS_REDIS_PASSWORD = '********************'
TASKS_REDIS_PORT = 6379
TASKS_REDIS_SENTINELS = []
TASKS_REDIS_SENTINEL_SERVICE = 'default'
TASKS_REDIS_SENTINEL_TIMEOUT = 10
TASKS_REDIS_SSL = False
TASKS_REDIS_USING_SENTINEL = False
TEMPLATES = [{'BACKEND':
'django.template.backends.django.DjangoTemplates', 'DIRS':
['/opt/netbox/netbox/templates'], 'APP_DIRS': True, 'OPTIONS':
{'context_processors': ['django.template.context_processors.debug',
'django.template.context_processors.request',
'django.template.context_processors.media',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
'utilities.context_processors.settings_and_registry']}}]
TEMPLATES_DIR = '/opt/netbox/netbox/templates'
TEST_NON_SERIALIZED_APPS = []
TEST_RUNNER = 'django.test.runner.DiscoverRunner'
THOUSAND_SEPARATOR = ','
TIME_FORMAT = 'g:i a'
TIME_INPUT_FORMATS = ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M']
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = False
USE_THOUSAND_SEPARATOR = False
USE_TZ = True
USE_X_FORWARDED_HOST = True
USE_X_FORWARDED_PORT = False
VERSION = '2.9.9'
WSGI_APPLICATION = 'netbox.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.
--
MVH / Regards
Anders Löwinger