CLI: ip
This commit is contained in:
parent
d96f1dc05e
commit
a2e29784fb
|
@ -4,6 +4,7 @@
|
||||||
#include "cli-args.h"
|
#include "cli-args.h"
|
||||||
#include "cli-commands.h"
|
#include "cli-commands.h"
|
||||||
#include "helpers.h"
|
#include "helpers.h"
|
||||||
|
#include "network.h"
|
||||||
|
|
||||||
#define WIFI_SCAN_SIZE 20
|
#define WIFI_SCAN_SIZE 20
|
||||||
|
|
||||||
|
@ -161,3 +162,72 @@ void cli_wifi_sta_info(Cli* cli, mstring_t* args) {
|
||||||
|
|
||||||
free(ap_info);
|
free(ap_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cli_wifi_ip(Cli* cli, mstring_t* args) {
|
||||||
|
wifi_mode_t mode;
|
||||||
|
tcpip_adapter_ip_info_t ip_info;
|
||||||
|
|
||||||
|
if(esp_wifi_get_mode(&mode) == ESP_OK) {
|
||||||
|
if(mode == WIFI_MODE_STA) {
|
||||||
|
if(tcpip_adapter_get_ip_info(TCPIP_ADAPTER_IF_STA, &ip_info) == ESP_OK) {
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"ip: %d.%d.%d.%d",
|
||||||
|
(ip_info.ip.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 24) & 0xFF);
|
||||||
|
cli_write_eol(cli);
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"mask: %d.%d.%d.%d",
|
||||||
|
(ip_info.netmask.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 24) & 0xFF);
|
||||||
|
cli_write_eol(cli);
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"gw: %d.%d.%d.%d",
|
||||||
|
(ip_info.gw.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 24) & 0xFF);
|
||||||
|
} else {
|
||||||
|
cli_write_str(cli, "FAIL");
|
||||||
|
}
|
||||||
|
} else if(mode == WIFI_MODE_APSTA) {
|
||||||
|
if(tcpip_adapter_get_ip_info(TCPIP_ADAPTER_IF_AP, &ip_info) == ESP_OK) {
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"ip: %d.%d.%d.%d",
|
||||||
|
(ip_info.ip.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.ip.addr >> 24) & 0xFF);
|
||||||
|
cli_write_eol(cli);
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"mask: %d.%d.%d.%d",
|
||||||
|
(ip_info.netmask.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.netmask.addr >> 24) & 0xFF);
|
||||||
|
cli_write_eol(cli);
|
||||||
|
cli_printf(
|
||||||
|
cli,
|
||||||
|
"gw: %d.%d.%d.%d",
|
||||||
|
(ip_info.gw.addr >> 0) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 8) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 16) & 0xFF,
|
||||||
|
(ip_info.gw.addr >> 24) & 0xFF);
|
||||||
|
} else {
|
||||||
|
cli_write_str(cli, "FAIL");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
cli_write_str(cli, "FAIL");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
cli_write_str(cli, "FAIL");
|
||||||
|
}
|
||||||
|
}
|
|
@ -18,6 +18,7 @@ void cli_ping(Cli* cli, mstring_t* args);
|
||||||
void cli_sw_reset(Cli* cli, mstring_t* args);
|
void cli_sw_reset(Cli* cli, mstring_t* args);
|
||||||
void cli_wifi_scan(Cli* cli, mstring_t* args);
|
void cli_wifi_scan(Cli* cli, mstring_t* args);
|
||||||
void cli_wifi_ap_clients(Cli* cli, mstring_t* args);
|
void cli_wifi_ap_clients(Cli* cli, mstring_t* args);
|
||||||
|
void cli_wifi_ip(Cli* cli, mstring_t* args);
|
||||||
void cli_wifi_sta_info(Cli* cli, mstring_t* args);
|
void cli_wifi_sta_info(Cli* cli, mstring_t* args);
|
||||||
|
|
||||||
void cli_config_get(Cli* cli, mstring_t* args);
|
void cli_config_get(Cli* cli, mstring_t* args);
|
||||||
|
@ -102,6 +103,10 @@ const CliItem cli_items[] = {
|
||||||
.name = "wifi_ap_clients",
|
.name = "wifi_ap_clients",
|
||||||
.callback = cli_wifi_ap_clients,
|
.callback = cli_wifi_ap_clients,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.name = "wifi_ip",
|
||||||
|
.callback = cli_wifi_ip,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = "wifi_sta_info",
|
.name = "wifi_sta_info",
|
||||||
.callback = cli_wifi_sta_info,
|
.callback = cli_wifi_sta_info,
|
||||||
|
|
Loading…
Reference in New Issue