Skip to content

Crowdstrike falcon intel v2 support #1768

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 8 commits into from
Jul 9, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
81 changes: 23 additions & 58 deletions Integrations/integration-CrowdStrikeIntel.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,11 @@ name: FalconIntel
display: CrowdStrike Falcon Intel
category: Data Enrichment & Threat Intelligence
image: 
description: Actors, indicators and reports intelligence
description: Actors, indicators and reports intelligence with indicator V2 api support
detaileddescription: |-
Please provide the API id and key for the CrowsStrike Falcon Intelligence.
API Key Pairs can be generated by accessing the CrowdStrike API tab located in the user settings on the Intelligence Portal.
Indicator API v2 is supported.
configuration:
- display: Server URL (e.g. https://192.168.0.1)
name: url
Expand All @@ -35,8 +36,16 @@ configuration:
defaultvalue: "false"
type: 8
required: false
- display: Support indicator API V2
name: version
defaultvalue: "true"
type: 8
required: false
script:
script: |
// determine api version for api calls
var version = (params.version ? "v2" : "v1");

var serverUrl = params.url;
if (serverUrl[serverUrl.length - 1] !== '/') {
serverUrl += '/';
Expand All @@ -50,7 +59,8 @@ script:
'X-CSIX-CUSTID': [params.id],
'X-CSIX-CUSTKEY': [params.key],
'Content-Type': ['application/json'],
'Accept': ['application/json']
'Accept': ['application/json'],
'X-INTEGRATION' : ['Demisto_demisto_3.6']
},
Method: method,
Body: body ? JSON.stringify(body) : ''
Expand Down Expand Up @@ -237,7 +247,7 @@ script:
a.order = parts[1];
}
}
var res = doReq('GET', 'indicator/v1/search/' + args.parameter, a);
var res = doReq('GET', 'indicator/'+ version +'/search/' + args.parameter, a);
var md = '## Falcon Intel Indicator Search for: ' + args.value + '\n';
var found = false;
var ec = {};
Expand Down Expand Up @@ -289,7 +299,7 @@ script:

