mirror of https://github.com/D4-project/d4-core
chg: [worker4] add dnscap workers
parent
0f8a13a11a
commit
797ec0056a
|
@ -0,0 +1,102 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
import redis
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
def data_incorrect_format(session_uuid):
|
||||||
|
print('Incorrect format')
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
redis_server = redis.StrictRedis(
|
||||||
|
host="localhost",
|
||||||
|
port=6379,
|
||||||
|
db=0)
|
||||||
|
|
||||||
|
type = 4
|
||||||
|
rotation_save_cycle = 300 #seconds
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
|
||||||
|
if len(sys.argv) != 2:
|
||||||
|
print('usage:', 'Worker.py', 'session_uuid')
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
session_uuid = sys.argv[1]
|
||||||
|
stream_name = 'stream:{}:{}'.format(type, session_uuid)
|
||||||
|
id = '0'
|
||||||
|
|
||||||
|
res = redis_server.xread({stream_name: id}, count=1)
|
||||||
|
if res:
|
||||||
|
date = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
|
||||||
|
uuid = res[0][1][0][1][b'uuid'].decode()
|
||||||
|
data_rel_path = os.path.join('../../data', uuid, str(type))
|
||||||
|
dir_path = os.path.join(data_rel_path, date[0:4], date[4:6], date[6:8])
|
||||||
|
if not os.path.isdir(dir_path):
|
||||||
|
os.makedirs(dir_path)
|
||||||
|
filename = '{}-{}-{}-{}-{}.dnscap.txt'.format(uuid, date[0:4], date[4:6], date[6:8], date[8:14])
|
||||||
|
rel_path = os.path.join(dir_path, filename)
|
||||||
|
else:
|
||||||
|
sys.exit(1)
|
||||||
|
print('Incorrect message')
|
||||||
|
redis_server.sadd('working_session_uuid:{}'.format(type), session_uuid)
|
||||||
|
|
||||||
|
time_file = time.time()
|
||||||
|
rotate_file = False
|
||||||
|
|
||||||
|
while True:
|
||||||
|
|
||||||
|
res = redis_server.xread({stream_name: id}, count=1)
|
||||||
|
if res:
|
||||||
|
new_id = res[0][1][0][0].decode()
|
||||||
|
if id != new_id:
|
||||||
|
id = new_id
|
||||||
|
data = res[0][1][0][1]
|
||||||
|
if id and data:
|
||||||
|
#print(id)
|
||||||
|
#print(data)
|
||||||
|
new_date = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
|
||||||
|
if ( new_date[0:8] != date[0:8] ) or ( time.time() - time_file > rotation_save_cycle ):
|
||||||
|
date = new_date
|
||||||
|
rotate_file = True
|
||||||
|
|
||||||
|
if rotate_file:
|
||||||
|
if b'\n[' in data[b'message']:
|
||||||
|
old_str, new_str = data[b'message'].split(b'\n[', maxsplit=1)
|
||||||
|
|
||||||
|
with open(rel_path, 'ab') as f:
|
||||||
|
f.write(old_str)
|
||||||
|
|
||||||
|
dir_path = os.path.join(data_rel_path, date[0:4], date[4:6], date[6:8])
|
||||||
|
if not os.path.isdir(dir_path):
|
||||||
|
os.makedirs(dir_path)
|
||||||
|
filename = '{}-{}-{}-{}-{}.dnscap.txt'.format(data[b'uuid'].decode(), date[0:4], date[4:6], date[6:8], date[8:14])
|
||||||
|
rel_path = os.path.join(dir_path, filename)
|
||||||
|
time_file = time.time()
|
||||||
|
rotate_file = False
|
||||||
|
with open(rel_path, 'ab') as f:
|
||||||
|
f.write(b'['+new_str)
|
||||||
|
|
||||||
|
else:
|
||||||
|
with open(rel_path, 'ab') as f:
|
||||||
|
f.write(data[b'message'])
|
||||||
|
|
||||||
|
redis_server.xdel(stream_name, id)
|
||||||
|
|
||||||
|
else:
|
||||||
|
# sucess, all data are saved
|
||||||
|
if redis_server.sismember('ended_session', session_uuid):
|
||||||
|
redis_server.srem('ended_session', session_uuid)
|
||||||
|
redis_server.srem('session_uuid:{}'.format(type), session_uuid)
|
||||||
|
redis_server.srem('working_session_uuid:{}'.format(type), session_uuid)
|
||||||
|
redis_server.hdel('map-type:session_uuid-uuid:{}'.format(type), session_uuid)
|
||||||
|
redis_server.delete(stream_name)
|
||||||
|
# make sure that tcpdump can save all datas
|
||||||
|
print('dnscap: {} Done'.format(session_uuid))
|
||||||
|
sys.exit(0)
|
||||||
|
else:
|
||||||
|
time.sleep(10)
|
|
@ -0,0 +1,35 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
import redis
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
redis_server = redis.StrictRedis(
|
||||||
|
host="localhost",
|
||||||
|
port=6379,
|
||||||
|
db=0)
|
||||||
|
type = 4
|
||||||
|
|
||||||
|
try:
|
||||||
|
redis_server.ping()
|
||||||
|
except redis.exceptions.ConnectionError:
|
||||||
|
print('Error: Redis server {}:{}, ConnectionError'.format(host_redis, port_redis))
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
stream_name = 'stream:{}'.format(type)
|
||||||
|
redis_server.delete('working_session_uuid:{}'.format(type))
|
||||||
|
|
||||||
|
while True:
|
||||||
|
for session_uuid in redis_server.smembers('session_uuid:{}'.format(type)):
|
||||||
|
session_uuid = session_uuid.decode()
|
||||||
|
if not redis_server.sismember('working_session_uuid:{}'.format(type), session_uuid):
|
||||||
|
|
||||||
|
process = subprocess.Popen(['./worker.py', session_uuid])
|
||||||
|
print('New worker launched: {}'.format(session_uuid))
|
||||||
|
|
||||||
|
|
||||||
|
#print('.')
|
||||||
|
time.sleep(10)
|
Loading…
Reference in New Issue