Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ | 5 #ifndef CHROME_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ |
| 6 #define CHROME_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ | 6 #define CHROME_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | |
| 9 | 10 |
| 10 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
| 11 #include "base/files/file_path.h" | 12 #include "base/files/file_path.h" |
| 12 #include "base/macros.h" | 13 #include "base/macros.h" |
| 13 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
| 15 #include "base/memory/scoped_vector.h" | |
| 14 #include "base/memory/weak_ptr.h" | 16 #include "base/memory/weak_ptr.h" |
| 17 #include "base/scoped_observer.h" | |
| 18 #include "chrome/browser/extensions/extension_error_reporter.h" | |
| 15 #include "content/public/browser/web_ui_message_handler.h" | 19 #include "content/public/browser/web_ui_message_handler.h" |
| 16 | 20 |
| 17 namespace base { | 21 namespace base { |
| 18 class ListValue; | 22 class ListValue; |
| 19 } | 23 } |
| 20 | 24 |
| 21 namespace content { | 25 namespace content { |
| 22 class WebUIDataSource; | 26 class WebUIDataSource; |
| 23 } | 27 } |
| 24 | 28 |
| 25 class Profile; | 29 class Profile; |
| 26 | 30 |
| 27 namespace extensions { | 31 namespace extensions { |
| 28 | 32 |
| 29 class Extension; | 33 class Extension; |
| 30 | 34 |
| 31 // The handler page for the Extension Commands UI overlay. | 35 // The handler page for the Extension Commands UI overlay. |
| 32 class ExtensionLoaderHandler : public content::WebUIMessageHandler { | 36 class ExtensionLoaderHandler : public content::WebUIMessageHandler, |
| 37 public ExtensionErrorReporter::Observer { | |
| 33 public: | 38 public: |
| 34 explicit ExtensionLoaderHandler(Profile* profile); | 39 explicit ExtensionLoaderHandler(Profile* profile); |
| 35 virtual ~ExtensionLoaderHandler(); | 40 virtual ~ExtensionLoaderHandler(); |
| 36 | 41 |
| 37 // Fetches the localized values for the page and deposits them into |source|. | 42 // Fetches the localized values for the page and deposits them into |source|. |
| 38 void GetLocalizedValues(content::WebUIDataSource* source); | 43 void GetLocalizedValues(content::WebUIDataSource* source); |
| 39 | 44 |
| 40 // WebUIMessageHandler implementation. | 45 // WebUIMessageHandler implementation. |
| 41 virtual void RegisterMessages() OVERRIDE; | 46 virtual void RegisterMessages() OVERRIDE; |
| 42 | 47 |
| 43 private: | 48 private: |
| 44 class FileHelper; | 49 class FileHelper; |
| 45 | 50 |
| 51 // Struct to hold failure data when NotifyFrontendOfFailure is called before | |
| 52 // the extensions page is fully loaded. | |
| 53 struct FailureData { | |
| 54 explicit FailureData(base::FilePath file_path, | |
|
Devlin
2014/06/30 21:06:42
no need for explicit with multiple parameters to t
gpdavis
2014/06/30 21:41:19
Done.
| |
| 55 std::string error, | |
|
Devlin
2014/06/30 21:06:42
nit: indentation error.
gpdavis
2014/06/30 21:41:19
Done.
| |
| 56 size_t line_number, | |
| 57 std::string manifest) | |
| 58 : file_path(file_path), | |
| 59 error(error), | |
| 60 line_number(line_number), | |
| 61 manifest(manifest) {} | |
|
gpdavis
2014/06/30 19:42:52
There should probably be a newline here, right?
H
Devlin
2014/06/30 21:06:42
Make an out-of-line constructor, and an explicit d
gpdavis
2014/06/30 21:41:19
An "out-of-line" constructor? I've never heard th
Devlin
2014/06/30 22:32:36
out-of-line is the (slang) opposite of inline. Me
gpdavis
2014/06/30 23:35:11
Ah, gotcha. Can do.
| |
| 62 base::FilePath file_path; | |
| 63 std::string error; | |
| 64 size_t line_number; | |
| 65 std::string manifest; | |
| 66 | |
| 67 DISALLOW_COPY_AND_ASSIGN(FailureData); | |
|
Devlin
2014/06/30 21:06:42
One note and one problem:
note - we don't actually
gpdavis
2014/06/30 21:41:19
C++ is a pretty new language to me-- I'm pretty we
Devlin
2014/06/30 22:32:36
So, what DISALLOW_COPY_AND_ASSIGN does is just dec
gpdavis
2014/06/30 23:35:11
Ahh, I see. So by creating private dummies for tho
| |
| 68 }; | |
| 69 | |
| 46 // Handle the 'extensionLoaderLoadUnpacked' message. | 70 // Handle the 'extensionLoaderLoadUnpacked' message. |
| 47 void HandleLoadUnpacked(const base::ListValue* args); | 71 void HandleLoadUnpacked(const base::ListValue* args); |
| 48 | 72 |
| 49 // Handle the 'extensionLoaderRetry' message. | 73 // Handle the 'extensionLoaderRetry' message. |
| 50 void HandleRetry(const base::ListValue* args); | 74 void HandleRetry(const base::ListValue* args); |
| 51 | 75 |
| 76 // Handle the 'extensionLoaderSetDisplayLoading' message. | |
| 77 void HandleSetDisplayLoading(const base::ListValue* args); | |
| 78 | |
| 79 // Handle the 'extensionLoaderDisplayFailures' message. | |
| 80 void HandleDisplayFailures(const base::ListValue* args); | |
| 81 | |
| 52 // Try to load an unpacked extension from the given |file_path|. | 82 // Try to load an unpacked extension from the given |file_path|. |
| 53 void LoadUnpackedExtensionImpl(const base::FilePath& file_path); | 83 void LoadUnpackedExtensionImpl(const base::FilePath& file_path); |
| 54 | 84 |
| 55 // Called when an unpacked extension fails to load. | 85 // ExtensionErrorReporter::Observer implementation. |
| 56 void OnLoadFailure(const base::FilePath& file_path, const std::string& error); | 86 virtual void OnLoadFailure(const base::FilePath& file_path, |
| 87 const std::string& error) OVERRIDE; | |
| 57 | 88 |
| 58 // Notify the frontend of the failure. If it was a manifest error, |manifest| | 89 // Notify the frontend of the failure. If it was a manifest error, |manifest| |
| 59 // will hold the manifest contents, and |line_number| will point to the line | 90 // will hold the manifest contents, and |line_number| will point to the line |
| 60 // at which the error was found. | 91 // at which the error was found. |
| 61 void NotifyFrontendOfFailure(const base::FilePath& file_path, | 92 void NotifyFrontendOfFailure(const base::FilePath& file_path, |
| 62 const std::string& error, | 93 const std::string& error, |
| 63 size_t line_number, | 94 size_t line_number, |
| 64 const std::string& manifest); | 95 const std::string& manifest); |
| 65 | 96 |
| 66 // The profile with which this Handler is associated. | 97 // The profile with which this Handler is associated. |
| 67 Profile* profile_; | 98 Profile* profile_; |
| 68 | 99 |
| 69 // A helper to manage file picking. | 100 // A helper to manage file picking. |
| 70 scoped_ptr<FileHelper> file_helper_; | 101 scoped_ptr<FileHelper> file_helper_; |
| 71 | 102 |
| 72 // The file path to the extension that failed to load, or empty. This is | 103 // The file path to the extension that failed to load, or empty. This is |
| 73 // loaded when the user selects "retry". | 104 // loaded when the user selects "retry". |
| 74 base::FilePath failed_path_; | 105 base::FilePath failed_path_; |
| 75 | 106 |
| 107 // Holds information about all unpacked extension install failures that | |
| 108 // were reported while the extensions page was loading. | |
| 109 ScopedVector<FailureData> failures_; | |
| 110 | |
| 111 ScopedObserver<ExtensionErrorReporter, ExtensionErrorReporter::Observer> | |
| 112 extension_error_reporter_observer_; | |
| 113 | |
| 114 bool display_ready_; | |
| 115 | |
| 76 // Weak pointer factory for posting background tasks. | 116 // Weak pointer factory for posting background tasks. |
| 77 base::WeakPtrFactory<ExtensionLoaderHandler> weak_ptr_factory_; | 117 base::WeakPtrFactory<ExtensionLoaderHandler> weak_ptr_factory_; |
| 78 | 118 |
| 79 DISALLOW_COPY_AND_ASSIGN(ExtensionLoaderHandler); | 119 DISALLOW_COPY_AND_ASSIGN(ExtensionLoaderHandler); |
| 80 }; | 120 }; |
| 81 | 121 |
| 82 } // namespace extensions | 122 } // namespace extensions |
| 83 | 123 |
| 84 #endif // CHROME_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ | 124 #endif // CHROME_BROWSER_UI_WEBUI_EXTENSIONS_EXTENSION_LOADER_HANDLER_H_ |
| OLD | NEW |