Skip to main content

ServiceNow v2

This Integration is part of the ServiceNow Pack.#

IT service management. Cortex XSOAR interfaces with ServiceNow to help streamline security-related service management and IT operations. For example, you can use the ServiceNow integration in order to:

  • View, create, update or delete a ServiceNow ticket directly from the Cortex XSOAR CLI, and enrich it with Cortex XSOAR data.
  • View, create, update and delete records from any ServiceNow table.
  • Query ServiceNow data with the ServiceNow query syntax.
  • Manage Security Incident Response (SIR) tickets with Cortex XSOAR, update tickets and enrich them with data.

Please refer to ServiceNow documentation for additional information. We especially recommend the Operators available for filters and queries page.

This integration was integrated and tested with the Xanadu version of ServiceNow.

This is the default integration for this content pack when configured by the Data Onboarder in Cortex XSIAM.

Use cases#

  1. Get, update, create, and delete ServiceNow tickets, as well as add links and comments, or upload files to the tickets.
  2. Fetch newly created incidents.
  3. Get, update, create, delete records from any ServiceNow table.

Required Permissions#

To use ServiceNow on Cortex XSOAR, ensure your user account has the snc_platform_rest_api_access role. This role is required to make API calls. Also add to your user account the specific tables that you want to have access to. However, these permissions may not suffice for managing records in some tables. Make sure you have the correct role so you have permissions to work with the relevant table.

Wrapper Scripts#

There are 3 scripts that serve as examples for wrapping the following generic commands: servicenow-query-table - ServiceNowQueryIncident servicenow-create-record - ServiceNowCreateIncident servicenow-update-record - ServiceNowUpdateIncident

You can use these scripts if you want to wrap these commands around a ServiceNow table of your choice. These scripts are wrapped around the incident table, so to wrap them around another table simply copy the scripts and edit the code, arguments and outputs accordingly.

Configure ServiceNow v2 on Cortex XSOAR#

  1. Navigate to Settings > Integrations > Servers & Services.
  2. Search for ServiceNow v2.
  3. Click Add instance to create and configure a new integration instance.
  4. To ensure that mirroring works:
    1. Select the Fetches incidents radio button.

    2. Under Classifier, select ServiceNow Classifier.

    3. Under Mapper (incoming), select ServiceNow - Incoming Mapper.

    4. Under Mapper (outgoing), select ServiceNow - Outgoing Mapper.

    5. To enable mirroring to close a ticket in Cortex XSOAR, under the Mirrored XSOAR Ticket closure method dropdown, select the ticket closing method, or set the Mirrored XSOAR Ticket custom close resolution code or Mirrored XSOAR Ticket custom close state code parameter, in order to override the default closure method with a custom close code or custom state. In order to use Mirrored XSOAR Ticket custom close resolution code or Mirrored XSOAR Ticket custom close state code parameter, it must follow this format: "custom_state_code1=custom_label1,custom_state_code2=custom_label2,...", for example: “10=Design,11=Development,12=Testing”. Also, a matching user-defined list of customized incident close reasons must be configured as a "Server configuration" in Cortex XSOAR. (Meaning each Service Now custom state label will have a matching Cortex XSOAR custom close reason with the same name). Not following this format will result in a server error! For more information about Customize Incident Close Reasons, see Cortex XSOAR 6.13 or Cortex XSOAR 8 Cloud or Cortex XSOAR 8.7 On-prem. image

    6. To enable mirroring to close an incident in ServiceNow, under the Mirrored ServiceNow Ticket closure method dropdown, select the ticket closing method, or set the Mirrored ServiceNow Ticket custom close state code parameter, in order to override the default closure method with a custom state.

      image

Instance Creation Flow#

This integration supports two types of authorization:

  1. Basic authorization using username and password.
  2. OAuth 2.0 authorization.

OAuth 2.0 Authorization#

To use OAuth 2.0 authorization follow the next steps:

  1. Login to your ServiceNow instance and create an endpoint for XSOAR to access your instance (please see Snow OAuth for more information).
  2. Copy the Client Id and Client Secret (press the lock next to the client secret to reveal it) that were automatically generated when creating the endpoint into the Username and Password fields of the instance configuration.
  3. Select the Use OAuth Login checkbox and click the Done button.
  4. Run the command !servicenow-oauth-login from the XSOAR CLI and fill in the username and password of the ServiceNow instance. This step generates an access token to the ServiceNow instance and is required only in the first time after configuring a new instance in the XSOAR platform.
  5. (Optional) Test the created instance by running the !servicenow-oauth-test command.

Notes:

  1. When running the !servicenow-oauth-login command, a refresh token is generated and will be used to produce new access tokens after the current access token has expired.
  2. Every time the refresh token expires you will have to run the servicenow-oauth-login command again. Hence, we recommend setting the Refresh Token Lifespan field in the endpoint created in step 1 to a long period (can be set to several years).
  3. The grant type used to get an access token is Resource owner password credentials. See the Snow documentation for more information.

Using Multi-Factor Authentication (MFA)#

MFA can be used both when using basic authorization and when using OAuth 2.0 authorization, however we strongly recommend using OAuth 2.0 when using MFA. If MFA is enabled for your user, follow the next steps:

  1. Open the Google Authenticator application on your mobile device and make note of the number. The number refreshes every 30 seconds.
  2. Enter your username and password, and append the One Time Password (OTP) that you currently see on your mobile device to your password without any extra spaces. For example, if your password is 12345 and the current OTP code is 424 058, enter 12345424058.

Notes:

  1. When using basic authorization, you will have to update your password with the current OTP every time the current code expires (30 seconds), hence we recommend using OAuth 2.0 authorization.

  2. For using OAuth 2.0 see the above instructions. The OTP code should be appended to the password parameter in the !servicenow-oauth-login command.

    ParameterDescriptionRequired
    ServiceNow URL, in the format https://company.service-now.com/True
    Username/Client IDFalse
    PasswordFalse
    Use OAuth LoginSelect this checkbox if to use OAuth 2.0 authentication. See (?) for more information.False
    Default ticket type for running ticket commands and fetching incidentsThe ticket type can be: incident, problem, change_request, sc_request, sc_task or sc_req_item.False
    ServiceNow API Version (e.g. 'v1')False
    Fetch incidentsFalse
    The query to use when fetching incidentsFalse
    How many incidents to fetch each timeFalse
    First fetch timestamp (<number> <time unit>, e.g., 12 hours, 7 days, 3 months, 1 year)False
    Timestamp field to filter by (e.g., opened_at) This is how the filter is applied to the query: "ORDERBYopened_at^opened_at>[Last Run]".
    To prevent duplicate incidents, this field is mandatory for fetching incidents.
    False
    ServiceNow ticket column to be set as the incident name. Default is the incident numberFalse
    Incident typeFalse
    Get incident attachmentsFalse
    Incident Mirroring DirectionChoose the direction to mirror the incident: Incoming (from ServiceNow to Cortex XSOAR), Outgoing (from Cortex XSOAR to ServiceNow), or Incoming and Outgoing (from/to Cortex XSOAR and ServiceNow).False
    Use Display ValueSelect this checkbox to retrieve comments and work notes without accessing the `sys_field_journal` table.False
    Instance Date FormatSelect the date format of your ServiceNow instance. Mandatory when using the `Use Display Value` option. More details under the troubleshooting section in the documentation of the integration. The integration supports the ServiceNow default time format (full form) HH:mm:ss with support to a notation for AM/PM.False
    Comment Entry TagChoose the tag to add to an entry to mirror it as a comment in ServiceNow.False
    Work Note Entry TagChoose the tag to add to an entry to mirror it as a work note in ServiceNow.False
    File Entry Tag To ServiceNowChoose the tag to add to an entry to mirror it as a file in ServiceNow.False
    File Entry Tag From ServiceNowChoose the tag to add to an entry to mirror it as a file from ServiceNow.False
    Timestamp field to query for updates as part of the mirroring flowAccording to the timestamp in this field, records will be queried to check for updates.False
    How many incidents to mirror incoming each timeIf a greater number of incidents than the limit were modified, then they won't be mirrored in.False
    Custom Fields to MirrorCustom (user defined) fields in the format: ufieldname1,u_fieldname2 custom fields start with a 'u'. These fields will be included in the mirroring capabilities, if added here.False
    Mirrored XSOAR Ticket closure methodDefine how to close the mirrored tickets in Cortex XSOAR. Choose 'resolved' to enable reopening from the UI. Otherwise, choose 'closed'. Choose 'None' to disable closing the mirrored tickets in Cortex XSOAR.False
    Mirrored XSOAR Ticket custom close state codeDefine how to close the mirrored tickets in Cortex XSOAR with a custom state. Enter here a comma-separated list of custom closure state codes and their labels (acceptable format example: “10=Design,11=Development,12=Testing”) to override the default closure method. Note that a matching user-defined list of custom close reasons must be configured as a "Server configuration" in Cortex XSOAR. Not following this format will result in closing the incident with a default close reason.False
    Mirrored XSOAR Ticket custom close resolution codeDefine how to close the mirrored tickets in Cortex XSOAR with a custom resolution code. Enter a comma-separated list of custom resolution codes and their labels (acceptable format example: “10=Design,11=Development,12=Testing”) to override the default closure method. Note that a matching user-defined list of custom close reasons must be configured as a "Server configuration" in Cortex XSOAR. Not following this format will result in closing the incident with a default close reason.False
    Mirrored ServiceNow Ticket closure methodDefine how to close the mirrored tickets in ServiceNow, choose 'resolved' to enable reopening from the UI. Otherwise, choose 'closed'.False
    Mirrored ServiceNow Ticket custom close state codeDefine how to close the mirrored tickets in ServiceNow with custom state. Enter here the custom closure state code (should be an integer) to override the default closure method. If the closure code does not exist, the default one will be used instead.False
    Mirror Existing Notes For New Fetched IncidentsWhen enabled, comments and work notes are mirrored as note entries for each newly fetched incident. Note: This setting triggers an API call for each incident during the first mirroring, potentially causing overload if numerous incidents are present.False
    Use system proxy settingsFalse
    Trust any certificate (not secure)False
    Incidents Fetch IntervalFalse
    Advanced: Minutes to look back when fetchingUse this parameter to determine how long backward to look in the search for incidents that were created before the last run time and did not match the query when they were created.False
  1. Click Test to validate the URLs, token, and connection.
  2. Click Done.

Fetch Incidents#

The integration fetches newly created tickets according to the following parameters, which you define in the instance configuration: ticket_type, query, and limit. For the first fetch, the integration will fetch incidents that were created 10 minutes earlier. After that, the integration will fetch incidents created after the timestamp of the last fetch.

look-back parameter note: In case the look-back parameter is initialized with a certain value and during a time that incidents were fetched, if changing the look back to a number that is greater than the previous value, then in the initial incident fetching there will be incidents duplications. If the integration was already set with look back > 0, and the look-back is not being increased at any point of time, then those incident duplications would not occur. Note that using a look-back value that is very large (more than an hour) can lead to an increase in the memory usage of the system in some cases, and it is highly unrecommended. If there is a need to fetch incidents that require a long look-back to get fetched (for tracking issues, for example), use the mirroring feature and filter the results using the relevant tags instead of using the look-back feature. You can create a custom mapper and track the relevant fields.

