Files
azul/front/oscar/foodgroups/bucp.py
T
Athena Funderburg 21f38ee3e1 production init
2026-05-26 16:41:23 +00:00

69 lines
2.1 KiB
Python

from util.misc import Logger
from util.hash import gen_salt
from ..proto.backend import login, LoginError
from ..proto.snac import OSCARClient, OSCARContext, SNACMessage, Foodgroup, Subgroup
from ..proto.tlv import unmarshal_tlvs, find_tlv
pw_change_url_format = 'http://aim.aol.com/redirects/password/change_password.adp?ScreenName={}&ccode=us&lang=en'
@Foodgroup(0x0017)
class BUCPFoodgroup:
logger: Logger
@Subgroup(0x0006)
def challenge_request(self, client: OSCARClient, context: OSCARContext, message: SNACMessage) -> None:
self.logger.info('[Client] BUCP__CHALLENGE_REQUEST')
tlvs = unmarshal_tlvs(message.data)
screen_name_tlv = find_tlv(tlvs, 0x0001)
screen_name = screen_name_tlv.data.decode()
salt = context.backend.user_service.aim_get_md5_salt(screen_name)
if salt is None:
# screen name doesn't exist or user did not enable OSCAR
salt = gen_salt()
response_msg = SNACMessage(0x0001, 0x0007)
response_msg.write_u16(len(salt))
response_msg.write_string(salt)
self.logger.info('[Server] BUCP__CHALLENGE_RESPONSE (salt:', salt + ')')
client.send_snac(response_msg)
@Subgroup(0x0002)
def login_request(self, client: OSCARClient, context: OSCARContext, message: SNACMessage) -> None:
self.logger.info('[Client] BUCP__LOGIN_REQUEST')
tlvs = unmarshal_tlvs(message.data)
screen_name_tlv = find_tlv(tlvs, 0x0001)
hashed_pw_tlv = find_tlv(tlvs, 0x0025)
screen_name = screen_name_tlv.data.decode()
self.logger.info('Screen Name (client-given):', screen_name)
self.logger.info('Password (hashed):', hashed_pw_tlv.data)
response_msg = SNACMessage(0x0017, 0x0003)
error_code = None
if (uuid := context.backend.util_get_uuid_from_username(screen_name)) is None:
error_code = LoginError.UnregisteredScreenname
self.logger.info('Unregistered screenname')
else:
password = context.backend.user_service.aim_get_md5_password(screen_name)
if password != hashed_pw_tlv.data:
error_code = LoginError.IncorrectPassword
self.logger.info('Incorrect password')
response_msg.write_bytes(login(self.logger, context, tlvs, uuid, error_code))
client.send_snac(response_msg)