ail-framework/bin/Categ.py

110 lines
3.5 KiB
Python
Raw Normal View History

2018-04-16 12:50:04 +00:00
#!/usr/bin/env python3.5
# -*-coding:UTF-8 -*
"""
The ZMQ_PubSub_Categ Module
============================
This module is consuming the Redis-list created by the ZMQ_PubSub_Tokenize_Q
Module.
Each words files created under /files/ are representing categories.
This modules take these files and compare them to
the stream of data given by the ZMQ_PubSub_Tokenize_Q Module.
When a word from a paste match one or more of these words file, the filename of
the paste is published/forwarded to the next modules.
Each category (each files) are representing a dynamic channel.
This mean that if you create 1000 files under /files/ you'll have 1000 channels
where every time there is a matching word to a category, the paste containing
this word will be pushed to this specific channel.
..note:: The channel will have the name of the file created.
Implementing modules can start here, create your own category file,
and then create your own module to treat the specific paste matching this
category.
..note:: Module ZMQ_Something_Q and ZMQ_Something are closely bound, always put
the same Subscriber name in both of them.
Requirements
------------
*Need running Redis instances. (Redis)
*Categories files of words in /files/ need to be created
*Need the ZMQ_PubSub_Tokenize_Q Module running to be able to work properly.
"""
2014-08-19 17:07:07 +00:00
import os
import argparse
import time
2014-09-05 15:05:45 +00:00
import re
from pubsublogger import publisher
from packages import Paste
from Helper import Process
2014-08-19 17:07:07 +00:00
if __name__ == "__main__":
publisher.port = 6380
2014-08-19 17:07:07 +00:00
publisher.channel = "Script"
config_section = 'Categ'
p = Process(config_section)
matchingThreshold = p.config.getint("Categ", "matchingThreshold")
# SCRIPT PARSER #
2016-02-10 15:39:56 +00:00
parser = argparse.ArgumentParser(description='Start Categ module on files.')
parser.add_argument(
2014-08-19 17:07:07 +00:00
'-d', type=str, default="../files/",
help='Path to the directory containing the category files.',
action='store')
args = parser.parse_args()
# FUNCTIONS #
publisher.info("Script Categ started")
2018-04-26 12:42:39 +00:00
categories = ['CreditCards', 'Mail', 'Onion', 'Web', 'Credential', 'Cve', 'ApiKey']
2014-08-19 17:07:07 +00:00
tmp_dict = {}
for filename in categories:
2014-08-19 17:07:07 +00:00
bname = os.path.basename(filename)
tmp_dict[bname] = []
with open(os.path.join(args.d, filename), 'r') as f:
2018-04-16 12:50:04 +00:00
patterns = [r'%s' % ( re.escape(s.strip()) ) for s in f]
2014-09-05 15:05:45 +00:00
tmp_dict[bname] = re.compile('|'.join(patterns), re.IGNORECASE)
prec_filename = None
while True:
2014-09-05 15:05:45 +00:00
filename = p.get_from_set()
2016-02-10 15:39:56 +00:00
if filename is None:
publisher.debug("Script Categ is Idling 10s")
2018-04-16 12:50:04 +00:00
print('Sleeping')
time.sleep(10)
2016-02-10 15:39:56 +00:00
continue
paste = Paste.Paste(filename)
content = paste.get_p_content()
2018-04-20 08:42:19 +00:00
#print('-----------------------------------------------------')
#print(filename)
#print(content)
#print('-----------------------------------------------------')
2018-04-16 12:50:04 +00:00
2016-02-10 15:39:56 +00:00
for categ, pattern in tmp_dict.items():
found = set(re.findall(pattern, content))
if len(found) >= matchingThreshold:
2016-02-10 15:39:56 +00:00
msg = '{} {}'.format(paste.p_path, len(found))
2018-04-16 12:50:04 +00:00
#msg = " ".join( [paste.p_path, bytes(len(found))] )
print(msg, categ)
2016-02-10 15:39:56 +00:00
p.populate_set_out(msg, categ)
publisher.info(
'Categ;{};{};{};Detected {} as {};{}'.format(
2016-02-10 15:39:56 +00:00
paste.p_source, paste.p_date, paste.p_name,
len(found), categ, paste.p_path))