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

Unified Diff: content/public/common/service_registry.h

Issue 285333003: Support exposing Mojo services between render frames, render threads, and their respective hosts. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: handle the case where handles arrive before the RenderFrame is ready Created 6 years, 6 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: content/public/common/service_registry.h
diff --git a/content/public/common/service_registry.h b/content/public/common/service_registry.h
new file mode 100644
index 0000000000000000000000000000000000000000..bbad59efad8e0266b1857f86181bf335431b5a77
--- /dev/null
+++ b/content/public/common/service_registry.h
@@ -0,0 +1,73 @@
+// Copyright 2014 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.
+
+#ifndef CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_
+#define CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_
+
+#include <string>
+
+#include "base/bind.h"
+#include "base/callback.h"
+#include "base/strings/string_piece.h"
+#include "content/common/content_export.h"
+#include "mojo/public/cpp/bindings/interface_ptr.h"
+#include "mojo/public/cpp/bindings/interface_request.h"
+#include "mojo/public/cpp/system/core.h"
+
+namespace content {
+
+// A ServiceRegistry exposes local services that have been added using
+// AddService to a paired remote ServiceRegistry and provides local access to
+// services exposed by the remote ServiceRegistry through GetInterface.
+class CONTENT_EXPORT ServiceRegistry {
+ public:
+ virtual ~ServiceRegistry() {}
+
+ // Make the service created by |service_factory| available to the remote
+ // InterfaceProvider. In response to each request for a service,
+ // |service_factory| will be run with an InterfaceRequest<Interface>
+ // representing that request.
+ template <typename Interface>
+ void AddService(const base::Callback<void(mojo::InterfaceRequest<Interface>)>
+ service_factory) {
+ AddService(Interface::Name_,
+ base::Bind(&ServiceRegistry::ForwardToServiceFactory<Interface>,
+ service_factory));
+ }
+ virtual void AddService(
+ const std::string& service_name,
+ const base::Callback<void(mojo::ScopedMessagePipeHandle)>
+ service_factory) = 0;
+
+ // Remove future access to the service implementing Interface. Existing
+ // connections to the service are unaffected.
+ template <typename Interface>
+ void RemoveService() {
+ RemoveService(Interface::Name_);
+ }
+ virtual void RemoveService(const std::string& service_name) = 0;
+
+ // Connect to an interface provided by the remote interface provider.
+ template <typename Interface>
+ void GetInterface(mojo::InterfacePtr<Interface>* ptr) {
darin (slow to review) 2014/06/18 00:09:29 nit: You might call this GetRemoteInterface for cl
Sam McNally 2014/06/18 01:31:40 Done.
+ mojo::MessagePipe pipe;
+ ptr->Bind(pipe.handle0.Pass());
+ GetInterface(Interface::Name_, pipe.handle1.Pass());
+ }
+ virtual void GetInterface(const base::StringPiece& name,
+ mojo::ScopedMessagePipeHandle handle) = 0;
+
+ private:
+ template <typename Interface>
+ static void ForwardToServiceFactory(
+ const base::Callback<void(mojo::InterfaceRequest<Interface>)>
+ service_factory,
+ mojo::ScopedMessagePipeHandle handle) {
+ service_factory.Run(mojo::MakeRequest<Interface>(handle.Pass()));
+ }
+};
+
+} // namespace content
+
+#endif // CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_

Powered by Google App Engine
This is Rietveld 408576698