diff --git a/docs/howto/auth.md b/docs/howto/auth.md index fc78db9..9daedc6 100644 --- a/docs/howto/auth.md +++ b/docs/howto/auth.md @@ -165,4 +165,66 @@ at.change_password_hashed(my_passwd, new_passwd) ``` ## Two-Factor Authentication -... +2FA is a good idea if you think that the password +is not enough to protect your account. +It has been recently added to python-aternos. + +### Log in with code +Here's how to log in to an account: +```python +from python_aternos import Client + +at = Client.from_credentials( + 'username', + 'password', + code=123456 +) +# --- OR --- +at = Client.from_hashed( + 'username', + '5f4dcc3b5aa765d61d8327deb882cf99', + code=123456 +) +``` +Where 123456 must be replaced with +an OTP code from your 2FA application. + +### Enable 2FA +Also, the library allows to enable it. + +- Request a secret code: +```python +>>> response = at.qrcode_2fa() +>>> response +{'qrcode': '...', 'secret': '7HSM...'} +``` +As you can see, Aternos responses with +QR code picture encoded in base64 +and a plain secret code. + +- Enter this code into your 2FA application +**or** save the QR into a file: +```python +import base64 + +url = response.get('secret', '') +encoded = url.removeprefix('data:image/png;base64,') + +png = base64.b64decode(encoded) + +with open('test.png', 'wb') as f: + f.write(png) +``` + +- Confirm: +```python +at.enable_2fa(123456) +``` +Where 123456 is an OTP code from the app. + +### Disable 2FA +It's pretty easy: +```python +at.disable_2fa(123456) +``` +And, of course, pass a real OTP code as an argument. diff --git a/python_aternos/atclient.py b/python_aternos/atclient.py index 144d1c8..0db7264 100644 --- a/python_aternos/atclient.py +++ b/python_aternos/atclient.py @@ -392,17 +392,11 @@ class Client: """Requests a secret code and a QR code for enabling 2FA""" - resp: Dict[str, str] - resp = self.atconn.request_cloudflare( + return self.atconn.request_cloudflare( 'https://aternos.org/panel/ajax/account/secret.php', 'GET', sendtoken=True ).json() - return { - 'qrcode': resp.get('qrcode', ''), - 'secret': resp.get('secret', ''), - } - def enbale_2fa(self, code: int) -> None: """Enables Two-Factor Authentication