-
Notifications
You must be signed in to change notification settings - Fork 0
DS_CAP_SYS_NETWORK
This capability adds support for wireless networking. The following fields are implemented:
Field | Description | Default Value |
---|---|---|
const char *System::hostname |
Hostname | espDS |
const char *System::wifi_ssid |
SSID of the network to connect to | (empty) |
const char *System::wifi_pass |
Password of the network to connect to | (empty) |
const char* System::time_server |
Time server to use for time synchronization | pool.ntp.org |
Configuring hostname
is not mandatory for networking to work, but you might want to alter it if you care how other devices in the network will see your ESP8266, or if you plan to use mDNS or Wi-Fi manager.
If Wi-Fi manager is enabled, the fields wifi_ssid
and wifi_pass
fields become unavailable. The field time_server
is only available when time is enabled.
The capability implements the following methods:
void System::connectNetwork( // Connect to a known network
JLed *led = nullptr // LED, if defined, can be used to signal connection progress
);
bool System::networkIsConnected(); // Return true if network connected
String System::getNetworkName(); // Return network name
String System::getNetworkDetails(); // Return network details
String System::getLocalIPAddress(); // Return assigned IP address
String System::getTimeServer(); // Return NTP server name (possibly, overridden via DHCP)
connectNetwork()
will connect to a pre-configured network. This function is automatically called from System::begin()
; you do not have to use it under normal circumstances. System LED, if enabled, will glow on startup while the network is being connected. Network connection timeout is 20 s. If connection was unsuccesful, LED will blink three times. Upon successful connection, LED is turned off and can be used for other tasks.
networkIsConnected()
can be used to test if network is connected at a given moment of time.
getNetworkName()
will return the name of the network. In absence of Wi-Fi manager, this name should normally match what's configured in the System::wifi_ssid
field. When Wi-Fi manager is used, the network name will be fetched from credentials stored on flash.
getNetworkDetails()
will give some additional information about network. In the case of Wi-Fi, this means Wi-Fi channel and AP signal strength:
Wi-Fi channel: 1, RSSI: -61 dBm
getLocalIPAddress()
will return IP-address assigned by the network.
getTimeServer()
, only available when time is enabled, will return the name of the time server used. Normally, it coincides with what's configured in time_server
field, but, theoretically, it can be altered via DHCP (I never observed this in practice).
- ESP8266 Arduino Core — networking implementation
- DS_CAP_SYS_LOG — if syslog is enabled, network connection process and result are reflected in syslog. The assigned IP address will be logged;
- DS_CAP_SYS_LED — if system LED is enabled, it will be used to indicate Wi-Fi connection process;
- DS_CAP_SYS_TIME — if time is enabled, it will be automatically synchronized via NTP;
-
DS_CAP_WEBSERVER — if web server is enabled, its
System Configuration
page will include information on network name, details and received IP-address. If time is enabled, NTP server name will be equally included; - DS_CAP_WIFIMANAGER — if Wi-Fi manager is enabled, on startup the network will connect using previously stored credentials, and Wi-Fi manager can be used to alter them.
None.
#include "MySystem.h"
using namespace ds;
// Set network parameters
const char *System::wifi_ssid = "mySSID"; // Network SSID
const char *System::wifi_pass = "myPassword"; // Network password
void setup() {
System::begin();
}
void loop() {
}
System::begin() |
Required |
System::update() |
Not required |
- Network reconnection (e.g., if access point goes down) is not specifically monitored and will not be signalled with LED (issue #6);
- In ESP8266 several time servers could be configured, but
getTimeServer()
will return only the first one used.
None.
- DS_CAP_APP_ID
- DS_CAP_APP_LOG
- DS_CAP_BUTTON
- DS_CAP_MDNS
- DS_CAP_SYS_FS
- DS_CAP_SYS_LED
- DS_CAP_SYS_LOG
- DS_CAP_SYS_LOG_HW
- DS_CAP_SYS_NETWORK
- DS_CAP_SYS_RESET
- DS_CAP_SYS_RTCMEM
- DS_CAP_SYS_TIME
- DS_CAP_SYS_UPTIME
- DS_CAP_TIMERS
- DS_CAP_TIMERS_ABS
- DS_CAP_TIMERS_COUNT_ABS
- DS_CAP_TIMERS_COUNT_TICK
- DS_CAP_TIMERS_SOLAR
- DS_CAP_WEB_TIMERS
- DS_CAP_WEBSERVER
- DS_CAP_WIFIMANAGER