Configure Incident Mirroring#

This feature is compliant with XSOAR version 6.0 and above.
When mirroring incidents, you can make changes in ServiceNow that will be reflected in Cortex XSOAR, or vice versa. You can also attach files from either of the systems which will then be available in the other system.

The following instructions include steps for configuring the integration and incoming and outgoing mappers. However, they do not cover every option available in the integration nor classification and mapping features. For information about classification and mapping see Classification and Mapping (Cortex XSOAR 6.13) or Classification and Mapping (Cortex XSOAR 8 Cloud) or Classification and Mapping (Cortex XSOAR 8.7 On-prem).

Note:

  • For Cortex XSOAR version 6.1 only, the final source of truth for an incident are the values in Cortex XSOAR. For example, if you change the severity in Cortex XSOAR and then change it back in ServiceNow, the final value that will be presented is the one in Cortex XSOAR. For versions 6.2 and later, if mirroring is in both directions then the latest update is the source of truth.
  • The mirroring settings apply only for incidents that are fetched after applying the settings. Pre-existing comments or work notes are not fetched/mirrored at the time of incident creation.
  • To use a custom mapper, you must first duplicate the mapper and edit the field in the copy of the mapper. If you detach the out of the box mapper and make changes to it, the pack does not automatically get updates.

To set up incident mirroring you need to:

  1. Configure the ServiceNow Service Account roles.
  2. Configure mirroring for ServiceNow trigger incidents or configure mirroring for other trigger incidents.

Configure the ServiceNow Service Account Roles#

To use ServiceNow on Cortex XSOAR, ensure your service account has the following roles required to make API calls:

  • Rest_api_explorer
  • Snc_platform_rest_api_access
  • itil (optional)

Note: If you choose to give permissions only for specific tables, you then need to add to your user account the specific tables you want to have access to. Make sure you have the correct role so you have permissions to work with the relevant table. Keep in mind that these permissions may not suffice for managing records in some tables.

  • Read access to sys_journal_field (this is an elevated privilege) for accessing comments and work notes and for incoming mirroring. This is not required if you have Use Display Value enabled with Instance Date Format defined.

    Note:
    See this ServiceNow community link for giving elevated read access and potential risks.

Configure Incident Mirroring When the Trigger Incident is ServiceNow#

When the trigger incident is ServiceNow, you use the ServiceNow Classifier and leave the Incident type as N/A, with either the default incoming and outgoing mappers or optional custom mappers.

STEP 1 - Configure the ServiceNow v2 Integration Instance for Mirroring.#

  1. Navigate to Integrations and search for ServiceNow v2.

  2. Click Add instance.

  3. Select Fetches incidents.

  4. Under Classifier, select ServiceNow Classifier.
    Note:
    You define either the Classifier or the Incident type (not both). It is recommended to define the Classifier and leave Incident type N/A to enable labeling custom incident types under the ServiceNow Classifier.

  5. Under Mapper (incoming), for default mapping select ServiceNow - Incoming Mapper. For custom mapping, follow the instructions in STEP 2 and then select the custom mapper name.

  6. Under Mapper (outgoing), for default mapping select ServiceNow - Outgoing Mapper. For custom mapping, follow the instructions in STEP 3 and then select the custom mapper name.

    image

  7. Enter the connection parameters.

    • Confirm whether your organization uses basic authorization or OAuth authorization (most use basic) and enter the relevant authorization details.
    • Leave ServiceNow API Version empty since ServiceNow typically automatically provides the appropriate version.
  8. Under The query to use when fetching incidents, the default query is to filter for new incidents: stateNOT IN6,7, where 6= resolved incidents and 7= closed incidents. For a different query, ask your ServiceNow representative to provide the exact states and their numbers.

  9. Select Get incident attachments to retrieve attachments from ServiceNow incident creation in Cortex XSOAR.

  10. Select the Incident Mirroring Direction:

    • In - Mirrors changes on the ServiceNow ticket in to the Cortex XSOAR ticket.
    • Out - Mirrors changes on the Cortex XSOAR ticket to the ServiceNow ticket.
    • Both - Mirrors changes both in and out on both tickets.
  11. Enable the checkbox for Use Display Value if you want to fetch comments and work notes without using sys_journal_field table which required an elevated read only permission.

  12. If Use Display Value is enabled, Instance Date Format needs to be set to the date format that matches the date format used in ServiceNow by the user account used to configure the instance.

image

  1. Set the Timestamp field to query as part of the mirroring flow. This defines the ticket_last_update - the epoch timestamp when the ServiceNow incident was last updated. The default is sys_updated_on.
  2. Enter the relevant Comment Entry Tag, Work Note Entry Tag, File Entry Tag To ServiceNow and File Entry Tag From ServiceNow values.
    These values are mapped to the dbotMirrorTags incident field in Cortex XSOAR, which defines how Cortex XSOAR handles comments when you tag them in the War Room.
    Note:
    These tags work only for mirroring comments, work notes, and files from Cortex XSOAR to ServiceNow.

image

  1. Configure any Custom Fields to Mirror. These must start with "u_". This is available for ServiceNow v2 version 2.2.10 and later.
    Note:
    To enable mirroring custom fields, make a copy of the incoming and outgoing mappers and add the custom fields to the copies (see STEP 2 and STEP 3). Select these copies in the integration instance Mapper (incoming) and Mapper (outgoing) settings.
  2. To enable mirroring when closing an incident or ticket in Cortex XSOAR and ServiceNow, select the closed option from the Mirrored XSOAR Ticket closure method dropdown and Mirrored ServiceNow Ticket closure method respectively.
  3. Click Done.

STEP 2 (Optional) Configure the Incoming Mapper by Incident Type for Custom Fields#

Note: Any modifications require that the mappers be cloned before any changes can be applied.

  1. Navigate to Classification and Mapping and for Incidents search for the ServiceNow - Incoming Mapper.

  2. Select it and click Duplicate.

  3. Under the Incident Type dropdown, select ServiceNow Create Ticket and Mirror.

  4. Verify the mapper has these fields mapped. They will pull the values configured on the integration instance settings at the time of ingestion.

    image

    • dbotMirrorId - dbotMirrorId - the field used by the third-party integration to identify the ticket. This should be the sys_id of the ServiceNow ticket. The value is mapped to incident.servicenowticketid.
    • dbotMirrorDirection - determines whether mirroring is incoming, outgoing, or both. Default is Both. This should match the instance configuration.
    • dbotMirrorInstance - determines the ServiceNow instance with which to mirror. This should match the instance configuration.
    • dbotMirrorLastSync - determines the field by which to indicate the last time that the systems synchronized.
    • dbotMirrorTags - determines the tags that you need to add in Cortex XSOAR for entries to be pushed to ServiceNow. They should be copied from the tags in the instance configuration. These are also the tags that must be put on the War Room record in order for it to sync.
      • To mirror files, use the ForServiceNow tag.
      • To mirror general notes, use the comments tag.
      • To mirror private notes that can be read only by users with the necessary permissions, use the work_notes tag.
    • Configure any custom fields you want mapped to Cortex XSOAR. Custom fields start with “u_” and are available for ServiceNow v2 version 2.2.10 and later. These must be added to the integration instance Custom Fields to Mirror setting.

STEP 3 - Modify the Outgoing Mapper#

Note:
Any modifications require that the mappers be cloned before any changes can be applied.

  1. Navigate to Classification and Mapping, and for Incidents search for the ServiceNow - Outgoing Mapper.
  2. Select it and click Duplicate.
    The left side of the screen shows the ServiceNow fields to which to map and the right side of the screen shows the Cortex XSOAR fields by which you are mapping.
  3. Under the Incident Type dropdown, select the relevant incident type (for example ServiceNow Ticket).
  4. Under Schema Type, select incident. The Schema Type represents the ServiceNow entity that you are mapping to. In our example it is an incident, but it can also be any other kind of ticket that ServiceNow supports.
  5. On the right side of the screen, under Incident, select the incident based on which you want to match.
  6. Change the mapping according to your needs, including any fields you want mapped outward to ServiceNow and any custom fields. Make sure the custom fields you want mirrored are added to the integration instance settings.
  7. Save your changes.

image

STEP 4 - Create an Incident in ServiceNow#

For purposes of this use case, it can be a simple incident. The new ticket will be ingested in Cortex XSOAR in approximately one minute.

STEP 5 - Add a Note to the Incident in Cortex XSOAR#

In the example below, we have written A comment from Cortex XSOAR to ServiceNow.

  1. Click Actions > Tags and add the comments tag.
  2. Add a file to the incident and mark it with the ForServiceNow tag.

image

  1. Navigate back to the incident in ServiceNow and within approximately one minute, the changes will be reflected there, too.
    You can make additional changes like closing the incident or changing severity and those will be reflected in both systems.

image

Configure Incident Mirroring When the Trigger Incident is Not ServiceNow#

You can set up any source integration to create a ServiceNow ticket based on a fetched incident and mirror the ticket in Cortex XSOAR. To do this you need to:

  • Configure the ServiceNow v2 integration to map the appropriate fields from the ServiceNow Create Ticket and Mirror incident type to the relevant trigger incident type (for example, Phishing Custom).
  • Set up the source integration to create a ServiceNow ticket and start mirroring.

STEP 1 - Configure the ServiceNow v2 Integration Instance for Mirroring.#

  1. Navigate to Classification and Mapping. For Incidents, search for ServiceNow - Incoming Mapper and ServiceNow - Outgoing Mapper.

  2. For each mapper, click Duplicate.
    Your copied mappers will be called ServiceNow - Incoming Mapper_copy and ServiceNow - Outgoing Mapper_copy, you can rename them. The copied mappers appear in the drop down for the Mapper (incoming) and Mapper (outgoing) integration instance settings fields.

  3. Navigate to Integrations and search for ServiceNow v2.

  4. Click Add instance.

  5. Select Do not Fetch.

  6. Under Classifier, select ServiceNow Classifier.
    Note:
    You define either the Classifier or the Incident type (not both). It is recommended to define the Classifier and leave Incident type N/A to enable labeling custom incident types under the ServiceNow Classifier.

  7. Under Mapper (incoming), select ServiceNow - Incoming Mapper_copy (or whatever you renamed it).

  8. Under Mapper (outgoing), select ServiceNow - Outgoing Mapper_copy (or whatever you renamed it).

  9. Enter the connection parameters.

    • Confirm whether your organization uses basic authorization or OAuth authorization (most use basic) and enter the relevant authorization details.
    • Leave ServiceNow API Version empty since ServiceNow typically automatically provides the appropriate version.
  10. Under The query to use when fetching incidents, the default query is to filter for new incidents: stateNOT IN6,7, where 6= resolved incidents and 7= closed incidents. For a different query, ask your ServiceNow representative to provide the exact states and their numbers.

  11. Select Get incident attachments to retrieve attachments from ServiceNow incident creation in Cortex XSOAR.

  12. Select the Incident Mirroring Direction:

    • In - Mirrors changes on the ServiceNow ticket in to the Cortex XSOAR ticket.
    • Out - Mirrors changes on the Cortex XSOAR ticket to the ServiceNow ticket.
    • Both - Mirrors changes both in and out on both tickets.
  13. Enable the checkbox for Use Display Value if you want to fetch comments and work notes without using sys_journal_field table which required an elevated read only permission.

  14. If Use Display Value is enabled, Instance Date Format needs to be set to the date format that matches the date format used in ServiceNow by the user account used to configure the instance.

