Written about 2FA in how-to docs
This commit is contained in:
parent
f996b27ef6
commit
7924678c96
2 changed files with 64 additions and 8 deletions
|
@ -165,4 +165,66 @@ at.change_password_hashed(my_passwd, new_passwd)
|
||||||
```
|
```
|
||||||
|
|
||||||
## Two-Factor Authentication
|
## 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.
|
||||||
|
|
|
@ -392,17 +392,11 @@ class Client:
|
||||||
"""Requests a secret code and
|
"""Requests a secret code and
|
||||||
a QR code for enabling 2FA"""
|
a QR code for enabling 2FA"""
|
||||||
|
|
||||||
resp: Dict[str, str]
|
return self.atconn.request_cloudflare(
|
||||||
resp = self.atconn.request_cloudflare(
|
|
||||||
'https://aternos.org/panel/ajax/account/secret.php',
|
'https://aternos.org/panel/ajax/account/secret.php',
|
||||||
'GET', sendtoken=True
|
'GET', sendtoken=True
|
||||||
).json()
|
).json()
|
||||||
|
|
||||||
return {
|
|
||||||
'qrcode': resp.get('qrcode', ''),
|
|
||||||
'secret': resp.get('secret', ''),
|
|
||||||
}
|
|
||||||
|
|
||||||
def enbale_2fa(self, code: int) -> None:
|
def enbale_2fa(self, code: int) -> None:
|
||||||
|
|
||||||
"""Enables Two-Factor Authentication
|
"""Enables Two-Factor Authentication
|
||||||
|
|
Reference in a new issue