Merge Upstream

This commit is contained in:
Andreas Bielawski 2016-08-16 17:42:25 +02:00
commit d4ed80a288
3 changed files with 50 additions and 16 deletions

@ -3,7 +3,7 @@ local bot = {}
bindings = require('miku.bindings') bindings = require('miku.bindings')
utilities = require('miku.utilities') utilities = require('miku.utilities')
bot.version = '160815' bot.version = '160816'
function bot:init(config) -- The function run when the bot is started or reloaded. function bot:init(config) -- The function run when the bot is started or reloaded.
cred_data = load_cred() cred_data = load_cred()

@ -47,6 +47,9 @@ function banhammer:kick_user(user_id, chat_id, self, onlykick)
chat_id = chat_id, chat_id = chat_id,
user_id = user_id user_id = user_id
} ) } )
local hash = 'chat:'..chat_id..':users'
print('User '..user_id..' was kicked/left the chat, deleting them from redis set '..hash)
redis:srem(hash, user_id)
if onlykick then return end if onlykick then return end
if not request then return 'User gebannt, aber kicken war nicht erfolgreich. Bin ich Administrator oder ist der User hier überhaupt?' end if not request then return 'User gebannt, aber kicken war nicht erfolgreich. Bin ich Administrator oder ist der User hier überhaupt?' end
return 'User '..user_id..' gebannt!' return 'User '..user_id..' gebannt!'
@ -173,8 +176,7 @@ end
function banhammer:action(msg, config, matches) function banhammer:action(msg, config, matches)
if not is_sudo(msg, config) then if not is_sudo(msg, config) then
utilities.send_reply(self, msg, config.errors.sudo) return -- Silent ignore
return
end end
if matches[1] == 'leave' then if matches[1] == 'leave' then
@ -193,8 +195,14 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
elseif msg.reply_to_message.left_chat_member then
user_id = msg.reply_to_message.left_chat_member.id
else
user_id = msg.reply_to_message.from.id user_id = msg.reply_to_message.from.id
end end
end
if msg.chat.type == 'group' or msg.chat.type == 'supergroup' then if msg.chat.type == 'group' or msg.chat.type == 'supergroup' then
if matches[2] == 'user' or not matches[2] then if matches[2] == 'user' or not matches[2] then
@ -220,8 +228,12 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
else
user_id = msg.reply_to_message.from.id user_id = msg.reply_to_message.from.id
end end
end
banhammer:kick_user(user_id, msg.chat.id, self, true) banhammer:kick_user(user_id, msg.chat.id, self, true)
return return
else else
@ -249,7 +261,11 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
local user_id = msg.reply_to_message.from.id if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
else
user_id = msg.reply_to_message.from.id
end
local hash = 'whitelist:user#id'..user_id local hash = 'whitelist:user#id'..user_id
redis:set(hash, true) redis:set(hash, true)
utilities.send_reply(self, msg, 'User '..user_id..' whitelisted') utilities.send_reply(self, msg, 'User '..user_id..' whitelisted')
@ -260,7 +276,13 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
local user_id = msg.reply_to_message.from.id if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
elseif msg.reply_to_message.left_chat_member then
user_id = msg.reply_to_message.left_chat_member.id
else
user_id = msg.reply_to_message.from.id
end
local hash = 'whitelist:user#id'..user_id local hash = 'whitelist:user#id'..user_id
redis:del(hash) redis:del(hash)
utilities.send_reply(self, msg, 'User '..user_id..' von der Whitelist entfernt!') utilities.send_reply(self, msg, 'User '..user_id..' von der Whitelist entfernt!')
@ -326,7 +348,13 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
local user_id = msg.reply_to_message.from.id if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
elseif msg.reply_to_message.left_chat_member then
user_id = msg.reply_to_message.left_chat_member.id
else
user_id = msg.reply_to_message.from.id
end
local hash = 'blocked:'..user_id local hash = 'blocked:'..user_id
redis:set(hash, true) redis:set(hash, true)
utilities.send_reply(self, msg, 'User '..user_id..' darf den Bot nun nicht mehr nutzen.') utilities.send_reply(self, msg, 'User '..user_id..' darf den Bot nun nicht mehr nutzen.')
@ -337,7 +365,13 @@ function banhammer:action(msg, config, matches)
if not msg.reply_to_message then if not msg.reply_to_message then
return return
end end
local user_id = msg.reply_to_message.from.id if msg.reply_to_message.new_chat_member then
user_id = msg.reply_to_message.new_chat_member.id
elseif msg.reply_to_message.left_chat_member then
user_id = msg.reply_to_message.left_chat_member.id
else
user_id = msg.reply_to_message.from.id
end
local hash = 'blocked:'..user_id local hash = 'blocked:'..user_id
redis:del(hash) redis:del(hash)
utilities.send_reply(self, msg, 'User '..user_id..' darf den Bot wieder nutzen.') utilities.send_reply(self, msg, 'User '..user_id..' darf den Bot wieder nutzen.')

@ -80,21 +80,21 @@ function stats:chat_stats(chat_id)
end end
function stats:pre_process(msg, self) function stats:pre_process(msg, self)
-- Ignore service msg
if is_service_msg(msg) then
print('Service message')
return msg
end
if msg.left_chat_member then if msg.left_chat_member then
-- delete user from redis set, but keep message count -- delete user from redis set, but keep message count
local hash = 'chat:'..msg.chat.id..':users' local hash = 'chat:'..msg.chat.id..':users'
local user_id_left = msg.left_chat_member.id local user_id_left = msg.left_chat_member.id
print('User '..user_id_left..' was kicked, deleting him/her from redis set '..hash) print('User '..user_id_left..' was kicked/left the chat, deleting them from redis set '..hash)
redis:srem(hash, user_id_left) redis:srem(hash, user_id_left)
return msg return msg
end end
-- Ignore service msg
if is_service_msg(msg) then
print('Service message')
return msg
end
-- Save user on Redis -- Save user on Redis
local hash = 'user:'..msg.from.id local hash = 'user:'..msg.from.id
-- print('Saving user', hash) -- remove comment to restore old behaviour -- print('Saving user', hash) -- remove comment to restore old behaviour