[ServerUp] New Syntax, Bulk Checking, Limit for multiple Ports

master
Sfan5 2013-01-19 15:14:01 +01:00
parent bb4ef86fa8
commit b9f3e1e223
1 changed files with 55 additions and 23 deletions

View File

@ -13,14 +13,46 @@ def serverup(phenny, input):
if not '.' in arg:
return phenny.reply("Invalid Address")
if ':' in arg:
address = arg.split(':')[0]
phenny.reply("Note: Syntax changed please use 'example.org 1337' instead of 'example.org:1337'")
arg = arg.split(':')[0] + ' ' + arg.split(':')[1]
if ' ' in arg:
address = arg.split(' ')[0]
port = arg.split(' ')[1]
if '-' in port or ',' in port:
ports = []
ports_ = port.split(',')
for p in ports_:
if '-' in p:
if len(p.split('-')) != 2:
return phenny.reply("Invalid Port List")
else:
try:
port = int(arg.split(':')[1])
a = int(p.split('-')[0])
except:
return phenny.reply("Invalid Port")
return phenny.reply("Invalid Port: %s" % p.split('-')[0])
try:
b = int(p.split('-')[1]) + 1
except:
return phenny.reply("Invalid Port: %s" % p.split('-')[1])
for i in range(a, b):
ports.append(i)
else:
try:
ports.append(int(p))
except:
return phenny.reply("Invalid Port: %s" % p)
else:
try:
ports = [int(port)]
except:
return phenny.reply("Invalid Port: %s" % port)
else:
address = arg
port = 30000
ports = [30000]
if len(ports) > 4 and not (input.admin or input.owner): # Owner and Admins of the Bot can bypass the Limit
return phenny.reply("Too many Ports specified")
for port in ports:
repres = address + ':' + str(port)
try:
start = time.time()
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
@ -34,11 +66,11 @@ def serverup(phenny, input):
sock.sendto(buf, (address, port))
sock.close()
end = time.time()
phenny.reply("%s is up (%0.3fms)" % (arg,end-start))
phenny.reply("%s is up (%0.3fms)" % (repres,end-start))
else:
phenny.reply("%s seems to be down " % arg)
phenny.reply("%s seems to be down " % repres)
except:
phenny.reply("%s seems to be down " % arg)
phenny.reply("%s seems to be down " % repres)