Skip to main content

ServiceNow

ServiceNow is a cloud-based, IT service management tool that provides records for incidents, problems, and assets. You can bring application, asset, business service, device, group, incident and more data from ServiceNow into Brinqa and in turn, use this information to make more informed decisions about your risk management, thus strengthening your cybersecurity posture. You can also push the remediation tickets created in the Brinqa Platform to ServiceNow.

This document details the information you must provide for the connector to authenticate with ServiceNow and how to obtain that information from ServiceNow. 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 ServiceNow 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 ServiceNow with Brinqa:

  • ServiceNow URL: Your organization's ServiceNow Server URL. The default format is https://<ServiceNowServerName>.service-now.com.

  • Username and Password: The username and password associated with the ServiceNow user account, which must have permissions to access the ServiceNow API return data.

Create a ServiceNow user

For the ServiceNow connector to access the ServiceNow API, you must create a user account. To create a new ServiceNow user, follow these steps:

  1. Log in to your organization's ServiceNow server as an administrator.

  2. Navigate to All > User Administration > Users.

  3. Click New.

  4. Provide a User ID, First name, and Last name for the new user, and ensure you select Active as well. Complete the other fields as desired.

    ServiceNow new user creation page

  5. Click Submit.

  6. Locate the new user in the Users table, and click the user ID.

  7. Click Set Password and generate a new password for the user. Take note of this password and provide it to the user accessing the account.

  8. Click Close in the "Set Password" dialog, and then click Update.

    Copy the User ID and the Password into the corresponding fields in the integration configuration.

note

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

Assign the required roles and permissions

After you have created the ServiceNow user, you can assign the necessary roles to the user so that they have the proper permissions to retrieve data from the ServiceNow API. To assign roles to the user, follow these steps:

  1. Locate the new user in the Users table and click the user ID.

  2. Locate the Roles section on the page and click Edit.

  3. Under Collection, select the desired roles, and then click Add.

    The user account must have the following roles to successfully retrieve your ServiceNow data and tables:

    • data_classification_auditor
    • data_exchange
    • itil
    • snc_platform_rest_api_access

    data_exchange is a custom role that contains read permissions to the following tables:

    • sys_dictionary*

    • sys_dictionary

    • sys_db_object*

    • sys_db_object

    • sys_glide_object*

    • sys_glide_object

      sys_dictionary permission

      sys_dictionary is a required permission and is necessary for the ServiceNow connector to function properly, as it allows Brinqa to access and view your ServiceNow tables and retrieve the schema details in these tables from your ServiceNow instance.

      note

      The * permissions grant access to both the table and all extensions of that table.

    Your roles should resemble the following:

    ServiceNow user roles

  4. Click Save.

note

If you do not have the permissions to assign roles to users, contact your ServiceNow administrator. For additional information, see ServiceNow documentation about how to assign roles, create a new role, and base system roles.

(Optional) Obtain the client ID and client secret for OAuth2 authentication

The ServiceNow connector also supports OAuth2 authentication. If you want to use OAuth2 authentication, you must provide a client ID and client secret in addition to the ServiceNow username and password. To obtain the credentials, follow these steps:

  1. Log in to your organization's ServiceNow server as an administrator.

  2. Navigate to All > System OAuth > Application Registry.

  3. Click New.

  4. Click Create an OAuth API endpoint for external clients. A new page appears.

  5. Provide a name for the OAuth2 client application, fill in the Client Secret field, and select Active. You can also leave the Client Secret field blank if you want the system to auto-generate one. Leave the other fields as is.

  6. Click Submit.

    You are taken back to the Application Registries page.

  7. Click the name of the new OAuth2 client in the table.

  8. Click Toggle Password Visibility next to the Client Secret field to reveal the secret.

    ServiceNow Client ID and Client Secret

    Copy the Client ID and Client Secret values and paste them into the Client ID and Client secret fields in the integration configuration. Although you can return to this page to view the Client ID and Client secret, you should handle them with care by ensuring that they are stored in a secure location.

note

If you do not have the permissions to create the credentials for OAuth2 authentication, contact your ServiceNow administrator. For additional information, see ServiceNow documentation.

Additional settings

