stats with local scope
This commit is contained in:
parent
a889d410f1
commit
e22d2670fd
@ -1,5 +1,14 @@
|
|||||||
|
-- Saves the number of messages from a user
|
||||||
|
-- Can check the number of messages with !stats
|
||||||
|
|
||||||
|
do
|
||||||
|
|
||||||
|
local socket = require('socket')
|
||||||
|
local _file_stats = './res/stats.lua'
|
||||||
|
local _stats
|
||||||
|
|
||||||
function update_user_stats(msg)
|
function update_user_stats(msg)
|
||||||
-- Save user to _users table
|
-- Save user to stats table
|
||||||
local from_id = tostring(msg.from.id)
|
local from_id = tostring(msg.from.id)
|
||||||
local to_id = tostring(msg.to.id)
|
local to_id = tostring(msg.to.id)
|
||||||
local user_name = get_name(msg)
|
local user_name = get_name(msg)
|
||||||
@ -7,54 +16,53 @@ function update_user_stats(msg)
|
|||||||
-- If last name is nil dont save last_name.
|
-- If last name is nil dont save last_name.
|
||||||
local user_last_name = msg.from.last_name
|
local user_last_name = msg.from.last_name
|
||||||
local user_print_name = msg.from.print_name
|
local user_print_name = msg.from.print_name
|
||||||
if _users[to_id] == nil then
|
if _stats[to_id] == nil then
|
||||||
_users[to_id] = {}
|
print ('New stats key to_id: '..to_id)
|
||||||
|
_stats[to_id] = {}
|
||||||
end
|
end
|
||||||
if _users[to_id][from_id] == nil then
|
if _stats[to_id][from_id] == nil then
|
||||||
_users[to_id][from_id] = {
|
print ('New stats key from_id: '..to_id)
|
||||||
|
_stats[to_id][from_id] = {
|
||||||
name = user_name,
|
name = user_name,
|
||||||
last_name = user_last_name,
|
last_name = user_last_name,
|
||||||
print_name = user_print_name,
|
print_name = user_print_name,
|
||||||
msg_num = 1
|
msg_num = 1
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
local actual_num = _users[to_id][from_id].msg_num
|
print ('Updated '..to_id..' '..from_id)
|
||||||
_users[to_id][from_id].msg_num = actual_num + 1
|
local actual_num = _stats[to_id][from_id].msg_num
|
||||||
|
_stats[to_id][from_id].msg_num = actual_num + 1
|
||||||
-- And update last_name
|
-- And update last_name
|
||||||
_users[to_id][from_id].last_name = user_last_name
|
_stats[to_id][from_id].last_name = user_last_name
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function load_user_stats()
|
function read_file_stats( )
|
||||||
local f = io.open('res/users.json', "r+")
|
local f = io.open(_file_stats, "r+")
|
||||||
-- If file doesn't exists
|
-- If file doesn't exists
|
||||||
if f == nil then
|
if f == nil then
|
||||||
f = io.open('res/users.json', "w+")
|
-- Create a new empty table
|
||||||
f:write("{}") -- Write empty table
|
print ('Created user stats file '.._file_stats)
|
||||||
f:close()
|
serialize_to_file({}, _file_stats)
|
||||||
return {}
|
|
||||||
else
|
else
|
||||||
local c = f:read "*a"
|
print ('Stats loaded: '.._file_stats)
|
||||||
f:close()
|
f:close()
|
||||||
return json:decode(c)
|
|
||||||
end
|
end
|
||||||
|
return loadfile (_file_stats)()
|
||||||
end
|
end
|
||||||
|
|
||||||
function save_stats()
|
|
||||||
|
local function save_stats()
|
||||||
-- Save stats to file
|
-- Save stats to file
|
||||||
local json_users = json:encode_pretty(_users)
|
serialize_to_file(_stats, _file_stats)
|
||||||
vardump(json_users)
|
|
||||||
file_users = io.open ("./res/users.json", "w")
|
|
||||||
file_users:write(json_users)
|
|
||||||
file_users:close()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function get_stats_status( msg )
|
local function get_stats_status( msg )
|
||||||
-- vardump(_users)
|
-- vardump(stats)
|
||||||
local text = ""
|
local text = ""
|
||||||
local to_id = tostring(msg.to.id)
|
local to_id = tostring(msg.to.id)
|
||||||
|
|
||||||
for id, user in pairs(_users[to_id]) do
|
for id, user in pairs(_stats[to_id]) do
|
||||||
if user.last_name == nil then
|
if user.last_name == nil then
|
||||||
text = text..user.name.." ["..id.."]: "..user.msg_num.."\n"
|
text = text..user.name.." ["..id.."]: "..user.msg_num.."\n"
|
||||||
else
|
else
|
||||||
@ -65,25 +73,28 @@ function get_stats_status( msg )
|
|||||||
return text
|
return text
|
||||||
end
|
end
|
||||||
|
|
||||||
function run(msg, matches)
|
local function run(msg, matches)
|
||||||
-- TODO: I need to know wich patterns matches.
|
if matches[1] == "stats" then -- Hack
|
||||||
if matches[1] == "!stats" then
|
return get_stats_status(msg)
|
||||||
return get_stats_status(msg)
|
|
||||||
else
|
else
|
||||||
print ("update stats")
|
print ("update stats")
|
||||||
update_user_stats(msg)
|
update_user_stats(msg)
|
||||||
|
print(socket.gettime())
|
||||||
|
save_stats()
|
||||||
|
print(socket.gettime())
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- TODO: local vars
|
_stats = read_file_stats()
|
||||||
_users = load_user_stats()
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
description = "Numer of messages by user",
|
description = "Numer of messages by user",
|
||||||
usage = "!stats",
|
usage = "!stats",
|
||||||
patterns = {
|
patterns = {
|
||||||
".*",
|
".*",
|
||||||
"^!stats"
|
"^!(stats)"
|
||||||
},
|
},
|
||||||
run = run
|
run = run
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end
|
Reference in New Issue
Block a user