2016-12-30 01:44:45 +01:00
|
|
|
/*
|
|
|
|
Server.cpp - Server class for Raspberry Pi
|
|
|
|
Copyright (c) 2016 Hristo Gochkov All right reserved.
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with this library; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
#include "WiFiServer.h"
|
|
|
|
#include <lwip/sockets.h>
|
|
|
|
#include <lwip/netdb.h>
|
|
|
|
|
|
|
|
#undef write
|
2017-06-14 10:22:16 +02:00
|
|
|
#undef close
|
2016-12-30 01:44:45 +01:00
|
|
|
|
|
|
|
int WiFiServer::setTimeout(uint32_t seconds){
|
|
|
|
struct timeval tv;
|
|
|
|
tv.tv_sec = seconds;
|
|
|
|
tv.tv_usec = 0;
|
|
|
|
if(setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(struct timeval)) < 0)
|
|
|
|
return -1;
|
|
|
|
return setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, (char *)&tv, sizeof(struct timeval));
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t WiFiServer::write(const uint8_t *data, size_t len){
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void WiFiServer::stopAll(){}
|
|
|
|
|
|
|
|
WiFiClient WiFiServer::available(){
|
|
|
|
if(!_listening)
|
|
|
|
return WiFiClient();
|
2017-05-23 08:12:39 +02:00
|
|
|
int client_sock;
|
|
|
|
if (_accepted_sockfd >= 0) {
|
|
|
|
client_sock = _accepted_sockfd;
|
|
|
|
_accepted_sockfd = -1;
|
|
|
|
}
|
|
|
|
else {
|
2016-12-30 01:44:45 +01:00
|
|
|
struct sockaddr_in _client;
|
|
|
|
int cs = sizeof(struct sockaddr_in);
|
2017-11-30 16:17:26 +01:00
|
|
|
client_sock = lwip_accept_r(sockfd, (struct sockaddr *)&_client, (socklen_t*)&cs);
|
2017-05-23 08:12:39 +02:00
|
|
|
}
|
2016-12-30 01:44:45 +01:00
|
|
|
if(client_sock >= 0){
|
|
|
|
int val = 1;
|
2017-05-22 14:16:07 +02:00
|
|
|
if(setsockopt(client_sock, SOL_SOCKET, SO_KEEPALIVE, (char*)&val, sizeof(int)) == ESP_OK) {
|
|
|
|
val = _noDelay;
|
|
|
|
if(setsockopt(client_sock, IPPROTO_TCP, TCP_NODELAY, (char*)&val, sizeof(int)) == ESP_OK)
|
|
|
|
return WiFiClient(client_sock);
|
|
|
|
}
|
2016-12-30 01:44:45 +01:00
|
|
|
}
|
|
|
|
return WiFiClient();
|
|
|
|
}
|
|
|
|
|
2018-06-27 09:01:06 +02:00
|
|
|
void WiFiServer::begin(uint16_t port){
|
2020-11-06 13:16:50 +01:00
|
|
|
begin(port, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void WiFiServer::begin(uint16_t port, int enable){
|
2016-12-30 01:44:45 +01:00
|
|
|
if(_listening)
|
|
|
|
return;
|
2018-06-27 09:01:06 +02:00
|
|
|
if(port){
|
|
|
|
_port = port;
|
|
|
|
}
|
2016-12-30 01:44:45 +01:00
|
|
|
struct sockaddr_in server;
|
|
|
|
sockfd = socket(AF_INET , SOCK_STREAM, 0);
|
|
|
|
if (sockfd < 0)
|
|
|
|
return;
|
2020-11-06 13:16:50 +01:00
|
|
|
setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &enable, sizeof(int));
|
2016-12-30 01:44:45 +01:00
|
|
|
server.sin_family = AF_INET;
|
|
|
|
server.sin_addr.s_addr = INADDR_ANY;
|
|
|
|
server.sin_port = htons(_port);
|
|
|
|
if(bind(sockfd, (struct sockaddr *)&server, sizeof(server)) < 0)
|
|
|
|
return;
|
|
|
|
if(listen(sockfd , _max_clients) < 0)
|
|
|
|
return;
|
|
|
|
fcntl(sockfd, F_SETFL, O_NONBLOCK);
|
|
|
|
_listening = true;
|
2017-05-23 08:12:39 +02:00
|
|
|
_noDelay = false;
|
|
|
|
_accepted_sockfd = -1;
|
2016-12-30 01:44:45 +01:00
|
|
|
}
|
|
|
|
|
2017-05-22 14:16:07 +02:00
|
|
|
void WiFiServer::setNoDelay(bool nodelay) {
|
|
|
|
_noDelay = nodelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool WiFiServer::getNoDelay() {
|
|
|
|
return _noDelay;
|
|
|
|
}
|
|
|
|
|
2017-05-23 08:12:39 +02:00
|
|
|
bool WiFiServer::hasClient() {
|
|
|
|
if (_accepted_sockfd >= 0) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
struct sockaddr_in _client;
|
|
|
|
int cs = sizeof(struct sockaddr_in);
|
2017-11-30 16:17:26 +01:00
|
|
|
_accepted_sockfd = lwip_accept_r(sockfd, (struct sockaddr *)&_client, (socklen_t*)&cs);
|
2017-05-23 08:12:39 +02:00
|
|
|
if (_accepted_sockfd >= 0) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-12-30 01:44:45 +01:00
|
|
|
void WiFiServer::end(){
|
2017-06-14 10:22:16 +02:00
|
|
|
lwip_close_r(sockfd);
|
2016-12-30 01:44:45 +01:00
|
|
|
sockfd = -1;
|
|
|
|
_listening = false;
|
|
|
|
}
|
|
|
|
|
2017-06-14 10:22:16 +02:00
|
|
|
void WiFiServer::close(){
|
|
|
|
end();
|
|
|
|
}
|
|
|
|
|
|
|
|
void WiFiServer::stop(){
|
|
|
|
end();
|
|
|
|
}
|
|
|
|
|