The ServiceNow connector contains additional options for specific configuration:

  • Client ID and Client secret: The client ID and client secret for OAuth2 access to ServiceNow. When specified, the ServiceNow connector uses OAuth2 authorization. If not specified, the ServiceNow connector reverts to basic authorization using the ServiceNow username and password provided. For additional information, see Obtain the client ID and client secret for OAuth2 authentication.

  • Additional tables: A comma-separated list of additional ServiceNow tables that you wish to include in addition to the tables the connector brings in by default, e.g. problem, incident, change_request, sn_vul_vulnerability.

    • By default, the ServiceNow connector brings in the following tables:

      • cmdb_ci_appl
      • cmdb_ci_service
      • cmdb_rel_ci
      • cmdb_ci_cluster
      • cmdb_ci_comm
      • cmdb_ci_computer
      • sys_user_group
      • sys_user_grmember
      • cmn_location
      • cmdb_ci_msd
      • cmdb_ci_netgear
      • cmdb_ci_printer
      • cmdb_ci_server
      • task
      • sys_user
      • cmdb_ci_vm_instance
  • Page size: The maximum number of records to get per API request. The default setting is 1000. It is not recommended to go over 1000.

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

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

  • Use cached schema: Select this option to allow Brinqa to use a previously stored version of the ServiceNow schema when connecting to ServiceNow. Rather than requesting the schema from ServiceNow each time a connection is established, this can speed up the connection process and reduce the load on ServiceNow.

Types of data to retrieve

The ServiceNow connector retrieves the following types of data from the ServiceNow tables through the ServiceNow Table API:

Table 1: Data retrieved from ServiceNow

Connector ObjectRequiredServiceNow Table
ApplicationNocmdb_ci_appl
Business ServiceNocmdb_ci_service
CI RelationshipNocmdb_rel_ci
ClusterNocmdb_ci_cluster
Communication DeviceNocmdb_ci_comm
ComputerNocmdb_ci_computer
GroupNosys_user_group
Group MemberNosys_user_grmember
LocationNocmn_location
Mass Storage DeviceNocmdb_ci_msd
Network GearNocmdb_ci_netgear
PrinterNocmdb_ci_printer
ServerNocmdb_ci_server
TaskNotask
UserNosys_user
Virtual Machine InstanceNocmdb_ci_vm_instance
info

None of the connector objects in the above table are required. You can select tables based on your specific integration needs. You can also add additional ServiceNow tables, such as incident for ServiceNow incidents, to your integration in the additional settings section of the configuration.

Some ServiceNow objects and tables are mapped directly to data models in the Brinqa Platform. For example, Computer (cmdb_ci_computer) is mapped to Host and Incident (incident) is mapped to Ticket. For the other objects, you must define the mappings yourself. See Data Consolidation for additional information.

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

note

For additional information about ServiceNow tables, see ServiceNow documentation.

Computer to Host attribute mappings

The table below details the attribute mappings from the ServiceNow Computer object to the Host data model in Brinqa:

Table 2: Computer to Host attribute mappings

Source Field NameMaps to Attribute
categoriescategories
fdqndnsNames, publicDnsName, privateDnsName
first_discoveredfirstSeen
hostnamehostnames
ip_addressipAddresses, publicIpAddresses, privateIpAddresses
last_discoveredlastSeen
mac_addressmacAddresses
namename
operational_statusstatus
osoperatingSystem
serial_numberserialNumber
short_descriptiondescription
sys_created_onsourceCreatedDate
sys_updated_onsourceLastModified
uiduid

Operation options

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

Table 3: ServiceNow connector operation options

OptionAll Possible ValuesDescriptionExample
lower_case_namefalseRetains the original case of names. By default, the ServiceNow connector converts all names to lowercase.Key: lower_case_name Value: false. This key and value combination ensures that the original casing of names is preserved.
reference_fieldsAny ServiceNow object reference field.Retrieves the sys_ids for specified fields instead of their display values.Key: reference_fields Value: location,assigned_to. This key and value combination retrieves the sys_ids for the location and assigned_to fields of the Computer object, instead of their display values.
query or sysparm_queryAny ServiceNow query used to filter resultsSpecifies the query used to filter the results retrieved by the connector. You can use logical operators and conditions.Key: sysparm_query Value: =employee_number!=NULL&active=true. This key and value combination filters the results to only include records where the employee_number is not NULL and the active field is set to true.
note

