2013-02-14 21:27:04 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
"""
|
|
|
|
antiabuse.py - Phenny AntiAbuse Module
|
2014-06-21 23:32:52 +02:00
|
|
|
Copyright 2012, sfan5
|
2013-02-14 21:27:04 +01:00
|
|
|
"""
|
2014-03-03 19:27:28 +01:00
|
|
|
import time, sqlite3
|
2013-02-14 21:27:04 +01:00
|
|
|
|
|
|
|
antiabuse = {}
|
2014-03-03 18:03:44 +01:00
|
|
|
antiabuse["ignorelist"] = []
|
2014-06-22 11:55:42 +02:00
|
|
|
antiabuse["cooldown_l"] = {}
|
2014-06-21 23:32:52 +02:00
|
|
|
antiabuse["cooldown"] = 3 # seconds
|
2013-02-14 21:27:04 +01:00
|
|
|
|
2014-06-22 12:23:21 +02:00
|
|
|
def aa_hook(phenny, input, func):
|
2013-02-14 21:27:04 +01:00
|
|
|
if input.admin or input.owner:
|
|
|
|
return False
|
2014-06-21 23:32:52 +02:00
|
|
|
|
|
|
|
# Ignore list
|
|
|
|
for entry in antiabuse["ignorelist"]:
|
|
|
|
if phenny.match_hostmask(entry, input.hostmask):
|
2013-02-14 21:27:04 +01:00
|
|
|
return True # abort command
|
2014-06-21 23:32:52 +02:00
|
|
|
|
|
|
|
# Cooldown
|
2014-06-22 12:23:21 +02:00
|
|
|
if input.nick in antiabuse["cooldown_l"]:
|
2014-06-22 11:55:42 +02:00
|
|
|
ot = antiabuse["cooldown_l"][input.nick]
|
2014-06-22 12:23:21 +02:00
|
|
|
else:
|
2013-02-14 21:27:04 +01:00
|
|
|
ot = 0
|
2014-06-22 11:55:42 +02:00
|
|
|
antiabuse["cooldown_l"][input.nick] = time.time()
|
|
|
|
if antiabuse["cooldown_l"][input.nick] - antiabuse["cooldown"] < ot:
|
2013-05-01 20:35:29 +02:00
|
|
|
return True # abort command
|
2013-02-23 23:30:52 +01:00
|
|
|
pass
|
2014-06-21 23:32:52 +02:00
|
|
|
|
2013-02-14 21:27:04 +01:00
|
|
|
return False
|
2014-06-21 23:32:52 +02:00
|
|
|
|
2014-06-22 12:23:21 +02:00
|
|
|
aa_hook.hook = True
|
2014-06-21 23:32:52 +02:00
|
|
|
|
|
|
|
def hmasktrans(va):
|
|
|
|
a = "!" in va
|
|
|
|
b = "@" in va
|
|
|
|
if not a and not b:
|
|
|
|
return va + "!*@*"
|
|
|
|
elif a and not b:
|
|
|
|
return va + "@*"
|
|
|
|
elif not a and b:
|
|
|
|
return "*!" + va
|
|
|
|
else: # a and b
|
|
|
|
return va
|
2013-02-14 21:27:04 +01:00
|
|
|
|
|
|
|
def ignore(phenny, input):
|
2014-03-03 18:03:44 +01:00
|
|
|
if not input.admin:
|
|
|
|
return
|
2014-06-21 23:32:52 +02:00
|
|
|
arg = hmasktrans(input.group(2).strip())
|
2014-03-03 18:03:44 +01:00
|
|
|
antiabuse["ignorelist"].append(arg)
|
|
|
|
db = sqlite3.connect("antiabuse.sqlite")
|
|
|
|
c = db.cursor()
|
2014-03-17 20:26:19 +01:00
|
|
|
c.execute("INSERT INTO ignore (nick) VALUES (?)", (arg,))
|
2014-03-03 18:03:44 +01:00
|
|
|
c.close()
|
|
|
|
db.commit()
|
|
|
|
db.close()
|
|
|
|
phenny.reply("'%s' added to ignore list." % arg)
|
2013-02-14 21:27:04 +01:00
|
|
|
|
|
|
|
ignore.commands = ['ignore']
|
|
|
|
ignore.priority = 'high'
|
|
|
|
|
|
|
|
def unignore(phenny, input):
|
2014-03-03 18:03:44 +01:00
|
|
|
if not input.admin:
|
|
|
|
return
|
2014-06-21 23:32:52 +02:00
|
|
|
arg = hmasktrans(input.group(2).strip())
|
2014-03-03 18:03:44 +01:00
|
|
|
if not arg in antiabuse["ignorelist"]:
|
|
|
|
return
|
|
|
|
antiabuse['ignorelist'].remove(arg)
|
|
|
|
db = sqlite3.connect("antiabuse.sqlite")
|
|
|
|
c = db.cursor()
|
|
|
|
c.execute("DELETE FROM ignore WHERE nick = ?", (arg,))
|
|
|
|
c.close()
|
|
|
|
db.commit()
|
|
|
|
db.close()
|
|
|
|
phenny.reply("'%s' removed from ignore list." % arg)
|
2013-02-14 21:27:04 +01:00
|
|
|
|
|
|
|
unignore.commands = ['unignore']
|
|
|
|
unignore.priority = 'high'
|
|
|
|
|
2014-06-22 11:55:42 +02:00
|
|
|
def listignore(phenny, input):
|
|
|
|
if not input.admin:
|
|
|
|
return
|
|
|
|
phenny.reply(', '.join(antiabuse['ignorelist']))
|
|
|
|
|
|
|
|
listignore.commands = ['listignore']
|
|
|
|
listignore.priority = 'high'
|
|
|
|
|
2014-03-03 18:03:44 +01:00
|
|
|
db = sqlite3.connect("antiabuse.sqlite")
|
|
|
|
c = db.cursor()
|
|
|
|
c.execute('''CREATE TABLE IF NOT EXISTS ignore (nick text)''')
|
|
|
|
c.execute("SELECT * FROM ignore")
|
|
|
|
while True:
|
|
|
|
e = c.fetchone()
|
|
|
|
if not e:
|
|
|
|
break
|
|
|
|
antiabuse["ignorelist"].append(e[0])
|
|
|
|
c.close()
|
|
|
|
db.commit()
|
|
|
|
db.close()
|