IdentificationEngineScriptableApi - Global
- UpdatedJan 30, 2025
- 54 minutes to read
- Yokohama
- API reference
The IdentificationEngineScriptableApi uses the Identification and Reconciliation framework to minimize the creation of duplicate configuration items (CIs) and to reconcile CI attributes by only accepting information from authorized data sources when updating the Configuration Management Database (CMDB).
IdentificationEngineScriptableApi - createOrUpdateCI(String source, String input)
Inserts or updates configuration items (CI) and non-Configuration Management Database (CMDB) CIs (classes not extending from cmdb_ci) in the CMDB based on identification and reconciliation rules. Use this API instead of updating the CMDB directly.
You must pass non-CMDB CIs as lookup or related items in the IRE payload. For additional information on non-CMDB table ingestion, see IRE support for non-CMDB tables.
Name | Type | Description |
---|---|---|
input | String | Required. Input payload. A JSON formatted string of
configuration items to add or update.
|
input.items | Array of Objects | Items to add or update.
|
input.items.className | String | Required. Class/table name, sys_class_name, of the
configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_ci_linux_server or cmdb_ci_win_server. |
input.items.display_values | Object | Reference fields to create or update for this related item as name-value pairs,
where the name is the field name and the value is the referenced display value. If you
want to use the sys_id instead of the display value for reference fields, pass the
information in the input.items.lookup.values parameter instead of
in this parameter. Reference field names depend on the fields selected by the user, such as:
|
input.items.internal_id | String | Unique item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup | Array of Objects | Identifies the top-level item containing the lookup (lookup-based identification). These records are used to identify the configuration item based on a lookup table that has a reference back to cmdb_ci. For example:
|
input.items.lookup.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_serial_number or cmdb_ci_network_adapter. |
input.items.lookup.internal_id | String | Unique item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup.sys_object_source_info | Object | Unique CI identifier for a specific
source.
|
input.items.lookup.sys_object_source_info.source_feed | String | If the source can have
multiple feeds, use this field to provide the name of the feed sending this
item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.lookup.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.lookup.sys_object_source_info.source_native_key | String | Unique key/id for the
item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.lookup.sys_object_source_info.source_recency_timestamp | String | UTC date and
time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.lookup.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.items.related | Array | Reference to the top-level item that contains the related list. Rules in the Related Entry [cmdb_related_entry] define what type of records can be in this array. These records are used to add items based on
a related table that has a reference to the CI that is being identified. The related table may or may not extend cmdb_ci. These records are not used to identify the configuration item.
|
input.items.related.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_software_instance or cmdb_key_value. |
input.items.related.internal_id | String | Unique item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.related.sys_object_source_info | Object | Unique CI identifier for a specific
source.
|
input.items.related.sys_object_source_info.source_feed | String | If the source can have
multiple feeds, use this field to provide the name of the feed sending this
item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.related.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.related.sys_object_source_info.source_native_key | String | Unique key/id for the
item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.related.sys_object_source_info.source_recency_timestamp | String | UTC date and
time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.related.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.items.settings | Object | Parameters that define the types of updates that are
permitted.
|
input.items.settings.skipReclassificationRestrictionRules | Boolean | Flag that indicates whether IRE should not run the Reclassification Restriction rule that matches the class for the payload item. Valid values:
Default: false |
input.items.settings.updateWithoutDowngrade | Boolean | Flag that indicates whether update and downgrade are both permitted for this item. Valid values:
Default: false |
input.items.settings.updateWithoutUpgrade | Boolean | Flag that indicates whether update and upgrade are both permitted for this item. Valid values:
Default: false |
input.items.settings.updateWithoutSwitch | Boolean | Flag that indicates whether the item can be updated and the class switched. Valid values:
Default: false |
input.items.sys_object_source_info | Object | Unique CI identifier for a specific
source.
|
input.items.sys_object_source_info.source_feed | String | If the source can have
multiple feeds, use this field to provide the name of the feed sending this
item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.sys_object_source_info.source_native_key | String | Unique key/id for the
item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.sys_object_source_info.source_recency_timestamp | String | UTC date and
time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.referenceItems | Array of Objects | List that define references between items in the input payload.
|
input.referenceItems.referenced | String | The internal_id defined for the item being referenced by another item. |
input.referenceItems.referencedBy | String | The internal_id defined for the item that references another item. |
input.referenceItems.referenceField | String | Name of the reference field in the class/table for the referencedBy item. |
input.relations | Array of Objects | List that specifies relationships between items in the input payload. An object in this array can use either of two formats.
|
input.relations.child | Number | Integer index of the CI object in the items array that represents the child in the relationship (items, items.related, or items.lookup.) |
input.relations.child_id | String | The internal_id of the child item in the relation (items, items.related, or items.lookup.) |
input.relations.parent | Number | Integer index of the parent item in the items array (items, items.related, or items.lookup.) |
input.relations.parent_id | String | The internal_id of the parent item in the relation (items, items.related, or items.lookup.) |
input.relations.sys_rel_source_info | Object | Discovery source information for the relationship. For non-dependency relationships, this information is saved in the Relationship Sources [sys_rel_source] table (not persisted for
identifyCIEnhanced() or identifyCI() methods.) Data type: Object
|
input.relations.sys_rel_source_info.source_name | String | Discovery source name. Default: Discovery source passed in the API method parameter. |
input.relations.sys_rel_source_info.source_feed | String | Any string that is a
sub-discovery/scan within the discovery source. Default: 'UNKNOWN' is stored in the source_feed column when creating a record in sys_rel_source table. |
input.relations.type | String | Type of relationship that exists between the parent and child items. This must be a name field value from the CI Relationship Type [cmdb_rel_type] table. |
source | String | Identifies the data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the cmdb_ci table. |
Type | Description |
---|---|
<String> | JSON formatted string that is a list of results for the configuration items in
the input string. Each result string is in the format 'items: [{}], relations:[{}]',
where each item within the items and relations lists contains name-value pairs.
Data type: String |
<String>.additionalCommittedItems | No values are currently returned. |
<String>.additionalCommittedRelations | No values are currently returned. |
<String>.items | Description of the created or updated CIs. Data type: Object
|
<String>.items.additionalRelatedItems | List of information about additional lookup and related items that were processed but not provided as part of the input payload. These items are from partial payloads. This information is not currently returned. Data type: Array of Objects
|
<String>.items.additionalRelatedItems.className | Class/table name (sys_class_name) of the CI that was created or updated. Data type: String |
<String>.items.additionalRelatedItems.inputIndices | Index of the corresponding input item. For top-level items, it is a list of integers. For related or lookup items, it is list of JSON objects. Data type: Array of Numbers or Array of Objects
|
<String>.items.additionalRelatedItems.inputIndices.mainIndex | Index value from the request body items array that
corresponds to the CI parent of the additional related item. Data type: Number |
<String>.items.additionalRelatedItems.inputIndices.subIndex | Index value from the request body items.lookup array that
corresponds to the additional related item. Data type: Number |
<String>.items.additionalRelatedItems.operation | Type of operation. Possible values:
Data type: String |
<String>.items.additionalRelatedItems.sysId | Sys_id of the additional related items. Data type: String |
<String>.items.className | Class/table name (sys_class_name) of the CI that
was created or updated. Data type: String |
<String>.items.duplicateIndices | List of indexes of CIs that are
duplicates of the current item. Data type: Array |
<String>.items.errorCount | Number of errors. Data type: Number |
<String>.items.errors | List of errors encountered while processing this CI. Data type: Array of Objects
|
<String>.items.errors.error | Type of error encountered while processing the
CI. Data type: String |
<String>.items.errors.message | Error message associated with the error. Data type: String |
<String>.items.identificationAttempts | List of attempts that were made to identify the CIs. Data type: Array of Objects
|
<String>.items.identificationAttempts.attemptResult | Results of the attempt to identify the CI. Possible values:
Data type: String |
<String>.items.identificationAttempts.attributes | List of CI identifier entry attributes that were used during the identification process. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>.items.identificationAttempts.hybridEntryCiAttributes | No values are currently returned. |
<String>.items.identificationAttempts.identifierName | Identifier rule used
for this CI identification attempt. Data type: String |
<String>.items.identificationAttempts.searchOnTable | Name of the table
searched during the identification process. Data type: String |
<String>.items.identifierEntrySysId | Sys_id for the identifier rule used to identify the CI. Data type: String Table: Identifier Entry [cmdb_identifier_entry] |
<String>.items.info | List that contain additional information about the processing of the item. Data type: Array of Objects
|
<String>.items.info.code | Reclassification type that was skipped. Possible values:
Data type: String |
<String>.items.info.message | Message that provides additional insights into the reason for skipping the
reclassification. Data type: String |
<String>.items.info.ruleSysId | Sys_id of the reclassification restriction rule that was matched. Applicable only
when IRE skips reclassification due to reclassification restriction rule. This value
is empty if the reclassification is skipped due to a payload or global flag. Data type: String |
<String>.items.inputIndices | Index values for CIs from the request body items array that
correspond to this CI. Data type: Array |
<String>.items.maskedAttributes | List of attributes whose update by a
non-authoritative data source was skipped as defined by the
Reconciliation
Rules. Data type: Array |
<String>.items.relatedItems | List that provides information about the processed related items. Data type: Array of Objects
|
<String>.items.relatedItems.className | Class/table name (sys_class_name) of the related item. Data type: String |
<String>.items.relatedItems.errors | List of errors that occurred during processing. Data type: Array of Objects
|
<String>.items.relatedItems.errorCount | Number of errors detected during processing. Data type: Number |
<String>.items.relatedItems.inputIndices | Indexes of the corresponding related items. Data type: Array or Numbers
|
<String>.items.relatedItems.inputIndices.mainIndex | Integer value from the request body items array that
corresponds to the CI parent of the related item. Data type: Number |
<String>.items.relatedItems.inputIndices.subIndex | Integer value from the request body items.lookup array that
corresponds to the related item. Data type: Number |
<String>.items.relatedItems.operation | Type of operation. Possible values:
Data type: String |
<String>.items.relatedSysIds | List of the sys_id values for related items (table lookup items) from the request body items.lookup array. Notable values - null: No sys_id was identified for this related item. Data type: Array |
<String>.items.sys_id | Sys_id of the CI that was updated or
created. Data type: String |
<String>.relations | Information about the processed relations. Data type: Array of Objects
|
<String>.relations.className | Sys_class_name of this dependent relationship CI. Only supported value: cmdb_rel_ci: CI Relationship table. Data type: String |
<String>.relations.errorCount | Number of errors. Data type: Number |
<String>.relations.inputIndices | Indexes of the corresponding input relations. Data type: Array |
<String>.relations.operation | Type of operation performed. Possible values:
Data type: String |
<String>.relations.sysId | Sys_id of the dependent relationship
CI. Data type: String |
Example
The following shows how to reclassify a configuration item.
var payload = {
"items": [
{
"className": "cmdb_ci_win_server",
"values": {
"short_description": "Linux server description",
"name": "Linux Server 1"
}
}
]
};
var input = new JSON().encode(payload);
var output = SNC.IdentificationEngineScriptableApi.createOrUpdateCI('ServiceNow', input);
gs.print(output);
Output:
{
"items": [
{
"className": "cmdb_ci_linux_server",
"operation": "NO_CHANGE",
"sysId": "440577800f321010150efc91ff767e94",
"identifierEntrySysId": "556eb250c3400200d8d4bea192d3ae92",
"identificationAttempts": [
{
"attributes": [],
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"serial_number",
"serial_number_type"
],
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"serial_number"
],
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"name"
],
"identifierName": "Hardware Rule",
"attemptResult": "MATCHED",
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
}
],
"info": [
{
"message": "CI Reclassification not allowed from class: [cmdb_ci_linux_server] to [cmdb_ci_win_server] by a reclassification restriction rule",
"code": "SKIPPED_CLASS_SWITCH",
"ruleSysId": "b3d4b3800f321010150efc91ff767eab"
}
],
"errorCount": 0,
"warningCount": 0,
"markers": [],
"inputIndices": [
0
],
"mergedPayloadIds": []
}
],
"additionalCommittedItems": [],
"relations": [],
"additionalCommittedRelations": []
}
Example
var payload = {
"items": [
{
"className": "cmdb_ci_win_server",
"values": {
"chassis_type": "Desktop",
"os": "Windows 2012 R2 Datacenter",
"name": "Windows2012Server1",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"cpu_count": "1"
},
"lookup": [
{
"values": {
"valid": "true",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"serial_number_type": "bios"
},
"className": "cmdb_serial_number"
},
{
"values": {
"valid": "true",
"serial_number": "3311-9736-4988-9744-1749-4183-41",
"serial_number_type": "chassis"
},
"className": "cmdb_serial_number"
}],
"internal_id": "16777219",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "16777219",
"source_recency_timestamp": "2019-10-18 08:31:23"
}},
{
"className": "cmdb_ci_spkg",
"values": {
"name": "Windows 2012 R2 Datacenter",
"key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL"
},
"related": [
{
"internal_id": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219",
"values": {
"name": "Windows 2012 R2 Datacenter-SAMLABVM52"
},
"className": "cmdb_software_instance",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}}]},
{
"className": "cmdb_ci_app_server_tomcat",
"values": {
"running_process_key_parameters": "/opt/OV/nonOV/tomcat/b/temp org.apache.catalina.startup.Bootstrap start",
"install_directory": "/opt/OV/nonOV/tomcat/b",
"name": "Tomcat@hpom9:3443",
"server_port": "8006",
"sys_class_name": "cmdb_ci_app_server_tomcat"
},
"internal_id": "tomcat_id"
}],
"relations": [
{
"parent_id": "tomcat_id",
"child_id": "16777219",
"type": "Runs on::Runs"
}],
"referenceItems": [
{
"referenceField": "installed_on",
"referenced": "16777219",
"referencedBy": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}]};
var jsonUntil = new JSON();
var input = jsonUntil.encode(payload);
var output = SNC.IdentificationEngineScriptableApi.createOrUpdateCI('ServiceNow', input);
gs.print(output);
Output:
{
"items": [
{
"className": "cmdb_ci_win_server",
"operation": "INSERT",
"sysId": "d56ab6eadbd510102f67dfea5e96194e",
"relatedSysIds": [
"dd6af62adb1910102f67dfea5e96197f",
"996af62adb1910102f67dfea5e961980"
],
"relatedItems": [
{
"errors": [],
"operation": "INSERT",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"sysId": "dd6af62adb1910102f67dfea5e96197f",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 0
}
],
"className": "cmdb_serial_number"
},
{
"errors": [],
"operation": "INSERT",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"sysId": "996af62adb1910102f67dfea5e961980",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 1
}
],
"className": "cmdb_serial_number"
}
],
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source NO_MATCH",
"identifierName": "",
"attemptResult": "NO_MATCH",
"attributes": [],
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"serial_number",
"serial_number_type"
],
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"serial_number"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"name"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"mac_address",
"name"
],
"searchOnTable": "cmdb_ci_network_adapter",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
0
]
},
{
"className": "cmdb_ci_spkg",
"operation": "INSERT",
"sysId": "116af62adb1910102f67dfea5e961981",
"relatedSysIds": [
"6d6af62adb1910102f67dfea5e961984"
],
"relatedItems": [
{
"errors": [],
"operation": "INSERT",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"sysId": "6d6af62adb1910102f67dfea5e961984",
"markers": [],
"inputIndices": [
{
"mainIndex": 1,
"subIndex": 0
}
],
"className": "cmdb_software_instance"
}
],
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
},
{
"identifierName": "Software",
"attemptResult": "NO_MATCH",
"attributes": [
"key"
],
"searchOnTable": "cmdb_ci_spkg",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
1
]
},
{
"className": "cmdb_ci_app_server_tomcat",
"operation": "INSERT",
"sysId": "e96af62adb1910102f67dfea5e961985",
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
2
]
}
],
"additionalCommittedItems": [],
"relations": [
{
"className": "cmdb_rel_ci",
"operation": "INSERT",
"sysId": "e96af62adb1910102f67dfea5e961989",
"identifierEntrySysId": "Unknown",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
0
]
}
],
"additionalCommittedRelations": []
}
Example
Identify a dependent CI.
var payload =
{items: [
{className:'cmdb_ci_web_server',
values: {name:'apache linux den 200',
running_process_command: 'xyz',
running_process_key_parameters: 'abc',
tcp_port:'3452'}},
{className:'cmdb_ci_linux_server',
values: {name:'lnux100', ram:'2048'}}],
relations:[{parent: 0, child: 1, type: 'Runs on::Runs'}]
};
var jsonUntil = new JSON();
var input = jsonUntil.encode(payload);
var output = SNC.IdentificationEngineScriptableApi.createOrUpdateCI('ServiceWatch', input);
gs.print(output);
Output:
{
"items": [
{
"className": "cmdb_ci_web_server",
"operation": "INSERT",
"sysId": "b9bb766adb1910102f67dfea5e961962",
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
},
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
0
]
},
{
"className": "cmdb_ci_linux_server",
"operation": "INSERT",
"sysId": "a5bb766adb1910102f67dfea5e96195b",
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"serial_number",
"serial_number_type"
],
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"serial_number"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"name"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"mac_address",
"name"
],
"searchOnTable": "cmdb_ci_network_adapter",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
1
]
}
],
"additionalCommittedItems": [],
"relations": [
{
"className": "cmdb_rel_ci",
"operation": "INSERT",
"sysId": "fdbb766adb1910102f67dfea5e961964",
"identifierEntrySysId": "Unknown",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
0
]
}
],
"additionalCommittedRelations": []
}
Example
Identify an independent CI with lookup-based identification.
var payload = {items: [
{className:'cmdb_ci_netgear',
values: {name:'ny8500-nbxs08',
ports:'1200'},
lookup: [{className:'cmdb_serial_number',
values:{serial_number:'1234ABCD', serial_number_type:'uuid',absent:'false',valid:'true'}},
{className:'cmdb_serial_number',
values:{serial_number:'3456EFGH', serial_number_type:'system',absent:'false',valid:'true'}}]}]};
var jsonUntil = new JSON();
var input = jsonUntil.encode(payload);
var output = SNC.IdentificationEngineScriptableApi.createOrUpdateCI('ServiceNow', input);
gs.print(output);
Output:
{
"items": [
{
"className": "cmdb_ci_netgear",
"operation": "INSERT",
"sysId": "787c7e6adb1910102f67dfea5e96196e",
"relatedSysIds": [
"f47c7e6adb1910102f67dfea5e961977",
"3c7c7e6adb1910102f67dfea5e961977"
],
"relatedItems": [
{
"errors": [],
"operation": "INSERT",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"sysId": "f47c7e6adb1910102f67dfea5e961977",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 0
}
],
"className": "cmdb_serial_number"
},
{
"errors": [],
"operation": "INSERT",
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"sysId": "3c7c7e6adb1910102f67dfea5e961977",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 1
}
],
"className": "cmdb_serial_number"
}
],
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [],
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"serial_number",
"serial_number_type"
],
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"serial_number"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"name"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"mac_address",
"name"
],
"searchOnTable": "cmdb_ci_network_adapter",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"mergedPayloadIds": [],
"warningCount": 0,
"markers": [],
"inputIndices": [
0
]
}
],
"additionalCommittedItems": [],
"relations": [],
"additionalCommittedRelations": []
}
Scoped equivalent
To use the createOrUpdateCI(String source, String input) method in a scoped application, use the corresponding scoped IdentificationEngine method: createOrUpdateCI( String source, String input).
IdentificationEngineScriptableApi - createOrUpdateCIEnhanced(String source, String input, Object options)
Inserts or updates configuration items (CI) and non-Configuration Management Database (CMDB) CIs (classes not extending from cmdb_ci) in the CMDB based on identification and reconciliation rules. Use this API instead of updating the CMDB directly.
You must pass non-CMDB CIs as lookup or related items in the IRE payload. For additional information on non-CMDB table ingestion, see IRE support for non-CMDB tables.
- Handling partial payloads
- Handling partial commits
- Removing duplicate items within a payload
- Generating output summaries
For additional information on non-CMDB table ingestion, see IRE support for non-CMDB tables.
Name | Type | Description |
---|---|---|
input | String | Required. Input payload. A JSON formatted string of
configuration items to add or update.
|
input.items | Array of Objects | Items to add or update.
|
input.items.className | String | Required. Class/table name, sys_class_name, of the
configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_ci_linux_server or cmdb_ci_win_server. |
input.items.display_values | Object | Reference fields to create or update for this related item as name-value pairs,
where the name is the field name and the value is the referenced display value. If you
want to use the sys_id instead of the display value for reference fields, pass the
information in the input.items.lookup.values parameter instead of
in this parameter. Reference field names depend on the fields selected by the user, such as:
|
input.items.internal_id | String | Unique item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup | Array of Objects | Identifies the top-level item containing the lookup (lookup-based identification). These records are used to identify the configuration item based on a lookup table that has a reference back to cmdb_ci. For example:
|
input.items.lookup.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_serial_number or cmdb_ci_network_adapter. |
input.items.lookup.internal_id | String | Unique lookup item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup.sys_object_source_info | Object | Defines a unique CI identifier for a specific data source. Different sources may
have different name-value pairs for the same
CI.
|
input.items.lookup.sys_object_source_info.source_feed | String | If the source can have multiple feeds, use this field to provide the name of the
feed sending this item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.lookup.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.lookup.sys_object_source_info.source_native_key | String | Unique key-id for the item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.lookup.sys_object_source_info.source_recency_timestamp | String | UTC date/time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.lookup.values | Object | Field information for the CI as name-value pairs, where the name is the field name. When updating reference fields, the value must be the referenced sys_id. Field names and types depend on the fields selected by the user, such as:
|
input.items.related | Array of Objects | Reference to the top-level item that contains the related list. Rules in the Related Entry [cmdb_related_entry] define what type of records can be in this array. These records are used to add items based on
a related table that has a reference to the CI that is being identified. The related table may or may not extend cmdb_ci. These records are not used to identify the configuration item.
|
input.items.related.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_software_instance or cmdb_key_value. |
input.items.related.internal_id | String | Unique identifier for this related item in this payload. Can be any value, but must be unique within the payload. |
input.items.related.sys_object_source_info | Object | Object that makes up a unique CI identifier for a specified data source.
Different sources may have different name-value pairs for the same
CI.
|
input.items.related.sys_object_source_info.source_feed | String | If the source can have multiple feeds, use this field to provide the name of the
feed sending this item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.related.sys_object_source_info.source_name | String | Identifies the data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.related.sys_object_source_info.source_native_key | String | Unique key/ID from the source for the related item. The data source generates this key. It can be any string that is unique to the item. |
input.items.related.sys_object_source_info.source_recency_timestamp | String | UTC date and time that the item was scanned. Format: |
input.items.related.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.items.settings | Object | Parameters that define the types of updates that are
permitted.
|
input.items.settings.skipReclassificationRestrictionRules | Boolean | Flag that indicates whether IRE should not run the Reclassification Restriction rule that matches the class for the payload item. Valid values:
Default: false |
input.items.settings.updateWithoutDowngrade | Boolean | Flag that indicates whether update and downgrade are both permitted for this item. Valid values:
Default: false |
input.items.settings.updateWithoutSwitch | Boolean | Flag that indicates whether the item can be updated and the class switched. Valid values:
Default: false |
input.items.settings.updateWithoutUpgrade | Boolean | Flag that indicates whether update and upgrade are both permitted for this item. Valid values:
Default: false |
input.items.sys_object_source_info | Object | Unique CI identifier for a specific
source.
|
input.items.sys_object_source_info.source_feed | String | If the source can have
multiple feeds, use this field to provide the name of the feed sending this
item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.sys_object_source_info.source_native_key | String | Unique key/id for the
item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.sys_object_source_info.source_recency_timestamp | String | UTC date and
time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.referenceItems | Array of Objects | List that define references between items in the input payload.
|
input.referenceItems.referenced | String | The internal_id defined for the item being referenced by another item. |
input.referenceItems.referencedBy | String | The internal_id defined for the item that references another item. |
input.referenceItems.referenceField | String | Name of the reference field in the class/table for the referencedBy item. |
input.relations | Array of Objects | List that specifies relationships between items in the input payload. An object in this array can use either of two formats.
|
input.relations.child | Number | Integer index of the CI object in the items array that represents the child in the relationship (items, items.related, or items.lookup.) |
input.relations.child_id | String | The internal_id of the child item in the relation (items, items.related, or items.lookup.) |
input.relations.parent | Number | Integer index of the parent item in the items array (items, items.related, or items.lookup.) |
input.relations.parent_id | String | The internal_id of the parent item in the relation (items, items.related, or items.lookup.) |
input.relations.sys_rel_source_info | Object | Discovery source information for the relationship. For non-dependency relationships, this information is saved in the Relationship Sources [sys_rel_source] table (not persisted for
identifyCIEnhanced() or identifyCI() methods.) Data type: Object
|
input.relations.sys_rel_source_info.source_name | String | Discovery source name. Default: Discovery source passed in the API method parameter. |
input.relations.sys_rel_source_info.source_feed | String | Any string that is a
sub-discovery/scan within the discovery source. Default: 'UNKNOWN' is stored in the source_feed column when creating a record in sys_rel_source table. |
input.relations.type | String | Type of relationship that exists between the parent and child items. This must be a name field value from the CI Relationship Type [cmdb_rel_type] table. |
options | Object | Optional, but {} or null must be passed-in. Options to enable or disable features. Note: By default or if partial_payloads is set to true, both partial_commits and
deduplicate_payloads are enabled, even if they are set to false, as those features are essential for partial payloads functionality.
|
options.deduplicate_payloads | Boolean | Flag that indicates whether duplicate items are merged or considered errors. Valid values:
Default: true |
options.generate_summary | Boolean | Flag that indicates whether the returned results contain summary information. For the details of the returned summary information, see <String>.summary in the
return results table. Valid values:
Default: false |
options.partial_commits | Boolean | Flag that indicates whether partial commit support is enabled. For additional information on partial commits, see Enhanced IRE features. Valid values:
Default: true |
options.partial_payloads | Boolean | Flag that indicates whether partial payload support is enabled. For additional information on partial payloads, see Enhanced IRE features and Create an IRE data source rule. Valid values:
Default: true |
options.skip_updating_last_scan_to_now | Boolean | Flag that indicates whether to skip updating the sys_object_source's last_scan time field. Valid values:
Default: Uses the value in the glide.identification_engine.skip_updating_last_scan_to_now system property. |
options.skip_updating_source_last_discovered_to_now | Boolean | Flag that indicates whether to skip updating the discovery_source and last_discovered fields in the Configuration Item [cmdb_ci] table. Valid values:
Default: Uses the value in the glide.identification_engine.skip_updating_source_last_discovered_to_now system property. |
source | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
Parameter | Description |
---|---|
<String> | JSON formatted string that is a list of results for the configuration items in the input string. Data type: String
|
<String>.additionalCommittedItems | List of CIs that were committed during the IRE processing of the current payload, but were not present in the current input payload. Data type: Array of Objects
|
<String>.additionalCommittedItems.className | Sys_class_name of this additional CI. Data type: String |
<String>.additionalCommittedItems.errorCount | Number of errors encountered while processing this additional CI. Data type: Number |
<String>.additionalCommittedItems.errors | Array of objects that describes errors encountered while processing this additional CI. Data type: Array
|
<String>.additionalCommittedItems.errors.error | Type of error encountered while processing the additional
CI. Data type: String |
<String>.additionalCommittedItems.errors.message | Error message encountered while processing the
additional CI. Data type: String |
<String>.additionalCommittedItems.identificationAttempts | Array of objects in which each object describes an attempt made to identify this additional CI. Data type: Array of
Objects
|
<String>.additionalCommittedItems.identificationAttempts.attemptResult | Outcome of this additional CI identification attempt. Data type: String Possible values:
|
<String>.additionalCommittedItems.identificationAttempts.attributes | CI identifier entry attributes used during this additional CI identification attempt. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>.additionalCommittedItems.identificationAttempts.hybridEntryCiAttributes | Array of CI identifier entry attributes used during this additional CI identification attempt. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>.additionalCommittedItems.identificationAttempts.identifierName | Identifier rule used for this
additional CI identification attempt. Data type: String |
<String>.additionalCommittedItems.identificationAttempts.searchOnTable | Name of the table searched for
this additional CI identification attempt. Data type: String |
<String>.additionalCommittedItems.identifierEntrySysId | Sys_id for the identifier rule
used to identify this additional CI. Notable values - Unknown: Identification of this additional CI failed. See errors for details. |
<String>.additionalCommittedItems.inputIndices | Index values for CIs from the request body items array that correspond to this additional CI. Data type: Array of Numbers
|
<String>.additionalCommittedItems.markers | Marker values for internal use. Data type: Array
|
<String>.additionalCommittedItems.mergedPayloads | Sys_id values for partial payloads from the CMDB IRE Partial Payloads [cmdb_ire_partial_payloads] table that were merged during processing of this additional CI. Data type: Array
|
<String>.additionalCommittedItems.operation | Operation performed for this additional CI. Data type: String Possible values:
|
<String>.additionalCommittedItems.sysId | Sys_id found for this additional CI through identification. Data type: String Notable values - Unknown: Identification of this additional CI failed. See errors for details. |
<String>.additionalCommittedItems.warnings | Description of warnings encountered while processing this additional CI. Data type: Array of Objects
|
<String>.additionalCommittedItems.warnings.error | Type of warning encountered while
processing this additional CI. Data type: String |
<String>.additionalCommittedItems.warnings.message | Warning message encountered while
processing this additional CI. Data type: String |
<String>.additionalCommittedRelations | Description of a dependent relationship CI that was not included in the request body relations list to insert or update. Data type: Array of Objects
|
<String>.additionalCommittedRelations.className | The sys_class_name of this additional dependent relationship CI. Data type: String Only supported value: cmdb_rel_ci: The CI Relationship table. |
<String>.additionalCommittedRelations.errorCount | Number of errors encountered while
processing this additional dependent relationship CI. Data type: Number |
<String>.additionalCommittedRelations.errors | Description of the errors encountered while processing this additional dependent relationship CI. Data type: Array of Objects
|
<String>.additionalCommittedRelations.errors.error | Type of error encountered while processing
the additional dependent relationship CI. Data type: String |
<String>.additionalCommittedRelations.errors.message | Error message encountered while processing this additional dependent relationship CI. Data type: String |
<String>.additionalCommittedRelations.inputIndices | Index values for dependent relationship CI objects in the request body relations array that correspond to this additional dependent relationship CI. Data type: Array
|
<String>.additionalCommittedRelations.markers | Marker values for internal use. Data type: Array
|
<String>.additionalCommittedRelations.mergedPayloadIds | Sys_id values for partial payloads from the CMDB IRE Partial Payloads [cmdb_ire_partial_payloads] table that were merged for this CI.that were merged during processing of this additional
dependent relationship CI. Data type: Array
|
<String>.additionalCommittedRelations.operation | Operation that was performed for the additional dependent relationship CI. Possible values:
Data type: String |
<String>.hasError | Flag that indicates whether any
item or relation has errors. Data type: Boolean |
<String>.hasWarning | Flag that indicates whether any
item or relation has warnings. Data type: Boolean |
<String>.items | Description of the created or updated CIs. Data type: Array of Objects
|
<String>.items.additionalRelatedItems | Information about additional lookup and related items that were processed but not provided as part of the input payload. These items are from partial payloads. Data type: Array of Objects
|
<String>.items.additionalRelatedItems.className | Class/table name (sys_class_name) of
the CI that was created or updated. Data type: String |
<String>.items.additionalRelatedItems.inputIndices | Index values for CIs from the
request body items array that correspond to this related
item. Data type: Array of Numbers |
<String>.items.additionalRelatedItems.mergedPayloadIds | List of sys_ids of the partial payloads that were merged into the related item. Data type: Array Table: CMDB IRE Partial Payloads [cmdb_ire_partial_payloads] |
<String>.items.additionalRelatedItems.operation | Type of operation. Possible values:
Data type: String |
<String>.items.additionalRelatedItems.sysId | Sys_id of the CI that was updated or
created. Data type: String |
<String>.items.className | Class/table name (sys_class_name) of the CI that
was created or updated. Data type: String |
<String>.items.duplicateIndices | List of indexes of CIs that are
duplicates of the current item. Data type: Array |
<String>.items.errorCount | Number of errors encountered while processing
the item. Data type: Number |
<String>.items.errors | List of errors encountered while processing this CI. Data type: Array of Objects
|
<String>.items.errors.error | Type of error encountered while processing the
CI. Data type: String |
<String>.items.errors.message | Error message associated with the error. Data type: String |
<String>.items.identificationAttempts | List of attempts that were made to identify the CIs. Data type: Array of Objects
|
<String>.items.identificationAttempts.attemptResult | Results of the attempt to identify the CI. Possible values:
Data type: String |
<String>.items.identificationAttempts.attributes | List of CI identifier entry attributes that were used during the identification process. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>items.identificationAttempts.hybridEntryCiAttributes | List of CI identifier entry attributes that were used during the identification process. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>.items.identificationAttempts.identifierName | Identifier rule used
for this CI identification attempt. Data type: String |
<String>.items.identificationAttempts.searchOnTable | Name of the table
searched during the identification process. Data type: String |
<String>.items.identifierEntrySysId | Sys_id for the identifier rule used to identify the CI. Data type: String Table: Identifier Entry [cmdb_identifier_entry] |
<String>.items.incompleteSysIds | If the item had errors and was saved as an
incomplete payload, this parameter contains the sys_id of the record in the CMDB IRE
Incomplete Payloads [cmdb_ire_incomplete_payloads] table. Data type: String |
<String>.items.info | Additional information about the processing of the item. Data type: Array of Objects
|
<String>.items.info.code | Reclassification type that was skipped. Possible values:
Data type: String |
<String>.items.info.message | Message that provides additional insights into
the reason for skipping the reclassification. Data type: String |
<String>.items.info.ruleSysId | Sys_id of the reclassification restriction
rule that was matched. Applicable only when IRE skips reclassification due to
reclassification restriction rule. This value is empty if the reclassification is
skipped due to a payload or global flag. Data type: String |
<String>.items.inputIndices | Indexes of the corresponding input CI. For
top-level items, it is a list of integers. For related or lookup CIs, it is list of
JSON objects. Data type: Array of Numbers |
<String>.items.maskedAttributes | List of attributes whose update by a
non-authoritative data source was skipped as defined by the
Reconciliation
Rules. Data type: Array |
<String>.items.operation | Operation that took place. Possible values:
Data type: String |
<String>.items.partialSysIds | If the item had errors and was saved as a
partial payload, this parameter contains the sys_id of the partial payload record.
Data type: String |
<String>.items.relatedItems | List of JSON objects that describe a related CI (table lookup CI) from the request body items.lookup array. Data type: Array of Objects
|
<String>.items.relatedItems.className | Class/table name (sys_class_name) of the related item. Data type: String |
<String>.items.relatedItems.errors | List of errors that occurred during processing of the related item. Data type: Array of Objects
|
<String>.items.relatedItems.errors.error | Type of error encountered while processing the related item. Data type: String |
<String>.items.relatedItems.errors.message | Error message associated with the error. Data type: String |
<String>.items.relatedItems.errorCount | Number of errors detected while
processing the related items. Data type: Number |
<String>.items.relatedItems.incompleteSysIds | If the relation had errors and was saved as an incomplete payload, this value is
the sys_id of the record in the CMDB IRE Incomplete Payloads
[cmdb_ire_incomplete_payloads] table. Data type: String |
<String>.items.relatedItems.inputIndices | Index of the corresponding input item. For top-level items, it is a list of integers. For related or lookup items, it is list of JSON objects. Data type: Array of Numbers or Array of Objects
|
<String>.items.relatedItems.inputIndices.mainIndex | Index value from the
request body items array that corresponds to the CI parent of the
related item. Data type: Number |
<String>.items.relatedItems.inputIndices.subIndex | Index value from the
request body items.lookup array that corresponds to the related
item. Data type: Number |
<String>.items.relatedItems.mergedPayloadIds | List of sys_ids of the partial payloads that were merged into the CI during
processing. Data type: Array |
<String>.items.relatedItems.operation | Operation that took place. Possible values:
Data type: String |
<String>.items.relatedItems.partialSysIds | If the related item had errors and was saved as a partial payload, this contains
a list of the sys_ids of the associated records in the CMDB IRE Partial Payloads
[cmdb_ire_partial_payloads] table. Data type: Array |
<String>.items.relatedItems.sysId | Sys_id of the related item. Data type: String |
<String>.items.relatedItems.warningCount | Number of warnings encountered when processing the related items. Data type: Number |
<String>.items.relatedItems.warnings | Description of warnings encountered while processing the related items. Data type: Array of Objects
|
<String>.items.relatedItems.warnings.error | Type of warning encountered while processing the related item. Data type: String |
<String>.items.relatedItems.warnings.message | Message associated with the warning. Data type: String |
<String>.items.relatedSysIds | List of the sys_id values of the CIs used
during lookup-based identification of related items. Data type: String |
<String>.items.sys_id | Sys_id of the CI that was updated or
created. Data type: String |
<String>.relations | Description of a dependent relationship CI from the request body relations array. Data type: Array of Objects
|
<String>.relations.className | Sys_class_name of this dependent relationship CI. Only supported value: cmdb_rel_ci: CI Relationship table. Data type: String |
<String>.relations.errorCount | Number of errors encountered when
processing the dependent relationship CI. Data type: Number |
<String>.relations.errors | List that describes errors that were encountered while processing this dependent relationship CI. Data type: Array of Objects
|
<String>.relations.errors.error | Type of error encountered while processing the dependent relationship CI. Data type: String |
<String>.relations.errors.message | Error message encountered while processing this dependent relationship CI. Data type: String |
<String>.relations.incompleteSysIds | If the relation had errors and was
saved as an incomplete payload, this value is the sys_id of the record in the CMDB IRE
Incomplete Payloads [cmdb_ire_incomplete_payloads] table. Data type: String |
<String>.relations.inputIndices | Indexes for the dependent relationship
CI objects in the request body relations array that correspond to
this dependent relationship CI. Data type: Array |
<String>.relations.operation | Type of operation performed. Possible values:
Data type: String |
<String>.relations.partialSysIds | If the relation had errors and was saved
as a partial payload, this value is the sys_id of the record in the CMDB IRE Partial
Payloads [cmdb_ire_partial_payloads] table. Data type: String |
<String>.relations.sysId | Sys_id of the dependent relationship
CI. Data type: String |
<String>.summary | List of JSON properties that provide statistics on how
many items were inserted, updated, and such, per class. Data type: Array |
<String>.summary.<class_name> | Statistics for a specific class. Data type: Object
|
<String>.summary.<class_name>.additionalInsertedItemCount | Number of items
inserted due to processing of partial payloads. Data type: Number |
<String>.summary.<class_name>.errorCount | Number of errors encounter when
processing items. Data type: Number |
<String>.summary.<class_name>.incompleteItemCount | Number of items inserted
in the CMDB IRE Incomplete Payloads [cmdb_ire_incomplete_payloads] table. Data type: Number |
<String>.summary.<class_name>.insertedItemCount | Number of items
created. Data type: Number |
<String>.summary.<class_name>.partialItemCount | Number of items saved in
the Partial Payload table [cmdb_ire_partial_payloads]. Data type: Number |
<String>.summary.<class_name>.skippedItemCount | Number of items that were skipped. Data type: Number |
<String>.summary.<class_name>.unchangedItemCount | Number of items that had
entries but were not modified. Data type: Number |
<String>.summary.<class_name>.updatedItemCount | Number of items
updated. Data type: Number |
<String>.summary.<class_name>.warningCount | Number of items that generated
a warning when processed. Data type: Number |
Example
Identify a dependent CI.
var payload = {
"items": [
{
"className": "cmdb_ci_win_server",
"values": {
"chassis_type": "Desktop",
"os": "Windows 2012 R2 Datacenter",
"name": "Windows2012Server1",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"cpu_count": "1"
},
"lookup": [
{
"values": {
"valid": "true",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"serial_number_type": "bios"
},
"className": "cmdb_serial_number"
},
{
"values": {
"valid": "true",
"serial_number": "3311-9736-4988-9744-1749-4183-41",
"serial_number_type": "chassis"
},
"className": "cmdb_serial_number"
}],
"internal_id": "16777219",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "16777219",
"source_recency_timestamp": "2019-10-18 08:31:23"
}},
{
"className": "cmdb_ci_spkg",
"values": {
"name": "Windows 2012 R2 Datacenter",
"key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL"
},
"related": [
{
"internal_id": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219",
"values": {
"name": "Windows 2012 R2 Datacenter-SAMLABVM52"
},
"className": "cmdb_software_instance",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}}]
"settings" : {
"skipReclassificationRestrictionRules" : "false",
"updateWithoutDowngrade" : "true",
"updateWithoutUpgrade" : "true",
"updateWithoutSwitch" : "true"
}},
{
"className": "cmdb_ci_app_server_tomcat",
"values": {
"running_process_key_parameters": "/opt/OV/nonOV/tomcat/b/temp org.apache.catalina.startup.Bootstrap start",
"install_directory": "/opt/OV/nonOV/tomcat/b",
"name": "Tomcat@hpom9:3443",
"server_port": "8006",
"sys_class_name": "cmdb_ci_app_server_tomcat"
},
"internal_id": "tomcat_id"
}],
"relations": [
{
"parent_id": "tomcat_id",
"child_id": "16777219",
"type": "Runs on::Runs"
}],
"referenceItems": [
{
"referenceField": "installed_on",
"referenced": "16777219",
"referencedBy": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}]};
var input = new JSON().encode(payload);
var output = SNC.IdentificationEngineScriptableApi.createOrUpdateCIEnhanced('ServiceNow', input, {});
Output:
{
"items": [
{
"className": "cmdb_ci_win_server",
"operation": "NO_CHANGE",
"sysId": "65d873d2b3a0001028f6eae2c6a8dc2a",
"relatedSysIds": [
"a1d873d2b3a0001028f6eae2c6a8dc32",
"a1d873d2b3a0001028f6eae2c6a8dc33"
],
"relatedItems": [
{
"className": "cmdb_serial_number",
"sysId": "a1d873d2b3a0001028f6eae2c6a8dc32",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 0
}]
},
"className": "cmdb_serial_number",
"sysId": "a1d873d2b3a0001028f6eae2c6a8dc33",
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 1
}]
}],
"additionalRelatedItems": [],
"identificationAttempts": [],
"errorCount": 0,
"inputIndices": [0]
},
{
"className": "cmdb_ci_spkg",
"operation": "NO_CHANGE",
"sysId": "c764e971b320001028f6eae2c6a8dc44",
"relatedSysIds": [
"8b64e971b320001028f6eae2c6a8dc47"
],
"relatedItems": [
{
"className": "cmdb_software_instance",
"sysId": "8b64e971b320001028f6eae2c6a8dc47",
"markers": [],
"inputIndices": [
{
"mainIndex": 1,
"subIndex": 0
}]
}],
"additionalRelatedItems": [],
"identifierEntrySysId": "a52a87c03746220006b216a543990e8c",
"identificationAttempts": [
{
"attributes": [
"key"
],
"identifierName": "Software",
"attemptResult": "MATCHED",
"searchOnTable": "cmdb_ci_spkg",
"hybridEntryCiAttributes": []
}],
"errorCount": 0,
"inputIndices": [1]
},
{
"className": "cmdb_ci_app_server_tomcat",
"operation": "INSERT",
"sysId": "6f29f3d2b3a0001028f6eae2c6a8dcc6",
"identifierEntrySysId": "Unknown",
"identificationAttempts": [
{
"attributes": [
"install_directory",
"running_process_key_parameters",
"sys_class_name"
],
"identifierName": "Tomcat",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_ci_app_server_tomcat",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"cl_port",
"sys_class_name"
],
"identifierName": "Application Rule",
"attemptResult": "SKIPPED",
"searchOnTable": "cmdb_ci_appl",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"running_process_command",
"running_process_key_parameters",
"sys_class_name"
],
"identifierName": "Application Rule",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_ci_appl",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"inputIndices": [2]
}
],
"additionalCommittedItems": [],
"relations": [
{
"className": "cmdb_rel_ci",
"operation": "INSERT",
"sysId": "6729f3d2b3a0001028f6eae2c6a8dcc9",
"errorCount": 0,
"inputIndices": [0]
}],
"additionalCommittedRelations": []
}
IdentificationEngineScriptableApi - identifyCI(String jsonString)
Determines the operation (insert/update) to perform with the specified payload without committing the operation in the database.
This works just like createOrUpdateCI(), but does not commit the result.
Name | Type | Description |
---|---|---|
jsonString | String | A JSON formatted string of configuration items to be added or updated. Each input string is in the format 'items: [{}], relations:[{}]', where each item within the items and relations lists contains name-value pairs.
The possible name-value pairs within the items list are:
Possible name-value pairs within the relations list are:
|
Type | Description |
---|---|
String | A JSON formatted string that is a list of results. Each result string is in the format 'items: [{}], relations:[{}]', where each item within the items and relations lists contains name-value pairs. The possible
name-value pairs within the items list are:
Possible name-value pairs within the relations list are:
|
Example
Identify an independent CI with lookup-based identification.
var payload = {items: [
{className:'cmdb_ci_netgear',
values: {name:'ny8500-nbxs08',
ports:'1200'},
lookup: [{className:'cmdb_serial_number',
values:{serial_number:'1234ABCD', serial_number_type:'uuid',absent:'false',valid:'true'}},
{className:'cmdb_serial_number',
values:{serial_number:'3456EFGH', serial_number_type:'system',absent:'false',valid:'true'}}]}]};
var jsonUntil = new JSON();
var input = jsonUntil.encode(payload);
var output = SNC.IdentificationEngineScriptableApi.identifyCI(input);
gs.print(output);
Output:
{
"items": [
{
"className": "cmdb_ci_netgear",
"operation": "UPDATE",
"sysId": "55b35562c0a8010e01cff22378e0aea9",
"relatedSysIds": [
null,
null
],
"relatedItems": [
{
"errors": [
],
"operation": "INSERT",
"info": [
],
"errorCount": 0,
"mergedPayloadIds": [
],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 0
}
],
"warningCount": 0,
"markers": [
],
"className": "cmdb_serial_number"
},
{
"errors": [
],
"operation": "INSERT",
"info": [
],
"errorCount": 0,
"mergedPayloadIds": [
],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 1
}
],
"warningCount": 0,
"markers": [
],
"className": "cmdb_serial_number"
}
],
"identifierEntrySysId": "556eb250c3400200d8d4bea192d3ae92",
"identificationAttempts": [
{
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"attributes": [
"source_name",
"source_native_key"
],
"searchOnTable": "sys_object_source",
"hybridEntryCiAttributes": [
]
},
{
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"attributes": [
"serial_number",
"serial_number_type"
],
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": [
]
},
{
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"attributes": [
"serial_number"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": [
]
},
{
"identifierName": "Hardware Rule",
"attemptResult": "MATCHED",
"attributes": [
"name"
],
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": [
]
}
],
"info": [
],
"errorCount": 0,
"mergedPayloadIds": [
],
"inputIndices": [
0
],
"warningCount": 0,
"markers": [
]
}
],
"additionalCommittedItems": [
],
"relations": [
],
"additionalCommittedRelations": [
],
"hasError": false,
"hasWarning": false
}
Scoped equivalent
To use the identifyCI(String jsonString) method in a scoped application, use the corresponding scoped IdentificationEngine method: identifyCI(String jsonString).
IdentificationEngineScriptableApi - identifyCIEnhanced(String source, String input, Object options)
Determines the Configuration Management Database (CMDB) operation (insert/update) to perform with the specified payload (request body), without committing the operations in the database.
Use this method to simulate submission of a payload.
- Partial payloads
- In case of an item having a warning or error, indicates if an item operation is INSERT_AS_PARTIAL or INSERT_INCOMPLETE.
- Returns the sys_ids of partial payloads that were merged with existing partial payloads.
- Supports payload deduplicate feature.
- Generates a summary.
Name | Type | Description |
---|---|---|
input | String | Required. Input payload. A JSON formatted string of
configuration items to add or update.
|
input.items | Array of Objects | Items to add or update.
|
input.items.className | String | Required. Class/table name, sys_class_name, of the
configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_ci_linux_server or cmdb_ci_win_server. |
input.items.display_values | Object | Reference fields to create or update for this related item as name-value pairs,
where the name is the field name and the value is the referenced display value. If you
want to use the sys_id instead of the display value for reference fields, pass the
information in the input.items.lookup.values parameter instead of
in this parameter. Reference field names depend on the fields selected by the user, such as:
|
input.items.internal_id | String | Unique item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup | Array of Objects | Identifies the top-level item containing the lookup (lookup-based identification). These records are used to identify the configuration item based on a lookup table that has a reference back to cmdb_ci. For example:
|
input.items.lookup.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_serial_number or cmdb_ci_network_adapter. |
input.items.lookup.internal_id | String | Unique lookup item identifier for the associated payload. This can be any value, but must be unique within the payload. |
input.items.lookup.sys_object_source_info | Object | Defines a unique CI identifier for a specific data source. Different sources may
have different name-value pairs for the same
CI.
|
input.items.lookup.sys_object_source_info.source_feed | String | If the source can have multiple feeds, use this field to provide the name of the
feed sending this item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.lookup.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.lookup.sys_object_source_info.source_native_key | String | Unique key-id for the item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.lookup.sys_object_source_info.source_recency_timestamp | String | UTC date/time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.lookup.values | Object | Field information for the CI as name-value pairs, where the name is the field name. When updating reference fields, the value must be the referenced sys_id. Field names and types depend on the fields selected by the user, such as:
|
input.items.related | Array of Objects | Reference to the top-level item that contains the related list. Rules in the Related Entry [cmdb_related_entry] define what type of records can be in this array. These records are used to add items based on
a related table that has a reference to the CI that is being identified. The related table may or may not extend cmdb_ci. These records are not used to identify the configuration item.
|
input.items.related.className | String | Required. Class/table name,
sys_class_name, of the configuration item (CI) to create or update. This value can be any CMDB class/table, such as cmdb_software_instance or cmdb_key_value. |
input.items.related.internal_id | String | Unique identifier for this related item in this payload. Can be any value, but must be unique within the payload. |
input.items.related.sys_object_source_info | Object | Object that makes up a unique CI identifier for a specified data source.
Different sources may have different name-value pairs for the same
CI.
|
input.items.related.sys_object_source_info.source_feed | String | If the source can have multiple feeds, use this field to provide the name of the
feed sending this item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.related.sys_object_source_info.source_name | String | Identifies the data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.related.sys_object_source_info.source_native_key | String | Unique key/ID from the source for the related item. The data source generates this key. It can be any string that is unique to the item. |
input.items.related.sys_object_source_info.source_recency_timestamp | String | UTC date and time that the item was scanned. Format: |
input.items.related.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.items.settings | Object | Parameters that define the types of updates that are
permitted.
|
input.items.settings.skipReclassificationRestrictionRules | Boolean | Flag that indicates whether IRE should not run the Reclassification Restriction rule that matches the class for the payload item. Valid values:
Default: false |
input.items.settings.updateWithoutDowngrade | Boolean | Flag that indicates whether update and downgrade are both permitted for this item. Valid values:
Default: false |
input.items.settings.updateWithoutSwitch | Boolean | Flag that indicates whether the item can be updated and the class switched. Valid values:
Default: false |
input.items.settings.updateWithoutUpgrade | Boolean | Flag that indicates whether update and upgrade are both permitted for this item. Valid values:
Default: false |
input.items.sys_object_source_info | Object | Unique CI identifier for a specific
source.
|
input.items.sys_object_source_info.source_feed | String | If the source can have
multiple feeds, use this field to provide the name of the feed sending this
item. The data source generates this feed name. It can be any string that uniquely identifies the source feed. |
input.items.sys_object_source_info.source_name | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
input.items.sys_object_source_info.source_native_key | String | Unique key/id for the
item from the source. The data source generates this key. It can be any string that is unique to the item. |
input.items.sys_object_source_info.source_recency_timestamp | String | UTC date and
time that the item was scanned. Format: YYYY-MM-DD hh:mm:ss |
input.items.values | Object | Fields to create or update for this related item as name/value pairs, where the name is the field name. For a reference field, the value must be the referenced sys_id. If you want to use the display value
instead of the sys_id for reference fields, pass this information in a display_values object instead of in the values object. Field names and types depend on the fields selected by the user, such as:
|
input.referenceItems | Array of Objects | List that define references between items in the input payload.
|
input.referenceItems.referenced | String | The internal_id defined for the item being referenced by another item. |
input.referenceItems.referencedBy | String | The internal_id defined for the item that references another item. |
input.referenceItems.referenceField | String | Name of the reference field in the class/table for the referencedBy item. |
input.relations | Array of Objects | List that specifies relationships between items in the input payload. An object in this array can use either of two formats.
|
input.relations.child | Number | Integer index of the CI object in the items array that represents the child in the relationship (items, items.related, or items.lookup.) |
input.relations.child_id | String | The internal_id of the child item in the relation (items, items.related, or items.lookup.) |
input.relations.parent | Number | Integer index of the parent item in the items array (items, items.related, or items.lookup.) |
input.relations.parent_id | String | The internal_id of the parent item in the relation (items, items.related, or items.lookup.) |
input.relations.sys_rel_source_info | Object | Discovery source information for the relationship. For non-dependency relationships, this information is saved in the Relationship Sources [sys_rel_source] table (not persisted for
identifyCIEnhanced() or identifyCI() methods.) Data type: Object
|
input.relations.sys_rel_source_info.source_name | String | Discovery source name. Default: Discovery source passed in the API method parameter. |
input.relations.sys_rel_source_info.source_feed | String | Any string that is a
sub-discovery/scan within the discovery source. Default: 'UNKNOWN' is stored in the source_feed column when creating a record in sys_rel_source table. |
input.relations.type | String | Type of relationship that exists between the parent and child items. This must be a name field value from the CI Relationship Type [cmdb_rel_type] table. |
options | Object | Optional, but {} or null must be passed-in. Options to enable or disable features. Note: By default or if partial_payloads is set to true, both partial_commits and
deduplicate_payloads are enabled, even if they are set to false, as those features are essential for partial payloads functionality.
|
options.deduplicate_payloads | Boolean | Flag that indicates whether duplicate items are merged or considered errors. Valid values:
Default: true |
options.generate_summary | Boolean | Flag that indicates whether the returned results contain summary information. For the details of the returned summary information, see <String>.summary in the
return results table. Valid values:
Default: false |
options.partial_commits | Boolean | Flag that indicates whether partial commit support is enabled. For additional information on partial commits, see Enhanced IRE features. Valid values:
Default: true |
options.partial_payloads | Boolean | Flag that indicates whether partial payload support is enabled. For additional information on partial payloads, see Enhanced IRE features and Create an IRE data source rule. Valid values:
Default: true |
options.skip_updating_last_scan_to_now | Boolean | Flag that indicates whether to skip updating the sys_object_source's last_scan time field. Valid values:
Default: Uses the value in the glide.identification_engine.skip_updating_last_scan_to_now system property. |
options.skip_updating_source_last_discovered_to_now | Boolean | Flag that indicates whether to skip updating the discovery_source and last_discovered fields in the Configuration Item [cmdb_ci] table. Valid values:
Default: Uses the value in the glide.identification_engine.skip_updating_source_last_discovered_to_now system property. |
source | String | Data source of the CI information. This value must be one of the choice values defined for the discovery_source field of the Configuration Item [cmdb_ci] table. |
Type | Description |
---|---|
<String> | JSON formatted string that is a list of results for the configuration items in the input string. Data type: String
|
<String>.additionalCommittedItems | List of CIs that were committed during the IRE processing of the current payload, but were not present in the current input payload. Data type: Array of Objects
|
<String>.additionalCommittedRelations | Description of a dependent relationship CI that was not included in the request body relations list to insert or update. Data type: Array of Objects
|
<String>.hasError | Flag that indicates whether any
item or relation has errors. Data type: Boolean |
<String>.hasWarning | Flag that indicates whether any
item or relation has warnings. Data type: Boolean |
<String>.items | Description of the created or updated CIs. Data type: Array of Objects
|
<String>.items.additionalRelatedItems | Information about additional lookup and related items that were processed but not provided as part of the input payload. These items are from partial payloads. Data type: Array of Objects
|
<String>.items.additionalRelatedItems.className | Class/table name (sys_class_name) of
the CI that was created or updated. Data type: String |
<String>.items.additionalRelatedItems.inputIndices | Index values for CIs from the
request body items array that correspond to this related
item. Data type: Array of Numbers |
<String>.items.additionalRelatedItems.mergedPayloadIds | List of sys_ids of the partial payloads that were merged into the related item. Data type: Array Table: CMDB IRE Partial Payloads [cmdb_ire_partial_payloads] |
<String>.items.additionalRelatedItems.operation | Type of operation. Possible values:
Data type: String |
<String>.items.additionalRelatedItems.sysId | Sys_id of the CI that was updated or
created. Data type: String |
<String>.items.className | Class/table name (sys_class_name) of the CI that
was created or updated. Data type: String |
<String>.items.duplicateIndices | List of indexes of CIs that are
duplicates of the current item. Data type: Array |
<String>.items.errorCount | Number of errors encountered while processing
the item. Data type: Number |
<String>.items.errors | List of errors encountered while processing this CI. Data type: Array of Objects
|
<String>.items.errors.error | Type of error encountered while processing the CI. Data type: String |
<String>.items.errors.message | Error message encountered while processing the CI. Data type: String |
<String>.items.identificationAttempts | List of attempts that were made to identify the CIs. Data type: Array of Objects
|
<String>.items.identificationAttempts.attemptResult | Results of the attempt to identify the CI. Possible values:
Data type: String |
<String>.items.identificationAttempts.attributes | List of CI identifier entry attributes that were used during the identification process. Data type: Array Attribute names and types depend on the request body data and the identifier in use, such as:
|
<String>.items.identificationAttempts.identifierName | Identifier rule used
for this CI identification attempt. Data type: String |
<String>.items.identificationAttempts.searchOnTable | Name of the table
searched during the identification process. Data type: String |
<String>.items.identifierEntrySysId | Sys_id for the identifier rule used to identify the CI. Data type: String Table: Identifier Entry [cmdb_identifier_entry] |
<String>.items.info | Additional information about the processing of the item. Data type: Array of Objects
|
<String>.items.info.code | Reclassification type that was skipped. Possible values:
Data type: String |
<String>.items.info.message | Message that provides additional insights into the reason for skipping the
reclassification. Data type: String |
<String>.items.info.ruleSysId | Sys_id of the reclassification restriction rule that was matched. Applicable only
when IRE skips reclassification due to reclassification restriction rule. This value
is empty if the reclassification is skipped due to a payload or global flag. Data type: String |
<String>.items.inputIndices | Indexes of the corresponding input CI. For
top-level items, it is a list of integers. For related or lookup CIs, it is list of
JSON objects. Data type: Array of Numbers |
<String>.items.maskedAttributes | List of attributes whose update by a
non-authoritative data source was skipped as defined by the
Reconciliation
Rules. Data type: Array |
<String>.items.operation | Operation that took place. Possible values:
Data type: String |
<String>.items.relatedItems | Information about the processed related items. Data type: Array of Objects
|
<String>.items.relatedItems.className | Class/table name (sys_class_name) of the related item. Data type: String |
<String>.items.relatedItems.errorCount | Number of errors detected while
processing the related items. Data type: Number |
<String>.items.relatedItems.errors | List of errors that occurred during processing of the related item. Data type: Array of Objects
|
<String>.items.relatedItems.errors.error | Type of error encountered while processing the related item. Data type: String |
<String>.items.relatedItems.errors.message | Error message encountered while processing the related item. Data type: String |
<String>.items.relatedItems.inputIndices | Index of the corresponding input item. For top-level items, it is a list of integers. For related or lookup items, it is list of JSON objects. Data type: Array of Numbers or Array of Objects
|
<String>.items.relatedItems.inputIndices.mainIndex | Index value from the
request body items array that corresponds to the CI parent of the
related item. Data type: Number |
<String>.items.relatedItems.inputIndices.subIndex | Index value from the
request body items.lookup array that corresponds to the related
item. Data type: Number |
<String>.items.relatedItems.mergedPayloadIds | List of sys_ids of the partial payloads that were merged into the CI during
processing. Data type: Array |
<String>.items.relatedItems.operation | Operation that took place. Possible values:
Data type: String |
<String>.items.relatedItems.sysId | Sys_id of the related item. Data type: String |
<String>.items.relatedItems.warningCount | Number of warnings encountered when processing the related items. Data type: Number |
<String>.items.relatedItems.warnings | Description of warnings encountered while processing the related items. Data type: Array of Objects
|
<String>.items.relatedSysIds | List of the sys_id values of the CIs used
during lookup-based identification of related items. Data type: String |
<String>.items.sys_id | Sys_id of the CI that was updated or
created. Data type: String |
<String>.relations | Information about the processed relations. Data type: Array of Objects
|
<String>.relations.className | Sys_class_name of this dependent relationship CI. Only supported value: cmdb_rel_ci: CI Relationship table. Data type: String |
<String>.relations.errorCount | Number of errors encountered when
processing the dependent relationship CI. Data type: Number |
<String>.relations.errors | List that describes errors that were encountered while processing this dependent relationship CI. Data type: Array of Objects
|
<String>.relations.inputIndices | Indexes for the dependent relationship
CI objects in the request body relations array that correspond to
this dependent relationship CI. Data type: Array |
<String>.relations.operation | Type of operation performed. Possible values:
Data type: String |
<String>.relations.sysId | Sys_id of the dependent relationship
CI. Data type: String |
<String>.summary | List of JSON properties that provide statistics on how
many items were inserted, updated, and such, per class. Data type: Array |
<String>.summary.<class_name> | Statistics for a specific class. Data type: Object
|
<String>.summary.<class_name>.additionalInsertedItemCount | Number of items
inserted due to processing of partial payloads. Data type: Number |
<String>.summary.<class_name>.errorCount | Number of errors encounter when
processing items. Data type: Number |
<String>.summary.<class_name>.incompleteItemCount | Number of items inserted
in the CMDB IRE Incomplete Payloads [cmdb_ire_incomplete_payloads] table. Data type: Number |
<String>.summary.<class_name>.insertedItemCount | Number of items
created. Data type: Number |
<String>.summary.<class_name>.partialItemCount | Number of items saved in
the Partial Payload table [cmdb_ire_partial_payloads]. Data type: Number |
<String>.summary.<class_name>.skippedItemCount | Number of items that were skipped. Data type: Number |
<String>.summary.<class_name>.unchangedItemCount | Number of items that had
entries but were not modified. Data type: Number |
<String>.summary.<class_name>.updatedItemCount | Number of items
updated. Data type: Number |
<String>.summary.<class_name>.warningCount | Number of items that generated
a warning when processed. Data type: Number |
Example
var payload = {
"items": [
{
"className": "cmdb_ci_win_server",
"values": {
"chassis_type": "Desktop",
"os": "Windows 2012 R2 Datacenter",
"name": "Windows2012Server1",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"cpu_count": "1"
},
"lookup": [
{
"values": {
"valid": "true",
"serial_number": "0000-0011-1690-8730-8636-5722-52",
"serial_number_type": "bios"
},
"className": "cmdb_serial_number"
},
{
"values": {
"valid": "true",
"serial_number": "3311-9736-4988-9744-1749-4183-41",
"serial_number_type": "chassis"
},
"className": "cmdb_serial_number"
}],
"internal_id": "16777219",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "16777219",
"source_recency_timestamp": "2019-10-18 08:31:23"
}},
{
"className": "cmdb_ci_spkg",
"values": {
"name": "Windows 2012 R2 Datacenter",
"key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL"
},
"related": [
{
"internal_id": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219",
"values": {
"name": "Windows 2012 R2 Datacenter-SAMLABVM52"
},
"className": "cmdb_software_instance",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}},
{
"internal_id": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777229",
"values": {
},
"className": "cmdb_software_instance",
"sys_object_source_info": {
"source_feed": "SN Discovery Feed 1",
"source_name": "ServiceNow",
"source_native_key": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777229"
}}
],
"settings" : {
"skipReclassificationRestrictionRules" : "true",
"updateWithoutDowngrade" : "true",
"updateWithoutUpgrade" : "true",
"updateWithoutSwitch" : "true"
}},
{
"className": "cmdb_ci_app_server_tomcat",
"values": {
"running_process_key_parameters": "/opt/OV/nonOV/tomcat/b/temp org.apache.catalina.startup.Bootstrap start",
"install_directory": "/opt/OV/nonOV/tomcat/b",
"name": "Tomcat@hpom9:3443",
"server_port": "8006",
"sys_class_name": "cmdb_ci_app_server_tomcat"
},
"internal_id": "tomcat_id"
}],
"relations": [
{
"parent_id": "tomcat_id",
"child_id": "16777219",
"type": "Runs on::Runs"
}],
"referenceItems": [
{
"referenceField": "installed_on",
"referenced": "16777219",
"referencedBy": "Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777219"
}]};
var input = new JSON().encode(payload);
var output = SNC.IdentificationEngineScriptableApi.identifyCIEnhanced('ServiceNow', input, {});
Output:
{
"items": [
{
"className": "cmdb_ci_win_server",
"operation": "INSERT",
"relatedSysIds": [
null,
null
],
"relatedItems": [
{
"errors": [],
"operation": "INSERT",
"className": "cmdb_serial_number",
"errorCount": 0,
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 0
}
],
"mergedPayloadIds": [],
"warningCount": 0
},
{
"errors": [],
"operation": "INSERT",
"className": "cmdb_serial_number",
"errorCount": 0,
"markers": [],
"inputIndices": [
{
"mainIndex": 0,
"subIndex": 1
}
],
"mergedPayloadIds": [],
"warningCount": 0
}
],
"identificationAttempts": [
{
"attributes": [],
"info": "sys_object_source NO_MATCH",
"identifierName": "",
"attemptResult": "NO_MATCH",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"serial_number",
"serial_number_type"
],
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_serial_number",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"serial_number"
],
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"name"
],
"identifierName": "Hardware Rule",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_ci_hardware",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"mac_address",
"name"
],
"identifierName": "Hardware Rule",
"attemptResult": "SKIPPED",
"searchOnTable": "cmdb_ci_network_adapter",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"markers": [],
"inputIndices": [
0
],
"mergedPayloadIds": [],
"warningCount": 0
},
{
"className": "cmdb_ci_spkg",
"operation": "INSERT",
"relatedSysIds": [
null
],
"relatedItems": [
{
"errors": [],
"operation": "INSERT",
"className": "cmdb_software_instance",
"errorCount": 0,
"markers": [],
"inputIndices": [
{
"mainIndex": 1,
"subIndex": 0
}
],
"mergedPayloadIds": [],
"warningCount": 0
},
{
"errors": [],
"warnings": [
{
"error": "MISSING_MATCHING_ATTRIBUTES",
"message": "In payload missing minimum set of input values for criterion (matching) attributes from identify rule for table [cmdb_software_instance]. Add these input values in payload item '{\"className\":\"cmdb_software_instance\",\"values\":{},\"internal_id\":\"f7273cccec30101056cd4bb46eb4db5d\",\"sys_object_source_info\":{\"source_feed\":\"SN Discovery Feed 1\",\"source_name\":\"ServiceNow\",\"source_native_key\":\"Microsoft Windows Server 2012 R2 Datacenter_:::_NULL|16777229\"},\"settings\":{},\"sys_ire_info\":{\"ire_received_time\":\"2020-05-10 17:57:48\"}}'"
}
],
"operation": "INSERT_AS_PARTIAL",
"className": "cmdb_software_instance",
"errorCount": 0,
"sysId": "Unknown",
"markers": [],
"inputIndices": [
{
"mainIndex": 1,
"subIndex": 1
}
],
"mergedPayloadIds": [],
"warningCount": 1
}
],
"identificationAttempts": [
{
"attributes": [],
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"hybridEntryCiAttributes": []
},
{
"attributes": [
"key"
],
"identifierName": "Software",
"attemptResult": "NO_MATCH",
"searchOnTable": "cmdb_ci_spkg",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"markers": [],
"inputIndices": [
1
],
"mergedPayloadIds": [],
"warningCount": 0
},
{
"className": "cmdb_ci_app_server_tomcat",
"operation": "INSERT",
"identificationAttempts": [
{
"attributes": [],
"info": "sys_object_source SKIPPED",
"identifierName": "",
"attemptResult": "SKIPPED",
"hybridEntryCiAttributes": []
}
],
"errorCount": 0,
"markers": [],
"inputIndices": [
2
],
"mergedPayloadIds": [],
"warningCount": 0
}
],
"additionalCommittedItems": [],
"relations": [
{
"className": "cmdb_rel_ci",
"operation": "INSERT",
"errorCount": 0,
"markers": [],
"inputIndices": [
0
],
"mergedPayloadIds": [],
"warningCount": 0
}
],
"additionalCommittedRelations": []
}
IdentificationEngineScriptableApi - runIdentificationAudit(GlideRecord now_GR)
Runs an identification audit against the specified configuration item (CI) to detect duplicates.
If duplicates are found, duplication tasks are created. Only use this method on CI types with independent identification rules.
Name | Type | Description |
---|---|---|
now_GR | GlideRecord | CI on which to run the audit to detect duplicates. The CI must have independent identification rules. |
Type | Description |
---|---|
void |
Example
The following example shows how to check the server for duplicate tasks and creates a remediate duplicate task if any exist.
var grServer = new GlideRecord('cmdb_ci_server');
grServer.query();
while (grServer.next()) {
SNC.IdentificationEngineScriptableApi.runIdentificationAudit(grServer);
}
Scoped equivalent
To use the runIdentificationAudit(GlideRecord now_GR) method in a scoped application, use the corresponding scoped IdentificationEngine method: runIdentificationAudit(GlideRecord now_GR).
On this page
- IdentificationEngineScriptableApi - createOrUpdateCI(String source, String input)
- IdentificationEngineScriptableApi - createOrUpdateCIEnhanced(String source, String input,
Object options)
- IdentificationEngineScriptableApi - identifyCI(String jsonString)
- IdentificationEngineScriptableApi - identifyCIEnhanced(String source, String input, Object
options)
- IdentificationEngineScriptableApi - runIdentificationAudit(GlideRecord now_GR)