#!/usr/bin/env python3 ''' Copyright Daniel Jones 2018 This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . ''' import os, json; class Message: ''' messages.append(Message(filepath)); print(messages[x].filepath); ''' msgcount = 0; channels = []; def __init__(self, fp, line): self.filepath = fp; self.line = line; Message.msgcount+=1; def parsechannel(self): # channel name is taken from file path self.channel = self.filepath.split("#")[1].split("_")[0]; def parsedate(self): # date taken from file path self.date = self.filepath.rsplit("_", 1)[1].rsplit(".", 1)[0]; def parseline(self): try: self.user = self.line.split("<", 1)[1].split(">", 1)[0]; except: self.user = "ZNCLOG"; self.line = "[99:99:99] name change or join/part, disregard.\n"; self.time = self.line.split(" <", 1)[0].replace("[", "").replace("]", ""); self.message = self.line.split("> ", 1)[1]; if self.message.endswith("\n"): self.message = self.message[:-1]; def getstructuredmsg(self): self.data = {}; self.data["date"] = self.date; self.data["time"] = self.time; self.data["channel"] = self.channel; self.data["user"] = self.user; self.data["message"] = self.message; return self.data; def parse(self): # get message time self.parseline(); self.parsechannel(); self.parsedate(); def getlines(logfile): with open(logfile, encoding="utf-8") as f: for line in f: messages.append(Message(logfile, line)); def getlogpaths(): # loop through each .log file inside indir for file in os.listdir(indir): if (file.endswith(".log")): filepath = os.path.join(indir, file); logfiles.append(filepath); if (debug): break; if __name__ == "__main__": debug = 0; indir = "logs/parse"; logfiles = []; messages = []; getlogpaths(); tmpdata = []; # collect all lines for file in logfiles: getlines(file); # parse each line for x in range(len(messages)): messages[x].parse(); tmpdata.append(messages[x].getstructuredmsg()); jsondata = json.dumps(tmpdata); print(jsondata);