| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/renderer/mojo/interface_provider_js_wrapper.h" | 5 #include "content/renderer/mojo/interface_provider_js_wrapper.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "content/public/common/service_names.mojom.h" |
| 10 #include "mojo/edk/js/handle.h" | 11 #include "mojo/edk/js/handle.h" |
| 12 #include "services/service_manager/public/cpp/connector.h" |
| 11 #include "services/service_manager/public/cpp/interface_provider.h" | 13 #include "services/service_manager/public/cpp/interface_provider.h" |
| 12 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 14 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
| 13 | 15 |
| 14 namespace content { | 16 namespace content { |
| 15 | 17 |
| 16 gin::WrapperInfo InterfaceProviderJsWrapper::kWrapperInfo = { | 18 gin::WrapperInfo InterfaceProviderJsWrapper::kWrapperInfo = { |
| 17 gin::kEmbedderNativeGin}; | 19 gin::kEmbedderNativeGin}; |
| 18 const char InterfaceProviderJsWrapper::kPerFrameModuleName[] = | 20 const char InterfaceProviderJsWrapper::kPerFrameModuleName[] = |
| 19 "content/public/renderer/frame_interfaces"; | 21 "content/public/renderer/frame_interfaces"; |
| 20 const char InterfaceProviderJsWrapper::kPerProcessModuleName[] = | 22 const char InterfaceProviderJsWrapper::kPerProcessModuleName[] = |
| 21 "content/public/renderer/interfaces"; | 23 "content/public/renderer/interfaces"; |
| 22 | 24 |
| 23 InterfaceProviderJsWrapper::~InterfaceProviderJsWrapper() { | 25 InterfaceProviderJsWrapper::~InterfaceProviderJsWrapper() { |
| 24 } | 26 } |
| 25 | 27 |
| 26 // static | 28 // static |
| 27 gin::Handle<InterfaceProviderJsWrapper> InterfaceProviderJsWrapper::Create( | 29 gin::Handle<InterfaceProviderJsWrapper> InterfaceProviderJsWrapper::Create( |
| 28 v8::Isolate* isolate, | 30 v8::Isolate* isolate, |
| 29 v8::Handle<v8::Context> context, | 31 v8::Handle<v8::Context> context, |
| 32 service_manager::Connector* connector) { |
| 33 return gin::CreateHandle( |
| 34 isolate, new InterfaceProviderJsWrapper(isolate, context, |
| 35 connector->GetWeakPtr())); |
| 36 } |
| 37 |
| 38 // static |
| 39 gin::Handle<InterfaceProviderJsWrapper> InterfaceProviderJsWrapper::Create( |
| 40 v8::Isolate* isolate, |
| 41 v8::Handle<v8::Context> context, |
| 30 service_manager::InterfaceProvider* remote_interfaces) { | 42 service_manager::InterfaceProvider* remote_interfaces) { |
| 31 return gin::CreateHandle( | 43 return gin::CreateHandle( |
| 32 isolate, | 44 isolate, |
| 33 new InterfaceProviderJsWrapper( | 45 new InterfaceProviderJsWrapper( |
| 34 isolate, context, | 46 isolate, context, |
| 35 remote_interfaces->GetWeakPtr())); | 47 remote_interfaces->GetWeakPtr())); |
| 36 } | 48 } |
| 37 | 49 |
| 38 gin::ObjectTemplateBuilder | 50 gin::ObjectTemplateBuilder |
| 39 InterfaceProviderJsWrapper::GetObjectTemplateBuilder(v8::Isolate* isolate) { | 51 InterfaceProviderJsWrapper::GetObjectTemplateBuilder(v8::Isolate* isolate) { |
| 40 return Wrappable<InterfaceProviderJsWrapper>::GetObjectTemplateBuilder( | 52 return Wrappable<InterfaceProviderJsWrapper>::GetObjectTemplateBuilder( |
| 41 isolate) | 53 isolate) |
| 42 .SetMethod("getInterface", | 54 .SetMethod("getInterface", |
| 43 &InterfaceProviderJsWrapper::GetInterface) | 55 &InterfaceProviderJsWrapper::GetInterface) |
| 44 .SetMethod("addInterfaceOverrideForTesting", | 56 .SetMethod("addInterfaceOverrideForTesting", |
| 45 &InterfaceProviderJsWrapper::AddOverrideForTesting) | 57 &InterfaceProviderJsWrapper::AddOverrideForTesting) |
| 46 .SetMethod("clearInterfaceOverridesForTesting", | 58 .SetMethod("clearInterfaceOverridesForTesting", |
| 47 &InterfaceProviderJsWrapper::ClearOverridesForTesting); | 59 &InterfaceProviderJsWrapper::ClearOverridesForTesting); |
| 48 } | 60 } |
| 49 | 61 |
| 50 mojo::Handle InterfaceProviderJsWrapper::GetInterface( | 62 mojo::Handle InterfaceProviderJsWrapper::GetInterface( |
| 51 const std::string& interface_name) { | 63 const std::string& interface_name) { |
| 52 mojo::MessagePipe pipe; | 64 mojo::MessagePipe pipe; |
| 53 if (remote_interfaces_) { | 65 if (connector_) { |
| 66 connector_->BindInterface( |
| 67 service_manager::Identity(mojom::kBrowserServiceName, |
| 68 service_manager::mojom::kInheritUserID), |
| 69 interface_name, std::move(pipe.handle0)); |
| 70 } else if (remote_interfaces_) { |
| 54 remote_interfaces_->GetInterface( | 71 remote_interfaces_->GetInterface( |
| 55 interface_name, std::move(pipe.handle0)); | 72 interface_name, std::move(pipe.handle0)); |
| 56 } | 73 } |
| 57 return pipe.handle1.release(); | 74 return pipe.handle1.release(); |
| 58 } | 75 } |
| 59 | 76 |
| 60 void InterfaceProviderJsWrapper::AddOverrideForTesting( | 77 void InterfaceProviderJsWrapper::AddOverrideForTesting( |
| 61 const std::string& interface_name, | 78 const std::string& interface_name, |
| 62 v8::Local<v8::Function> service_factory) { | 79 v8::Local<v8::Function> service_factory) { |
| 63 ScopedJsFactory factory(v8::Isolate::GetCurrent(), service_factory); | 80 ScopedJsFactory factory(v8::Isolate::GetCurrent(), service_factory); |
| 64 service_manager::InterfaceProvider::TestApi test_api( | 81 BindCallback callback = base::Bind(&InterfaceProviderJsWrapper::CallJsFactory, |
| 65 remote_interfaces_.get()); | 82 weak_factory_.GetWeakPtr(), factory); |
| 66 test_api.SetBinderForName( | 83 if (remote_interfaces_) { |
| 67 interface_name, | 84 service_manager::InterfaceProvider::TestApi test_api( |
| 68 base::Bind(&InterfaceProviderJsWrapper::CallJsFactory, | 85 remote_interfaces_.get()); |
| 69 weak_factory_.GetWeakPtr(), factory)); | 86 test_api.SetBinderForName(interface_name, callback); |
| 87 } else if (connector_) { |
| 88 service_manager::Connector::TestApi test_api(connector_.get()); |
| 89 test_api.OverrideBinderForTesting(interface_name, callback); |
| 90 } |
| 70 } | 91 } |
| 71 | 92 |
| 72 void InterfaceProviderJsWrapper::ClearOverridesForTesting() { | 93 void InterfaceProviderJsWrapper::ClearOverridesForTesting() { |
| 73 service_manager::InterfaceProvider::TestApi test_api( | 94 if (remote_interfaces_) { |
| 74 remote_interfaces_.get()); | 95 service_manager::InterfaceProvider::TestApi test_api( |
| 75 test_api.ClearBinders(); | 96 remote_interfaces_.get()); |
| 97 test_api.ClearBinders(); |
| 98 } else if (connector_) { |
| 99 service_manager::Connector::TestApi test_api(connector_.get()); |
| 100 test_api.ClearBinderOverrides(); |
| 101 } |
| 76 } | 102 } |
| 77 | 103 |
| 78 InterfaceProviderJsWrapper::InterfaceProviderJsWrapper( | 104 InterfaceProviderJsWrapper::InterfaceProviderJsWrapper( |
| 105 v8::Isolate* isolate, |
| 106 v8::Handle<v8::Context> context, |
| 107 base::WeakPtr<service_manager::Connector> connector) |
| 108 : isolate_(isolate), |
| 109 context_(isolate, context), |
| 110 connector_(connector), |
| 111 weak_factory_(this) { |
| 112 context_.SetWeak(this, &InterfaceProviderJsWrapper::ClearContext, |
| 113 v8::WeakCallbackType::kParameter); |
| 114 } |
| 115 |
| 116 InterfaceProviderJsWrapper::InterfaceProviderJsWrapper( |
| 79 v8::Isolate* isolate, | 117 v8::Isolate* isolate, |
| 80 v8::Handle<v8::Context> context, | 118 v8::Handle<v8::Context> context, |
| 81 base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces) | 119 base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces) |
| 82 : isolate_(isolate), | 120 : isolate_(isolate), |
| 83 context_(isolate, context), | 121 context_(isolate, context), |
| 84 remote_interfaces_(remote_interfaces), | 122 remote_interfaces_(remote_interfaces), |
| 85 weak_factory_(this) { | 123 weak_factory_(this) { |
| 86 context_.SetWeak(this, &InterfaceProviderJsWrapper::ClearContext, | 124 context_.SetWeak(this, &InterfaceProviderJsWrapper::ClearContext, |
| 87 v8::WeakCallbackType::kParameter); | 125 v8::WeakCallbackType::kParameter); |
| 88 } | 126 } |
| (...skipping 15 matching lines...) Expand all Loading... |
| 104 } | 142 } |
| 105 | 143 |
| 106 // static | 144 // static |
| 107 void InterfaceProviderJsWrapper::ClearContext( | 145 void InterfaceProviderJsWrapper::ClearContext( |
| 108 const v8::WeakCallbackInfo<InterfaceProviderJsWrapper>& data) { | 146 const v8::WeakCallbackInfo<InterfaceProviderJsWrapper>& data) { |
| 109 InterfaceProviderJsWrapper* registry = data.GetParameter(); | 147 InterfaceProviderJsWrapper* registry = data.GetParameter(); |
| 110 registry->context_.Reset(); | 148 registry->context_.Reset(); |
| 111 } | 149 } |
| 112 | 150 |
| 113 } // namespace content | 151 } // namespace content |
| OLD | NEW |