Make channel values being inserted into SQLite integers if they're numbers.
Update ducks.py, you can now .bef and .bang! Coming soon: .friends, .killers, and .ducks Update google to use gb instead of us. We're British goddamnit.
This commit is contained in:
parent
e272d50f49
commit
8d6f0fffa9
3 changed files with 182 additions and 2 deletions
16
Database.py
16
Database.py
|
@ -112,10 +112,24 @@ class ServerSettings(Table):
|
||||||
[server_id, setting.lower()])
|
[server_id, setting.lower()])
|
||||||
|
|
||||||
class ChannelSettings(Table):
|
class ChannelSettings(Table):
|
||||||
|
def jsonKeys2int(self, x):
|
||||||
|
if isinstance(x, dict):
|
||||||
|
hold = {}
|
||||||
|
for k, v in x.items():
|
||||||
|
key = int(k) if k.isdigit() else k
|
||||||
|
val = int(v) if v.isdigit() else v
|
||||||
|
|
||||||
|
hold[key] = val
|
||||||
|
return hold
|
||||||
|
else:
|
||||||
|
return x
|
||||||
|
|
||||||
def set(self, channel_id, setting, value):
|
def set(self, channel_id, setting, value):
|
||||||
|
converted_json = self.jsonKeys2int(value)
|
||||||
|
|
||||||
self.database.execute(
|
self.database.execute(
|
||||||
"INSERT OR REPLACE INTO channel_settings VALUES (?, ?, ?)",
|
"INSERT OR REPLACE INTO channel_settings VALUES (?, ?, ?)",
|
||||||
[channel_id, setting.lower(), json.dumps(value)])
|
[channel_id, setting.lower(), converted_json])
|
||||||
def get(self, channel_id, setting, default=None):
|
def get(self, channel_id, setting, default=None):
|
||||||
value = self.database.execute_fetchone(
|
value = self.database.execute_fetchone(
|
||||||
"""SELECT value FROM channel_settings WHERE
|
"""SELECT value FROM channel_settings WHERE
|
||||||
|
|
166
modules/ducks.py
Normal file
166
modules/ducks.py
Normal file
|
@ -0,0 +1,166 @@
|
||||||
|
import datetime, time
|
||||||
|
import random, IRCLogging
|
||||||
|
|
||||||
|
DUCK_LAST_SEEN = datetime.datetime.now()
|
||||||
|
|
||||||
|
class Module(object):
|
||||||
|
def __init__(self, bot):
|
||||||
|
self.log = IRCLogging.Log
|
||||||
|
self.bot = bot
|
||||||
|
self.active_duck = 0
|
||||||
|
|
||||||
|
bot.events.on("received.command.bef").hook(self.duck_bef,
|
||||||
|
help="Befriend a duck!")
|
||||||
|
bot.events.on("received.command.bang").hook(self.duck_bang,
|
||||||
|
help="Shoot a duck! Meanie.")
|
||||||
|
# bot.events.on("received.command.friends").hook(self.duck_friends,
|
||||||
|
# help="See who the friendliest people to ducks are!")
|
||||||
|
# bot.events.on("received.command.killers").hook(self.duck_killers,
|
||||||
|
# help="See who shoots the most amount of ducks.")
|
||||||
|
# bot.events.on("received.command.ducks").hook(self.duck_list,
|
||||||
|
# help="Shows a list of the most popular duck superstars.")
|
||||||
|
|
||||||
|
now = datetime.datetime.now()
|
||||||
|
next_duck_time = random.randint(30, 40)
|
||||||
|
|
||||||
|
self.duck_times = {}
|
||||||
|
|
||||||
|
tricky = next_duck_time - now.second
|
||||||
|
tricky += ((next_duck_time - (now.minute + 1))*2)
|
||||||
|
|
||||||
|
bot.events.on("postboot").on("configure").on(
|
||||||
|
"channelset").assure_call(setting="ducks-enabled",
|
||||||
|
help="Toggles ducks! (1 or 0)")
|
||||||
|
|
||||||
|
bot.events.on("postboot").on("configure").on(
|
||||||
|
"channelset").assure_call(setting="min-duck-time",
|
||||||
|
help="Minimum seconds before a duck is summoned")
|
||||||
|
|
||||||
|
bot.events.on("postboot").on("configure").on(
|
||||||
|
"channelset").assure_call(setting="max-duck-time",
|
||||||
|
help="Max seconds before a duck is summoned")
|
||||||
|
|
||||||
|
bot.events.on("timer").on("duck-appear").hook(self.show_duck)
|
||||||
|
bot.add_timer("duck-appear", next_duck_time, persist=False)
|
||||||
|
|
||||||
|
bot.events.on("received.numeric.366").hook(self.bootstrap)
|
||||||
|
|
||||||
|
|
||||||
|
def bootstrap(self, event):
|
||||||
|
for server in self.bot.servers.values():
|
||||||
|
for channel in server.channels.values():
|
||||||
|
ducks_enabled = channel.get_setting("ducks-enabled", 0)
|
||||||
|
min_time = "min-duck-time-%s" % channel.name
|
||||||
|
max_time = "max-duck-time-%s" % channel.name
|
||||||
|
|
||||||
|
min_duck_time = channel.get_setting("min-duck-time", 240)
|
||||||
|
max_duck_time = channel.get_setting("max-duck-time", 1200)
|
||||||
|
|
||||||
|
self.duck_times[min_time] = min_duck_time
|
||||||
|
self.duck_times[max_time] = max_duck_time
|
||||||
|
|
||||||
|
if ducks_enabled == 1:
|
||||||
|
channel.set_setting("active-duck", 0)
|
||||||
|
|
||||||
|
print(self.duck_times)
|
||||||
|
|
||||||
|
def duck_time(self, channel):
|
||||||
|
if isinstance(channel, str):
|
||||||
|
channel_name = channel
|
||||||
|
else:
|
||||||
|
channel_name = channel["target"].name
|
||||||
|
|
||||||
|
min = "min-duck-time-%s" % (channel_name)
|
||||||
|
max = "max-duck-time-%s" % (channel_name)
|
||||||
|
|
||||||
|
self.bot.log.debug("Attempting to set %s to %s", [str(min), str(self.duck_times[min])]);
|
||||||
|
self.bot.log.debug("Attempting to set %s to %s", [str(max), str(self.duck_times[max])]);
|
||||||
|
|
||||||
|
return random.randint(self.duck_times[min], self.duck_times[max])
|
||||||
|
|
||||||
|
def duck_bef(self, event):
|
||||||
|
target = event["user"].nickname
|
||||||
|
if event["target"].get_setting("active-duck", 0) == 0:
|
||||||
|
event["stderr"].set_prefix("Kick")
|
||||||
|
if event["server"].has_user(target):
|
||||||
|
if not event["server"].is_own_nickname(target):
|
||||||
|
event["target"].send_kick(target, "You tried befriending a non-existent duck. Creepy!")
|
||||||
|
else:
|
||||||
|
event["stderr"].write("Nope.")
|
||||||
|
else:
|
||||||
|
event["stderr"].write("That user is not in this channel")
|
||||||
|
else:
|
||||||
|
setting = "bef-ducks-%s-%s" % (target, event["target"].name)
|
||||||
|
befriended_ducks = event["server"].get_setting(setting, 0)
|
||||||
|
event["server"].set_setting(setting, befriended_ducks + 1)
|
||||||
|
event["target"].set_setting("active-duck", 0)
|
||||||
|
|
||||||
|
grammar = "" if befriended_ducks == 0 else "s"
|
||||||
|
|
||||||
|
event["stdout"].write(target + ", you've befriended " + str(befriended_ducks + 1) + " duck" + grammar + " in " + event["target"].name);
|
||||||
|
|
||||||
|
next_duck_time = self.duck_time(event)
|
||||||
|
self.bot.add_timer("duck-appear", next_duck_time, persist=False)
|
||||||
|
|
||||||
|
|
||||||
|
def duck_bang(self, event):
|
||||||
|
target = event["user"].nickname
|
||||||
|
if event["target"].get_setting("active-duck", 0) == 0:
|
||||||
|
event["stderr"].set_prefix("Kick")
|
||||||
|
if event["server"].has_user(target):
|
||||||
|
if not event["server"].is_own_nickname(target):
|
||||||
|
event["target"].send_kick(target, "You tried shooting a non-existent duck. Creepy!")
|
||||||
|
else:
|
||||||
|
event["stderr"].write("Nope.")
|
||||||
|
else:
|
||||||
|
event["stderr"].write("That user is not in this channel")
|
||||||
|
else:
|
||||||
|
setting = "shot-ducks-%s-%s" % (target, event["target"].name)
|
||||||
|
shot_ducks = event["server"].get_setting(setting, 0)
|
||||||
|
event["server"].set_setting(setting, shot_ducks + 1)
|
||||||
|
event["target"].set_setting("active-duck", 0)
|
||||||
|
|
||||||
|
grammar = "" if shot_ducks == 0 else "s"
|
||||||
|
|
||||||
|
event["stdout"].write(target + ", you've shot " + str(shot_ducks + 1) + " duck" + grammar + " in " + event["target"].name);
|
||||||
|
|
||||||
|
next_duck_time = self.duck_time(event)
|
||||||
|
self.bot.add_timer("duck-appear", next_duck_time, persist=False)
|
||||||
|
|
||||||
|
def show_duck(self, event):
|
||||||
|
for server in self.bot.servers.values():
|
||||||
|
for channel in server.channels.values():
|
||||||
|
ducks_enabled = channel.get_setting("ducks-enabled", 0)
|
||||||
|
self.bot.log.info("Ducks enabled for %s: %s", [str(channel.name), str(ducks_enabled)])
|
||||||
|
active_duck = channel.get_setting("active-duck", 0)
|
||||||
|
|
||||||
|
if ducks_enabled == 1 and active_duck == 0:
|
||||||
|
ducks = [
|
||||||
|
"・゜゜・。。・゜ ゜\_O< quack!",
|
||||||
|
"・゜゜・。。・゜ ゜\_o< QUACK!",
|
||||||
|
"・゜゜・。 。・゜゜\_ó< quack!",
|
||||||
|
"・゜゜・。 。・゜゜\_ó< quack quack!",
|
||||||
|
"・゜゜ 。 。・゜ \_ó< bawk!",
|
||||||
|
"・゜゜ 。 。・゜゜\_ó< squawk!",
|
||||||
|
"・ ゜・。 。・゜゜ \_ó< beep beep!"
|
||||||
|
]
|
||||||
|
|
||||||
|
channel.send_message(random.choice(ducks))
|
||||||
|
|
||||||
|
channel.set_setting("active-duck", 1)
|
||||||
|
else:
|
||||||
|
channel.set_setting("active-duck", 0)
|
||||||
|
|
||||||
|
next_duck_time = self.duck_time(channel.name)
|
||||||
|
self.bot.add_timer("duck-appear", next_duck_time, persist=False)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# def coins(self, event):
|
||||||
|
# if event["args_split"]:
|
||||||
|
# target = event["server"].get_user(event["args_split"][0])
|
||||||
|
# else:
|
||||||
|
# target = event["user"]
|
||||||
|
# coins = decimal.Decimal(target.get_setting("coins", "0.0"))
|
||||||
|
# event["stdout"].write("%s has %s coin%s" % (target.nickname,
|
||||||
|
# "{0:.2f}".format(coins), "" if coins == 1 else "s"))
|
|
@ -19,7 +19,7 @@ class Module(object):
|
||||||
"q": phrase, "key": self.bot.config[
|
"q": phrase, "key": self.bot.config[
|
||||||
"google-api-key"], "cx": self.bot.config[
|
"google-api-key"], "cx": self.bot.config[
|
||||||
"google-search-id"], "prettyPrint": "true",
|
"google-search-id"], "prettyPrint": "true",
|
||||||
"num": 1, "gl": "us"}, json=True)
|
"num": 1, "gl": "gb"}, json=True)
|
||||||
if page:
|
if page:
|
||||||
if "items" in page and len(page["items"]):
|
if "items" in page and len(page["items"]):
|
||||||
event["stdout"].write(page["items"][0][
|
event["stdout"].write(page["items"][0][
|
||||||
|
|
Loading…
Reference in a new issue