image

  1. Set the Timestamp field to query as part of the mirroring flow. This defines the ticket_last_update - the epoch timestamp when the ServiceNow incident was last updated. The default is sys_updated_on.
  2. Enter the relevant Comment Entry Tag, Work Note Entry Tag, File Entry Tag To ServiceNow and File Entry Tag From ServiceNow values. These values are mapped to the dbotMirrorTags incident field in Cortex XSOAR, which defines how Cortex XSOAR handles comments when you tag them in the War Room.
    Note:
    These tags work only for mirroring comments from Cortex XSOAR to ServiceNow.

image

  1. Configure any Custom Fields to Mirror. These must start with "u_". This is available for ServiceNow v2 version 2.2.10 and later.
    Note:
    To enable mirroring custom fields, make a copy of the incoming and outgoing mappers and add the custom fields to the copies (see STEP 2 and STEP 3). Select these copies in the integration instance Mapper (incoming) and Mapper (outgoing) settings.
  2. To enable mirroring when closing an incident or ticket in Cortex XSOAR and ServiceNow, select the closed option from the Mirrored XSOAR Ticket closure method dropdown and Mirrored ServiceNow Ticket closure method respectively.
  3. Click Done.

STEP 2 (Optional) Configure the Incoming Mapper by Incident Type for Custom Fields#

Note: Any modifications require that the mappers be cloned before any changes can be applied.

  1. Navigate to Classification and Mapping and for Incidents search for the ServiceNow - Incoming Mapper_copy (or whatever you renamed it).

  2. Under the Incident Type dropdown, select the relevant triggering incident type, for example Phishing.

  3. Verify the mapper has these fields mapped. They will pull the values configured on the integration instance settings at the time of ingestion.

    image

    • dbotMirrorId - dbotMirrorId - the field used by the third-party integration to identify the ticket. This should be the sys_id of the ServiceNow ticket. The value is mapped to incident.servicenowticketid.
    • dbotMirrorDirection - determines whether mirroring is incoming, outgoing, or both. Default is Both. This should match the instance configuration.
    • dbotMirrorInstance - determines the ServiceNow instance with which to mirror. This should match the instance configuration.
    • dbotMirrorLastSync - determines the field by which to indicate the last time that the systems synchronized.
    • dbotMirrorTags - determines the tags that you need to add in Cortex XSOAR for entries to be pushed to ServiceNow. They should be copied from the tags in the instance configuration. These are also the tags that must be put on the War Room record in order for it to sync.
      • To mirror files from XSOAR to ServiceNow, use the ForServiceNow tag.
      • Mirrored files from ServiceNow to XSOAR will be tagged by default with the FromServiceNow tag.
      • To mirror general notes, use the comments tag.
      • To mirror private notes that can be read only by users with the necessary permissions, use the work_notes tag.
    • Configure any custom fields you want mapped to Cortex XSOAR. Custom fields start with “u_” and are available for ServiceNow v2 version 2.2.10 and later. These must be added to the integration instance Custom Fields to Mirror setting.
  4. Save your changes.

STEP 3 - Modify the Outgoing Mapper for Custom Fields#

Note:
Any modifications require that the mappers be cloned before any changes can be applied.

  1. Navigate to Classification and Mapping, and for Incidents search for the ServiceNow - Outgoing Mapper_copy (or whatever you renamed it).
  2. Under the Incident Type dropdown, select the relevant incident type (for example ServiceNow Ticket).
  3. Under Schema Type, select incident. The Schema Type represents the ServiceNow entity that you are mapping to. In our example it is an incident, but it can also be any other kind of ticket that ServiceNow supports.
  4. On the right side of the screen, under Incident, select the incident based on which you want to match.
    The left side of the screen shows the ServiceNow fields to which to map and the right side of the screen shows the Cortex XSOAR fields by which you are mapping.
  5. Change the mapping according to your needs, including any fields you want mapped outward to ServiceNow and any custom fields. Make sure the custom fields you want mirrored are added to the integration instance settings.
  6. Save your changes.

image

STEP 4 - Set up Your Source Integration#

Set up your source integration so that after fetching a trigger incident a ServiceNow ticket is created and mirroring starts.

  1. Fetch an incident with your chosen integration. For example, for Phishing using any email integration (Gmail, MSGraph, O365).
  2. Classify and map the incident fields.
  3. Create a task in the playbook that creates a ServiceNow ticket followed by a set incident task that starts the mirroring capability.

Example: The following shows the Create New Record playbook task, which creates a ServiceNow ticket.

image

The Create New Record task is followed by the Set Mirroring Fields task, which starts the mirroring capability.

image

The new ServiceNow ticket will be ingested in Cortex XSOAR in approximately one minute.

STEP 5 - Add a Note to the Incident in Cortex XSOAR#

In the example below, we have written A comment from Cortex XSOAR to ServiceNow.

  1. Click Actions > Tags and add the comments tag.
  2. Add a file to the incident and mark it with the ForServiceNow tag.

image

  1. Navigate back to the incident in ServiceNow and within approximately one minute, the changes will be reflected there, too.
    You can make additional changes like closing the incident or changing severity and those will be reflected in both systems.

image

Commands#

You can execute these commands from the Cortex XSOAR CLI, as part of an automation, or in a playbook. After you successfully execute a command, a DBot message appears in the War Room with the command details.

servicenow-login#


This function should be used once before running any command when using OAuth authentication.

Base Command#

servicenow-login

Input#

Argument NameDescriptionRequired
usernameThe username that should be used for login.Required
passwordThe password that should be used for login.Required

Context Output#

There is no context output for this command.

Command Example#

!servicenow-login username=username password=password

Context Example#

{}

Human Readable Output#

Logged in successfully#

servicenow-test#


Test the instance configuration when using OAuth authorization.

Base Command#

servicenow-test

Input#

There are no input arguments for this command.

Context Output#

There is no context output for this command.

Command Example#

!servicenow-test

Context Example#

{}

Human Readable Output#

Instance Configured Successfully#

servicenow-get-ticket#


Retrieves ticket information by ticket ID.

Base Command#

servicenow-get-ticket

Input#

Argument NameDescriptionRequired
idTicket system ID for which to retrieve information.Optional
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
numberTicket number to retrieve.Optional
get_attachmentsIf "true" will retrieve ticket attachments.Note this option will always use the v1 API version, as it is not supported in v2. Default is "false".Optional
custom_fieldsCustom fields on which to query. For example: state_code=AR,time_zone=PST.Optional
additional_fieldsAdditional fields to display in the War Room entry and incident context.Optional

Context Output#

PathTypeDescription
ServiceNow.Ticket.IDstringServiceNow ticket ID.
ServiceNow.Ticket.OpenedBystringServiceNow ticket opener ID.
ServiceNow.Ticket.CreatedOndateServiceNow ticket creation date.
ServiceNow.Ticket.AssigneestringServiceNow ticket assignee ID.
ServiceNow.Ticket.StatestringServiceNow ticket state.
ServiceNow.Ticket.SummarystringServiceNow ticket short summary.
ServiceNow.Ticket.NumberstringServiceNow ticket number.
ServiceNow.Ticket.ActivebooleanServiceNow ticket active.
ServiceNow.Ticket.AdditionalCommentsstringServiceNow ticket comments.
ServiceNow.Ticket.PrioritystringServiceNow ticket priority.
ServiceNow.Ticket.OpenedAtdateServiceNow ticket opening time.
ServiceNow.Ticket.ResolvedBystringServiceNow ticket resolver ID.
ServiceNow.Ticket.CloseCodestringServiceNow ticket close code.
File.InfostringAttachment file info.
File.NamestringAttachment file name.
File.SizenumberAttachment file size.
File.SHA1stringAttachment file SHA1 hash.
File.SHA256stringAttachment file SHA256 hash.
File.EntryIDstringAttachment file entry ID.
File.TypestringAttachment file type.
File.MD5stringAttachment file MD5 hash.

Command Example#

!servicenow-get-ticket number=INC0000040

Context Example#

{
"ServiceNow": {
"Ticket": {
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2020-01-26 00:43:54",
"Creator": "admin",
"ID": "id",
"Number": "INC0000040",
"OpenedAt": "2020-01-26 00:42:45",
"OpenedBy": "admin",
"Priority": "3 - Moderate",
"State": "3",
"Summary": "JavaScript error on hiring page of corporate website"
}
},
"Ticket": {
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2020-01-26 00:43:54",
"Creator": "admin",
"ID": "id",
"Number": "INC0000040",
"OpenedAt": "2020-01-26 00:42:45",
"OpenedBy": "admin",
"Priority": "3 - Moderate",
"State": "3",
"Summary": "JavaScript error on hiring page of corporate website"
}
}

Human Readable Output#

ServiceNow ticket#

System IDNumberImpactUrgencySeverityPriorityStateCreated OnCreated ByActiveDescriptionOpened AtShort Description
idINC00000402 - Medium2 - Medium3 - Low3 - Moderate3 - On Hold2020-01-26 00:43:54admintrueSeeing JavaScript error message on hiring page on Explorer and Firefox.2020-01-26 00:42:45JavaScript error on hiring page of corporate website

servicenow-create-ticket#


Creates new ServiceNow ticket.

Base Command#

servicenow-create-ticket

Input#

