From 658295361b5c8b92123e02d637943d40e18adb85 Mon Sep 17 00:00:00 2001 From: "Ian C." <108159253+ic-dev21@users.noreply.github.com> Date: Mon, 28 Oct 2024 21:11:31 -0400 Subject: [PATCH 1/2] Extra logging and remove hardcoding --- pyhilo/api.py | 18 ++++++++++++++---- pyhilo/websocket.py | 2 +- 2 files changed, 15 insertions(+), 5 deletions(-) mode change 100644 => 100755 pyhilo/api.py mode change 100644 => 100755 pyhilo/websocket.py diff --git a/pyhilo/api.py b/pyhilo/api.py old mode 100644 new mode 100755 index 29d37bb..761e23f --- a/pyhilo/api.py +++ b/pyhilo/api.py @@ -364,10 +364,11 @@ async def refresh_ws_token(self) -> None: async def post_devicehub_negociate(self) -> tuple[str, str]: LOG.debug("Getting websocket url") url = f"{AUTOMATION_DEVICEHUB_ENDPOINT}/negotiate" + LOG.debug(f"devicehub URL is {url}") resp = await self.async_request("post", url) ws_url = resp.get("url") ws_token = resp.get("accessToken") - LOG.debug("Calling set_state") + LOG.debug("Calling set_state devicehub_negotiate") await set_state( self._state_yaml, "websocket", @@ -381,6 +382,7 @@ async def post_devicehub_negociate(self) -> tuple[str, str]: async def get_websocket_params(self) -> None: uri = parse.urlparse(self.ws_url) LOG.debug("Getting websocket params") + LOG.debug(f"Getting uri {uri}") resp: dict[str, Any] = await self.async_request( "post", f"{uri.path}negotiate?{uri.query}", @@ -391,6 +393,7 @@ async def get_websocket_params(self) -> None: ) conn_id: str = resp.get("connectionId", "") self.full_ws_url = f"{self.ws_url}&id={conn_id}&access_token={self.ws_token}" + LOG.debug(f"Getting full ws URL {self.full_ws_url}") transport_dict: list[WebsocketTransportsDict] = resp.get( "availableTransports", [] ) @@ -399,7 +402,7 @@ async def get_websocket_params(self) -> None: "available_transports": transport_dict, "full_ws_url": self.full_ws_url, } - LOG.debug("Calling set_state") + LOG.debug("Calling set_state websocket_params") await set_state(self._state_yaml, "websocket", websocket_dict) async def fb_install(self, fb_id: str) -> None: @@ -425,7 +428,7 @@ async def fb_install(self, fb_id: str) -> None: raise RequestError(err) from err LOG.debug(f"FB Install data: {resp}") auth_token = resp.get("authToken", {}) - LOG.debug("Calling set_state") + LOG.debug("Calling set_state fb_install") await set_state( self._state_yaml, "firebase", @@ -467,7 +470,7 @@ async def android_register(self) -> None: LOG.error(f"Android registration error: {msg}") raise RequestError token = msg.split("=")[-1] - LOG.debug("Calling set_state") + LOG.debug("Calling set_state android_register") await set_state( self._state_yaml, "android", @@ -478,12 +481,14 @@ async def android_register(self) -> None: async def get_location_id(self) -> int: url = f"{API_AUTOMATION_ENDPOINT}/Locations" + LOG.debug(f"LocationId URL is {url}") req: list[dict[str, Any]] = await self.async_request("get", url) return int(req[0]["id"]) async def get_devices(self, location_id: int) -> list[dict[str, Any]]: """Get list of all devices""" url = self._get_url("Devices", location_id) + LOG.debug(f"Devices URL is {url}") devices: list[dict[str, Any]] = await self.async_request("get", url) devices.append(await self.get_gateway(location_id)) # Now it's time to add devices coming from external sources like hass @@ -499,6 +504,7 @@ async def _set_device_attribute( value: Union[str, float, int, None], ) -> None: url = self._get_url(f"Devices/{device.id}/Attributes", device.location_id) + LOG.debug(f"Device Attribute URL is {url}") await self.async_request("put", url, json={key.hilo_attribute: value}) async def get_event_notifications(self, location_id: int) -> dict[str, Any]: @@ -526,6 +532,7 @@ async def get_event_notifications(self, location_id: int) -> dict[str, Any]: "viewed": false }""" url = self._get_url(None, location_id, events=True) + LOG.debug(f"Event Notifications URL is {url}") return cast(dict[str, Any], await self.async_request("get", url)) async def get_gd_events( @@ -597,6 +604,8 @@ async def get_gd_events( url += "?active=true" else: url += f"/{event_id}" + + LOG.debug(f"get_gd_events URL is {url}") return cast(dict[str, Any], await self.async_request("get", url)) async def get_seasons(self, location_id: int) -> dict[str, Any]: @@ -624,6 +633,7 @@ async def get_seasons(self, location_id: int) -> dict[str, Any]: async def get_gateway(self, location_id: int) -> dict[str, Any]: url = self._get_url("Gateways/Info", location_id) + LOG.debug(f"Gateway URL is {url}") req = await self.async_request("get", url) saved_attrs = [ "zigBeePairingActivated", diff --git a/pyhilo/websocket.py b/pyhilo/websocket.py old mode 100644 new mode 100755 index a49c900..7af61b4 --- a/pyhilo/websocket.py +++ b/pyhilo/websocket.py @@ -281,7 +281,7 @@ async def async_connect(self) -> None: try: self._client = await self._api.session.ws_connect( URL( - self._api.full_ws_url.replace("/DeviceHub", "%2FDeviceHub"), + self._api.full_ws_url, #self._api.full_ws_url.replace("/DeviceHub", "%2FDeviceHub") encoded=True, ), heartbeat=55, From d9a1174cf3276c244cc618bbb874ad5047d76bbe Mon Sep 17 00:00:00 2001 From: "Ian C." <108159253+ic-dev21@users.noreply.github.com> Date: Thu, 31 Oct 2024 19:42:59 -0400 Subject: [PATCH 2/2] Remove comment --- pyhilo/websocket.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyhilo/websocket.py b/pyhilo/websocket.py index 7af61b4..ee2b6fc 100755 --- a/pyhilo/websocket.py +++ b/pyhilo/websocket.py @@ -281,7 +281,7 @@ async def async_connect(self) -> None: try: self._client = await self._api.session.ws_connect( URL( - self._api.full_ws_url, #self._api.full_ws_url.replace("/DeviceHub", "%2FDeviceHub") + self._api.full_ws_url, encoded=True, ), heartbeat=55,