blob: fa2ffdb6ab00588a4e16b448d98e92f1254f3a93 [file] [log] [blame]
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001/*
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
21namespace rtc {
22
23///////////////////////////////////////////////////////////////////////////////
24// HttpRequest
25///////////////////////////////////////////////////////////////////////////////
26
27class FirewallManager;
28class MemoryStream;
29
30class HttpRequest {
31public:
32 HttpRequest(const std::string &user_agent);
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000033 ~HttpRequest();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000034
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
71protected:
72 void set_error(HttpErrorType error) { error_ = error; }
73
74private:
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
91class HttpMonitor : public sigslot::has_slots<> {
92public:
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
106private:
107 bool complete_;
108 HttpErrorType error_;
109 SocketServer *ss_;
110};
111
112///////////////////////////////////////////////////////////////////////////////
113
114} // namespace rtc_
115
116#endif // _HTTPREQUEST_H_