Argument NameDescriptionRequired
short_descriptionShort description of the ticket.Optional
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", "sn_si_incident" or "std_change_template". Default is "incident".Optional
urgencyTicket urgency. You can either select from the predefined options or enter another value, for example: "Urgent" or "5".Optional
severityTicket severity. You can either select from the predefined options or enter another value, for example: "Urgent" or "5".Optional
impactTicket impact.Optional
activeWhether to set the ticket as Active. Can be "true" or "false".Optional
activity_dueThe ticket activity due date, in the format "2016-07-02 21:51:11".Optional
additional_assignee_listList of users assigned to the ticket.Optional
approval_historyTicket history approval.Optional
approval_setThe ticket approval set date, in the format "2016-07-02 21:51:11".Optional
assigned_toUser assigned to the ticket.Optional
business_durationBusiness duration, in the format: YYYY-MM-DD HH:MM:SS.Optional
business_serviceBusiness service.Optional
business_stcBusiness source.Optional
business_criticalityBusiness criticality of the ticket.Optional
calendar_durationCalendar duration, in the format: YYYY-MM-DD HH:MM:SS.Optional
caller_idCaller ID (UID format).Optional
categoryCategory of the ticket.Optional
caused_byUID FormatOptional
close_codeTicket's close code. Can be "Solved (Work Around)", "Solved (Permanently)", "Solved Remotely (Work Around)", "Solved Remotely (Permanently)", "Not Solved (Not Reproducible)", "Not Solved (Too Costly)", or "Closed/Resolved by Caller".Optional
close_notesClose notes of the ticket.Optional
closed_atWhen the ticket was closed, in the format: YYYY-MM-DD HH:MM:SS.Optional
closed_byUser who closed the ticket.Optional
cmdb_ciUID Format.Optional
commentsFormat type journal input.Optional
comments_and_work_notesFormat type journal input.Optional
companyCompany (UID format).Optional
contact_typeContact type.Optional
correlation_displayCorrelation display.Optional
correlation_idCorrelation ID.Optional
delivery_planDelivery plan (UID format).Optional
displayWhether to display comments, work notes, and so on. Can be "true" or "false".Optional
descriptionTicket description.Optional
due_dateTicket due date, in the format: YYYY-MM-DD HH:MM:SS.Optional
escalationEscalationOptional
expected_startExpected start date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
follow_upFollow up date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
group_listUID format list (group).Optional
knowledgeWhether the ticket is solved in the knowledge base. Can be "true" or "false".Optional
locationLocation of the ticket.Optional
made_slaSLA of the ticket.Optional
notifyWhether to be notified about this ticket. Can be "1" or "0".Optional
orderOrder number.Optional
parentUID FormatOptional
parent_incidentUID FormatOptional
problem_idUID FormatOptional
reassignment_countThe number of users included in this ticket.Optional
reopen_countHow many times the ticket has been reopened.Optional
resolved_atThe date/time that the ticket was resolved, in the format: YYYY-MM-DD HH:MM:SS.Optional
resolved_byID of the user that resolved the ticket.Optional
risk_scoreIncident risk score.Optional
rfcUIDOptional
sla_dueSLA due date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
subcategoryTicket subcategory.Optional
sys_updated_byLast updated by.Optional
sys_updated_onLast date/time that the system was updated, in the format: YYYY-MM-DD HH:MM:SS.Optional
user_inputInput from the end user.Optional
watch_listA list of watched tickets.Optional
work_endFormat: YYYY-MM-DD HH:MM:SSOptional
work_notesFormat journal listOptional
work_notes_listList work notes UIDs.Optional
work_startDate/time when work started on the ticket.Optional
assignment_groupThe sys_id of the group to assign.Optional
incident_stateThe number that represents the incident state.Optional
numberTicket number.Optional
priorityPriority of the ticket.Optional
templateTemplate name to use as a base to create new tickets.Optional
custom_fieldsCustom (user defined) fields in the format: fieldname1=value;fieldname2=value; custom fields start with a "u_".Optional
change_typeType of Change Request ticket. Can be "normal", "standard", or "emergency". Default is "normal".Optional
stateState of the ticket, for example: "Closed" or "7" or "7 - Closed".Optional
opened_atDate/time the ticket was opened, in the format: YYYY-MM-DD HH:MM:SS.Optional
callerCaller system ID.Optional
approvalTicket approval.Optional
additional_fieldsAdditional fields in the format: fieldname1=value;fieldname2=value;Optional
input_display_valueFlag that indicates whether to set field values using the display value or the actual value. True will treat the input value as the display value. False treats the input values as actual values. The default setting is false.Optional

For more information regarding the input_display_value Argument, please see: https://docs.servicenow.com/bundle/xanadu-platform-administration/page/administer/exporting-data/concept/query-parameters-display-value.html

Context Output#

PathTypeDescription
ServiceNow.Ticket.IDstringServiceNow ticket ID.
ServiceNow.Ticket.OpenedBystringServiceNow ticket opener ID.
ServiceNow.Ticket.CreatedOndateServiceNow ticket creation date.
ServiceNow.Ticket.AssigneestringServiceNow ticket assignee ID.
ServiceNow.Ticket.StatestringServiceNow ticket state.
ServiceNow.Ticket.SummarystringServiceNow ticket short summary.
ServiceNow.Ticket.NumberstringServiceNow ticket number.
ServiceNow.Ticket.ActivebooleanServiceNow ticket active.
ServiceNow.Ticket.AdditionalCommentsstringServiceNow ticket comments.
ServiceNow.Ticket.PrioritystringServiceNow ticket priority.
ServiceNow.Ticket.OpenedAtdateServiceNow ticket opening time.
ServiceNow.Ticket.ResolvedBystringServiceNow ticket resolver ID.
ServiceNow.Ticket.CloseCodestringServiceNow ticket close code.

Command Example#

!servicenow-create-ticket active=true severity="2 - Medium" short_description="Ticket example"

Context Example#

{
"ServiceNow": {
"Ticket": {
"Active": "true",
"CreatedOn": "2020-05-10 09:04:06",
"Creator": "admin",
"ID": "id",
"Number": "INC0010002",
"OpenedAt": "2020-05-10 09:04:06",
"OpenedBy": "admin",
"Priority": "5 - Planning",
"State": "1",
"Summary": "Ticket exmaple"
}
},
"Ticket": {
"Active": "true",
"CreatedOn": "2020-05-10 09:04:06",
"Creator": "admin",
"ID": "id",
"Number": "INC0010002",
"OpenedAt": "2020-05-10 09:04:06",
"OpenedBy": "admin",
"Priority": "5 - Planning",
"State": "1",
"Summary": "Ticket example"
}
}

Human Readable Output#

ServiceNow ticket was created successfully.#

System IDNumberImpactUrgencySeverityPriorityStateCreated OnCreated ByActiveOpened AtShort Description
idINC00100023 - Low3 - Low2 - Medium5 - Planning1 - New2020-05-10 09:04:06admintrue2020-05-10 09:04:06Ticket example

servicenow-update-ticket#


Updates the specified ticket.

Base Command#

servicenow-update-ticket

Input#

Argument NameDescriptionRequired
short_descriptionShort description of the ticket.Optional
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
urgencyTicket urgency. You can either select from the predefined options or enter another value, for example: "Urgent" or "5".Optional
severityTicket severity. You can either select from the predefined options or enter another value, for example: "Urgent" or "5".Optional
impactTicket impact.Optional
activeWhether the ticket is Active. Can be "true" or "false".Optional
activity_dueThe ticket activity due date, in the format: "2016-07-02 21:51:11".Optional
additional_assignee_listList of users assigned to the ticket.Optional
approval_historyTicket history approval.Optional
approval_setThe ticket approval set date/time, in the format: "2016-07-02 21:51:11".Optional
assigned_toUser assigned to the ticket.Optional
business_durationBusiness duration, in the format: YYYY-MM-DD HH:MM:SS.Optional
business_serviceBusiness service.Optional
business_stcBusiness source.Optional
business_criticalityBusiness criticality of the ticket.Optional
calendar_durationCalendar duration, in the format: YYYY-MM-DD HH:MM:SS.Optional
caller_idCaller ID (UID format).Optional
categoryCategory name.Optional
caused_byUID format.Optional
close_codeTicket's close code. Ticket's close code. Can be "Solved (Work Around)", "Solved (Permanently)", "Solved Remotely (Work Around)", "Solved Remotely (Permanently)", "Not Solved (Not Reproducible)", "Not Solved (Too Costly)", or "Closed/Resolved by Caller".Optional
close_notesClose notes of the ticket.Optional
closed_atDate/time the ticket was closed, in the format: YYYY-MM-DD HH:MM:SS.Optional
closed_byUser who closed the ticket.Optional
cmdb_ciUID Format.Optional
commentsFormat type journal input.Optional
comments_and_work_notesFormat type journal input.Optional
companyUID Format.Optional
contact_typeContact type.Optional
correlation_displayCorrelation display.Optional
correlation_idCorrelation ID.Optional
delivery_planUID Format.Optional
displayWhether to display comments, work notes, and so on. Can be "true" or "false".Optional
descriptionTicket description.Optional
due_dateTicket due date, in the format: YYYY-MM-DD HH:MM:SS.Optional
escalationEscalation.Optional
expected_startExpected start date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
follow_upFollow up date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
group_listUID format list.Optional
knowledgeWhether the ticket is solved in the knowledge base. Can be "true" or "false".Optional
locationLocation of the ticket.Optional
made_slaSLA of the ticket.Optional
notifyWhether to be notified about this ticket. Can be "1" or "0".Optional
orderOrder number.Optional
parentParent (UID format).Optional
parent_incidentParent incident (UID format).Optional
problem_idProblem ID (UID format).Optional
reassignment_countThe number of users included in this ticket.Optional
reopen_countThe number of times the ticket has been reopened.Optional
resolved_atDate/time the ticket was resolved, in the format: YYYY-MM-DD HH:MM:SS.Optional
resolved_byResolved by (UID format).Optional
risk_scoreIncident risk score.Optional
rfcUIDOptional
sla_dueSLA due date/time, in the format: YYYY-MM-DD HH:MM:SS.Optional
subcategoryTicket subcategory.Optional
sys_updated_byLast updated byOptional
sys_updated_onDate/time the system was last updated.Optional
user_inputInput from the end user.Optional
watch_listA list of watched tickets.Optional
work_endFormat: YYYY-MM-DD HH:MM:SSOptional
work_notesFormat journal list.Optional
work_notes_listComma-separated list of work notes UIDs.Optional
work_startDate/time when work started on the ticket.Optional
assignment_groupAssignment group UID.Optional
incident_stateNumber representing the incident state.Optional
numberTicket number.Optional
priorityPriority of the ticket.Optional
idSystem ID of the ticket to update.Required
custom_fieldsCustom (user defined) fields in the format: fieldname1=value;fieldname2=value; custom fields start with a "u_".Optional
change_typeType of Change Request ticket. Can be "normal", "standard", or "emergency". Default is "normal".Optional
stateState of the ticket, for example: "Closed" or "7" or "7 - Closed".Optional
callerCaller system ID.Optional
approvalTicket approval.Optional
additional_fieldsAdditional fields in the format: fieldname1=value;fieldname2=value;Optional
input_display_valueFlag that indicates whether to set field values using the display value or the actual value. True will treat the input value as the display value. False treats the input values as actual values. The default setting is false.Optional
clear_fieldsA comma-separated list of fields to clear.Optional

For more information regarding the input_display_value Argument, please see: https://docs.servicenow.com/bundle/xanadu-platform-administration/page/administer/exporting-data/concept/query-parameters-display-value.html

Context Output#

There is no context output for this command.

Command Example#

!servicenow-update-ticket id=id severity="2 - Medium"

Context Example#

{
"ServiceNow": {
"Ticket": {
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2020-01-26 00:43:54",
"Creator": "admin",
"ID": "id",
"Number": "INC0000040",
"OpenedAt": "2020-01-26 00:42:45",
"OpenedBy": "admin",
"Priority": "3 - Moderate",
"State": "3",
"Summary": "JavaScript error on hiring page of corporate website"
}
}
}

Human Readable Output#

ServiceNow ticket updated successfully#