var doIndicator = function(ind, type, title, appendContextFunc) {
var a = {equal: ind};
var res = doReq('GET', 'indicator/v1/search/indicator', a);
var res = doReq('GET', 'indicator/'+ version +'/search/indicator', a);
var md = '## ' + title + ': ' + ind + '\n';
var ec = {};
var found = false;
Expand Down Expand Up @@ -431,8 +441,13 @@ script:

switch (command) {
case 'test-module':
doReq('GET', 'actors/queries/actors/v1', {q: 'panda'});
return true;
if(version === 'v2') {
doReq('GET', 'indicator/'+ version +'/search/indicator', {equal: '4.4.4.4'});
return true;
} else {
doReq('GET', 'actors/queries/actors/v1', {q: 'panda'});
return true;
}
case 'file':
return doFile(args.file);
case 'ip':
Expand All @@ -455,11 +470,9 @@ script:
type: javascript
commands:
- name: file
deprecated: false
arguments:
- name: file
required: true
deprecated: false
default: true
description: The file hash md5/sha1/sha256 to check
outputs:
Expand All @@ -483,11 +496,9 @@ script:
description: The actual score
description: Check file reputation
- name: url
deprecated: false
arguments:
- name: url
required: true
deprecated: false
default: true
description: URL to be checked
outputs:
Expand All @@ -507,11 +518,9 @@ script:
description: The actual score
description: Check the given URL reputation
- name: domain
deprecated: false
arguments:
- name: domain
required: true
deprecated: false
default: true
description: Domain to be checked
outputs:
Expand All @@ -531,11 +540,9 @@ script:
description: The actual score
description: Check the given URL reputation
- name: ip
deprecated: false
arguments:
- name: ip
required: true
deprecated: false
default: true
description: IP to check
outputs:
Expand All @@ -555,74 +562,55 @@ script:
description: The actual score
description: Check IP reputation
- name: cs-actors
deprecated: false
arguments:
- name: q
deprecated: false
default: true
description: Search all fields for the given data
- name: name
deprecated: false
description: Search based on actor name
- name: desc
deprecated: false
description: Search based on description
- name: minLastModifiedDate
deprecated: false
description: Search range from modified date. Dates are formatted as YYYY-MM-DD.
- name: maxLastModifiedDate
deprecated: false
description: Search range to modified date. Dates are formatted as YYYY-MM-DD.
- name: minLastActivityDate
deprecated: false
description: Search range from activity date. Dates are formatted as YYYY-MM-DD.
- name: maxLastActivityDate
deprecated: false
description: Search range to activity date. Dates are formatted as YYYY-MM-DD.
- name: origins
deprecated: false
description: Search by origins separated by ","
- name: targetCountries
deprecated: false
description: Search by target countries separated by ","
- name: targetIndustries
deprecated: false
description: Search by target industries separated by ","
- name: motivations
deprecated: false
description: Search by motivations separated by ","
- name: offset
deprecated: false
description: Which page of the results to retrieve. It is 0 based.
- name: limit
deprecated: false
description: Number of results for the page
- name: sort
deprecated: false
description: Sort is field_name.order, field_name.order where order is either
asc or desc
- name: slug
deprecated: false
description: 'Search by ''slug'' or short descriptive name. Ex: "anchor-panda"'
description: Search known actors based on the given parameters. Dates are formatted
as YYYY-MM-DD. Max date is taken automatically looking at end-of-day time. Origins,
targetCountries, targetIndustries and motivations can all receive multiple values
separated by ",". Offset is 0 based. Sort is field_name.order, field_name.order
where order is either asc or desc.
- name: cs-indicators
deprecated: false
arguments:
- name: parameter
required: true
deprecated: false
description: Based on what parameter to search. See CrowdStrike documentation
for details. Can be one of indicator, type, report, actor, malicious_confidence,
published_date, last_updated, malware_family, kill_chain, labels, DomainType,
EmailAddressType, IntelNews, IPAddressType, Malware, Status, Target, ThreatType,
Vulnerability
- name: filter
required: true
deprecated: false
auto: PREDEFINED
predefined:
- match
Expand All @@ -634,18 +622,14 @@ script:
description: Can be either match, equal, gt(e), lt(e)
- name: value
required: true
deprecated: false
description: The value for the given parameter
- name: sort
deprecated: false
description: Sort by a field. Should be field_name.order where order is either
asc or desc. Fields are indicator, type, report, actor, malicious_confidence,
published_date, last_updated.
- name: page
deprecated: false
description: The page to retrieve - 1 based
- name: pageSize
deprecated: false
description: The size of the page to retrieve
outputs:
- contextPath: File.MD5
Expand Down Expand Up @@ -718,35 +702,25 @@ script:
description: The actual score
description: Search known indicators based on the given parameters
- name: cs-reports
deprecated: false
arguments:
- name: q
deprecated: false
description: Perform a generic substring search across all fields in a report
- name: name
deprecated: false
description: Search for keywords across report names (i.e. the report’s title)
- name: actor
deprecated: false
description: Search for a report related to a particular actor. For a list of
actors, refer to the Intel Actors API
- name: targetCountries
deprecated: false
description: Search reports by targeted country/countries
- name: targetIndustries
deprecated: false
description: Search reports by targeted industry/industries
- name: motivations
deprecated: false
description: Search by motivation
- name: slug
deprecated: false
description: Search by report 'slug' or short descriptive name
- name: description
deprecated: false
description: Search the body of the report
- name: type
deprecated: false
auto: PREDEFINED
predefined:
- intelligence report
Expand All @@ -755,7 +729,6 @@ script:
- tipper
description: The type of object to search for.
- name: subType
deprecated: false
auto: PREDEFINED
predefined:
- weekly
Expand All @@ -764,38 +737,30 @@ script:
- annual
description: The sub-type to search for.
- name: tags
deprecated: false
description: Tags associated with a report (managed internally by CS)
- name: minLastModifiedDate
deprecated: false
description: Constrain results to those modified on or after a certain date
- format YYYY-MM-DD
- name: maxLastModifiedDate
deprecated: false
description: Constrain results to those modified on or before a certain date
- format YYYY-MM-DD
- name: offset
deprecated: false
description: Used to paginate the response. You can then use limit to set the
number of results for the next page.
- name: limit
deprecated: false
description: Limits the number of results to return
- name: sort
deprecated: false
description: 'The field and direction to sort results on in the format of: <field>.<asc>
or <field>.<desc>. Valid values include: name, target_countries, target_industries,
type, created_date, last_modified_date'
description: The Falcon Intel Reports API allows to query CrowdStrike intelligence
publications.
- name: cs-report-pdf
deprecated: false
arguments:
- name: id
required: true
deprecated: false
default: true
description: The ID of the report to retrieve
description: Retrieve the Falcon Intel Report PDF
hidden: false
fromversion: 3.5.0
runonce: false
releaseNotes: "Added support for v2 indicator API"
Loading