tilde-projects/Code/python/chatchecker.py

37 lines
1.4 KiB
Python
Executable File

#!/usr/bin/python
import fileinput
import json
import time
import calendar
import shutil
logfile = "/home/archangelic/irc/log"
# logfile = "/home/jumblesale/Code/irc/log"
outfile = "/home/krowbar/logs/userData.json"
userData = {} # hash keyed by "user" that contains an array of timestamps
# we only care about recent chats, let's say for the past couple weeks
oneWeek = 7 * 24 * 60 * 60
fiveMinutes = 5 * 60
timeCutoff = calendar.timegm(time.gmtime()) - (5 * oneWeek)
with open(logfile, "r") as log:
for line in log:
try:
time, user, message = line.split("\t", 3)
time = int(time)
except ValueError:
continue # There are some bad lines in the log file that we'll ignore if we can't parse
if time > timeCutoff:
# standardize all times into a single "week"
# time %= oneWeek
# if the user already exists in the list
if user in userData:
if time < userData[user][-1] + fiveMinutes:
continue # only record times that are at least five minutes apart
userData[user].append(time) # append the new time
else: # if they are new
userData[user] = [time] # create a new list
with open(outfile + ".tmp", "w") as tmpFile:
tmpFile.write(json.dumps(userData))
shutil.move(outfile + ".tmp", outfile)