Index: content/common/feature_policy/feature_policy.h |
diff --git a/third_party/WebKit/Source/platform/feature_policy/FeaturePolicy.h b/content/common/feature_policy/feature_policy.h |
similarity index 51% |
copy from third_party/WebKit/Source/platform/feature_policy/FeaturePolicy.h |
copy to content/common/feature_policy/feature_policy.h |
index 47b22e6b7951c1183d00a0ce4e824b48c75495cc..22b7d1b9b45036bc035e8fe1843c2026f7f5acf5 100644 |
--- a/third_party/WebKit/Source/platform/feature_policy/FeaturePolicy.h |
+++ b/content/common/feature_policy/feature_policy.h |
@@ -2,19 +2,19 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#ifndef FeaturePolicy_h |
-#define FeaturePolicy_h |
- |
-#include "platform/PlatformExport.h" |
-#include "platform/weborigin/SecurityOrigin.h" |
-#include "public/platform/WebFeaturePolicy.h" |
-#include "wtf/RefPtr.h" |
-#include "wtf/Vector.h" |
-#include "wtf/text/WTFString.h" |
+#ifndef CONTENT_COMMON_FEATURE_POLICY_FEATURE_POLICY_H_ |
+#define CONTENT_COMMON_FEATURE_POLICY_FEATURE_POLICY_H_ |
+#include <map> |
#include <memory> |
+#include <string> |
+#include <vector> |
+ |
+#include "content/common/content_export.h" |
+#include "third_party/WebKit/public/platform/WebFeaturePolicy.h" |
+#include "url/origin.h" |
-namespace blink { |
+namespace content { |
// Feature Policy is a mechanism for controlling the availability of web |
// platform features in a frame, including all embedded frames. It can be used |
@@ -23,8 +23,8 @@ namespace blink { |
// feature; see the specification for details). |
// |
// Policies can be defined in the HTTP header stream, with the |Feature-Policy| |
-// HTTP header, or can be set by |enable| and |disable| attributes on the iframe |
-// element which embeds the document. |
+// HTTP header, or can be set by the |allow| attributes on the iframe element |
+// which embeds the document. |
// |
// See https://wicg.github.io/FeaturePolicy/ |
// |
@@ -32,21 +32,30 @@ namespace blink { |
// |
// Features |
// -------- |
-// Features which can be controlled by policy are defined as instances of the |
-// FeaturePoliicy::Feature struct. The features are referenced by pointer, so |
-// only a single instance of each feature should be defined. The features which |
-// are declared in the feature policy specification are all defined in |
-// |FeaturePolicy.cpp|. |
+// Features which can be controlled by policy are defined by instances of the |
+// FeaturePolicy::Feature struct. The features are referenced by the |
+// |WebFeaturePolicyFeature| enum, declared in |WebFeaturePolicy.h|. |
// |
// Whitelists |
// ---------- |
-// Policies are defined as a mapping of feaure names to whitelists. Whitelists |
-// are collections of origins, although two special terms can be used when |
-// declaring them: |
+// Whitelists are collections of origins, although two special terms can be used |
+// when declaring them: |
// "self" refers to the orgin of the frame which is declaring the policy. |
// "*" refers to all origins; any origin will match a whitelist which contains |
// it. |
// |
+// Declarations |
+// ------------ |
+// A feature policy declaration is a mapping of a feature name to a whitelist. |
+// A set of declarations is a declared policy. |
+// |
+// Inherited Policy |
+// ---------------- |
+// In addition to the declared policy (which may be empty), every frame has |
+// an inherited policy, which is determined by the context in which it is |
+// embedded, or by the defaults for each feature in the case of the top-level |
+// document. |
+// |
// Defaults |
// -------- |
// Each defined feature has a default policy, which determines whether the |
@@ -66,32 +75,48 @@ namespace blink { |
// determined by the feature's default policy. (Again, see the comments in |
// FeaturePolicy::DefaultPolicy for details) |
-class PLATFORM_EXPORT FeaturePolicy final { |
+// This struct holds feature policy whitelist data that needs to be replicated |
+// between a RenderFrame and any of its associated RenderFrameProxies. A list of |
+// these form a FeaturePolicyHeader. |
+// NOTE: These types are used for replication frame state between processes. |
+// They exist only because we can't transfer WebVectors directly over IPC. |
+struct CONTENT_EXPORT FeaturePolicyParsedDeclaration { |
+ FeaturePolicyParsedDeclaration(); |
+ FeaturePolicyParsedDeclaration(std::string feature_name, |
+ bool matches_all_origins, |
+ std::vector<url::Origin> origins); |
+ FeaturePolicyParsedDeclaration(const FeaturePolicyParsedDeclaration& rhs); |
+ ~FeaturePolicyParsedDeclaration(); |
+ |
+ std::string feature_name; |
+ bool matches_all_origins; |
+ std::vector<url::Origin> origins; |
+}; |
+using FeaturePolicyHeader = std::vector<FeaturePolicyParsedDeclaration>; |
+ |
+class CONTENT_EXPORT FeaturePolicy : public blink::WebFeaturePolicy { |
public: |
// Represents a collection of origins which make up a whitelist in a feature |
// policy. This collection may be set to match every origin (corresponding to |
- // the "*" syntax in the policy string, in which case the contains() method |
+ // the "*" syntax in the policy string, in which case the Contains() method |
// will always return true. |
class Whitelist final { |
public: |
- static std::unique_ptr<Whitelist> from( |
- const WebFeaturePolicy::ParsedWhitelist&); |
- |
Whitelist(); |
+ ~Whitelist(); |
// Adds a single origin to the whitelist. |
- void add(RefPtr<SecurityOrigin>); |
+ void Add(const url::Origin& origin); |
// Adds all origins to the whitelist. |
- void addAll(); |
+ void AddAll(); |
// Returns true if the given origin has been added to the whitelist. |
- bool contains(const SecurityOrigin&) const; |
- String toString(); |
+ bool Contains(const url::Origin& origin) const; |
private: |
- bool m_matchesAllOrigins; |
- Vector<RefPtr<SecurityOrigin>> m_origins; |
+ bool matches_all_origins_; |
+ std::vector<url::Origin> origins_; |
}; |
// The FeaturePolicy::FeatureDefault enum defines the default enable state for |
@@ -118,90 +143,63 @@ class PLATFORM_EXPORT FeaturePolicy final { |
// for any given feature (declared below). |
struct Feature { |
// The name of the feature, as it should appear in a policy string |
- const char* const featureName; |
+ const char* const feature_name; |
// Controls whether the feature should be available in the platform by |
// default, in the absence of any declared policy. |
- FeatureDefault defaultPolicy; |
+ FeatureDefault default_policy; |
}; |
- using FeatureList = const Vector<const FeaturePolicy::Feature*>; |
- |
- // Converts a JSON feature policy string into a vector of whitelists, one for |
- // each feature specified. Unrecognized features are parsed and included |
- // but will be filtered out when the policy is constructed. If |messages| is |
- // not null, then any errors in the input will cause an error message to be |
- // appended to it. |
- static WebParsedFeaturePolicy parseFeaturePolicy(const String& policy, |
- RefPtr<SecurityOrigin>, |
- Vector<String>* messages); |
+ using FeatureList = |
+ std::map<blink::WebFeaturePolicyFeature, const FeaturePolicy::Feature*>; |
- static std::unique_ptr<FeaturePolicy> createFromParentPolicy( |
- const FeaturePolicy* parent, |
- RefPtr<SecurityOrigin>); |
+ ~FeaturePolicy() override; |
- // Sets the declared policy from the parsed Feature-Policy HTTP header. |
- // Unrecognized features will be ignored. |
- void setHeaderPolicy(const WebParsedFeaturePolicy&); |
+ static std::unique_ptr<FeaturePolicy> CreateFromParentPolicy( |
+ const FeaturePolicy* parent_policy, |
+ url::Origin origin); |
// Returns whether or not the given feature is enabled by this policy. |
- bool isFeatureEnabledForOrigin(const Feature&, const SecurityOrigin&) const; |
- |
- // Returns whether or not the given feature is enabled for the frame that owns |
- // the policy. |
- bool isFeatureEnabled(const Feature&) const; |
+ bool IsFeatureEnabledForOrigin(blink::WebFeaturePolicyFeature feature, |
+ url::Origin origin) const; |
- // Returns the list of features which can be controlled by Feature Policy. |
- static FeatureList& getDefaultFeatureList(); |
+ // Returns whether or not the given feature is enabled for the origin of the |
+ // document that owns the policy. |
+ bool IsFeatureEnabled(blink::WebFeaturePolicyFeature feature) const; |
- String toString(); |
+ // Sets the declared policy from the parsed Feature-Policy HTTP header. |
+ // Unrecognized features will be ignored. |
+ void SetHeaderPolicy(const FeaturePolicyHeader& parsed_header); |
private: |
friend class FeaturePolicyTest; |
- friend class FeaturePolicyInFrameTest; |
- FeaturePolicy(RefPtr<SecurityOrigin>, FeatureList& features); |
+ explicit FeaturePolicy(url::Origin origin); |
+ FeaturePolicy(url::Origin origin, const FeatureList& feature_list); |
+ static std::unique_ptr<FeaturePolicy> CreateFromParentPolicy( |
+ const FeaturePolicy* parent_policy, |
+ url::Origin origin, |
+ const FeatureList& features); |
+ |
+ // Returns the list of features which can be controlled by Feature Policy. |
+ static const FeatureList& getDefaultFeatureList(); |
- static std::unique_ptr<FeaturePolicy> createFromParentPolicy( |
- const FeaturePolicy* parent, |
- RefPtr<SecurityOrigin>, |
- FeatureList& features); |
+ url::Origin origin_; |
- RefPtr<SecurityOrigin> m_origin; |
+ // Map of feature names to declared whitelists. Any feature which is missing |
+ // from this map should use the inherited policy. |
+ std::map<blink::WebFeaturePolicyFeature, std::unique_ptr<Whitelist>> |
+ whitelists_; |
// Records whether or not each feature was enabled for this frame by its |
// parent frame. |
// TODO(iclelland): Generate, instead of this map, a set of bool flags, one |
// for each feature, as all features are supposed to be represented here. |
- HashMap<const Feature*, bool> m_inheritedFeatures; |
+ std::map<blink::WebFeaturePolicyFeature, bool> inherited_policies_; |
- // Map of feature names to declared whitelists. Any feature which is missing |
- // from this map should use the inherited policy. |
- HashMap<const Feature*, std::unique_ptr<Whitelist>> m_headerWhitelists; |
- |
- // Contains the set of all features which can be controlled by this policy. |
- FeatureList& m_features; |
- |
- DISALLOW_COPY_AND_ASSIGN(FeaturePolicy); |
+ const FeatureList& feature_list_; |
}; |
-// Declarations for all features currently under control of the Feature Policy |
-// mechanism should be placed here. |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kDocumentCookie; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kDocumentDomain; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kDocumentWrite; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kGeolocationFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kFullscreenFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kMidiFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kNotificationsFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kPaymentFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kPushFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncScript; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncXHR; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kUsermedia; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kVibrateFeature; |
-extern const PLATFORM_EXPORT FeaturePolicy::Feature kWebRTC; |
- |
-} // namespace blink |
- |
-#endif // FeaturePolicy_h |
+} // namespace content |
+ |
+#endif // CONTENT_COMMON_FEATURE_POLICY_FEATURE_POLICY_H_ |