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

Unified Diff: net/proxy/proxy_resolver_mojo.cc

Issue 1017453005: Add support for ProxyResolverErrorObserver to ProxyResolverMojo. (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
« no previous file with comments | « net/proxy/proxy_resolver_mojo.h ('k') | net/proxy/proxy_resolver_mojo_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/proxy/proxy_resolver_mojo.cc
diff --git a/net/proxy/proxy_resolver_mojo.cc b/net/proxy/proxy_resolver_mojo.cc
index c676827a90ae9d2e1d190599283e62445d6517b5..c0e38fb26a138a37d53d2ab233fa158894d12730 100644
--- a/net/proxy/proxy_resolver_mojo.cc
+++ b/net/proxy/proxy_resolver_mojo.cc
@@ -4,20 +4,123 @@
#include "net/proxy/proxy_resolver_mojo.h"
+#include <set>
+
#include "base/bind.h"
#include "base/logging.h"
#include "base/stl_util.h"
+#include "base/threading/thread_checker.h"
#include "mojo/common/common_type_converters.h"
#include "mojo/common/url_type_converters.h"
+#include "net/base/load_states.h"
#include "net/base/net_errors.h"
#include "net/dns/mojo_host_resolver_impl.h"
+#include "net/interfaces/host_resolver_service.mojom.h"
+#include "net/interfaces/proxy_resolver_service.mojom.h"
#include "net/proxy/mojo_proxy_resolver_factory.h"
#include "net/proxy/mojo_proxy_type_converters.h"
#include "net/proxy/proxy_info.h"
+#include "net/proxy/proxy_resolver.h"
+#include "net/proxy/proxy_resolver_error_observer.h"
+#include "net/proxy/proxy_resolver_script_data.h"
#include "third_party/mojo/src/mojo/public/cpp/bindings/binding.h"
#include "third_party/mojo/src/mojo/public/cpp/bindings/error_handler.h"
namespace net {
+namespace {
+
+class ErrorObserverHolder : public interfaces::ProxyResolverErrorObserver {
+ public:
+ ErrorObserverHolder(
+ scoped_ptr<net::ProxyResolverErrorObserver> error_observer,
+ mojo::InterfaceRequest<interfaces::ProxyResolverErrorObserver> request);
+ ~ErrorObserverHolder() override;
+
+ void OnPacScriptError(int32_t line_number,
+ const mojo::String& error) override;
+
+ private:
+ scoped_ptr<net::ProxyResolverErrorObserver> error_observer_;
+ mojo::Binding<interfaces::ProxyResolverErrorObserver> binding_;
+
+ DISALLOW_COPY_AND_ASSIGN(ErrorObserverHolder);
+};
+
+ErrorObserverHolder::ErrorObserverHolder(
+ scoped_ptr<net::ProxyResolverErrorObserver> error_observer,
+ mojo::InterfaceRequest<interfaces::ProxyResolverErrorObserver> request)
+ : error_observer_(error_observer.Pass()), binding_(this, request.Pass()) {
+}
+
+ErrorObserverHolder::~ErrorObserverHolder() = default;
+
+void ErrorObserverHolder::OnPacScriptError(int32_t line_number,
+ const mojo::String& error) {
+ DCHECK(error_observer_);
+ error_observer_->OnPACScriptError(line_number, error.To<base::string16>());
+}
+
+// Implementation of ProxyResolver that connects to a Mojo service to evaluate
+// PAC scripts. This implementation only knows about Mojo services, and
+// therefore that service may live in or out of process.
+//
+// This implementation reports disconnections from the Mojo service (i.e. if the
+// service is out-of-process and that process crashes) using the error code
+// ERR_PAC_SCRIPT_TERMINATED.
+class ProxyResolverMojo : public ProxyResolver, public mojo::ErrorHandler {
+ public:
+ // Constructs a ProxyResolverMojo that connects to a mojo proxy resolver
+ // implementation using |resolver_ptr|. The implementation uses
+ // |host_resolver| as the DNS resolver, using |host_resolver_binding| to
+ // communicate with it. When deleted, the closure contained within
+ // |on_delete_callback_runner| will be run.
+ // TODO(amistry): Add NetLog.
+ ProxyResolverMojo(
+ interfaces::ProxyResolverPtr resolver_ptr,
+ scoped_ptr<interfaces::HostResolver> host_resolver,
+ scoped_ptr<mojo::Binding<interfaces::HostResolver>> host_resolver_binding,
+ scoped_ptr<base::ScopedClosureRunner> on_delete_callback_runner,
+ scoped_ptr<ErrorObserverHolder> error_observer);
+ ~ProxyResolverMojo() override;
+
+ // ProxyResolver implementation:
+ int GetProxyForURL(const GURL& url,
+ ProxyInfo* results,
+ const net::CompletionCallback& callback,
+ RequestHandle* request,
+ const BoundNetLog& net_log) override;
+ void CancelRequest(RequestHandle request) override;
+ LoadState GetLoadState(RequestHandle request) const override;
+ void CancelSetPacScript() override;
+ int SetPacScript(const scoped_refptr<ProxyResolverScriptData>& pac_script,
+ const net::CompletionCallback& callback) override;
+
+ private:
+ class Job;
+
+ // Overridden from mojo::ErrorHandler:
+ void OnConnectionError() override;
+
+ void RemoveJob(Job* job);
+
+ // Connection to the Mojo proxy resolver.
+ interfaces::ProxyResolverPtr mojo_proxy_resolver_ptr_;
+
+ // Mojo host resolver service and binding.
+ scoped_ptr<interfaces::HostResolver> mojo_host_resolver_;
+ scoped_ptr<mojo::Binding<interfaces::HostResolver>>
+ mojo_host_resolver_binding_;
+
+ scoped_ptr<ErrorObserverHolder> error_observer_;
+
+ std::set<Job*> pending_jobs_;
+
+ base::ThreadChecker thread_checker_;
+
+ scoped_ptr<base::ScopedClosureRunner> on_delete_callback_runner_;
+
+ DISALLOW_COPY_AND_ASSIGN(ProxyResolverMojo);
+};
class ProxyResolverMojo::Job : public interfaces::ProxyResolverRequestClient,
public mojo::ErrorHandler {
@@ -114,11 +217,13 @@ ProxyResolverMojo::ProxyResolverMojo(
interfaces::ProxyResolverPtr resolver_ptr,
scoped_ptr<interfaces::HostResolver> host_resolver,
scoped_ptr<mojo::Binding<interfaces::HostResolver>> host_resolver_binding,
- scoped_ptr<base::ScopedClosureRunner> on_delete_callback_runner)
+ scoped_ptr<base::ScopedClosureRunner> on_delete_callback_runner,
+ scoped_ptr<ErrorObserverHolder> error_observer)
: ProxyResolver(true),
mojo_proxy_resolver_ptr_(resolver_ptr.Pass()),
mojo_host_resolver_(host_resolver.Pass()),
mojo_host_resolver_binding_(host_resolver_binding.Pass()),
+ error_observer_(error_observer.Pass()),
on_delete_callback_runner_(on_delete_callback_runner.Pass()) {
mojo_proxy_resolver_ptr_.set_error_handler(this);
}
@@ -187,6 +292,8 @@ LoadState ProxyResolverMojo::GetLoadState(RequestHandle request) const {
return job->load_state();
}
+} // namespace
+
class ProxyResolverFactoryMojo::Job
: public interfaces::ProxyResolverFactoryRequestClient,
public mojo::ErrorHandler,
@@ -205,11 +312,20 @@ class ProxyResolverFactoryMojo::Job
new mojo::Binding<interfaces::HostResolver>(host_resolver_.get())) {
interfaces::HostResolverPtr host_resolver_ptr;
interfaces::ProxyResolverFactoryRequestClientPtr client_ptr;
+ interfaces::ProxyResolverErrorObserverPtr error_observer_ptr;
binding_.Bind(mojo::GetProxy(&client_ptr));
+ if (!factory_->error_observer_factory_.is_null()) {
+ scoped_ptr<ProxyResolverErrorObserver> error_observer =
+ factory_->error_observer_factory_.Run();
+ if (error_observer) {
+ error_observer_.reset(new ErrorObserverHolder(
+ error_observer.Pass(), mojo::GetProxy(&error_observer_ptr)));
+ }
+ }
host_resolver_binding_->Bind(mojo::GetProxy(&host_resolver_ptr));
on_delete_callback_runner_ = factory_->mojo_proxy_factory_->CreateResolver(
mojo::String::From(pac_script->utf16()), mojo::GetProxy(&resolver_ptr_),
- host_resolver_ptr.Pass(), client_ptr.Pass());
+ host_resolver_ptr.Pass(), error_observer_ptr.Pass(), client_ptr.Pass());
resolver_ptr_.set_error_handler(this);
binding_.set_error_handler(this);
}
@@ -226,7 +342,8 @@ class ProxyResolverFactoryMojo::Job
if (error == OK) {
resolver_->reset(new ProxyResolverMojo(
resolver_ptr_.Pass(), host_resolver_.Pass(),
- host_resolver_binding_.Pass(), on_delete_callback_runner_.Pass()));
+ host_resolver_binding_.Pass(), on_delete_callback_runner_.Pass(),
+ error_observer_.Pass()));
}
on_delete_callback_runner_.reset();
callback_.Run(error);
@@ -240,14 +357,18 @@ class ProxyResolverFactoryMojo::Job
scoped_ptr<interfaces::HostResolver> host_resolver_;
scoped_ptr<mojo::Binding<interfaces::HostResolver>> host_resolver_binding_;
scoped_ptr<base::ScopedClosureRunner> on_delete_callback_runner_;
+ scoped_ptr<ErrorObserverHolder> error_observer_;
};
ProxyResolverFactoryMojo::ProxyResolverFactoryMojo(
MojoProxyResolverFactory* mojo_proxy_factory,
- HostResolver* host_resolver)
+ HostResolver* host_resolver,
+ const base::Callback<scoped_ptr<ProxyResolverErrorObserver>()>&
+ error_observer_factory)
: ProxyResolverFactory(true),
mojo_proxy_factory_(mojo_proxy_factory),
- host_resolver_(host_resolver) {
+ host_resolver_(host_resolver),
+ error_observer_factory_(error_observer_factory) {
}
ProxyResolverFactoryMojo::~ProxyResolverFactoryMojo() = default;
« no previous file with comments | « net/proxy/proxy_resolver_mojo.h ('k') | net/proxy/proxy_resolver_mojo_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698