123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- /**
- * \addtogroup webclient
- * @{
- */
- /**
- * \file
- * Header file for the HTTP client.
- * \author Adam Dunkels <adam@dunkels.com>
- */
- /*
- * Copyright (c) 2002, Adam Dunkels.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following
- * disclaimer in the documentation and/or other materials provided
- * with the distribution.
- * 3. The name of the author may not be used to endorse or promote
- * products derived from this software without specific prior
- * written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
- * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
- * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
- * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- * This file is part of the uIP TCP/IP stack.
- *
- * $Id: webclient.h,v 1.2 2006/06/11 21:46:37 adam Exp $
- *
- */
- #ifndef __WEBCLIENT_H__
- #define __WEBCLIENT_H__
- #include "webclient-strings.h"
- #include "uipopt.h"
- #define WEBCLIENT_CONF_MAX_URLLEN 100
- struct webclient_state {
- u8_t timer;
- u8_t state;
- u8_t httpflag;
- u16_t port;
- char host[40];
- char file[WEBCLIENT_CONF_MAX_URLLEN];
- u16_t getrequestptr;
- u16_t getrequestleft;
-
- char httpheaderline[200];
- u16_t httpheaderlineptr;
- char mimetype[32];
- };
- typedef struct webclient_state uip_tcp_appstate_t;
- #define UIP_APPCALL webclient_appcall
- /**
- * Callback function that is called from the webclient code when HTTP
- * data has been received.
- *
- * This function must be implemented by the module that uses the
- * webclient code. The function is called from the webclient module
- * when HTTP data has been received. The function is not called when
- * HTTP headers are received, only for the actual data.
- *
- * \note This function is called many times, repetedly, when data is
- * being received, and not once when all data has been received.
- *
- * \param data A pointer to the data that has been received.
- * \param len The length of the data that has been received.
- */
- void webclient_datahandler(char *data, u16_t len);
- /**
- * Callback function that is called from the webclient code when the
- * HTTP connection has been connected to the web server.
- *
- * This function must be implemented by the module that uses the
- * webclient code.
- */
- void webclient_connected(void);
- /**
- * Callback function that is called from the webclient code if the
- * HTTP connection to the web server has timed out.
- *
- * This function must be implemented by the module that uses the
- * webclient code.
- */
- void webclient_timedout(void);
- /**
- * Callback function that is called from the webclient code if the
- * HTTP connection to the web server has been aborted by the web
- * server.
- *
- * This function must be implemented by the module that uses the
- * webclient code.
- */
- void webclient_aborted(void);
- /**
- * Callback function that is called from the webclient code when the
- * HTTP connection to the web server has been closed.
- *
- * This function must be implemented by the module that uses the
- * webclient code.
- */
- void webclient_closed(void);
- /**
- * Initialize the webclient module.
- */
- void webclient_init(void);
- /**
- * Open an HTTP connection to a web server and ask for a file using
- * the GET method.
- *
- * This function opens an HTTP connection to the specified web server
- * and requests the specified file using the GET method. When the HTTP
- * connection has been connected, the webclient_connected() callback
- * function is called and when the HTTP data arrives the
- * webclient_datahandler() callback function is called.
- *
- * The callback function webclient_timedout() is called if the web
- * server could not be contacted, and the webclient_aborted() callback
- * function is called if the HTTP connection is aborted by the web
- * server.
- *
- * When the HTTP request has been completed and the HTTP connection is
- * closed, the webclient_closed() callback function will be called.
- *
- * \note If the function is passed a host name, it must already be in
- * the resolver cache in order for the function to connect to the web
- * server. It is therefore up to the calling module to implement the
- * resolver calls and the signal handler used for reporting a resolv
- * query answer.
- *
- * \param host A pointer to a string containing either a host name or
- * a numerical IP address in dotted decimal notation (e.g., 192.168.23.1).
- *
- * \param port The port number to which to connect, in host byte order.
- *
- * \param file A pointer to the name of the file to get.
- *
- * \retval 0 if the host name could not be found in the cache, or
- * if a TCP connection could not be created.
- *
- * \retval 1 if the connection was initiated.
- */
- unsigned char webclient_get(char *host, u16_t port, char *file);
- /**
- * Close the currently open HTTP connection.
- */
- void webclient_close(void);
- void webclient_appcall(void);
- /**
- * Obtain the MIME type of the current HTTP data stream.
- *
- * \return A pointer to a string contaning the MIME type. The string
- * may be empty if no MIME type was reported by the web server.
- */
- char *webclient_mimetype(void);
- /**
- * Obtain the filename of the current HTTP data stream.
- *
- * The filename of an HTTP request may be changed by the web server,
- * and may therefore not be the same as when the original GET request
- * was made with webclient_get(). This function is used for obtaining
- * the current filename.
- *
- * \return A pointer to the current filename.
- */
- char *webclient_filename(void);
- /**
- * Obtain the hostname of the current HTTP data stream.
- *
- * The hostname of the web server of an HTTP request may be changed
- * by the web server, and may therefore not be the same as when the
- * original GET request was made with webclient_get(). This function
- * is used for obtaining the current hostname.
- *
- * \return A pointer to the current hostname.
- */
- char *webclient_hostname(void);
- /**
- * Obtain the port number of the current HTTP data stream.
- *
- * The port number of an HTTP request may be changed by the web
- * server, and may therefore not be the same as when the original GET
- * request was made with webclient_get(). This function is used for
- * obtaining the current port number.
- *
- * \return The port number of the current HTTP data stream, in host byte order.
- */
- unsigned short webclient_port(void);
- #endif /* __WEBCLIENT_H__ */
- /** @} */
|