Style Guide
NetBox generally follows the Django style guide, which is itself based on PEP 8. ruff is used for linting (with certain exceptions).
Code
General Guidance
-
When in doubt, remain consistent: It is better to be consistently incorrect than inconsistently correct. If you notice in the course of unrelated work a pattern that should be corrected, continue to follow the pattern for now and submit a separate bug report so that the entire code base can be evaluated at a later point.
-
Prioritize readability over concision. Python is a very flexible language that typically offers several multiple options for expressing a given piece of logic, but some may be more friendly to the reader than others. (List comprehensions are particularly vulnerable to over-optimization.) Always remain considerate of the future reader who may need to interpret your code without the benefit of the context within which you are writing it.
-
Include a newline at the end of every file.
-
No easter eggs. While they can be fun, NetBox must be considered as a business-critical tool. The potential, however minor, for introducing a bug caused by unnecessary code is best avoided entirely.
-
Constants (variables which do not change) should be declared in
constants.py
within each app. Wildcard imports from the file are acceptable. -
Every model must have a docstring. Every custom method should include an explanation of its function.
-
Nested API serializers generate minimal representations of an object. These are stored separately from the primary serializers to avoid circular dependencies. Always import nested serializers from other apps directly. For example, from within the DCIM app you would write
from ipam.api.nested_serializers import NestedIPAddressSerializer
.
Linting
The ruff linter is used to enforce code style. A pre-commit hook which runs this automatically is included with NetBox. To invoke ruff
manually, run:
ruff check netbox/
Linter Exceptions
The following rules are ignored when linting.
E501: Line too long
NetBox does not enforce a hard restriction on line length, although a maximum length of 120 characters is strongly encouraged for Python code where possible. The maximum length does not apply to HTML templates or to automatically generated code (e.g. database migrations).
F403: Undefined local with import star
Wildcard imports (for example, from .constants import *
) are acceptable under any of the following conditions:
- The library being import contains only constant declarations (e.g.
constants.py
) - The library being imported explicitly defines
__all__
F405: Undefined local with import star usage
The justification for ignoring this rule is the same as F403 above.
Introducing New Dependencies
The introduction of a new dependency is best avoided unless it is absolutely necessary. For small features, it's generally preferable to replicate functionality within the NetBox code base rather than to introduce reliance on an external project. This reduces both the burden of tracking new releases and our exposure to outside bugs and supply chain attacks.
If there's a strong case for introducing a new dependency, it must meet the following criteria:
- Its complete source code must be published and freely accessible without registration.
- Its license must be conducive to inclusion in an open source project.
- It must be actively maintained, with no longer than one year between releases.
- It must be available via the Python Package Index (PyPI).
When adding a new dependency, a short description of the package and the URL of its code repository must be added to base_requirements.txt
. Additionally, a line specifying the package name pinned to the current stable release must be added to requirements.txt
. This ensures that NetBox will install only the known-good release.
Written Works
General Guidance
-
Written material must always meet a reasonable professional standard, with proper grammar, spelling, and punctuation.
-
Use two line breaks between paragraphs.
-
Use only a single space between sentences.
-
All documentation is to be written in Markdown, with modest amounts of HTML permitted where needed to overcome technical limitations.
Branding
-
When referring to NetBox in writing, use the proper form "NetBox," with the letters N and B capitalized. The lowercase form "netbox" should be used in code, filenames, etc. but never "Netbox" or any other deviation.
-
There is an SVG form of the NetBox logo at docs/netbox_logo.svg. It is preferred to use this logo for all purposes as it scales to arbitrary sizes without loss of resolution. If a raster image is required, the SVG logo should be converted to a PNG image of the prescribed size.