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

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

Issue 2791533002: Convert Web Store Inline Install IPCs to mojo (Closed)
Patch Set: Addressed Devlin's comments Created 3 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 unified diff | Download patch
« no previous file with comments | « chrome/common/extensions/typemaps.gni ('k') | chrome/renderer/extensions/webstore_bindings.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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/mojom/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 "extensions/renderer/object_backed_native_handler.h" 12 #include "extensions/renderer/object_backed_native_handler.h"
13 #include "mojo/public/cpp/bindings/binding_set.h"
14 #include "v8/include/v8.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;
19 22
20 // A V8 extension that creates an object at window.chrome.webstore. This object 23 // 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 24 // allows JavaScript to initiate inline installs of apps that are listed in the
22 // Chrome Web Store (CWS). 25 // Chrome Web Store (CWS).
23 class WebstoreBindings : public ObjectBackedNativeHandler, 26 class WebstoreBindings : public ObjectBackedNativeHandler,
24 public ChromeV8ExtensionHandler { 27 public mojom::InlineInstallProgressListener {
25 public: 28 public:
26 explicit WebstoreBindings(ScriptContext* context); 29 explicit WebstoreBindings(ScriptContext* context);
30 ~WebstoreBindings() override;
27 31
28 // IPC::Listener 32 // mojom::InlineInstallProgressListener:
29 bool OnMessageReceived(const IPC::Message& message) override; 33 void InlineInstallStageChanged(api::webstore::InstallStage stage) override;
34 void InlineInstallDownloadProgress(int percent_downloaded) override;
30 35
31 private: 36 private:
37 void InlineInstallResponse(int install_id,
38 bool success,
39 const std::string& error,
40 webstore_install::Result result);
32 void Install(const v8::FunctionCallbackInfo<v8::Value>& args); 41 void Install(const v8::FunctionCallbackInfo<v8::Value>& args);
33 42
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" 43 // 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 44 // 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| 45 // 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 46 // parameter will be populated with the ID. On failure, false will be returned
47 // and |error| will be populated with the error. 47 // and |error| will be populated with the error.
48 static bool GetWebstoreItemIdFromFrame( 48 static bool GetWebstoreItemIdFromFrame(
49 blink::WebLocalFrame* frame, 49 blink::WebLocalFrame* frame,
50 const std::string& preferred_store_link_url, 50 const std::string& preferred_store_link_url,
51 std::string* webstore_item_id, 51 std::string* webstore_item_id,
52 std::string* error); 52 std::string* error);
53 53
54 mojom::InlineInstallerAssociatedPtr inline_installer_;
55
56 mojo::BindingSet<mojom::InlineInstallProgressListener>
57 install_progress_listener_bindings_;
58
54 DISALLOW_COPY_AND_ASSIGN(WebstoreBindings); 59 DISALLOW_COPY_AND_ASSIGN(WebstoreBindings);
55 }; 60 };
56 61
57 } // namespace extensions 62 } // namespace extensions
58 63
59 #endif // CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_ 64 #endif // CHROME_RENDERER_EXTENSIONS_WEBSTORE_BINDINGS_H_
OLDNEW
« no previous file with comments | « chrome/common/extensions/typemaps.gni ('k') | chrome/renderer/extensions/webstore_bindings.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698