/* * Copyright 2004 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 WEBRTC_BASE_ASYNCHTTPREQUEST_H_ #define WEBRTC_BASE_ASYNCHTTPREQUEST_H_ #include <string> #include "webrtc/base/event.h" #include "webrtc/base/httpclient.h" #include "webrtc/base/signalthread.h" #include "webrtc/base/socketpool.h" #include "webrtc/base/sslsocketfactory.h" namespace rtc { class FirewallManager; /////////////////////////////////////////////////////////////////////////////// // AsyncHttpRequest // Performs an HTTP request on a background thread. Notifies on the foreground // thread once the request is done (successfully or unsuccessfully). /////////////////////////////////////////////////////////////////////////////// class AsyncHttpRequest : public SignalThread { public: explicit AsyncHttpRequest(const std::string &user_agent); ~AsyncHttpRequest(); // If start_delay is less than or equal to zero, this starts immediately. // Start_delay defaults to zero. int start_delay() const { return start_delay_; } void set_start_delay(int delay) { start_delay_ = delay; } const ProxyInfo& proxy() const { return proxy_; } 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; } // Time to wait on the download, in ms. 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 redirect) { fail_redirect_ = redirect; } // Returns the redirect when redirection occurs const std::string& response_redirect() { return response_redirect_; } HttpRequestData& request() { return client_.request(); } HttpResponseData& response() { return client_.response(); } HttpErrorType error() { return error_; } protected: void set_error(HttpErrorType error) { error_ = error; } virtual void OnWorkStart(); virtual void OnWorkStop(); void OnComplete(HttpClient* client, HttpErrorType error); virtual void OnMessage(Message* message); virtual void DoWork(); private: void LaunchRequest(); int start_delay_; ProxyInfo proxy_; FirewallManager* firewall_; std::string host_; int port_; bool secure_; int timeout_; bool fail_redirect_; SslSocketFactory factory_; ReuseSocketPool pool_; HttpClient client_; HttpErrorType error_; std::string response_redirect_; }; } // namespace rtc #endif // WEBRTC_BASE_ASYNCHTTPREQUEST_H_