Ticket type: incident |Active|Created By|Created On|Description|Impact|Number|Opened At|Priority|Severity|Short Description|State|System ID|Urgency| |---|---|---|---|---|---|---|---|---|---|---|---|---| | true | admin | 2020-01-26 00:43:54 | Seeing JavaScript error message on hiring page on Explorer and Firefox. | 2 - Medium | INC0000040 | 2020-01-26 00:42:45 | 3 - Moderate | 2 - Medium | JavaScript error on hiring page of corporate website | 3 - On Hold | 471d4732a9fe198100affbf655e59172 | 2 - Medium |

servicenow-delete-ticket#


Deletes a ticket from ServiceNow.

Base Command#

servicenow-delete-ticket

Input#

Argument NameDescriptionRequired
idTicket System IDRequired
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident".Optional

Context Output#

There is no context output for this command.

Command Example#

!servicenow-delete-ticket id=id

Context Example#

{}

Human Readable Output#

Ticket with ID id was successfully deleted.

servicenow-query-tickets#


Retrieves ticket information according to the supplied query.

Base Command#

servicenow-query-tickets

Input#

Argument NameDescriptionRequired
limitThe maximum number of tickets to retrieve.Optional
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
queryThe query to run. To learn about querying in ServiceNow, see https://docs.servicenow.com/bundle/istanbul-servicenow-platform/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.htmlOptional
offsetStarting record index to begin retrieving records from.Optional
additional_fieldsAdditional fields to present in the War Room entry and incident context.Optional
system_paramsSystem parameters in the format: fieldname1=value;fieldname2=value. For example: "sysparm_display_value=true;sysparm_exclude_reference_link=True"Optional

Context Output#

PathTypeDescription
Ticket.IDstringThe unique ticket identifier.
Ticket.CreatorstringA string field that indicates the user who created the ticket.
Ticket.CreatedOndateThe date/time when the ticket was created.
Ticket.AssigneestringSpecifies the user assigned to complete the ticket. By default, this field uses a reference qualifier to only display users with the itil role.
Ticket.StatestringStatus of the ticket.
Ticket.SummarystringA human-readable title for the record.
Ticket.NumberstringThe display value of the ticket.
Ticket.ActivebooleanSpecifies whether work is still being done on a task or whether the work for the task is complete.
Ticket.AdditionalCommentsUnknownComments about the task record.
Ticket.PrioritystringSpecifies the ticket priority for the assignee.
Ticket.OpenedAtdateThe date/time when the ticket was first opened.
Ticket.EscalationstringIndicates how long the ticket has been open.

Command Example#

!servicenow-query-tickets limit="3" query="impact<2^short_descriptionISNOTEMPTY" ticket_type="incident"

Context Example#

{
"ServiceNow": {
"Ticket": [
{
"Active": "false",
"Assignee": "admin",
"CloseCode": "Closed/Resolved by Caller",
"CreatedOn": "2018-08-24 18:24:13",
"Creator": "admin",
"ID": "id",
"Number": "INC0000001",
"OpenedAt": "2020-01-23 23:09:51",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"ResolvedBy": "admin",
"State": "7",
"Summary": "Can't read email"
},
{
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2018-08-13 22:30:06",
"Creator": "admin",
"ID": "id",
"Number": "INC0000002",
"OpenedAt": "2020-01-17 23:07:12",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"State": "3",
"Summary": "Network file shares access issue"
},
{
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2018-08-28 14:41:46",
"Creator": "admin",
"ID": "id",
"Number": "INC0000003",
"OpenedAt": "2020-01-24 23:07:30",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"State": "2",
"Summary": "Wireless access is down in my area"
}
]
},
"Ticket": [
{
"Active": "false",
"Assignee": "admin",
"CloseCode": "Closed/Resolved by Caller",
"CreatedOn": "2018-08-24 18:24:13",
"Creator": "admin",
"ID": "id",
"Number": "INC0000001",
"OpenedAt": "2020-01-23 23:09:51",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"ResolvedBy": "admin",
"State": "7",
"Summary": "Can't read email"
},
{
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2018-08-13 22:30:06",
"Creator": "admin",
"ID": "id",
"Number": "INC0000002",
"OpenedAt": "2020-01-17 23:07:12",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"State": "3",
"Summary": "Network file shares access issue"
},
{
"Active": "true",
"Assignee": "admin",
"CreatedOn": "2018-08-28 14:41:46",
"Creator": "admin",
"ID": "id",
"Number": "INC0000003",
"OpenedAt": "2020-01-24 23:07:30",
"OpenedBy": "admin",
"Priority": "1 - Critical",
"State": "2",
"Summary": "Wireless access is down in my area"
}
]
}

Human Readable Output#

ServiceNow tickets#

System IDNumberImpactUrgencySeverityPriorityStateCreated OnCreated ByActiveClose NotesClose CodeDescriptionOpened AtResolved ByResolved AtShort Description
idINC00000011 - High1 - High1 - High1 - Critical7 - Closed2018-08-24 18:24:13patfalseClosed before close notes were made mandatory
Closed/Resolved by CallerUser can't access email on mail.company.com.
2020-01-23 23:09:51admin2020-04-24 19:56:12Can't read email
idINC00000021 - High1 - High1 - High1 - Critical3 - On Hold2018-08-13 22:30:06pattrueUser can't get to any of his files on the file server.2020-01-17 23:07:12Network file shares access issue
idINC00000031 - High1 - High1 - High1 - Critical2 - In Progress2018-08-28 14:41:46admintrueI just moved from floor 2 to floor 3 and my laptop cannot connect to any wireless network.2020-01-24 23:07:30Wireless access is down in my area

servicenow-add-link#


Adds a link to the specified ticket.

Base Command#

servicenow-add-link

Input#

Argument NameDescriptionRequired
idTicket System ID.Required
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
linkThe actual link to publish in ServiceNow ticket, in a valid URL format, for example, http://www.demisto.com.Required
post-as-commentWhether to publish the link as comment on the ticket. Can be "true" or "false". If false will publish the link as WorkNote.Optional
textThe text to represent the link.Optional

Context Output#

There is no context output for this command.

Command Example#

!servicenow-add-link id=id link="http://www.demisto.com" text=demsito_link

Context Example#

{}

Human Readable Output#

Link successfully added to ServiceNow ticket#

System IDNumberImpactUrgencySeverityPriorityStateCreated OnCreated ByActiveDescriptionOpened AtShort Description
idINC00000402 - Medium2 - Medium2 - Medium3 - Moderate3 - On Hold2020-01-26 00:43:54admintrueSeeing JavaScript error message on hiring page on Explorer and Firefox.2020-01-26 00:42:45JavaScript error on hiring page of corporate website

servicenow-add-comment#


Adds a comment to the specified ticket, by ticket ID.

Base Command#

servicenow-add-comment

Input#

Argument NameDescriptionRequired
idTicket System ID.Required
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
commentComment to add.Required
post-as-commentWhether to publish the note as comment on the ticket. Can be "true" or "false". Default is "false".Optional

Context Output#

There is no context output for this command.

Command Example#

!servicenow-add-comment id=id comment="Nice work!"

Context Example#

{}

Human Readable Output#

Comment successfully added to ServiceNow ticket#

System IDNumberImpactUrgencySeverityPriorityStateCreated OnCreated ByActiveDescriptionOpened AtShort Description
idINC00000402 - Medium2 - Medium2 - Medium3 - Moderate3 - On Hold2020-01-26 00:43:54admintrueSeeing JavaScript error message on hiring page on Explorer and Firefox.2020-01-26 00:42:45JavaScript error on hiring page of corporate website

servicenow-upload-file#


Uploads a file to the specified ticket.

Base Command#

servicenow-upload-file

Input#

Argument NameDescriptionRequired
idTicket System ID.Required
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional
file_idWar Room entry ID that includes the file.Required
file_nameFilename of the uploaded file to override the existing file name in the entry.Optional

Context Output#

PathTypeDescription
ServiceNow.Ticket.File.FilenamestringName of the file.
ServiceNow.Ticket.File.LinkstringDownload link for the file.
ServiceNow.Ticket.File.SystemIDstringSystem ID of the file.

Command Example#

Human Readable Output#

servicenow-delete-file#


Delete an attachment from a ticket.

Base Command#

servicenow-delete-file

Input#

Argument NameDescriptionRequired
file_sys_idAttachment File ID.Required

Context Output#

There is no context output for this command.

Command example#

!servicenow-delete-file file_sys_id=1234

Human Readable Output#

Attachment with Sys ID 1234 was successfully deleted.

servicenow-get-record#


Retrieves record information, by record ID.

Base Command#

servicenow-get-record

Input#

Argument NameDescriptionRequired
idRecord System ID.Required
fieldsComma-separated list of table fields to display and output to the context, for example: name,tag,company. ID field is added by default.Optional
table_nameThe name of the table from which to get the record.Required

Context Output#

PathTypeDescription
ServiceNow.Record.IDstringThe unique record identifier for the record.
ServiceNow.Record.UpdatedBystringA string field that indicates the user who most recently updated the record.
ServiceNow.Record.UpdatedAtdateA time-stamp field that indicates the date and time of the most recent update.
ServiceNow.Record.CreatedBystringA string field that indicates the user who created the record.
ServiceNow.Record.CreatedOndateA time-stamp field that indicates when a record was created.

Command Example#

!servicenow-get-record table_name=alm_asset id=id fields=asset_tag,sys_updated_by,display_name

Context Example#

{
"ServiceNow": {
"Record": {
"ID": "id",
"asset_tag": "P1000807",
"display_name": "P1000807 - Apple MacBook Pro 17\"",
"sys_updated_by": "system"
}
}
}

Human Readable Output#

ServiceNow record#

IDasset_tagdisplay_namesys_updated_by
idP1000807P1000807 - Apple MacBook Pro 17"system

servicenow-query-table#


Queries the specified table in ServiceNow.

Base Command#

servicenow-query-table

Input#

Argument NameDescriptionRequired
table_nameThe name of the table to queryRequired
limitThe maximum number of tickets to retrieve.Optional
queryThe query to run. For more information about querying in ServiceNow, see https://docs.servicenow.com/bundle/istanbul-servicenow-platform/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.htmlOptional
fieldsComma-separated list of table fields to display and output to the context, for example: name,tag,company. ID field is added by default.Optional
offsetStarting record index to begin retrieving records from.Optional
system_paramsSystem parameters in the format: fieldname1=value;fieldname2=value. For example: "sysparm_display_value=true;sysparm_exclude_reference_link=True"Optional

Context Output#

PathTypeDescription
ServiceNow.Record.IDstringThe unique record identifier for the record.
ServiceNow.Record.UpdatedBystringA string field that indicates the user who most recently updated the record.
ServiceNow.Record.UpdatedAtdateA time-stamp field that indicates the date and time of the most recent update.
ServiceNow.Record.CreatedBystringA string field that indicates the user who created the record.
ServiceNow.Record.CreatedOndateA time-stamp field that indicates when a record was created.

Command Example#

