| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 FeaturePolicy_h | 5 #ifndef FeaturePolicy_h |
| 6 #define FeaturePolicy_h | 6 #define FeaturePolicy_h |
| 7 | 7 |
| 8 #include "platform/PlatformExport.h" | 8 #include "platform/PlatformExport.h" |
| 9 #include "platform/weborigin/SecurityOrigin.h" | 9 #include "platform/weborigin/SecurityOrigin.h" |
| 10 #include "public/platform/WebFeaturePolicy.h" |
| 10 #include "wtf/RefPtr.h" | 11 #include "wtf/RefPtr.h" |
| 11 #include "wtf/Vector.h" | 12 #include "wtf/Vector.h" |
| 12 #include "wtf/text/WTFString.h" | 13 #include "wtf/text/WTFString.h" |
| 13 | 14 |
| 14 #include <memory> | 15 #include <memory> |
| 15 | 16 |
| 16 namespace blink { | 17 namespace blink { |
| 17 | 18 |
| 18 // Feature Policy is a mechanism for controlling the availability of web | 19 // Feature Policy is a mechanism for controlling the availability of web |
| 19 // platform features in a frame, including all embedded frames. It can be used | 20 // platform features in a frame, including all embedded frames. It can be used |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 116 // The name of the feature, as it should appear in a policy string | 117 // The name of the feature, as it should appear in a policy string |
| 117 const char* const featureName; | 118 const char* const featureName; |
| 118 | 119 |
| 119 // Controls whether the feature should be available in the platform by | 120 // Controls whether the feature should be available in the platform by |
| 120 // default, in the absence of any declared policy. | 121 // default, in the absence of any declared policy. |
| 121 FeatureDefault defaultPolicy; | 122 FeatureDefault defaultPolicy; |
| 122 }; | 123 }; |
| 123 | 124 |
| 124 using FeatureList = const Vector<const FeaturePolicy::Feature*>; | 125 using FeatureList = const Vector<const FeaturePolicy::Feature*>; |
| 125 | 126 |
| 127 // Converts a JSON feature policy string into a vector of whitelists, one for |
| 128 // each feature specified. Unrecognized features are parsed and included |
| 129 // but will be filtered out when the policy is constructed. If |messages| is |
| 130 // not null, then any errors in the input will cause an error message to be |
| 131 // appended to it. |
| 132 static WebVector<WebFeaturePolicy::ParsedWhitelist> parseFeaturePolicy( |
| 133 const String& policy, |
| 134 const SecurityOrigin*, |
| 135 Vector<String>* messages); |
| 136 |
| 126 static std::unique_ptr<FeaturePolicy> createFromParentPolicy( | 137 static std::unique_ptr<FeaturePolicy> createFromParentPolicy( |
| 127 const FeaturePolicy* parent, | 138 const FeaturePolicy* parent, |
| 128 RefPtr<SecurityOrigin>); | 139 RefPtr<SecurityOrigin>); |
| 129 | 140 |
| 130 // Sets the declared policy from the Feature-Policy HTTP header. If the header | 141 // Sets the declared policy from the parsed Feature-Policy HTTP header. |
| 131 // cannot be parsed, errors will be appended to the |messages| vector, if not | 142 // Unrecognized features will be ignored. |
| 132 // null. | 143 void setHeaderPolicy(const WebVector<WebFeaturePolicy::ParsedWhitelist>&); |
| 133 void setHeaderPolicy(const String&, Vector<String>* messages); | |
| 134 | 144 |
| 135 // Returns whether or not the given feature is enabled by this policy. | 145 // Returns whether or not the given feature is enabled by this policy. |
| 136 bool isFeatureEnabledForOrigin(const Feature&, const SecurityOrigin&) const; | 146 bool isFeatureEnabledForOrigin(const Feature&, const SecurityOrigin&) const; |
| 137 | 147 |
| 138 // Returns whether or not the given feature is enabled for the frame that owns | 148 // Returns whether or not the given feature is enabled for the frame that owns |
| 139 // the policy. | 149 // the policy. |
| 140 bool isFeatureEnabled(const Feature&) const; | 150 bool isFeatureEnabled(const Feature&) const; |
| 141 | 151 |
| 142 // Returns the list of features which can be controlled by Feature Policy. | 152 // Returns the list of features which can be controlled by Feature Policy. |
| 143 static FeatureList& getDefaultFeatureList(); | 153 static FeatureList& getDefaultFeatureList(); |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 185 extern const PLATFORM_EXPORT FeaturePolicy::Feature kPushFeature; | 195 extern const PLATFORM_EXPORT FeaturePolicy::Feature kPushFeature; |
| 186 extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncScript; | 196 extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncScript; |
| 187 extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncXHR; | 197 extern const PLATFORM_EXPORT FeaturePolicy::Feature kSyncXHR; |
| 188 extern const PLATFORM_EXPORT FeaturePolicy::Feature kUsermedia; | 198 extern const PLATFORM_EXPORT FeaturePolicy::Feature kUsermedia; |
| 189 extern const PLATFORM_EXPORT FeaturePolicy::Feature kVibrateFeature; | 199 extern const PLATFORM_EXPORT FeaturePolicy::Feature kVibrateFeature; |
| 190 extern const PLATFORM_EXPORT FeaturePolicy::Feature kWebRTC; | 200 extern const PLATFORM_EXPORT FeaturePolicy::Feature kWebRTC; |
| 191 | 201 |
| 192 } // namespace blink | 202 } // namespace blink |
| 193 | 203 |
| 194 #endif // FeaturePolicy_h | 204 #endif // FeaturePolicy_h |
| OLD | NEW |