Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1575)

Unified Diff: net/proxy/proxy_resolver_v8_tracing_wrapper.cc

Issue 1145153004: Split ProxyResolverV8Tracing into an implementation and a wrapper. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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

Powered by Google App Engine
This is Rietveld 408576698