|
@@ -26,6 +26,7 @@ from bleak_retry_connector import (
|
|
from ..const import DEFAULT_RETRY_COUNT, DEFAULT_SCAN_TIMEOUT
|
|
from ..const import DEFAULT_RETRY_COUNT, DEFAULT_SCAN_TIMEOUT
|
|
from ..discovery import GetSwitchbotDevices
|
|
from ..discovery import GetSwitchbotDevices
|
|
from ..models import SwitchBotAdvertisement
|
|
from ..models import SwitchBotAdvertisement
|
|
|
|
+from ..util import execute_task
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
@@ -48,7 +49,6 @@ DISCONNECT_DELAY = 8.5
|
|
|
|
|
|
|
|
|
|
class ColorMode(Enum):
|
|
class ColorMode(Enum):
|
|
-
|
|
|
|
OFF = 0
|
|
OFF = 0
|
|
COLOR_TEMP = 1
|
|
COLOR_TEMP = 1
|
|
RGB = 2
|
|
RGB = 2
|
|
@@ -331,7 +331,7 @@ class SwitchbotBaseDevice:
|
|
self._reset_disconnect_timer()
|
|
self._reset_disconnect_timer()
|
|
return
|
|
return
|
|
self._cancel_disconnect_timer()
|
|
self._cancel_disconnect_timer()
|
|
- asyncio.create_task(self._execute_timed_disconnect())
|
|
|
|
|
|
+ execute_task(self._execute_timed_disconnect())
|
|
|
|
|
|
def _cancel_disconnect_timer(self):
|
|
def _cancel_disconnect_timer(self):
|
|
"""Cancel disconnect timer."""
|
|
"""Cancel disconnect timer."""
|
|
@@ -375,7 +375,7 @@ class SwitchbotBaseDevice:
|
|
self._client = None
|
|
self._client = None
|
|
self._read_char = None
|
|
self._read_char = None
|
|
self._write_char = None
|
|
self._write_char = None
|
|
- if client and client.is_connected:
|
|
|
|
|
|
+ if client:
|
|
_LOGGER.debug("%s: Disconnecting", self.name)
|
|
_LOGGER.debug("%s: Disconnecting", self.name)
|
|
await client.disconnect()
|
|
await client.disconnect()
|
|
_LOGGER.debug("%s: Disconnect completed", self.name)
|
|
_LOGGER.debug("%s: Disconnect completed", self.name)
|