Skip to content

Commit

Permalink
wpa changes added
Browse files Browse the repository at this point in the history
  • Loading branch information
cmuhammedrafi committed Dec 26, 2024
1 parent ccc28ee commit b8d5719
Show file tree
Hide file tree
Showing 14 changed files with 644 additions and 85 deletions.
19 changes: 12 additions & 7 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ add_definitions(-DPLUGIN_BUILD_REFERENCE=${PLUGIN_BUILD_REFERENCE})

if(ENABLE_GNOME_NETWORKMANAGER)
pkg_check_modules(GLIB REQUIRED glib-2.0)
pkg_check_modules(GIO REQUIRED gio-2.0)
pkg_check_modules(LIBNM REQUIRED libnm)
else()
find_package(IARMBus REQUIRED)
Expand Down Expand Up @@ -102,12 +103,16 @@ set_target_properties(${MODULE_NAME} PROPERTIES


if(ENABLE_GNOME_NETWORKMANAGER)
target_sources(${MODULE_NAME} PRIVATE NetworkManagerGnomeProxy.cpp
NetworkManagerGnomeWIFI.cpp
NetworkManagerGnomeEvents.cpp
NetworkManagerGnomeUtils.cpp )
target_include_directories(${MODULE_NAME} PRIVATE ${GLIB_INCLUDE_DIRS} ${LIBNM_INCLUDE_DIRS})
target_link_libraries(${MODULE_NAME} PRIVATE ${LIBNM_LIBRARIES})
target_sources(${MODULE_NAME} PRIVATE
gdbus/NetworkManagerGdbusProxy.cpp
gdbus/NetworkManagerGdbusClient.cpp
gdbus/NetworkManagerGdbusEvent.cpp
gdbus/NetworkManagerGdbusMgr.cpp
gdbus/NetworkManagerGdbusWPS.cpp
gdbus/NetworkManagerGdbusUtils.cpp )

target_include_directories(${MODULE_NAME} PRIVATE ${GLIB_INCLUDE_DIRS} ${LIBNM_INCLUDE_DIRS} ${GIO_INCLUDE_DIRS} ${GLIB_INCLUDE_DIRS})
target_link_libraries(${MODULE_NAME} PRIVATE ${GLIB_LIBRARIES} ${GIO_LIBRARIES} uuid)
else()
target_sources(${MODULE_NAME} PRIVATE NetworkManagerRDKProxy.cpp)
target_include_directories(${MODULE_NAME} PRIVATE ${IARMBUS_INCLUDE_DIRS})
Expand Down Expand Up @@ -171,5 +176,5 @@ write_config(PLUGINS LegacyPlugin_WiFiManagerAPIs CLASSNAME WiFiManager LOCATOR

if(ENABLE_UNIT_TESTING)
include(Tests/unit_test/unit_tests.cmake)
include(Tests/raspberrypi/NetworkManagerGdbusTest.cmake)
endif(ENABLE_UNIT_TESTING)
include(Tests/raspberrypi/NetworkManagerGdbusTest.cmake)
2 changes: 1 addition & 1 deletion NetworkManagerLogger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@
#endif

namespace NetworkManagerLogger {
static LogLevel gDefaultLogLevel = INFO_LEVEL;
static LogLevel gDefaultLogLevel = DEBUG_LEVEL;


#ifdef USE_RDK_LOGGER
Expand Down
2 changes: 2 additions & 0 deletions Tests/raspberrypi/NetworkManagerGdbusTest.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ add_executable(${RPI_TEST}
gdbus/NetworkManagerGdbusUtils.cpp
gdbus/NetworkManagerGdbusMgr.cpp
gdbus/NetworkManagerGdbusEvent.cpp
gdbus/NetworkManagerGdbusWPS.cpp
Tests/raspberrypi/NetworkManagerGdbusTest.cpp
)

Expand All @@ -37,3 +38,4 @@ target_include_directories(${RPI_TEST} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR})

# Install the executable to the appropriate location
install(TARGETS ${RPI_TEST} DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
install(TARGETS ${RPI_TEST} DESTINATION ${CMAKE_INSTALL_PREFIX}/lib/${STORAGE_DIRECTORY}/plugins)
71 changes: 62 additions & 9 deletions Tests/raspberrypi/NetworkManagerGdbusTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
#include "NetworkManagerGdbusEvent.h"
#include "INetworkManager.h"
#include "NetworkManagerGdbusUtils.h"
#include "NetworkManagerImplementation.h"
#include "NetworkManagerGdbusWPS.h"
#include <iostream>
#include <thread>
#include <chrono>
Expand All @@ -15,7 +17,46 @@ using namespace WPEFramework::Plugin;
using namespace WPEFramework::Exchange;
using namespace std;

void displayMenu() {
namespace WPEFramework
{
namespace Plugin
{

void NetworkManagerImplementation::ReportInterfaceStateChange(const Exchange::INetworkManager::InterfaceState state, const string interface)
{
NMLOG_INFO("calling 'ReportInterfaceStateChange' cb");
}
void NetworkManagerImplementation::ReportActiveInterfaceChange(const string prevActiveInterface, const string currentActiveinterface)
{
NMLOG_INFO("calling 'ReportActiveInterfaceChange' cb");
}
void NetworkManagerImplementation::ReportIPAddressChange(const string interface, const string ipversion, const string ipaddress, const Exchange::INetworkManager::IPStatus status)
{
NMLOG_INFO("calling 'ReportIPAddressChange' cb");
}
void NetworkManagerImplementation::ReportInternetStatusChange(const Exchange::INetworkManager::InternetStatus prevState, const Exchange::INetworkManager::InternetStatus currState)
{
NMLOG_INFO("calling 'ReportInternetStatusChange' cb");
}
void NetworkManagerImplementation::ReportAvailableSSIDs(JsonArray &arrayofWiFiScanResults)
{
NMLOG_INFO("calling 'ReportAvailableSSIDs' cb");
}
void NetworkManagerImplementation::ReportWiFiStateChange(const Exchange::INetworkManager::WiFiState state)
{
NMLOG_INFO("calling 'ReportWiFiStateChange' cb");
}
void NetworkManagerImplementation::ReportWiFiSignalStrengthChange(const string ssid, const string strength, const Exchange::INetworkManager::WiFiSignalQuality quality)
{
NMLOG_INFO("calling 'ReportWiFiSignalStrengthChange' cb");
}

NetworkManagerImplementation* _instance = nullptr;
}
}

void displayMenu()
{
std::cout << "\n--- Network Manager API Test Menu ---" << std::endl;
std::cout << "1. Get Known SSIDs" << std::endl;
std::cout << "2. Get Available SSIDs" << std::endl;
Expand All @@ -27,11 +68,13 @@ void displayMenu() {
std::cout << "8. WiFi Disconnect" << std::endl;
std::cout << "9. Get WiFi State" << std::endl;
std::cout << "10. Get WiFi Signal Strength" << std::endl;
std::cout << "11. start wps" << std::endl;
std::cout << "0. Exit" << std::endl;
std::cout << "-------------------------------------" << std::endl;
}

WPEFramework::Exchange::INetworkManager::WIFISecurityMode getSecurityType() {
WPEFramework::Exchange::INetworkManager::WIFISecurityMode getSecurityType()
{
int securityChoice;
std::cout << "Select Security Type:" << std::endl;
std::cout << "1. WPA/WPA2 PSK AES" << std::endl;
Expand All @@ -52,8 +95,8 @@ WPEFramework::Exchange::INetworkManager::WIFISecurityMode getSecurityType() {
}
}


void printSSIDs(const std::list<std::string>& ssids) {
void printSSIDs(const std::list<std::string>& ssids)
{
if (ssids.empty()) {
std::cout << "No SSIDs found" << std::endl;
} else {
Expand All @@ -64,13 +107,14 @@ void printSSIDs(const std::list<std::string>& ssids) {
}
}

int main() {
DbusMgr test;
int main()
{

NetworkManagerClient* nmClient = NetworkManagerClient::getInstance();
NetworkManagerEvents* nmEvents = NetworkManagerEvents::getInstance();
NetworkManagerWps* nmwps = NetworkManagerWps::getInstance();
int choice = -1;

while (choice != 0) {
displayMenu();
std::cout << "Enter your choice: \n";
Expand Down Expand Up @@ -216,6 +260,15 @@ int main() {
break;
}

case 11: {
if (nmwps->startWPS()) {
NMLOG_INFO("start wps success");
} else {
NMLOG_ERROR("start wps failed");
}
break;
}

case 0:
std::cout << "Exiting program." << std::endl;
break;
Expand All @@ -229,4 +282,4 @@ int main() {
NMLOG_INFO("Program completed successfully");
nmEvents->stopNetworkMangerEventMonitor();
return 0;
}
}
24 changes: 7 additions & 17 deletions gdbus/NetworkManagerGdbusClient.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -52,13 +52,7 @@ namespace WPEFramework
if(ConnProxy == NULL)
return false;

settingsProxy = g_dbus_proxy_call_sync(ConnProxy,
"GetSettings",
NULL,
G_DBUS_CALL_FLAGS_NONE,
-1,
NULL,
&error);
settingsProxy = g_dbus_proxy_call_sync(ConnProxy, "GetSettings", NULL, G_DBUS_CALL_FLAGS_NONE, -1, NULL, &error);
if (!settingsProxy) {
g_dbus_error_strip_remote_error(error);
NMLOG_ERROR("Failed to get connection settings: %s", error->message);
Expand Down Expand Up @@ -156,13 +150,7 @@ namespace WPEFramework
if(ConnProxy == NULL)
return false;

deleteVar = g_dbus_proxy_call_sync(ConnProxy,
"Delete",
NULL,
G_DBUS_CALL_FLAGS_NONE,
-1,
NULL,
&error);
deleteVar = g_dbus_proxy_call_sync(ConnProxy, "Delete", NULL, G_DBUS_CALL_FLAGS_NONE, -1, NULL, &error);
if (!deleteVar) {
g_dbus_error_strip_remote_error(error);
NMLOG_ERROR("Failed to get connection settings: %s", error->message);
Expand Down Expand Up @@ -886,17 +874,19 @@ namespace WPEFramework
wProxy = m_dbus.getNetworkManagerDeviceProxy(devInfo.path.c_str());
if(wProxy == NULL)
return false;

else
g_dbus_proxy_call_sync(wProxy, "Disconnect", NULL, G_DBUS_CALL_FLAGS_NONE, -1, NULL, &error);
return true;
if (error) {
NMLOG_ERROR("Error calling Disconnect method: %s", error->message);
g_error_free(error);
g_object_unref(wProxy);
return false;
}
else
NMLOG_INFO("wifi disconnected success");
NMLOG_INFO("wifi disconnected success");

g_object_unref(wProxy);
return true;
}

Expand All @@ -911,4 +901,4 @@ namespace WPEFramework
}

} // WPEFramework
} // Plugin
} // Plugin
2 changes: 1 addition & 1 deletion gdbus/NetworkManagerGdbusClient.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,4 +64,4 @@ namespace WPEFramework
DbusMgr m_dbus;
};
} // Plugin
} // WPEFramework
} // WPEFramework
Loading

0 comments on commit b8d5719

Please sign in to comment.