Version: 1.0
Status: ⚫⚫⚫
NetworkControl plugin for Thunder framework.
This document describes purpose and functionality of the NetworkControl plugin. It includes detailed specification of its configuration, methods and properties provided, as well as notifications sent.
All identifiers on the interface 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 |
The Network Control plugin provides functionality for network interface management.
The plugin is designed to be loaded and executed within the Thunder framework. For more information about the framework refer to [Thunder].
The table below lists configuration options of the plugin.
Name | Type | Description |
---|---|---|
callsign | string | Plugin instance name (default: NetworkControl) |
classname | string | Class name: NetworkControl |
locator | string | Library name: libWPEFrameworkNetworkControl.so |
autostart | boolean | Determines if the plugin is to be started automatically along with the framework |
The following methods are provided by the NetworkControl plugin:
NetworkControl interface methods:
Method | Description |
---|---|
reload | Reloads a static and non-static network interface adapter |
request | Reloads a non-static network interface adapter |
assign | Reloads a static network interface adapter |
flush | Flushes a network interface adapter |
Reloads a static and non-static network interface adapter.
Name | Type | Description |
---|---|---|
params | object | |
params.device | string | Network interface |
Name | Type | Description |
---|---|---|
result | null | Always null |
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavailable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.reload",
"params": {
"device": "eth0"
}
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": null
}
Reloads a non-static network interface adapter.
Also see: connectionchange
Name | Type | Description |
---|---|---|
params | object | |
params.device | string | Network interface |
Name | Type | Description |
---|---|---|
result | null | Always null |
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavaliable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.request",
"params": {
"device": "eth0"
}
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": null
}
Reloads a static network interface adapter.
Name | Type | Description |
---|---|---|
params | object | |
params.device | string | Network interface |
Name | Type | Description |
---|---|---|
result | null | Always null |
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavaliable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.assign",
"params": {
"device": "eth0"
}
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": null
}
Flushes a network interface adapter.
Name | Type | Description |
---|---|---|
params | object | |
params.device | string | Network interface |
Name | Type | Description |
---|---|---|
result | null | Always null |
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavaliable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.flush",
"params": {
"device": "eth0"
}
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": null
}
The following properties are provided by the NetworkControl plugin:
NetworkControl interface properties:
Property | Description |
---|---|
network RO | Current network information |
up | Interface up status |
Provides access to the current network information.
This property is read-only.
Name | Type | Description |
---|---|---|
(property) | array | Current network information |
(property)[#] | object | |
(property)[#]?.interface | string | (optional) Interface name |
(property)[#]?.mode | string | (optional) Mode (must be one of the following: Manual, Static, Dynamic) |
(property)[#]?.address | string | (optional) IP address |
(property)[#]?.mask | number | (optional) Network interface mask |
(property)[#]?.gateway | string | (optional) Gateway address |
(property)[#]?.broadcast | string | (optional) Broadcast IP |
The interface shall be passed as the index to the property, e.g. NetworkControl.1.network@eth0. If network interface is not given, all network interfaces are returned.
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavailable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.network@eth0"
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": [
{
"interface": "eth0",
"mode": "dynamic",
"address": "192.168.1.158",
"mask": 24,
"gateway": "192.168.1.1",
"broadcast": "192.168.1.255"
}
]
}
Provides access to the interface up status.
Name | Type | Description |
---|---|---|
(property) | boolean | Interface up status |
The interface shall be passed as the index to the property, e.g. NetworkControl.1.up@eth0.
Name | Type | Description |
---|---|---|
result | null | Always null |
Code | Message | Description |
---|---|---|
2 | ERROR_UNAVAILABLE |
Unavailable network interface |
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.up@eth0"
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": false
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"method": "NetworkControl.1.up@eth0",
"params": false
}
{
"jsonrpc": "2.0",
"id": 1234567890,
"result": "null"
}
Notifications are autonomous events, triggered by the internals of the plugin, 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 NetworkControl plugin:
NetworkControl interface events:
Event | Description |
---|---|
connectionchange | Notifies about connection status (created, updated, removed, connected and connectionfailed) |
Notifies about connection status (created, updated, removed, connected and connectionfailed).
Name | Type | Description |
---|---|---|
params | object | |
params.name | string | Name of network interface |
params.address | string | IP Address of network interface, if it is connected |
params.status | string | Status of the interface, update, connected or not (must be one of the following: created, updated, removed, connected, connectionfailed) |
{
"jsonrpc": "2.0",
"method": "client.events.1.connectionchange",
"params": {
"name": "eth0",
"address": "192.168.1.10",
"status": "connected"
}
}