Merge pull request #17092 from joba-1/rgx-portmap

add command RgxPort to setup port forwarding
This commit is contained in:
Theo Arends 2022-11-16 14:17:55 +01:00 committed by GitHub
commit 56a71c3ca9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 48 additions and 2 deletions

View File

@ -94,6 +94,8 @@ const char kDrvRgxCommands[] PROGMEM = "Rgx|" // Prefix
#ifdef USE_WIFI_RANGE_EXTENDER_NAPT #ifdef USE_WIFI_RANGE_EXTENDER_NAPT
"|" "|"
"NAPT" "NAPT"
"|"
"Port"
#endif // USE_WIFI_RANGE_EXTENDER_NAPT #endif // USE_WIFI_RANGE_EXTENDER_NAPT
"|" "|"
"Clients" "Clients"
@ -108,6 +110,7 @@ void (*const DrvRgxCommand[])(void) PROGMEM = {
&CmndRgxPassword, &CmndRgxPassword,
#ifdef USE_WIFI_RANGE_EXTENDER_NAPT #ifdef USE_WIFI_RANGE_EXTENDER_NAPT
&CmndRgxNAPT, &CmndRgxNAPT,
&CmndRgxPort,
#endif // USE_WIFI_RANGE_EXTENDER_NAPT #endif // USE_WIFI_RANGE_EXTENDER_NAPT
&CmndRgxClients, &CmndRgxClients,
&CmndRgxAddresses, &CmndRgxAddresses,
@ -120,7 +123,6 @@ void (*const DrvRgxCommand[])(void) PROGMEM = {
#endif // ESP8266 #endif // ESP8266
#endif // USE_WIFI_RANGE_EXTENDER_NAPT #endif // USE_WIFI_RANGE_EXTENDER_NAPT
#include <ESP8266WiFi.h>
#include <lwip/dns.h> #include <lwip/dns.h>
#ifdef ESP8266 #ifdef ESP8266
#include <dhcpserver.h> #include <dhcpserver.h>
@ -280,7 +282,51 @@ void CmndRgxNAPT(void)
} }
} }
ResponseCmndStateText(Settings->sbflag1.range_extender_napt); ResponseCmndStateText(Settings->sbflag1.range_extender_napt);
}; }
void CmndRgxPort(void)
{
char *tok, *state, *parm_mac;
uint16_t gw, dst;
uint8_t proto = 0;
Response_P(PSTR("ERROR"));
if (ArgC()!=4) return;
if ((tok = strtok_r(XdrvMailbox.data, ", ", &state)) == 0) return;
if (strcasecmp("TCP", tok) == 0) proto = IP_PROTO_TCP;
if (strcasecmp("UDP", tok) == 0) proto = IP_PROTO_UDP;
if (!proto) return;
if ((tok = strtok_r(0, ", ", &state)) == 0) return;
if ((gw = strtoul(tok, nullptr, 0)) == 0) return;
if ((parm_mac = strtok_r(0, ", ", &state)) == 0) return;
if ((tok = strtok_r(0, ", ", &state)) == 0) return;
if ((dst = strtoul(tok, nullptr, 0)) == 0) return;
#ifdef ESP32
wifi_sta_list_t wifi_sta_list = {0};
tcpip_adapter_sta_list_t adapter_sta_list = {0};
esp_wifi_ap_get_sta_list(&wifi_sta_list);
tcpip_adapter_get_sta_list(&wifi_sta_list, &adapter_sta_list);
for (int i=0; i<adapter_sta_list.num; i++)
{
char list_mac[13];
const uint8_t *m = adapter_sta_list.sta[i].mac;
snprintf(list_mac, sizeof(list_mac), PSTR("%02X%02X%02X%02X%02X%02X"), m[0], m[1], m[2], m[3], m[4], m[5]);
if (strcasecmp(list_mac, parm_mac) == 0)
{
if (ip_portmap_add(proto, (uint32_t)WiFi.localIP(), gw, adapter_sta_list.sta[i].ip.addr, dst))
{
Response_P(PSTR("OK %s %_I:%u -> %_I:%u"),
(proto == IP_PROTO_TCP) ? "TCP" : "UDP", (uint32_t)WiFi.localIP(), gw, adapter_sta_list.sta[i].ip.addr, dst);
}
break;
}
}
#endif // ESP32
}
#endif // USE_WIFI_RANGE_EXTENDER_NAPT #endif // USE_WIFI_RANGE_EXTENDER_NAPT
void ResponseRgxConfig(void) void ResponseRgxConfig(void)