Browse Source

Merge fb6673a105 into 26166e047b

pull/361/merge
Luckydonald 2 years ago
committed by GitHub
parent
commit
9d8d52f451
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 72
      steam/guard.py

72
steam/guard.py

@ -71,7 +71,7 @@ from binascii import hexlify
from time import time
from steam import webapi
from steam.enums import ETwoFactorTokenType
from steam.steamid import SteamID
from steam.exceptions import SteamError
from steam.core.crypto import hmac_sha1, sha1_hash
from steam.enums.common import EResult
from steam.webauth import MobileWebAuth
@ -144,7 +144,10 @@ class SteamAuthenticator(object):
if isinstance(backend, MobileWebAuth):
if not backend.logged_on:
raise SteamAuthenticatorError("MobileWebAuth instance not logged in")
raise SteamAuthenticatorError(
message="MobileWebAuth instance not logged in",
eresult=None,
)
params['access_token'] = backend.oauth_token
params['http_timeout'] = 10
@ -152,22 +155,32 @@ class SteamAuthenticator(object):
try:
resp = webapi.post('ITwoFactorService', action, 1, params=params)
except requests.exceptions.RequestException as exp:
raise SteamAuthenticatorError("Error adding via WebAPI: %s" % str(exp))
raise SteamAuthenticatorError(
message="Error adding via WebAPI: %s" % str(exp),
eresult=None,
)
resp = resp['response']
else:
if not backend.logged_on:
raise SteamAuthenticatorError("SteamClient instance not logged in")
raise SteamAuthenticatorError(
message="SteamClient instance not logged in",
eresult=None,
)
resp = backend.send_um_and_wait("TwoFactor.%s#1" % action,
params, timeout=10)
if resp is None:
raise SteamAuthenticatorError("Failed. Request timeout")
raise SteamAuthenticatorError(
message="Failed. Request timeout",
eresult=None,
)
if resp.header.eresult != EResult.OK:
raise SteamAuthenticatorError("Failed: %s (%s)" % (resp.header.error_message,
repr(resp.header.eresult)))
raise SteamAuthenticatorError(
message="Failed: %s (%s)" % (resp.header.error_message, repr(resp.header.eresult)),
eresult=resp.header.eresult,
)
resp = proto_to_dict(resp.body)
if action == 'AddAuthenticator':
@ -183,7 +196,10 @@ class SteamAuthenticator(object):
:raises: :class:`SteamAuthenticatorError`
"""
if not self.has_phone_number():
raise SteamAuthenticatorError("Account doesn't have a verified phone number")
raise SteamAuthenticatorError(
message="Account doesn't have a verified phone number",
eresult=None,
)
resp = self._send_request('AddAuthenticator', {
'steamid': self.backend.steam_id,
@ -194,7 +210,10 @@ class SteamAuthenticator(object):
})
if resp['status'] != EResult.OK:
raise SteamAuthenticatorError("Failed to add authenticator. Error: %s" % repr(EResult(resp['status'])))
raise SteamAuthenticatorError(
message="Failed to add authenticator. Error: %s" % repr(EResult(resp['status'])),
eresult=resp['status'],
)
self.secrets = resp
self.steam_time_offset = int(resp['server_time']) - time()
@ -220,7 +239,10 @@ class SteamAuthenticator(object):
return
elif not resp['success']:
self._finalize_attempts = 5
raise SteamAuthenticatorError("Failed to finalize authenticator. Error: %s" % repr(EResult(resp['status'])))
raise SteamAuthenticatorError(
message="Failed to finalize authenticator. Error: %s" % repr(EResult(resp['status'])),
eresult=resp['status'],
)
self.steam_time_offset = int(resp['server_time']) - time()
@ -239,9 +261,15 @@ class SteamAuthenticator(object):
:raises: :class:`SteamAuthenticatorError`
"""
if not self.secrets:
raise SteamAuthenticatorError("No authenticator secrets available?")
raise SteamAuthenticatorError(
message="No authenticator secrets available?",
eresult=None,
)
if not isinstance(self.backend, MobileWebAuth):
raise SteamAuthenticatorError("Only available via MobileWebAuth")
raise SteamAuthenticatorError(
message="Only available via MobileWebAuth",
eresult=None,
)
resp = self._send_request('RemoveAuthenticator', {
'steamid': self.backend.steam_id,
@ -250,9 +278,11 @@ class SteamAuthenticator(object):
})
if not resp['success']:
raise SteamAuthenticatorError("Failed to remove authenticator. (attempts remaining: %s)" % (
resp['revocation_attempts_remaining'],
))
raise SteamAuthenticatorError(
message="Failed to remove authenticator. (attempts remaining: %s)" %
(resp['revocation_attempts_remaining'],),
eresult=None,
)
self.secrets.clear()
@ -483,8 +513,14 @@ class SteamAuthenticator(object):
return resp
class SteamAuthenticatorError(Exception):
pass
class SteamAuthenticatorError(SteamError):
def __init__(self, message, eresult=None):
Exception.__init__(self, message, eresult)
self.message = message
self.eresult = EResult(eresult) if eresult is not None else None #: :class:`.EResult`|:class:`None`
def __str__(self):
return "(%s) %s" % (self.eresult, self.message) if self.eresult is not None else self.message
def generate_twofactor_code(shared_secret):

Loading…
Cancel
Save