mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-25 18:26:34 +00:00
fix(tokens-repo): properly expire new device keys
This commit is contained in:
parent
c037a12f4d
commit
5d4ed73435
|
@ -140,6 +140,9 @@ class AbstractTokensRepository(ABC):
|
||||||
if not new_device_key:
|
if not new_device_key:
|
||||||
raise NewDeviceKeyNotFound
|
raise NewDeviceKeyNotFound
|
||||||
|
|
||||||
|
if not new_device_key.is_valid():
|
||||||
|
raise NewDeviceKeyNotFound
|
||||||
|
|
||||||
if not self._assert_mnemonic(new_device_key.key, mnemonic_phrase):
|
if not self._assert_mnemonic(new_device_key.key, mnemonic_phrase):
|
||||||
raise NewDeviceKeyNotFound("Phrase is not token!")
|
raise NewDeviceKeyNotFound("Phrase is not token!")
|
||||||
|
|
||||||
|
|
|
@ -513,15 +513,20 @@ def test_use_not_exists_mnemonic_new_device_key(
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_use_mnemonic_new_device_key(
|
def mnemonic_from_hex(hexkey):
|
||||||
empty_repo, mock_new_device_key_generate_for_mnemonic
|
return Mnemonic(language="english").to_mnemonic(bytes.fromhex(hexkey))
|
||||||
):
|
|
||||||
|
|
||||||
|
def test_use_mnemonic_new_device_key(empty_repo):
|
||||||
repo = empty_repo
|
repo = empty_repo
|
||||||
assert repo.get_new_device_key() is not None
|
key = repo.get_new_device_key()
|
||||||
|
assert key is not None
|
||||||
|
|
||||||
|
mnemonic_phrase = mnemonic_from_hex(key.key)
|
||||||
|
|
||||||
new_token = repo.use_mnemonic_new_device_key(
|
new_token = repo.use_mnemonic_new_device_key(
|
||||||
device_name="imnew",
|
device_name="imnew",
|
||||||
mnemonic_phrase="captain ribbon toddler settle symbol minute step broccoli bless universe divide bulb",
|
mnemonic_phrase=mnemonic_phrase,
|
||||||
)
|
)
|
||||||
|
|
||||||
assert new_token.device_name == "imnew"
|
assert new_token.device_name == "imnew"
|
||||||
|
@ -532,12 +537,32 @@ def test_use_mnemonic_new_device_key(
|
||||||
assert (
|
assert (
|
||||||
repo.use_mnemonic_new_device_key(
|
repo.use_mnemonic_new_device_key(
|
||||||
device_name="imnew",
|
device_name="imnew",
|
||||||
mnemonic_phrase="captain ribbon toddler settle symbol minute step broccoli bless universe divide bulb",
|
mnemonic_phrase=mnemonic_phrase,
|
||||||
)
|
)
|
||||||
is None
|
is None
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def test_use_mnemonic_expired_new_device_key(
|
||||||
|
some_tokens_repo,
|
||||||
|
):
|
||||||
|
repo = some_tokens_repo
|
||||||
|
expiration = datetime.now() - timedelta(minutes=5)
|
||||||
|
|
||||||
|
key = repo.get_new_device_key()
|
||||||
|
assert key is not None
|
||||||
|
assert key.expires_at is not None
|
||||||
|
key.expires_at = expiration
|
||||||
|
assert not key.is_valid()
|
||||||
|
repo._store_new_device_key(key)
|
||||||
|
|
||||||
|
with pytest.raises(NewDeviceKeyNotFound):
|
||||||
|
token = repo.use_mnemonic_new_device_key(
|
||||||
|
mnemonic_phrase=mnemonic_from_hex(key.key),
|
||||||
|
device_name="imnew",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_use_mnemonic_new_device_key_when_empty(empty_repo):
|
def test_use_mnemonic_new_device_key_when_empty(empty_repo):
|
||||||
repo = empty_repo
|
repo = empty_repo
|
||||||
|
|
||||||
|
|
|
@ -2,9 +2,17 @@ import pytest
|
||||||
from datetime import datetime, timedelta
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
from selfprivacy_api.models.tokens.recovery_key import RecoveryKey
|
from selfprivacy_api.models.tokens.recovery_key import RecoveryKey
|
||||||
|
from selfprivacy_api.models.tokens.new_device_key import NewDeviceKey
|
||||||
|
|
||||||
|
|
||||||
def test_recovery_key_expired():
|
def test_recovery_key_expired():
|
||||||
expiration = datetime.now() - timedelta(minutes=5)
|
expiration = datetime.now() - timedelta(minutes=5)
|
||||||
key = RecoveryKey.generate(expiration=expiration, uses_left=2)
|
key = RecoveryKey.generate(expiration=expiration, uses_left=2)
|
||||||
assert not key.is_valid()
|
assert not key.is_valid()
|
||||||
|
|
||||||
|
|
||||||
|
def test_new_device_key_expired():
|
||||||
|
expiration = datetime.now() - timedelta(minutes=5)
|
||||||
|
key = NewDeviceKey.generate()
|
||||||
|
key.expires_at = expiration
|
||||||
|
assert not key.is_valid()
|
||||||
|
|
Loading…
Reference in a new issue