Indicators
An Indicator represents an atomic piece of information that has some intelligence value. Indicators are guaranteed to be unique within an owner. For example, an Organization can have only one copy of the badguy@bad.com
Email Address Indicator.
Endpoint: /api/v3/indicators
Note
When retrieving, updating, and deleting Indicators, you can target a specific Indicator using its ID or summary. If targeting an Indicator by its summary, the API request will search for the Indicator in your Organization. To target an Indicator in one of your Communities or Sources by its summary, use the owner
query parameter in your API request.
Endpoint Options
Available Fields
Send the following request to retrieve a list of available fields, including each field’s name, description, and accepted data type, that can be included in the body of a POST or PUT request to the /v3/indicators
endpoint:
OPTIONS /v3/indicators
Note
Objects in the response for an OPTIONS /v3/indicators
request that have a common
field with a value of true
correspond to API fields that can be updated by API users with read-only permissions (that is, API users with an Organization role of Read Only User or Read Only Commenter, as well as API users with a Community role of User, Commenter, or Subscriber in a given Community or Source) if the v3ApiReadOnlyReports system setting is turned on for your ThreatConnect instance.
Hint
To include read-only fields in the response, append ?show=readonly
to the end of the request URL.
Alternatively, refer to the following table for a list of available fields that can be included in the body of a POST or PUT request for all Indicator types.
Field |
Description |
Type |
Required for Creation? |
Updatable? |
Example Value(s) |
---|---|---|---|---|---|
active |
Indicates whether the Indicator is active |
Boolean |
FALSE |
TRUE |
true, false |
activeLocked |
Indicates whether the active Indicator Status is locked |
Boolean |
FALSE |
TRUE |
true, false |
associatedArtifacts |
A list of Artifacts associated to the Indicator |
FALSE |
TRUE |
{“data”: [{“id”: 12345}]}
{“data”: [{ “caseId”: 1, “summary”: “badguy@bad.com”, “type”: “Email Address”}]}
|
|
associatedCases |
A list of Cases associated to the Indicator |
FALSE |
TRUE |
{“data”: [{“id”: 12345}]}
{“data”: [{“name”: “Hacker Investigation”, “status”: “Open”, “severity”: “Low” }]}
|
|
associatedGroups |
A list of Groups associated to the Indicator |
FALSE |
TRUE |
{“data”: [{“id”: 12345}]}
{“data”: [{“name”: “Bad Adversary”, “type”: “Adversary”}]}
|
|
associatedIndicators |
A list of Indicators associated to the Indicator |
Indicator Object |
FALSE |
TRUE |
{“data”: [{“id”: 12345}]}
{“data”: [{“hostName”: “badguy.com”, “type”: “Host”}]}
|
A list of Attributes added to the Indicator |
FALSE |
TRUE |
{“data”: [{“type”: “Description”, “value”: “Malicious IOC”, “default”: true}]} |
||
confidence |
The Indicator’s Confidence Rating |
Integer |
FALSE |
TRUE |
1, 2, 3,…100 |
externalDateAdded |
The date and time when the Indicator was created externally |
DateTime |
FALSE |
TRUE |
“2023-10-04T12:34:56Z” |
externalDateExpires |
The date and time when the Indicator expires externally |
DateTime |
FALSE |
TRUE |
“2023-10-04T12:34:56Z” |
externalLastModified |
The date and time when the Indicator was last modified externally |
DateTime |
FALSE |
TRUE |
“2023-10-04T12:34:56Z” |
falsePositiveFlag |
Indicates whether the Indicator is a false positive |
Boolean |
FALSE |
TRUE |
true, false |
firstSeen |
The date and time when the Indicator was first seen |
DateTime |
FALSE |
TRUE |
“2023-10-04T12:34:56Z” |
lastSeen |
The date and time when the Indicator was last seen |
DateTime |
FALSE |
TRUE |
“2023-10-04T12:34:56Z” |
observations |
The number of times the Indicator was observed |
Integer |
FALSE |
TRUE |
1, 2, 3,… |
ownerId [3] |
The ID of the owner to which the Indicator belongs |
Integer |
FALSE |
FALSE |
1, 2, 3,…100 |
ownerName [3] |
The name of the owner to which the Indicator belongs |
String |
FALSE |
FALSE |
“Demo Community” |
privateFlag |
Indicates whether the Indicator is private |
Boolean |
FALSE |
TRUE |
true, false |
rating |
The Indicator’s Threat Rating |
Big Decimal |
FALSE |
TRUE |
1.0, 2.0, 3.0, 4.0, 5.0 |
securityLabels |
A list of Security Labels applied to the Indicator |
FALSE |
TRUE |
{“data”: [{“name”: “TLP:AMBER”}]} |
|
tags |
A list of Tags applied to the Indicator |
FALSE |
TRUE |
{“data”: [{“name”: “Targeted Attack”}]} |
|
type [4] |
The type of Indicator being created |
String |
TRUE |
FALSE |
“Address”, “Host”, “Registry Key” |
Indicator-Specific Fields
Based on the type of Indicator being created, you may need to include additional fields in the body of a POST request. Similarly, some Indicator types include additional fields that may be updated via a PUT request.
The following tables list valid fields, some of which are required, that can be included in the body of a POST or PUT request for each Indicator type.
Address
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
ip |
The IP address associated with the Address Indicator |
String |
TRUE |
FALSE |
EmailAddress
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
address |
The email address associated with the Email Address Indicator |
String |
TRUE |
FALSE |
File
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
fileActions |
A list of File Actions associated with the File Indicator |
FALSE |
TRUE |
|
fileOccurrences |
A list of File Occurrences associated with the File Indicator |
FALSE |
TRUE |
|
md5 |
The MD5 hash associated with the File Indicator |
String |
TRUE [5] |
FALSE |
sha1 |
The SHA1 hash associated with the File Indicator |
String |
TRUE [5] |
FALSE |
sha256 |
The SHA256 hash associated with the File Indicator |
String |
TRUE [5] |
FALSE |
size |
The size of the file associated with the File Indicator |
String |
FALSE |
TRUE |
When creating a File Indicator, you must include at least one valid hash.
Host
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
dnsActive |
Indicates whether the DNS feature is active for the Host Indicator |
Boolean |
FALSE |
TRUE |
hostName |
The host name associated with the Host Indicator |
String |
TRUE |
FALSE |
whoisActive |
Indicates whether the Whois feature is active for the Host Indicator |
Boolean |
FALSE |
TRUE |
URL
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
text |
The URL associated with the URL Indicator |
String |
TRUE |
FALSE |
ASN
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
AS Number |
The AS number associated with the ASN Indicator |
String |
TRUE |
FALSE |
CIDR
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
Block |
The block of network IP addresses associated with the CIDR Indicator |
String |
TRUE |
FALSE |
Email Subject
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
Subject |
The subject line of the email associated with the Email Subject Indicator |
String |
TRUE |
FALSE |
Hashtag
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
Hashtag |
The hashtag term associated with the Hashtag Indicator |
String |
TRUE |
FALSE |
Mutex
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
Mutex |
The synchronization primitive used to identify malware files that is associated with the Mutex |
String |
TRUE |
FALSE |
Registry Key
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
Key Name |
The name of the registry key associated with the Registry Key Indicator |
String |
TRUE |
FALSE |
Value Name |
The registry value associated with the Registry Key Indicator |
String |
TRUE |
FALSE |
Value Type [6] |
The registry value type associated with the Registry Key Indicator |
String |
TRUE |
FALSE |
The following are accepted values for a Registry Key Indicator’s Value Type
field:
REG_NONE
REG_BINARY
REG_DWORD
REG_DWORD_LITTLE_ENDIAN
REG_DWORD_BIG_ENDIAN
REG_EXPAND_SZ
REG_LINK
REG_MULTI_SZ
REG_QWORD
REG_QWORD_LITTLE_ENDIAN
REG_SZ
User Agent
Field |
Description |
Type |
Required for Creation? |
Updatable? |
---|---|---|---|---|
User Agent String |
The characteristic identification string associated with the User Agent Indicator |
String |
TRUE |
FALSE |
Include Additional Fields in Responses
When creating, retrieving, or updating data, you can use the fields
query parameter to include additional fields in the API response that are not included by default.
Send the following request to retrieve a list of fields you can include in responses returned from the /v3/indicators
endpoint:
OPTIONS /v3/indicators/fields
Filter Results
When retrieving data, you can use the tql
query parameter to filter results with ThreatConnect Query Language (TQL).
Send the following request to retrieve a list of valid TQL parameters you can use when including the tql
query parameter in a request to the /v3/indicators
endpoint:
OPTIONS /v3/indicators/tql
Create Indicators
The follow example illustrates the basic format for creating an Indicator:
POST /v3/indicators
Content-Type: application/json
{
"type": "Indicator type goes here",
//required fields for the selected Indicator type
}
Refer to the Available Fields and Indicator-Specific Fields sections for a list of available fields that can be included in the body of a POST request to the /v3/indicators
endpoint.
Note
You can add multiple Attributes, Tags, and Security Labels to an Indicator in a single POST or PUT request.
Example POST Request
The following request will create an ultrabadguy.com Host Indicator. It will also complete the following actions for the Indicator:
Activate the DNS and Whois features for the Indicator
Set the Indicator Status for the Indicator to active
Associate the existing Group whose ID is 12 to the Indicator, and create a new Bad Guy Adversary Group in a Source and associate it to the Indicator
Add a Description (i.e., a default Description Attribute) to the Indicator
Set the Indicator’s Threat and Confidence Ratings
Apply the TLP:AMBER Security Label to the Indicator
Apply the Targeted Attack standard Tag and the T1566 - Phishing ATT&CK® Tag to the Indicator
Attention
To apply an ATT&CK Tag to an Indicator, use either the corresponding technique ID or name. For example, to apply the T1566 - Phishing ATT&CK Tag to an Indicator, either set name
to "Phishing"
or techniqueId
to "T1566"
when defining the ATT&CK Tag object in the request body.
Also, if you applied a new Tag to an Indicator and that Tag matches a synonymous Tag listed in a Tag normalization rule, it will be converted to the main Tag listed in the rule. Similarly, if you applied a new Tag to an Indicator and that Tag matches an ATT&CK Tag, it will be converted to that ATT&CK Tag.
Hint
To include the associatedGroups
, attributes
, securityLabels
, and tags
fields in the API response, append ?fields=associatedGroups&fields=attributes&fields=securityLabels&fields=tags
to the end of the request URL.
POST /v3/indicators
Content-Type: application/json
{
"type": "Host",
"hostName": "ultrabadguy.com",
"dnsActive": true,
"whoisActive": true,
"active": true,
"associatedGroups": {
"data": [
{
"id": 12
},
{
"name": "Bad Guy",
"type": "Adversary",
"ownerName": "Demo Source"
}
]
},
"attributes": {
"data": [
{
"type": "Description",
"value": "This host is very dangerous",
"default": true
}
]
},
"confidence": 85,
"rating": 5,
"securityLabels": {
"data": [
{
"name": "TLP:AMBER"
}
]
},
"tags": {
"data": [
{
"name": "Targeted Attack"
},
{
"techniqueId": "T1566"
}
]
}
}
JSON Response
{
"data": {
"id": 4,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-11-05T16:43:17Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/4/overview",
"type": "Host",
"lastModified": "2021-11-05T16:43:17Z",
"rating": 5.00,
"confidence": 85,
"description": "This host is very dangerous",
"summary": "ultrabadguy.com",
"privateFlag": false,
"active": true,
"activeLocked": false,
"hostName": "ultrabadguy.com",
"dnsActive": true,
"whoisActive": true,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=ultrabadguy.com&owner=Demo+Organization"
},
"message": "Created",
"status": "Success"
}
Retrieve Indicators
Note
By default, only active Indicators will be included in responses for GET requests to the /v3/indicators
endpoint.
Retrieve All Indicators
Send the following request to retrieve data for all Indicators:
GET /v3/indicators
JSON Response
{
"data": [
{
"id": 10,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-11-02T13:07:08Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/10/overview",
"type": "File",
"lastModified": "2021-11-02T14:04:55Z",
"summary": "F5A2496CF66CB8CFFE66CB1B27D7DEDE",
"privateFlag": false,
"active": true,
"activeLocked": false,
"md5": "F5A2496CF66CB8CFFE66CB1B27D7DEDE",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/file.xhtml?file=F5A2496CF66CB8CFFE66CB1B27D7DEDE&owner=Demo+Organization"
},
{
"id": 9,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-11-02T12:34:03Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/9/overview",
"type": "EmailAddress",
"lastModified": "2021-11-02T12:48:51Z",
"description": "A bad email address",
"summary": "[email protected]",
"privateFlag": false,
"active": true,
"activeLocked": false,
"address": "[email protected]",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/emailaddress.xhtml?emailaddress=badguy%40bad.com&owner=Demo+Organization"
},
{...}
],
"status": "Success"
}
Hint
Use the owner
query parameter to limit the results to a specific owner.
Retrieve a Specific Indicator
Send a request in the following format to retrieve data for a specific Indicator:
GET /v3/indicators/{indicatorId or indicatorSummary}
For example, the following request will return data for the Indicator whose ID is 3:
GET /v3/indicators/3
JSON Response
{
"data": {
"id": 3,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-10-26T12:40:00Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/3/overview",
"type": "Host",
"lastModified": "2021-11-02T14:58:55Z",
"rating": 3.00,
"confidence": 74,
"description": "A bad host.",
"summary": "badguy.com",
"privateFlag": false,
"active": true,
"activeLocked": false,
"hostName": "badguy.com",
"dnsActive": true,
"whoisActive": false,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=badguy.com&owner=Demo+Organization"
},
"status": "Success"
}
The same response will be returned for the following request was used, where the Indicator’s ID is replaced with its summary:
GET /v3/indicators/badguy.com
JSON Response
{
"data": {
"id": 3,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-10-26T12:40:00Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/3/overview",
"type": "Host",
"lastModified": "2021-11-02T14:58:55Z",
"rating": 3.00,
"confidence": 74,
"description": "A bad host.",
"summary": "badguy.com",
"privateFlag": false,
"active": true,
"activeLocked": false,
"hostName": "badguy.com",
"dnsActive": true,
"whoisActive": false,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=badguy.com&owner=Demo+Organization"
},
"status": "Success"
}
Retrieve Deleted Indicators
Send the following request to retrieve data for all Indicators that have been deleted from your Organization recently:
GET /v3/indicators/deleted
JSON Response
{
"data": [
{
"ownerName": "Demo Organization",
"dateAdded": "2021-11-02T15:17:28Z",
"type": "URL",
"summary": "http://badsite.com"
}
],
"count": 1,
"status": "Success"
}
To retrieve deleted Indicators from a Community or Source, use the owner
query parameter. You can also use the type
and deletedSince
query parameters to limit the results by Indicator type and deletion date, respectively.
Note
The number of days for which deleted Indicators are retained is configured by your System Administrator.
Update Indicators
The following example illustrates the basic format for updating an Indicator:
PUT /v3/indicators/{indicatorId or indicatorSummary}
Content-Type: application/json
{
{updatedField}: {updatedValue}
}
Refer to the Available Fields and Indicator-Specific Fields sections for a list of available fields that can be included in the body of a PUT request to the /v3/indicators
endpoint.
Hint
When updating an Indicator, you can use the mode
field to add or remove the following metadata:
associatedArtifacts
associatedCases
associatedGroups
associatedIndicators
attributes
fileActions
fileOccurrences
securityLabels
tags
See Update an Object’s Metadata for instructions on using the mode
field.
Example PUT Request
The following request will make the following updates to the ultrabadguy.com Host Indicator:
Disable the DNS feature for the Indicator
Dissociate the Bad Guy Adversary Group from the Indicator
Update the Indicator’s Confidence Rating
Replace any existing Security Labels applied to the Indicator with the TLP: RED Security Label
Apply a new Russia Tag to the Indicator without replacing any existing Tags applied to the Indicator.
Hint
To include the associatedGroups
, securityLabels
, and tags
fields in the API response, append ?fields=associatedGroups&fields=securityLabels&fields=tags
to the end of the request URL.
PUT /v3/indicators/ultrabadguy.com
Content-Type: application/json
{
"dnsActive": false,
"associatedGroups": {
"data": [
{
"id": 15
}
],
"mode": "delete"
},
"confidence": 92,
"securityLabels": {
"data": [
{
"name": "TLP:RED"
}
],
"mode": "replace"
},
"tags": {
"data": [
{
"name": "Russia"
}
],
"mode": "append"
}
}
JSON Response
{
"data": {
"id": 4,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-11-05T16:43:17Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/4/overview",
"type": "Host",
"lastModified": "2021-11-05T17:21:06Z",
"rating": 5.00,
"confidence": 92,
"description": "This host is very dangerous",
"summary": "ultrabadguy.com",
"privateFlag": false,
"active": true,
"activeLocked": false,
"hostName": "ultrabadguy.com",
"dnsActive": false,
"whoisActive": true,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=ultrabadguy.com&owner=Demo+Organization"
},
"message": "Updated",
"status": "Success"
}
Delete Indicators
Send a request in the following format to delete an Indicator:
DELETE /v3/indicators/{indicatorId or indicatorSummary}
For example, the following request will delete the Indicator whose ID is 3:
DELETE /v3/indicators/3
JSON Response
{
"message": "Deleted",
"status": "Success"
}
The same response will be returned for the following request, where the Indicator’s ID is replaced with its summary:
DELETE /v3/indicators/badguy.com
JSON Response
{
"message": "Deleted",
"status": "Success"
}
Associations
Create Associations
For instructions on associating Artifacts, Cases, and Groups to an Indicator, see Create and Manage Associations. For instructions on creating Indicator-to-Indicator associations, see the “Indicator-to-Indicator Associations” section.
Retrieve Custom Associations
When working with Indicators, you can retrieve data about an Indicator’s custom associations, including the name of the custom association and the Indicator involved in this association.
For example, the following request will retrieve data for the Indicator whose ID is 30, including information about its custom associations.
GET /v3/indicators/30?fields=customAssociations
JSON Response
{
"data": {
"id": 30,
"dateAdded": "2023-06-26T15:23:28Z",
"ownerId": 1,
"ownerName": "Demo Organization",
"webLink": "https://app.threatconnect.com/#/details/indicators/30/overview",
"type": "Host",
"lastModified": "2023-09-25T13:40:12Z",
"confidence": 0,
"summary": "zayla.co",
"privateFlag": false,
"active": true,
"activeLocked": false,
"customAssociations": {
"data": [
{
"id": 32,
"dateAdded": "2023-06-27T15:38:38Z",
"ownerId": 1,
"ownerName": "Demo Organization",
"webLink": "https://app.threatconnect.com/#/details/indicators/32/overview",
"type": "Address",
"lastModified": "2023-08-18T13:03:11Z",
"confidence": 0,
"summary": "107.180.48.66",
"privateFlag": false,
"active": true,
"activeLocked": false,
"customAssociationName": "DNS PTR Record",
"ip": "107.180.48.66",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/address.xhtml?address=107.180.48.66&owner=Demo+Organization"
},
{
"id": 33,
"dateAdded": "2023-06-27T19:49:13Z",
"ownerId": 1,
"ownerName": "Demo Organization",
"webLink": "https://app.threatconnect.com/#/details/indicators/33/overview",
"type": "URL",
"lastModified": "2023-09-25T13:40:12Z",
"rating": 3.00,
"confidence": 0,
"summary": "http://www.badstuff.com",
"privateFlag": false,
"active": true,
"activeLocked": false,
"customAssociationName": "Host To All",
"text": "http://www.badstuff.com",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/url.xhtml?orgid=1&owner=Demo+Organization"
}
],
"count": 2
},
"hostName": "zayla.co",
"dnsActive": false,
"whoisActive": false,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=zayla.co&owner=Demo+Organization"
},
"status": "Success"
}
Indicator-to-Indicator Associations
In ThreatConnect, you can associate two Indicators of certain types to one another using the following methods:
Create an Indicator-to-Indicator Association
Create a File Action (for File Indicators)
Each type of Indicator-to-Indicator association contains one primary (or parent) Indicator type and at least one non-primary (or child) Indicator type, as defined on the Indicators tab of the System Settings screen in ThreatConnect. When creating Indicator-to-Indicator associations using the v3 API, you can only associate Indicators of the non-primary type(s) to Indicators of the primary type. For example, in an ASN to Address association, the ASN Indicator is the primary Indicator type and the Address Indicator is the non-primary Indicator type. This means you can associate an Address Indicator to an ASN Indicator, but you cannot associate an ASN Indicator to an Address Indicator.
When creating Indicator-to-Indicator associations using the ThreatConnect v3 API, follow these guidelines:
To create an association to a new Indicator of the non-primary type, include all fields required to create the type of Indicator when setting the
associatedIndicators
field. To create the Indicator in a Community or Source, include theownerId
orownerName
field in the request and specify the ID or name, respectively, of the Community or Source in which to create the Indicator when setting theassociatedIndicators
field.To create an association to an existing Indicator of the non-primary type, use the Indicator’s ID, or use its type and summary type (e.g.,
"associatedIndicators": {"data": [{"type": "Host", "hostname": "badguy.com"}]}
), when setting theassociatedIndicators
field. To create an association to an Indicator that exists in a Community or Source using the Indicator’s summary and type, include theownerId
orownerName
field and specify the ID or name, respectively, of the Community or Source to which the Indicator belongs when setting theassociatedIndicators
field.
The following table outlines the default Indicator-to-Indicator associations in ThreatConnect and the Indicator types each association supports.
Association Name |
Primary Indicator Type |
Non-Primary Indicator Type(s) |
---|---|---|
Address to User Agent |
Address |
User Agent |
ASN to Address |
ASN |
Address |
ASN to CIDR |
ASN |
CIDR |
CIDR to Address |
CIDR |
Address |
DNS PTR Record |
Address |
Host |
Domain Registrant Email |
Host |
EmailAddress |
Domain Registrant Email |
Host |
EmailAddress |
File Download |
URL |
File |
URL Host |
URL |
Host, Address |
Note
In addition to the association types listed in this table, customer-configured custom associations are also supported. Your System Administrator can retrieve information for these association types, including the primary and non-primary Indicator types the association supports, on the Indicators tab of the System Settings screen.
In the following example, the request will associate an existing Address Indicator to an existing ASN Indicator. Because the associatedIndicators
field is not included in the API response by default, the fields
query parameter is added to the request URL and assigned a value of associatedIndicators
so that this field is included in the response.
PUT /v3/indicators/ASN204288?fields=associatedIndicators
Content-Type: application/json
{
"associatedIndicators": {
"data": [
{
"ip": "66.96.146.129",
"type": "Address"
}
]
}
}
JSON Response
{
"data": {
"id": 15,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2022-03-11T19:25:43Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/15/overview",
"type": "ASN",
"lastModified": "2022-06-13T18:25:30Z",
"summary": "ASN204288",
"privateFlag": false,
"active": true,
"activeLocked": false,
"associatedIndicators": {
"data": [
{
"id": 14,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2021-10-08T13:48:05Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/14/overview",
"type": "Address",
"lastModified": "2022-06-13T18:25:30Z",
"summary": "66.96.146.129",
"privateFlag": false,
"active": true,
"activeLocked": false,
"ip": "66.96.146.129",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/address.xhtml?address=66.96.146.129&owner=Demo+Organization"
}
]
},
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/customIndicator.xhtml?id=15&owner=Demo+Organization",
"AS Number": "ASN204288"
},
"message": "Updated",
"status": "Success"
}
If you try to associate an ASN Indicator to an Address Indicator, as in the following example, an error message will be returned stating that the association cannot be applied to the Indicator types.
PUT /v3/indicators/66.96.146.129
Content-Type: application/json
{
"associatedIndicators": {
"data": [
{
"AS Number": "ASN204288",
"type": "ASN"
}
]
}
}
JSON Response
{
"errCode": "0x1001",
"message": "Association cannot be applied to the indicator types.",
"status": "Error"
}
Note
In this example, the two Indicators would be associated and no error would be returned only if your System Administrator created a custom association where Address Indicators are the primary Indicator type and ASN Indicators are the non-primary Indicator type.
You can append, replace, and delete Indicator-to-Indicator associations via the mode
field. See Update an Object’s Metadata for more information on using this field.
File Actions
File Indicators can model a special Indicator-to-Indicator association, which is based on their behavior once opened. These associations can be used to model the fact that malware may contain and create additional files or communicate with network devices. A File Action adds an Indicator to a File Indicator’s behavior model, which can be viewed on the Behavior tab of the File Indicator’s Details screen.
When creating File Actions using the v3 API, follow these guidelines:
To create an association to a new Indicator via a File Action, include all fields required to create the type of Indicator when setting the
indicator
field. To create the Indicator in a Community or Source, include theownerId
orownerName
field in the request and specify the ID or name, respectively, of the Community or Source in which to create the Indicator when setting theindicator
field.To create an association to an existing Indicator of the non-primary type, use the Indicator’s ID, or use its type and summary type (e.g.,
"indicator": {"data": [{"type": "Host", "hostname": "badguy.com"}]}
), when setting theindicator
field. To create an association to an Indicator that exists in a Community or Source using the Indicator’s summary and type, include theownerId
orownerName
field and specify the ID or name, respectively, of the Community or Source to which the Indicator belongs when setting theindicator
field.
The following table outlines the default File Actions available in ThreatConnect, along with the Indicator type(s) that can be associated to a File Indicator via each File Action.
File Action Name |
Associable Indicator Type(s) |
---|---|
File Archive |
File |
File DNS Query |
Host |
File Drop |
File |
File Traffic |
Address, Host, URL |
File Mutex |
Mutex |
File Registry Key |
Registry Key |
File User Agent |
User Agent |
Note
In addition to the File Actions listed in this table, customer-configured custom File Actions are also supported. Your System Administrator can retrieve information for these File Actions, including the Indicator types the File Action supports, on the Indicators tab of the System Settings screen.
The following table outlines the fields you must include in your request when creating File Actions for a File Indicator.
Field |
Description |
Type |
Required for Creation? |
---|---|---|---|
indicator |
The Indicator being associated to the File Indicator via the specified File Action |
Indicator Object |
TRUE |
relationship |
The name of the File Action |
String |
TRUE |
In the following example, the request will perform the following actions:
Create a new File Indicator based on an MD5 file hash
Create a new Address Indicator and associate it to the newly created File Indicator using the File Traffic File Action
Associate the existing File Indicator whose ID is 12 to the newly created File Indicator using the File Archive File Action
Because the fileActions
field is not included in the API response by default, the fields
query parameter is added to the request URL and assigned a value of fileActions
so that this field is included in the response.
POST /v3/indicators?fields=fileActions
Content-Type: application/json
{
"type": "File",
"md5": "2ea0564f33e4cb67063c4a06734eb627",
"fileActions": {
"data": [
{
"relationship": "File Traffic",
"indicator": {
"type": "Address",
"ip": "66.96.146.132"
}
},
{
"relationship": "File Archive",
"indicator": {
"id": 12
}
}
]
}
}
JSON Response
{
"data": {
"id": 18,
"ownerId": 18,
"ownerName": "Demo Organization",
"dateAdded": "2022-06-14T12:57:53Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/18/overview",
"type": "File",
"lastModified": "2022-06-14T12:57:53Z",
"summary": "2EA0564F33E4CB67063C4A06734EB627",
"privateFlag": false,
"active": true,
"activeLocked": false,
"fileActions": {
"data": [
{
"relationship": "File Archive",
"indicator": {
"id": 12,
"id": 1,
"ownerName": "Demo Organization",
"dateAdded": "2022-05-27T12:42:28Z ",
"webLink": "https://app.threatconnect.com/#/details/indicators/12/overview",
"type": "File",
"lastModified": "2022-05-27T12:42:28Z ",
"summary": "FB69E1273E7A53AD8E9BBE64B80859FC",
"privateFlag": false,
"active": true,
"activeLocked": false,
"fileActions": {
"count": 0
},
"md5": "FB69E1273E7A53AD8E9BBE64B80859FC",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/file.xhtml?file=FB69E1273E7A53AD8E9BBE64B80859FC&owner=Demo+Organization"
}
},
{
"relationship": "File Traffic",
"indicator": {
"id": 19,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2022-06-14T12:57:53Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/19/overview",
"type": "Address",
"lastModified": "2022-06-14T12:57:53Z",
"summary": "66.96.146.132",
"privateFlag": false,
"active": true,
"activeLocked": false,
"fileActions": {
"count": 0
},
"ip": "66.96.146.132",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/address.xhtml?address=66.96.146.132&owner=Demo+Organization"
}
}
],
"count": 2
},
"md5": "2EA0564F33E4CB67063C4A06734EB627",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/file.xhtml?file=2EA0564F33E4CB67063C4A06734EB627&owner=Demo+Organization"
},
"message": "Created",
"status": "Success"
}
You can append, replace, and delete File Actions via the mode
field. See Update an Object’s Metadata for more information on using this field.
File Occurrences
Create a File Occurrence
The following table outlines the fields available when creating File Occurrences for a File Indicator.
Field |
Description |
Type |
Required for Creation? |
---|---|---|---|
date |
The date and time of the File Occurrence |
Date |
FALSE* |
fileName |
The name of the file corresponding to the File Occurrence |
String |
FALSE* |
path |
The run path for the file corresponding to the File Occurrence |
String |
FALSE* |
Note
*While none of these fields are required, you must include at least one of them to create a File Occurrence.
In the following example, the request will add a File Occurrence to the existing File Indicator whose ID is 20. Because the fileOccurrences
field is not included in the API response by default, the fields
query parameter is added to the request URL and assigned a value of fileOccurrences
so that this field is included in the response.
PUT /v3/indicators/20?fields=fileOccurrences
Content-Type: application/json
{
"fileOccurrences": {
"data": [
{
"fileName": "win999301.dll",
"path": "C:\\\\Windows\\System",
"date": "2022-06-14T10:00:00Z"
}
]
}
}
JSON Response
{
"data": {
"id": 20,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2022-06-14T13:59:54Z",
"webLink": "https://appthreatconnect.com/#/details/indicators/20/overview",
"type": "File",
"lastModified": "2022-06-14T14:00:11Z",
"summary": "9D67E81C18101FC266057CD7851604B8",
"privateFlag": false,
"active": true,
"activeLocked": false,
"fileOccurrences": {
"data": [
{
"id": 5,
"fileName": "win999301.dll",
"path": "C:\\\\Windows\\System",
"date": "2022-06-14T10:00:00Z"
}
],
"count": 1
},
"md5": "9D67E81C18101FC266057CD7851604B8",
"legacyLink": "https://appthreatconnect.com/auth/indicators/details/file.xhtml?file=9D67E81C18101FC266057CD7851604B8&owner=Demo+Organization"
},
"message": "Updated",
"status": "Success"
}
Manage an Indicator’s File Actions
You can append, replace, and delete File Occurrences via the mode
field. If deleting a File Occurrence, use the File Occurrence’s ID when constructing your request. For example, the following request will delete the File Occurrence whose ID is 5 added to the File Indicator whose ID is 20:
PUT /v3/indicators/20
Content-Type: application/json
{
"fileOccurrences": {
"data": [
{
"id": 5
}
],
"mode": "delete"
}
}
For more information on using the mode
field, see Update an Object’s Metadata.
Hint
Send a request in the following format to retrieve a File Occurrence’s ID:
GET v3/indicators/{fileIndicatorId or fileIndicatorSummary}?fields=fileOccurrences
Merge File Hashes
If adding a new file hash to an existing File Indicator and a File Indicator containing that file hash exists in the same owner, you can merge the two File Indicators into a single File Indicator containing both file hashes and any Attributes, Security Labels, and Tags added to each Indicator.
You can merge only File Indicators containing different file hash types. For example, you can merge a File Indicator containing an MD5 file hash with a File Indicator containing a SHA1 file hash, but you cannot merge two File Indicators containing MD5 file hashes.
Attention
You cannot merge multiple hash values at once. For example, if you want to merge three separate File Indicators, each of which contains a unique file hash type, you must submit two separate requests: one to merge the first two file hash types (e.g., MD5 and SHA1) and another to merge the last file hash type (e.g., SHA256).
The following request will update an existing File Indicator containing an MD5 file hash (AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA) and add a SHA1 file hash (BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB) to it. Because another File Indicator containing this SHA1 file hash exists in the same owner as the File Indicator being updated, "mode": "merge"
will be included in the body of the request to merge the two File Indicators into a single File Indicator.
PUT /v3/indicators/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
Content-Type: application/json
{
"sha1": "BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB",
"mode": "merge"
}
JSON Response
{
"data": {
"id": 28,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2023-01-27T17:03:38Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/28/overview",
"type": "File",
"lastModified": "2023-01-27T17:09:03Z",
"summary": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA : BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB",
"privateFlag": false,
"active": true,
"activeLocked": false,
"md5": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA",
"sha1": "BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/file.xhtml?file=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA&owner=Demo+Organization"
},
"message": "Updated",
"status": "Success"
}
To remove a single file hash from a File Indicator, include "mode": "delete"
in the body of the request. For example, the following request will remove the SHA1 file hash (BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB) just added to the File Indicator containing an MD5 file hash (AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA). Note that the Indicator’s summary is encoded in the URL for this request.
PUT /v3/indicators/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA%20%3A%20BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
Content-Type: application/json
{
"sha1": "BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB",
"mode": "delete"
}
JSON Response
{
"data": {
"id": 28,
"ownerId": 1,
"ownerName": "Demo Organization",
"dateAdded": "2023-01-27T17:03:38Z",
"webLink": "https://app.threatconnect.com/#/details/indicators/28/overview",
"type": "File",
"lastModified": "2023-01-27T17:15:42Z",
"summary": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA",
"privateFlag": false,
"active": true,
"activeLocked": false,
"md5": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA",
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/file.xhtml?file=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA&owner=Demo+Organization"
},
"message": "Updated",
"status": "Success"
}
False Positives and Observations
As of ThreatConnect 7.8, API users can report false positives and observations for an Indicator that belongs to their Organization, Communities, and Sources.
Requirements
To report false positives and observations for Indicators via the ThreatConnect v3 API, the Include in Observations and False Positives option must be selected for your API user account.
To report false positives and observations for Indicators in an Organization, your API user account must have an Organization role of Standard User, Sharing User, Organization Administrator, or App Developer. Alternatively, if the v3ApiReadOnlyReports system setting is turned on for your ThreatConnect instance, your API user account can have any Organization role.
To report false positives and observations for Indicators in a Community or Source, your API user account must have a Community role of Contributor, Editor, or Director for the Community or Source. Alternatively, if the v3ApiReadOnlyReports system setting is turned on for your ThreatConnect instance, your API user account can have any Community role except Banned for the Community or Source.
Report an Indicator as False Positive
When creating a new Indicator or updating an existing one, you can report the Indicator as false positive. The following request demonstrates how to report an existing Indicator as false positive. Because false positive data are not included in the API response by default, the fields
query parameter is used and assigned a value of falsePositives
to include those data in the response.
PUT /v3/indicators/75?fields=falsePositives
{
"falsePositiveFlag": true
}
JSON Response
{
"data": {
"id": 75,
"dateAdded": "2024-11-07T12:55:33Z",
"ownerId": 2,
"ownerName": "Demo Source",
"webLink": "https://app.threatconnect.com/#/details/indicators/75",
"type": "Host",
"lastModified": "2024-12-09T19:34:21Z",
"summary": "nefarious.com",
"falsePositives": 1,
"falsePositiveReportedByUser": true,
"privateFlag": false,
"active": false,
"activeLocked": false,
"hostName": "nefarious.com",
"dnsActive": false,
"whoisActive": false,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=nefarious.com&owner=Demo+Source"
},
"message": "Updated",
"status": "Success"
}
JSON Response (Read Only)
{
"data": {
"type": "Host",
"threatAssessRating": 3.59,
"threatAssessConfidence": 20.65,
"threatAssessScore": 273,
"threatAssessScoreObserved": 0,
"threatAssessScoreFalsePositive": 0,
"summary": "nefarious.com",
"observations": 0,
"falsePositives": 1,
"lastFalsePositive": "2024-12-09T00:00:00Z",
"falsePositiveReportedByUser": true,
"trackedUsers": {
"John Smith": {
"observations": 0,
"falsePositives": 1,
"lastFalsePositive": "2024-12-09T00:00:00Z"
},
"Patrick Jones": {
"observations": 0,
"falsePositives": 0
}
}
},
"message": "Updated",
"status": "Success"
}
Report Observations for an Indicator
When creating a new Indicator or updating an existing one, you can report observations for the Indicator. The following request demonstrates how to report observations for an existing Indicator. Because observation data are not included in the API response by default, the fields
query parameter is used and assigned a value of observations
to include those data in the response.
PUT /v3/indicators/75?fields=observations
{
"observations": 1
}
JSON Response
{
"data": {
"id": 75,
"dateAdded": "2024-11-07T12:55:33Z",
"ownerId": 2,
"ownerName": "Demo Source",
"webLink": "https://app.threatconnect.com/#/details/indicators/75",
"type": "Host",
"lastModified": "2024-12-09T19:34:21Z",
"summary": "nefarious.com",
"observations": 1,
"lastObserved": "2024-12-09T00:00:00Z",
"privateFlag": false,
"active": false,
"activeLocked": false,
"hostName": "nefarious.com",
"dnsActive": false,
"whoisActive": false,
"legacyLink": "https://app.threatconnect.com/auth/indicators/details/host.xhtml?host=nefarious.com&owner=Demo+Source"
},
"message": "Updated",
"status": "Success"
}
JSON Response (Read Only)
{
"data": {
"type": "Host",
"threatAssessRating": 3.59,
"threatAssessConfidence": 20.65,
"threatAssessScore": 273,
"threatAssessScoreObserved": 0,
"threatAssessScoreFalsePositive": 0,
"summary": "nefarious.com",
"observations": 1,
"lastObserved": "2024-12-09T20:13:50Z",
"falsePositives": 0,
"falsePositiveReportedByUser": false,
"trackedUsers": {
"John Smith": {
"observations": 1,
"lastObserved": "2024-12-09T20:13:50Z",
"falsePositives": 0
},
"Patrick Jones": {
"observations": 0,
"falsePositives": 0
}
}
},
"message": "Updated",
"status": "Success"
}
MITRE ATT&CK® and ATT&CK® are registered trademarks of The MITRE Corporation.