aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/suricata/contrib/file_processor/Processor/ShadowServer.pm
blob: c9c7a5f9a0dce33bccfa4b9cb2cbf3f951a110c9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package Processor::ShadowServer;
use Moose;
extends 'Processor';
use Data::Dumper;
use LWP::UserAgent;
use JSON;

has 'md5' => (is => 'ro', isa => 'Str', required => 1);
has 'ua' => (is => 'rw', isa => 'LWP::UserAgent', required => 1, default => sub { return LWP::UserAgent->new(agent => 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:10.0.1) Gecko/20100101 Firefox/10.0.1'); });
has 'url_template' => (is => 'ro', isa => 'Str', required => 1, default => 'http://innocuous.shadowserver.org/api/?query=%s');
sub name { 'ShadowServer' }
sub description { 'Processor for shadowserver.com' }

sub process {
	my $self = shift;
	my $url = sprintf($self->url_template, $self->md5);
	$self->log->debug('Getting url ' . $url);
	my $response = $self->ua->get($url);
	if ($response->code eq 200){
		if ($response->decoded_content =~ /No match/){
			$self->log->debug('No result');
			return 0;
		}
		elsif ($response->decoded_content =~ /Whitelisted/){
			$self->log->info('Whitelisted');
			return 0;
		}
		$self->log->info('Got shadowserver.com result');
		my $ret;
		eval {
			my ($meta,$json) = split(/\n/, $response->decoded_content);
			my @meta_cols = qw(md5 sha1 first_date last_date type ssdeep);
			my %metas;
			@metas{@meta_cols} = split(/\,/, $meta);
			$ret = { meta => \%metas, results => decode_json($json) };
		};
		if ($@){
			$self->log->error($@);
			return 0;
		}
		return $ret;
	}
	else {
		$self->log->debug('Communications failure: ' . Dumper($response));
		return 0;
	}
}

1