1
0
mirror of https://github.com/arduino/Arduino.git synced 2024-12-10 21:24:12 +01:00
Arduino/WiFi/WiFiClient.cpp

171 lines
3.2 KiB
C++
Raw Normal View History

2011-02-28 13:49:08 +01:00
extern "C" {
#include "utility/wl_definitions.h"
#include "utility/wl_types.h"
2011-02-28 13:49:08 +01:00
#include "socket.h"
#include "string.h"
#include "utility/debug.h"
2011-02-28 13:49:08 +01:00
}
#include "WiFi.h"
#include "WiFiClient.h"
#include "WiFiServer.h"
2011-02-28 13:49:08 +01:00
#include "server_drv.h"
uint16_t WiFiClient::_srcport = 1024;
2011-02-28 13:49:08 +01:00
WiFiClient::WiFiClient() : _sock(MAX_SOCK_NUM) {
}
WiFiClient::WiFiClient(uint8_t sock) : _sock(sock) {
2011-02-28 13:49:08 +01:00
}
int WiFiClient::connect(const char* host, uint16_t port) {
/* TODO Add DNS wifi spi function to resolve DNS */
#if 0
// Look up the host first
int ret = 0;
DNSClient dns;
IPAddress remote_addr;
dns.begin(Ethernet.dnsServerIP());
ret = dns.getHostByName(host, remote_addr);
if (ret == 1) {
return connect(remote_addr, port);
} else {
return ret;
}
#endif
2012-02-04 17:01:24 +01:00
return 0;
2011-02-28 13:49:08 +01:00
}
int WiFiClient::connect(IPAddress ip, uint16_t port) {
_sock = getFirstSocket();
if (_sock != NO_SOCKET_AVAIL)
2011-02-28 13:49:08 +01:00
{
ServerDrv::startClient(uint32_t(ip), port, _sock);
WiFiClass::_state[_sock] = _sock;
2011-02-28 13:49:08 +01:00
}else{
return 0;
2011-02-28 13:49:08 +01:00
}
return 1;
2011-02-28 13:49:08 +01:00
}
size_t WiFiClient::write(uint8_t b) {
2011-02-28 13:49:08 +01:00
if (_sock != 255)
{
START();
2011-02-28 13:49:08 +01:00
ServerDrv::sendData(_sock, &b, 1);
while (!ServerDrv::isDataSent(_sock));
END();
return 1;
2011-02-28 13:49:08 +01:00
}
return 0;
2011-02-28 13:49:08 +01:00
}
size_t WiFiClient::write(const uint8_t *buf, size_t size) {
2011-02-28 13:49:08 +01:00
if (_sock != 255)
{
ServerDrv::sendData(_sock, buf, size);
while (!ServerDrv::isDataSent(_sock));
return size;
2011-02-28 13:49:08 +01:00
}
return 0;
2011-02-28 13:49:08 +01:00
}
int WiFiClient::available() {
2011-02-28 13:49:08 +01:00
if (_sock != 255)
{
return ServerDrv::availData(_sock);
}
return 0;
}
int WiFiClient::read() {
2011-02-28 13:49:08 +01:00
uint8_t b;
if (!available())
return -1;
ServerDrv::getData(_sock, &b);
return b;
}
int WiFiClient::read(uint8_t* buf, size_t size) {
if (!ServerDrv::getDataBuf(_sock, buf, &size))
2011-02-28 13:49:08 +01:00
return -1;
return 0;
}
int WiFiClient::peek() {
//TODO to be implemented
return 0;
}
void WiFiClient::flush() {
2011-02-28 13:49:08 +01:00
while (available())
read();
}
void WiFiClient::stop() {
INFO("1)Stop WiFi client sock:%d state:%d status:%d", _sock, WiFiClass::_state[_sock], status());
2011-02-28 13:49:08 +01:00
if (_sock == 255)
return;
ServerDrv::stopClient(_sock);
2011-02-28 13:49:08 +01:00
unsigned long start = millis();
// wait a second for the connection to close
while (status() != CLOSED && millis() - start < 1000)
delay(1);
// if it hasn't closed, close it forcefully
if (status() != CLOSED)
{
//TODO force close
//close(_sock);
}
2011-02-28 13:49:08 +01:00
INFO("2)Stop WiFi client sock:%d state:%d status:%d", _sock, WiFiClass::_state[_sock], status());
2011-02-28 13:49:08 +01:00
_sock = 255;
}
uint8_t WiFiClient::connected() {
2011-02-28 13:49:08 +01:00
if (_sock == 255) {
return 0;
} else {
uint8_t s = status();
INFO("Client status: %d", s);
2011-02-28 13:49:08 +01:00
return !(s == LISTEN || s == CLOSED || s == FIN_WAIT_1 || s == FIN_WAIT_2 ||
(s == CLOSE_WAIT && !available()));
}
}
uint8_t WiFiClient::status() {
2011-02-28 13:49:08 +01:00
if (_sock == 255) {
return CLOSED;
} else {
return ServerDrv::getClientState(_sock);
2011-02-28 13:49:08 +01:00
}
}
WiFiClient::operator bool() {
2011-02-28 13:49:08 +01:00
return _sock != 255;
}
// Private Methods
uint8_t WiFiClient::getFirstSocket()
{
for (int i = 0; i < MAX_SOCK_NUM; i++) {
if (WiFiClass::_state[i] == 0)
{
return i;
}
}
return SOCK_NOT_AVAIL;
2011-02-28 13:49:08 +01:00
}