mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-06 15:59:52 +03:00
json is always chunked
This commit is contained in:
67
lib/PsychicHttp/src_old/PsychicClient.cpp
Normal file
67
lib/PsychicHttp/src_old/PsychicClient.cpp
Normal file
@@ -0,0 +1,67 @@
|
||||
#include "PsychicClient.h"
|
||||
|
||||
PsychicClient::PsychicClient(httpd_handle_t server, int socket)
|
||||
: _server(server)
|
||||
, _socket(socket)
|
||||
, _friend(NULL)
|
||||
, isNew(false) {
|
||||
}
|
||||
|
||||
PsychicClient::~PsychicClient() {
|
||||
}
|
||||
|
||||
httpd_handle_t PsychicClient::server() {
|
||||
return _server;
|
||||
}
|
||||
|
||||
int PsychicClient::socket() {
|
||||
return _socket;
|
||||
}
|
||||
|
||||
// I'm not sure this is entirely safe to call. I was having issues with race conditions when highly loaded using this.
|
||||
esp_err_t PsychicClient::close() {
|
||||
esp_err_t err = httpd_sess_trigger_close(_server, _socket);
|
||||
//PsychicHttpServer::closeCallback(_server, _socket); // call this immediately so the client is taken off the list.
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
IPAddress PsychicClient::localIP() {
|
||||
IPAddress address(0, 0, 0, 0);
|
||||
|
||||
char ipstr[INET6_ADDRSTRLEN];
|
||||
struct sockaddr_in6 addr; // esp_http_server uses IPv6 addressing
|
||||
socklen_t addr_size = sizeof(addr);
|
||||
|
||||
if (getsockname(_socket, (struct sockaddr *)&addr, &addr_size) < 0) {
|
||||
ESP_LOGE(PH_TAG, "Error getting client IP");
|
||||
return address;
|
||||
}
|
||||
|
||||
// Convert to IPv4 string
|
||||
inet_ntop(AF_INET, &addr.sin6_addr.un.u32_addr[3], ipstr, sizeof(ipstr));
|
||||
ESP_LOGI(PH_TAG, "Client Local IP => %s", ipstr);
|
||||
address.fromString(ipstr);
|
||||
|
||||
return address;
|
||||
}
|
||||
|
||||
IPAddress PsychicClient::remoteIP() {
|
||||
IPAddress address(0, 0, 0, 0);
|
||||
|
||||
char ipstr[INET6_ADDRSTRLEN];
|
||||
struct sockaddr_in6 addr; // esp_http_server uses IPv6 addressing
|
||||
socklen_t addr_size = sizeof(addr);
|
||||
|
||||
if (getpeername(_socket, (struct sockaddr *)&addr, &addr_size) < 0) {
|
||||
ESP_LOGE(PH_TAG, "Error getting client IP");
|
||||
return address;
|
||||
}
|
||||
|
||||
// Convert to IPv4 string
|
||||
inet_ntop(AF_INET, &addr.sin6_addr.un.u32_addr[3], ipstr, sizeof(ipstr));
|
||||
ESP_LOGI(PH_TAG, "Client Remote IP => %s", ipstr);
|
||||
address.fromString(ipstr);
|
||||
|
||||
return address;
|
||||
}
|
||||
Reference in New Issue
Block a user