Merge pull request #2021 from larsstenberg/dev-esp32-getmac

ESP32: added functions wifi.sta.getmac() and wifi.ap.getmac()
This commit is contained in:
Johny Mattsson 2017-08-17 12:36:42 +10:00 committed by GitHub
commit d5d8990bf2
5 changed files with 51 additions and 1 deletions

View File

@ -168,6 +168,10 @@ static int wifi_ap_config (lua_State *L)
0 : luaL_error (L, "failed to set wifi config, code %d", err);
}
static int wifi_ap_getmac (lua_State *L)
{
return wifi_getmac(WIFI_IF_AP, L);
}
static int wifi_ap_on (lua_State *L)
{
@ -179,6 +183,7 @@ const LUA_REG_TYPE wifi_ap_map[] =
{
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_config ) },
{ LSTRKEY( "on" ), LFUNCVAL( wifi_ap_on ) },
{ LSTRKEY( "getmac" ), LFUNCVAL( wifi_ap_getmac ) },
{ LNILKEY, LNILVAL }
};

View File

@ -77,3 +77,17 @@ int wifi_on (lua_State *L, const event_desc_t *table, unsigned n, int *event_cb)
return 0;
}
int wifi_getmac (wifi_interface_t interface, lua_State *L)
{
uint8_t mac[6];
esp_err_t err = esp_wifi_get_mac(interface, mac);
if (err != ESP_OK)
return luaL_error (L, "failed to get mac, code %d", err);
char mac_str[MAC_STR_SZ];
macstr (mac_str, mac);
lua_pushstring (L, mac_str);
return 1;
}

View File

@ -71,4 +71,6 @@ int wifi_on (lua_State *L, const event_desc_t *table, unsigned n, int *event_cb)
#define STR_WIFI_SECOND_CHAN_BELOW "HT40_BELOW"
extern const char * const wifi_second_chan_names[];
int wifi_getmac (wifi_interface_t interface, lua_State *L);
#endif

View File

@ -278,6 +278,10 @@ static int wifi_sta_getconfig (lua_State *L)
return 1;
}
static int wifi_sta_getmac (lua_State *L)
{
return wifi_getmac(WIFI_IF_STA, L);
}
static void on_scan_done (const system_event_t *evt)
{
@ -385,6 +389,7 @@ const LUA_REG_TYPE wifi_sta_map[] = {
{ LSTRKEY( "connect" ), LFUNCVAL( wifi_sta_connect ) },
{ LSTRKEY( "disconnect" ), LFUNCVAL( wifi_sta_disconnect ) },
{ LSTRKEY( "getconfig" ), LFUNCVAL( wifi_sta_getconfig ) },
{ LSTRKEY( "getmac" ), LFUNCVAL( wifi_sta_getmac ) },
{ LSTRKEY( "on" ), LFUNCVAL( wifi_sta_on ) },
{ LSTRKEY( "scan" ), LFUNCVAL( wifi_sta_scan ) },

View File

@ -320,6 +320,17 @@ end)
wifi.sta.on("got_ip", nil)
```
## wifi.sta.getmac()
Gets MAC address in station mode.
#### Syntax
`wifi.sta.getmac()`
#### Parameters
None
## wifi.sta.scan()
Scan for available networks.
@ -436,3 +447,16 @@ Event information provided for each event is as follows:
- `probe_req`: information about the probing client
- `from`: MAC address of the probing client
- `rssi`: Received Signal Strength Indicator value
## wifi.ap.getmac()
Gets MAC address in access point mode.
#### Syntax
`wifi.ap.getmac()`
#### Parameters
None
#### Returns
MAC address as string e.g. "18:fe:34:a2:d7:34"