/PasteHunter

Scanning pastebin with yara rules

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

PasteHunter

PasteHunter is a python3 application that is designed to query a collection of sites that host publicliy pasted data. For all the pasts it finds it scans the raw contents against a series of yara rules looking for information that can be used by an org or a researcher.

Supported Inputs

Pastehunter currently has support for the following sites:

  • pastebin.com
  • dumpz.org
  • gist.github.com

Support for the following sites is listed as ToDo:

  • paste.ee

Supported Outputs

Pastehunter supports several output modules:

  • dump to ElasticSearch DB (default)
  • email sending over SMTP
  • dump to JSON file
  • dump to CSV file

SMTP

Multiple recipients can be specified, with different rulesets each. It's possible to combine these rules using simple OR or AND logic (respectively rule_list and mandatory_rule_list). You need to set SMTP_SECURITY in the config file to one of the following options:

  • 'tls'
  • 'starttls'
  • 'none'

Refer to your email provider to determine which you require.

PostProcess Modules

Pastehunter comes with a couple of post process modules that extact useful data from pastes or pass them to other services The following are default modules:

  • Base64 Decoders
    • Cuckoo
    • Viper

PreReqs

Pastebin

You need a Pro account on pastebin that has access to the scraping API. https://pastebin.com/api_scraping_faq

GitHub

Github needs an oauth token to stop it hitting the free ratelimit. Create one at https://github.com/settings/tokens

YOU DO NOT NEED TO GIVE IT ANY ACCESS PERMISSIONS

Installation

Local install

Elastic Search

https://www.elastic.co/guide/en/elasticsearch/reference/current/deb.html

Kibana

https://www.elastic.co/guide/en/kibana/current/deb.html

Yara

https://yara.readthedocs.io/en/latest/gettingstarted.html#compiling-and-installing-yara

If you have yara errors check the installed version numbers for yara and yara-python match the lastest versions.

PasteHunter

git clone https://github.com/kevthehermit/pastehunter

Python / Deps

Python 3 pip3 install -r requirements.txt

Using Docker

Install Docker & docker-compose

docker build . -t pastehunter

Using Docker-compose

Running all the applications

Run docker-compose up -d

Kibana

Kibana is running only on the localhost interface on default port (5601).

Kibana use the default login and password : elastic and changme

Kibana is using the static IP address : 172.16.10.12 in the esnet network

Elasticsearch

Elasticsearch is running only on the localhost interface on default port 9200. The mount point is /usr/share/elasticsearch/data by default

if elastic search fails to start and you see "max virtual memory areas vm.max_map_count [65530] likely too low" in the logs then try

sudo sysctl -w vm.max_map_count=262144

https://elk-docker.readthedocs.io/#troubleshooting Paragraph starting As from version 5

Pastehunter

You can re-run the pastehunter script by doing docker-compose up -d Docker-compose will use already running instances of Elasticsearch and Kibana

Configure

copy settings.json.sample to settings.json populate the details. For the scraping API you need to whitelist your IP on pastebin. No API key is required. See the link above

The logging level can be set to one of the following values.

Level Numerical
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
NOTSET 0

The default is INFO:20

Running

Start the application with python3 pastehunter.py

It may be useful to run in a screen to keep it running in the background.

Service

Service config is coming