Home | History | Annotate | Download | only in features
      1 // Copyright 2013 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 EXTENSIONS_COMMON_FEATURES_FEATURE_H_
      6 #define EXTENSIONS_COMMON_FEATURES_FEATURE_H_
      7 
      8 #include <set>
      9 #include <string>
     10 
     11 #include "base/values.h"
     12 #include "extensions/common/manifest.h"
     13 
     14 class GURL;
     15 
     16 namespace extensions {
     17 
     18 class Extension;
     19 
     20 // Represents a single feature accessible to an extension developer, such as a
     21 // top-level manifest key, a permission, or a programmatic API. A feature can
     22 // express requirements for where it can be accessed, and supports testing
     23 // support for those requirements. If platforms are not specified, then feature
     24 // is available on all platforms.
     25 class Feature {
     26  public:
     27   // The JavaScript contexts the feature is supported in.
     28   enum Context {
     29     UNSPECIFIED_CONTEXT,
     30 
     31     // A context in a privileged extension process.
     32     BLESSED_EXTENSION_CONTEXT,
     33 
     34     // A context in an unprivileged extension process.
     35     UNBLESSED_EXTENSION_CONTEXT,
     36 
     37     // A context from a content script.
     38     CONTENT_SCRIPT_CONTEXT,
     39 
     40     // A normal web page. This should have an associated URL matching pattern.
     41     WEB_PAGE_CONTEXT,
     42 
     43     // A web page context which has been blessed by the user. Typically this
     44     // will be via the installation of a hosted app, so this may host an
     45     // extension. This is not affected by the URL matching pattern.
     46     BLESSED_WEB_PAGE_CONTEXT,
     47   };
     48 
     49   // The location required of extensions the feature is supported in.
     50   enum Location {
     51     UNSPECIFIED_LOCATION,
     52     COMPONENT_LOCATION
     53   };
     54 
     55   // The platforms the feature is supported in.
     56   enum Platform {
     57     UNSPECIFIED_PLATFORM,
     58     CHROMEOS_PLATFORM,
     59     LINUX_PLATFORM,
     60     MACOSX_PLATFORM,
     61     WIN_PLATFORM
     62   };
     63 
     64   // Whether a feature is available in a given situation or not, and if not,
     65   // why not.
     66   enum AvailabilityResult {
     67     IS_AVAILABLE,
     68     NOT_FOUND_IN_WHITELIST,
     69     INVALID_URL,
     70     INVALID_TYPE,
     71     INVALID_CONTEXT,
     72     INVALID_LOCATION,
     73     INVALID_PLATFORM,
     74     INVALID_MIN_MANIFEST_VERSION,
     75     INVALID_MAX_MANIFEST_VERSION,
     76     NOT_PRESENT,
     77     UNSUPPORTED_CHANNEL,
     78   };
     79 
     80   // Container for AvailabiltyResult that also exposes a user-visible error
     81   // message in cases where the feature is not available.
     82   class Availability {
     83    public:
     84     AvailabilityResult result() const { return result_; }
     85     bool is_available() const { return result_ == IS_AVAILABLE; }
     86     const std::string& message() const { return message_; }
     87 
     88    private:
     89     friend class SimpleFeature;
     90     friend class Feature;
     91 
     92     // Instances should be created via Feature::CreateAvailability.
     93     Availability(AvailabilityResult result, const std::string& message)
     94         : result_(result), message_(message) { }
     95 
     96     const AvailabilityResult result_;
     97     const std::string message_;
     98   };
     99 
    100   Feature();
    101   virtual ~Feature();
    102 
    103   // Used by ChromeV8Context until the feature system is fully functional.
    104   static Availability CreateAvailability(AvailabilityResult result,
    105                                          const std::string& message);
    106 
    107   const std::string& name() const { return name_; }
    108   void set_name(const std::string& name) { name_ = name; }
    109   const std::set<std::string>& dependencies() { return dependencies_; }
    110   bool no_parent() const { return no_parent_; }
    111 
    112   // Gets the platform the code is currently running on.
    113   static Platform GetCurrentPlatform();
    114 
    115   // Gets the Feature::Location value for the specified Manifest::Location.
    116   static Location ConvertLocation(Manifest::Location extension_location);
    117 
    118   virtual std::set<Context>* GetContexts() = 0;
    119 
    120   // Tests whether this is an internal API or not.
    121   virtual bool IsInternal() const = 0;
    122 
    123   // Returns true if the feature is available to be parsed into a new extension
    124   // manifest.
    125   Availability IsAvailableToManifest(const std::string& extension_id,
    126                                      Manifest::Type type,
    127                                      Location location,
    128                                      int manifest_version) const {
    129     return IsAvailableToManifest(extension_id, type, location, manifest_version,
    130                                  GetCurrentPlatform());
    131   }
    132   virtual Availability IsAvailableToManifest(const std::string& extension_id,
    133                                              Manifest::Type type,
    134                                              Location location,
    135                                              int manifest_version,
    136                                              Platform platform) const = 0;
    137 
    138   // Returns true if the feature is available to be used in the specified
    139   // extension and context.
    140   Availability IsAvailableToContext(const Extension* extension,
    141                                     Context context,
    142                                     const GURL& url) const {
    143     return IsAvailableToContext(extension, context, url, GetCurrentPlatform());
    144   }
    145   virtual Availability IsAvailableToContext(const Extension* extension,
    146                                             Context context,
    147                                             const GURL& url,
    148                                             Platform platform) const = 0;
    149 
    150   virtual std::string GetAvailabilityMessage(AvailabilityResult result,
    151                                              Manifest::Type type,
    152                                              const GURL& url,
    153                                              Context context) const = 0;
    154 
    155   virtual bool IsIdInWhitelist(const std::string& extension_id) const = 0;
    156 
    157  protected:
    158   std::string name_;
    159   std::set<std::string> dependencies_;
    160   bool no_parent_;
    161 };
    162 
    163 }  // namespace extensions
    164 
    165 #endif  // EXTENSIONS_COMMON_FEATURES_FEATURE_H_
    166