OLD | NEW |
(Empty) | |
| 1 /* |
| 2 * Copyright 2006 The WebRTC Project Authors. All rights reserved. |
| 3 * |
| 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ |
| 10 |
| 11 #ifndef _HTTPREQUEST_H_ |
| 12 #define _HTTPREQUEST_H_ |
| 13 |
| 14 #include "webrtc/base/httpclient.h" |
| 15 #include "webrtc/base/logging.h" |
| 16 #include "webrtc/base/proxyinfo.h" |
| 17 #include "webrtc/base/socketserver.h" |
| 18 #include "webrtc/base/thread.h" |
| 19 #include "webrtc/base/sslsocketfactory.h" // Deprecated include |
| 20 |
| 21 namespace rtc { |
| 22 |
| 23 /////////////////////////////////////////////////////////////////////////////// |
| 24 // HttpRequest |
| 25 /////////////////////////////////////////////////////////////////////////////// |
| 26 |
| 27 class FirewallManager; |
| 28 class MemoryStream; |
| 29 |
| 30 class HttpRequest { |
| 31 public: |
| 32 HttpRequest(const std::string &user_agent); |
| 33 ~HttpRequest(); |
| 34 |
| 35 void Send(); |
| 36 |
| 37 void set_proxy(const ProxyInfo& proxy) { |
| 38 proxy_ = proxy; |
| 39 } |
| 40 void set_firewall(FirewallManager * firewall) { |
| 41 firewall_ = firewall; |
| 42 } |
| 43 |
| 44 // The DNS name of the host to connect to. |
| 45 const std::string& host() { return host_; } |
| 46 void set_host(const std::string& host) { host_ = host; } |
| 47 |
| 48 // The port to connect to on the target host. |
| 49 int port() { return port_; } |
| 50 void set_port(int port) { port_ = port; } |
| 51 |
| 52 // Whether the request should use SSL. |
| 53 bool secure() { return secure_; } |
| 54 void set_secure(bool secure) { secure_ = secure; } |
| 55 |
| 56 // Returns the redirect when redirection occurs |
| 57 const std::string& response_redirect() { return response_redirect_; } |
| 58 |
| 59 // Time to wait on the download, in ms. Default is 5000 (5s) |
| 60 int timeout() { return timeout_; } |
| 61 void set_timeout(int timeout) { timeout_ = timeout; } |
| 62 |
| 63 // Fail redirects to allow analysis of redirect urls, etc. |
| 64 bool fail_redirect() const { return fail_redirect_; } |
| 65 void set_fail_redirect(bool fail_redirect) { fail_redirect_ = fail_redirect; } |
| 66 |
| 67 HttpRequestData& request() { return client_.request(); } |
| 68 HttpResponseData& response() { return client_.response(); } |
| 69 HttpErrorType error() { return error_; } |
| 70 |
| 71 protected: |
| 72 void set_error(HttpErrorType error) { error_ = error; } |
| 73 |
| 74 private: |
| 75 ProxyInfo proxy_; |
| 76 FirewallManager * firewall_; |
| 77 std::string host_; |
| 78 int port_; |
| 79 bool secure_; |
| 80 int timeout_; |
| 81 bool fail_redirect_; |
| 82 HttpClient client_; |
| 83 HttpErrorType error_; |
| 84 std::string response_redirect_; |
| 85 }; |
| 86 |
| 87 /////////////////////////////////////////////////////////////////////////////// |
| 88 // HttpMonitor |
| 89 /////////////////////////////////////////////////////////////////////////////// |
| 90 |
| 91 class HttpMonitor : public sigslot::has_slots<> { |
| 92 public: |
| 93 HttpMonitor(SocketServer *ss); |
| 94 |
| 95 void reset() { |
| 96 complete_ = false; |
| 97 error_ = HE_DEFAULT; |
| 98 } |
| 99 |
| 100 bool done() const { return complete_; } |
| 101 HttpErrorType error() const { return error_; } |
| 102 |
| 103 void Connect(HttpClient* http); |
| 104 void OnHttpClientComplete(HttpClient * http, HttpErrorType error); |
| 105 |
| 106 private: |
| 107 bool complete_; |
| 108 HttpErrorType error_; |
| 109 SocketServer *ss_; |
| 110 }; |
| 111 |
| 112 /////////////////////////////////////////////////////////////////////////////// |
| 113 |
| 114 } // namespace rtc_ |
| 115 |
| 116 #endif // _HTTPREQUEST_H_ |
OLD | NEW |