From c0c4211375410bc40aa524dfb711cadc8b917e32 Mon Sep 17 00:00:00 2001 From: elraro Date: Fri, 5 Jan 2024 00:42:04 +0100 Subject: [PATCH] fix: attempt to try fix #93 --- .../LinuxWifiConfigurationCapability.js | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/backend/lib/robots/common/linuxCapabilities/LinuxWifiConfigurationCapability.js b/backend/lib/robots/common/linuxCapabilities/LinuxWifiConfigurationCapability.js index d2aeb164..80d0c0c9 100644 --- a/backend/lib/robots/common/linuxCapabilities/LinuxWifiConfigurationCapability.js +++ b/backend/lib/robots/common/linuxCapabilities/LinuxWifiConfigurationCapability.js @@ -36,8 +36,13 @@ class LinuxWifiConfigurationCapability extends WifiConfigurationCapability { :-) */ - const iwOutput = spawnSync("iw", ["dev", this.networkInterface, "link"]).stdout.toString(); - const wifiStatus = this.parseIwStdout(iwOutput); + const iwOutput = spawnSync("iw", ["dev", this.networkInterface, "link"]).stdout; + let wifiStatus; + if (iwOutput !== null) { + wifiStatus = this.parseIwStdout(iwOutput.toString()); + } else { + wifiStatus = this.parseIwStdout(""); + } //IPs are not part of the iw output if (wifiStatus.state === ValetudoWifiStatus.STATE.CONNECTED) { @@ -46,7 +51,9 @@ class LinuxWifiConfigurationCapability extends WifiConfigurationCapability { }); } + // @ts-ignore return wifiStatus; + } /** @@ -54,6 +61,7 @@ class LinuxWifiConfigurationCapability extends WifiConfigurationCapability { * @returns {Promise} * @abstract */ + // @ts-ignore async setWifiConfiguration(wifiConfig) { throw new NotImplementedError(); } @@ -71,6 +79,7 @@ class LinuxWifiConfigurationCapability extends WifiConfigurationCapability { const connectedMatch = stdout.match(WIFI_CONNECTED_IW_REGEX); if (connectedMatch) { + // @ts-ignore output.state = ValetudoWifiStatus.STATE.CONNECTED; output.details.bssid = connectedMatch.groups.bssid.trim(); @@ -108,6 +117,7 @@ class LinuxWifiConfigurationCapability extends WifiConfigurationCapability { output.details.frequency = ValetudoWifiStatus.FREQUENCY_TYPE.W2_4Ghz; } else if (stdout.trim().match(WIFI_NOT_CONNECTED_IW_REGEX)) { + // @ts-ignore output.state = ValetudoWifiStatus.STATE.NOT_CONNECTED; }