configuration.example.py 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. #########################
  2. # #
  3. # Required settings #
  4. # #
  5. #########################
  6. # This is a list of valid fully-qualified domain names (FQDNs) for the NetBox server. NetBox will not permit write
  7. # access to the server via any other hostnames. The first FQDN in the list will be treated as the preferred name.
  8. #
  9. # Example: ALLOWED_HOSTS = ['netbox.example.com', 'netbox.internal.local']
  10. ALLOWED_HOSTS = []
  11. # PostgreSQL database configuration. See the Django documentation for a complete list of available parameters:
  12. # https://docs.djangoproject.com/en/stable/ref/settings/#databases
  13. DATABASE = {
  14. 'NAME': 'netbox', # Database name
  15. 'USER': '', # PostgreSQL username
  16. 'PASSWORD': '', # PostgreSQL password
  17. 'HOST': 'localhost', # Database server
  18. 'PORT': '', # Database port (leave blank for default)
  19. 'CONN_MAX_AGE': 300, # Max database connection age
  20. }
  21. # Redis database settings. The Redis database is used for caching and background processing such as webhooks
  22. # Seperate sections for webhooks and caching allow for connecting to seperate Redis instances/datbases if desired.
  23. # Full connection details are required in both sections, even if they are the same.
  24. REDIS = {
  25. 'webhooks': {
  26. 'HOST': 'localhost',
  27. 'PORT': 6379,
  28. # Comment out `HOST` and `PORT` lines and uncomment the following if using Redis Sentinel
  29. # 'SENTINELS': [('mysentinel.redis.example.com', 6379)],
  30. # 'SENTINEL_SERVICE': 'netbox',
  31. 'PASSWORD': '',
  32. 'DATABASE': 0,
  33. 'DEFAULT_TIMEOUT': 300,
  34. 'SSL': False,
  35. },
  36. 'caching': {
  37. 'HOST': 'localhost',
  38. 'PORT': 6379,
  39. # Comment out `HOST` and `PORT` lines and uncomment the following if using Redis Sentinel
  40. # 'SENTINELS': [('mysentinel.redis.example.com', 6379)],
  41. # 'SENTINEL_SERVICE': 'netbox',
  42. 'PASSWORD': '',
  43. 'DATABASE': 1,
  44. 'DEFAULT_TIMEOUT': 300,
  45. 'SSL': False,
  46. }
  47. }
  48. # This key is used for secure generation of random numbers and strings. It must never be exposed outside of this file.
  49. # For optimal security, SECRET_KEY should be at least 50 characters in length and contain a mix of letters, numbers, and
  50. # symbols. NetBox will not run without this defined. For more information, see
  51. # https://docs.djangoproject.com/en/stable/ref/settings/#std:setting-SECRET_KEY
  52. SECRET_KEY = ''
  53. #########################
  54. # #
  55. # Optional settings #
  56. # #
  57. #########################
  58. # Specify one or more name and email address tuples representing NetBox administrators. These people will be notified of
  59. # application errors (assuming correct email settings are provided).
  60. ADMINS = [
  61. # ['John Doe', 'jdoe@example.com'],
  62. ]
  63. # Optionally display a persistent banner at the top and/or bottom of every page. HTML is allowed. To display the same
  64. # content in both banners, define BANNER_TOP and set BANNER_BOTTOM = BANNER_TOP.
  65. BANNER_TOP = ''
  66. BANNER_BOTTOM = ''
  67. # Text to include on the login page above the login form. HTML is allowed.
  68. BANNER_LOGIN = ''
  69. # Base URL path if accessing NetBox within a directory. For example, if installed at http://example.com/netbox/, set:
  70. # BASE_PATH = 'netbox/'
  71. BASE_PATH = ''
  72. # Cache timeout in seconds. Set to 0 to dissable caching. Defaults to 900 (15 minutes)
  73. CACHE_TIMEOUT = 900
  74. # Maximum number of days to retain logged changes. Set to 0 to retain changes indefinitely. (Default: 90)
  75. CHANGELOG_RETENTION = 90
  76. # API Cross-Origin Resource Sharing (CORS) settings. If CORS_ORIGIN_ALLOW_ALL is set to True, all origins will be
  77. # allowed. Otherwise, define a list of allowed origins using either CORS_ORIGIN_WHITELIST or
  78. # CORS_ORIGIN_REGEX_WHITELIST. For more information, see https://github.com/ottoyiu/django-cors-headers
  79. CORS_ORIGIN_ALLOW_ALL = False
  80. CORS_ORIGIN_WHITELIST = [
  81. # 'https://hostname.example.com',
  82. ]
  83. CORS_ORIGIN_REGEX_WHITELIST = [
  84. # r'^(https?://)?(\w+\.)?example\.com$',
  85. ]
  86. # Set to True to enable server debugging. WARNING: Debugging introduces a substantial performance penalty and may reveal
  87. # sensitive information about your installation. Only enable debugging while performing testing. Never enable debugging
  88. # on a production system.
  89. DEBUG = False
  90. # Email settings
  91. EMAIL = {
  92. 'SERVER': 'localhost',
  93. 'PORT': 25,
  94. 'USERNAME': '',
  95. 'PASSWORD': '',
  96. 'TIMEOUT': 10, # seconds
  97. 'FROM_EMAIL': '',
  98. }
  99. # Enforcement of unique IP space can be toggled on a per-VRF basis. To enforce unique IP space within the global table
  100. # (all prefixes and IP addresses not assigned to a VRF), set ENFORCE_GLOBAL_UNIQUE to True.
  101. ENFORCE_GLOBAL_UNIQUE = False
  102. # Exempt certain models from the enforcement of view permissions. Models listed here will be viewable by all users and
  103. # by anonymous users. List models in the form `<app>.<model>`. Add '*' to this list to exempt all models.
  104. EXEMPT_VIEW_PERMISSIONS = [
  105. # 'dcim.site',
  106. # 'dcim.region',
  107. # 'ipam.prefix',
  108. ]
  109. # Enable custom logging. Please see the Django documentation for detailed guidance on configuring custom logs:
  110. # https://docs.djangoproject.com/en/stable/topics/logging/
  111. LOGGING = {}
  112. # Setting this to True will permit only authenticated users to access any part of NetBox. By default, anonymous users
  113. # are permitted to access most data in NetBox (excluding secrets) but not make any changes.
  114. LOGIN_REQUIRED = False
  115. # The length of time (in seconds) for which a user will remain logged into the web UI before being prompted to
  116. # re-authenticate. (Default: 1209600 [14 days])
  117. LOGIN_TIMEOUT = None
  118. # Setting this to True will display a "maintenance mode" banner at the top of every page.
  119. MAINTENANCE_MODE = False
  120. # An API consumer can request an arbitrary number of objects =by appending the "limit" parameter to the URL (e.g.
  121. # "?limit=1000"). This setting defines the maximum limit. Setting it to 0 or None will allow an API consumer to request
  122. # all objects by specifying "?limit=0".
  123. MAX_PAGE_SIZE = 1000
  124. # The file path where uploaded media such as image attachments are stored. A trailing slash is not needed. Note that
  125. # the default value of this setting is derived from the installed location.
  126. # MEDIA_ROOT = '/opt/netbox/netbox/media'
  127. # By default uploaded media is stored on the local filesystem. Using Django-storages is also supported. Provide the
  128. # class path of the storage driver in STORAGE_BACKEND and any configuration options in STORAGE_CONFIG. For example:
  129. # STORAGE_BACKEND = 'storages.backends.s3boto3.S3Boto3Storage'
  130. # STORAGE_CONFIG = {
  131. # 'AWS_ACCESS_KEY_ID': 'Key ID',
  132. # 'AWS_SECRET_ACCESS_KEY': 'Secret',
  133. # 'AWS_STORAGE_BUCKET_NAME': 'netbox',
  134. # 'AWS_S3_REGION_NAME': 'eu-west-1',
  135. # }
  136. # Expose Prometheus monitoring metrics at the HTTP endpoint '/metrics'
  137. METRICS_ENABLED = False
  138. # Credentials that NetBox will uses to authenticate to devices when connecting via NAPALM.
  139. NAPALM_USERNAME = ''
  140. NAPALM_PASSWORD = ''
  141. # NAPALM timeout (in seconds). (Default: 30)
  142. NAPALM_TIMEOUT = 30
  143. # NAPALM optional arguments (see http://napalm.readthedocs.io/en/latest/support/#optional-arguments). Arguments must
  144. # be provided as a dictionary.
  145. NAPALM_ARGS = {}
  146. # Determine how many objects to display per page within a list. (Default: 50)
  147. PAGINATE_COUNT = 50
  148. # When determining the primary IP address for a device, IPv6 is preferred over IPv4 by default. Set this to True to
  149. # prefer IPv4 instead.
  150. PREFER_IPV4 = False
  151. # Remote authentication support
  152. REMOTE_AUTH_ENABLED = False
  153. REMOTE_AUTH_BACKEND = 'utilities.auth_backends.RemoteUserBackend'
  154. REMOTE_AUTH_HEADER = 'HTTP_REMOTE_USER'
  155. REMOTE_AUTH_AUTO_CREATE_USER = True
  156. REMOTE_AUTH_DEFAULT_GROUPS = []
  157. REMOTE_AUTH_DEFAULT_PERMISSIONS = []
  158. # The file path where custom reports will be stored. A trailing slash is not needed. Note that the default value of
  159. # this setting is derived from the installed location.
  160. # REPORTS_ROOT = '/opt/netbox/netbox/reports'
  161. # The file path where custom scripts will be stored. A trailing slash is not needed. Note that the default value of
  162. # this setting is derived from the installed location.
  163. # SCRIPTS_ROOT = '/opt/netbox/netbox/scripts'
  164. # By default, NetBox will store session data in the database. Alternatively, a file path can be specified here to use
  165. # local file storage instead. (This can be useful for enabling authentication on a standby instance with read-only
  166. # database access.) Note that the user as which NetBox runs must have read and write permissions to this path.
  167. SESSION_FILE_PATH = None
  168. # Time zone (default: UTC)
  169. TIME_ZONE = 'UTC'
  170. # Date/time formatting. See the following link for supported formats:
  171. # https://docs.djangoproject.com/en/stable/ref/templates/builtins/#date
  172. DATE_FORMAT = 'N j, Y'
  173. SHORT_DATE_FORMAT = 'Y-m-d'
  174. TIME_FORMAT = 'g:i a'
  175. SHORT_TIME_FORMAT = 'H:i:s'
  176. DATETIME_FORMAT = 'N j, Y g:i a'
  177. SHORT_DATETIME_FORMAT = 'Y-m-d H:i'