Multiple plugins in one message

This commit is contained in:
yago 2014-12-31 17:45:52 +01:00
parent e811ea8a52
commit 4774bf52e8
2 changed files with 70 additions and 51 deletions

View File

@ -5,7 +5,7 @@ json = (loadfile "./libs/JSON.lua")()
serpent = (loadfile "./libs/serpent.lua")() serpent = (loadfile "./libs/serpent.lua")()
require("./bot/utils") require("./bot/utils")
VERSION = '0.8.0' VERSION = '0.8.1'
function on_msg_receive (msg) function on_msg_receive (msg)
vardump(msg) vardump(msg)
@ -14,7 +14,6 @@ function on_msg_receive (msg)
return return
end end
update_user_stats(msg)
do_action(msg) do_action(msg)
mark_read(get_receiver(msg), ok_cb, false) mark_read(get_receiver(msg), ok_cb, false)
@ -30,7 +29,6 @@ function on_binlog_replay_end ()
-- See plugins/ping.lua as an example for cron -- See plugins/ping.lua as an example for cron
_config = load_config() _config = load_config()
_users = load_user_stats()
-- load plugins -- load plugins
plugins = {} plugins = {}
@ -63,16 +61,15 @@ function do_action(msg)
for name, desc in pairs(plugins) do for name, desc in pairs(plugins) do
-- print("Trying module", name) -- print("Trying module", name)
for k, pattern in pairs(desc.patterns) do for k, pattern in pairs(desc.patterns) do
-- print("Trying", text, "against", pattern) print("Trying", text, "against", pattern)
matches = { string.match(text, pattern) } matches = { string.match(text, pattern) }
if matches[1] then if matches[1] then
print(" matches", pattern) print(" matches", pattern)
if desc.run ~= nil then if desc.run ~= nil then
result = desc.run(msg, matches) result = desc.run(msg, matches)
print(" sending", result)
if (result) then if (result) then
print(" sending", result)
_send_msg(receiver, result) _send_msg(receiver, result)
return
end end
end end
end end
@ -105,6 +102,7 @@ function save_config( )
}) })
file:write(serialized) file:write(serialized)
file:close() file:close()
print ('saved config into ./bot/config.lua')
end end
@ -150,47 +148,7 @@ function create_config( )
}) })
file:write(serialized) file:write(serialized)
file:close() file:close()
end print ('saved config into ./bot/config.lua')
function update_user_stats(msg)
-- Save user to _users table
local from_id = tostring(msg.from.id)
local to_id = tostring(msg.to.id)
local user_name = get_name(msg)
-- If last name is nil dont save last_name.
local user_last_name = msg.from.last_name
local user_print_name = msg.from.print_name
if _users[to_id] == nil then
_users[to_id] = {}
end
if _users[to_id][from_id] == nil then
_users[to_id][from_id] = {
name = user_name,
last_name = user_last_name,
print_name = user_print_name,
msg_num = 1
}
else
local actual_num = _users[to_id][from_id].msg_num
_users[to_id][from_id].msg_num = actual_num + 1
-- And update last_name
_users[to_id][from_id].last_name = user_last_name
end
end
function load_user_stats()
local f = io.open('res/users.json', "r+")
-- If file doesn't exists
if f == nil then
f = io.open('res/users.json', "w+")
f:write("{}") -- Write empty table
f:close()
return {}
else
local c = f:read "*a"
f:close()
return json:decode(c)
end
end end
function on_our_id (id) function on_our_id (id)

View File

@ -1,12 +1,56 @@
function run(msg, matches) function update_user_stats(msg)
vardump(_users) -- Save user to _users table
local from_id = tostring(msg.from.id)
local to_id = tostring(msg.to.id)
local user_name = get_name(msg)
print ('New message from '..user_name..'['..to_id..']'..'['..from_id..']')
-- If last name is nil dont save last_name.
local user_last_name = msg.from.last_name
local user_print_name = msg.from.print_name
if _users[to_id] == nil then
_users[to_id] = {}
end
if _users[to_id][from_id] == nil then
_users[to_id][from_id] = {
name = user_name,
last_name = user_last_name,
print_name = user_print_name,
msg_num = 1
}
else
local actual_num = _users[to_id][from_id].msg_num
_users[to_id][from_id].msg_num = actual_num + 1
-- And update last_name
_users[to_id][from_id].last_name = user_last_name
end
end
function load_user_stats()
local f = io.open('res/users.json', "r+")
-- If file doesn't exists
if f == nil then
f = io.open('res/users.json', "w+")
f:write("{}") -- Write empty table
f:close()
return {}
else
local c = f:read "*a"
f:close()
return json:decode(c)
end
end
function save_stats()
-- Save stats to file -- Save stats to file
local json_users = json:encode_pretty(_users) local json_users = json:encode_pretty(_users)
vardump(json_users) vardump(json_users)
file_users = io.open ("./res/users.json", "w") file_users = io.open ("./res/users.json", "w")
file_users:write(json_users) file_users:write(json_users)
file_users:close() file_users:close()
end
function get_stats_status( msg )
-- vardump(_users)
local text = "" local text = ""
local to_id = tostring(msg.to.id) local to_id = tostring(msg.to.id)
@ -17,12 +61,29 @@ function run(msg, matches)
text = text..user.name.." "..user.last_name.." ["..id.."]: "..user.msg_num.."\n" text = text..user.name.." "..user.last_name.." ["..id.."]: "..user.msg_num.."\n"
end end
end end
print("usuarios: "..text)
return text return text
end end
function run(msg, matches)
-- TODO: I need to know wich patterns matches.
if matches[1] == "!stats" then
return get_stats_status(msg)
else
print ("update stats")
update_user_stats(msg)
end
end
-- TODO: local vars
_users = load_user_stats()
return { return {
description = "Numer of messages by user", description = "Numer of messages by user",
usage = "!stats", usage = "!stats",
patterns = {"^!stats"}, patterns = {
".*",
"^!stats"
},
run = run run = run
} }