You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

136 lines
3.1 KiB

7 years ago
#!/usr/bin/perl -w
use strict;
use XML::Simple;
use Data::Dumper;
# Date
use POSIX qw(strftime);
my $date = strftime "%d/%m/%Y %H:%M", localtime;
# Functions
sub uniq {
my %seen;
grep !$seen{$_}++, @_;
}
print "\033[36m \nDEFACEMENT CHECK [" . $date . "]\n\nSearching for suspects ...\n";
7 years ago
print "FOUND \t\t=> URLs\n";
# # Import config Website (LOAD domain in conf/websites.cfg)
# my @scan;
# my @search;
# my $websites = 'conf/websites.cfg';
# if (open(my $f, '<:encoding(UTF-8)', $websites)) {
# while (my $row = <$f>) {
# chomp $row;
# push @scan, $row;
# }
# } else {
# warn "Could not open file '$websites' $!";
# }
#
# # Slurp Websites
# my $site;
# system("rm urls/*.urls");
# foreach $site (@scan)
# {
# system("/bin/bash slurp_urls.sh $site");
# }
# Import config Website (LOAD domain in ARG : perl defacement_check.pl example.com)
my @whitelist;
7 years ago
my @search;
my $site = $ARGV[0];
# Slurp Site
7 years ago
system("rm urls/*.urls");
system("/bin/bash slurp_urls.sh $site");
7 years ago
# Import config Ignore
my $ignores = 'conf/' . $site . '.ignore';
if (open(my $f, '<:encoding(UTF-8)', $ignores)) {
while (my $row = <$f>) {
chomp $row;
push @whitelist, $row;
}
} else {
warn "Could not open file '$ignores' $!";
}
7 years ago
# Import config Keywords
7 years ago
my $keywords = 'conf/keywords.cfg';
if (open(my $f, '<:encoding(UTF-8)', $keywords)) {
while (my $row = <$f>) {
chomp $row;
push @search, $row;
}
} else {
warn "Could not open file '$keywords' $!";
}
# Open URLS files
my @files = glob( "urls/*.urls" );
7 years ago
my $file;
my $somme_total_found = 0;
my $grand_total_found = 0;
7 years ago
foreach $file (@files)
{
my @urls;
7 years ago
my $url;
my $somme_total_found = 0;
open(FH, '<', $file) or die $!;
while(<FH>){
my $survey = $_;
7 years ago
# Create a user agent object
use LWP::UserAgent;
my $ua = LWP::UserAgent->new;
# Create a request
my $req = HTTP::Request->new(GET => $survey);
# Pass request to the user agent and get a response back
my $res = $ua->request($req);
my $site = $res->content;
my @found;
7 years ago
my @clean;
7 years ago
my $total_found = 0;
7 years ago
foreach my $s (@search) {
foreach (grep(/$s/i, split(/\n/, $site))) {
push @found, $_;
}
}
foreach my $i (@whitelist) {
foreach (uniq(@found)) {
foreach (grep(/$i/i, split(/\n/))) {
7 years ago
print "\033[35mIGNORE ";
pop @found, $_;
7 years ago
}
}
}
7 years ago
# Results
foreach (uniq(@found)) {
$total_found++;
7 years ago
print "\033[33m[" . $total_found . "]\t\t" . $_ . "\n"; # VERBOSE
7 years ago
}
if ($total_found == 0) {
7 years ago
print "\033[32m[" . $total_found . "]\t\t=> " . $survey. "\n"; # SAFE
7 years ago
} else {
7 years ago
print "\033[31mTREATH [" . $total_found . "]\t=> " . $survey. "\n"; # TREATH
$somme_total_found = $somme_total_found + $total_found;
7 years ago
}
}
close(FH);
print "\033[36mTREATH detected on this site \t\t\t\t=> [" . $somme_total_found . "]\n\n";
$grand_total_found = $somme_total_found + $grand_total_found;
7 years ago
}
print "\033[36mGrand Total TREATH detected on ALL website \t\t=> [" . $grand_total_found . "]\n\n";
# Print results in Output file
open(my $out, '>', 'out.txt');
print $out $grand_total_found;
close $out;