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