From acee329d8d43a493bd37a0084e1d1dac3c3824da Mon Sep 17 00:00:00 2001 From: pierantoniomerlino Date: Fri, 13 Dec 2024 10:21:09 +0100 Subject: [PATCH] Added filtering of WPA3 on hotspot scans Signed-off-by: pierantoniomerlino --- .../META-INF/MANIFEST.MF | 2 +- .../web/client/ui/network/TabWirelessUi.java | 25 +++++++++++++------ 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/kura/org.eclipse.kura.web2/META-INF/MANIFEST.MF b/kura/org.eclipse.kura.web2/META-INF/MANIFEST.MF index 1bcab37272..ac3137becb 100644 --- a/kura/org.eclipse.kura.web2/META-INF/MANIFEST.MF +++ b/kura/org.eclipse.kura.web2/META-INF/MANIFEST.MF @@ -79,7 +79,7 @@ Import-Package: com.eclipsesource.json;version="0.9.5", org.eclipse.kura.security.keystore;version="1.0.0", org.eclipse.kura.security.tamper.detection;version="[1.0,2.0)", org.eclipse.kura.ssl;version="[2.0,3.0)", - org.eclipse.kura.system;version="[1.3,2.0)", + org.eclipse.kura.system;version="[1.9,2.0)", org.eclipse.kura.type;version="[1.0,2.0)", org.eclipse.kura.usb;version="[1.0,2.0)", org.eclipse.kura.util.base;version="[1.0,2.0)", diff --git a/kura/org.eclipse.kura.web2/src/main/java/org/eclipse/kura/web/client/ui/network/TabWirelessUi.java b/kura/org.eclipse.kura.web2/src/main/java/org/eclipse/kura/web/client/ui/network/TabWirelessUi.java index 03fb39c978..272d6ac62a 100644 --- a/kura/org.eclipse.kura.web2/src/main/java/org/eclipse/kura/web/client/ui/network/TabWirelessUi.java +++ b/kura/org.eclipse.kura.web2/src/main/java/org/eclipse/kura/web/client/ui/network/TabWirelessUi.java @@ -17,6 +17,7 @@ import java.util.Collections; import java.util.List; import java.util.Optional; +import java.util.concurrent.atomic.AtomicBoolean; import java.util.logging.Logger; import org.eclipse.kura.system.SystemService; @@ -166,6 +167,7 @@ interface TabWirelessUiUiBinder extends UiBinder { private GwtWifiNetInterfaceConfig selectedNetIfConfig; private String tcp4Status; private String tcp6Status; + private AtomicBoolean isWPA3Supported = new AtomicBoolean(false); GwtWifiConfig activeConfig; GwtWifiChannelModel previousSelection; @@ -922,7 +924,7 @@ private void initForm() { }); // Wireless Security - initWifiSecurityListBox(false); + initWifiSecurityListBox(); // Password this.labelPassword.setText(MSGS.netWifiWirelessPassword()); @@ -1499,9 +1501,16 @@ public void onFailure(Throwable caught) { @Override public void onSuccess(List result) { TabWirelessUi.this.ssidDataProvider.getList().clear(); - for (GwtWifiHotspotEntry pair : result) { - TabWirelessUi.this.ssidDataProvider.getList().add(pair); + if (pair.getSecurity().equals(GwtWifiSecurity.netWifiSecurityWPA3.value()) + || pair.getSecurity() + .equals(GwtWifiSecurity.netWifiSecurityWPA2_WPA3.value())) { + if (TabWirelessUi.this.isWPA3Supported.get()) { + TabWirelessUi.this.ssidDataProvider.getList().add(pair); + } + } else { + TabWirelessUi.this.ssidDataProvider.getList().add(pair); + } } TabWirelessUi.this.ssidDataProvider.flush(); if (!TabWirelessUi.this.ssidDataProvider.getList().isEmpty()) { @@ -1885,7 +1894,8 @@ public void onSuccess(List result) { .findFirst(); if (wpa3SupportPair.isPresent() && Boolean.parseBoolean(wpa3SupportPair.get().getValue())) { - initWifiSecurityListBox(true); + TabWirelessUi.this.isWPA3Supported.set(true); + initWifiSecurityListBox(); } } }); @@ -1893,12 +1903,13 @@ public void onSuccess(List result) { }); } - private void initWifiSecurityListBox(boolean isWPA3WifiSecuritySupported) { + private void initWifiSecurityListBox() { this.labelSecurity.setText(MSGS.netWifiWirelessSecurity()); this.security.addMouseOverHandler(event -> { if (TabWirelessUi.this.security.isEnabled()) { TabWirelessUi.this.helpText.clear(); - TabWirelessUi.this.helpText.add(new Span(composeNetWifiToolTipSecurity(isWPA3WifiSecuritySupported))); + TabWirelessUi.this.helpText + .add(new Span(composeNetWifiToolTipSecurity(TabWirelessUi.this.isWPA3Supported.get()))); } }); this.security.addMouseOutHandler(event -> resetHelp()); @@ -1906,7 +1917,7 @@ private void initWifiSecurityListBox(boolean isWPA3WifiSecuritySupported) { for (GwtWifiSecurity mode : GwtWifiSecurity.values()) { if (mode.equals(GwtWifiSecurity.netWifiSecurityWPA3) || mode.equals(GwtWifiSecurity.netWifiSecurityWPA2_WPA3)) { - if (isWPA3WifiSecuritySupported) { + if (TabWirelessUi.this.isWPA3Supported.get()) { this.security.addItem(MessageUtils.get(mode.name())); } } else {