}
}
-void init_bots() {
- set_bot_alias(0, "0");
- start_zero_bots();
- set_trigger_callback(0, 0, zero_bots_trigger_callback);
- bind_bot_ready(zero_bots_bot_ready, 0);
-
+static TIMEQ_CALLBACK(load_timed_bans) {
MYSQL_RES *res;
MYSQL_ROW row;
- //load all timed bans
- printf_mysql_query("SELECT `ban_id`, `ban_timeout` FROM `bans` WHERE `ban_timeout` > 0");
+ //load all timed bans for the next 7 days
+ printf_mysql_query("SELECT `ban_id`, `ban_timeout` FROM `bans` WHERE `ban_timeout` > 0 AND `ban_timeout` < (UNIX_TIMESTAMP() + (86400 * 7))");
res = mysql_use();
char nameBuf[20];
while ((row = mysql_fetch_row(res)) != NULL) {
printf_mysql_query("DELETE FROM `bans` WHERE `ban_id` = '%s'", row[0]);
}
}
+ timeq_add(86400*7, 0, load_timed_bans, NULL);
+}
+
+void init_bots() {
+ set_bot_alias(0, "0");
+ start_zero_bots();
+ set_trigger_callback(0, 0, zero_bots_trigger_callback);
+ bind_bot_ready(zero_bots_bot_ready, 0);
+
+ timeq_add(10, 0, load_timed_bans, NULL);
+
}
struct ClientSocket *getChannelBot(struct ChanNode *chan, int botid) {