1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-01-08 23:46:08 +01:00
Arduino/WiFi/WiFiClient.cpp

168 lines
2.9 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;
while(!connected());
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) {
return write(&b, 1);
2011-02-28 13:49:08 +01:00
}
size_t WiFiClient::write(const uint8_t *buf, size_t size) {
if (_sock >= MAX_SOCK_NUM)
2011-02-28 13:49:08 +01:00
{
setWriteError();
return 0;
2011-02-28 13:49:08 +01:00
}
if (size==0)
{
setWriteError();
return 0;
}
if ((!ServerDrv::sendData(_sock, buf, size)) ||
(!ServerDrv::checkDataSent(_sock)))
{
setWriteError();
return 0;
}
return size;
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;
2011-02-28 13:49:08 +01:00
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() {
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);
_sock = 255;
}
uint8_t WiFiClient::connected() {
2011-02-28 13:49:08 +01:00
if (_sock == 255) {
return 0;
} else {
uint8_t s = status();
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
}