Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_ |
| OLD | NEW |