Skip to main content

NetBox

NetBox is a network management tool that documents and manages your network infrastructure. You can bring network and device data from NetBox into Brinqa to enhance your network security and provide a comprehensive view of your attack surface.

This document details the information you must provide for the connector to authenticate with NetBox and how to obtain that information from NetBox. See create a data integration for step-by-step instructions on setting up the integration.

Required connection settings

When setting up a data integration, select NetBox from the Connector drop-down. If you cannot find the connector in the drop-down, make sure that you have installed it first. You must provide the following information to authenticate NetBox with Brinqa:

  • Server URL: Your organization's NetBox server URL.

  • API token: The API token associated with the NetBox account, which must have permissions to log in to the API server and return data.

Generate a NetBox API token

For the NetBox connector to use the NetBox API, you must provide an API token. To generate a new token, follow these steps:

  1. Log in to your organization's NetBox server.

  2. Click your user profile in the upper-right corner of the page, and then click API Tokens.

  3. Click Add a token and fill in the fields as shown below:

    • Key: Give your new token a key. If you don't provide a key, NetBox generates one automatically.

    • Write enabled: A NetBox API token can be used to perform all actions via the API that a user is permitted to do via the web UI. As Brinqa only requires read operations, uncheck this box to restrict API requests made with the token to read operations (GET) only.

    • Expires: Set an expiration date and time for the token.

    • Description: Provide a description for the token.

    • Allowed IPs: Specify any Internet Protocol (IP) v4 or v6 addresses allowed by the token. Leave this field blank if there are no restrictions.

  4. Click Create.

    A new API token appears on the API Tokens page. You can view this token later without restrictions, eliminating the need to save it immediately to a secure location. However, it is still important to protect the token and limit access to authorized personnel.

note

For additional information on managing API tokens for your NetBox account and API permissions, see NetBox documentation.

Additional settings

The NetBox connector contains additional options for specific configuration:

  • Set page size: The maximum number of records to get per API request. The default setting is 100. It is not recommended to go over 100.

  • Parallel requests: The maximum number of parallel API requests. The default setting is 4.

Types of data to retrieve

The NetBox connector can retrieve the following types of data from the NetBox API:

Table 1: Data retrieved from NetBox

Connector ObjectRequiredMaps to Data Model
ClusterNoNot mapped
DeviceYesDevice
PrefixesYesSubnet
Virtual LANNoNot mapped
Virtual MachineYesHost
info

The NetBox connector does not currently support operation options for the types of data it retrieves.

For detailed steps on how to view the data retrieved from NetBox in the Brinqa Platform, see How to view your data.

Attribute mappings

Expand the sections below to view the mappings between the source and the Brinqa data model attributes.

Device

Table 2: Device attribute mappings

Source Field NameMaps to Attribute
airflowLocal variable
asset_tagtags
categoriescategories
cluster.idLocal variable
commentsLocal variable
createdfirstSeen
descriptiondescription
device_role.idLocal variable
device_role.nameLocal variable
device_type.idLocal variable
device_type.nameLocal variable
displayLocal variable
faceLocal variable
iduid
last_updatedlastSeen, sourceLastModified
location.idLocal variable
location.nameLocal variable
namename
parent_deviceLocal variable
platform.idLocal variable
platform.nameLocal variable
positionLocal variable
primary_ipipAddresses, publicIpAddresses, privateIpAddresses
primary_ip4ipAddresses, publicIpAddresses, privateIpAddresses
primary_ip6ipAddresses, publicIpAddresses, privateIpAddresses
rack.idLocal variable
rack.nameLocal variable
serialserialNumber
site.idLocal variable
site.nameLocal variable
status.valuestatus, statusCategory
tagstags
tenant.idLocal variable
tenant.nameLocal variable
urlLocal variable
vc_positionLocal variable
vc_priorityLocal variable
virtual_chassis.idLocal variable
virtual_chassis.nameLocal variable
Prefixes

Table 3: Prefixes attribute mappings

Source Field NameMaps to Attribute
_depthLocal variable
categoriescategories
childrenLocal variable
commentsLocal variable
createdfirstSeen
descriptiondescription
displayname
family.labelLocal variable
iduid
is_poolLocal variable
last_updatedlastSeen, sourceLastModified
mark_utilizedLocal variable
prefixLocal variable
role.idLocal variable
role.nameLocal variable
site.idLocal variable
site.nameLocal variable
status.valuestatus, statusCategory
tagstags
tenant.idLocal variable
tenant.nameLocal variable
urlLocal variable
vrf.idLocal variable
vrf.nameLocal variable
vlan.idLocal variable
vlan.nameLocal variable
Virtual Machine

Table 4: Virtual Machine attribute mappings

Source Field NameMaps to Attribute
categoriescategories
cluster.idLocal variable
cluster.nameLocal variable
commentsLocal variable
createdfirstSeen
descriptiondescription
device.idLocal variable
device.nameLocal variable
diskLocal variable
displayLocal variable
iduid
last_updatedlastSeen, sourceLastModified
memoryLocal variable
namehostNames, name
platform.idLocal variable
platform.nameLocal variable
primary_ipipAddresses, publicIpAddresses, privateIpAddresses
primary_ip4ipAddresses, publicIpAddresses, privateIpAddresses
primary_ip6ipAddresses, publicIpAddresses, privateIpAddresses
role.idLocal variable
role.nameLocal variable
site.idLocal variable
site.nameLocal variable
status.valuestatus, statusCategory
tagstags
tenant.idLocal variable
tenant.nameLocal variable
urlLocal variable
vcpusLocal variable
info

Local variable indicates that the field is processed within a specific context, such as a particular workflow or calculation. Unlike other attributes, local variables aren't mapped to the unified data models. They only exist on the source data model.

APIs

The NetBox connector uses the NetBox REST API. Specifically, it uses the following endpoints:

Table 5: NetBox API Endpoints

Connector ObjectAPI Endpoints
ClusterGET /api/virtualization/clusters/
DeviceGET /api/dcim/devices
PrefixesGET /api/ipam/prefixes
Virtual LANGET /api/ipam/vlans
Virtual MachineGET /api/virtualization/virtual-machines

You can view the NetBox REST API documentation by navigating to https://YourNetBoxInstance/api/docs/. For more information, see NetBox documentation.

Changelog

The NetBox connector has undergone the following changes:

Table 6: NetBox connector changelog

VersionDescription
3.0.0Initial Integration+ release.