mirror of
https://github.com/hastagAB/Awesome-Python-Scripts.git
synced 2025-01-18 15:27:02 +00:00
105 lines
3.5 KiB
Python
105 lines
3.5 KiB
Python
|
def itirate_of(logfile):
|
||
|
logging.debug("itirate_of")
|
||
|
lineCount = 0
|
||
|
start_flag = 0
|
||
|
elementarray = []
|
||
|
array2 = []
|
||
|
with open(logfile, "r") as ifile:
|
||
|
for line in ifile:
|
||
|
lineCount += 1
|
||
|
if "<log4j:event" in line:
|
||
|
logging.debug("found <log4j:event")
|
||
|
array2.append(line)
|
||
|
logging.debug("line: %s", line)
|
||
|
start_flag = 1
|
||
|
|
||
|
elif "</log4j:event>" in line:
|
||
|
logging.debug("found </log4j:event>")
|
||
|
start_flag = 0
|
||
|
array2.append(line)
|
||
|
logging.debug("line: %s", line)
|
||
|
elementarray.append(array2)
|
||
|
array2 = []
|
||
|
|
||
|
elif start_flag == 1:
|
||
|
logging.debug("startflag set")
|
||
|
array2.append(line)
|
||
|
logging.debug("line: %s", line)
|
||
|
|
||
|
return elementarray, lineCount
|
||
|
|
||
|
|
||
|
def parse(xmlelement):
|
||
|
logging.debug("parse")
|
||
|
root = ET.fromstring(xmlelement)
|
||
|
message = root[0].text
|
||
|
logger = root.attrib['logger']
|
||
|
timestamp = root.attrib['timestamp']
|
||
|
error_level = root.attrib['level']
|
||
|
thread = root.attrib['thread']
|
||
|
|
||
|
return message, logger, timestamp, error_level, thread
|
||
|
|
||
|
|
||
|
def ruleset(rule, message, logger, timestamp, error_level, thread):
|
||
|
logging.debug("ruleset")
|
||
|
compiled = message + logger + timestamp + error_level + thread
|
||
|
if args.regexsearch:
|
||
|
finder = re.findall(rule, compiled)
|
||
|
if finder:
|
||
|
frontend(message, logger, timestamp, error_level, thread)
|
||
|
if args.asciisearch:
|
||
|
if rule in compiled:
|
||
|
frontend(message, logger, timestamp, error_level, thread)
|
||
|
else:
|
||
|
if rule in compiled:
|
||
|
frontend(message, logger, timestamp, error_level, thread)
|
||
|
|
||
|
|
||
|
def frontend(message, logger, timestamp, error_level, thread):
|
||
|
logging.debug("frontend")
|
||
|
if args.frontend:
|
||
|
print(eval(args.frontend))
|
||
|
else:
|
||
|
print("{}: {} - {}".format(error_level, logger, timestamp))
|
||
|
|
||
|
|
||
|
def main(logfile, itir_file, ruleset, frontend):
|
||
|
logging.debug("main")
|
||
|
errors = 0
|
||
|
warns = 0
|
||
|
if args.asciisearch:
|
||
|
rule = args.asciisearch
|
||
|
elif args.regexsearch:
|
||
|
rule = args.regexsearch
|
||
|
else:
|
||
|
rule = ""
|
||
|
elementarray, lineCount = itir_file(logfile)
|
||
|
string = ""
|
||
|
for i in range(len(elementarray)):
|
||
|
xmlelement = "".join(elementarray[i])
|
||
|
message, logger, timestamp, error_level, thread = parse(xmlelement.replace("log4j:", "").rstrip('\n'))
|
||
|
ruleset(rule, message, logger, timestamp, error_level, thread)
|
||
|
if error_level == "ERROR":
|
||
|
errors += 1
|
||
|
if error_level == "WARN":
|
||
|
warns += 1
|
||
|
|
||
|
|
||
|
if __name__ in '__main__':
|
||
|
import xml.etree.ElementTree as ET
|
||
|
import logging
|
||
|
import sys
|
||
|
import re
|
||
|
import argparse
|
||
|
|
||
|
parser = argparse.ArgumentParser()
|
||
|
parser.add_argument('-f','--file', help='log4j file to parse', type=str, required=True)
|
||
|
parser.add_argument('-as','--asciisearch', help='ascii search pattern', type=str, required=False, default="")
|
||
|
parser.add_argument('-rs','--regexsearch', help='regex search pattern', type=str, required=False, default="")
|
||
|
parser.add_argument('-fe', '--frontend', help='customize output: message, logger, timestamp, error_level, thread', type=str, required=False, default="error_level, logger, timestamp")
|
||
|
args = parser.parse_args()
|
||
|
|
||
|
logging.basicConfig(format='%(levelname)s:%(message)s', level=logging.INFO)
|
||
|
main(args.file, itirate_of, ruleset, frontend)
|