/* * Copyright 2006 The WebRTC Project Authors. All rights reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef _HTTPREQUEST_H_ #define _HTTPREQUEST_H_ #include "webrtc/base/httpclient.h" #include "webrtc/base/logging.h" #include "webrtc/base/proxyinfo.h" #include "webrtc/base/socketserver.h" #include "webrtc/base/thread.h" #include "webrtc/base/sslsocketfactory.h" // Deprecated include namespace rtc { /////////////////////////////////////////////////////////////////////////////// // HttpRequest /////////////////////////////////////////////////////////////////////////////// class FirewallManager; class MemoryStream; class HttpRequest { public: HttpRequest(const std::string &user_agent); ~HttpRequest(); void Send(); void set_proxy(const ProxyInfo& proxy) { proxy_ = proxy; } void set_firewall(FirewallManager * firewall) { firewall_ = firewall; } // The DNS name of the host to connect to. const std::string& host() { return host_; } void set_host(const std::string& host) { host_ = host; } // The port to connect to on the target host. int port() { return port_; } void set_port(int port) { port_ = port; } // Whether the request should use SSL. bool secure() { return secure_; } void set_secure(bool secure) { secure_ = secure; } // Returns the redirect when redirection occurs const std::string& response_redirect() { return response_redirect_; } // Time to wait on the download, in ms. Default is 5000 (5s) int timeout() { return timeout_; } void set_timeout(int timeout) { timeout_ = timeout; } // Fail redirects to allow analysis of redirect urls, etc. bool fail_redirect() const { return fail_redirect_; } void set_fail_redirect(bool fail_redirect) { fail_redirect_ = fail_redirect; } HttpRequestData& request() { return client_.request(); } HttpResponseData& response() { return client_.response(); } HttpErrorType error() { return error_; } protected: void set_error(HttpErrorType error) { error_ = error; } private: ProxyInfo proxy_; FirewallManager * firewall_; std::string host_; int port_; bool secure_; int timeout_; bool fail_redirect_; HttpClient client_; HttpErrorType error_; std::string response_redirect_; }; /////////////////////////////////////////////////////////////////////////////// // HttpMonitor /////////////////////////////////////////////////////////////////////////////// class HttpMonitor : public sigslot::has_slots<> { public: HttpMonitor(SocketServer *ss); void reset() { complete_ = false; error_ = HE_DEFAULT; } bool done() const { return complete_; } HttpErrorType error() const { return error_; } void Connect(HttpClient* http); void OnHttpClientComplete(HttpClient * http, HttpErrorType error); private: bool complete_; HttpErrorType error_; SocketServer *ss_; }; /////////////////////////////////////////////////////////////////////////////// } // namespace rtc_ #endif // _HTTPREQUEST_H_