!servicenow-query-table table_name=alm_asset fields=asset_tag,sys_updated_by,display_name query=display_nameCONTAINSMacBook limit=4 !servicenow-query-table table_name=sys_journal_field query=element_id=<SYS_ID>^ORDERBYsys_created_on limit=10 fields=value,name,element,sys_created_by,sys_created_on

Context Example#

{
"ServiceNow": {
"Record": [
{
"ID": "id",
"asset_tag": "P1000637",
"display_name": "P1000637 - Apple MacBook Air 13\"",
"sys_updated_by": "system"
},
{
"ID": "id",
"asset_tag": "P1000412",
"display_name": "P1000412 - Apple MacBook Pro 17\"",
"sys_updated_by": "system"
},
{
"ID": "id",
"asset_tag": "P1000563",
"display_name": "P1000563 - Apple MacBook Pro 15\"",
"sys_updated_by": "system"
},
{
"ID": "id",
"asset_tag": "P1000626",
"display_name": "P1000626 - Apple MacBook Air 13\"",
"sys_updated_by": "system"
}
]
}
}

Human Readable Output#

ServiceNow records#

IDasset_tagdisplay_namesys_updated_by
idP1000637P1000637 - Apple MacBook Air 13"system
idP1000412P1000412 - Apple MacBook Pro 17"system
idP1000563P1000563 - Apple MacBook Pro 15"system
idP1000626P1000626 - Apple MacBook Air 13"system

servicenow-create-record#


Creates a new record in the specified ServiceNow table.

Base Command#

servicenow-create-record

Input#

Argument NameDescriptionRequired
table_nameThe name of the table in which to create a record.Required
fieldsFields and their values to create the record with, in the format: fieldname1=value;fieldname2=value;...Optional
custom_fieldsCustom (user defined) fields in the format: fieldname1=value;fieldname2=value;...Optional
input_display_valueFlag that indicates whether to set field values using the display value or the actual value. True will treat the input value as the display value. False treats the input values as actual values. The default setting is false.Optional

For more information regarding the input_display_value Argument, please see: https://docs.servicenow.com/bundle/xanadu-platform-administration/page/administer/exporting-data/concept/query-parameters-display-value.html

Context Output#

PathTypeDescription
ServiceNow.Record.IDstringThe unique record identifier for the record.
ServiceNow.Record.UpdatedBystringA string field that indicates the user who most recently updated the record.
ServiceNow.Record.UpdatedAtdateA time-stamp field that indicates the date and time of the most recent update.
ServiceNow.Record.CreatedBystringA string field that indicates the user who created the record.
ServiceNow.Record.CreatedOndateA time-stamp field that indicates when a record was created.

Command Example#

!servicenow-create-record table_name=alm_asset fields="asset_tag=P1000807"

Context Example#

{
"ServiceNow": {
"Record": {
"CreatedAt": "2020-05-10 09:04:27",
"CreatedBy": "admin",
"ID": "id",
"UpdatedAt": "2020-05-10 09:04:27",
"UpdatedBy": "admin"
}
}
}

Human Readable Output#

ServiceNow record created successfully#

CreatedAtCreatedByIDUpdatedAtUpdatedBy
2020-05-10 09:04:27adminid2020-05-10 09:04:27admin

servicenow-update-record#


Updates a record in the specified ServiceNow table.

Base Command#

servicenow-update-record

Input#

Argument NameDescriptionRequired
table_nameThe name of the table to update the record in.Required
idThe system ID of the ticket to update.Required
fieldsFields and their values to update in the record, in the format: fieldname1=value;fieldname2=value;...Optional
custom_fieldsCustom (user defined) fields and their values to update in the record, in the format: fieldname1=value;fieldname2=value;...Optional
input_display_valueFlag that indicates whether to set field values using the display value or the actual value. True will treat the input value as the display value. False treats the input values as actual values. The default setting is false.Optional
clear_fieldsA comma-separated list of fields to clear.Optional

For more information regarding the input_display_value Argument, please see: https://docs.servicenow.com/bundle/xanadu-platform-administration/page/administer/exporting-data/concept/query-parameters-display-value.html

Context Output#

PathTypeDescription
ServiceNow.Record.IDstringThe unique record identifier for the record.
ServiceNow.Record.UpdatedBystringA string field that indicates the user who most recently updated the record.
ServiceNow.Record.UpdatedAtdateA time-stamp field that indicates the date and time of the most recent update.
ServiceNow.Record.CreatedBystringA string field that indicates the user who created the record.
ServiceNow.Record.CreatedOndateA time-stamp field that indicates when a record was created.

Command Example#

!servicenow-update-record table_name=alm_asset id=id custom_fields="display_name=test4"

Context Example#

{
"ServiceNow": {
"Record": {
"CreatedAt": "2019-07-16 08:14:09",
"CreatedBy": "admin",
"ID": "id",
"UpdatedAt": "2020-05-09 19:08:42",
"UpdatedBy": "system"
}
}
}

Human Readable Output#

ServiceNow record with ID 01a92c0d3790200044e0bfc8bcbe5d36 updated successfully#

CreatedAtCreatedByIDUpdatedAtUpdatedBy
2019-07-16 08:14:09adminid2020-05-09 19:08:42system

servicenow-delete-record#


Deletes a record in the specified ServiceNow table.

Base Command#

servicenow-delete-record

Input#

Argument NameDescriptionRequired
table_nameThe table name.Required
idThe system ID of the ticket to delete.Required

Context Output#

There is no context output for this command.

Command Example#

!servicenow-delete-record table_name=alm_asset id=id

Context Example#

{}

Human Readable Output#

ServiceNow record with ID id was successfully deleted.

servicenow-list-table-fields#


Lists API fields for the specified ServiceNow table.

Base Command#

servicenow-list-table-fields

Input#

Argument NameDescriptionRequired
table_nameTable nameRequired

Context Output#

PathTypeDescription
ServiceNow.FieldstringTable API field name.

Command Example#

!servicenow-list-table-fields table_name=alm_asset

Context Example#

{
"ServiceNow": {
"Field": [
{
"Name": "parent"
},
{
"Name": "skip_sync"
},
{
"Name": "residual_date"
},
{
"Name": "residual"
},
{
"Name": "sys_updated_on"
},
{
"Name": "request_line"
},
{
"Name": "sys_updated_by"
},
{
"Name": "due_in"
},
{
"Name": "model_category"
},
{
"Name": "sys_created_on"
},
{
"Name": "sys_domain"
},
{
"Name": "disposal_reason"
},
{
"Name": "model"
},
{
"Name": "install_date"
},
{
"Name": "gl_account"
},
{
"Name": "invoice_number"
},
{
"Name": "sys_created_by"
},
{
"Name": "warranty_expiration"
},
{
"Name": "depreciated_amount"
},
{
"Name": "substatus"
},
{
"Name": "pre_allocated"
},
{
"Name": "owned_by"
},
{
"Name": "checked_out"
},
{
"Name": "display_name"
},
{
"Name": "sys_domain_path"
},
{
"Name": "delivery_date"
},
{
"Name": "retirement_date"
},
{
"Name": "beneficiary"
},
{
"Name": "install_status"
},
{
"Name": "cost_center"
},
{
"Name": "supported_by"
},
{
"Name": "assigned"
},
{
"Name": "purchase_date"
},
{
"Name": "work_notes"
},
{
"Name": "managed_by"
},
{
"Name": "sys_class_name"
},
{
"Name": "sys_id"
},
{
"Name": "po_number"
},
{
"Name": "stockroom"
},
{
"Name": "checked_in"
},
{
"Name": "resale_price"
},
{
"Name": "vendor"
},
{
"Name": "company"
},
{
"Name": "retired"
},
{
"Name": "justification"
},
{
"Name": "department"
},
{
"Name": "expenditure_type"
},
{
"Name": "depreciation"
},
{
"Name": "assigned_to"
},
{
"Name": "depreciation_date"
},
{
"Name": "old_status"
},
{
"Name": "comments"
},
{
"Name": "cost"
},
{
"Name": "quantity"
},
{
"Name": "acquisition_method"
},
{
"Name": "ci"
},
{
"Name": "sys_mod_count"
},
{
"Name": "old_substatus"
},
{
"Name": "sys_tags"
},
{
"Name": "order_date"
},
{
"Name": "support_group"
},
{
"Name": "reserved_for"
},
{
"Name": "due"
},
{
"Name": "location"
},
{
"Name": "lease_id"
},
{
"Name": "salvage_value"
}
]
}
}

Human Readable Output#

ServiceNow Table fields - alm_asset#

Name
parent
skip_sync
residual_date
residual
sys_updated_on
request_line
sys_updated_by
due_in
model_category
sys_created_on
sys_domain
disposal_reason
model
install_date
gl_account
invoice_number
sys_created_by
warranty_expiration
depreciated_amount
substatus
pre_allocated
owned_by
checked_out
display_name
sys_domain_path
delivery_date
retirement_date
beneficiary
install_status
cost_center
supported_by
assigned
purchase_date
work_notes
managed_by
sys_class_name
sys_id
po_number
stockroom
checked_in
resale_price
vendor
company
retired
justification
department
expenditure_type
depreciation
assigned_to
depreciation_date
old_status
comments
cost
quantity
acquisition_method
ci
sys_mod_count
old_substatus
sys_tags
order_date
support_group
reserved_for
due
location
lease_id
salvage_value

servicenow-query-computers#


Queries the cmdb_ci_computer table in ServiceNow.

Base Command#

servicenow-query-computers

Input#

Argument NameDescriptionRequired
computer_idQuery by computer sys_id.Optional
computer_nameQuery by computer name.Optional
queryQuery by specified query, for more information about querying in ServiceNow, see https://docs.servicenow.com/bundle/istanbul-servicenow-platform/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.htmlOptional
asset_tagQuery by asset tag.Optional
limitMaximum number of query results. Default is 10.Optional
offsetStarting record index to begin retrieving records from.Optional

Context Output#

PathTypeDescription
ServiceNow.Computer.IDstringComputer system ID.
ServiceNow.Computer.AssetTagstringComputer Asset tag.
ServiceNow.Computer.NamestringComputer name.
ServiceNow.Computer.DisplayNamestringComputer display name.
ServiceNow.Computer.SupportGroupstringComputer support group.
ServiceNow.Computer.OperatingSystemstringComputer operating system.
ServiceNow.Computer.CompanystringComputer company system ID.
ServiceNow.Computer.AssignedTostringComputer assigned to user system ID.
ServiceNow.Computer.StatestringComputer state.
ServiceNow.Computer.CoststringComputer cost.
ServiceNow.Computer.CommentsstringComputer comments.

Command Example#

!servicenow-query-computers asset_tag=P1000412

Context Example#

{
"ServiceNow": {
"Computer": {
"AssetTag": "P1000412",
"AssignedTo": "admin",
"Company": "admin",
"Cost": "2499.99 USD",
"DisplayName": "P1000412 - MacBook Pro 17\"",
"ID": "id",
"Name": "MacBook Pro 17\"",
"OperatingSystem": "Mac OS 10 (OS/X)",
"State": "In use"
}
}
}

