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