Custom Fields¶
Each model in Nautobot is represented in the database as a discrete table, and each attribute of a model exists as a column within its table. For example, locations are stored in the dcim_location table, which has columns named name, facility, physical_address, and so on. As new attributes are added to objects throughout the development of Nautobot, tables are expanded to include new columns.
However, some users might want to store additional object attributes that are somewhat esoteric in nature, and that would not make sense to include in the core Nautobot database schema. For instance, suppose your organization needs to associate each device with a ticket number correlating it with an internal support system record. This is certainly a legitimate use for Nautobot, but it's not a common enough need to warrant including a field for every Nautobot installation. Instead, you can create a custom field to hold this data.
Within the database, custom fields are stored as JSON data directly alongside each object. This alleviates the need for complex queries when retrieving objects.
Creating Custom Fields¶
Custom fields can be created through the UI under Extensibility > Miscellaneous > Custom Fields or through the REST API.
Nautobot supports these custom field types:
- Text: Free-form text (up to 255 characters)
- Integer: A whole number (positive or negative)
- Boolean: True or false
- Date: A date in ISO 8601 format (YYYY-MM-DD)
- URL: This will be presented as a link in the web UI
- JSON: Arbitrary JSON data
- Selection: A selection of one of several pre-defined custom choices
- Multiple selection: A selection field which supports the assignment of multiple values
Added in version 1.3.0
Support for JSON-type custom fields was added.
Each custom field must have a key; this should be a simple database-friendly string, e.g. tps_report. You may also assign a corresponding human-friendly label (e.g. "TPS report"); the label will be displayed on web forms. A weight is also required: Higher-weight fields will be ordered lower within a form. (The default weight is 100.) If a description is provided, it will appear beneath the field in a form.
Changed in version 1.4.0
Custom fields now have both a name and a slug; in older versions there was no slug field. When migrating existing data to Nautobot 1.4.0 or later, the label and slug will be automatically populated for existing custom fields if necessary.
Changed in version 2.0.0
The custom field slug has been renamed to key, and name to label, in order to provide more clarity around their usage. Existing custom fields will automatically be migrated when upgrading to Nautobot 2.0.0 or later.
Additionally, the key now must be a valid GraphQL identifier, which in general means that it must start with a lowercase letter and contain only lowercase letters, numbers, and underscores.
Note
The key and type of a custom field cannot be modified once created, so take care in defining these fields. This helps to reduce the possibility of inconsistent data and enforces the importance of thinking about the data model when defining a new custom field.
Marking a field as required will force the user to provide a value for the field when creating a new object or when saving an existing object. A default value for the field may also be provided. Use "true" or "false" for boolean fields, or the exact value of a choice for selection fields.
The filter logic controls how values are matched when filtering objects by the custom field. Loose filtering (the default) matches on a partial value, whereas exact matching requires a complete match of the given string to a field's value. For example, exact filtering with the string "red" will only match the exact value "red", whereas loose filtering will match on the values "red", "red-orange", or "bored". Setting the filter logic to "disabled" disables filtering by the field entirely.
Changed in version 1.4.0
Custom field extended filtering introduced extended lookup expression filters for exact and icontains, duplicating the functionality of both the Strict and Loose settings.
A custom field must be assigned to one or more object types, or models, in Nautobot. Once created, custom fields will automatically appear as part of these models in the web UI and REST API.
When creating a custom field, if "Move to Advanced tab" is checked, this custom field won't appear on the object's main detail tab in the UI, but will appear in the "Advanced" tab. This is useful when the requirement is to hide this field from the main detail tab when, for instance, it is only required for machine-to-machine communication and not user consumption.
Custom Field Validation¶
Nautobot supports limited custom validation for custom field values. Following are the types of validation enforced for each field type:
- Text: Regular expression (optional)
- URL: Regular expression (optional)
- Integer: Minimum and/or maximum value (optional)
- JSON: If not empty, this field must contain valid JSON data
- Selection: Must exactly match one of the prescribed choices- Selection Fields: Regular expression (optional)
 
Custom Selection Fields¶
Choices are stored as independent values and are assigned a numeric weight which affects their ordering in selection lists and dropdowns. Note that choice values are saved exactly as they appear, so it's best to avoid superfluous punctuation or symbols where possible.
A regular expression can optionally be defined on custom selection choices to validate the defined field choices in the user interface and the API.
If a default value is specified for a selection field, it must exactly match one of the provided choices. Note that the default value can only be set on the custom field after its corresponding choice has been added.
The value of a multiple selection field will always return a list, even if only one value is selected.
Filtering on Custom Fields¶
There are a number of available built-in filters for custom fields.
Filtering on an object's list view follows the same pattern as custom field filtering on the API.
When using the ORM, you can filter on custom fields using _custom_field_data__<field name> (note the underscore before custom_field_data and the double-underscore before the field name). For example, if a custom field of string type with a name of  "location_code" was created for Location objects, you could filter as follows:
from nautobot.dcim.models import Location
all_locs = Location.objects.all()  # -> ['Raleigh', 'Charlotte', 'Greensboro']
filtered_locs_1 = Location.objects.filter(_custom_field_data__location_code="US-NC-RAL42")  # -> ['Raleigh']
filtered_locs_2 = Location.objects.filter(_custom_field_data__location_code__in=["US-NC-RAL42", "US-NC-CLT22"])  # -> ['Raleigh', 'Charlotte']
For further ORM interaction with custom fields check out the custom fields user guide.
Custom Fields and the REST API¶
When retrieving an object via the REST API, all of its custom field data will be included within the custom_fields attribute. For example, below is the partial output of a location with two custom fields defined:
{
    "id": 42568d63-0f8c-453f-8d13-1355f677af4e,
    "url": "http://localhost:8080/api/dcim/locations/42568d63-0f8c-453f-8d13-1355f677af4e/",
    "name": "Raleigh 42",
    ...
    "custom_fields": {
        "deployed": "2018-06-19",
        "location_code": "US-NC-RAL42"
    },
    ...
Changed in version 2.0.0
In the Nautobot 1.x REST API, depending on the exact API version in use, the custom_fields dictionary would be keyed by either the name or the slug of each custom field. In Nautobot 2.0, this has been standardized and the dictionary keys will always correspond to the custom field's key strings.
To set or change custom field values, simply include nested JSON data in your REST API POST, PATCH, or PUT request. Unchanged fields may be omitted from the data. For example, the below would set a value for the deployed custom field but would leave the location_code value unchanged:
Custom Fields User Guide¶
More in depth documentation on how to use custom fields can be found in the custom fields user guide.