diff --git a/src/sfrbox_api/bridge.py b/src/sfrbox_api/bridge.py
index ac6c887..d950cb6 100644
--- a/src/sfrbox_api/bridge.py
+++ b/src/sfrbox_api/bridge.py
@@ -38,7 +38,7 @@
def _with_error_wrapping(
- func: Callable[_P, Awaitable[_R]]
+ func: Callable[_P, Awaitable[_R]],
) -> Callable[_P, Coroutine[Any, Any, _R]]:
"""Catch httpx errors."""
@@ -69,7 +69,9 @@ def __init__(self, *, ip: str, client: httpx.AsyncClient) -> None:
self._ip = ip
self._client = client
- async def authenticate(self, *, username: str = "admin", password: str) -> None:
+ async def authenticate(
+ self, *, username: str = "admin", password: str
+ ) -> None:
"""Initialise le token pour pouvoir accéder aux méthodes privées de l'API."""
self._username = username
self._password = password
@@ -95,7 +97,9 @@ async def _get_token(self) -> str:
)
token = element.get("token", "")
hash = compute_hash(token, self._username, self._password)
- element = await self._send_get("auth", "checkToken", token=token, hash=hash)
+ element = await self._send_get(
+ "auth", "checkToken", token=token, hash=hash
+ )
assert element is not None # noqa: S101
return element.get("token", "")
@@ -118,7 +122,9 @@ def _check_response(self, response: httpx.Response) -> XmlElement:
try:
element: XmlElement = DefusedElementTree.fromstring(response_text)
except Exception as exc:
- raise SFRBoxError(f"Failed to parse response: {response_text}") from exc
+ raise SFRBoxError(
+ f"Failed to parse response: {response_text}"
+ ) from exc
stat = element.get("stat", "")
if (
stat == "fail"
@@ -129,7 +135,9 @@ def _check_response(self, response: httpx.Response) -> XmlElement:
if code in {"115", "204", "901"}:
# Reset token on auth failure
self._token = None
- raise SFRBoxAuthenticationError(f"Api call failed: [{code}] {msg}")
+ raise SFRBoxAuthenticationError(
+ f"Api call failed: [{code}] {msg}"
+ )
raise SFRBoxApiError(f"Api call failed: [{code}] {msg}")
if stat != "ok":
raise SFRBoxError(f"Response was not ok: {response_text}")
@@ -140,7 +148,9 @@ async def _send_get_simple(
self, namespace: str, method: str, **kwargs: str
) -> XmlElement:
params = httpx.QueryParams(method=f"{namespace}.{method}", **kwargs)
- response = await self._client.get(f"http://{self._ip}/api/1.0/", params=params)
+ response = await self._client.get(
+ f"http://{self._ip}/api/1.0/", params=params
+ )
element = self._check_response(response)
return element
@@ -149,7 +159,9 @@ async def _send_get(
self, namespace: str, method: str, **kwargs: str
) -> XmlElement | None:
params = httpx.QueryParams(method=f"{namespace}.{method}", **kwargs)
- response = await self._client.get(f"http://{self._ip}/api/1.0/", params=params)
+ response = await self._client.get(
+ f"http://{self._ip}/api/1.0/", params=params
+ )
element = self._check_response(response)
if len(element) == 0:
return None
@@ -211,10 +223,14 @@ async def wan_get_info(self) -> WanInfo | None:
async def wlan_get_client_list(self) -> WlanClientList:
"""Liste des clients WiFi."""
token = await self._ensure_token()
- xml_response = await self._send_get_simple("wlan", "getClientList", token=token)
+ xml_response = await self._send_get_simple(
+ "wlan", "getClientList", token=token
+ )
client_elements = xml_response.findall("client")
return WlanClientList(
- clients=[WlanClient(**element.attrib) for element in client_elements]
+ clients=[
+ WlanClient(**element.attrib) for element in client_elements
+ ]
)
async def wlan_get_info(self) -> WlanInfo:
diff --git a/src/sfrbox_api/cli/__main__.py b/src/sfrbox_api/cli/__main__.py
index d37fd43..a892718 100644
--- a/src/sfrbox_api/cli/__main__.py
+++ b/src/sfrbox_api/cli/__main__.py
@@ -1,4 +1,5 @@
"""Command-line interface."""
+
import click
diff --git a/src/sfrbox_api/helpers.py b/src/sfrbox_api/helpers.py
index 29c00a8..155b469 100644
--- a/src/sfrbox_api/helpers.py
+++ b/src/sfrbox_api/helpers.py
@@ -1,4 +1,5 @@
"""SFR Box helpers."""
+
import hashlib
import hmac
diff --git a/src/sfrbox_api/models.py b/src/sfrbox_api/models.py
index 6af493f..90e63ca 100644
--- a/src/sfrbox_api/models.py
+++ b/src/sfrbox_api/models.py
@@ -12,7 +12,7 @@
def _empty_to_none(
- v: Union[float, int, str, None]
+ v: Union[float, int, str, None],
) -> Optional[Union[float, int, str, None]]:
return None if v == "" else v
@@ -22,7 +22,9 @@ class DslInfo:
"""Informations sur le lien ADSL."""
# validators
- _empty_to_none = validator("uptime", pre=True, allow_reuse=True)(_empty_to_none)
+ _empty_to_none = validator("uptime", pre=True, allow_reuse=True)(
+ _empty_to_none
+ )
linemode: str
"""Mode du lien.
diff --git a/tests/cli/test_main.py b/tests/cli/test_main.py
index 3aad306..45052fd 100644
--- a/tests/cli/test_main.py
+++ b/tests/cli/test_main.py
@@ -1,4 +1,5 @@
"""Test cases for the __main__ module."""
+
import pytest
from click.testing import CliRunner
diff --git a/tests/test_bridge.py b/tests/test_bridge.py
index 010a6a9..cc74ebd 100644
--- a/tests/test_bridge.py
+++ b/tests/test_bridge.py
@@ -23,7 +23,9 @@
def _load_fixture(filename: str) -> str:
- return pathlib.Path(__file__).parent.joinpath("fixtures", filename).read_text()
+ return (
+ pathlib.Path(__file__).parent.joinpath("fixtures", filename).read_text()
+ )
@respx.mock
@@ -71,7 +73,9 @@ async def test_authenticate_invalid_password() -> None:
box._token = "previous_token" # noqa: S105
with pytest.raises(
SFRBoxAuthenticationError,
- match=re.escape("Api call failed: [204] Invalid login and/or password"),
+ match=re.escape(
+ "Api call failed: [204] Invalid login and/or password"
+ ),
):
await box.authenticate(password="invalid_password") # noqa: S106
assert box._username == "admin"
@@ -85,7 +89,9 @@ async def test_authenticate_no_credentials() -> None:
"""It exits with a status code of zero."""
async with httpx.AsyncClient() as client:
box = SFRBox(ip="192.168.0.1", client=client)
- with pytest.raises(SFRBoxAuthenticationError, match="Credentials not set"):
+ with pytest.raises(
+ SFRBoxAuthenticationError, match="Credentials not set"
+ ):
await box._ensure_token()
@@ -341,8 +347,12 @@ async def test_wlan_getclientlist() -> None:
info = await box.wlan_get_client_list()
assert info == WlanClientList(
clients=[
- WlanClient(mac_addr="01:02:03:04:05:06", ip_addr="192.168.1.23"),
- WlanClient(mac_addr="06:07:08:09:10:11", ip_addr="192.168.1.24"),
+ WlanClient(
+ mac_addr="01:02:03:04:05:06", ip_addr="192.168.1.23"
+ ),
+ WlanClient(
+ mac_addr="06:07:08:09:10:11", ip_addr="192.168.1.24"
+ ),
]
)
@@ -385,7 +395,9 @@ async def test_wan_getinfo_fail() -> None:
box = SFRBox(ip="192.168.0.1", client=client)
with pytest.raises(
SFRBoxApiError,
- match=re.escape("Api call failed: [[code-erreur]] [message-erreur]"),
+ match=re.escape(
+ "Api call failed: [[code-erreur]] [message-erreur]"
+ ),
):
await box.wan_get_info()
@@ -399,7 +411,9 @@ async def test_wan_getinfo_invalid_xml() -> None:
)
async with httpx.AsyncClient() as client:
box = SFRBox(ip="192.168.0.1", client=client)
- with pytest.raises(SFRBoxError, match="Failed to parse response: Invalid XML"):
+ with pytest.raises(
+ SFRBoxError, match="Failed to parse response: Invalid XML"
+ ):
await box.wan_get_info()
@@ -412,7 +426,9 @@ async def test_wan_getinfo_incorrect_xml() -> None:
)
async with httpx.AsyncClient() as client:
box = SFRBox(ip="192.168.0.1", client=client)
- with pytest.raises(SFRBoxError, match="Response was not ok: "):
+ with pytest.raises(
+ SFRBoxError, match="Response was not ok: "
+ ):
await box.wan_get_info()
@@ -425,7 +441,9 @@ async def test_wan_getinfo_incorrect_namespace() -> None:
)
async with httpx.AsyncClient() as client:
box = SFRBox(ip="192.168.0.1", client=client)
- with pytest.raises(SFRBoxError, match="Namespace wan not found in response"):
+ with pytest.raises(
+ SFRBoxError, match="Namespace wan not found in response"
+ ):
await box.wan_get_info()
diff --git a/tests/test_helper.py b/tests/test_helper.py
index 4b9b256..3ff6d94 100644
--- a/tests/test_helper.py
+++ b/tests/test_helper.py
@@ -1,4 +1,5 @@
"""Test cases for the __main__ module."""
+
from sfrbox_api.helpers import compute_hash