logging messages, removed broken import

This commit is contained in:
əlemi 2022-02-12 00:33:00 +01:00
parent b1e95b43bd
commit 2089e215d1
No known key found for this signature in database
GPG key ID: BBCBFE5D7244634E
2 changed files with 13 additions and 4 deletions

View file

@ -1,3 +1,2 @@
from .token import *
from .packet import Packet
from .definitions import *

View file

@ -1,8 +1,11 @@
import re
import uuid
import logging
from urllib.parse import urlencode
from typing import Dict, Optional, Any
from yarl import URL
import aiohttp
from ..definitions import GameProfile
@ -26,6 +29,7 @@ class MicrosoftAuthenticator(AuthInterface):
accessToken : str
selectedProfile : GameProfile
MINECRAFT_CLIENT_ID = "00000000402b5328"
OAUTH_LOGIN = "https://login.live.com/oauth20"
XBL_LOGIN = "https://user.auth.xboxlive.com/user/authenticate"
XSTS_LOGIN = "https://xsts.auth.xboxlive.com/xsts/authorize"
@ -59,15 +63,14 @@ class MicrosoftAuthenticator(AuthInterface):
f"&state={state}"
)
# TODO implement auth directly from credentials
async def authenticate(self, code:str, state:str=""): # TODO nicer way to get code?
async def login(self, code:str): # TODO nicer way to get code?
await self._ms_auth(code)
await self._xbl_auth()
await self._xsts_auth()
await self._mc_auth()
await self.fetch_mcstore()
await self.fetch_profile()
logging.info("Successfully logged into Microsoft account")
async def refresh(self):
if not self.ms_refresh_token:
@ -76,9 +79,11 @@ class MicrosoftAuthenticator(AuthInterface):
await self._xbl_auth()
await self._xsts_auth()
await self._mc_auth()
logging.info("Successfully refreshed Microsoft token")
async def _ms_auth(self, code:str=""):
"""Authorize Microsoft account"""
logging.debug("Authenticating Microsoft account")
payload = {
"client_id": self.client_id,
"client_secret": self.client_secret,
@ -104,6 +109,7 @@ class MicrosoftAuthenticator(AuthInterface):
"""Authorize with XBox Live"""
if not self.ms_token:
raise InvalidStateError("Missing MS access token")
logging.debug("Authenticating against XBox Live")
auth_response = await self._post(
self.XBL_LOGIN,
headers={
@ -127,6 +133,7 @@ class MicrosoftAuthenticator(AuthInterface):
"""Authenticate with XBox Security Tokens"""
if not self.xbl_token:
raise InvalidStateError("Missing XBL Token")
logging.debug("Authenticating against XSTS")
auth_response = await self._post(
self.XSTS_LOGIN,
headers={
@ -154,6 +161,7 @@ class MicrosoftAuthenticator(AuthInterface):
raise InvalidStateError("Missing userhash")
if not self.xsts_token:
raise InvalidStateError("Missing XSTS Token")
logging.debug("Authenticating against Minecraft")
auth_response = await self._post(
self.MINECRAFT_API + "/authentication/login_with_xbox",
headers={
@ -168,6 +176,7 @@ class MicrosoftAuthenticator(AuthInterface):
async def fetch_mcstore(self):
"""Get the store information"""
logging.debug("Fetching MC Store")
self.mcstore = await self._get(
self.MINECRAFT_API + "/entitlements/mcstore",
headers={ "Authorization": f"Bearer {self.access_token}" },
@ -175,6 +184,7 @@ class MicrosoftAuthenticator(AuthInterface):
async def fetch_profile(self):
"""Get player profile"""
logging.debug("Fetching profile")
p = await self._get(
self.MINECRAFT_API + "/minecraft/profile",
headers={ "Authorization": f"Bearer {self.access_token}" },