The ThreatCrowd API allows you to quickly identify related infrastructure and malware.
With the ThreatCrowd API you can search for:
- Domains
- IP Addreses
- E-mail adddresses
- Filehashes
- Antivirus detections
You can download a sample python application, a sample C# application and a sample javascript application.
The request and response format is similiar to that of the VirusTotal API - this is to allow for code reuse. HTTP GET requests are used to return JSON objects, for example:
- https://www.threatcrowd.org/searchApi/v2/email/report/[email protected]
- https://www.threatcrowd.org/searchApi/v2/domain/report/?domain=aoldaily.com
- https://www.threatcrowd.org/searchApi/v2/ip/report/?ip=188.40.75.132
- https://www.threatcrowd.org/searchApi/v2/antivirus/report/?antivirus=plugx
- https://www.threatcrowd.org/searchApi/v2/file/report/?resource=ec8c89aa5e521572c74e2dd02a4daf78
For example, the following python code:
import requests, json
result = requests.get("https://www.threatcrowd.org/searchApi/v2/email/report/", params = {"email": "[email protected]"})
print result.text
j = json.loads(result.text)
print j['domains'][0]
Would print:
{"response_code":"1","domains":["aoldaily.com","aunewsonline.com","cnndaily.com","usnewssite.com"],"references":[],"permalink":"https:\/\/www.threatcrowd.org\/[email protected]"}
aoldaily.com
Results for entities will include a "votes" field, which will have one of the following values: -1 Most users have voted this malicious 0 An equal number of users have voted this malicious 1 Most users have voted this not malicious
You can submit votes via the interface, or a simple API:
- This will place a vote for "good.com" being non-malicious: https://www.threatcrowd.org/vote.php?vote=1&value=good.com
- This will place a vote for "bad.com" being malicious: https://www.threatcrowd.org/vote.php?vote=0&value=bad.com
A feed of malicious domains and IP addresses are available at http://threatcrowd.blogspot.co.uk/2016/02/crowdsourced-feeds-from-threatcrowd.html
The previous version of the API (http://threatcrowd.blogspot.co.uk/p/api.html) is deprecated but the endpoint is still active. Maltego transforms (http://threatcrowd.blogspot.co.uk/p/threatcrowd-maltego-transform.html) are also available.
The Search API is designed to provide a simple way to identify threats, and those related to them. However - it isn't designed to provide detailed information. In particular it is no replacement for more detailed APIs such as VirusTotal, TotalHash and PassiveTotal.
Please limit all requests to no more than one request every ten seconds.
Brief bursts of requests that exceed this (eg; if you're using Maltego to enrich a large set of indicators) are ok so long as they don't significantly impact the performance of the server.
If you require faster acccess than this please drop me a line at [email protected] and I can raise it - the broad principal is that faster access is fine, so long as it doesn't impact the performance for other users.
- Python pypi Library - https://pypi.python.org/pypi/threatcrowd
- Go package - https://github.com/jheise/gothreat
- Splunk Application - https://splunkbase.splunk.com/app/1657/
- Web application - https://ipintel.io/
- Python application - https://github.com/QTek/QRadio
- RabbitMQ - http://stoq.punchcyber.com/docs/
- Buatapa - http://www.brimorlabsblog.com/2015/08/publicly-announcing-buatapa.html
- Command line - https://github.com/jheise/threatcmd
- Splunk Application 2 - https://splunkbase.splunk.com/app/3081/
- R Package - https://github.com/threatcrowd/ApiV2/tree/master/RExample
I make no guarantees as to the availability or veracity of results. Additionally, all information is provided "as is" and I disclaim all warranties. All access to the server is logged.