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