configuration.example.py 7.0 KB

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