From 514ff5b04cae9a3fbdc84a1042886b333c529e55 Mon Sep 17 00:00:00 2001 From: Ben Francis Date: Thu, 10 Oct 2024 18:50:01 +0100 Subject: [PATCH] Better error handling when getting IP addresses --- src/platforms/linux-ubuntu.ts | 53 ++++++++++++++++++++++++----------- 1 file changed, 37 insertions(+), 16 deletions(-) diff --git a/src/platforms/linux-ubuntu.ts b/src/platforms/linux-ubuntu.ts index c1f9b3bc8..ceb8affed 100644 --- a/src/platforms/linux-ubuntu.ts +++ b/src/platforms/linux-ubuntu.ts @@ -222,6 +222,40 @@ class LinuxUbuntuPlatform extends BasePlatform { }); } + /** + * Get the IP address of the first Ethernet adapter. + * + * @returns {Promise} A Promise which resolves with the IP address as + * a string or an empty string. + */ + private async getEthernetIpAddress(): Promise { + return this.getEthernetDevices().then((ethernetDevices) => { + return this.getDeviceIp4Config(ethernetDevices[0]); + }).then((ethernetIp4Config) => { + return ethernetIp4Config[0].address; + }).catch(() => { + console.log(`Unable to get detect Ethernet IP address.`); + return ''; + }); + } + + /** + * Get the IP address of the first Wi-Fi adapter. + * + * @returns {Promise} A Promise which resolves with the IP address as + * a string or an empty string. + */ + private async getWifiIpAddress(): Promise { + return this.getWifiDevices().then((wifiDevices) => { + return this.getDeviceIp4Config(wifiDevices[0]); + }).then((wifiIp4Config) => { + return wifiIp4Config[0].address; + }).catch(() => { + console.log(`Unable to get detect Wi-Fi IP address.`); + return ''; + }); + } + /** * Get the LAN mode and options. * @@ -264,8 +298,6 @@ class LinuxUbuntuPlatform extends BasePlatform { * } */ async getNetworkAddressesAsync(): Promise { - // TODO: Handle the case where there is no Ethernet adapter or no Wi-Fi - // adapter or one of them isn't assigned an IP let result: NetworkAddresses = { lan: '', wlan: { @@ -273,20 +305,9 @@ class LinuxUbuntuPlatform extends BasePlatform { ssid: '' } }; - return this.getEthernetDevices().then((ethernetDevices) => { - return this.getDeviceIp4Config(ethernetDevices[0]); - }).then((ethernetIp4Config) => { - result.lan = ethernetIp4Config[0].address; - return this.getWifiDevices(); - }).then((wifiDevices) => { - return this.getDeviceIp4Config(wifiDevices[0]); - }).then((wifiIp4Config) => { - result.wlan.ip = wifiIp4Config[0].address; - return result; - }).catch((error) => { - console.error('Error getting IP addresses from NetworkManager: ' + error); - return result; - }); + result.lan = await this.getEthernetIpAddress(); + result.wlan.ip = await this.getWifiIpAddress(); + return result; } // Currently unused code...