Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(627)

Unified Diff: content/common/feature_policy/feature_policy.h

Issue 2636843003: Move most Feature Policy code into content/ (Closed)
Patch Set: Addressing review comments Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/common/feature_policy/OWNERS ('k') | content/common/feature_policy/feature_policy.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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_
« no previous file with comments | « content/common/feature_policy/OWNERS ('k') | content/common/feature_policy/feature_policy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698