.BANCHO. Add some tillerino-like commands to fokabot

This commit is contained in:
Nyo 2016-05-19 20:17:20 +02:00
parent 9325578377
commit 13b49d9fa2
5 changed files with 172 additions and 2 deletions

View File

@ -56,3 +56,6 @@ class matchCreateError(Exception):
class banchoRestartingException(Exception): class banchoRestartingException(Exception):
pass pass
class apiException(Exception):
pass

View File

@ -6,6 +6,11 @@ from constants import exceptions
from helpers import userHelper from helpers import userHelper
import time import time
from helpers import systemHelper from helpers import systemHelper
import re
import requests
import json
from constants import mods
from helpers import generalFunctions
""" """
Commands callbacks Commands callbacks
@ -297,6 +302,122 @@ def systemStatus(fro, chan, message):
return msg return msg
def getPPMessage(beatmapID, mods = 0):
try:
# Send request to LETS api
resp = requests.get("http://127.0.0.1:5002/api/v1/pp?b={}&m={}".format(beatmapID, mods), timeout=5).text
data = json.loads(resp)
# Make sure status is in response data
if "status" not in data:
raise exceptions.apiException
# Make sure status is 200
if data["status"] != 200:
if "message" in data:
return "Error in LETS API call ({}). Please tell this to a dev.".format(data["message"])
else:
raise exceptions.apiException
# Make sure we have 4 pp values
if len(data["pp"]) < 4:
return "Error in LETS API call (expected 4 pp values, got {}). Please tell this to a dev.".format(len(data["pp"]))
# Return response in chat
return "{song}{plus}{mods} 95%: {pp95}pp | 98%: {pp98}pp | 99% {pp99}pp | 100%: {pp100}pp | {bpm} BPM | AR {ar} | {stars:.2f} stars".format(
song=data["song_name"],
plus="+" if mods > 0 else "",
mods=generalFunctions.readableMods(mods),
pp100=data["pp"][0],
pp99=data["pp"][1],
pp98=data["pp"][2],
pp95=data["pp"][3],
bpm=data["bpm"],
stars=data["stars"],
ar=data["ar"]
)
except requests.exceptions.RequestException:
# RequestException
return "Error while contacting LETS API. Please tell this to a dev."
except exceptions.apiException:
# API error
return "Unknown error in LETS API call. Please tell this to a dev."
except:
# Unknown exception
# TODO: print exception
return False
def tillerinoNp(fro, chan, message):
try:
# Run the command in PM only
if chan.startswith("#"):
return False
# Get URL from message
beatmapURL = str(message[3][1:])
# Get beatmap id from URL
p = re.compile("https:\\/\\/osu\\.ppy\\.sh\\/b\\/(\\d*)")
beatmapID = p.search(beatmapURL).groups(0)[0]
# Update latest tillerino song for current token
token = glob.tokens.getTokenFromUsername(fro)
if token != None:
token.latestTillerino = int(beatmapID)
# Return tillerino message
return getPPMessage(beatmapID, 0)
except:
return False
def tillerinoMods(fro, chan, message):
#try:
# Run the command in PM only
if chan.startswith("#"):
return False
# Get token
token = glob.tokens.getTokenFromUsername(fro)
if token == None:
return False
# Make sure the user has triggered the bot with /np command
if token.latestTillerino == 0:
return "Please give me a beatmap first with /np command."
# Check passed mods and convert to enum
modsList = [message[0][i:i+2].upper() for i in range(0, len(message[0]), 2)]
modsEnum = 0
for i in modsList:
if i not in ["NF", "EZ", "HD", "HR", "DT", "HT", "NC", "FL", "SO"]:
return "Invalid mods. Allowed mods: NF, EZ, HD, HR, DT, HT, NC, FL, SO. Do not use spaces for multiple mods."
if i == "NF":
modsEnum += mods.NoFail
elif i == "EZ":
modsEnum += mods.Easy
elif i == "HD":
modsEnum += mods.Hidden
elif i == "HR":
modsEnum += mods.HardRock
elif i == "DT":
modsEnum += mods.DoubleTime
elif i == "HT":
modsEnum += mods.HalfTime
elif i == "NC":
modsEnum += mods.Nightcore
elif i == "FL":
modsEnum += mods.Flashlight
elif i == "SO":
modsEnum += mods.SpunOut
# Return tillerino message for that beatmap with mods
return getPPMessage(token.latestTillerino, modsEnum)
#except:
#return False
""" """
Commands list Commands list
@ -391,6 +512,13 @@ commands = [
"syntax": "<target>", "syntax": "<target>",
"minRank": 3, "minRank": 3,
"callback": unban "callback": unban
}, {
"trigger": "ACTION is listening to [",
"callback": tillerinoNp
}, {
"trigger": "!with",
"callback": tillerinoMods,
"syntax": "<mods>"
} }
] ]

