1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_PROXY_PROXY_RESOLVER_V8_TRACING_H_
6 #define NET_PROXY_PROXY_RESOLVER_V8_TRACING_H_
8 #include "base/basictypes.h"
9 #include "base/memory/ref_counted.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "base/threading/non_thread_safe.h"
12 #include "net/base/net_export.h"
13 #include "net/proxy/proxy_resolver.h"
17 class MessageLoopProxy
;
24 class ProxyResolverErrorObserver
;
25 class ProxyResolverV8
;
27 // ProxyResolverV8Tracing is a non-blocking ProxyResolver. It executes
28 // ProxyResolverV8 on a single helper thread, and does some magic to avoid
29 // blocking in DNS. For more details see the design document:
30 // https://docs.google.com/a/google.com/document/d/16Ij5OcVnR3s0MH4Z5XkhI9VTPoMJdaBn9rKreAmGOdE/edit?pli=1
31 class NET_EXPORT_PRIVATE ProxyResolverV8Tracing
32 : public ProxyResolver
,
33 NON_EXPORTED_BASE(public base::NonThreadSafe
) {
35 // Constructs a ProxyResolver that will issue DNS requests through
36 // |host_resolver|, forward Javascript errors through |error_observer|, and
37 // log Javascript errors and alerts to |net_log|.
39 // Note that the constructor takes ownership of |error_observer|, whereas
40 // |host_resolver| and |net_log| are expected to outlive |this|.
41 ProxyResolverV8Tracing(HostResolver
* host_resolver
,
42 ProxyResolverErrorObserver
* error_observer
,
45 // Constructs a ProxyResolver that will issue DNS requests through
46 // |host_resolver|, forward Javascript errors through |error_observer|, and
47 // log Javascript errors and alerts to |net_log|. When the LoadState for a
48 // request changes, |on_load_state_changed| will be invoked with the
49 // RequestHandle for that request with the new LoadState.
51 // Note that the constructor takes ownership of |error_observer|, whereas
52 // |host_resolver| and |net_log| are expected to outlive |this|.
53 ProxyResolverV8Tracing(HostResolver
* host_resolver
,
54 ProxyResolverErrorObserver
* error_observer
,
56 const LoadStateChangedCallback
& on_load_state_changed
);
58 ~ProxyResolverV8Tracing() override
;
60 // ProxyResolver implementation:
61 int GetProxyForURL(const GURL
& url
,
63 const CompletionCallback
& callback
,
64 RequestHandle
* request
,
65 const BoundNetLog
& net_log
) override
;
66 void CancelRequest(RequestHandle request
) override
;
67 LoadState
GetLoadState(RequestHandle request
) const override
;
68 void CancelSetPacScript() override
;
69 int SetPacScript(const scoped_refptr
<ProxyResolverScriptData
>& script_data
,
70 const CompletionCallback
& callback
) override
;
75 // The worker thread on which the ProxyResolverV8 will be run.
76 scoped_ptr
<base::Thread
> thread_
;
77 scoped_ptr
<ProxyResolverV8
> v8_resolver_
;
79 // Non-owned host resolver, which is to be operated on the origin thread.
80 HostResolver
* host_resolver_
;
82 scoped_ptr
<ProxyResolverErrorObserver
> error_observer_
;
85 // The outstanding SetPacScript operation, or NULL.
86 scoped_refptr
<Job
> set_pac_script_job_
;
88 // The number of outstanding (non-cancelled) jobs.
89 int num_outstanding_callbacks_
;
91 // Invoked when the load state for a request changes.
92 const LoadStateChangedCallback on_load_state_changed_
;
94 DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8Tracing
);
99 #endif // NET_PROXY_PROXY_RESOLVER_V8_TRACING_H_