Version: 0.6.0
Status: ⚪⚪⚪
org.rdk.NetworkManager interface for Thunder framework.
(Defined by NetworkManager.json)
This document describes purpose and functionality of the org.rdk.NetworkManager interface (version 0.6.0). It includes detailed specification about its methods provided and notifications sent.
All identifiers of the interfaces described in this document are case-sensitive. Thus, unless stated otherwise, all keywords, entities, properties, relations and actions should be treated as such.
The table below provides and overview of acronyms used in this document and their definitions.
Acronym | Description |
---|---|
API | Application Programming Interface |
HTTP | Hypertext Transfer Protocol |
JSON | JavaScript Object Notation; a data interchange format |
JSON-RPC | A remote procedure call protocol encoded in JSON |
The table below provides and overview of terms and abbreviations used in this document and their definitions.
Term | Description |
---|---|
callsign | The name given to an instance of a plugin. One plugin can be instantiated multiple times, but each instance the instance name, callsign, must be unique. |
Ref ID | Description |
---|---|
HTTP | HTTP specification |
JSON-RPC | JSON-RPC 2.0 specification |
JSON | JSON specification |
Thunder | Thunder API Reference |
A Unified NetworkManager
plugin that allows you to manage Ethernet and Wifi interfaces on the device.
The following methods are provided by the org.rdk.NetworkManager interface:
NetworkManager interface methods:
Method | Description |
---|---|
SetLogLevel | Set Log level for more information |
GetLogLevel | Get Log level that is currently used |
GetAvailableInterfaces | Get device supported list of available interface including their state |
GetPrimaryInterface | Gets the primary/default network interface for the device |
SetPrimaryInterface | Sets the primary/default interface for the device |
SetInterfaceState | Enable or disable the specified interface |
GetInterfaceState | Gets the current Status of the specified interface |
GetIPSettings | Gets the IP setting for the given interface |
SetIPSettings | Sets the IP settings for the given interface |
GetStunEndpoint | Get the STUN endpoint that is used to identify public IP of the device |
SetStunEndpoint | Set the STUN endpoint to be used to identify public IP of the device |
GetConnectivityTestEndpoints | Gets currently used test endpoints |
SetConnectivityTestEndpoints | This method used to set up to 5 endpoints for a connectivity test |
IsConnectedToInternet | Seeks whether the device has internet connectivity |
GetCaptivePortalURI | Gets the captive portal URI if connected to any captive portal network |
StartConnectivityMonitoring | Enable a continuous monitoring of internet connectivity with heart beat interval thats given |
StopConnectivityMonitoring | Stops the connectivity monitoring |
GetPublicIP | Gets the internet/public IP Address of the device |
Ping | Pings the specified endpoint with the specified number of packets |
Trace | Traces the specified endpoint with the specified number of packets using traceroute |
StartWiFiScan | Initiates WiFi scaning |
StopWiFiScan | Stops WiFi scanning |
GetKnownSSIDs | Gets list of saved SSIDs |
AddToKnownSSIDs | Saves the SSID, passphrase, and security mode for upcoming and future sessions |
RemoveKnownSSID | Remove given SSID from saved SSIDs |
WiFiConnect | Initiates request to connect to the specified SSID with the given passphrase |
WiFiDisconnect | Disconnects from the currently connected SSID |
GetConnectedSSID | Returns the connected SSID information |
StartWPS | Initiates a connection using Wifi Protected Setup (WPS) |
StopWPS | Cancels the in-progress WPS pairing operation |
GetWiFiSignalStrength | Get WiFiSignalStrength of connected SSID |
GetSupportedsecurityModes | Returns the Wifi security modes that the device supports |
GetWifiState | Returns the current Wifi State |
SetLogLevel method
Set Log level for more information. The possible set log level are as follows.
0
: FATAL1
: ERROR2
: WARNING3
: INFO4
: DEBUG .
Name | Type | Description |
---|---|---|
params | object | |
params.level | integer | Set Log level to get more information |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetLogLevel",
"params": {
"level": 1
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetLogLevel method
Get Log level that is currently used.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.level | integer | Get Log level to get more information |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetLogLevel"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"level": 1,
"success": true
}
}
GetAvailableInterfaces method
Get device supported list of available interface including their state.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.interfaces | array | An interface details |
result.interfaces[#] | object | |
result.interfaces[#].type | string | Interface Type |
result.interfaces[#].name | string | Interface Name. ex: eth0 or wlan0 |
result.interfaces[#].mac | string | Interface MAC address |
result.interfaces[#].enabled | boolean | Whether the interface is currently enabled |
result.interfaces[#].connected | boolean | Whether the interface is currently connected |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetAvailableInterfaces"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"interfaces": [
{
"type": "ETHERNET",
"name": "eth0",
"mac": "AA:AA:AA:AA:AA:AA",
"enabled": true,
"connected": true
}
],
"success": true
}
}
GetPrimaryInterface method
Gets the primary/default network interface for the device. The active network interface is defined as the one that can make requests to the external network. Returns one of the supported interfaces as per GetAvailableInterfaces
.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetPrimaryInterface"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"interface": "wlan0"
}
}
SetPrimaryInterface method
Sets the primary/default interface for the device. This call fails if the interface is not enabled.
Also see: onActiveInterfaceChange, onInterfaceStateChange, onAddressChange, onInternetStatusChange
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetPrimaryInterface",
"params": {
"interface": "wlan0"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
SetInterfaceState method
Enable or disable the specified interface.
Also see: onInterfaceStateChange
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | Enable the specified interface |
params.enabled | boolean | Whether the interface must be enabled or disabled |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetInterfaceState",
"params": {
"interface": "wlan0",
"enabled": true
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetInterfaceState method
Gets the current Status of the specified interface.
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | Disable the specified interface |
Name | Type | Description |
---|---|---|
result | object | |
result.enabled | boolean | Whether the interface is enabled or disabled |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetInterfaceState",
"params": {
"interface": "wlan0"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"enabled": true,
"success": true
}
}
GetIPSettings method
Gets the IP setting for the given interface.
Name | Type | Description |
---|---|---|
params | object | |
params?.interface | string | (optional) An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
params?.ipversion | string | (optional) Either IPv4 or IPv6 |
Name | Type | Description |
---|---|---|
result | object | |
result.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
result.ipversion | string | Either IPv4 or IPv6 |
result.autoconfig | boolean | true if DHCP is used, false if IP is configured manually |
result?.dhcpserver | string | (optional) The DHCP Server address |
result.ipaddress | string | The IP address |
result.prefix | integer | The prefix number |
result.gateway | string | The gateway address |
result.ula | string | The IPv6 Unified Local Address |
result.primarydns | string | The primary DNS address |
result.secondarydns | string | The secondary DNS address |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetIPSettings",
"params": {
"interface": "wlan0",
"ipversion": "IPv4"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"interface": "wlan0",
"ipversion": "IPv4",
"autoconfig": true,
"dhcpserver": "192.168.1.1",
"ipaddress": "192.168.1.101",
"prefix": 24,
"gateway": "192.168.1.1",
"ula": "d00:410:2016::",
"primarydns": "192.168.1.1",
"secondarydns": "192.168.1.2",
"success": true
}
}
SetIPSettings method
Sets the IP settings for the given interface.
Also see: onAddressChange, onInternetStatusChange
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
params.ipversion | string | Either IPv4 or IPv6 |
params.autoconfig | boolean | true if DHCP is used, false if IP is configured manually |
params.ipaddress | string | The IP address |
params.prefix | integer | The prefix number |
params.gateway | string | The gateway address |
params.primarydns | string | The primary DNS address |
params.secondarydns | string | The secondary DNS address |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetIPSettings",
"params": {
"interface": "wlan0",
"ipversion": "IPv4",
"autoconfig": true,
"ipaddress": "192.168.1.101",
"prefix": 24,
"gateway": "192.168.1.1",
"primarydns": "192.168.1.1",
"secondarydns": "192.168.1.2"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetStunEndpoint method
Get the STUN endpoint that is used to identify public IP of the device.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.endpoint | string | The host name or IP address |
result.port | integer | STUN server port |
result.timeout | integer | Timeout |
result.cacheLifetime | integer | STUN server cache timeout |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetStunEndpoint"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"endpoint": "45.57.221.20",
"port": 3478,
"timeout": 30,
"cacheLifetime": 0,
"success": true
}
}
SetStunEndpoint method
Set the STUN endpoint to be used to identify public IP of the device.
Name | Type | Description |
---|---|---|
params | object | |
params.endpoint | string | The host name or IP address |
params.port | integer | STUN server port |
params?.timeout | integer | (optional) Timeout |
params?.cacheLifetime | integer | (optional) STUN server cache timeout |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetStunEndpoint",
"params": {
"endpoint": "45.57.221.20",
"port": 3478,
"timeout": 30,
"cacheLifetime": 0
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetConnectivityTestEndpoints method
Gets currently used test endpoints. on success list out the connectivity test points connections.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.endpoints | array | |
result.endpoints[#] | string | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetConnectivityTestEndpoints"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"endpoints": [
"http://clients3.google.com/generate_204"
],
"success": true
}
}
SetConnectivityTestEndpoints method
This method used to set up to 5 endpoints for a connectivity test. Successful connections are verified with HTTP Status code 204 (No Content).
Name | Type | Description |
---|---|---|
params | object | |
params.endpoints | array | A list of endpoints to test |
params.endpoints[#] | string |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.SetConnectivityTestEndpoints",
"params": {
"endpoints": [
"http://clients3.google.com/generate_204"
]
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
IsConnectedToInternet method
Seeks whether the device has internet connectivity. This API might take up to 3s to validate internet connectivity.
Name | Type | Description |
---|---|---|
params | object | |
params?.ipversion | string | (optional) Either IPv4 or IPv6 |
Name | Type | Description |
---|---|---|
result | object | |
result.ipversion | string | Either IPv4 or IPv6 |
result.connected | boolean | true if internet connectivity is detected, otherwise false |
result.state | integer | Internet state |
result.status | string | Internet status |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.IsConnectedToInternet",
"params": {
"ipversion": "IPv4"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"ipversion": "IPv4",
"connected": true,
"state": 3,
"status": "FULLY_CONNECTED",
"success": true
}
}
GetCaptivePortalURI method
Gets the captive portal URI if connected to any captive portal network.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.uri | string | Captive portal URI |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetCaptivePortalURI"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"uri": "http://10.0.0.1/captiveportal.jst",
"success": true
}
}
StartConnectivityMonitoring method
Enable a continuous monitoring of internet connectivity with heart beat interval thats given. If the monitoring is already happening, it will be restarted with new given interval. When the interval is not passed, it will be 60s by default.
Also see: onInternetStatusChange
Name | Type | Description |
---|---|---|
params | object | |
params?.interval | integer | (optional) Interval in sec |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StartConnectivityMonitoring",
"params": {
"interval": 30
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
StopConnectivityMonitoring method
Stops the connectivity monitoring.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StopConnectivityMonitoring"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetPublicIP method
Gets the internet/public IP Address of the device.
Name | Type | Description |
---|---|---|
params | object | It allows empty parameter too |
params?.ipversion | string | (optional) Either IPv4 or IPv6 |
Name | Type | Description |
---|---|---|
result | object | |
result.ipaddress | string | The IP address |
result.ipversion | string | Either IPv4 or IPv6 |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetPublicIP",
"params": {
"ipversion": "IPv4"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"ipaddress": "192.168.1.101",
"ipversion": "IPv4",
"success": true
}
}
Ping method
Pings the specified endpoint with the specified number of packets.
Name | Type | Description |
---|---|---|
params | object | |
params.endpoint | string | The host name or IP address |
params.ipversion | string | Either IPv4 or IPv6 |
params?.count | integer | (optional) The number of requests to send. Default is 3 |
params?.timeout | integer | (optional) Timeout |
params?.guid | string | (optional) The globally unique identifier |
Name | Type | Description |
---|---|---|
result | object | |
result.endpoint | string | The host name or IP address |
result.packetsTransmitted | integer | The number of packets sent |
result.packetsReceived | integer | The number of packets received |
result.packetLoss | string | The number of packets lost |
result.tripMin | string | The minimum amount of time to receive the packets |
result.tripAvg | string | The average time to receive the packets |
result.tripMax | string | The maximum amount of time to receive the packets |
result.tripStdDev | string | The standard deviation for the trip |
result.error | string | An error message |
result.guid | string | The globally unique identifier |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.Ping",
"params": {
"endpoint": "45.57.221.20",
"ipversion": "IPv4",
"count": 10,
"timeout": 30,
"guid": "..."
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"endpoint": "45.57.221.20",
"packetsTransmitted": 10,
"packetsReceived": 10,
"packetLoss": "0.0",
"tripMin": "61.264",
"tripAvg": "130.397",
"tripMax": "230.832",
"tripStdDev": "80.919",
"error": "...",
"guid": "...",
"success": true
}
}
Trace method
Traces the specified endpoint with the specified number of packets using traceroute
.
Name | Type | Description |
---|---|---|
params | object | |
params.endpoint | string | The host name or IP address |
params.ipversion | string | Either IPv4 or IPv6 |
params?.packets | integer | (optional) The number of packets to send. Default is 5 |
params?.guid | string | (optional) The globally unique identifier |
Name | Type | Description |
---|---|---|
result | object | |
result.endpoint | string | The host name or IP address |
result.results | string | The response of traceroute |
result.guid | string | The globally unique identifier |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.Trace",
"params": {
"endpoint": "45.57.221.20",
"ipversion": "IPv4",
"packets": 10,
"guid": "..."
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"endpoint": "45.57.221.20",
"results": "...",
"guid": "...",
"success": true
}
}
StartWiFiScan method
Initiates WiFi scaning. This method supports scanning for specific range of frequency like 2.4GHz only or 5GHz only or 6GHz only or ALL. When no input passed about the frequency to be scanned, it scans for all. When list of SSIDs to be scanned specifically, it can be passed as input. It publishes 'onAvailableSSIDs' event upon completion.
Also see: onAvailableSSIDs
Name | Type | Description |
---|---|---|
params | object | |
params?.frequency | string | (optional) The frequency to scan. An empty or null value scans all frequencies |
params?.ssids | array | (optional) The list of SSIDs to be scanned |
params?.ssids[#] | string | (optional) |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StartWiFiScan",
"params": {
"frequency": "5",
"ssids": [
"Xfinity Mobile"
]
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
StopWiFiScan method
Stops WiFi scanning. Any discovered SSIDs from the call to the StartWiFiScan
method up to the point where this method is called are still returned as event.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StopWiFiScan"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetKnownSSIDs method
Gets list of saved SSIDs. This method returns all the SSIDs that are saved as array.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.ssids | array | Known SSIDS |
result.ssids[#] | string | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetKnownSSIDs"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"ssids": [
"Xfinity_Guest"
],
"success": true
}
}
AddToKnownSSIDs method
Saves the SSID, passphrase, and security mode for upcoming and future sessions. This method only adds to the persistent memory; does not disconnect from currently connected SSID.
Name | Type | Description |
---|---|---|
params | object | |
params.ssid | string | The paired SSID |
params.passphrase | string | The access point password |
params.security | integer | The security mode. See getSupportedsecurityModes |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.AddToKnownSSIDs",
"params": {
"ssid": "123412341234",
"passphrase": "password",
"security": 6
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
RemoveKnownSSID method
Remove given SSID from saved SSIDs. This method just removes an entry from the list and of the list is having only one entry thats being removed, it will initiate a disconnect.
Also see: onWiFiStateChange, onAddressChange, onInternetStatusChange
Name | Type | Description |
---|---|---|
params | object | |
params.ssid | string | The paired SSID |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.RemoveKnownSSID",
"params": {
"ssid": "123412341234"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
WiFiConnect method
Initiates request to connect to the specified SSID with the given passphrase. Passphrase can be null
when the network security is NONE
. When called with no arguments, this method attempts to connect to the saved SSID and password. See AddToKnownSSIDs
.
Also see: onWiFiStateChange
Name | Type | Description |
---|---|---|
params | object | |
params.ssid | string | The paired SSID |
params.passphrase | string | The access point password |
params.security | integer | The security mode. See getSupportedsecurityModes |
params?.ca_cert | string | (optional) The ca_cert to be used for EAP |
params?.client_cert | string | (optional) The client_cert to be used for EAP |
params?.private_key | string | (optional) The private_key to be used for EAP |
params?.private_key_passwd | string | (optional) The private_key_passwd to be used for EAP |
params?.eap | string | (optional) The EAP type to be used |
params?.eap_identity | string | (optional) The identity to be used for EAP |
params?.eap_password | string | (optional) The eap_password to be used for EAP |
params?.eap_phase1 | string | (optional) The eap_phase1 to be used for EAP |
params?.eap_phase2 | string | (optional) The eap_phase2 to be used for EAP |
params?.persist | boolean | (optional) To persist the SSID across reboots; similar to auto connect |
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.WiFiConnect",
"params": {
"ssid": "123412341234",
"passphrase": "password",
"security": 6,
"ca_cert": "...",
"client_cert": "...",
"private_key": "...",
"private_key_passwd": "...",
"eap": "TLS",
"eap_identity": "...",
"eap_password": "...",
"eap_phase1": "...",
"eap_phase2": "...",
"persist": true
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
WiFiDisconnect method
Disconnects from the currently connected SSID. A event will be posted upon completion.
Also see: onWIFIStateChange, onAddressChange, onInternetStatusChange
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.WiFiDisconnect"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetConnectedSSID method
Returns the connected SSID information.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.ssid | string | The paired SSID |
result.bssid | string | The paired BSSID |
result.security | string | The security mode. See the connect method |
result.strength | string | The RSSI value in dBm |
result.frequency | string | The supported frequency for this SSID in GHz |
result.rate | string | The physical data rate in Mbps |
result.noise | string | The average noise strength in dBm |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetConnectedSSID"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"ssid": "123412341234",
"bssid": "ff:ff:ff:ff:ff:ff",
"security": "5",
"strength": "-27.000000",
"frequency": "2.442000",
"rate": "144.000000",
"noise": "-121.000000",
"success": true
}
}
StartWPS method
Initiates a connection using Wifi Protected Setup (WPS). An existing connection will be disconnected before attempting to initiate a new connection. Failure in WPS pairing will trigger an error event.
If the method
parameter is set to SERIALIZED_PIN
, then RDK retrieves the serialized pin using the Manufacturer (MFR) API. If the method
parameter is set to PIN
, then RDK use the pin supplied as part of the request. If the method
parameter is set to PBC
, then RDK uses Push Button Configuration (PBC) to obtain the pin.
Also see: onWIFIStateChange, onAddressChange, onInternetStatusChange
Name | Type | Description |
---|---|---|
params | object | |
params.method | string | The method used to obtain the pin (must be one of the following: PBC=0, PIN=1, SERIALIZED_PIN=2) |
params?.pin | string | (optional) A valid 8 digit WPS pin number. Use this parameter when the method parameter is set to PIN |
Name | Type | Description |
---|---|---|
result | object | |
result?.pin | string | (optional) The WPS pin value. Valid only when method is set to PIN or SERIALIZED_PIN |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StartWPS",
"params": {
"method": "PIN",
"pin": "88888888"
}
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"pin": "88888888",
"success": true
}
}
StopWPS method
Cancels the in-progress WPS pairing operation. The operation forcefully stops the in-progress pairing attempt and aborts the current scan. WPS pairing must be in-progress for the operation to succeed.
Also see: onWIFIStateChange
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.StopWPS"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"success": true
}
}
GetWiFiSignalStrength method
Get WiFiSignalStrength of connected SSID. The signal quality is identifed based on the signal strength. The possible states are
- 'Excellent'
- 'Good'
- 'Fair'
- 'Weak'
- 'Disconnected' .
Also see: onWiFiSignalStrengthChange
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.ssid | string | The paired SSID |
result.strength | string | The RSSI value in dBm |
result.quality | string | Signal strength Quality |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetWiFiSignalStrength"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"ssid": "123412341234",
"strength": "-27.000000",
"quality": "Excellent",
"success": true
}
}
GetSupportedsecurityModes method
Returns the Wifi security modes that the device supports.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.security_modes | object | The supported security modes and its associated integer value |
result.security_modes?.NET_WIFI_SECURITY_NONE | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WEP_64 | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WEP_128 | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_PSK_TKIP | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_PSK_AES | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA2_PSK_TKIP | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA2_PSK_AES | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_ENTERPRISE_TKIP | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_ENTERPRISE_AES | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA2_ENTERPRISE_TKIP | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA2_ENTERPRISE_AES | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_WPA2_PSK | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA_WPA2_ENTERPRISE | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA3_PSK_AES | integer | (optional) |
result.security_modes?.NET_WIFI_SECURITY_WPA3_SAE | integer | (optional) |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetSupportedsecurityModes"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"security_modes": {
"NET_WIFI_SECURITY_NONE": 0,
"NET_WIFI_SECURITY_WEP_64": 1,
"NET_WIFI_SECURITY_WEP_128": 2,
"NET_WIFI_SECURITY_WPA_PSK_TKIP": 3,
"NET_WIFI_SECURITY_WPA_PSK_AES": 4,
"NET_WIFI_SECURITY_WPA2_PSK_TKIP": 5,
"NET_WIFI_SECURITY_WPA2_PSK_AES": 6,
"NET_WIFI_SECURITY_WPA_ENTERPRISE_TKIP": 7,
"NET_WIFI_SECURITY_WPA_ENTERPRISE_AES": 8,
"NET_WIFI_SECURITY_WPA2_ENTERPRISE_TKIP": 9,
"NET_WIFI_SECURITY_WPA2_ENTERPRISE_AES": 10,
"NET_WIFI_SECURITY_WPA_WPA2_PSK": 11,
"NET_WIFI_SECURITY_WPA_WPA2_ENTERPRISE": 12,
"NET_WIFI_SECURITY_WPA3_PSK_AES": 13,
"NET_WIFI_SECURITY_WPA3_SAE": 14
},
"success": true
}
}
GetWifiState method
Returns the current Wifi State. The possible Wifi states are as follows.
Wifi States
0
: WIFI_STATE_UNINSTALLED - The device was in an installed state and was uninstalled; or, the device does not have a Wifi radio installed1
: WIFI_STATE_DISABLED - The device is installed but not yet enabled2
: WIFI_STATE_DISCONNECTED - The device is installed and enabled, but not yet connected to a network3
: WIFI_STATE_PAIRING - The device is in the process of pairing, but not yet connected to a network4
: WIFI_STATE_CONNECTING - The device is attempting to connect to a network5
: WIFI_STATE_CONNECTED - The device is successfully connected to a network6
: WIFI_STATE_SSID_NOT_FOUND - The requested SSID to connect is not found7
: WIFI_STATE_SSID_CHANGED - The device connected SSID is changed8
: WIFI_STATE_CONNECTION_LOST - The device network connection is lost9
: WIFI_STATE_CONNECTION_FAILED - The device connection got failed10
: WIFI_STATE_CONNECTION_INTERRUPTED - The device connection is interrupted11
: WIFI_STATE_INVALID_CREDENTIALS - The credentials provided to connect is not valid12
: WIFI_STATE_AUTHENTICATION_FAILED - Authentication process as a whole could not be successfully completed13
: WIFI_STATE_ERROR - The device has encountered an unrecoverable error with the Wifi adapter.
This method takes no parameters.
Name | Type | Description |
---|---|---|
result | object | |
result.state | integer | The given State |
result.status | string | WiFi status |
result.success | boolean | Whether the request succeeded |
{
"jsonrpc": "2.0",
"id": 42,
"method": "org.rdk.NetworkManager.1.GetWifiState"
}
{
"jsonrpc": "2.0",
"id": 42,
"result": {
"state": 4,
"status": "WIFI_STATE_CONNECTED",
"success": true
}
}
Notifications are autonomous events triggered by the internals of the implementation and broadcasted via JSON-RPC to all registered observers. Refer to [Thunder] for information on how to register for a notification.
The following events are provided by the org.rdk.NetworkManager interface:
NetworkManager interface events:
Event | Description |
---|---|
onInterfaceStateChange | Triggered when an interface state is changed |
onAddressChange | Triggered when an IP Address is assigned or lost |
onActiveInterfaceChange | Triggered when the primary/active interface changes, regardless if it's from a system operation or through the SetPrimaryInterface method |
onInternetStatusChange | Triggered when internet connection state changed |
onAvailableSSIDs | Triggered when scan completes or when scan cancelled |
onWiFiStateChange | Triggered when WIFI connection state get changed |
onWiFiSignalStrengthChange | Triggered when WIFI connection Signal Strength get changed |
onInterfaceStateChange event
Triggered when an interface state is changed. The possible states are
- 'INTERFACE_ADDED'
- 'INTERFACE_LINK_UP'
- 'INTERFACE_LINK_DOWN'
- 'INTERFACE_ACQUIRING_IP'
- 'INTERFACE_REMOVED'
- 'INTERFACE_DISABLED' .
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
params.state | integer | Current state of the interface |
params.status | string | Current status of the interface |
{
"jsonrpc": "2.0",
"method": "client.events.1.onInterfaceStateChange",
"params": {
"interface": "wlan0",
"state": 1,
"status": "INTERFACE_LINK_UP"
}
}
onAddressChange event
Triggered when an IP Address is assigned or lost.
Name | Type | Description |
---|---|---|
params | object | |
params.interface | string | An interface, such as eth0 or wlan0 , depending upon availability of the given interface |
params.ipaddress | string | The IP address |
params.ipversion | string | Either IPv4 or IPv6 |
params.status | string | Whether IP address was acquired or lost (must be one of the following: 'ACQUIRED', 'LOST') |
{
"jsonrpc": "2.0",
"method": "client.events.1.onAddressChange",
"params": {
"interface": "wlan0",
"ipaddress": "192.168.1.101",
"ipversion": "IPv4",
"status": "ACQUIRED"
}
}
onActiveInterfaceChange event
Triggered when the primary/active interface changes, regardless if it's from a system operation or through the SetPrimaryInterface
method.
Name | Type | Description |
---|---|---|
params | object | |
params.prevActiveInterface | string | The previous interface that was changed |
params.activeInterface | string | The current interface |
{
"jsonrpc": "2.0",
"method": "client.events.1.onActiveInterfaceChange",
"params": {
"prevActiveInterface": "wlan0",
"activeInterface": "eth0"
}
}
onInternetStatusChange event
Triggered when internet connection state changed.The possible internet connection status are NO_INTERNET
, LIMITED_INTERNET
, CAPTIVE_PORTAL
, FULLY_CONNECTED
.
Name | Type | Description |
---|---|---|
params | object | |
params.prevState | integer | The privious internet connection state |
params.prevStatus | string | The previous internet connection status |
params.state | integer | The internet connection state |
params.status | string | The internet connection status |
{
"jsonrpc": "2.0",
"method": "client.events.1.onInternetStatusChange",
"params": {
"prevState": 1,
"prevStatus": "NO_INTERNET",
"state": 4,
"status": "FULLY_CONNECTED"
}
}
onAvailableSSIDs event
Triggered when scan completes or when scan cancelled.
Name | Type | Description |
---|---|---|
params | object | |
params.ssids | array | On Available SSID's |
params.ssids[#] | object | |
params.ssids[#].ssid | string | Ssid |
params.ssids[#].security | integer | Security |
params.ssids[#].strength | string | Strength |
params.ssids[#].frequency | string | Frequency |
{
"jsonrpc": "2.0",
"method": "client.events.1.onAvailableSSIDs",
"params": {
"ssids": [
{
"ssid": "myAP-2.4",
"security": 6,
"strength": "-27.000000",
"frequency": "2.442000"
}
]
}
}
onWiFiStateChange event
Triggered when WIFI connection state get changed. The possible states are defined in GetWifiState()
.
Name | Type | Description |
---|---|---|
params | object | |
params.state | integer | WiFi State |
params.status | string | WiFi status |
{
"jsonrpc": "2.0",
"method": "client.events.1.onWiFiStateChange",
"params": {
"state": 5,
"status": "WIFI_STATE_CONNECTED"
}
}
onWiFiSignalStrengthChange event
Triggered when WIFI connection Signal Strength get changed.
Name | Type | Description |
---|---|---|
params | object | |
params.ssid | string | Signal Strength changed SSID |
params.strength | string | Signal Strength |
params.quality | string | Signal quality |
{
"jsonrpc": "2.0",
"method": "client.events.1.onWiFiSignalStrengthChange",
"params": {
"ssid": "home-new_123",
"strength": "-27.000000",
"quality": "Excellent"
}
}