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

Side by Side Diff: chrome/renderer/extensions/webstore_bindings.cc

Issue 2791533002: Convert Web Store Inline Install IPCs to mojo (Closed)
Patch Set: Created 3 years, 8 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/renderer/extensions/webstore_bindings.h" 5 #include "chrome/renderer/extensions/webstore_bindings.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "base/strings/string_util.h" 10 #include "base/strings/string_util.h"
11 #include "chrome/common/extensions/api/webstore/webstore_api_constants.h" 11 #include "chrome/common/extensions/api/webstore/webstore_api_constants.h"
12 #include "chrome/common/extensions/chrome_extension_messages.h"
13 #include "components/crx_file/id_util.h" 12 #include "components/crx_file/id_util.h"
14 #include "content/public/renderer/render_frame.h" 13 #include "content/public/renderer/render_frame.h"
15 #include "extensions/common/extension.h" 14 #include "extensions/common/extension.h"
16 #include "extensions/common/extension_urls.h" 15 #include "extensions/common/extension_urls.h"
17 #include "extensions/renderer/script_context.h" 16 #include "extensions/renderer/script_context.h"
17 #include "mojo/public/cpp/bindings/strong_binding.h"
18 #include "services/service_manager/public/cpp/interface_provider.h"
19 #include "services/service_manager/public/cpp/interface_registry.h"
18 #include "third_party/WebKit/public/web/WebDocument.h" 20 #include "third_party/WebKit/public/web/WebDocument.h"
19 #include "third_party/WebKit/public/web/WebElement.h" 21 #include "third_party/WebKit/public/web/WebElement.h"
20 #include "third_party/WebKit/public/web/WebLocalFrame.h" 22 #include "third_party/WebKit/public/web/WebLocalFrame.h"
21 #include "third_party/WebKit/public/web/WebNode.h" 23 #include "third_party/WebKit/public/web/WebNode.h"
22 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h" 24 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h"
23 #include "url/gurl.h" 25 #include "url/gurl.h"
24 #include "v8/include/v8.h" 26 #include "v8/include/v8.h"
25 27
26 using blink::WebDocument; 28 using blink::WebDocument;
27 using blink::WebElement; 29 using blink::WebElement;
(...skipping 10 matching lines...) Expand all
38 "Chrome Web Store installations can only be started by the top frame."; 40 "Chrome Web Store installations can only be started by the top frame.";
39 const char kNotUserGestureError[] = 41 const char kNotUserGestureError[] =
40 "Chrome Web Store installations can only be initated by a user gesture."; 42 "Chrome Web Store installations can only be initated by a user gesture.";
41 const char kNoWebstoreItemLinkFoundError[] = 43 const char kNoWebstoreItemLinkFoundError[] =
42 "No Chrome Web Store item link found."; 44 "No Chrome Web Store item link found.";
43 const char kInvalidWebstoreItemUrlError[] = 45 const char kInvalidWebstoreItemUrlError[] =
44 "Invalid Chrome Web Store item URL."; 46 "Invalid Chrome Web Store item URL.";
45 47
46 // chrome.webstore.install() calls generate an install ID so that the install's 48 // chrome.webstore.install() calls generate an install ID so that the install's
47 // callbacks may be fired when the browser notifies us of install completion 49 // callbacks may be fired when the browser notifies us of install completion
48 // (successful or not) via OnInlineWebstoreInstallResponse. 50 // (successful or not) via InlineWebstoreInstallResponse.
49 int g_next_install_id = 0; 51 int g_next_install_id = 0;
50 52
51 } // anonymous namespace 53 } // anonymous namespace
52 54
53 WebstoreBindings::WebstoreBindings(ScriptContext* context) 55 WebstoreBindings::WebstoreBindings(ScriptContext* context)
54 : ObjectBackedNativeHandler(context) { 56 : ObjectBackedNativeHandler(context) {
55 RouteFunction("Install", "webstore", 57 RouteFunction("Install", "webstore",
56 base::Bind(&WebstoreBindings::Install, base::Unretained(this))); 58 base::Bind(&WebstoreBindings::Install, base::Unretained(this)));
59 context->GetRenderFrame()->GetRemoteInterfaces()->GetInterface(
60 &inline_install_);
61 context->GetRenderFrame()->GetInterfaceRegistry()->AddInterface(
62 base::Bind(&WebstoreBindings::BindInlineInstallStatusRequest, context));
63 }
64
65 WebstoreBindings::~WebstoreBindings() {}
66
67 // static
68 void WebstoreBindings::BindInlineInstallStatusRequest(
69 ScriptContext* context,
70 mojom::InlineInstallStatusRequest request) {
71 mojo::MakeStrongBinding(base::MakeUnique<WebstoreBindings>(context),
Devlin 2017/03/31 14:18:39 Here, too, this pattern will result in creating a
catmullings 2017/04/06 20:50:15 Done.
72 std::move(request));
57 } 73 }
58 74
59 void WebstoreBindings::Install( 75 void WebstoreBindings::Install(
60 const v8::FunctionCallbackInfo<v8::Value>& args) { 76 const v8::FunctionCallbackInfo<v8::Value>& args) {
61 content::RenderFrame* render_frame = context()->GetRenderFrame(); 77 content::RenderFrame* render_frame = context()->GetRenderFrame();
62 if (!render_frame) 78 if (!render_frame)
63 return; 79 return;
64 80
65 // The first two arguments indicate whether or not there are install stage 81 // The first two arguments indicate whether or not there are install stage
66 // or download progress listeners. 82 // or download progress listeners.
(...skipping 17 matching lines...) Expand all
84 100
85 if (!GetWebstoreItemIdFromFrame( 101 if (!GetWebstoreItemIdFromFrame(
86 frame, preferred_store_link_url, &webstore_item_id, &error)) { 102 frame, preferred_store_link_url, &webstore_item_id, &error)) {
87 args.GetIsolate()->ThrowException( 103 args.GetIsolate()->ThrowException(
88 v8::String::NewFromUtf8(args.GetIsolate(), error.c_str())); 104 v8::String::NewFromUtf8(args.GetIsolate(), error.c_str()));
89 return; 105 return;
90 } 106 }
91 107
92 int install_id = g_next_install_id++; 108 int install_id = g_next_install_id++;
93 109
94 Send(new ExtensionHostMsg_InlineWebstoreInstall( 110 inline_install_->InlineWebstoreInstall(install_id, GetRoutingID(),
95 render_frame->GetRoutingID(), install_id, GetRoutingID(), 111 webstore_item_id, listener_mask);
96 webstore_item_id, listener_mask));
97 112
98 args.GetReturnValue().Set(static_cast<int32_t>(install_id)); 113 args.GetReturnValue().Set(static_cast<int32_t>(install_id));
99 } 114 }
100 115
101 // static 116 // static
102 bool WebstoreBindings::GetWebstoreItemIdFromFrame( 117 bool WebstoreBindings::GetWebstoreItemIdFromFrame(
103 blink::WebLocalFrame* frame, 118 blink::WebLocalFrame* frame,
104 const std::string& preferred_store_link_url, 119 const std::string& preferred_store_link_url,
105 std::string* webstore_item_id, 120 std::string* webstore_item_id,
106 std::string* error) { 121 std::string* error) {
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
180 195
181 *webstore_item_id = candidate_webstore_item_id; 196 *webstore_item_id = candidate_webstore_item_id;
182 return true; 197 return true;
183 } 198 }
184 199
185 *error = kNoWebstoreItemLinkFoundError; 200 *error = kNoWebstoreItemLinkFoundError;
186 return false; 201 return false;
187 } 202 }
188 203
189 bool WebstoreBindings::OnMessageReceived(const IPC::Message& message) { 204 bool WebstoreBindings::OnMessageReceived(const IPC::Message& message) {
190 IPC_BEGIN_MESSAGE_MAP(WebstoreBindings, message)
191 IPC_MESSAGE_HANDLER(ExtensionMsg_InlineWebstoreInstallResponse,
192 OnInlineWebstoreInstallResponse)
193 IPC_MESSAGE_HANDLER(ExtensionMsg_InlineInstallStageChanged,
194 OnInlineInstallStageChanged)
195 IPC_MESSAGE_HANDLER(ExtensionMsg_InlineInstallDownloadProgress,
196 OnInlineInstallDownloadProgress)
197 IPC_MESSAGE_UNHANDLED(CHECK(false) << "Unhandled IPC message")
198 IPC_END_MESSAGE_MAP()
199 return true; 205 return true;
200 } 206 }
201 207
202 void WebstoreBindings::OnInlineWebstoreInstallResponse( 208 void WebstoreBindings::InlineWebstoreInstallResponse(
203 int install_id, 209 int install_id,
204 bool success, 210 bool success,
205 const std::string& error, 211 const std::string& error,
206 webstore_install::Result result) { 212 webstore_install::Result result) {
207 v8::Isolate* isolate = context()->isolate(); 213 v8::Isolate* isolate = context()->isolate();
208 v8::HandleScope handle_scope(isolate); 214 v8::HandleScope handle_scope(isolate);
209 v8::Context::Scope context_scope(context()->v8_context()); 215 v8::Context::Scope context_scope(context()->v8_context());
210 v8::Local<v8::Value> argv[] = { 216 v8::Local<v8::Value> argv[] = {
211 v8::Integer::New(isolate, install_id), 217 v8::Integer::New(isolate, install_id),
212 v8::Boolean::New(isolate, success), 218 v8::Boolean::New(isolate, success),
213 v8::String::NewFromUtf8(isolate, error.c_str()), 219 v8::String::NewFromUtf8(isolate, error.c_str()),
214 v8::String::NewFromUtf8( 220 v8::String::NewFromUtf8(
215 isolate, api::webstore::kInstallResultCodes[static_cast<int>(result)]) 221 isolate, api::webstore::kInstallResultCodes[static_cast<int>(result)])
216 }; 222 };
217 context()->module_system()->CallModuleMethodSafe( 223 context()->module_system()->CallModuleMethodSafe(
218 "webstore", "onInstallResponse", arraysize(argv), argv); 224 "webstore", "onInstallResponse", arraysize(argv), argv);
219 } 225 }
220 226
221 void WebstoreBindings::OnInlineInstallStageChanged(int stage) { 227 void WebstoreBindings::InlineInstallStageChanged(
228 api::webstore::InstallStage stage) {
222 const char* stage_string = NULL; 229 const char* stage_string = NULL;
223 api::webstore::InstallStage install_stage = 230 api::webstore::InstallStage install_stage =
224 static_cast<api::webstore::InstallStage>(stage); 231 static_cast<api::webstore::InstallStage>(stage);
225 switch (install_stage) { 232 switch (install_stage) {
226 case api::webstore::INSTALL_STAGE_DOWNLOADING: 233 case api::webstore::INSTALL_STAGE_DOWNLOADING:
227 stage_string = api::webstore::kInstallStageDownloading; 234 stage_string = api::webstore::kInstallStageDownloading;
228 break; 235 break;
229 case api::webstore::INSTALL_STAGE_INSTALLING: 236 case api::webstore::INSTALL_STAGE_INSTALLING:
230 stage_string = api::webstore::kInstallStageInstalling; 237 stage_string = api::webstore::kInstallStageInstalling;
231 break; 238 break;
232 } 239 }
233 v8::Isolate* isolate = context()->isolate(); 240 v8::Isolate* isolate = context()->isolate();
234 v8::HandleScope handle_scope(isolate); 241 v8::HandleScope handle_scope(isolate);
235 v8::Context::Scope context_scope(context()->v8_context()); 242 v8::Context::Scope context_scope(context()->v8_context());
236 v8::Local<v8::Value> argv[] = { 243 v8::Local<v8::Value> argv[] = {
237 v8::String::NewFromUtf8(isolate, stage_string)}; 244 v8::String::NewFromUtf8(isolate, stage_string)};
238 context()->module_system()->CallModuleMethodSafe( 245 context()->module_system()->CallModuleMethodSafe(
239 "webstore", "onInstallStageChanged", arraysize(argv), argv); 246 "webstore", "onInstallStageChanged", arraysize(argv), argv);
240 } 247 }
241 248
242 void WebstoreBindings::OnInlineInstallDownloadProgress(int percent_downloaded) { 249 void WebstoreBindings::InlineInstallDownloadProgress(int percent_downloaded) {
243 v8::Isolate* isolate = context()->isolate(); 250 v8::Isolate* isolate = context()->isolate();
244 v8::HandleScope handle_scope(isolate); 251 v8::HandleScope handle_scope(isolate);
245 v8::Context::Scope context_scope(context()->v8_context()); 252 v8::Context::Scope context_scope(context()->v8_context());
246 v8::Local<v8::Value> argv[] = { 253 v8::Local<v8::Value> argv[] = {
247 v8::Number::New(isolate, percent_downloaded / 100.0)}; 254 v8::Number::New(isolate, percent_downloaded / 100.0)};
248 context()->module_system()->CallModuleMethodSafe( 255 context()->module_system()->CallModuleMethodSafe(
249 "webstore", "onDownloadProgress", arraysize(argv), argv); 256 "webstore", "onDownloadProgress", arraysize(argv), argv);
250 } 257 }
251 258
252 } // namespace extensions 259 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698