86 lines
2.8 KiB
Python
86 lines
2.8 KiB
Python
# CFLog.py - CFLog class
|
|
#
|
|
# Copyright (C) 2002 Joris Bontje
|
|
#
|
|
# 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 2 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, write to the Free Software
|
|
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
#
|
|
# The author can be reached via e-mail at jbontje@suespammers.org
|
|
#
|
|
|
|
# Updated to use new path functions in CFPython -Todd Mitchell
|
|
#
|
|
# Updated to add new fields and functions (kick, muzzle)
|
|
# and rewritten to use plain text file storage (CFDataFile) instead of shelve.
|
|
|
|
|
|
import Crossfire
|
|
|
|
from time import localtime, strftime, time
|
|
from CFDataFile import CFDataFile, CFData
|
|
|
|
class CFLog:
|
|
|
|
def __init__(self):
|
|
logheader = ['Born', 'IP', 'Last_Login_Date', 'Login_Count', 'Kick_Count'
|
|
, 'Last_Kick_Date', 'Muzzle_Count', 'Last_Muzzle_Date']
|
|
self.log = CFData('Player_log', logheader)
|
|
|
|
def create(self, name):
|
|
date = strftime("%a, %d %b %Y %H:%M:%S %Z", localtime(time()))
|
|
record={'#': name
|
|
,'Born':date
|
|
,'IP':'unknown'
|
|
,'Last_Login_Date':date
|
|
,'Login_Count':0
|
|
,'Kick_Count':0
|
|
,'Last_Kick_Date':'never'
|
|
,'Muzzle_Count':0
|
|
,'Last_Muzzle_Date':'never'}
|
|
self.log.put_record(record)
|
|
|
|
def remove(self, name):
|
|
self.log.remove_record(name)
|
|
|
|
def login_update(self, name, ip):
|
|
date = strftime("%a, %d %b %Y %H:%M:%S %Z", localtime(time()))
|
|
record = self.log.get_record(name)
|
|
record['IP']=ip
|
|
record['Last_Login_Date']=date
|
|
record['Login_Count']=int(record['Login_Count'])+1
|
|
self.log.put_record(record)
|
|
|
|
def kick_update(self, name):
|
|
date = strftime("%a, %d %b %Y %H:%M:%S %Z", localtime(time()))
|
|
record = self.log.get_record(name)
|
|
record['Kick_Count']=int(record['Kick_Count'])+1
|
|
record['Last_Kick_Date']=date
|
|
self.log.put_record(record)
|
|
|
|
def muzzle_update(self, name):
|
|
date = strftime("%a, %d %b %Y %H:%M:%S %Z", localtime(time()))
|
|
record = self.log.get_record(name)
|
|
record['Muzzle_Count']=int(record['Muzzle_Count'])+1
|
|
record['Last_Muzzle_Date']=date
|
|
self.log.put_record(record)
|
|
|
|
def info(self, name):
|
|
if name == '#':
|
|
return 0
|
|
record = self.log.get_record(name)
|
|
if record:
|
|
return record
|
|
else:
|
|
return 0
|