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
3 // found in the LICENSE file.
5 #ifndef CHROME_INSTALLER_UTIL_PRODUCT_OPERATIONS_H_
6 #define CHROME_INSTALLER_UTIL_PRODUCT_OPERATIONS_H_
12 #include "base/files/file_path.h"
13 #include "base/strings/string16.h"
14 #include "chrome/installer/util/shell_util.h"
15 #include "chrome/installer/util/util_constants.h"
17 class BrowserDistribution
;
23 class MasterPreferences
;
25 // An interface to product-specific operations that depend on product
26 // configuration. Implementations are expected to be stateless. Configuration
27 // can be read from a MasterPreferences instance or from a product's uninstall
29 class ProductOperations
{
31 virtual ~ProductOperations() {}
33 // Reads product-specific options from |prefs|, adding them to |options|.
34 virtual void ReadOptions(const MasterPreferences
& prefs
,
35 std::set
<base::string16
>* options
) const = 0;
37 // Reads product-specific options from |command|, adding them to |options|.
38 virtual void ReadOptions(const CommandLine
& command
,
39 std::set
<base::string16
>* options
) const = 0;
41 // A key-file is a file such as a DLL on Windows that is expected to be in use
42 // when the product is being used. For example "chrome.dll" for Chrome.
43 // Before attempting to delete an installation directory during an
44 // uninstallation, the uninstaller will check if any one of a potential set of
45 // key files is in use and if they are, abort the delete operation. Only if
46 // none of the key files are in use, can the folder be deleted. Note that
47 // this function does not return a full path to the key file(s), only (a) file
49 virtual void AddKeyFiles(const std::set
<base::string16
>& options
,
50 std::vector
<base::FilePath
>* key_files
) const = 0;
52 // Adds to |com_dll_list| the list of COM DLLs that are to be registered
53 // and/or unregistered. The list may be empty.
54 virtual void AddComDllList(
55 const std::set
<base::string16
>& options
,
56 std::vector
<base::FilePath
>* com_dll_list
) const = 0;
58 // Given a command line, appends the set of product-specific flags. These are
59 // required for product-specific uninstall commands, but are of use for any
60 // invocation of setup.exe for the product.
61 virtual void AppendProductFlags(const std::set
<base::string16
>& options
,
62 CommandLine
* cmd_line
) const = 0;
64 // Given a command line, appends the set of product-specific rename flags.
65 virtual void AppendRenameFlags(const std::set
<base::string16
>& options
,
66 CommandLine
* cmd_line
) const = 0;
68 // Adds or removes product-specific flags in |channel_info|. Returns true if
69 // |channel_info| is modified.
70 virtual bool SetChannelFlags(const std::set
<base::string16
>& options
,
72 ChannelInfo
* channel_info
) const = 0;
74 // Returns true if setup should create an entry in the Add/Remove list
75 // of installed applications for this product. This does not test for use of
76 // MSI; see InstallerState::is_msi.
77 virtual bool ShouldCreateUninstallEntry(
78 const std::set
<base::string16
>& options
) const = 0;
80 // Modifies a ShellUtil::ShortcutProperties object by assigning default values
81 // to unintialized members.
82 virtual void AddDefaultShortcutProperties(
83 BrowserDistribution
* dist
,
84 const base::FilePath
& target_exe
,
85 ShellUtil::ShortcutProperties
* properties
) const = 0;
87 // After an install or upgrade the user might qualify to participate in an
88 // experiment. This function determines if the user qualifies and if so it
89 // sets the wheels in motion or in simple cases does the experiment itself.
90 virtual void LaunchUserExperiment(const base::FilePath
& setup_path
,
91 const std::set
<base::string16
>& options
,
93 bool system_level
) const = 0;
96 } // namespace installer
98 #endif // CHROME_INSTALLER_UTIL_PRODUCT_OPERATIONS_H_