From 18ef8da8eddae2389a6041bdb838aab4d8f4160b Mon Sep 17 00:00:00 2001 From: mckaygerhard Date: Mon, 1 Apr 2024 00:17:38 -0400 Subject: [PATCH] mods - governing - updated adminisntration tool * detection of dragonfire moved to respective modules * reorganize code, minimize callbacks invokations * implements the beowulf anticheat client detection and improve it * featured antispawn by appgurueu * implement basic anticheat and admin commands : anticheat + beowulf + fairplay * LICENSED under CC-BY-SA-NC 4.0 by mckaygerhard and mckayshiroy --- .../{anticracker.lua => administration.lua} | 178 +++++++++-- mods/governing/anticheats.lua | 283 +----------------- mods/governing/geoip.lua | 145 --------- mods/governing/init.lua | 32 +- mods/governing/process.lua | 121 ++++++++ 5 files changed, 279 insertions(+), 480 deletions(-) rename mods/governing/{anticracker.lua => administration.lua} (68%) delete mode 100644 mods/governing/geoip.lua create mode 100644 mods/governing/process.lua diff --git a/mods/governing/anticracker.lua b/mods/governing/administration.lua similarity index 68% rename from mods/governing/anticracker.lua rename to mods/governing/administration.lua index dd3e927..042705a 100644 --- a/mods/governing/anticracker.lua +++ b/mods/governing/administration.lua @@ -1,8 +1,36 @@ --- taken from https://github.com/S-S-X/dftest/blob/master/init.lua -local has_beerchat = minetest.get_modpath("beerchat") +-- mod governor by mckaygerhard, administration specific code +-- Copyright 2023 --- luacheck: push no max line length -local df = { +---------------------------------------------------------------------------- +-- this program can be used free but cannot be used commertially or +-- modified for, licenced CC-BY-SA-NC 4.0 unless explicit permission + +-- This program is distributed in the hope that it will be useful, +-- but WITHOUT ANY WARRANTY; without even the implied warranty of +-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +---------------------------------------------------------------------------- + +--[[ init privileges registrations ]] + +minetest.register_privilege("governing", { + description = "can do geoip lookups on players for governing", + give_to_singleplayer = false +}) + +if not governing.modgeoip then + minetest.register_privilege("geoip", { + description = "governing: ip checks + lookups on players", + give_to_singleplayer = false + }) +end + +--[[ end privileges registrations ]] + + + +gapi.extraversion = { + "2.0.4", -- multicraft "dragonfire", -- many based clients by example teamclient "f8fd5c11b", -- Merge pull request #59 from PrairieAstronomer/readme_irrlicht_change "c66ae6717", -- Add exact irrlichtmt version to the clone command @@ -205,46 +233,136 @@ local df = { --[[ To update commit list: save commit logs for master branches of minetest in mt.log and dragonfire in df.log -For example (assuming you have added dragonfire remote, adapt if not): -$ git log --oneline origin/master > mt.log; git log --oneline dragonfire/master > df.log +$ git log --oneline origin/master > mt.log; git log --oneline dragonfire/master > df.log (both in same remo using git remote) Find and drop commits that seems to exist in both remotes, print rest of it: $ sort -k3 <(awk '{print NR" "$0}' df.log mt.log mt.log) | uniq -uf2 | sort -nk1 | sed -r 's/^[^ ]+ ([^ ]+) (.*)$/\t"\1", -- \2/' Replace above entries with output --]] --- luacheck: pop -local function dfver(s) - -- loop into table of commmits and find the compared version - for _,v in ipairs(df) do - if string.find(v) then - return v +function gapi.isdf(stringversion) + for _,ev in ipairs(gapi.extraversion) do + local pp = stringversion:find(ev) + if pp then + return ev -- loop into table of commmits and find the compared version string if are a devel buil, or just compare the version string end end end -minetest.register_on_joinplayer(function(player) - local name = player:get_player_name() - local info = minetest.get_player_information(name) - local version = info.version_string - if not version then - -- version not available - return + +function gapi.is_player(player) + + return (type(player) == "userdata" or type(player) == "table") -- check player for real, a player is also a datatable + +end + + +function governing.is_creative(name) + if creative then + return creative.is_creative(name) + else + return minetest.check_player_privs(name, {creative = true}) or creative_mode_cache end +end - local dfv = dfver(version) - if dfv then - local msg = "Unsupported client detected: " .. dfv .. " player: " .. name - minetest.log("action", "[beowulf] " .. msg) - if has_beerchat then - beerchat.send_on_channel("DF-Detect", beerchat.moderator_channel_name, msg) + +function gapi.format_result_geoip(result) + local txt = " Place: " + if result then + if result.status == "success" and result.data and result.data.geo then + if result.data.geo.ip then + if result.data.geo.ip == "127.0.0.1" then return txt .. " seems localhost " ..".. <_< ." end + end + if result.data.geo.continent_name then + if result.data.geo.continent_name ~= "" then txt = txt .. result.data.geo.continent_name .."," end + end + if result.data.geo.country_name then + if result.data.geo.country_name ~= "" then txt = txt .. result.data.geo.country_name .."," end + end + if result.data.geo.region_name then + if result.data.geo.region_name ~= "" then txt = txt .. result.data.geo.region_name .. "," end + end + if result.data.geo.city then + if result.data.geo.city ~= "" then txt = txt .. result.data.geo.city .."" end + end + if result.data.geo.timezone then + if result.data.geo.timezone ~= "" then txt = txt .. " Timezone: " .. result.data.geo.timezone end + end + if result.data.geo.asn then + if result.data.geo.asn ~= "" then txt = txt .. " ASN: " .. result.data.geo.asn end + end + if result.data.geo.isp then + if result.data.geo.isp ~= "" then txt = txt .. " ISP: " .. result.data.geo.isp end + end + if result.data.geo.ip then + if result.data.geo.ip ~= "" then txt = txt .. " IP: " .. result.data.geo.ip end + end + return txt + else + return false end - --- if minetest.settings:get_bool("beowulf.dfdetect.enable_kick", false) then --- minetest.kick_player(name, "Unsupported client") --- end + else + return false end +end + + +function gapi.format_result_checkip(result) + local txt = " Place: " + local flg = "" + if result then + if result.message then + return result.message .. ".. <_< . if no key, use /geoip command" + end + if result.security then + if result.security.vpn then + if result.security.vpn ~= "true" then flg = flg .. "+VPN" end + end + if result.security.proxy then + if result.security.proxy ~= "true" then flg = flg .. "+PRX" end + end + if result.security.tor then + if result.security.tor ~= "true" then flg = flg .. "+TOR" end + end + if result.security.relay then + if result.security.tor ~= "true" then flg = flg .. "+REL" end + end + end + if result.location then + if result.location then + if result.location.continent ~= "" then txt = txt .. result.location.continent_name .."," end + end + if result.location.country then + if result.location.country ~= "" then txt = txt .. result.location.country .."," end + end + if result.location.region then + if result.location.region ~= "" then txt = txt .. result.location.region .. "," end + end + if result.location.city then + if result.location.city ~= "" then txt = txt .. result.location.city .." " end + end + if result.location.time_zone then + if result.location.time_zone ~= "" then txt = txt .. "Timezone: " .. result.location.time_zone end + end + end + if result.network then + if result.network.autonomous_system_number then + if result.network.autonomous_system_number ~= "" then txt = txt .. " ASN: " .. result.network.autonomous_system_number end + end + if result.network.autonomous_system_organization then + if result.network.autonomous_system_organization ~= "" then txt = txt .. " ISP: " .. result.network.autonomous_system_organization end + end + end + if result.ip then + if result.ip ~= "" then txt = txt .. " IP: " .. result.ip end + end + return flg .. txt + else + return false + end +end + +governing.joinplayer_callback = function(playername, result)end -end) diff --git a/mods/governing/anticheats.lua b/mods/governing/anticheats.lua index cfbc0d3..89c5a2e 100644 --- a/mods/governing/anticheats.lua +++ b/mods/governing/anticheats.lua @@ -73,233 +73,6 @@ local function track_player(player) data.pre_pos = pos end ------------------------------------------------------------------------ --- ANTI CRACKERS and CHEATERS by mckaygerhard based on beowulf ------------------------------------------------------------------------- - --- luacheck: push no max line length -local df = { - "2.0", - "dragonfire", -- many based clients by example teamclient - "f8fd5c11b", -- Merge pull request #59 from PrairieAstronomer/readme_irrlicht_change - "c66ae6717", -- Add exact irrlichtmt version to the clone command - "296cce39d", -- Fix upstream merge issues - "350b6d175", -- Install lua_async dependency - "393c83928", -- Don't include client/game.h on server build - "ccd4c504d", -- Ship dragonfireclient with selected high-quality mods - "147aaf326", -- Fix build instructions - "b09fc5de5", -- Add spider - "d404517d2", -- Make LuaVoxelManipulator available to CSM API - "1ccf88e80", -- minetest.dig_node: Remove node - "950d2c9b3", -- Add ClientObjectRef:remove and return true in on_object_add callback to remove newly added object - "fb4815c66", -- Merge pull request #35 from arydevy/patch-1 - "f12288814", -- Merge pull request #42 from Minetest-j45/master - "f3082146c", -- remove irrlicht from lid dir (accident) - "a3925db22", -- add airjump and remove unused headers - "7824a4956", -- Merge pull request #1 from EliasFleckenstein03/master - "35445d24f", -- Make set_pitch and set_yaw more accurate by not rounding it to integers - "5131675a6", -- Add guards to stop server build fail - "96a37aed3", -- Add minetest.get_send_speed - "d08242316", -- Fix format - "ce0d81a82", -- Change default cheat menu entry height - "b7abc8df2", -- Add on_object_add callback - "4f613bbf5", -- Include tile definitions in get_node_def; Client-side minetest.object_refs table - "c86dcd0f6", -- Add on_object_hp_change callback and nametag images - "b84ed7d0b", -- Call on_object_properties_change callback when adding object to scene - "26cfbda65", -- Add on_object_properties_change callback - "6dc7a65d9", -- Add ClientObjectRef:set_properties - "7d7d4d675", -- Add ClientObjectRef.get_properties - "ea8fa30b6", -- Changed README.md to fit the dragonfire client - "c47eae316", -- Add table.combine to luacheckrc - "83d09ffaf", -- Complete documentation - "e0b4859e7", -- Add ClientObjectRef:remove - "63f7c96ec", -- Fix legit_speed - "5c06763e8", -- Add noise to client CSM API - "7613d9bfe", -- Update .wielded command to output the entire itemstring; add LocalPlayer:get_hotbar_size - "bc79c2344", -- CSM: Use server-like (and safe) HTTP API instead of Mainmenu-like - "166968232", -- Port formspec API from waspsaliva This API is inofficial and undocumented; invalid usage causes the game to crash. Use at own risk! - "e391ee435", -- Forcefully place items when minetest.place_node is used - "546ab256b", -- Update buildbot to new MineClone2 repo and set the game name to MineClone2 rather than mineclone2 - "d3780cefd", -- Attempt to fix SEGFAULT in push_inventory - "d1c84ada2", -- Merge minetest changes - "74f5f033e", -- Add Custom version string - "b2f629d8d", -- Logo improvements - "78b7d1019", -- Add dragonfire logo - "19e0528e3", -- Add minetest.get_nearby_objects - "47d0882cc", -- Fix line containing only whitespace - "4fedc3a31", -- Add minetest.interact - "dc67f669e", -- Make the Cheat Menu size configureable - "906845a87", -- Add minetest.registered_items and minetest.registered_nodes (Doesn't do anything yet) - "3a4325902", -- Fixed crash by adding legacy stuff to defaultsettings (for now) - "53c991c5f", -- Fixed crash due to missing entry in defaultsettings.cpp - "0c6e0c717", -- Reorganize categories - "e8faa2afb", -- Rework Range - "a4d914ba2", -- Make GitHub Actions Happy try 3 - "a34c61093", -- Make GitHub Actions Happy try 2 - "f783f5939", -- Make GitHub Actions Happy try 1 - "8b58465aa", -- Remove obsolete code from clientenvironment - "35c15567a", -- Update builtin/settingtypes.txt to the new philosophy - "0c9e7466e", -- New Cheat Philosophy - "a1e61e561", -- World Cheats improvements; Add BlockLava; Readd minetest.request_http_api for Compatibility - "56d536ea5", -- Update CheatDB URL again - "ce47003cc", -- Update defaults for ContentDB (->CheatDB) - "89995efee", -- CheatDB Support & Enable/Disable CSMs in Main Menu - "3df23e23c", -- Small AutoTool Fix - "8b3eaf5b0", -- Lua API: Particle callbacks; Add NoWeather - "0a285dd33", -- Remove NextItem - "4695222bc", -- Fix and Improve AutoTool - "5bead7daa", -- Added minetest.close_formspec - "f825cf0e3", -- Fixed Minimap position - "eaa8a5132", -- Fixed FastPlace and AutoPlace - "b4e475726", -- Added configureable Colors for PlayerESP and EntityESP - "549025f6a", -- EntityESP, EntityTracers, PlayerESP, PlayerTracers - "eb6aca8b4", -- Merged Minetest - "8de51dae9", -- Fixed crash when attempting to access nonexistant inventory from Lua API - "a65251a7a", -- Fixed glowing GenericCAOs being rendered completely back when Fullbright is enabled - "eaec3645b", -- Added ClientObjectRef:get_hp() - "fb4d54ee3", -- Added minetest.register_on_play_sound - "50629cc6a", -- Improved Scaffold - "3d74e17cc", -- Added AutoSlip (-> Credit to Code-Sploit) - "f9c632466", -- Added JetPack and AutoHit (-> Credits to Code-Sploit and cora) - "843239c0b", -- Added Speed/Jump/Gravity Override - "598e9bdbc", -- Update Credits - "7d327def8", -- Improved AutoSneak - "82216e147", -- LocalPlayer:set_physics_override; minetest.register_on_recieve_physics_override - "4dd5ecfc5", -- Added setpitch & setyaw commands; AutoSprint - "b65db98bd", -- Added OnlyTracePlayers - "e16bbc1fb", -- Merge pull request #14 from corarona/master - "1780adeea", -- lua-api: fix get/set_pitch - "3e7c5d720", -- Possibility to use cheat menu while pressing other keys - "0aa63aafc", -- Fixed warning - "9db80fc6f", -- Run Lint Script - "91ad0d049", -- Merge pull request #10 from corarona/master - "6bda686c0", -- MapBlockMesh Performance Improvement - "1bab49049", -- add LUA_FCT - "6efa8a758", -- add g/s pitch and make_screenshot in lua api - "46237330d", -- Several Enhancements - "60a9ff6ff", -- api-screenshot: change function name to make_screenshot - "1f56317d5", -- Added NodeESP - "75ecaa217", -- Fix and run the Lint autocorrect script - "6ccb5835f", -- Revert "Make Lint Happy" - "244713971", -- Added script that automaticall corrects lint style - "07e61e115", -- Fix github build problems #3 - "3af10766f", -- Fix github build problems #2 - "16d302c9a", -- Fix github build problems - "ad148587d", -- Make Lint Happy - "1145b05ea", -- Updated Credits - "c9221730d", -- Updated Cheat Menu Color Design - "1799d5aa9", -- Cheat Menu Improvements Change - "fba7dc216", -- Merge pull request #8 from realOneplustwo/master - "a7dc1135e", -- Added CheatHUD - "f1d9ac014", -- Moved Killaura to Lua; Added ForceField; Added Friendlist; Added ClientObjectRef:is_local_player(); Documented LocalPlayer:get_object() - "06b72069d", -- Fixed ColorChat - "62958bd60", -- Reverted accidental commit in wrong repo - "00d51fbd5", -- Armor textures support - "7cbe42b1d", -- Re-Added Chat Effects - "28f6a7970", -- lua api: add set/get_pitch - "4f9797b6e", -- lua api: add core.take_screenshot() - "8e9e76a50", -- Revert "Add Block Formspec Hack" - "6652d7ac2", -- Add Block Formspec Hack - "8bc7d49b3", -- Added Nuke - "62cf9b466", -- Fix compile error - "519f98c65", -- Merge pull request #3 from JosiahWI/ui_revamp - "f236476af", -- Fix errors in cheatMenu. - "7af3dee31", -- Merge pull request #2 from JosiahWI/ui_revamp - "ea88dde4b", -- Added Strip, AutoRefill, indexing for InventoryActions and Wield Index starts at 1 now - "7aff09ab2", -- Fix overindent! - "aea9b36ef", -- Improved Colours - "1ef72ad9c", -- Fix indentation style. - "586241008", -- Add missing return. - "b211e90ff", -- Prepare cheatMenu::draw function for easier UI changes. - "e22e334e9", -- Merge pull request #1 from JosiahWI/ui_revamp - "f605308ee", -- Improve drawEntry. - "130d476f6", -- Changed Cheat Menu UI - "f1ff05bf5", -- Added ThroughWalls, InventoryActions API and AutoTotem - "1a7d3d818", -- Extended ClientObjectRef; Improved CrystalPvP - "1e4f35492", -- This is the last try for lint... - "7e0f8fba0", -- Another Lint commit - "151e5782e", -- Lint is still not happy... - "28a560684", -- Added the API additions from waspsaliva - "c1aea404b", -- Lint is bitch - "3a718f12b", -- Make lint happy; Remove stupid redirector - "3b596a96e", -- Fixed Github build problems - "847198edb", -- Edited .gitignore properly; fixed armor invulnarability in the server code. - "bbcd24954", -- New Mod System - "80f416d51", -- Added AttachmentFloat - "cb1915efa", -- Added minetest.drop_selected_item(), Improved AutoEject - "43ee069db", -- Improved X-Ray, added AutoEject - "faa32610e", -- Added ESP, fixed Tracers, improved Jesus - "ee88f4b94", -- Improved Tracers - "c36ff3edb", -- Added AutoSneak and improved X-Ray MapBlock updating - "0a2c90f4c", -- Only draw tracers to objects that are not attached (that fixes tracers to armor) - "044a12666", -- Added Tracers, NoSlow and NoForceRotate; GUI Colors changed - "b9f8f0a23", -- The Robot Update - "af085acbd", -- Added Schematicas - "0730ed216", -- Delete my stupid test mod lol - "772c9629e", -- Unrestricted HTTP API for Client, Server and Main Menu - "9b1030cac", -- Added minetest.get_inventory(location) - "2321e3da4", -- Removed console output spammed by minetest.find_node_near - "90f66dad8", -- Removed experimental code - "8b4d27141", -- Fixed typo in clientmods/inventory/mod.conf - "d8b8c1d31", -- Added Documentation for Additional API - "6e6c68ba0", -- Added Chat Spam, Replace and settingtypes.txt for Clientmods - "79d0314d7", -- Update Buildbots - "770bde9c6", -- idk - "e245151c5", -- Improved World hacks - "19205f6b3", -- Improved World Hacks, added API functions - "73b89703f", -- Improved World hacks, added fill - "248dedaba", -- Added floationg water to BlockWater - "9dc3eb777", -- Fixed broken Chatcommands - "80371bc16", -- Added .listwarps - "1c29f21e0", -- Imporoved set_wield_index() to include camera update - "3bed0981d", -- UI Update; Added AutoTool - "622d54726", -- Added DestroyWater (:P anon) - "9019e18b9", -- Some Updates - "107dec6c0", -- Added Coords - "f1760622e", -- Added BrightNight - "2675bcca1", -- Added more cheats - "3d980cf57", -- Improved Xray and Fullbright - "f7a042223", -- Added cheat Menu - "344fddc17", -- Improved Killaura and Chat position - "678559bb6", -- removed leagcy clientmods - "9194165cf", -- Added autodig, moved chat - "064c25caa", -- Added EntitySpeed - "5a8610c2f", -- Added customizable keybindings, improved freecam, added special inventory keybind (by default ender inventory) - "83f59484d", -- Fixed 5.4.0-dev build - "ffe3c2ae0", -- Update to minetest 5.4.0-dev - "45aa2516b", -- Added settings - "f22339ed8", -- Removed fast killaura - "408e39a1d", -- Added Anti Knockback - "eee0f960b", -- Removed minetest.conf.old - "39d7567c1", -- Fixed Crash - "305e0e0d3", -- Auto disable smooth lighting when fullbright is active - "6796baec6", -- Defaultsettings - "5a2bf6634", -- Added Clientmods - "e610149c0", -- Initial Commit - "68f9263a2", -- Hacked Client - "90d885506", -- GalwayGirl Client -} - ---[[ -To update commit list: save commit logs for master branches of minetest in mt.log and dragonfire in df.log -$ git log --oneline origin/master > mt.log; git log --oneline dragonfire/master > df.log (both in same remo using git remote) - -Find and drop commits that seems to exist in both remotes, print rest of it: -$ sort -k3 <(awk '{print NR" "$0}' df.log mt.log mt.log) | uniq -uf2 | sort -nk1 | sed -r 's/^[^ ]+ ([^ ]+) (.*)$/\t"\1", -- \2/' - -Replace above entries with output ---]] - -local function dfver(stringversion) - -- loop into table of commmits and find the compared version - for _,v in ipairs(df) do - local pp = stringversion:find(v) - if pp then - return v - end - end -end - ------------------------------------------------------------------------- -- ANTI CHEAT for MT4 and old MT5 engines by rnd -- Copyright 2016 rnd LGPL v3 @@ -666,7 +439,6 @@ minetest.register_on_joinplayer(function(player) -- =================================== local ip = tostring(minetest.get_player_ip(name)); - local info = minetest.get_player_information(name) local msgiplevelone = ""; local msgipleveltwo = ""; @@ -690,58 +462,12 @@ minetest.register_on_joinplayer(function(player) end) end - -- rare case / simple sanity check, _should_ not happen ;) pretty rare but modified client that does not give info - if not info then - if not is_player(player) then - name = name .. " is a bot confirmed, also" - end - msgipleveltwo = "[governing] can't retrieve info, player '" .. name .. "' disappeared or seems craker" - minetest.after(2, function() - for namemd,_ in pairs(cheat.moderators) do - minetest.chat_send_player(namemd,msgipleveltwo); - end - end) - minetest.log("warning", msgipleveltwo) - return - end - - -- prepare information report log, "version_string" is only available if the engine was compiled in debug mode (or patched accordingly) - local msgipleveltwo = "[governing] player '" .. name .. "' joined" .. - " from:" .. info.address .. - " protocol_version:" .. (info.protocol_version or "20?") .. - " formspec_version:" .. (info.formspec_version or "old") .. - " lang_code:" .. (info.lang_code or "") .. - " serialization_version:" .. (info.serialization_version or "20?") .. - " version_string:" .. (info.version_string or "not supported") - minetest.log("action", msgipleveltwo) - - local msgm = "#anticheat detected a cheater with ".. tostring(minetest.get_player_ip(name)).." named "..name - if info.version_string then - local dfv = dfver(info.version_string) - if dfv then - minetest.after(3, function() - minetest.chat_send_player(name, msgiplevelone); - if minetest.settings:get_bool("beowulf.dfdetect.enable_kick", false) then - minetest.kick_player(name, "Are you a cheater stupid user? change your cracked client for play") - end - for namemd,_ in pairs(cheat.moderators) do - minetest.chat_send_player(namemd,msgm); -- advertise moderators - end - end) - minetest.log(msgm) - end - else - for namemd,_ in pairs(cheat.moderators) do - minetest.chat_send_player(namemd,msgm); -- advertise moderators - end - minetest.log(msgm) - end - end) minetest.register_chatcommand("cchk", { privs = { - interact = true + interact = true, + server = true }, description = "cchk NAME, checks if player is cheating in this moment", func = function(name, param) @@ -756,7 +482,7 @@ minetest.register_chatcommand("cchk", { local info = minetest.get_player_information(param) local msgm = "#anticheat detected a cheater with "..ip.." named "..param if info.version_string then - local dfv = dfver(info.version_string) + local dfv = gapi.isdf(info.version_string) if dfv then msgm = msgm.." using "..info.version_string minetest.chat_send_player(param, "..... cheat"); @@ -768,6 +494,9 @@ minetest.register_chatcommand("cchk", { minetest.chat_send_player(namemd,msgm); -- advertise moderators end minetest.log(msgm) + else + msgm = "Still just suspicius for "..param.." at "..ip.." using "..info.version_string + minetest.chat_send_player(name,msgm); -- advertise command executor end else for namemd,_ in pairs(cheat.moderators) do diff --git a/mods/governing/geoip.lua b/mods/governing/geoip.lua deleted file mode 100644 index d982fc1..0000000 --- a/mods/governing/geoip.lua +++ /dev/null @@ -1,145 +0,0 @@ --- mod governor by mckaygerhard, geoip specific code --- Copyright 2023 - ----------------------------------------------------------------------------- --- this program can be used free but cannot be used commertially or --- modified for, licenced CC-BY-SA-NC 4.0 unless explicit permission - --- This program is distributed in the hope that it will be useful, --- but WITHOUT ANY WARRANTY; without even the implied warranty of --- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - ----------------------------------------------------------------------------- - - -function format_result_geoip(result) - local txt = " Place: " - if result then - if result.status == "success" and result.data and result.data.geo then - if result.data.geo.ip then - if result.data.geo.ip == "127.0.0.1" then return txt .. " seems localhost " ..".. <_< ." end - end - if result.data.geo.continent_name then - if result.data.geo.continent_name ~= "" then txt = txt .. result.data.geo.continent_name .."," end - end - if result.data.geo.country_name then - if result.data.geo.country_name ~= "" then txt = txt .. result.data.geo.country_name .."," end - end - if result.data.geo.region_name then - if result.data.geo.region_name ~= "" then txt = txt .. result.data.geo.region_name .. "," end - end - if result.data.geo.city then - if result.data.geo.city ~= "" then txt = txt .. result.data.geo.city .."" end - end - if result.data.geo.timezone then - if result.data.geo.timezone ~= "" then txt = txt .. " Timezone: " .. result.data.geo.timezone end - end - if result.data.geo.asn then - if result.data.geo.asn ~= "" then txt = txt .. " ASN: " .. result.data.geo.asn end - end - if result.data.geo.isp then - if result.data.geo.isp ~= "" then txt = txt .. " ISP: " .. result.data.geo.isp end - end - if result.data.geo.ip then - if result.data.geo.ip ~= "" then txt = txt .. " IP: " .. result.data.geo.ip end - end - return txt - else - return false - end - else - return false - end -end - -function format_result_checkip(result) - local txt = " Place: " - local flg = "" - if result then - if result.message then - return result.message .. ".. <_< . if no key, use /geoip command" - end - if result.security then - if result.security.vpn then - if result.security.vpn ~= "true" then flg = flg .. "+VPN" end - end - if result.security.proxy then - if result.security.proxy ~= "true" then flg = flg .. "+PRX" end - end - if result.security.tor then - if result.security.tor ~= "true" then flg = flg .. "+TOR" end - end - if result.security.relay then - if result.security.tor ~= "true" then flg = flg .. "+REL" end - end - end - if result.location then - if result.location then - if result.location.continent ~= "" then txt = txt .. result.location.continent_name .."," end - end - if result.location.country then - if result.location.country ~= "" then txt = txt .. result.location.country .."," end - end - if result.location.region then - if result.location.region ~= "" then txt = txt .. result.location.region .. "," end - end - if result.location.city then - if result.location.city ~= "" then txt = txt .. result.location.city .." " end - end - if result.location.time_zone then - if result.location.time_zone ~= "" then txt = txt .. "Timezone: " .. result.location.time_zone end - end - end - if result.network then - if result.network.autonomous_system_number then - if result.network.autonomous_system_number ~= "" then txt = txt .. " ASN: " .. result.network.autonomous_system_number end - end - if result.network.autonomous_system_organization then - if result.network.autonomous_system_organization ~= "" then txt = txt .. " ISP: " .. result.network.autonomous_system_organization end - end - end - if result.ip then - if result.ip ~= "" then txt = txt .. " IP: " .. result.ip end - end - return flg .. txt - else - return false - end -end - - -governing.joinplayer_callback = function() end -- function(name, result) - - ---[[ init of call back on join of a player, ]] -minetest.register_on_joinplayer(function(player) -- query ip on join, record in logs and execute callback - if not player then return end - if not player:is_player() then return end - if not minetest.get_player_ip then return end - local name = player:get_player_name() - local ip = minetest.get_player_ip(name) - if not ip then return end - -- do log ip check: if not apikey then geoip from mod; if not mod then our own geoip - if governing.checkapikey ~= "" then - governing.checkip(ip, function(data) -- log, but TODO: record in storage log file - local txt = format_result_checkip(data) - if txt then minetest.log("warning", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. "," .. txt) - else minetest.log("error", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. ", seems fails") - end - governing.joinplayer_callback(name, data) -- execute callback - end) - else - if not governing.modgeoip then - governing.lookup(ip, function(data) -- log, but TODO: record in storage log file - local txt = format_result_checkip(data) - if txt then minetest.log("warning", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. "," .. txt) - else minetest.log("error", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. ", seems fails") - end - governing.joinplayer_callback(name, data) -- execute callback - end) - end - end -end) ---[[ end of call back on join of a player, ]] - - diff --git a/mods/governing/init.lua b/mods/governing/init.lua index 6b534b4..1e90697 100644 --- a/mods/governing/init.lua +++ b/mods/governing/init.lua @@ -76,6 +76,7 @@ end --[[ init - namespace of the mod and varible usages ]] +gapi = {} governing = {} governing.is_46 = is_46 -- detect minetest engine 4.0.16 or mayor @@ -106,33 +107,6 @@ governing.checkapikey = checkapikey -- need for geoip improved ip information, t - ---[[ init privileges registrations ]] - -function governing.is_creative(name) - if creative then - return creative.is_creative(name) - else - return minetest.check_player_privs(name, {creative = true}) or creative_mode_cache - end -end - -minetest.register_privilege("governing", { - description = "can do geoip lookups on players for governing", - give_to_singleplayer = false -}) - -if not governing.modgeoip then - minetest.register_privilege("geoip", { - description = "governing: ip checks + lookups on players", - give_to_singleplayer = false - }) -end - ---[[ end privileges registrations ]] - - - --[[ init http calls, must be only on main ]] function governing.lookup(ip, callback) @@ -181,7 +155,7 @@ end --[[ include code files mod features ]] -dofile(governing.modpath.."/geoip.lua") -- format the geoip responses managed by "callback(data)" +dofile(governing.modpath.."/administration.lua") -- more of commonformats dofile(governing.modpath.."/anticheats.lua") -- load anticheat mod that combined rnd + beowulf + fairplay @@ -189,6 +163,8 @@ dofile(governing.modpath.."/antispawn.lua") -- load antispawn chat features only dofile(governing.modpath.."/commands.lua") -- must be at end. so relies on others functionalities +dofile(governing.modpath.."/process.lua") -- must be at end. so relies on others functionalities + --[[ end of include code files mod features ]] diff --git a/mods/governing/process.lua b/mods/governing/process.lua new file mode 100644 index 0000000..2336bd4 --- /dev/null +++ b/mods/governing/process.lua @@ -0,0 +1,121 @@ +-- mod governor by mckaygerhard, geoip specific code +-- Copyright 2023 + +---------------------------------------------------------------------------- +-- this program can be used free but cannot be used commertially or +-- modified for, licenced CC-BY-SA-NC 4.0 unless explicit permission + +-- This program is distributed in the hope that it will be useful, +-- but WITHOUT ANY WARRANTY; without even the implied warranty of +-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +---------------------------------------------------------------------------- + + +--[[ init of call back on join of a player, ]] +minetest.register_on_joinplayer(function(player) + + local msgsys = "#anticheat cannot get player info from minetest api.." + + if not player then return end + if not gapi.is_player(player) then return end + if not minetest.get_player_ip then minetest.log("error", msgsys) end + + local ip + local pos + local name + local info + + pos = player:getpos() + name = player:get_player_name() + ip = minetest.get_player_ip(name) + info = minetest.get_player_information(name) + + -- natural checks for player object apar of player:is_player + + if not ip then + minetest.log("error", msgsys.." (ip) for "..name) + end + + if not name then + minetest.log("error", msgsys.." (name) seems fake player") + end + + if not info then + minetest.log("error", msgsys.." (info), processing limited") + end + + -- process for ip information from player network + + if governing.checkapikey ~= "" then + governing.checkip(ip, function(data) -- log, but TODO: record in storage log file + local txt = gapi.format_result_checkip(data) + if txt then minetest.log("warning", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. "," .. txt) + else minetest.log("error", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. ", seems fails") + end + governing.joinplayer_callback(name, data) -- execute callback + end) + else + if not governing.modgeoip then + governing.lookup(ip, function(data) -- log, but TODO: record in storage log file + local txt = gapi.format_result_checkip(data) + if txt then minetest.log("warning", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. "," .. txt) + else minetest.log("error", "[goberning/geoip] joined player, " .. name .. ":" .. ip .. ", seems fails") + end + governing.joinplayer_callback(name, data) -- execute callback + end) + end + end + + -- process for client and players information for cheated program + + if not info then + if not gapi.is_player(player) then + name = name .. " is a bot confirmed, also" + end + msgsys = "[governing] can't retrieve info, player '" .. name .. "' disappeared or seems craker" + minetest.after(0.1, function() + for namemd,_ in pairs(cheat.moderators) do + minetest.chat_send_player(namemd,msgsys); + end + end) + minetest.log("warning", msgsys) + else + info = minetest.get_player_information(name) + msgsys = "[governing] player '" .. name .. "' joined" .. + " from:" .. info.address .. + " protocol_version:" .. (info.protocol_version or "20?") .. + " formspec_version:" .. (info.formspec_version or "old") .. + " lang_code:" .. (info.lang_code or "") .. + " serialization_version:" .. (info.serialization_version or "20?") .. + " version_string:" .. (info.version_string or "not supported") + minetest.log("action", msgsys) + + end + + if info.version_string then + msgsys = "#anticheat detected a cheater client does not provide info, ".. tostring(ip).." named "..name + local dfv = gapi.isdf(info.version_string) + if dfv then + minetest.after(3, function() + minetest.chat_send_player(name, msgiplevelone); + if minetest.settings:get_bool("beowulf.dfdetect.enable_kick", false) then + minetest.kick_player(name, "Are you a cheater stupid user? change your cracked client for play") + end + for namemd,_ in pairs(cheat.moderators) do + minetest.chat_send_player(namemd,msgsys); -- advertise moderators + end + end) + minetest.log(msgsys) + end + else + for namemd,_ in pairs(cheat.moderators) do + minetest.chat_send_player(namemd,msgsys); -- advertise moderators + end + minetest.log(msgsys) + end + +end) +--[[ end of call back on join of a player, ]] + +