Skip to main content

VulnDB

VulnDB is a vulnerability management tool that provides details on software, hardware, and vulnerabilities. You can bring product, product version, vendor, and security data from VulnDB into Brinqa to identify, prioritize, and address vulnerabilities within your infrastructure, thus enhancing your cybersecurity strategy and strengthening your cybersecurity posture.

This document details the information you must provide for the connector to authenticate with VulnDB and how to obtain that information from VulnDB. 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 VulnDB from the Connector drop-down. If you cannot find the connector in the drop-down, make sure you have installed it first. You must provide the following information to authenticate VulnDB with Brinqa:

  • API URL: The VulnDB API Server URL. The default URL is https://vulndb.cyberriskanalytics.com.

  • Client ID and Client Secret: The client ID and client secret associated with the VulnDB account, which must have permissions to log in to the API server and return data.

Generate VulnDB client ID and secret

For the VulnDB connector to use the VulnDB REST API, you must register a new application to obtain the client ID and client secret. While you can view the credentials for any registered app within VulnDB, you can also create a new app. To do so, follow these steps:

  1. Log in to the VulnDB portal at https://vulndb.cyberriskanalytics.com.

  2. Click API > Overview.

  3. Locate the OAuth Client Applications section.

  4. Click Register new application. Fill in the following fields:

    • Name: The name of your application.

    • Main Application URL: This field may not have an impact on the functionality of the VulnDB connector. However, it's considered best practice to enter the URL where your Brinqa Platform is hosted, the default URL format being https://<BrinqaPlatformName>.brinqa.net.

  5. Click Register.

    Your new client ID and client secret displays. Make sure to copy the credentials and paste them into the Client ID and Client Secret fields in the integration configuration.

note

If you do not have the permissions to register a new application and create a client ID and client secret, contact your VulnDB administrator.

Additional settings

The VulnDB connector contains additional options for specific configuration:

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

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

Types of data to retrieve

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

Table 1: Data retrieved from VulnDB

Connector ObjectRequiredMaps to Data Model
ProductNoNot mapped
Product VersionNoNot mapped
VendorNoNot mapped
VulnerabilityYesCVE Record
info

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

Attribute mappings

The table below details the mappings between the source and the Brinqa data model attributes.

Table 2: Vulnerability attribute mappings

Source Field NameMaps to Attribute
affected_productsaffected
analysisdescription
change_logdescription
classificationcategories
cpeaffected
cvecveIds, cveRecords
cvss_scorecvssV2BaseScore
cvss_vectorcvssV2Vector
cvss_v3_scorecvssV3BaseScore
cvss_v3_vectorcvssV3Vector
descriptiondescription
disclosure_dateLocal variable
exploit_publish_dateLocal variable
exploit_refsexploits
keywordsLocal variable
last_modifedsourceLastModified
notesdescription
other cvss v2 and v3 fieldsother cvss v2/v3 fields
published_datepublishedDate
referencesreferences
related_vuln_db_idLocal variable
solutionrecommendation
solution_dateLocal variable
sys_iduid
third_party_solution_dateLocal variable
titlename
unaffected_productsLocal variable
vendor_ack_dateLocal variable
vendor_advisoriesLocal variable
vendor_informed_dateLocal 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.

Operation options

The VulnDB connector supports the following operation options. See connector operation options for information about how to apply them.

Table 3: VulnDB connector operation options

Connector ObjectOptionAll Possible ValuesDescriptionExample
Vulnerabilitychangelogtrue, falseRetrieve changelog information related to each vulnerability when set to true. The default is false.Key: changelog Value: true. This key and value combination retrieves changelog information for vulnerabilities.
library_infotrue, falseRetrieve affected library information (if available) related to each vulnerability when set to true. The default is false.Key: library_info Value: true. This key and value combination retrieves information about affected libraries.
package_infotrue, falseRetrieve affected package information (if available) related to each vulnerability when set to true. The default is false.Key: package_info Value: true. This key and value combination retrieves information about affected packages.
note

The option keys and values are case-sensitive as they are shown in this documentation.

APIs

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

Table 4: VulnDB REST API Endpoints

Connector ObjectAPI Endpoints
ProductGET /api/v1/products/modified_products
GET /api/v1/products/new_products
Product VersionGET /api/v1/vulnerabilities/find_next_to_vulndb_id
GET /api/v1/vulnerabilities/find_by_date
GET /api/v1/vulnerabilities/find_by_time
VendorGET /api/v1/vendors/modified_vendors
GET /api/v1/vendors/new_vendors
VulnerabilityGET /api/v1/vulnerabilities/find_next_to_vulndb_id
GET /api/v1/vulnerabilities/find_by_date
GET /api/v1/vulnerabilities/find_by_time

Changelog

The VulnDB connector has undergone the following changes:

Table 5: VulnDB connector changelog

VersionDescription
3.0.5Added a string-to-integer conversion before assigning the value to the AVG_DISCLOSURE_INTERVAL attribute on the Product object.
3.0.4Changed the SHORT_NAME attribute type on the Vendor object from integer to string.
3.0.3Updated to use a consistent format for CVSS vectors.
3.0.2Made the UNAFFECTED_PRODUCTS attribute multi-valued.
3.0.1Enhanced to store all date attributes as Date Time values.
3.0.0Initial Integration+ release.