Chromium Code Reviews| Index: net/proxy/proxy_resolver_v8_tracing_wrapper.cc |
| diff --git a/net/proxy/proxy_resolver_v8_tracing_wrapper.cc b/net/proxy/proxy_resolver_v8_tracing_wrapper.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..b300c2a90eca170ae45a54748d9af237b86536cb |
| --- /dev/null |
| +++ b/net/proxy/proxy_resolver_v8_tracing_wrapper.cc |
| @@ -0,0 +1,221 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "net/proxy/proxy_resolver_v8_tracing_wrapper.h" |
| + |
| +#include <string> |
| + |
| +#include "base/bind.h" |
| +#include "base/values.h" |
| +#include "net/base/net_errors.h" |
| +#include "net/log/net_log.h" |
| +#include "net/proxy/proxy_resolver_error_observer.h" |
| + |
| +namespace net { |
| +namespace { |
| + |
| +// Returns event parameters for a PAC error message (line number + message). |
| +scoped_ptr<base::Value> NetLogErrorCallback( |
| + int line_number, |
| + const base::string16* message, |
| + NetLogCaptureMode /* capture_mode */) { |
| + scoped_ptr<base::DictionaryValue> dict(new base::DictionaryValue()); |
| + dict->SetInteger("line_number", line_number); |
| + dict->SetString("message", *message); |
| + return dict.Pass(); |
| +} |
| + |
| +class ProxyResolverV8TracingWrapper : public ProxyResolver { |
| + public: |
| + ProxyResolverV8TracingWrapper( |
| + scoped_ptr<ProxyResolverV8Tracing> resolver_impl, |
| + NetLog* net_log, |
| + HostResolver* host_resolver, |
| + scoped_ptr<ProxyResolverErrorObserver> error_observer); |
| + |
| + int GetProxyForURL(const GURL& url, |
| + ProxyInfo* results, |
| + const CompletionCallback& callback, |
| + RequestHandle* request, |
| + const BoundNetLog& net_log) override; |
| + |
| + void CancelRequest(RequestHandle request) override; |
| + |
| + LoadState GetLoadState(RequestHandle request) const override; |
| + |
| + private: |
| + class BindingsImpl : public ProxyResolverV8Tracing::Bindings { |
| + public: |
| + BindingsImpl(ProxyResolverV8TracingWrapper* resolver, |
| + const BoundNetLog& bound_net_log) |
| + : resolver_(resolver), bound_net_log_(bound_net_log) {} |
| + |
| + void Alert(const base::string16& message) override { |
| + // Send to the NetLog. |
| + LogEventToCurrentRequestAndGlobally( |
| + NetLog::TYPE_PAC_JAVASCRIPT_ALERT, |
| + NetLog::StringCallback("message", &message)); |
| + } |
| + |
| + void OnError(int line_number, const base::string16& message) override { |
| + // Send the error to the NetLog. |
| + LogEventToCurrentRequestAndGlobally( |
| + NetLog::TYPE_PAC_JAVASCRIPT_ERROR, |
| + base::Bind(&NetLogErrorCallback, line_number, &message)); |
| + if (resolver_->error_observer_) |
| + resolver_->error_observer_->OnPACScriptError(line_number, message); |
| + } |
| + |
| + HostResolver* GetHostResolver() override { |
| + return resolver_->host_resolver_; |
| + } |
| + |
| + BoundNetLog GetBoundNetLog() override { return bound_net_log_; } |
| + |
| + private: |
| + void LogEventToCurrentRequestAndGlobally( |
| + NetLog::EventType type, |
| + const NetLog::ParametersCallback& parameters_callback) { |
| + bound_net_log_.AddEvent(type, parameters_callback); |
| + |
| + // Emit to the global NetLog event stream. |
| + if (resolver_->net_log_) |
| + resolver_->net_log_->AddGlobalEntry(type, parameters_callback); |
| + } |
| + |
| + ProxyResolverV8TracingWrapper* resolver_; |
| + BoundNetLog bound_net_log_; |
| + }; |
| + |
| + scoped_ptr<ProxyResolverV8Tracing> resolver_impl_; |
| + NetLog* net_log_; |
| + HostResolver* host_resolver_; |
| + scoped_ptr<ProxyResolverErrorObserver> error_observer_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8TracingWrapper); |
| +}; |
| + |
| +ProxyResolverV8TracingWrapper::ProxyResolverV8TracingWrapper( |
| + scoped_ptr<ProxyResolverV8Tracing> resolver_impl, |
| + NetLog* net_log, |
| + HostResolver* host_resolver, |
| + scoped_ptr<ProxyResolverErrorObserver> error_observer) |
| + : resolver_impl_(resolver_impl.Pass()), |
| + net_log_(net_log), |
| + host_resolver_(host_resolver), |
| + error_observer_(error_observer.Pass()) { |
| +} |
| + |
| +int ProxyResolverV8TracingWrapper::GetProxyForURL( |
| + const GURL& url, |
| + ProxyInfo* results, |
| + const CompletionCallback& callback, |
| + RequestHandle* request, |
| + const BoundNetLog& net_log) { |
| + resolver_impl_->GetProxyForURL( |
| + url, results, callback, request, |
| + make_scoped_ptr(new BindingsImpl(this, net_log))); |
| + return ERR_IO_PENDING; |
| +} |
| + |
| +void ProxyResolverV8TracingWrapper::CancelRequest(RequestHandle request) { |
| + resolver_impl_->CancelRequest(request); |
| +} |
| + |
| +LoadState ProxyResolverV8TracingWrapper::GetLoadState( |
| + RequestHandle request) const { |
| + return resolver_impl_->GetLoadState(request); |
| +} |
| + |
| +} // namespace |
| + |
| +class ProxyResolverFactoryV8TracingWrapper::BindingsImpl |
|
eroman
2015/06/05 01:11:47
This is the same as BindingsImpl above.
Can you e
Sam McNally
2015/06/23 00:32:47
Done.
|
| + : public ProxyResolverV8Tracing::Bindings { |
| + public: |
| + BindingsImpl(ProxyResolverFactoryV8TracingWrapper* factory, |
| + ProxyResolverErrorObserver* error_observer) |
| + : factory_(factory), error_observer_(error_observer) {} |
| + |
| + void Alert(const base::string16& message) override { |
| + // Send to the NetLog. |
| + LogEventToCurrentRequestAndGlobally( |
| + NetLog::TYPE_PAC_JAVASCRIPT_ALERT, |
| + NetLog::StringCallback("message", &message)); |
| + } |
| + |
| + void OnError(int line_number, const base::string16& message) override { |
| + // Send the error to the NetLog. |
| + LogEventToCurrentRequestAndGlobally( |
| + NetLog::TYPE_PAC_JAVASCRIPT_ERROR, |
| + base::Bind(&NetLogErrorCallback, line_number, &message)); |
| + if (error_observer_) |
| + error_observer_->OnPACScriptError(line_number, message); |
| + } |
| + |
| + HostResolver* GetHostResolver() override { return factory_->host_resolver_; } |
| + |
| + BoundNetLog GetBoundNetLog() override { return BoundNetLog(); } |
| + |
| + private: |
| + void LogEventToCurrentRequestAndGlobally( |
| + NetLog::EventType type, |
| + const NetLog::ParametersCallback& parameters_callback) { |
| + // Emit to the global NetLog event stream. |
| + if (factory_->net_log_) |
| + factory_->net_log_->AddGlobalEntry(type, parameters_callback); |
| + } |
| + |
| + ProxyResolverFactoryV8TracingWrapper* factory_; |
| + ProxyResolverErrorObserver* error_observer_; |
| +}; |
| + |
| +ProxyResolverFactoryV8TracingWrapper::ProxyResolverFactoryV8TracingWrapper( |
| + HostResolver* host_resolver, |
| + NetLog* net_log, |
| + const base::Callback<scoped_ptr<ProxyResolverErrorObserver>()>& |
| + error_observer_factory) |
| + : ProxyResolverFactory(true), |
| + factory_impl_(ProxyResolverV8TracingFactory::Create()), |
| + host_resolver_(host_resolver), |
| + net_log_(net_log), |
| + error_observer_factory_(error_observer_factory) { |
| +} |
| + |
| +ProxyResolverFactoryV8TracingWrapper::~ProxyResolverFactoryV8TracingWrapper() = |
| + default; |
| + |
| +int ProxyResolverFactoryV8TracingWrapper::CreateProxyResolver( |
| + const scoped_refptr<ProxyResolverScriptData>& pac_script, |
| + scoped_ptr<ProxyResolver>* resolver, |
| + const CompletionCallback& callback, |
| + scoped_ptr<Request>* request) { |
| + scoped_ptr<scoped_ptr<ProxyResolverV8Tracing>> passable_v8_resolver( |
| + new scoped_ptr<ProxyResolverV8Tracing>); |
| + scoped_ptr<ProxyResolverErrorObserver> error_observer = |
| + error_observer_factory_.Run(); |
| + scoped_ptr<ProxyResolverV8Tracing>* v8_resolver = passable_v8_resolver.get(); |
| + factory_impl_->CreateProxyResolverV8Tracing( |
| + pac_script, make_scoped_ptr(new BindingsImpl(this, error_observer.get())), |
| + v8_resolver, |
| + base::Bind(&ProxyResolverFactoryV8TracingWrapper::OnProxyResolverCreated, |
| + base::Unretained(this), base::Passed(&passable_v8_resolver), |
| + resolver, callback, base::Passed(&error_observer)), |
| + request); |
| + return ERR_IO_PENDING; |
| +} |
| + |
| +void ProxyResolverFactoryV8TracingWrapper::OnProxyResolverCreated( |
| + scoped_ptr<scoped_ptr<ProxyResolverV8Tracing>> v8_resolver, |
| + scoped_ptr<ProxyResolver>* resolver, |
| + const CompletionCallback& callback, |
| + scoped_ptr<ProxyResolverErrorObserver> error_observer, |
| + int error) { |
| + if (error == OK) { |
| + resolver->reset(new ProxyResolverV8TracingWrapper( |
| + v8_resolver->Pass(), net_log_, host_resolver_, error_observer.Pass())); |
| + } |
| + callback.Run(error); |
| +} |
| + |
| +} // namespace net |