X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/730b772b41ad9df76e5226290bb9eb917ea161f0..9e9574fe45b176ee74bba8fad7574cf9906145d1:/interface/wx/protocol/http.h diff --git a/interface/wx/protocol/http.h b/interface/wx/protocol/http.h index cdad04236d..744947e23a 100644 --- a/interface/wx/protocol/http.h +++ b/interface/wx/protocol/http.h @@ -2,8 +2,7 @@ // Name: protocol/http.h // Purpose: interface of wxHTTP // Author: wxWidgets team -// RCS-ID: $Id$ -// Licence: wxWindows license +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// /** @@ -38,9 +37,14 @@ public: By default, connection is made to the port 80 of the specified @a host. You may connect to a non-default port by specifying it explicitly using the second overload. + + Currently wxHTTP only supports IPv4. + + For the overload taking wxSockAddress, the @a wait argument is ignored. */ virtual bool Connect(const wxString& host); virtual bool Connect(const wxString& host, unsigned short port); + virtual bool Connect(const wxSockAddress& addr, bool wait); //@} /** @@ -85,6 +89,23 @@ public: */ int GetResponse() const; + /** + Set HTTP method. + + Set common + or expanded HTTP method. + + Overrides GET or POST methods that is used by default. + + @param method + HTTP method name, e.g. "GET". + + @since 3.0.0 + + @see SetPostBuffer(), SetPostText() + */ + void SetMethod(const wxString& method); + /** It sets data of a field to be sent during the next request to the HTTP server. @@ -92,5 +113,64 @@ public: This is a low level function and it assumes that you know what you are doing. */ void SetHeader(const wxString& header, const wxString& h_data); + + /** + Returns the value of a cookie. + */ + + wxString GetCookie(const wxString& cookie) const; + + /** + Returns @true if there were cookies. + */ + bool HasCookies() const; + + /** + Set the binary data to be posted to the server. + + If a non-empty buffer is passed to this method, the next request will + be an HTTP @c POST instead of the default HTTP @c GET and the given @a + data will be posted as the body of this request. + + For textual data a more convenient SetPostText() can be used instead. + + @param contentType + The value of HTTP "Content-Type" header, e.g. "image/png". + @param data + The data to post. + @return + @true if any data was passed in or @false if the buffer was empty. + + @since 2.9.4 + */ + bool SetPostBuffer(const wxString& contentType, const wxMemoryBuffer& data); + + /** + Set the text to be posted to the server. + + After a successful call to this method, the request will use HTTP @c + POST instead of the default @c GET when it's executed. + + Use SetPostBuffer() if you need to post non-textual data. + + @param contentType + The value of HTTP "Content-Type" header, e.g. "text/html; + charset=UTF-8". + @param data + The data to post. + @param conv + The conversion to use to convert @a data contents to a byte stream. + Its value should be consistent with the charset parameter specified + in @a contentType. + @return + @true if string was non-empty and was successfully converted using + the given @a conv or @false otherwise (in this case this request + won't be @c POST'ed correctly). + + @since 2.9.4 + */ + bool SetPostText(const wxString& contentType, + const wxString& data, + const wxMBConv& conv = wxConvUTF8); };