From 5218da2ead654a795f52a52aa4270fd574075c45 Mon Sep 17 00:00:00 2001 From: Sfan5 Date: Sat, 27 Apr 2013 20:05:15 +0200 Subject: [PATCH] [Server] Add server searching, add addr: , name: and players: search arguments --- server.py | 109 ++++++++++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 93 insertions(+), 16 deletions(-) diff --git a/server.py b/server.py index f87620d..de5ea2c 100755 --- a/server.py +++ b/server.py @@ -6,26 +6,103 @@ Copyright 2012, Sfan5 import web, json, random -def read_server(): - text = web.get("http://servers.minetest.net/list") - server_list = json.loads(text)["list"] - choice = random.randrange(0, len(server_list)) +def by_random(tbl, arg): + return random.randrange(0, len(tbl)) - name = server_list[choice]["name"] - address = server_list[choice]["address"] - clients = server_list[choice]["clients"] - version = server_list[choice]["version"] - ping = server_list[choice]["ping"] - clients_top = server_list[choice]["clients_top"] +def by_address(tbl, arg): + for i in range(0, len(tbl)): + e = tbl[i] + if arg.lower().strip() in e["address"].lower().strip(): + return i + return None - return "%s | %s | Clients: %s/%s | Version: %s | ping: %s" % (name, address, clients, clients_top, version, ping) +def by_name(tbl, arg): + for i in range(0, len(tbl)): + e = tbl[i] + if arg.lower().strip() in e["name"].lower().strip(): + return i + return None + +def by_players(tbl, arg): + if arg.startswith("<"): # less comparing + try: + nu = int(arg[1:]) + except: + return None + for i in range(0, len(tbl)): + if int(tbl[i]["clients"]) < nu: + return i + elif arg.startswith(">"): # more comparing + try: + nu = int(arg[1:]) + except: + return None + for i in range(0, len(tbl)): + if int(tbl[i]["clients"]) > nu: + return i + elif arg == "most": # most + ranking = (-1, None) + for i in range(0, len(tbl)): + if int(tbl[i]["clients"]) > ranking[0]: + ranking = (tbl[i]["clients"], i) + return ranking[1] + elif arg == "least": # least + ranking = (9999, None) + for i in range(0, len(tbl)): + if int(tbl[i]["clients"]) < ranking[0]: + ranking = (tbl[i]["clients"], i) + return ranking[1] + else: + if arg.startswith("="): # support "3" and "=3" + arg = arg[1:] + try: + nu = int(arg) + except: + return None + for i in range(0, len(tbl)): + if int(tbl[i]["clients"]) == nu: + return i + return nu + return None def server(phenny, input): - for x in phenny.bot.commands["high"].values(): - if x[0].__name__ == "aa_hook": - if x[0](phenny, input): - return # Abort function - phenny.reply(read_server()) + for x in phenny.bot.commands["high"].values(): + if x[0].__name__ == "aa_hook": + if x[0](phenny, input): + return # Abort function + + arg = input.group(2) + if not arg: + choicefunc = by_random + carg = None + else: + if arg.startswith("addr:"): + choicefunc = by_address + carg = arg[len("addr:"):] + elif arg.startswith("name:"): + choicefunc = by_address + carg = arg[len("name:"):] + elif arg.startswith("players:"): + choicefunc = by_players + carg = arg[len("players:"):] + else: + choicefunc = by_name + carg = None + + text = web.get("http://servers.minetest.net/list") + server_list = json.loads(text)["list"] + choice = choicefunc(server_list, carg) + if choice == None: + phenny.reply("No results") + + name = server_list[choice]["name"] + address = server_list[choice]["address"] + clients = server_list[choice]["clients"] + version = server_list[choice]["version"] + " " + server_list[choice]["gameid"] + ping = server_list[choice]["ping"] + clients_top = server_list[choice]["clients_top"] + + phenny.reply("%s | %s | Clients: %s/%s | Version: %s | ping: %s" % (name, address, clients, clients_top, version, ping)) server.commands = ['sv', 'server'] server.thread = True