Human Readable Output#

ServiceNow Computers#

IDAsset TagNameDisplay NameOperating SystemCompanyAssigned ToStateCost
idP1000412MacBook Pro 17"P1000412 - MacBook Pro 17"Mac OS 10 (OS/X)adminadminIn use2499.99 USD

servicenow-query-groups#


Queries the sys_user_group table in ServiceNow.

Base Command#

servicenow-query-groups

Input#

Argument NameDescriptionRequired
group_idQuery by group system ID.Optional
group_nameQuery by group name.Optional
queryQuery by specified query, for more information about querying in ServiceNow, see https://docs.servicenow.com/bundle/istanbul-servicenow-platform/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.htmlOptional
limitMaximum number of query results. Default is 10.Optional
offsetStarting record index to begin retrieving records from.Optional

Context Output#

PathTypeDescription
ServiceNow.Group.IDstringGroup system ID.
ServiceNow.Group.DescriptionstringGroup description.
ServiceNow.Group.NamestringGroup name.
ServiceNow.Group.ManagerstringGroup manager system ID.
ServiceNow.Group.UpdateddateDate/time the group was last updated.

Command Example#

!servicenow-query-groups group_name=test1

Context Example#

{}

Human Readable Output#

No groups found.

servicenow-query-users#


Queries the sys_user table in ServiceNow.

Base Command#

servicenow-query-users

Input#

Argument NameDescriptionRequired
user_idQuery by user system ID.Optional
user_nameQuery by username.Optional
queryQuery by specified query, for more information about querying in ServiceNow, see https://docs.servicenow.com/bundle/istanbul-servicenow-platform/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.htmlOptional
limitMaximum number of query results. Default is 10.Optional
offsetStarting record index to begin retrieving records from.Optional

Context Output#

PathTypeDescription
ServiceNow.User.IDstringUser system ID.
ServiceNow.User.NamestringUser name (first and last).
ServiceNow.User.UserNamestringUser username.
ServiceNow.User.EmailstringUser email address.
ServiceNow.User.CreateddateDate/time the user was created.
ServiceNow.User.UpdateddateDate/time the user was last updated.

Command Example#

!servicenow-query-users user_name=sean.bonnet

Context Example#

{
"ServiceNow": {
"User": {
"Created": "2012-02-18 03:04:50",
"Email": "sean.bonnet@example.com",
"ID": "id",
"Name": "Sean Bonnet",
"Updated": "2020-04-25 19:01:46",
"UserName": "sean.bonnet"
}
}
}

Human Readable Output#

ServiceNow Users#

IDNameUser NameEmailCreatedUpdated
idSean Bonnetsean.bonnetsean.bonnet@example.com2012-02-18 03:04:502020-04-25 19:01:46

servicenow-get-table-name#


Gets table names by a label to use in commands.

Base Command#

servicenow-get-table-name

Input#

Argument NameDescriptionRequired
labelThe table label, for example: Asset, Incident, IP address, and so on.Required
limitMaximum number of query results. Default is 10.Optional
offsetStarting record index to begin retrieving records from.Optional

Context Output#

PathTypeDescription
ServiceNow.Table.IDstringTable system ID.
ServiceNow.Table.NamestringTable name to use in commands, for example: alm_asset.
ServiceNow.Table.SystemNamestringTable system name, for example: Asset.

Command Example#

!servicenow-get-table-name label=ACE

Context Example#

{
"ServiceNow": {
"Table": {
"ID": "id",
"Name": "cmdb_ci_lb_ace",
"SystemName": "CMDB CI Lb Ace"
}
}
}

Human Readable Output#

ServiceNow Tables for label - ACE#

IDNameSystem Name
idcmdb_ci_lb_aceCMDB CI Lb Ace

servicenow-get-ticket-notes#


Gets notes from the specified ServiceNow ticket. Notes can be retrieved either by granting Read permissions for the sys_journal_field table, or by setting the use_display_value parameter to true.

Base Command#

servicenow-get-ticket-notes

Input#

Argument NameDescriptionRequired
idTicket System ID.Required
limitMaximum number of ticket notes. Default is 10.Optional
offsetOffset of the ticket notes. Default is 0.Optional
use_display_valueWhether to use sysparm_display_value to retrieve comments and work notes. Overrides the value set in the instance configuration. Possible values are: true, false.Optional
ticket_typeThe ticket type that notes should be retrieved for when using the use_display_value option. Possible values are: incident, problem, change_request, sc_request, sc_task, sc_req_item, sn_si_incident. Default is incident.Optional
add_as_entryWhether to add ticket notes and work notes as notes in the War Room. Possible values are true, false.Optional

Context Output#

PathTypeDescription
ServiceNow.Ticket.IDstringTicket ID.
ServiceNow.Ticket.Note.ValueunknownTicket note value.
ServiceNow.Ticket.Note.CreatedOndateDate/time the ticket note was created.
ServiceNow.Ticket.Note.CreatedBystringUser who created the ticket note.
ServiceNow.Ticket.Note.TypestringTicket note type.

Command Example#

!servicenow-get-ticket-notes id=id

Context Example#

{
"ServiceNow": {
"Ticket": {
"ID": "id",
"Note": [
{
"CreatedBy": "admin",
"CreatedOn": "2020-01-26 00:43:54",
"Type": "Comment",
"Value": "JavaScript error (line 202) on the home page. Not sure what is\n\t\t\tgoing on, does not happen on my Windows machine!\n\t\t"
},
{
"CreatedBy": "admin",
"CreatedOn": "2020-04-17 23:12:43",
"Type": "Comment",
"Value": "Added an attachment"
},
{
"CreatedBy": "admin",
"CreatedOn": "2020-05-10 09:04:15",
"Type": "Work Note",
"Value": "[code]<a class=\"web\" target=\"_blank\" href=\"http://www.demisto.com\" >demsito_link</a>[/code]"
},
{
"CreatedBy": "admin",
"CreatedOn": "2020-05-10 09:04:18",
"Type": "Work Note",
"Value": "Nice work!"
}
]
}
}
}

Human Readable Output#

ServiceNow notes for ticket 471d4732a9fe198100affbf655e59172#

ValueCreated OnCreated ByType
JavaScript error (line 202) on the home page. Not sure what is
going on, does not happen on my Windows machine!
2020-01-26 00:43:54adminComment
Added an attachment2020-04-17 23:12:43adminComment
[code]demsito_link[/code]2020-05-10 09:04:15adminWork Note
Nice work!2020-05-10 09:04:18adminWork Note

servicenow-add-tag#


Adds a tag to a ticket. The tag will be visible in the label_entry table and can be retrieved using the "!servicenow-query-table table_name=label_entry fields=title,table,sys_id,id_display,id_type" command.

Base Command#

servicenow-add-tag

Input#

Argument NameDescriptionRequired
idTicket System ID.Required
tag_idTag system ID. Can be retrieved using the "!servicenow-query-table table_name=label fields=name,active,sys_id" command.Required
titleTag title. For example: "Incident - INC000001".Required
ticket_typeTicket type. Can be "incident", "problem", "change_request", "sc_request", "sc_task", "sc_req_item", or "sn_si_incident". Default is "incident".Optional

Context Output#

PathTypeDescription
ServiceNow.Ticket.IDStringThe unique ticket identifier.
ServiceNow.Ticket.TagTitleStringTicket tag title.
ServiceNow.Ticket.TagIDStringTicket tag ID.

servicenow-query-items#


Queries the sc_cat_item table in ServiceNow.

Base Command#

servicenow-query-items

Input#

Argument NameDescriptionRequired
nameQuery by name. Does not require an exact match.Optional
offsetStarting record index to begin retrieving records from.Optional
limitMaximum number of query results. Default is 10.Optional

Context Output#

PathTypeDescription
ServiceNow.CatalogItem.IDStringCatalog item system ID.
ServiceNow.CatalogItem.NameStringCatalog item name.
ServiceNow.CatalogItem.DescriptionStringCatalog item description.
ServiceNow.CatalogItem.PriceNumberCatalog item price.

Command Example#

!servicenow-query-items name=laptop limit=2

Context Example#

{
"ServiceNow": {
"CatalogItem": [
{
"Description": "Lenovo - Carbon x1",
"ID": "id",
"Name": "Standard Laptop",
"Price": "1100"
},
{
"Description": "Dell XPS 13",
"ID": "id",
"Name": "Development Laptop (PC)",
"Price": "1100"
}
]
}
}

Human Readable Output#

ServiceNow Catalog Items#

IDNamePriceDescription
idStandard Laptop1100Lenovo - Carbon x1
idDevelopment Laptop (PC)1100Dell XPS 13

servicenow-get-item-details#


Retrieves item details by system ID.

Base Command#

servicenow-get-item-details

Input#

Argument NameDescriptionRequired
idCatalog item system ID.Required

Context Output#

PathTypeDescription
ServiceNow.CatalogItem.IDStringCatalog item system ID.
ServiceNow.CatalogItem.NameStringCatalog item name.
ServiceNow.CatalogItem.DescriptionStringCatalog item description.
ServiceNow.CatalogItem.PriceNumberCatalog item price.
ServiceNow.CatalogItem.Variables.MandatoryBooleanIs the variable mandatory as part of the ordering process.
ServiceNow.CatalogItem.Variables.NameStringA name to identify the question.
ServiceNow.CatalogItem.Variables.QuestionStringQuestion to ask users ordering the catalog item.
ServiceNow.CatalogItem.Variables.TypeStringThe variable type.

Command Example#

!servicenow-get-item-details id=id

Context Example#

{
"ServiceNow": {
"CatalogItem": {
"Description": "Dell XPS 13",
"ID": "id",
"Name": "Development Laptop (PC)",
"Price": "$1,000.00",
"Variables": [
{
"Mandatory": false,
"Name": "hard_drive",
"Question": "What size solid state drive do you want?",
"Type": "Multiple Choice"
},
{
"Mandatory": false,
"Name": "requested_os",
"Question": "Please specify an operating system",
"Type": "Multiple Choice"
}
]
}
}
}

Human Readable Output#

ServiceNow Catalog Item#

IDNameDescription
idDevelopment Laptop (PC)Dell XPS 13

Item Variables#

QuestionTypeNameMandatory
What size solid state drive do you want?Multiple Choicehard_drivefalse
Please specify an operating systemMultiple Choicerequested_osfalse

servicenow-create-item-order#


Orders the specified catalog item.

Base Command#

servicenow-create-item-order

Input#

Argument NameDescriptionRequired
idCatalog item system ID.Required
quantityQuantity of the item to order.Required
variablesIf there are mandatory variables defined for the item, they must be passed to the endpoint. Can be retrieved using the servicenow-get-item-details command. For example, var1=value1;var2=value2.Optional

Context Output#

PathTypeDescription
ServiceNow.OrderRequest.IDStringGenerated request system ID.
ServiceNow.OrderRequest.RequestNumberStringNumber of the generated request.

Command Example#

!servicenow-create-item-order id=id quantity=1 variables="hard_drive=16GB;requested_os=linux"

