blob: 2bdc85eb931dbfbad8b2bc745a0b49060354461d [file] [log] [blame]
[email protected]8e7b2cf42012-04-18 14:26:581// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]d8c8f25f2011-11-02 18:18:012// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef CHROME_BROWSER_EXTENSIONS_UNPACKED_INSTALLER_H_
6#define CHROME_BROWSER_EXTENSIONS_UNPACKED_INSTALLER_H_
[email protected]d8c8f25f2011-11-02 18:18:017
dchengc963c7142016-04-08 03:55:228#include <memory>
[email protected]d8c8f25f2011-11-02 18:18:019#include <string>
[email protected]98270432012-09-11 20:51:2410#include <vector>
[email protected]d8c8f25f2011-11-02 18:18:0111
[email protected]500c7bb2014-04-26 22:44:3312#include "base/bind.h"
[email protected]57999812013-02-24 05:40:5213#include "base/files/file_path.h"
avia2f4804a2015-12-24 23:11:1314#include "base/macros.h"
[email protected]d8c8f25f2011-11-02 18:18:0115#include "base/memory/ref_counted.h"
16#include "base/memory/weak_ptr.h"
[email protected]253fc2bb2014-07-10 04:21:1817#include "chrome/browser/extensions/extension_install_checker.h"
[email protected]d8c8f25f2011-11-02 18:18:0118
[email protected]d8c8f25f2011-11-02 18:18:0119class ExtensionService;
20
21namespace extensions {
22
[email protected]1c321ee2012-05-21 03:02:3423class Extension;
24
[email protected]98270432012-09-11 20:51:2425// Installs and loads an unpacked extension. Because internal state needs to be
26// held about the instalation process, only one call to Load*() should be made
27// per UnpackedInstaller.
[email protected]d8c8f25f2011-11-02 18:18:0128// TODO(erikkay): It might be useful to be able to load a packed extension
29// (presumably into memory) without installing it.
30class UnpackedInstaller
31 : public base::RefCountedThreadSafe<UnpackedInstaller> {
32 public:
rdevlin.croninf6ea63a2015-03-04 17:51:0433 using CompletionCallback = base::Callback<void(const Extension* extension,
34 const base::FilePath&,
35 const std::string&)>;
[email protected]500c7bb2014-04-26 22:44:3336
[email protected]d8c8f25f2011-11-02 18:18:0137 static scoped_refptr<UnpackedInstaller> Create(
38 ExtensionService* extension_service);
39
40 // Loads the extension from the directory |extension_path|, which is
41 // the top directory of a specific extension where its manifest file lives.
42 // Errors are reported through ExtensionErrorReporter. On success,
43 // ExtensionService::AddExtension() is called.
[email protected]650b2d52013-02-10 03:41:4544 void Load(const base::FilePath& extension_path);
[email protected]d8c8f25f2011-11-02 18:18:0145
46 // Loads the extension from the directory |extension_path|;
[email protected]2a69b942013-05-31 09:37:5347 // for use with command line switch --load-extension=path or
48 // --load-and-launch-app=path.
49 // This is equivalent to Load, except that it reads the extension from
50 // |extension_path| synchronously.
51 // The return value indicates whether the installation has begun successfully.
52 // The id of the extension being loaded is returned in |extension_id|.
53 bool LoadFromCommandLine(const base::FilePath& extension_path,
54 std::string* extension_id);
[email protected]d8c8f25f2011-11-02 18:18:0155
56 // Allows prompting for plugins to be disabled; intended for testing only.
57 bool prompt_for_plugins() { return prompt_for_plugins_; }
58 void set_prompt_for_plugins(bool val) { prompt_for_plugins_ = val; }
59
[email protected]b7462f32012-09-02 15:18:1260 // Allows overriding of whether modern manifest versions are required;
61 // intended for testing.
62 bool require_modern_manifest_version() const {
63 return require_modern_manifest_version_;
64 }
65 void set_require_modern_manifest_version(bool val) {
66 require_modern_manifest_version_ = val;
67 }
68
[email protected]1f0722442014-05-01 17:26:0269 void set_be_noisy_on_failure(bool be_noisy_on_failure) {
70 be_noisy_on_failure_ = be_noisy_on_failure;
71 }
72
rdevlin.croninf6ea63a2015-03-04 17:51:0473 void set_completion_callback(const CompletionCallback& callback) {
74 callback_ = callback;
75 }
76
[email protected]d8c8f25f2011-11-02 18:18:0177 private:
78 friend class base::RefCountedThreadSafe<UnpackedInstaller>;
79
80 explicit UnpackedInstaller(ExtensionService* extension_service);
81 virtual ~UnpackedInstaller();
82
[email protected]98270432012-09-11 20:51:2483 // Must be called from the UI thread.
[email protected]849749d2013-05-06 17:30:4584 void ShowInstallPrompt();
85
[email protected]253fc2bb2014-07-10 04:21:1886 // Begin management policy and requirements checks.
87 void StartInstallChecks();
[email protected]98270432012-09-11 20:51:2488
[email protected]253fc2bb2014-07-10 04:21:1889 // Callback from ExtensionInstallChecker.
90 void OnInstallChecksComplete(int failed_checks);
[email protected]98270432012-09-11 20:51:2491
[email protected]8e7b2cf42012-04-18 14:26:5892 // Verifies if loading unpacked extensions is allowed.
93 bool IsLoadingUnpackedAllowed() const;
94
[email protected]d8c8f25f2011-11-02 18:18:0195 // We change the input extension path to an absolute path, on the file thread.
96 // Then we need to check the file access preference, which needs
97 // to happen back on the UI thread, so it posts CheckExtensionFileAccess on
98 // the UI thread. In turn, once that gets the pref, it goes back to the
99 // file thread with LoadWithFileAccess.
100 // TODO(yoz): It would be nice to remove this ping-pong, but we need to know
[email protected]85df9d12014-04-15 17:02:14101 // what file access flags to pass to file_util::LoadExtension.
[email protected]d8c8f25f2011-11-02 18:18:01102 void GetAbsolutePath();
103 void CheckExtensionFileAccess();
[email protected]b7462f32012-09-02 15:18:12104 void LoadWithFileAccess(int flags);
[email protected]d8c8f25f2011-11-02 18:18:01105
[email protected]add57db72014-04-01 23:25:22106 // Notify the frontend that an attempt to retry will not be necessary.
107 void UnregisterLoadRetryListener();
108
[email protected]d8c8f25f2011-11-02 18:18:01109 // Notify the frontend that there was an error loading an extension.
110 void ReportExtensionLoadError(const std::string& error);
111
[email protected]253fc2bb2014-07-10 04:21:18112 // Passes the extension onto extension service.
113 void InstallExtension();
[email protected]d8c8f25f2011-11-02 18:18:01114
[email protected]b7462f32012-09-02 15:18:12115 // Helper to get the Extension::CreateFlags for the installing extension.
116 int GetFlags();
117
[email protected]253fc2bb2014-07-10 04:21:18118 const Extension* extension() { return install_checker_.extension().get(); }
119
[email protected]849749d2013-05-06 17:30:45120 // The service we will report results back to.
[email protected]d8c8f25f2011-11-02 18:18:01121 base::WeakPtr<ExtensionService> service_weak_;
122
123 // The pathname of the directory to load from, which is an absolute path
124 // after GetAbsolutePath has been called.
[email protected]650b2d52013-02-10 03:41:45125 base::FilePath extension_path_;
[email protected]d8c8f25f2011-11-02 18:18:01126
127 // If true and the extension contains plugins, we prompt the user before
128 // loading.
129 bool prompt_for_plugins_;
130
[email protected]b7462f32012-09-02 15:18:12131 // Whether to require the extension installed to have a modern manifest
132 // version.
133 bool require_modern_manifest_version_;
134
[email protected]1f0722442014-05-01 17:26:02135 // Whether or not to be noisy (show a dialog) on failure. Defaults to true.
136 bool be_noisy_on_failure_;
137
[email protected]253fc2bb2014-07-10 04:21:18138 // Checks management policies and requirements before the extension can be
139 // installed.
140 ExtensionInstallChecker install_checker_;
[email protected]849749d2013-05-06 17:30:45141
rdevlin.croninf6ea63a2015-03-04 17:51:04142 CompletionCallback callback_;
143
[email protected]d8c8f25f2011-11-02 18:18:01144 DISALLOW_COPY_AND_ASSIGN(UnpackedInstaller);
145};
146
147} // namespace extensions
148
149#endif // CHROME_BROWSER_EXTENSIONS_UNPACKED_INSTALLER_H_