Skip to main content

Qualys Policy Compliance Reporting Service

Qualys Policy Compliance Reporting Service (PCRS) is a compliance management tool within the Qualys Policy Compliance module, focused specifically on generating reports for compliance status and activities. You can bring host, policy, and violation data from Qualys into Brinqa to gain insights into your compliance posture, thus strengthening your cybersecurity posture.

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

note

Qualys recommends the Qualys PCRS connector for users with larger volumes of data due to its ability to generate reports faster. Although PCRS offers fewer fields than the Qualys Policy Compliance connector, it is optimized for speed and efficiency.

Required connection settings

When setting up a data integration, select Qualys Policy Compliance Reporting Service from the Connector drop-down. You must provide the following information to authenticate Qualys with Brinqa:

  • API Server URL: The Qualys platform API Server URL. For information on how to determine your Qualys API URL, see Qualys documentation.

  • Username and Password: The user name and password associated with the Qualys user, which must have permissions to log in to the API server and return data.

Create a Qualys user

To ensure the user account that the Qualys PCRS connector uses to access the Qualys server has the appropriate permissions, follow these steps.

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

  2. Navigate to Users, and then select the Users tab.

  3. Click New and select User. The New User dialog displays.

    Qualys VM New User

  4. Fill out the general information.

  5. Click User Role on the left menu.

    • From the User Role drop-down, select Reader.

    • Select GUI and API to enable API access, and leave Business Unit as Unassigned.

      note

      GUI access allows the user to log in to the Qualys GUI (graphical user interface). After you create the new Qualys user, log in to the Qualys GUI using the new credentials. The system prompts the user to reset their password. The Qualys connector will not function until you complete the password reset.

      Qualys VM User Role settings

  6. Click Asset Groups.

    • From the Add asset groups drop-down, select All or only the asset groups the Qualys user needs access to.
  7. Click Permissions and select all of the available permissions.

  8. Click Options to modify the notification options as needed.

  9. Click Save.

The new Qualys user with appropriate permissions to retrieve data displays on the Qualys Users page.

If you do not wish to create a new Qualys user, you can leverage an existing user with the appropriate permissions.

note

If you do not have permissions to create a new Qualys user, contact your Qualys administrator. For additional information, see Qualys documentation.

Additional settings

The Qualys PCRS connector contains additional options for specific configuration:

  • 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 2.

  • Maximum retries: The maximum number of times that the integration attempts to connect to the Qualys API before giving up and reporting a failure. The default setting is 5.

Types of data to retrieve

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

Table 1: Data retrieved from Qualys

Connector ObjectRequiredMaps to Data Model
HostYesHost
PolicyNoNot mapped
ViolationYesViolation
Violation DefinitionYesViolation
info

For detailed steps on how to view the data retrieved from Qualys PCRS 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.

Host

Table 2: Host attribute mappings

Source Field NameMaps to Attribute
assetIdLocal variable
Categoriescategories
complianceLastScanDatelastScanned
dnspublicDnsNames, privateDnsNames
domainNameLocal variable
hostIduid
instanceLocal variable
ippublicIpAddresses, privateIpAddresses, ipAddresses(calculate)
networkIdLocal variable
networkNameLocal variable
netBiosLocal variable
osos
Violation

Table 3: Violation attribute mappings

Source Field NameMaps to Attribute
causeOfFailure.missingLocal variable
causeOfFailure.missing.logicLocal variable
causeOfFailure.unexpectedLocal variable
controlIdtype
evidence.extendedEvidenceLocal variable
firstFailDatefirstFailed
firstPassDatefirstPassed
hostIdtargets
iduid
instanceLocal variable
lastFailDatelastFailed
lastPassDatelastPassed
netBiosLocal variable
policyIduid
postureModifiedDatesourceLastModified
previousStatusstatus, statusCategory
statusstatus, statusCategory
Violation Definition

Table 3: Violation Definition attribute mappings

Source Field NameMaps to Attribute
controlIduid
createdsourceCreatedDate
criticality.valueseverity(normalized), severityScore, sourceSeverity
instanceLocal variable
netBiosLocal variable
policyIduid
policyTitleLocal variable
postureModifiedDatesourceLastModified
rationaledescription
remediationrecommendation
technologyLocal 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 Qualys PCRS connector supports the following operation options. See connector operation options for information about how to apply them.

Table 5: Qualys PCRS connector operation options

Connector ObjectOptionAll Possible ValuesDescriptionExample
Hostpolicy_idsAny Qualys policy IDsA comma-separated list of Qualys policy IDs. Retrieve hosts associated with the specified policy IDs.Key: policy_ids Value: 123456,789012. This key and value combination only retrieves hosts associated with the specified policy IDs.
Violationpolicy_idsAny Qualys policy IDsA comma-separated list of Qualys policy IDs. Retrieve violations associated with the specified policy IDs.Key: policy_ids Value: 234567,890123. This key and value combination only retrieves violations associated with the specified policy IDs.
Violation Definitionpolicy_idsAny Qualys policy IDsA comma-separated list of Qualys policy IDs. Retrieve violation definitions associated with the specified policy IDs.Key: policy_ids Value: 345678,901234. This key and value combination only retrieves violation definitions associated with the specified policy IDs.
Policypolicy_idsAny Qualys policy IDsA comma-separated list of Qualys policy IDs. Retrieve policies associated with the specified policy IDs.Key: policy_ids Value: 456789,012345. This key and value combination only retrieves policies associated with the specified policy IDs.

APIs

The Qualys PCRS connector uses the Qualys PCRS API v1 and v2. Specifically, it uses the following endpoints:

Table 6: Qualys PCRS API Endpoints

Connector ObjectAPI Endpoints
HostGET pcrs/1.0/posture/hostids
GET pcrs/1.0/posture/policy/list
GET pcrs/2.0/posture/postureInfo
PolicyGET pcrs/1.0/posture/hostids
GET pcrs/1.0/posture/policy/list
GET pcrs/2.0/posture/postureInfo
ViolationGET pcrs/1.0/posture/hostids
GET pcrs/1.0/posture/policy/list
GET pcrs/2.0/posture/postureInfo
Violation DefinitionGET pcrs/1.0/posture/hostids
GET pcrs/1.0/posture/policy/list
GET pcrs/2.0/posture/postureInfo

Changelog

The Qualys PCRS connector has undergone the following changes:

Table 7: Qualys PCRS connector changelog

VersionDescription
5.3.9No change.
5.3.8Increased the read timeout to 3 minutes to improve sync reliability and address performance issues.
5.3.7- Fixed an issue where the Qualys PCRS sync was failing.
- Performance improvements for the Violation object sync.
5.3.6No change.
5.3.5No change.
5.3.4No change.
5.3.3No change.
5.3.2No change.
5.3.1- Changed the TARGETS attribute type on the Violation object from long to string.
- Changed the POLICY_ID attribute type on the Violation Definition object from long to string.
5.2.0Initial Integration+ release.