.BANCHO. Add support for locked accounts
This commit is contained in:
parent
48925c58c0
commit
14348a68bb
|
@ -83,3 +83,6 @@ class haxException(Exception):
|
||||||
|
|
||||||
class forceUpdateException(Exception):
|
class forceUpdateException(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class loginLockedException(Exception):
|
||||||
|
pass
|
||||||
|
|
|
@ -16,7 +16,12 @@ def forceUpdate():
|
||||||
|
|
||||||
def loginBanned():
|
def loginBanned():
|
||||||
packets = packetHelper.buildPacket(packetIDs.server_userID, [[-1, dataTypes.SINT32]])
|
packets = packetHelper.buildPacket(packetIDs.server_userID, [[-1, dataTypes.SINT32]])
|
||||||
packets += notification("You are banned. You can ask to get unbanned after 1 month since your ban by contacting support@ripple.moe")
|
packets += notification("You are banned. You can appeal after one month since your ban by sending an email to support@ripple.moe> from the email address you've used to sign up.")
|
||||||
|
return packets
|
||||||
|
|
||||||
|
def loginLocked():
|
||||||
|
packets = packetHelper.buildPacket(packetIDs.server_userID, [[-1, dataTypes.SINT32]])
|
||||||
|
packets += notification("Your account is locked. You can't log in, but your profile and scores are still visible from the website. If you want to unlock your account, send an email to support@ripple.moe from the email address you've used to sign up.")
|
||||||
return packets
|
return packets
|
||||||
|
|
||||||
def loginError():
|
def loginError():
|
||||||
|
|
|
@ -31,7 +31,7 @@ def handle(tornadoRequest):
|
||||||
|
|
||||||
# Make sure loginData is valid
|
# Make sure loginData is valid
|
||||||
if len(loginData) < 3:
|
if len(loginData) < 3:
|
||||||
raise exceptions.haxException()
|
raise exceptions.invalidArgumentsException()
|
||||||
|
|
||||||
# Get HWID, MAC address and more
|
# Get HWID, MAC address and more
|
||||||
# Structure (new line = "|", already split)
|
# Structure (new line = "|", already split)
|
||||||
|
@ -59,10 +59,12 @@ def handle(tornadoRequest):
|
||||||
# Invalid password
|
# Invalid password
|
||||||
raise exceptions.loginFailedException()
|
raise exceptions.loginFailedException()
|
||||||
|
|
||||||
# Make sure we are not banned
|
# Make sure we are not banned or locked
|
||||||
priv = userHelper.getPrivileges(userID)
|
priv = userHelper.getPrivileges(userID)
|
||||||
if userHelper.isBanned(userID) == True and priv & privileges.USER_PENDING_VERIFICATION == 0:
|
if userHelper.isBanned(userID) == True and priv & privileges.USER_PENDING_VERIFICATION == 0:
|
||||||
raise exceptions.loginBannedException()
|
raise exceptions.loginBannedException()
|
||||||
|
if userHelper.isLocked(userID) == True and priv & privileges.USER_PENDING_VERIFICATION == 0:
|
||||||
|
raise exceptions.loginLockedException()
|
||||||
|
|
||||||
# 2FA check
|
# 2FA check
|
||||||
if userHelper.check2FA(userID, requestIP):
|
if userHelper.check2FA(userID, requestIP):
|
||||||
|
@ -203,7 +205,7 @@ def handle(tornadoRequest):
|
||||||
# (we don't use enqueue because we don't have a token since login has failed)
|
# (we don't use enqueue because we don't have a token since login has failed)
|
||||||
err = True
|
err = True
|
||||||
responseData += serverPackets.loginFailed()
|
responseData += serverPackets.loginFailed()
|
||||||
except exceptions.haxException:
|
except exceptions.invalidArgumentsException:
|
||||||
# Invalid POST data
|
# Invalid POST data
|
||||||
# (we don't use enqueue because we don't have a token since login has failed)
|
# (we don't use enqueue because we don't have a token since login has failed)
|
||||||
err = True
|
err = True
|
||||||
|
@ -213,6 +215,10 @@ def handle(tornadoRequest):
|
||||||
# Login banned error packet
|
# Login banned error packet
|
||||||
err = True
|
err = True
|
||||||
responseData += serverPackets.loginBanned()
|
responseData += serverPackets.loginBanned()
|
||||||
|
except exceptions.loginLockedException:
|
||||||
|
# Login banned error packet
|
||||||
|
err = True
|
||||||
|
responseData += serverPackets.loginLocked()
|
||||||
except exceptions.banchoMaintenanceException:
|
except exceptions.banchoMaintenanceException:
|
||||||
# Bancho is in maintenance mode
|
# Bancho is in maintenance mode
|
||||||
responseData = responseToken.queue
|
responseData = responseToken.queue
|
||||||
|
@ -230,7 +236,7 @@ def handle(tornadoRequest):
|
||||||
# (we don't use enqueue because we don't have a token since login has failed)
|
# (we don't use enqueue because we don't have a token since login has failed)
|
||||||
err = True
|
err = True
|
||||||
responseData += serverPackets.forceUpdate()
|
responseData += serverPackets.forceUpdate()
|
||||||
responseData += serverPackets.notification("Hory shitto, your client is TOO old! Nice preistoria! Please turn off the switcher and update it.")
|
responseData += serverPackets.notification("Hory shitto, your client is TOO old! Nice prehistory! Please turn update it from the settings!")
|
||||||
except:
|
except:
|
||||||
log.error("Unknown error!\n```\n{}\n{}```".format(sys.exc_info(), traceback.format_exc()))
|
log.error("Unknown error!\n```\n{}\n{}```".format(sys.exc_info(), traceback.format_exc()))
|
||||||
finally:
|
finally:
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
from helpers import passwordHelper
|
from helpers import passwordHelper
|
||||||
from constants import gameModes
|
from constants import gameModes
|
||||||
|
from constants import privileges
|
||||||
from helpers import generalFunctions
|
from helpers import generalFunctions
|
||||||
from objects import glob
|
from objects import glob
|
||||||
from helpers import logHelper as log
|
from helpers import logHelper as log
|
||||||
|
@ -385,6 +386,19 @@ def isBanned(userID):
|
||||||
else:
|
else:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def isLocked(userID):
|
||||||
|
"""
|
||||||
|
Check if userID is locked
|
||||||
|
|
||||||
|
userID -- id of the user
|
||||||
|
return -- True if not locked, otherwise false.
|
||||||
|
"""
|
||||||
|
result = glob.db.fetch("SELECT privileges FROM users WHERE id = %s LIMIT 1", [userID])
|
||||||
|
if result != None:
|
||||||
|
return ((result["privileges"] & privileges.USER_PUBLIC > 0) and (result["privileges"] & privileges.USER_NORMAL == 0))
|
||||||
|
else:
|
||||||
|
return True
|
||||||
|
|
||||||
def ban(userID):
|
def ban(userID):
|
||||||
"""
|
"""
|
||||||
Ban userID
|
Ban userID
|
||||||
|
|
Loading…
Reference in New Issue
Block a user