chg: [statistics] add domain statistics

This commit is contained in:
Terrtia 2018-07-31 10:36:29 +02:00
parent 5dcb4ebb58
commit e455d244d8
No known key found for this signature in database
GPG key ID: 1E1B1F50D84613D0
2 changed files with 88 additions and 25 deletions

View file

@ -10,6 +10,8 @@ the out output of the Global module.
""" """
import time import time
import datetime
import redis
from packages import Paste from packages import Paste
from pubsublogger import publisher from pubsublogger import publisher
@ -26,6 +28,13 @@ def main():
p = Process(config_section) p = Process(config_section)
addr_dns = p.config.get("DomClassifier", "dns") addr_dns = p.config.get("DomClassifier", "dns")
# ARDB #
server_statistics = redis.StrictRedis(
host=p.config.get("ARDB_Statistics", "host"),
port=p.config.getint("ARDB_Statistics", "port"),
db=p.config.getint("ARDB_Statistics", "db"),
decode_responses=True)
publisher.info("""ZMQ DomainClassifier is Running""") publisher.info("""ZMQ DomainClassifier is Running""")
c = DomainClassifier.domainclassifier.Extract(rawtext="", nameservers=[addr_dns]) c = DomainClassifier.domainclassifier.Extract(rawtext="", nameservers=[addr_dns])
@ -46,20 +55,31 @@ def main():
paste = PST.get_p_content() paste = PST.get_p_content()
mimetype = PST._get_p_encoding() mimetype = PST._get_p_encoding()
nb_domain = 0
nb_tld_domain = 0
if mimetype == "text/plain": if mimetype == "text/plain":
c.text(rawtext=paste) c.text(rawtext=paste)
c.potentialdomain() c.potentialdomain()
c.validdomain(rtype=['A'], extended=True) valid = c.validdomain(rtype=['A'], extended=True)
nb_domain = len(set(valid))
if nb_domain > 0:
localizeddomains = c.include(expression=cc_tld) localizeddomains = c.include(expression=cc_tld)
if localizeddomains: if localizeddomains:
print(localizeddomains) nb_tld_domain = len(set(localizeddomains))
publisher.warning('DomainC;{};{};{};Checked {} located in {};{}'.format( publisher.warning('DomainC;{};{};{};Checked {} located in {};{}'.format(
PST.p_source, PST.p_date, PST.p_name, localizeddomains, cc_tld, PST.p_path)) PST.p_source, PST.p_date, PST.p_name, localizeddomains, cc_tld, PST.p_path))
localizeddomains = c.localizedomain(cc=cc) localizeddomains = c.localizedomain(cc=cc)
if localizeddomains: if localizeddomains:
print(localizeddomains) nb_tld_domain = nb_tld_domain + len(set(localizeddomains))
publisher.warning('DomainC;{};{};{};Checked {} located in {};{}'.format( publisher.warning('DomainC;{};{};{};Checked {} located in {};{}'.format(
PST.p_source, PST.p_date, PST.p_name, localizeddomains, cc, PST.p_path)) PST.p_source, PST.p_date, PST.p_name, localizeddomains, cc, PST.p_path))
date = datetime.datetime.now().strftime("%Y%m")
server_statistics.hincrby('domain_by_tld:'+date, 'ALL', nb_domain)
if nb_tld_domain > 0:
server_statistics.hincrby('domain_by_tld:'+date, cc, nb_tld_domain)
except IOError: except IOError:
print("CRC Checksum Failed on :", PST.p_path) print("CRC Checksum Failed on :", PST.p_path)
publisher.error('Duplicate;{};{};{};CRC Checksum Failed'.format( publisher.error('Duplicate;{};{};{};CRC Checksum Failed'.format(

View file

@ -8,6 +8,7 @@ lu
import os import os
import sys import sys
import redis import redis
import argparse
import datetime import datetime
import heapq import heapq
import operator import operator
@ -18,7 +19,7 @@ sys.path.append(os.environ['AIL_BIN'])
from Helper import Process from Helper import Process
def create_pie_chart(db_key, date, pie_title, path, save_name): def create_pie_chart(country ,db_key, date, pie_title, path, save_name):
monthly_credential_by_tld = server_statistics.hkeys(db_key + date) monthly_credential_by_tld = server_statistics.hkeys(db_key + date)
@ -37,19 +38,23 @@ def create_pie_chart(db_key, date, pie_title, path, save_name):
labels = [] labels = []
sizes = [] sizes = []
explode = [] # only "explode" the 2nd slice (i.e. 'Hogs') explode = [] # only "explode" the 2nd slice (i.e. 'Hogs')
explode_value = 0
for tld in mail_tld_top5: for tld in mail_tld_top5:
labels.append(tld[0]) labels.append(tld[0] +' ('+str(tld[1])+')')
sizes.append(tld[1]) sizes.append(tld[1])
explode.append(0) explode.append(explode_value)
explode_value = explode_value +0.1
nb_tld = server_statistics.hget(db_key + date, 'lu') nb_tld = server_statistics.hget(db_key + date, country)
if nb_tld is not None: if nb_tld is not None:
nb_tld = int(nb_tld) nb_tld = int(nb_tld)
else: else:
nb_tld = 0 nb_tld = 0
labels.append('lu') country_label = country + ' ('+str(nb_tld)+')'
if country_label not in labels:
labels.append(country_label)
sizes.append(nb_tld) sizes.append(nb_tld)
explode.append(0.3) # only "explode" lu slice explode.append(explode_value)
explode = tuple(explode) explode = tuple(explode)
fig1, ax1 = plt.subplots() fig1, ax1 = plt.subplots()
@ -85,12 +90,13 @@ def create_donut_chart(db_key, date, pie_title, path, save_name):
recipe.append(tld[0]) recipe.append(tld[0])
data.append(tld[1]) data.append(tld[1])
nb_tld = server_statistics.hget(db_key + date, 'lu') nb_tld = server_statistics.hget(db_key + date, country)
if nb_tld is not None: if nb_tld is not None:
nb_tld = int(nb_tld) nb_tld = int(nb_tld)
else: else:
nb_tld = 0 nb_tld = 0
recipe.append('lu') if country not in recipe:
recipe.append(country)
data.append(nb_tld) data.append(nb_tld)
fig1, ax1 = plt.subplots(figsize=(6, 3), subplot_kw=dict(aspect="equal")) fig1, ax1 = plt.subplots(figsize=(6, 3), subplot_kw=dict(aspect="equal"))
@ -118,6 +124,29 @@ def create_donut_chart(db_key, date, pie_title, path, save_name):
if __name__ == '__main__': if __name__ == '__main__':
parser = argparse.ArgumentParser(
description='''This script is a part of the Analysis Information Leak
framework. It create pie charts on a country statistics".''',
epilog='Example: ./create_lu_graph.py 0 lu now, create_lu_graph.py 0 lu 201807')
parser.add_argument('type', type=int, default=0,
help='''The graph type (default 0),
0: all,
1: credential_pie,
2: mail_pie
3: sqlinjection_pie,
4: domain_pie,''',
choices=[0, 1, 2, 3, 4], action='store')
parser.add_argument('country', type=str, default="de",
help='''The country code, de:default''',
action='store')
parser.add_argument('date', type=str, default="now",
help='''month %Y%m, example: 201810''', action='store')
args = parser.parse_args()
path = os.path.join(os.environ['AIL_HOME'], 'doc') # path to module config file path = os.path.join(os.environ['AIL_HOME'], 'doc') # path to module config file
config_section = 'ARDB_Statistics' config_section = 'ARDB_Statistics'
@ -131,7 +160,21 @@ if __name__ == '__main__':
db=p.config.getint("ARDB_Statistics", "db"), db=p.config.getint("ARDB_Statistics", "db"),
decode_responses=True) decode_responses=True)
if args.date == 'now' or len(args.date) != 6:
date = datetime.datetime.now().strftime("%Y%m") date = datetime.datetime.now().strftime("%Y%m")
create_pie_chart('credential_by_tld:', date, "AIL: Credential leak by tld", path, 'AIL_credential_by_tld.png') else:
create_pie_chart('mail_by_tld:', date, "AIL: mail leak by tld", path, 'AIL_mail_by_tld.png') date = args.date
create_pie_chart('SQLInjection_by_tld:', date, "AIL: sqlInjection by tld", path, 'AIL_sqlInjectionl_by_tld.png')
if args.type == 0:
create_pie_chart(args.country, 'credential_by_tld:', date, "AIL: Credential leak by tld", path, 'AIL_credential_by_tld.png')
create_pie_chart(args.country, 'mail_by_tld:', date, "AIL: mail leak by tld", path, 'AIL_mail_by_tld.png')
create_pie_chart(args.country, 'SQLInjection_by_tld:', date, "AIL: SQLInjection by tld", path, 'AIL_SQLInjection_by_tld.png')
create_pie_chart(args.country.upper(), 'domain_by_tld:', date, "AIL: Domain by tld", path, 'AIL_domain_by_tld.png')
elif args.type == 1:
create_pie_chart(args.country, 'credential_by_tld:', date, "AIL: Credential leak by tld", path, 'AIL_credential_by_tld.png')
elif args.type == 2:
create_pie_chart(args.country, 'mail_by_tld:', date, "AIL: mail leak by tld", path, 'AIL_mail_by_tld.png')
elif args.type == 3:
create_pie_chart(args.country, 'SQLInjection_by_tld:', date, "AIL: sqlInjection by tld", path, 'AIL_sqlInjectionl_by_tld.png')
elif args.type == 4:
create_pie_chart(args.country.upper(), 'domain_by_tld:', date, "AIL: Domain by tld", path, 'AIL_domain_by_tld.png')