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_EXTENSIONS_PENDING_EXTENSION_INFO_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_PENDING_EXTENSION_INFO_H_ |
6 #define CHROME_BROWSER_EXTENSIONS_PENDING_EXTENSION_INFO_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_PENDING_EXTENSION_INFO_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/gtest_prod_util.h" | 10 #include "base/gtest_prod_util.h" |
11 #include "base/version.h" | 11 #include "base/version.h" |
12 #include "extensions/common/manifest.h" | 12 #include "extensions/common/manifest.h" |
13 #include "url/gurl.h" | 13 #include "url/gurl.h" |
14 | 14 |
15 FORWARD_DECLARE_TEST(ExtensionServiceTest, AddPendingExtensionFromSync); | 15 FORWARD_DECLARE_TEST(ExtensionServiceTest, AddPendingExtensionFromSync); |
16 | 16 |
17 namespace extensions { | 17 namespace extensions { |
18 class Extension; | 18 class Extension; |
19 | 19 |
20 // A pending extension is an extension that hasn't been installed yet | 20 // A pending extension is an extension that hasn't been installed yet |
21 // and is intended to be installed in the next auto-update cycle. The | 21 // and is intended to be installed in the next auto-update cycle. The |
22 // update URL of a pending extension may be blank, in which case a | 22 // update URL of a pending extension may be blank, in which case a |
23 // default one is assumed. | 23 // default one is assumed. |
24 // TODO(skerner): Make this class an implementation detail of | 24 // TODO(skerner): Make this class an implementation detail of |
25 // PendingExtensionManager, and remove all other users. | 25 // PendingExtensionManager, and remove all other users. |
26 class PendingExtensionInfo { | 26 class PendingExtensionInfo { |
27 public: | 27 public: |
28 typedef bool (*ShouldAllowInstallPredicate)(const Extension*); | 28 typedef bool (*ShouldAllowInstallPredicate)(const Extension*); |
29 | 29 |
30 PendingExtensionInfo( | 30 PendingExtensionInfo(const std::string& id, |
31 const std::string& id, | 31 const std::string& install_parameter, |
32 const GURL& update_url, | 32 const GURL& update_url, |
33 const Version& version, | 33 const Version& version, |
34 ShouldAllowInstallPredicate should_allow_install, | 34 ShouldAllowInstallPredicate should_allow_install, |
35 bool is_from_sync, | 35 bool is_from_sync, |
36 bool install_silently, | 36 bool install_silently, |
37 Manifest::Location install_source, | 37 Manifest::Location install_source, |
38 int creation_flags, | 38 int creation_flags, |
39 bool mark_acknowledged); | 39 bool mark_acknowledged); |
40 | 40 |
41 // Required for STL container membership. Should not be used directly. | 41 // Required for STL container membership. Should not be used directly. |
42 PendingExtensionInfo(); | 42 PendingExtensionInfo(); |
43 | 43 |
| 44 ~PendingExtensionInfo(); |
| 45 |
44 // Consider two PendingExtensionInfos equal if their ids are equal. | 46 // Consider two PendingExtensionInfos equal if their ids are equal. |
45 bool operator==(const PendingExtensionInfo& rhs) const; | 47 bool operator==(const PendingExtensionInfo& rhs) const; |
46 | 48 |
47 const std::string& id() const { return id_; } | 49 const std::string& id() const { return id_; } |
48 const GURL& update_url() const { return update_url_; } | 50 const GURL& update_url() const { return update_url_; } |
49 const Version& version() const { return version_; } | 51 const Version& version() const { return version_; } |
| 52 const std::string& install_parameter() const { return install_parameter_; } |
50 | 53 |
51 // ShouldAllowInstall() returns the result of running constructor argument | 54 // ShouldAllowInstall() returns the result of running constructor argument |
52 // |should_allow_install| on an extension. After an extension is unpacked, | 55 // |should_allow_install| on an extension. After an extension is unpacked, |
53 // this function is run. If it returns true, the extension is installed. | 56 // this function is run. If it returns true, the extension is installed. |
54 // If not, the extension is discarded. This allows creators of | 57 // If not, the extension is discarded. This allows creators of |
55 // PendingExtensionInfo objects to ensure that extensions meet some criteria | 58 // PendingExtensionInfo objects to ensure that extensions meet some criteria |
56 // that can only be tested once the extension is unpacked. | 59 // that can only be tested once the extension is unpacked. |
57 bool ShouldAllowInstall(const Extension* extension) const { | 60 bool ShouldAllowInstall(const Extension* extension) const { |
58 return should_allow_install_(extension); | 61 return should_allow_install_(extension); |
59 } | 62 } |
60 bool is_from_sync() const { return is_from_sync_; } | 63 bool is_from_sync() const { return is_from_sync_; } |
61 bool install_silently() const { return install_silently_; } | 64 bool install_silently() const { return install_silently_; } |
62 Manifest::Location install_source() const { return install_source_; } | 65 Manifest::Location install_source() const { return install_source_; } |
63 int creation_flags() const { return creation_flags_; } | 66 int creation_flags() const { return creation_flags_; } |
64 bool mark_acknowledged() const { return mark_acknowledged_; } | 67 bool mark_acknowledged() const { return mark_acknowledged_; } |
65 | 68 |
66 // Returns -1, 0 or 1 if |this| has lower, equal or higher precedence than | 69 // Returns -1, 0 or 1 if |this| has lower, equal or higher precedence than |
67 // |other|, respectively. "Equal" precedence means that the version and the | 70 // |other|, respectively. "Equal" precedence means that the version and the |
68 // install source match. "Higher" precedence means that the version is newer, | 71 // install source match. "Higher" precedence means that the version is newer, |
69 // or the version matches but the install source has higher priority. | 72 // or the version matches but the install source has higher priority. |
70 // It is only valid to invoke this when the ids match. | 73 // It is only valid to invoke this when the ids match. |
71 int CompareTo(const PendingExtensionInfo& other) const; | 74 int CompareTo(const PendingExtensionInfo& other) const; |
72 | 75 |
73 private: | 76 private: |
74 std::string id_; | 77 std::string id_; |
75 | 78 |
76 GURL update_url_; | 79 GURL update_url_; |
77 Version version_; | 80 Version version_; |
| 81 std::string install_parameter_; |
78 | 82 |
79 // When the extension is about to be installed, this function is | 83 // When the extension is about to be installed, this function is |
80 // called. If this function returns true, the install proceeds. If | 84 // called. If this function returns true, the install proceeds. If |
81 // this function returns false, the install is aborted. | 85 // this function returns false, the install is aborted. |
82 ShouldAllowInstallPredicate should_allow_install_; | 86 ShouldAllowInstallPredicate should_allow_install_; |
83 | 87 |
84 bool is_from_sync_; // This update check was initiated from sync. | 88 bool is_from_sync_; // This update check was initiated from sync. |
85 bool install_silently_; | 89 bool install_silently_; |
86 Manifest::Location install_source_; | 90 Manifest::Location install_source_; |
87 int creation_flags_; | 91 int creation_flags_; |
88 bool mark_acknowledged_; | 92 bool mark_acknowledged_; |
89 | 93 |
90 FRIEND_TEST_ALL_PREFIXES(::ExtensionServiceTest, AddPendingExtensionFromSync); | 94 FRIEND_TEST_ALL_PREFIXES(::ExtensionServiceTest, AddPendingExtensionFromSync); |
91 }; | 95 }; |
92 | 96 |
93 } // namespace extensions | 97 } // namespace extensions |
94 | 98 |
95 #endif // CHROME_BROWSER_EXTENSIONS_PENDING_EXTENSION_INFO_H_ | 99 #endif // CHROME_BROWSER_EXTENSIONS_PENDING_EXTENSION_INFO_H_ |
OLD | NEW |