From e6694b703310fbeb50645a318f318bd60d8f7a3e Mon Sep 17 00:00:00 2001 From: nicolatimeus Date: Fri, 8 Nov 2024 16:36:44 +0100 Subject: [PATCH] fix: Ignore modem state when getting position from MM (#5532) Signed-off-by: Nicola Timeus --- .../org/eclipse/kura/nm/NMDbusConnector.java | 21 ++++++------------- 1 file changed, 6 insertions(+), 15 deletions(-) diff --git a/kura/org.eclipse.kura.nm/src/main/java/org/eclipse/kura/nm/NMDbusConnector.java b/kura/org.eclipse.kura.nm/src/main/java/org/eclipse/kura/nm/NMDbusConnector.java index 8709612ca3..bb77920035 100644 --- a/kura/org.eclipse.kura.nm/src/main/java/org/eclipse/kura/nm/NMDbusConnector.java +++ b/kura/org.eclipse.kura.nm/src/main/java/org/eclipse/kura/nm/NMDbusConnector.java @@ -33,7 +33,6 @@ import org.eclipse.kura.net.wifi.WifiChannel; import org.eclipse.kura.nm.configuration.NMSettingsConverter; import org.eclipse.kura.nm.enums.MMModemLocationSource; -import org.eclipse.kura.nm.enums.MMModemState; import org.eclipse.kura.nm.enums.NMDeviceState; import org.eclipse.kura.nm.enums.NMDeviceType; import org.eclipse.kura.nm.signal.handlers.DeviceCreationLock; @@ -650,7 +649,7 @@ private void configurationEnforcementDisable() throws DBusException { public List getAvailableMMLocations() { List availableLocations = new ArrayList<>(); - this.getEnabledModemsPaths().forEach(modemPath -> { + this.getModemsPaths().forEach(modemPath -> { try { Properties locationProperties = this.modemManager .getLocationProperties(this.modemManager.getModemManagerLocation(modemPath)); @@ -671,30 +670,22 @@ public List getAvailableMMLocations() { } - private List getEnabledModemsPaths() { - List enabledModemsPath = new ArrayList<>(); + private List getModemsPaths() { + List modemsPath = new ArrayList<>(); try { for (Device device : this.networkManager.getAllDevices()) { if (networkManager.getDeviceType(device.getObjectPath()).equals(NMDeviceType.NM_DEVICE_TYPE_MODEM)) { Optional modemPath = this.networkManager.getModemManagerDbusPath(device.getObjectPath()); - if (modemPath.isPresent()) { - Optional modemProps = this.modemManager.getModemProperties(modemPath.get()); - modemProps.ifPresent(props -> { - MMModemState modemState = this.modemManager.getMMModemState(props); - if (modemState.equals(MMModemState.MM_MODEM_STATE_CONNECTED) - || modemState.equals(MMModemState.MM_MODEM_STATE_REGISTERED)) { - enabledModemsPath.add(modemPath.get()); - } - }); - } + + modemPath.ifPresent(modemsPath::add); } } } catch (DBusException ex) { logger.debug("Impossible to retrieve information regarding available modems"); } - return enabledModemsPath; + return modemsPath; } }