Context Example#

{
"ServiceNow": {
"OrderRequest": {
"ID": "id",
"RequestNumber": "REQ0010004"
}
}
}

Human Readable Output#

ServiceNow Order Request#

IDRequest Number
idREQ0010004

servicenow-document-route-to-queue#


Documents a route to a queue. Requires an installation of the Advanced Work Assignments plugin. An active queue and service channel to the designated table.

Base Command#

servicenow-document-route-to-queue

Input#

Argument NameDescriptionRequired
queue_idQueue ID. Can be retrieved using the "!servicenow-query-table table_name=awa_queue fields=name,number,order" command.Required
document_tableDocument table.Optional
document_idDocument ID.Required

Context Output#

PathTypeDescription
ServiceNow.WorkItem.WorkItemIDStringUnique ID of the work item assigned to the queue.
ServiceNow.WorkItem.DocumentTableStringName of the table associated with the document
ServiceNow.WorkItem.DocumentIDStringUnique ID of the document to be routed to the queue.
ServiceNow.WorkItem.QueueIDStringUnique ID of the queue on which to route a document.
ServiceNow.WorkItem.DisplayNameStringName of the document to be routed by this work item, for example: case record.

get-mapping-fields#


Returns the list of fields for an incident type. This command is for debugging purposes.

Base Command#

get-mapping-fields

Input#

There are no input arguments for this command.

Context Output#

There is no context output for this command.

get-remote-data#


Get remote data from a remote incident. This method does not update the current incident, and should be used for debugging purposes.

Base Command#

get-remote-data

Input#

Argument NameDescriptionRequired
idThe ticket ID.Required
lastUpdateRetrieve entries that were created after lastUpdate.Required

Context Output#

There is no context output for this command.

servicenow-get-tasks-for-co#


gets the tasks associated to change request

Base Command#

servicenow-get-tasks-for-co

Input#

Argument NameDescriptionRequired
idID of the change request.Required

Context Output#

PathTypeDescription
ServiceNow.Tasks.IDStringTask ID
ServiceNow.Tasks.DescriptionUnknownDescription of task
ServiceNow.Tasks.NameUnknownName of task
ServiceNow.Tasks.StateUnknownstate of task

Command example#

!servicenow-get-tasks-for-co id="1234"

Context Example#

{
"ServiceNow": {
"Tasks": {
"ServiceNow.Tasks(val.ID===obj.ID)": [
{
"Description": "test",
"ID": "1234",
"Name": "CTASK0010007",
"State": "1 - New"
}
]
}
}
}

Human Readable Output#

ServiceNow Catalog Items#

IDNameStateDescription
1234CTASK00100071 - Newtest

servicenow-create-co-from-template#


Create a change request from a template.

Base Command#

servicenow-create-co-from-template

Input#

Argument NameDescriptionRequired
templateTemplate for creating a standard change request.Required
force_default_urlWhether to force-use the default api version (not versioned), ignoring the API version parameter. Default is falseOptional

Context Output#

PathTypeDescription
ServiceNow.Ticket.IDUnknownServiceNow ticket ID.
ServiceNow.Ticket.OpenedByUnknownServiceNow ticket opener ID.
ServiceNow.Ticket.CreatedOnUnknownServiceNow ticket creation date.
ServiceNow.Ticket.AssigneeUnknownServiceNow ticket assignee ID.
ServiceNow.Ticket.StateUnknownServiceNow ticket state.
ServiceNow.Ticket.SummaryUnknownServiceNow ticket short summary.
ServiceNow.Ticket.NumberUnknownServiceNow ticket number.
ServiceNow.Ticket.ActiveUnknownServiceNow ticket active.
ServiceNow.Ticket.AdditionalCommentsUnknownServiceNow ticket comments.
ServiceNow.Ticket.PriorityUnknownServiceNow ticket priority.
ServiceNow.Ticket.OpenedAtUnknownServiceNow ticket opening time.
ServiceNow.Ticket.ResolvedByUnknownServiceNow ticket resolver ID.
ServiceNow.Ticket.CloseCodeUnknownServiceNow ticket close code.

Command example#

!servicenow-create-co-from-template template=1234

Context Example#

{
"ServiceNow": {
"Ticket": {
"ServiceNow.Ticket(val.ID===obj.ID)": {
"Active": {
"display_value": "true",
"value": true
},
"AdditionalComments": {
"display_value": "",
"value": ""
},
"CloseCode": {
"display_value": "",
"value": ""
},
"CreatedOn": {
"display_value": "03/05/2022 08:17:00",
"display_value_internal": "2022-05-03 08:17:00",
"value": "2022-05-03 15:17:00"
},
"Creator": "1234",
"ID": {
"display_value": "1234",
"value": "1234"
},
"Number": {
"display_value": "CHG001234",
"value": "CHG001234"
},
"OpenedAt": {
"display_value": "03/05/2022 08:17:00",
"display_value_internal": "2022-05-03 08:17:00",
"value": "2022-05-03 15:17:00"
},
"OpenedBy": "1234",
"Priority": [
"4 - Low"
],
"State": {
"display_value": "New",
"value": -5
},
"Summary": {
"display_value": "Add network switch to cabinet",
"value": "Add network switch to cabinet"
}
},
"Ticket(val.ID===obj.ID)": {
"Active": {
"display_value": "true",
"value": true
},
"AdditionalComments": {
"display_value": "",
"value": ""
},
"CloseCode": {
"display_value": "",
"value": ""
},
"CreatedOn": {
"display_value": "03/05/2022 08:17:00",
"display_value_internal": "2022-05-03 08:17:00",
"value": "2022-05-03 15:17:00"
},
"Creator": "1234",
"ID": {
"display_value": "1234",
"value": "1234"
},
"Number": {
"display_value": "CHG001234",
"value": "CHG001234"
},
"OpenedAt": {
"display_value": "03/05/2022 08:17:00",
"display_value_internal": "2022-05-03 08:17:00",
"value": "2022-05-03 15:17:00"
},
"OpenedBy": "6b0e49021b158150042611b4bd4bcb5e",
"Priority": [
"4 - Low"
],
"State": {
"display_value": "New",
"value": -5
},
"Summary": {
"display_value": "Add network switch to cabinet",
"value": "Add network switch to cabinet"
}
}
}
}
}

Human Readable Output#

ServiceNow ticket was created successfully.#

System IDNumberImpactUrgencyPriorityStateCreated OnCreated ByActiveDescriptionOpened AtShort Description
1234CHG0012343 - Ministry3 - Low4 - Low-5 - New2022-05-03 15:17:00admin_cnt_test_Jan2022-01trueThis standard change template describes adding a new network switch to a datacenter cabinet2022-05-03 15:17:00Add network switch to cabinet

servicenow-generic-api-call#


Generic call to ServiceNow api

Base Command#

servicenow-generic-api-call

Input#

Argument NameDescriptionRequired
methodaction to be performed on path. Possible values are: GET, POST, PATCH, DELETE. Default is 0.Required
paththe API path starting with forward slash (/).Required
json_bodywhether or not the request body is json. Possible values are: true, false. Default is false.Optional
bodyjson to send in body.Optional
headersjson of headers to add.Optional
sc_apiService Catalog Call. Possible values are: true, false. Default is false.Optional
cr_apiChange Request Call. Possible values are: true, false. Default is false.Optional
custom_apiDefine a custom API root (like /api/custom/tasks).Optional

Context Output#

PathTypeDescription
ServiceNow.Generic.ResponsestringGeneric response to servicenow api

Command example#

!servicenow-generic-api-call method=GET path="/table/sn_cmdb_workspace_cmdb_ci_demo"

Context Example#

{
"ServiceNow": {
"Generic": {
"Response": {
"result": [
{
"sys_created_by": "admin_test_Nov2020-01",
"sys_created_on": "2021-02-13 13:36:55",
"sys_id": "1234",
"sys_mod_count": "0",
"sys_tags": "",
"sys_updated_by": "admin_test_Nov2020-01",
"sys_updated_on": "2021-02-13 13:36:55"
}
]
}
}
}
}

Human Readable Output#

Request for GET method is successful

servicenow-get-ticket-attachments#


Retrieve file attachments from tickets.

Base Command#

servicenow-get-ticket-attachments

Input#

Argument NameDescriptionRequired
sys_idsys_id of the ticket containing the file.Required

Context Output#

There is no context output for this command.

Human Readable Output#

Successfully retrieved attachments for ticket with sys id 111

Troubleshooting#

The following are tips for handling issues with mirroring incidents between ServiceNow and Cortex XSOAR.

IssueRecommendation
Unauthorized connection error.Check the credentials.
Make sure the oauth ID and secret are created using the account configured on Cortex XSOAR. Refer the KB.
Check the roles to ensure the following roles are granted - itil (For ServiceNow v2), cmdb_inst_admin (For ServiceNow CMDB), rest_api_explorer, snc_platform_rest_api_access, web_service_admin.
Use the client ID and secret in place of username and password in the instance configuration. And use the account's username and password during the oauth step in the pop up window.
Mirroring is not working.Open Context Data and search for dbot. Confirm the dbot fields are configured correctly either through the mapper for that specific incident type or using setIncident. Specifically, make sure the integration instance is configured correctly for the mirroring direction (ingoing, outgoing, both) - dbotMirrorId, dbotMirrorDirection, dbotMirrorInstance, dbotMirrorTags
Comments and work notes from before incident creation are not fetched/mirrored.Mirroring settings apply only for incidents that are fetched after applying the settings.
For example, if a user creates a ServiceNow incident with added comments/work notes and then defines a ServiceNow integration instance with mirroring in Cortex XSOAR, those comments/work notes are not fetched with the incident in Cortex XSOAR.
To fetch pre-existing comments/work notes, you can use the servicenow-get-ticket-notes command.
To retrieve comments and work notes using this command follow one of these steps:
- Grant elevated privileges to the sys_journal_field. This is done by assigning the Itil role (see this ServiceNow community link on giving elevated read access and potential risks).
- Select the Use Display Value checkbox in the instance configuration. This will retrieve comments and work notes using their display value from ServiceNow. When choosing this option, you must select the date format of your instance from the Instance Date Format dropdown menu (see the ServiceNow documentation for an explanation how to find the date format of your instance). Note that in this case, the values that will appear under the sys_created_by field of the retrieved notes are the display values from ServiceNow and not the system values, e.g., "System Administrator" instead of "admin".
Ticket is not closing.Verify the integration instance is configured correctly for the Mirrored XSOAR Ticket closure method or Mirrored ServiceNow Ticket closure method fields.
Required fields are not getting sent.This may be a mapping issue, specifically if close reason and close notes are required.
Auto-Extract extracts sys_id as a file.This is by design. To resolve this:
- Turn off Auto-Extract for all fields and only used on specific fields.
- Turn off Auto-Extract at the incident level and use the task level for extraction.
Date displayed in the Cortex XSOAR layout is not aligned with ServiceNow.1. Navigate to the incoming-mapper you are using.
2. For every field that uses the DateStringToISOFormat script, change the dayfirst argument to true.