monkey/monkey_island/cc/services/log.py

53 lines
1.5 KiB
Python
Raw Normal View History

from datetime import datetime
import gridfs
import cc.services.node
from cc.database import mongo
__author__ = "itay.mizeretz"
class LogService:
def __init__(self):
pass
@staticmethod
def get_log_by_monkey_id(monkey_id):
log = mongo.db.log.find_one({'monkey_id': monkey_id})
if log:
fs = gridfs.GridFS(mongo.db)
log_file = fs.get(log['file_id'])
monkey_label = cc.services.node.NodeService.get_monkey_label(
cc.services.node.NodeService.get_monkey_by_id(log['monkey_id']))
return \
{
'monkey_label': monkey_label,
'log': log_file.read(),
'timestamp': log['timestamp']
}
@staticmethod
def remove_logs_by_monkey_id(monkey_id):
fs = gridfs.GridFS(mongo.db)
for log in mongo.db.log.find({'monkey_id': monkey_id}):
fs.delete(log['file_id'])
mongo.db.log.delete_many({'monkey_id': monkey_id})
@staticmethod
def add_log(monkey_id, log_data, timestamp=datetime.now()):
LogService.remove_logs_by_monkey_id(monkey_id)
fs = gridfs.GridFS(mongo.db)
file_id = fs.put(log_data)
return mongo.db.log.insert(
{
'monkey_id': monkey_id,
'file_id': file_id,
'timestamp': timestamp
}
)
@staticmethod
def log_exists(monkey_id):
return mongo.db.log.find_one({'monkey_id': monkey_id}) is not None