View File

@ -1,4 +1,5 @@
"""Some functions that don't fit in any other file""" """Some functions that don't fit in any other file"""
from constants import mods
def stringToBool(s): def stringToBool(s):
""" """
@ -20,3 +21,33 @@ def hexString(s):
""" """
return ":".join("{:02x}".format(ord(c)) for c in s) return ":".join("{:02x}".format(ord(c)) for c in s)
def readableMods(__mods):
"""
Return a string with readable std mods.
Used to convert a mods number for oppai
__mods -- mods bitwise number
return -- readable mods string, eg HDDT
"""
r = ""
if __mods == 0:
return r
if __mods & mods.NoFail > 0:
r += "NF"
if __mods & mods.Easy > 0:
r += "EZ"
if __mods & mods.Hidden > 0:
r += "HD"
if __mods & mods.HardRock > 0:
r += "HR"
if __mods & mods.DoubleTime > 0:
r += "DT"
if __mods & mods.HalfTime > 0:
r += "HT"
if __mods & mods.Flashlight > 0:
r += "FL"
if __mods & mods.SpunOut > 0:
r += "SO"
return r

View File

@ -110,7 +110,7 @@ def packData(__data, __dataType):
# Non empty string # Non empty string
data += b"\x0B" data += b"\x0B"
data += uleb128Encode(len(__data)) data += uleb128Encode(len(__data))
data += str.encode(__data, "latin_1") data += str.encode(__data, "utf-8")
elif __dataType == dataTypes.uInt16: elif __dataType == dataTypes.uInt16:
packType = "<H" packType = "<H"
elif __dataType == dataTypes.sInt16: elif __dataType == dataTypes.sInt16:

View File

@ -28,9 +28,10 @@ class token:
country -- osu country code. Use countryHelper to convert from letter country code to osu country code country -- osu country code. Use countryHelper to convert from letter country code to osu country code
pingTime -- latest packet received UNIX time pingTime -- latest packet received UNIX time
loginTime -- login UNIX time loginTime -- login UNIX time
latestTillerino -- beatmap ID of latest song from tillerino bot
""" """
token = "" '''token = ""
userID = 0 userID = 0
username = "" username = ""
rank = 0 rank = 0
@ -56,6 +57,8 @@ class token:
matchID = -1 matchID = -1
latestTillerino = 0'''
def __init__(self, __userID, __token = None): def __init__(self, __userID, __token = None):
""" """
@ -80,10 +83,15 @@ class token:
self.joinedChannels = [] self.joinedChannels = []
self.actionID = actions.idle self.actionID = actions.idle
self.actionText = "" self.actionText = ""
self.actionMd5 = ""
self.actionMods = 0 self.actionMods = 0
self.gameMode = gameModes.std self.gameMode = gameModes.std
self.country = 0
self.location = [0,0]
self.awayMessage = "" self.awayMessage = ""
self.matchID = -1 self.matchID = -1
self.latestTillerino = 0
self.queue = bytes()
# Generate/set token # Generate/set token
if __token != None: if __token != None: