Merge pull request from DonBatman/master

Some changes
I personally wouldn't have added the print statements, but that's okay, it only shows in a log anyway.
This commit is contained in:
Nathan Salapat 2016-04-22 15:41:56 -05:00
commit bda99cb9b2
2 changed files with 45 additions and 33 deletions

@ -1,16 +1,18 @@
kickafk = {} kickafk = {}
players = {} players = {}
CPU_saver = 0 local CPU_saver = 0
kickafk.version = "1.0" kickafk.version = "1.0"
kickafk.path = minetest.get_modpath(minetest.get_current_modname())
kickafk.first_flag = 0 kickafk.first_flag = 0
kickafk.players = tonumber(minetest.setting_get('kickafk_number_of_players')) or 0 local modpath = minetest.get_modpath("kickafk")
kickafk.players = tonumber(minetest.setting_get("kickafk_number_of_players")) or 10
if kickafk.players < 0 or kickafk.players > 30 then if kickafk.players < 0 or kickafk.players > 30 then
kickafk.players = 15 kickafk.players = 15
end end
kickafk.timer = tonumber(minetest.setting_get('kickafk_length_of_time')) or 0
kickafk.timer = tonumber(minetest.setting_get('kickafk_length_of_time')) or 2000
if kickafk.timer < 0 or kickafk.timer > 1500 then if kickafk.timer < 0 or kickafk.timer > 1500 then
kickafk.timer = 1500 kickafk.timer = 1500
end end
@ -27,32 +29,42 @@ minetest.register_privilege("canafk",
"Player can remain afk without being kicked") "Player can remain afk without being kicked")
minetest.register_globalstep(function(dtime) minetest.register_globalstep(function(dtime)
-- No reason to constantly be checking for players online.
-- This function triggers the main function every ten-ish minutes. CPU_saver = CPU_saver + dtime
CPU_saver = CPU_saver + 1
if CPU_saver >= kickafk.timer then if CPU_saver < kickafk.timer then
return
end
CPU_saver = 0 CPU_saver = 0
players_online = 0
local players_online = 0
-- Loop through all connected players -- Loop through all connected players
for _,player in ipairs(minetest.get_connected_players()) do for _,player in ipairs(minetest.get_connected_players()) do
local player_name = player:get_player_name() local player_name = player:get_player_name()
-- Only continue if the player has an entry in the players table -- Only continue if the player has an entry in the players table
if players[player_name] then if players[player_name] then
print(players[player_name].last_pos)
players_online = players_online + 1 players_online = players_online + 1
if players_online >= kickafk.players then if players_online >= kickafk.players then
print("number of players is "..players_online)
-- Kick the player if their location hasn't changed. -- Kick the player if their location hasn't changed.
local pos = player:getpos() local pos = player:getpos()
local pos_hash = math.floor(pos.x) .. ':' .. math.floor(pos.z) local pos_hash = math.floor(pos.x) .. ',' .. math.floor(pos.z)
if players[player_name]["last_pos"] == pos_hash then
if minetest.check_player_privs(player_name, {canafk=false}) then if players[player_name].last_pos == pos_hash then
minetest.kick_player(player_name, "Network Timeout") if not minetest.check_player_privs(player_name,"canafk") == true then
minetest.kick_player(player_name, "Disconnected due to inactivity!")
end end
end end
-- Record the players location -- Record the players location
if players[player_name]["last_pos"] ~= pos_hash then if players[player_name].last_pos ~= pos_hash then
players[player_name]["last_pos"] = pos_hash players[player_name].last_pos = pos_hash
end
end end
end end
end end

@ -3,5 +3,5 @@
kickafk_number_of_players (Number of players) int 10 kickafk_number_of_players (Number of players) int 10
# How often to check for AFK players. # How often to check for AFK players.
# This is in server ticks, not seconds. # This is in seconds.
kickafk_length_of_time (How ofen to run) int 2000 kickafk_length_of_time (How ofen to run) int 2000