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

Unified Diff: third_party/WebKit/Source/platform/ServiceConnector.h

Issue 2460723003: Enable connection to Mojo services from Blink (Closed)
Patch Set: Rebase Created 4 years 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 | « third_party/WebKit/Source/platform/DEPS ('k') | third_party/WebKit/Source/platform/exported/Platform.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/WebKit/Source/platform/ServiceConnector.h
diff --git a/third_party/WebKit/Source/platform/ServiceConnector.h b/third_party/WebKit/Source/platform/ServiceConnector.h
new file mode 100644
index 0000000000000000000000000000000000000000..6d6b56b6fc915205253a55fb0128b819721bdaf1
--- /dev/null
+++ b/third_party/WebKit/Source/platform/ServiceConnector.h
@@ -0,0 +1,60 @@
+// Copyright 2016 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 ServiceConnector_h
+#define ServiceConnector_h
+
+#include "mojo/public/cpp/bindings/binding.h"
+#include "public/platform/Platform.h"
+#include "services/service_manager/public/interfaces/connector.mojom-blink.h"
+#include "wtf/StdLibExtras.h"
+
+namespace blink {
+
+// ServiceConnector supports connecting to Mojo services by name.
+class ServiceConnector {
+ public:
+ static ServiceConnector& instance() {
+ DEFINE_STATIC_LOCAL(ServiceConnector, instance, ());
+ return instance;
+ }
+
+ template <typename Interface>
+ void connectToInterface(const char* serviceName,
+ mojo::InterfaceRequest<Interface> request) {
+ if (!m_connector.is_bound()) {
+ Platform::current()->bindServiceConnector(
+ mojo::MakeRequest(&m_connector).PassMessagePipe());
+ }
+
+ if (m_connector.encountered_error())
+ return;
+
+ service_manager::mojom::blink::IdentityPtr remoteIdentity(
+ service_manager::mojom::blink::Identity::New());
+ remoteIdentity->name = serviceName;
+ remoteIdentity->user_id = service_manager::mojom::blink::kInheritUserID;
+ remoteIdentity->instance = "";
+
+ service_manager::mojom::blink::InterfaceProviderPtr remoteInterfaces;
+ m_connector->Connect(std::move(remoteIdentity),
+ MakeRequest(&remoteInterfaces), nullptr,
+ base::Bind(&ServiceConnector::onConnectionCompleted));
+
+ remoteInterfaces->GetInterface(Interface::Name_, request.PassMessagePipe());
+ }
+
+ private:
+ ServiceConnector() {}
+
+ static void onConnectionCompleted(
+ service_manager::mojom::ConnectResult result,
+ const WTF::String& targetUserID) {}
+
+ service_manager::mojom::blink::ConnectorPtr m_connector;
+};
+
+} // namespace blink
+
+#endif // ServiceConnector_h
« no previous file with comments | « third_party/WebKit/Source/platform/DEPS ('k') | third_party/WebKit/Source/platform/exported/Platform.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698