.BANCHO. Add accuracy, beatmap link and rank to !last

This commit is contained in:
russelg 2016-06-07 01:10:32 +08:00 committed by Nyo
parent e11ae27b36
commit f9d6e79447
4 changed files with 84 additions and 4 deletions

View File

@ -479,7 +479,8 @@ def tillerinoAcc(fro, chan, message):
def tillerinoLast(fro, chan, message): def tillerinoLast(fro, chan, message):
try: try:
data = glob.db.fetch("""SELECT beatmaps.song_name as sn, scores.pp data = glob.db.fetch("""SELECT beatmaps.song_name as sn, scores.*,
beatmaps.beatmap_id as bid
FROM scores FROM scores
LEFT JOIN beatmaps ON beatmaps.beatmap_md5=scores.beatmap_md5 LEFT JOIN beatmaps ON beatmaps.beatmap_md5=scores.beatmap_md5
LEFT JOIN users ON users.id = scores.userid LEFT JOIN users ON users.id = scores.userid
@ -488,7 +489,19 @@ def tillerinoLast(fro, chan, message):
LIMIT 1""", [fro]) LIMIT 1""", [fro])
if data == None: if data == None:
return False return False
return "{0:.2f}pp ({1} on {2})".format(data["pp"], fro, data["sn"])
rank = generalFunctions.getRank(data["play_mode"], data["mods"], data["accuracy"],\
data["300_count"], data["100_count"], data["50_count"], data["misses_count"])
msg = "{0:.2f}pp".format(data["pp"])
msg += " on " if chan == "FokaBot" else " | {0} on ".format(fro)
msg += "({0})[http://osu.ppy.sh/b/{1}]".format(data["sn"], data["bid"])
if data["mods"]:
msg += ' +' + generalFunctions.readableMods(data["mods"])
msg += " ({0:.2f}%, {1})".format(data["accuracy"], rank.upper())
return msg
except Exception as a: except Exception as a:
log.error(a) log.error(a)
return False return False

View File

@ -37,4 +37,4 @@ def handle(userToken, _):
glob.tokens.deleteToken(requestToken) glob.tokens.deleteToken(requestToken)
# Console output # Console output
log.info("{} have been disconnected.".format(username)) log.info("{} has been disconnected.".format(username))

View File

@ -165,7 +165,7 @@ class handler(requestHelper.asyncRequestHandler):
responseData = serverPackets.loginError() responseData = serverPackets.loginError()
responseData += serverPackets.notification("Whoops! Something went wrong, please login again.") responseData += serverPackets.notification("Whoops! Something went wrong, please login again.")
log.warning("Received packet from unknown token ({}).".format(requestTokenString)) log.warning("Received packet from unknown token ({}).".format(requestTokenString))
log.info("{} have been disconnected (invalid token)".format(requestTokenString)) log.info("{} has been disconnected (invalid token)".format(requestTokenString))
finally: finally:
# Unlock token # Unlock token
if userToken != None: if userToken != None:

View File

@ -53,6 +53,73 @@ def readableMods(__mods):
return r return r
def getRank(gameMode, __mods, acc, c300, c100, c50, cmiss):
"""
Return a string with rank/grade for a given score.
Used mainly for "tillerino"
gameMode -- mode (0 = osu!, 1 = Taiko, 2 = CtB, 3 = osu!mania)
__mods -- mods bitwise number
acc -- accuracy
c300 -- 300 hit count
c100 -- 100 hit count
c50 -- 50 hit count
cmiss -- miss count
return -- rank/grade string
"""
total = c300 + c100 + c50 + cmiss
hdfl = (__mods & mods.Hidden > 0) or (__mods & mods.Flashlight > 0)
def ss():
return "sshd" if hdfl else "ss"
def s():
return "shd" if hdfl else "s"
if gameMode == 0:
# osu!std
if acc == 100:
return ss()
if c300 / total > 0.90 and c50 / total < 0.1 and cmiss == 0:
return s()
if (c300 / total > 0.80 and cmiss == 0) or (c300 / total > 0.90):
return "a"
if (c300 / total > 0.70 and cmiss == 0) or (c300 / total > 0.80):
return "b"
if c300 / total > 0.60:
return "c"
return "d"
elif gameMode == 1:
# taiko not implemented as of yet.
return "a"
elif gameMode == 2:
# CtB
if acc == 100:
return ss()
if acc >= 98.01 and acc <= 99.99:
return s()
if acc >= 94.01 and acc <= 98.00:
return "a"
if acc >= 90.01 and acc <= 94.00:
return "b"
if acc >= 98.01 and acc <= 90.00:
return "c"
return "d"
elif gameMode == 3:
# osu!mania
if acc == 100:
return ss()
if acc > 95:
return s()
if acc > 90:
return "a"
if acc > 80:
return "b"
if acc > 70:
return "c"
return "d"
return "a"
def strContains(s, w): def strContains(s, w):
return (' ' + w + ' ') in (' ' + s + ' ') return (' ' + w + ' ') in (' ' + s + ' ')