python-roborock 2.16.0__tar.gz → 2.16.1__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. {python_roborock-2.16.0 → python_roborock-2.16.1}/PKG-INFO +1 -1
  2. {python_roborock-2.16.0 → python_roborock-2.16.1}/pyproject.toml +1 -1
  3. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/web_api.py +9 -6
  4. {python_roborock-2.16.0 → python_roborock-2.16.1}/LICENSE +0 -0
  5. {python_roborock-2.16.0 → python_roborock-2.16.1}/README.md +0 -0
  6. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/__init__.py +0 -0
  7. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/api.py +0 -0
  8. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/cli.py +0 -0
  9. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/cloud_api.py +0 -0
  10. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/code_mappings.py +0 -0
  11. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/command_cache.py +0 -0
  12. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/const.py +0 -0
  13. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/containers.py +0 -0
  14. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/exceptions.py +0 -0
  15. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/local_api.py +0 -0
  16. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/protocol.py +0 -0
  17. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/py.typed +0 -0
  18. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/roborock_future.py +0 -0
  19. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/roborock_message.py +0 -0
  20. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/roborock_typing.py +0 -0
  21. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/util.py +0 -0
  22. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_1_apis/__init__.py +0 -0
  23. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_1_apis/roborock_client_v1.py +0 -0
  24. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_1_apis/roborock_local_client_v1.py +0 -0
  25. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_1_apis/roborock_mqtt_client_v1.py +0 -0
  26. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_a01_apis/__init__.py +0 -0
  27. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_a01_apis/roborock_client_a01.py +0 -0
  28. {python_roborock-2.16.0 → python_roborock-2.16.1}/roborock/version_a01_apis/roborock_mqtt_client_a01.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: python-roborock
3
- Version: 2.16.0
3
+ Version: 2.16.1
4
4
  Summary: A package to control Roborock vacuums.
5
5
  Home-page: https://github.com/humbertogontijo/python-roborock
6
6
  License: GPL-3.0-only
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "python-roborock"
3
- version = "2.16.0"
3
+ version = "2.16.1"
4
4
  description = "A package to control Roborock vacuums."
5
5
  authors = ["humbertogontijo <humbertogontijo@users.noreply.github.com>"]
6
6
  license = "GPL-3.0-only"
@@ -36,8 +36,6 @@ class RoborockApiClient:
36
36
  self._default_url = "https://euiot.roborock.com"
37
37
  self.base_url = base_url
38
38
  self._device_identifier = secrets.token_urlsafe(16)
39
- if session is None:
40
- session = aiohttp.ClientSession()
41
39
  self.session = session
42
40
 
43
41
  async def _get_base_url(self) -> str:
@@ -470,7 +468,9 @@ class RoborockApiClient:
470
468
 
471
469
 
472
470
  class PreparedRequest:
473
- def __init__(self, base_url: str, session: aiohttp.ClientSession, base_headers: dict | None = None) -> None:
471
+ def __init__(
472
+ self, base_url: str, session: aiohttp.ClientSession | None = None, base_headers: dict | None = None
473
+ ) -> None:
474
474
  self.base_url = base_url
475
475
  self.base_headers = base_headers or {}
476
476
  self.session = session
@@ -478,10 +478,10 @@ class PreparedRequest:
478
478
  async def request(self, method: str, url: str, params=None, data=None, headers=None, json=None) -> dict:
479
479
  _url = "/".join(s.strip("/") for s in [self.base_url, url])
480
480
  _headers = {**self.base_headers, **(headers or {})}
481
+ close_session = self.session is None
482
+ session = self.session if self.session is not None else aiohttp.ClientSession()
481
483
  try:
482
- async with self.session.request(
483
- method, _url, params=params, data=data, headers=_headers, json=json
484
- ) as resp:
484
+ async with session.request(method, _url, params=params, data=data, headers=_headers, json=json) as resp:
485
485
  return await resp.json()
486
486
  except ContentTypeError as err:
487
487
  """If we get an error, lets log everything for debugging."""
@@ -494,3 +494,6 @@ class PreparedRequest:
494
494
  _LOGGER.info("Resp raw: %s", resp_raw)
495
495
  # Still raise the err so that it's clear it failed.
496
496
  raise err
497
+ finally:
498
+ if close_session:
499
+ await session.close()