Index: chrome/browser/extensions/webstore_install_prompt.h |
diff --git a/chrome/browser/extensions/webstore_install_prompt.h b/chrome/browser/extensions/webstore_install_prompt.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..71f53f1ca8343e971c71511d3a93fafb7e0726d2 |
--- /dev/null |
+++ b/chrome/browser/extensions/webstore_install_prompt.h |
@@ -0,0 +1,84 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_EXTENSIONS_WEBSTORE_INSTALL_PROMPT_H_ |
+#define CHROME_BROWSER_EXTENSIONS_WEBSTORE_INSTALL_PROMPT_H_ |
+ |
+#include "base/basictypes.h" |
+#include "content/public/browser/page_navigator.h" |
+#include "url/gurl.h" |
+#include "webstore_standalone_installer.h" |
tapted
2014/05/28 06:28:46
this should have the full path
|
+ |
+namespace content { |
+class WebContents; |
+} |
+ |
+namespace extensions { |
tapted
2014/05/28 06:28:46
Things under chrome/browser don't typically go in
|
+ |
+// Initiates the install of an extension from the webstore. Downloads and parses |
+// metadata from the webstore, shows an install UI and starts the download once |
+// the user confirms. No post-install UI is shown. |
+// |
+// Clients will be notified of success or failure via the |callback| argument |
+// passed into the constructor. |
+// |
+// Clients of this class must be trusted, as verification of the requestor is |
+// skipped. This class stubs out many WebstoreStandaloneInstaller abstract |
+// methods and can be used as a base class. |
+class WebstoreInstallPrompt : public WebstoreStandaloneInstaller, |
+ public content::PageNavigator { |
+ public: |
+ typedef WebstoreStandaloneInstaller::Callback Callback; |
tapted
2014/05/28 06:28:46
I.. think this line is redundant -- inheriting fro
|
+ |
+ // Use this constructor when there is no parent window. The install dialog |
+ // will be centered on the screen. |
+ WebstoreInstallPrompt(const std::string& webstore_item_id, |
+ Profile* profile, |
+ const Callback& callback); |
+ |
+ // If this constructor is used, the parent of the install dialog will be |
+ // |parent_window|. |
+ WebstoreInstallPrompt(const std::string& webstore_item_id, |
+ Profile* profile, |
tapted
2014/05/28 06:28:46
nit: indenting is off
|
+ gfx::NativeWindow parent_window, |
+ const Callback& callback); |
+ |
+ protected: |
+ friend class base::RefCountedThreadSafe<WebstoreInstallPrompt>; |
+ virtual ~WebstoreInstallPrompt(); |
+ |
+ // extensions::WebstoreStartupInstaller overrides: |
tapted
2014/05/28 06:28:46
Startup -> Standalone?
|
+ virtual bool CheckRequestorAlive() const OVERRIDE; |
+ virtual const GURL& GetRequestorURL() const OVERRIDE; |
+ virtual bool ShouldShowPostInstallUI() const OVERRIDE; |
+ virtual bool ShouldShowAppInstalledBubble() const OVERRIDE; |
+ virtual content::WebContents* GetWebContents() const OVERRIDE; |
+ virtual scoped_ptr<ExtensionInstallPrompt::Prompt> CreateInstallPrompt() |
+ const OVERRIDE; |
tapted
2014/05/28 06:28:46
nit: const/OVERRIDE shouldn't appear on a line by
tmdiep
2014/05/28 08:39:27
git cl format put the "const OVERRIDE" in a new li
tapted
2014/05/28 12:57:32
probably an accident/clang-format bug - clang-form
|
+ virtual scoped_ptr<ExtensionInstallPrompt> CreateInstallUI() OVERRIDE; |
+ virtual bool CheckInlineInstallPermitted( |
+ const base::DictionaryValue& webstore_data, |
+ std::string* error) const OVERRIDE; |
+ virtual bool CheckRequestorPermitted( |
+ const base::DictionaryValue& webstore_data, |
+ std::string* error) const OVERRIDE; |
+ |
+ // content::PageNavigator overrides: |
+ virtual content::WebContents* OpenURL( |
+ const content::OpenURLParams& params) OVERRIDE; |
+ |
+ private: |
+ GURL dummy_requestor_url_; |
+ |
+ // A non-visible WebContents used to download data from the webstore. |
+ scoped_ptr<content::WebContents> dummy_web_contents_; |
tapted
2014/05/28 06:28:46
nit: #include scoped_ptr for this
|
+ |
+ gfx::NativeWindow parent_window_; |
tapted
2014/05/28 06:28:46
nit: #include native_widget_types.h
|
+ |
+ DISALLOW_IMPLICIT_CONSTRUCTORS(WebstoreInstallPrompt); |
tapted
2014/05/28 06:28:46
nit: I think this is only if you don't define *any
|
+}; |
+ |
+} // namespace extensions |
+ |
+#endif // CHROME_BROWSER_EXTENSIONS_WEBSTORE_INSTALL_PROMPT_H_ |