The operation options can be used in conjunction with any ServiceNow tables that are retrieved by the connector. For additional information, see ServiceNow documentation about reference fields and query parameters.

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

APIs

The ServiceNow connector uses the ServiceNow Table API. Specifically, it uses the following endpoints:

Table 4: ServiceNow Table API endpoints

Connector ObjectAPI Endpoint
ApplicationGET /api/now/table/cmdb_ci_appl
Business ServiceGET /api/now/table/cmdb_ci_service
CI RelationshipGET /api/now/table/cmdb_rel_ci
ClusterGET /api/now/table/cmdb_ci_cluster
Communication DeviceGET /api/now/table/cmdb_ci_comm
ComputerGET /api/now/table/cmdb_ci_computer
GroupGET /api/now/table/sys_user_group
Group MemberGET /api/now/table/sys_user_grmember
LocationGET /api/now/table/cmn_location
Mass Storage DeviceGET /api/now/table/cmdb_ci_msd
Network GearGET /api/now/table/cmdb_ci_netgear
PrinterGET /api/now/table/cmdb_ci_printer
ServerGET /api/now/table/cmdb_ci_server
TaskGET /api/now/table/task
UserGET /api/now/table/sys_user
Virtual Machine InstanceGET /api/now/table/cmdb_ci_vm_instance

Troubleshooting the ServiceNow connector

Here are some common error codes and their meanings that you might encounter while working with the ServiceNow connector and suggestions on how to resolve them:

Table 5: ServiceNow connector error codes

Error Code or ProblemSuggestion
Forbidden RequestIndicates that the ServiceNow connector is configured with user credentials that lack the necessary permissions to access the ServiceNow API. Ensure that the user credentials used in the ServiceNow connector has the appropriate permissions to access the ServiceNow API and retrieve data.
Illegal character in https://<ServiceNowServerName>Typically occurs due to an illegal character in the ServiceNow URL. Double-check and correct the URL in the ServiceNow URL section of the configuration.
Table Not FoundThe ServiceNow connector is trying to access a table in the ServiceNow instance that either doesn't exist or is incorrectly specified. Ensure the ServiceNow table name is correctly specified in the Additional tables section of the configuration.
Timeout ErrorTypically occurs when the ServiceNow connector doesn't receive a response from the ServiceNow server within an expected time frame. This could be due to network latency, server overload, or other issues affecting response time. You can increase the Maximum retries value in the Additional settings section of the configuration to attempt to resolve this error.
Insufficient rights to query recordsThe ServiceNow connector hasn't been configured with valid user credentials, or the provided credentials are not being recognized by the ServiceNow instance. Double-check that the ServiceNow connector is configured correctly with valid user credentials.

Changelog

The ServiceNow connector has undergone the following changes:

Table 6: ServiceNow connector changelog

VersionDescription
3.2.5Fixed an issue where the connector did not retrieve all user records from the sys_user table in ServiceNow.
3.2.4- Fixed a data mismatch issue where some attribute types were incorrectly converted to strings instead of their respective data types.
- Corrected the conversion for decimal attributes to ensure proper handling.
- Added a new float data type to support attributes that require floating-point precision.
3.2.3Added a new operation option: lower_case_name.
3.2.2More updates to handle ServiceNow reference field types correctly.
3.2.0- Added a reference_fields operation option in the Computer object. This option supports obtaining ServiceNow reference fields as sys_id rather than their display values.
- Removed the display_value operation option from the Computer object.
- Added methods to convert text from ServiceNow to their appropriate types, such as Boolean, Integer, or Long. (The ServiceNow API returns all field values as text or string.)
3.1.4Added a check for null values.
3.1.3Improved its handling of dates when creating and updating records.
3.1.2Normalized names for data consolidation.
3.1.1Provided better help messages.
3.1.0- Reduced the ServiceNow source tables to only the most commonly-used ones.
- Improved performance by loading all table schema in parallel.
- Added additional connector objects, such as Group, Group Member, Mass Storage Device, and Server.
3.0.5Added FQDN as a source attribute and mapped it to DNS names.
3.0.4Displayed all date and time values in the Date format.
3.0.0Initial Integration+ release.