From 1753b9f87d9102493f3fb61a22f5f612fe5cf9c1 Mon Sep 17 00:00:00 2001 From: Gururaaja E S R Date: Fri, 9 Aug 2024 21:11:54 +0000 Subject: [PATCH] RDK-49931 - Refactor LNF Thunder Plugin to use NetworkManager Thunder Library Reason for change: Added additional security parameter in WiFiConnect for EAP authentication Test Procedure: use curl command to check the functionality of LNF plugin Risks: Low Priority: P1 Signed-off-by: Gururaaja ESR --- NetworkManager/INetworkManager.h | 2 ++ NetworkManager/NetworkManagerJsonRpc.cpp | 5 ++++- NetworkManager/NetworkManagerRDKProxy.cpp | 2 ++ 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/NetworkManager/INetworkManager.h b/NetworkManager/INetworkManager.h index 4f5ae86f69..91c17fc54f 100644 --- a/NetworkManager/INetworkManager.h +++ b/NetworkManager/INetworkManager.h @@ -134,6 +134,7 @@ namespace WPEFramework string m_clientCert; string m_privateKey; string m_privateKeyPasswd; + bool m_saveSSID; }; struct EXTERNAL WiFiSSIDInfo { @@ -297,6 +298,7 @@ namespace WPEFramework // Allow other processes to register/unregister from our notifications virtual uint32_t Register(INetworkManager::INotification* notification) = 0; virtual uint32_t Unregister(INetworkManager::INotification* notification) = 0; + bool m_defaultSaveSSID = true; }; } } diff --git a/NetworkManager/NetworkManagerJsonRpc.cpp b/NetworkManager/NetworkManagerJsonRpc.cpp index 8c2ab1142d..5cb89ebc6d 100644 --- a/NetworkManager/NetworkManagerJsonRpc.cpp +++ b/NetworkManager/NetworkManagerJsonRpc.cpp @@ -820,7 +820,10 @@ namespace WPEFramework ssid.m_privateKey = parameters["privateKey"].String(); if (parameters.HasLabel("privateKeyPasswd")) ssid.m_privateKeyPasswd = parameters["privateKeyPasswd"].String(); - + if (parameters.HasLabel("saveSSID")) + ssid.m_saveSSID = parameters["saveSSID"].Boolean(); + else + ssid.m_saveSSID = _NetworkManager->m_defaultSaveSSID; if (_NetworkManager) rc = _NetworkManager->WiFiConnect(ssid); else diff --git a/NetworkManager/NetworkManagerRDKProxy.cpp b/NetworkManager/NetworkManagerRDKProxy.cpp index ec4b95bdd5..c5614a58a3 100644 --- a/NetworkManager/NetworkManagerRDKProxy.cpp +++ b/NetworkManager/NetworkManagerRDKProxy.cpp @@ -236,6 +236,7 @@ typedef struct _WiFiConnection char carootcert[MAX_FILE_PATH_LEN]; char clientcert[MAX_FILE_PATH_LEN]; char privatekey[MAX_FILE_PATH_LEN]; + bool saveSSID; } WiFiConnection; typedef struct _WiFiConnectedSSIDInfo @@ -1131,6 +1132,7 @@ const string CIDR_PREFIXES[CIDR_NETMASK_IP_LEN] = { ssid.m_clientCert.copy(param.data.connect.clientcert, sizeof(param.data.connect.clientcert) - 1); if(!ssid.m_privateKey.empty()) ssid.m_privateKey.copy(param.data.connect.privatekey, sizeof(param.data.connect.privatekey) - 1); + param.data.connect.saveSSID = ssid.m_saveSSID; } retVal = IARM_Bus_Call( IARM_BUS_NM_SRV_MGR_NAME, IARM_BUS_WIFI_MGR_API_connect, (void *)¶m, sizeof(param));