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

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

Issue 2791533002: Convert Web Store Inline Install IPCs to mojo (Closed)
Patch Set: Removed WebstoreBindingsHelper; Added bindings set to WebstoreBindings Created 3 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 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 #ifndef CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_ 5 #ifndef CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_
6 #define CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_ 6 #define CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_
7 7
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "chrome/common/extensions/mojo/inline_install.mojom.h"
10 #include "chrome/common/extensions/webstore_install_result.h" 11 #include "chrome/common/extensions/webstore_install_result.h"
11 #include "chrome/renderer/extensions/chrome_v8_extension_handler.h" 12 #include "chrome/renderer/extensions/chrome_v8_extension_handler.h"
12 #include "extensions/renderer/object_backed_native_handler.h" 13 #include "extensions/renderer/object_backed_native_handler.h"
14 #include "mojo/public/cpp/bindings/binding_set.h"
13 15
14 namespace blink { 16 namespace blink {
15 class WebLocalFrame; 17 class WebLocalFrame;
16 } 18 }
17 19
18 namespace extensions { 20 namespace extensions {
21 class ScriptContext;
22 class WebstoreBindingsHelper;
Devlin 2017/04/28 18:33:02 not needed
catmullings 2017/05/02 19:02:15 Done.
19 23
20 // A V8 extension that creates an object at window.chrome.webstore. This object 24 // A V8 extension that creates an object at window.chrome.webstore. This object
21 // allows JavaScript to initiate inline installs of apps that are listed in the 25 // allows JavaScript to initiate inline installs of apps that are listed in the
22 // Chrome Web Store (CWS). 26 // Chrome Web Store (CWS).
23 class WebstoreBindings : public ObjectBackedNativeHandler, 27 class WebstoreBindings : public ObjectBackedNativeHandler,
24 public ChromeV8ExtensionHandler { 28 public ChromeV8ExtensionHandler,
29 public mojom::InlineInstallProgressListener {
25 public: 30 public:
26 explicit WebstoreBindings(ScriptContext* context); 31 explicit WebstoreBindings(ScriptContext* context);
32 ~WebstoreBindings() override;
27 33
28 // IPC::Listener 34 // IPC::Listener:
29 bool OnMessageReceived(const IPC::Message& message) override; 35 bool OnMessageReceived(const IPC::Message& message) override;
30 36
37 void InlineInstallResponse(int install_id,
Devlin 2017/04/28 18:33:02 I think this can be private, right?
catmullings 2017/05/02 19:02:15 With InlineInstallResponse as an mojo msg instead
38 bool success,
39 const std::string& error,
40 webstore_install::Result result);
41
42 // mojom::InlineInstallProgressListener
43 void InlineInstallStageChanged(api::webstore::InstallStage stage) override;
44 void InlineInstallDownloadProgress(int percent_downloaded) override;
45
31 private: 46 private:
47 void OnInstallProgressListenerBindingError();
48
32 void Install(const v8::FunctionCallbackInfo<v8::Value>& args); 49 void Install(const v8::FunctionCallbackInfo<v8::Value>& args);
33 50
34 void OnInlineWebstoreInstallResponse(int install_id,
35 bool success,
36 const std::string& error,
37 webstore_install::Result result);
38
39 void OnInlineInstallStageChanged(int stage);
40
41 void OnInlineInstallDownloadProgress(int percent_downloaded);
42
43 // Extracts a Web Store item ID from a <link rel="chrome-webstore-item" 51 // Extracts a Web Store item ID from a <link rel="chrome-webstore-item"
44 // href="https://chrome.google.com/webstore/detail/id"> node found in the 52 // href="https://chrome.google.com/webstore/detail/id"> node found in the
45 // frame. On success, true will be returned and the |webstore_item_id| 53 // frame. On success, true will be returned and the |webstore_item_id|
46 // parameter will be populated with the ID. On failure, false will be returned 54 // parameter will be populated with the ID. On failure, false will be returned
47 // and |error| will be populated with the error. 55 // and |error| will be populated with the error.
48 static bool GetWebstoreItemIdFromFrame( 56 static bool GetWebstoreItemIdFromFrame(
49 blink::WebLocalFrame* frame, 57 blink::WebLocalFrame* frame,
50 const std::string& preferred_store_link_url, 58 const std::string& preferred_store_link_url,
51 std::string* webstore_item_id, 59 std::string* webstore_item_id,
52 std::string* error); 60 std::string* error);
53 61
62 extensions::mojom::InlineInstallAssociatedPtr inline_install_;
Devlin 2017/04/28 18:33:02 no need for extensions:: namespace
catmullings 2017/05/02 19:02:15 Done.
63
64 mojo::BindingSet<mojom::InlineInstallProgressListener>
catmullings 2017/04/28 03:07:30 A (weak) binding set does not own the object that
Devlin 2017/04/28 18:33:02 I think that's desired - otherwise, we'd end up de
catmullings 2017/05/02 19:02:15 Confirming that indeed that a regular binding set
65 install_progress_listener_bindings_;
66
54 DISALLOW_COPY_AND_ASSIGN(WebstoreBindings); 67 DISALLOW_COPY_AND_ASSIGN(WebstoreBindings);
55 }; 68 };
56 69
57 } // namespace extensions 70 } // namespace extensions
58 71
59 #endif // CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_ 72 #endif // CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698