Retry query on 403 after succesful handshake (#785)

If a handshake session becomes invalid the device returns 403 on send and an `AuthenticationError` is raised which prevents a retry, however a retry would be successful.  In HA this causes devices to go into reauth flow which is not necessary.
This commit is contained in:
Steven B 2024-02-22 17:02:03 +00:00 committed by GitHub
parent d9d2f1a430
commit a87fc3b766
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 3 additions and 3 deletions

View File

@ -57,7 +57,7 @@ from yarl import URL
from .credentials import Credentials from .credentials import Credentials
from .deviceconfig import DeviceConfig from .deviceconfig import DeviceConfig
from .exceptions import AuthenticationError, KasaException from .exceptions import AuthenticationError, KasaException, _RetryableError
from .httpclient import HttpClient from .httpclient import HttpClient
from .json import loads as json_loads from .json import loads as json_loads
from .protocol import DEFAULT_CREDENTIALS, BaseTransport, get_default_credentials, md5 from .protocol import DEFAULT_CREDENTIALS, BaseTransport, get_default_credentials, md5
@ -337,7 +337,7 @@ class KlapTransport(BaseTransport):
# If we failed with a security error, force a new handshake next time. # If we failed with a security error, force a new handshake next time.
if response_status == 403: if response_status == 403:
self._handshake_done = False self._handshake_done = False
raise AuthenticationError( raise _RetryableError(
f"Got a security error from {self._host} after handshake " f"Got a security error from {self._host} after handshake "
+ "completed" + "completed"
) )

View File

@ -417,7 +417,7 @@ async def test_query(mocker):
pytest.param( pytest.param(
(200, 200, 403), (200, 200, 403),
True, True,
pytest.raises(AuthenticationError), pytest.raises(_RetryableError),
id="request-403-status", id="request-403-status",
), ),
pytest.param( pytest.param(