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

Side by Side Diff: components/content_settings/core/browser/content_settings_registry.cc

Issue 1991623005: Only Register() platform specific content settings types on different platforms (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address review comments and add tests Created 4 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 #include "components/content_settings/core/browser/content_settings_registry.h" 5 #include "components/content_settings/core/browser/content_settings_registry.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <utility> 8 #include <utility>
9 9
10 #include "base/macros.h" 10 #include "base/macros.h"
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after
117 117
118 // WARNING: The string names of the permissions passed in below are used to 118 // WARNING: The string names of the permissions passed in below are used to
119 // generate preference names and should never be changed! 119 // generate preference names and should never be changed!
120 120
121 Register(CONTENT_SETTINGS_TYPE_COOKIES, "cookies", CONTENT_SETTING_ALLOW, 121 Register(CONTENT_SETTINGS_TYPE_COOKIES, "cookies", CONTENT_SETTING_ALLOW,
122 WebsiteSettingsInfo::SYNCABLE, 122 WebsiteSettingsInfo::SYNCABLE,
123 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 123 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
124 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 124 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
125 CONTENT_SETTING_SESSION_ONLY), 125 CONTENT_SETTING_SESSION_ONLY),
126 WebsiteSettingsInfo::REQUESTING_DOMAIN_ONLY_SCOPE, 126 WebsiteSettingsInfo::REQUESTING_DOMAIN_ONLY_SCOPE,
127 WebsiteSettingsRegistry::ALL_PLATFORMS,
127 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 128 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
128 129
129 Register(CONTENT_SETTINGS_TYPE_IMAGES, "images", CONTENT_SETTING_ALLOW, 130 Register(CONTENT_SETTINGS_TYPE_IMAGES, "images", CONTENT_SETTING_ALLOW,
130 WebsiteSettingsInfo::SYNCABLE, 131 WebsiteSettingsInfo::SYNCABLE,
131 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme, 132 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme,
132 kExtensionScheme), 133 kExtensionScheme),
133 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 134 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
134 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 135 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
136 WebsiteSettingsRegistry::DESKTOP,
135 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 137 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
136 138
137 Register(CONTENT_SETTINGS_TYPE_JAVASCRIPT, "javascript", 139 Register(CONTENT_SETTINGS_TYPE_JAVASCRIPT, "javascript",
138 CONTENT_SETTING_ALLOW, WebsiteSettingsInfo::SYNCABLE, 140 CONTENT_SETTING_ALLOW, WebsiteSettingsInfo::SYNCABLE,
139 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme, 141 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme,
140 kExtensionScheme), 142 kExtensionScheme),
141 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 143 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
142 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 144 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
145 WebsiteSettingsRegistry::DESKTOP |
146 WebsiteSettingsRegistry::PLATFORM_ANDROID,
143 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 147 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
144 148
145 Register(CONTENT_SETTINGS_TYPE_PLUGINS, "plugins", 149 Register(CONTENT_SETTINGS_TYPE_PLUGINS, "plugins",
146 CONTENT_SETTING_DETECT_IMPORTANT_CONTENT, 150 CONTENT_SETTING_DETECT_IMPORTANT_CONTENT,
147 WebsiteSettingsInfo::SYNCABLE, 151 WebsiteSettingsInfo::SYNCABLE,
148 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 152 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
149 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 153 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
150 CONTENT_SETTING_ASK, 154 CONTENT_SETTING_ASK,
151 CONTENT_SETTING_DETECT_IMPORTANT_CONTENT), 155 CONTENT_SETTING_DETECT_IMPORTANT_CONTENT),
152 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 156 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
157 WebsiteSettingsRegistry::DESKTOP,
153 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 158 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
154 159
155 Register(CONTENT_SETTINGS_TYPE_POPUPS, "popups", CONTENT_SETTING_BLOCK, 160 Register(CONTENT_SETTINGS_TYPE_POPUPS, "popups", CONTENT_SETTING_BLOCK,
156 WebsiteSettingsInfo::SYNCABLE, 161 WebsiteSettingsInfo::SYNCABLE,
157 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme, 162 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme,
158 kExtensionScheme), 163 kExtensionScheme),
159 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 164 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
160 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 165 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
166 WebsiteSettingsRegistry::ALL_PLATFORMS,
161 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 167 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
162 168
163 Register(CONTENT_SETTINGS_TYPE_GEOLOCATION, "geolocation", 169 Register(CONTENT_SETTINGS_TYPE_GEOLOCATION, "geolocation",
164 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 170 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
165 WhitelistedSchemes(), 171 WhitelistedSchemes(),
166 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 172 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
167 CONTENT_SETTING_ASK), 173 CONTENT_SETTING_ASK),
168 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 174 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
175 WebsiteSettingsRegistry::DESKTOP |
176 WebsiteSettingsRegistry::PLATFORM_ANDROID,
169 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 177 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
170 178
171 Register(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, "notifications", 179 Register(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, "notifications",
172 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 180 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
173 WhitelistedSchemes(), 181 WhitelistedSchemes(),
174 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 182 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
175 CONTENT_SETTING_ASK), 183 CONTENT_SETTING_ASK),
176 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 184 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
185 WebsiteSettingsRegistry::DESKTOP |
186 WebsiteSettingsRegistry::PLATFORM_ANDROID,
177 // See also NotificationPermissionContext::DecidePermission which 187 // See also NotificationPermissionContext::DecidePermission which
178 // implements additional incognito exceptions. 188 // implements additional incognito exceptions.
179 ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW); 189 ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW);
180 190
181 Register(CONTENT_SETTINGS_TYPE_FULLSCREEN, "fullscreen", CONTENT_SETTING_ASK, 191 Register(CONTENT_SETTINGS_TYPE_FULLSCREEN, "fullscreen", CONTENT_SETTING_ASK,
182 WebsiteSettingsInfo::SYNCABLE, 192 WebsiteSettingsInfo::SYNCABLE,
183 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 193 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
184 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_ASK), 194 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_ASK),
185 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 195 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
196 WebsiteSettingsRegistry::DESKTOP |
197 WebsiteSettingsRegistry::PLATFORM_ANDROID,
186 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 198 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
187 199
188 Register(CONTENT_SETTINGS_TYPE_MOUSELOCK, "mouselock", CONTENT_SETTING_ASK, 200 Register(CONTENT_SETTINGS_TYPE_MOUSELOCK, "mouselock", CONTENT_SETTING_ASK,
189 WebsiteSettingsInfo::SYNCABLE, 201 WebsiteSettingsInfo::SYNCABLE,
190 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 202 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
191 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 203 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
192 CONTENT_SETTING_ASK), 204 CONTENT_SETTING_ASK),
193 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 205 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
206 WebsiteSettingsRegistry::DESKTOP,
194 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 207 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
195 208
196 Register(CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC, "media-stream-mic", 209 Register(CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC, "media-stream-mic",
197 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 210 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
198 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 211 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
199 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 212 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
200 CONTENT_SETTING_ASK), 213 CONTENT_SETTING_ASK),
201 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 214 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
215 WebsiteSettingsRegistry::DESKTOP |
216 WebsiteSettingsRegistry::PLATFORM_ANDROID,
202 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 217 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
203 218
204 Register(CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA, "media-stream-camera", 219 Register(CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA, "media-stream-camera",
205 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 220 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
206 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 221 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
207 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 222 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
208 CONTENT_SETTING_ASK), 223 CONTENT_SETTING_ASK),
209 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 224 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
225 WebsiteSettingsRegistry::DESKTOP |
226 WebsiteSettingsRegistry::PLATFORM_ANDROID,
210 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 227 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
211 228
212 Register(CONTENT_SETTINGS_TYPE_PPAPI_BROKER, "ppapi-broker", 229 Register(CONTENT_SETTINGS_TYPE_PPAPI_BROKER, "ppapi-broker",
213 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 230 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
214 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme), 231 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme),
215 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 232 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
216 CONTENT_SETTING_ASK), 233 CONTENT_SETTING_ASK),
217 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 234 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
235 WebsiteSettingsRegistry::DESKTOP,
218 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 236 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
219 237
220 Register(CONTENT_SETTINGS_TYPE_AUTOMATIC_DOWNLOADS, "automatic-downloads", 238 Register(CONTENT_SETTINGS_TYPE_AUTOMATIC_DOWNLOADS, "automatic-downloads",
221 CONTENT_SETTING_ASK, WebsiteSettingsInfo::SYNCABLE, 239 CONTENT_SETTING_ASK, WebsiteSettingsInfo::SYNCABLE,
222 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme, 240 WhitelistedSchemes(kChromeUIScheme, kChromeDevToolsScheme,
223 kExtensionScheme), 241 kExtensionScheme),
224 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 242 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
225 CONTENT_SETTING_ASK), 243 CONTENT_SETTING_ASK),
226 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 244 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
245 WebsiteSettingsRegistry::DESKTOP |
246 WebsiteSettingsRegistry::PLATFORM_ANDROID,
227 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 247 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
228 248
229 Register(CONTENT_SETTINGS_TYPE_MIDI_SYSEX, "midi-sysex", CONTENT_SETTING_ASK, 249 Register(CONTENT_SETTINGS_TYPE_MIDI_SYSEX, "midi-sysex", CONTENT_SETTING_ASK,
230 WebsiteSettingsInfo::SYNCABLE, WhitelistedSchemes(), 250 WebsiteSettingsInfo::SYNCABLE, WhitelistedSchemes(),
231 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 251 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
232 CONTENT_SETTING_ASK), 252 CONTENT_SETTING_ASK),
233 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 253 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
254 WebsiteSettingsRegistry::DESKTOP |
255 WebsiteSettingsRegistry::PLATFORM_ANDROID,
234 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 256 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
235 257
236 Register(CONTENT_SETTINGS_TYPE_PUSH_MESSAGING, "push-messaging", 258 Register(CONTENT_SETTINGS_TYPE_PUSH_MESSAGING, "push-messaging",
237 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 259 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
238 WhitelistedSchemes(), 260 WhitelistedSchemes(),
239 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 261 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
240 CONTENT_SETTING_ASK), 262 CONTENT_SETTING_ASK),
241 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 263 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
264 WebsiteSettingsRegistry::DESKTOP |
265 WebsiteSettingsRegistry::PLATFORM_ANDROID,
242 ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW); 266 ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW);
243 267
244 #if defined(OS_ANDROID) || defined(OS_CHROMEOS)
245 Register(CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER, 268 Register(CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER,
246 "protected-media-identifier", CONTENT_SETTING_ASK, 269 "protected-media-identifier", CONTENT_SETTING_ASK,
247 WebsiteSettingsInfo::UNSYNCABLE, WhitelistedSchemes(), 270 WebsiteSettingsInfo::UNSYNCABLE, WhitelistedSchemes(),
248 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK, 271 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK,
249 CONTENT_SETTING_ASK), 272 CONTENT_SETTING_ASK),
250 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 273 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
274 WebsiteSettingsRegistry::PLATFORM_ANDROID |
275 WebsiteSettingsRegistry::PLATFORM_CHROMEOS,
251 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 276 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
252 #endif
253 277
254 Register(CONTENT_SETTINGS_TYPE_DURABLE_STORAGE, "durable-storage", 278 Register(CONTENT_SETTINGS_TYPE_DURABLE_STORAGE, "durable-storage",
255 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 279 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
256 WhitelistedSchemes(), 280 WhitelistedSchemes(),
257 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 281 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
258 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 282 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
283 WebsiteSettingsRegistry::DESKTOP |
284 WebsiteSettingsRegistry::PLATFORM_ANDROID,
259 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 285 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
260 286
261 Register(CONTENT_SETTINGS_TYPE_KEYGEN, "keygen", 287 Register(CONTENT_SETTINGS_TYPE_KEYGEN, "keygen", CONTENT_SETTING_BLOCK,
262 CONTENT_SETTING_BLOCK, WebsiteSettingsInfo::SYNCABLE, 288 WebsiteSettingsInfo::SYNCABLE, WhitelistedSchemes(),
263 WhitelistedSchemes(),
264 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 289 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
265 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 290 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
291 WebsiteSettingsRegistry::DESKTOP |
292 WebsiteSettingsRegistry::PLATFORM_ANDROID,
266 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 293 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
267 294
268 Register(CONTENT_SETTINGS_TYPE_BACKGROUND_SYNC, "background-sync", 295 Register(CONTENT_SETTINGS_TYPE_BACKGROUND_SYNC, "background-sync",
269 CONTENT_SETTING_ALLOW, WebsiteSettingsInfo::UNSYNCABLE, 296 CONTENT_SETTING_ALLOW, WebsiteSettingsInfo::UNSYNCABLE,
270 WhitelistedSchemes(), 297 WhitelistedSchemes(),
271 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 298 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
272 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 299 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
300 WebsiteSettingsRegistry::DESKTOP |
301 WebsiteSettingsRegistry::PLATFORM_ANDROID,
273 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 302 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
274 303
275 Register(CONTENT_SETTINGS_TYPE_AUTOPLAY, "autoplay", 304 Register(CONTENT_SETTINGS_TYPE_AUTOPLAY, "autoplay", CONTENT_SETTING_ALLOW,
276 CONTENT_SETTING_ALLOW, WebsiteSettingsInfo::UNSYNCABLE, 305 WebsiteSettingsInfo::UNSYNCABLE, WhitelistedSchemes(),
277 WhitelistedSchemes(),
278 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK), 306 ValidSettings(CONTENT_SETTING_ALLOW, CONTENT_SETTING_BLOCK),
279 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE, 307 WebsiteSettingsInfo::REQUESTING_ORIGIN_ONLY_SCOPE,
308 WebsiteSettingsRegistry::DESKTOP |
309 WebsiteSettingsRegistry::PLATFORM_ANDROID,
280 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 310 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
281 311
282 // Content settings that aren't used to store any data. TODO(raymes): use a 312 // Content settings that aren't used to store any data. TODO(raymes): use a
283 // different mechanism rather than content settings to represent these. 313 // different mechanism rather than content settings to represent these.
284 // Since nothing is stored in them, there is no real point in them being a 314 // Since nothing is stored in them, there is no real point in them being a
285 // content setting. 315 // content setting.
286 Register(CONTENT_SETTINGS_TYPE_PROTOCOL_HANDLERS, "protocol-handler", 316 Register(CONTENT_SETTINGS_TYPE_PROTOCOL_HANDLERS, "protocol-handler",
287 CONTENT_SETTING_DEFAULT, WebsiteSettingsInfo::UNSYNCABLE, 317 CONTENT_SETTING_DEFAULT, WebsiteSettingsInfo::UNSYNCABLE,
288 WhitelistedSchemes(), ValidSettings(), 318 WhitelistedSchemes(), ValidSettings(),
289 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 319 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
320 WebsiteSettingsRegistry::DESKTOP,
290 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 321 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
291 322
292 Register(CONTENT_SETTINGS_TYPE_MIXEDSCRIPT, "mixed-script", 323 Register(CONTENT_SETTINGS_TYPE_MIXEDSCRIPT, "mixed-script",
293 CONTENT_SETTING_DEFAULT, WebsiteSettingsInfo::UNSYNCABLE, 324 CONTENT_SETTING_DEFAULT, WebsiteSettingsInfo::UNSYNCABLE,
294 WhitelistedSchemes(), ValidSettings(), 325 WhitelistedSchemes(), ValidSettings(),
295 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE, 326 WebsiteSettingsInfo::TOP_LEVEL_DOMAIN_ONLY_SCOPE,
327 WebsiteSettingsRegistry::DESKTOP,
296 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 328 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
297 329
298 Register(CONTENT_SETTINGS_TYPE_BLUETOOTH_GUARD, "bluetooth-guard", 330 Register(CONTENT_SETTINGS_TYPE_BLUETOOTH_GUARD, "bluetooth-guard",
299 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE, 331 CONTENT_SETTING_ASK, WebsiteSettingsInfo::UNSYNCABLE,
300 WhitelistedSchemes(), 332 WhitelistedSchemes(),
301 ValidSettings(CONTENT_SETTING_ASK, CONTENT_SETTING_BLOCK), 333 ValidSettings(CONTENT_SETTING_ASK, CONTENT_SETTING_BLOCK),
302 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE, 334 WebsiteSettingsInfo::REQUESTING_ORIGIN_AND_TOP_LEVEL_ORIGIN_SCOPE,
335 WebsiteSettingsRegistry::DESKTOP |
336 WebsiteSettingsRegistry::PLATFORM_ANDROID,
303 ContentSettingsInfo::INHERIT_IN_INCOGNITO); 337 ContentSettingsInfo::INHERIT_IN_INCOGNITO);
304 } 338 }
305 339
306 void ContentSettingsRegistry::Register( 340 void ContentSettingsRegistry::Register(
307 ContentSettingsType type, 341 ContentSettingsType type,
308 const std::string& name, 342 const std::string& name,
309 ContentSetting initial_default_value, 343 ContentSetting initial_default_value,
310 WebsiteSettingsInfo::SyncStatus sync_status, 344 WebsiteSettingsInfo::SyncStatus sync_status,
311 const std::vector<std::string>& whitelisted_schemes, 345 const std::vector<std::string>& whitelisted_schemes,
312 const std::set<ContentSetting>& valid_settings, 346 const std::set<ContentSetting>& valid_settings,
313 WebsiteSettingsInfo::ScopingType scoping_type, 347 WebsiteSettingsInfo::ScopingType scoping_type,
348 Platforms platforms,
314 ContentSettingsInfo::IncognitoBehavior incognito_behavior) { 349 ContentSettingsInfo::IncognitoBehavior incognito_behavior) {
315 // Ensure that nothing has been registered yet for the given type. 350 // Ensure that nothing has been registered yet for the given type.
316 DCHECK(!website_settings_registry_->Get(type)); 351 DCHECK(!website_settings_registry_->Get(type));
317 DCHECK(incognito_behavior 352 DCHECK(incognito_behavior
318 != ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW 353 != ContentSettingsInfo::INHERIT_IN_INCOGNITO_EXCEPT_ALLOW
319 || ContainsKey(valid_settings, CONTENT_SETTING_ASK)) 354 || ContainsKey(valid_settings, CONTENT_SETTING_ASK))
320 << "If INHERIT_IN_INCOGNITO_EXCEPT_ALLOW is set, ASK must be listed as a " 355 << "If INHERIT_IN_INCOGNITO_EXCEPT_ALLOW is set, ASK must be listed as a "
321 "valid setting."; 356 "valid setting.";
322 std::unique_ptr<base::Value> default_value( 357 std::unique_ptr<base::Value> default_value(
323 new base::FundamentalValue(static_cast<int>(initial_default_value))); 358 new base::FundamentalValue(static_cast<int>(initial_default_value)));
324 const WebsiteSettingsInfo* website_settings_info = 359 const WebsiteSettingsInfo* website_settings_info =
325 website_settings_registry_->Register( 360 website_settings_registry_->Register(
326 type, name, std::move(default_value), sync_status, 361 type, name, std::move(default_value), sync_status,
327 WebsiteSettingsInfo::NOT_LOSSY, scoping_type, 362 WebsiteSettingsInfo::NOT_LOSSY, scoping_type, platforms,
328 WebsiteSettingsInfo::INHERIT_IN_INCOGNITO); 363 WebsiteSettingsInfo::INHERIT_IN_INCOGNITO);
364
365 // WebsiteSettingsInfo::Register() will return nullptr if content setting type
366 // is not used on current platform and don't need to be registered.
raymes 2016/05/30 00:35:58 nit: is not used on the current platform and doesn
lshang 2016/05/30 03:22:11 Done.
367 if (!website_settings_info)
368 return;
369
329 DCHECK(!ContainsKey(content_settings_info_, type)); 370 DCHECK(!ContainsKey(content_settings_info_, type));
330 content_settings_info_[type] = base::WrapUnique( 371 content_settings_info_[type] = base::WrapUnique(
331 new ContentSettingsInfo(website_settings_info, whitelisted_schemes, 372 new ContentSettingsInfo(website_settings_info, whitelisted_schemes,
332 valid_settings, incognito_behavior)); 373 valid_settings, incognito_behavior));
333 } 374 }
334 375
335 } // namespace content_settings 376 } // namespace content_settings
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698