Port of LwIP performed by Ralf in 2010. Not recommended for use with recent mbed libraries, but good demos of raw LwIP possible

Dependents:   LwIP_raw_API_serverExample tiny-dtls

Committer:
RodColeman
Date:
Tue Sep 18 14:41:24 2012 +0000
Revision:
0:0791c1fece8e
[mbed] converted /Eth_TCP_Wei_Server/lwip

Who changed what in which revision?

UserRevisionLine numberNew contents of line
RodColeman 0:0791c1fece8e 1 #include "HTTPClient.h"
RodColeman 0:0791c1fece8e 2 #include "NetServer.h"
RodColeman 0:0791c1fece8e 3 #include "iputil.h"
RodColeman 0:0791c1fece8e 4
RodColeman 0:0791c1fece8e 5 using namespace mbed;
RodColeman 0:0791c1fece8e 6 using namespace std;
RodColeman 0:0791c1fece8e 7
RodColeman 0:0791c1fece8e 8 #define POST 0x1
RodColeman 0:0791c1fece8e 9 #define FDATA 0x2
RodColeman 0:0791c1fece8e 10 #define FRES 0x4
RodColeman 0:0791c1fece8e 11 #define GET 0x0
RodColeman 0:0791c1fece8e 12 #define CDATA 0x0
RodColeman 0:0791c1fece8e 13 #define CRES 0x0
RodColeman 0:0791c1fece8e 14
RodColeman 0:0791c1fece8e 15 long fleft(FILE *fd) {
RodColeman 0:0791c1fece8e 16 long len, cur;
RodColeman 0:0791c1fece8e 17 cur = ftell(fd);
RodColeman 0:0791c1fece8e 18 fseek(fd, 0, SEEK_END);
RodColeman 0:0791c1fece8e 19 len = ftell(fd);
RodColeman 0:0791c1fece8e 20 fseek(fd, cur, SEEK_SET);
RodColeman 0:0791c1fece8e 21 return len;
RodColeman 0:0791c1fece8e 22 }
RodColeman 0:0791c1fece8e 23
RodColeman 0:0791c1fece8e 24
RodColeman 0:0791c1fece8e 25 HTTPClient::HTTPClient(const char *hostname, struct ip_addr ip, struct ip_addr nm, struct ip_addr gw, struct ip_addr dns)
RodColeman 0:0791c1fece8e 26 : TCPConnection(), _auth(NULL), _timeout(0), _data(NULL), _headerfields(NULL), _timeout_max(60000) {
RodColeman 0:0791c1fece8e 27 NetServer *net = NULL;
RodColeman 0:0791c1fece8e 28 if(ip.addr != ip_addr_any.addr && nm.addr != ip_addr_any.addr && gw.addr != ip_addr_any.addr) {
RodColeman 0:0791c1fece8e 29 net = NetServer::create(ip, nm, gw);
RodColeman 0:0791c1fece8e 30 if(dns.addr != ip_addr_any.addr) {
RodColeman 0:0791c1fece8e 31 net->setDNS1(dns);
RodColeman 0:0791c1fece8e 32 }
RodColeman 0:0791c1fece8e 33 } else if(hostname) {
RodColeman 0:0791c1fece8e 34 net = NetServer::create();
RodColeman 0:0791c1fece8e 35 }
RodColeman 0:0791c1fece8e 36 if(hostname) {
RodColeman 0:0791c1fece8e 37 net->setHostname(hostname);
RodColeman 0:0791c1fece8e 38 }
RodColeman 0:0791c1fece8e 39 }
RodColeman 0:0791c1fece8e 40
RodColeman 0:0791c1fece8e 41 void HTTPClient::timeout(int value) {
RodColeman 0:0791c1fece8e 42 _timeout_max = value;
RodColeman 0:0791c1fece8e 43 }
RodColeman 0:0791c1fece8e 44
RodColeman 0:0791c1fece8e 45 void HTTPClient::err(err_t err) {
RodColeman 0:0791c1fece8e 46 release_callbacks();
RodColeman 0:0791c1fece8e 47 }
RodColeman 0:0791c1fece8e 48
RodColeman 0:0791c1fece8e 49 err_t HTTPClient::poll() {
RodColeman 0:0791c1fece8e 50 if(NetServer::time() - _timeout > _timeout_max) {
RodColeman 0:0791c1fece8e 51 release_callbacks();
RodColeman 0:0791c1fece8e 52 close();
RodColeman 0:0791c1fece8e 53 printf("TIMEOUT\n");
RodColeman 0:0791c1fece8e 54 _ready = true;
RodColeman 0:0791c1fece8e 55 _state = 99;
RodColeman 0:0791c1fece8e 56 }
RodColeman 0:0791c1fece8e 57 return ERR_OK;
RodColeman 0:0791c1fece8e 58 }
RodColeman 0:0791c1fece8e 59
RodColeman 0:0791c1fece8e 60 void HTTPClient::dnsreply(const char *hostname, struct ip_addr *ipaddr) {
RodColeman 0:0791c1fece8e 61 _ready = true;
RodColeman 0:0791c1fece8e 62 _ipaddr = *ipaddr;
RodColeman 0:0791c1fece8e 63 _state = (ipaddr==NULL)? 99 : 0;
RodColeman 0:0791c1fece8e 64 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 65 }
RodColeman 0:0791c1fece8e 66
RodColeman 0:0791c1fece8e 67 err_t HTTPClient::connected(err_t err) {
RodColeman 0:0791c1fece8e 68 TCPConnection::connected(err);
RodColeman 0:0791c1fece8e 69 _ready = false;
RodColeman 0:0791c1fece8e 70 _state = 0;
RodColeman 0:0791c1fece8e 71 _resultoff = 0;
RodColeman 0:0791c1fece8e 72 if(_mode&POST) {
RodColeman 0:0791c1fece8e 73 write((void *)"POST ", 5, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 74 } else {
RodColeman 0:0791c1fece8e 75 write((void *)"GET ", 4, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 76 }
RodColeman 0:0791c1fece8e 77 if(strlen(_path) == 0) {
RodColeman 0:0791c1fece8e 78 write((void *)"/", 1, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 79 } else {
RodColeman 0:0791c1fece8e 80 write((void *)_path, strlen(_path), TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 81 }
RodColeman 0:0791c1fece8e 82 write((void *)" HTTP/1.1\r\nHost: ", 17, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 83 write((void *)_host, _hostlen, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 84 if(_auth&&(*_auth!='\0')) {
RodColeman 0:0791c1fece8e 85 write((void *)"\r\nAuthorization: Basic ", 23, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 86 write((void *)_auth, strlen(_auth), TCP_WRITE_FLAG_COPY |TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 87 }
RodColeman 0:0791c1fece8e 88 if(_headerfields&&(*_headerfields!='\0')) {
RodColeman 0:0791c1fece8e 89 write((void *)"\r\n", 2, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 90 write((void *)_headerfields, strlen(_headerfields), TCP_WRITE_FLAG_COPY |TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 91 }
RodColeman 0:0791c1fece8e 92 write((void *)"\r\nConnection: Close\r\n", 21, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_COPY);
RodColeman 0:0791c1fece8e 93 if(_data) {
RodColeman 0:0791c1fece8e 94 char clen[256];
RodColeman 0:0791c1fece8e 95 int len, blen;
RodColeman 0:0791c1fece8e 96 if(_mode&FDATA) {
RodColeman 0:0791c1fece8e 97 //printf("Send file\n");
RodColeman 0:0791c1fece8e 98 len = fleft((FILE *)_data);
RodColeman 0:0791c1fece8e 99 sprintf(clen, "Content-Length: %d\r\n\r\n\0", len);
RodColeman 0:0791c1fece8e 100 write((void *)clen, strlen(clen), TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_COPY);
RodColeman 0:0791c1fece8e 101 if(len) {
RodColeman 0:0791c1fece8e 102 do {
RodColeman 0:0791c1fece8e 103 int sb = sndbuf();
RodColeman 0:0791c1fece8e 104 blen = fread(clen, sizeof(char), (int)min(sb, 100), (FILE *)_data);
RodColeman 0:0791c1fece8e 105 write(clen, blen, (TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE));
RodColeman 0:0791c1fece8e 106 len -= blen;
RodColeman 0:0791c1fece8e 107 } while(len > 1 && blen);
RodColeman 0:0791c1fece8e 108 }
RodColeman 0:0791c1fece8e 109 } else {
RodColeman 0:0791c1fece8e 110 len = strlen((const char *)_data);
RodColeman 0:0791c1fece8e 111 sprintf(clen, "Content-Length: %d\r\n\r\n\0", len);
RodColeman 0:0791c1fece8e 112 write((void *)clen, strlen(clen), TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_COPY);
RodColeman 0:0791c1fece8e 113 write((void *)_data, len, TCP_WRITE_FLAG_COPY | TCP_WRITE_FLAG_MORE);
RodColeman 0:0791c1fece8e 114 }
RodColeman 0:0791c1fece8e 115 }
RodColeman 0:0791c1fece8e 116 write((void *)"\r\n", 2, TCP_WRITE_FLAG_COPY);
RodColeman 0:0791c1fece8e 117 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 118 return ERR_OK;
RodColeman 0:0791c1fece8e 119 }
RodColeman 0:0791c1fece8e 120
RodColeman 0:0791c1fece8e 121 #define _min(x, y) (((x)<(y))?(x):(y))
RodColeman 0:0791c1fece8e 122 err_t HTTPClient::recv(struct pbuf *p, err_t err) {
RodColeman 0:0791c1fece8e 123 if(err == ERR_OK && p != NULL&&_state<10) {
RodColeman 0:0791c1fece8e 124 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 125 struct pbuf *q = p;
RodColeman 0:0791c1fece8e 126 char *d = (char *)q->payload;
RodColeman 0:0791c1fece8e 127 recved(p->tot_len);
RodColeman 0:0791c1fece8e 128
RodColeman 0:0791c1fece8e 129 while(q&&_state<10) {
RodColeman 0:0791c1fece8e 130 unsigned int end = ((unsigned int)(q->payload)+(unsigned int)(q->len));
RodColeman 0:0791c1fece8e 131 switch(_state) {
RodColeman 0:0791c1fece8e 132 case 0: {
RodColeman 0:0791c1fece8e 133 for(; _state==0 && ((unsigned int)d < end); d++) {
RodColeman 0:0791c1fece8e 134 if((*((char *)(d-0))=='\n')&&(*((char *)(d-1))=='\r')&&
RodColeman 0:0791c1fece8e 135 (*((char *)(d-2))=='\n')&&(*((char *)(d-3))=='\r')) {
RodColeman 0:0791c1fece8e 136 _state = 1;
RodColeman 0:0791c1fece8e 137 d += 1;
RodColeman 0:0791c1fece8e 138 break;
RodColeman 0:0791c1fece8e 139 }
RodColeman 0:0791c1fece8e 140 }
RodColeman 0:0791c1fece8e 141 } break;
RodColeman 0:0791c1fece8e 142 case 1: {
RodColeman 0:0791c1fece8e 143 if(_result) {
RodColeman 0:0791c1fece8e 144 if(_mode&FRES) {
RodColeman 0:0791c1fece8e 145 fwrite(d, sizeof(char), end - (unsigned int)d, (FILE *)_result);
RodColeman 0:0791c1fece8e 146 _resultoff += (end - (unsigned int)d);
RodColeman 0:0791c1fece8e 147 d = (char *)end;
RodColeman 0:0791c1fece8e 148 } else {
RodColeman 0:0791c1fece8e 149 unsigned int len = _min(_resultleft, (end-(unsigned int)d));
RodColeman 0:0791c1fece8e 150 memcpy((char *)_result + _resultoff, d, len);
RodColeman 0:0791c1fece8e 151 _resultleft -= len;
RodColeman 0:0791c1fece8e 152 _resultoff += len;
RodColeman 0:0791c1fece8e 153 d += len;
RodColeman 0:0791c1fece8e 154
RodColeman 0:0791c1fece8e 155 if(!_resultleft) {
RodColeman 0:0791c1fece8e 156 _state = 10;
RodColeman 0:0791c1fece8e 157 }
RodColeman 0:0791c1fece8e 158 }
RodColeman 0:0791c1fece8e 159 } else {
RodColeman 0:0791c1fece8e 160 _state = 10;
RodColeman 0:0791c1fece8e 161 }
RodColeman 0:0791c1fece8e 162 } break;
RodColeman 0:0791c1fece8e 163 default: {
RodColeman 0:0791c1fece8e 164 break;
RodColeman 0:0791c1fece8e 165 }
RodColeman 0:0791c1fece8e 166 }
RodColeman 0:0791c1fece8e 167 if(_state<10&&(unsigned int)d==end) {
RodColeman 0:0791c1fece8e 168 q = q->next;
RodColeman 0:0791c1fece8e 169 if(q) {
RodColeman 0:0791c1fece8e 170 d = static_cast<char *>(q->payload);
RodColeman 0:0791c1fece8e 171 }
RodColeman 0:0791c1fece8e 172 }
RodColeman 0:0791c1fece8e 173 }
RodColeman 0:0791c1fece8e 174 }
RodColeman 0:0791c1fece8e 175
RodColeman 0:0791c1fece8e 176 if(p!=NULL) {
RodColeman 0:0791c1fece8e 177 pbuf_free(p);
RodColeman 0:0791c1fece8e 178 }
RodColeman 0:0791c1fece8e 179
RodColeman 0:0791c1fece8e 180 if(_state>10||p==NULL||err!=ERR_OK) {
RodColeman 0:0791c1fece8e 181 release_callbacks();
RodColeman 0:0791c1fece8e 182 close();
RodColeman 0:0791c1fece8e 183 _ready = true;
RodColeman 0:0791c1fece8e 184 }
RodColeman 0:0791c1fece8e 185 return ERR_OK;
RodColeman 0:0791c1fece8e 186 }
RodColeman 0:0791c1fece8e 187
RodColeman 0:0791c1fece8e 188 unsigned int HTTPClient::make(const char *request) {
RodColeman 0:0791c1fece8e 189 _request = request;
RodColeman 0:0791c1fece8e 190 _resultoff = 0;
RodColeman 0:0791c1fece8e 191 _ready = false;
RodColeman 0:0791c1fece8e 192 _state = 0;
RodColeman 0:0791c1fece8e 193 _hostlen = 0;
RodColeman 0:0791c1fece8e 194 _port = 0;
RodColeman 0:0791c1fece8e 195 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 196 NetServer::ready();
RodColeman 0:0791c1fece8e 197
RodColeman 0:0791c1fece8e 198 int hostlen = 0;
RodColeman 0:0791c1fece8e 199 if(strlen(_request)<10||strncmp("http://", _request, 7)!=0) {
RodColeman 0:0791c1fece8e 200 printf("Only http requests are allowed\n");
RodColeman 0:0791c1fece8e 201 return 0;
RodColeman 0:0791c1fece8e 202 }
RodColeman 0:0791c1fece8e 203 _path = _host = _request + 6;
RodColeman 0:0791c1fece8e 204 _host++;
RodColeman 0:0791c1fece8e 205 while(!_state == 1) {
RodColeman 0:0791c1fece8e 206 switch(*(++_path)) {
RodColeman 0:0791c1fece8e 207 case ':':
RodColeman 0:0791c1fece8e 208 _port = atoi(_path+1);
RodColeman 0:0791c1fece8e 209 break;
RodColeman 0:0791c1fece8e 210 case '/':
RodColeman 0:0791c1fece8e 211 case '\0':
RodColeman 0:0791c1fece8e 212 _port = (_port)?_port:80;
RodColeman 0:0791c1fece8e 213 _state = 1;
RodColeman 0:0791c1fece8e 214 break;
RodColeman 0:0791c1fece8e 215 default:
RodColeman 0:0791c1fece8e 216 break;
RodColeman 0:0791c1fece8e 217 }
RodColeman 0:0791c1fece8e 218 if(!_port) {
RodColeman 0:0791c1fece8e 219 hostlen++;
RodColeman 0:0791c1fece8e 220 }
RodColeman 0:0791c1fece8e 221 if(!_state == 1) {
RodColeman 0:0791c1fece8e 222 _hostlen++;
RodColeman 0:0791c1fece8e 223 }
RodColeman 0:0791c1fece8e 224 }
RodColeman 0:0791c1fece8e 225 _state = 0;
RodColeman 0:0791c1fece8e 226
RodColeman 0:0791c1fece8e 227 if(hostlen>256) {
RodColeman 0:0791c1fece8e 228 printf("Hostname longer than allowed\n");
RodColeman 0:0791c1fece8e 229 return 0;
RodColeman 0:0791c1fece8e 230 }
RodColeman 0:0791c1fece8e 231
RodColeman 0:0791c1fece8e 232 char host[257];
RodColeman 0:0791c1fece8e 233 memcpy(host, _host, hostlen);
RodColeman 0:0791c1fece8e 234 host[hostlen] = 0;
RodColeman 0:0791c1fece8e 235 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 236 struct in_addr in;
RodColeman 0:0791c1fece8e 237 if(!inet_aton(host, &in)) {
RodColeman 0:0791c1fece8e 238 _ready = false;
RodColeman 0:0791c1fece8e 239 if(dnsrequest(host, &_ipaddr)==ERR_INPROGRESS) {
RodColeman 0:0791c1fece8e 240 while(!_ready) {
RodColeman 0:0791c1fece8e 241 NetServer::poll();
RodColeman 0:0791c1fece8e 242 wait_ms(10);
RodColeman 0:0791c1fece8e 243 }
RodColeman 0:0791c1fece8e 244 if(_state==99) {
RodColeman 0:0791c1fece8e 245 printf("Server not found\n");
RodColeman 0:0791c1fece8e 246 return 0;
RodColeman 0:0791c1fece8e 247 }
RodColeman 0:0791c1fece8e 248 }
RodColeman 0:0791c1fece8e 249 } else {
RodColeman 0:0791c1fece8e 250 _ipaddr.addr = in.s_addr;
RodColeman 0:0791c1fece8e 251 }
RodColeman 0:0791c1fece8e 252
RodColeman 0:0791c1fece8e 253 _ready = false;
RodColeman 0:0791c1fece8e 254 _timeout = NetServer::time();
RodColeman 0:0791c1fece8e 255 connect();
RodColeman 0:0791c1fece8e 256 set_poll_interval(10);
RodColeman 0:0791c1fece8e 257 tcp_setprio(_pcb, TCP_PRIO_MIN);
RodColeman 0:0791c1fece8e 258 while(!_ready) {
RodColeman 0:0791c1fece8e 259 NetServer::poll();
RodColeman 0:0791c1fece8e 260 wait_ms(10);
RodColeman 0:0791c1fece8e 261 }
RodColeman 0:0791c1fece8e 262 //release_callbacks();
RodColeman 0:0791c1fece8e 263 close();
RodColeman 0:0791c1fece8e 264 if(_state==99) {
RodColeman 0:0791c1fece8e 265 printf("Connection error\n");
RodColeman 0:0791c1fece8e 266 return 0;
RodColeman 0:0791c1fece8e 267 }
RodColeman 0:0791c1fece8e 268
RodColeman 0:0791c1fece8e 269 if(!_mode&FRES&&_result) {
RodColeman 0:0791c1fece8e 270 ((char *)_result)[_resultoff+1] = '\0';
RodColeman 0:0791c1fece8e 271 }
RodColeman 0:0791c1fece8e 272 return ((!_mode&FRES)&&!_result)?1:_resultoff;
RodColeman 0:0791c1fece8e 273
RodColeman 0:0791c1fece8e 274 }
RodColeman 0:0791c1fece8e 275
RodColeman 0:0791c1fece8e 276 void HTTPClient::auth(const char *user, const char *password) {
RodColeman 0:0791c1fece8e 277 if(user) {
RodColeman 0:0791c1fece8e 278 char up[256];
RodColeman 0:0791c1fece8e 279 sprintf(up, "%s:%s", user, password);
RodColeman 0:0791c1fece8e 280 _auth = new char[base64enc_len(up)+1];
RodColeman 0:0791c1fece8e 281 base64enc(up, strlen(up), _auth);
RodColeman 0:0791c1fece8e 282 } else if(_auth) {
RodColeman 0:0791c1fece8e 283 delete _auth;
RodColeman 0:0791c1fece8e 284 _auth = NULL;
RodColeman 0:0791c1fece8e 285 }
RodColeman 0:0791c1fece8e 286 }
RodColeman 0:0791c1fece8e 287
RodColeman 0:0791c1fece8e 288 void HTTPClient::headers(const char *fields) {
RodColeman 0:0791c1fece8e 289 _headerfields = fields;
RodColeman 0:0791c1fece8e 290 }
RodColeman 0:0791c1fece8e 291
RodColeman 0:0791c1fece8e 292 unsigned int HTTPClient::get(const char *url, char *result, int rsize) {
RodColeman 0:0791c1fece8e 293 _mode = GET | CDATA | CRES;
RodColeman 0:0791c1fece8e 294 _data = (void *)NULL;
RodColeman 0:0791c1fece8e 295 _result = (void *)result;
RodColeman 0:0791c1fece8e 296 _resultleft = rsize -1;
RodColeman 0:0791c1fece8e 297
RodColeman 0:0791c1fece8e 298 return make(url);
RodColeman 0:0791c1fece8e 299 }
RodColeman 0:0791c1fece8e 300
RodColeman 0:0791c1fece8e 301 unsigned int HTTPClient::get(const char *url, FILE *result) {
RodColeman 0:0791c1fece8e 302 _mode = GET | CDATA | FRES;
RodColeman 0:0791c1fece8e 303 _data = (void *)NULL;
RodColeman 0:0791c1fece8e 304 _result = (void *)result;
RodColeman 0:0791c1fece8e 305 _resultleft = 0;
RodColeman 0:0791c1fece8e 306
RodColeman 0:0791c1fece8e 307 return make(url);
RodColeman 0:0791c1fece8e 308 }
RodColeman 0:0791c1fece8e 309
RodColeman 0:0791c1fece8e 310 unsigned int HTTPClient::post(const char *url, const char *data, char *result, int rsize) {
RodColeman 0:0791c1fece8e 311 _mode = POST | CDATA | CRES;
RodColeman 0:0791c1fece8e 312 _data = (void *)data;
RodColeman 0:0791c1fece8e 313 _result = (void *)result;
RodColeman 0:0791c1fece8e 314 _resultleft = rsize -1;
RodColeman 0:0791c1fece8e 315
RodColeman 0:0791c1fece8e 316 return make(url);
RodColeman 0:0791c1fece8e 317 }
RodColeman 0:0791c1fece8e 318
RodColeman 0:0791c1fece8e 319 unsigned int HTTPClient::post(const char *url, const char *data, FILE *result) {
RodColeman 0:0791c1fece8e 320 _mode = POST | CDATA | FRES;
RodColeman 0:0791c1fece8e 321 _data = (void *)data;
RodColeman 0:0791c1fece8e 322 _result = (void *)result;
RodColeman 0:0791c1fece8e 323 _resultleft = 0;
RodColeman 0:0791c1fece8e 324
RodColeman 0:0791c1fece8e 325 return make(url);
RodColeman 0:0791c1fece8e 326 }
RodColeman 0:0791c1fece8e 327
RodColeman 0:0791c1fece8e 328 unsigned int HTTPClient::post(const char *url, FILE *data, FILE *result) {
RodColeman 0:0791c1fece8e 329 _mode = POST | FDATA | FRES;
RodColeman 0:0791c1fece8e 330 _data = (void *)data;
RodColeman 0:0791c1fece8e 331 _result = (void *)result;
RodColeman 0:0791c1fece8e 332 _resultleft = 0;
RodColeman 0:0791c1fece8e 333
RodColeman 0:0791c1fece8e 334 return make(url);
RodColeman 0:0791c1fece8e 335 }
RodColeman 0:0791c1fece8e 336
RodColeman 0:0791c1fece8e 337 unsigned int HTTPClient::post(const char *url, FILE *data, char *result, int rsize) {
RodColeman 0:0791c1fece8e 338 _mode = POST | FDATA | CRES;
RodColeman 0:0791c1fece8e 339 _data = (void *)data;
RodColeman 0:0791c1fece8e 340 _result = (void *)result;
RodColeman 0:0791c1fece8e 341 _resultleft = rsize -1;
RodColeman 0:0791c1fece8e 342
RodColeman 0:0791c1fece8e 343 return make(url);
RodColeman 0:0791c1fece8e 344 }
RodColeman 0:0791c1fece8e 345