// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_CONTENT_SETTINGS_CONTENT_SETTINGS_PREF_PROVIDER_H_
#define CHROME_BROWSER_CONTENT_SETTINGS_CONTENT_SETTINGS_PREF_PROVIDER_H_
#pragma once
// A content settings provider that takes its settings out of the pref service.
#include <map>
#include <string>
#include <utility>
#include "base/basictypes.h"
#include "base/synchronization/lock.h"
#include "chrome/browser/content_settings/content_settings_base_provider.h"
#include "chrome/browser/content_settings/content_settings_provider.h"
#include "chrome/browser/prefs/pref_change_registrar.h"
#include "content/common/notification_observer.h"
#include "content/common/notification_registrar.h"
class ContentSettingsDetails;
class DictionaryValue;
class PrefService;
class Profile;
namespace content_settings {
// Content settings provider that provides default content settings based on
// user prefs.
class PrefDefaultProvider : public DefaultProviderInterface,
public NotificationObserver {
public:
explicit PrefDefaultProvider(Profile* profile);
virtual ~PrefDefaultProvider();
// DefaultContentSettingsProvider implementation.
virtual ContentSetting ProvideDefaultSetting(
ContentSettingsType content_type) const;
virtual void UpdateDefaultSetting(ContentSettingsType content_type,
ContentSetting setting);
virtual void ResetToDefaults();
virtual bool DefaultSettingIsManaged(ContentSettingsType content_type) const;
static void RegisterUserPrefs(PrefService* prefs);
// NotificationObserver implementation.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
private:
// Informs observers that content settings have changed. Make sure that
// |lock_| is not held when calling this, as listeners will usually call one
// of the GetSettings functions in response, which would then lead to a
// mutex deadlock.
void NotifyObservers(const ContentSettingsDetails& details);
void UnregisterObservers();
// Sets the fields of |settings| based on the values in |dictionary|.
void GetSettingsFromDictionary(const DictionaryValue* dictionary,
ContentSettings* settings);
// Forces the default settings to be explicitly set instead of themselves
// being CONTENT_SETTING_DEFAULT.
void ForceDefaultsToBeExplicit();
// Reads the default settings from the preferences service. If |overwrite| is
// true and the preference is missing, the local copy will be cleared as well.
void ReadDefaultSettings(bool overwrite);
void MigrateObsoleteNotificationPref(PrefService* prefs);
// Copies of the pref data, so that we can read it on the IO thread.
ContentSettings default_content_settings_;
Profile* profile_;
// Whether this settings map is for an Incognito session.
bool is_incognito_;
// Used around accesses to the default_content_settings_ object to guarantee
// thread safety.
mutable base::Lock lock_;
PrefChangeRegistrar pref_change_registrar_;
NotificationRegistrar notification_registrar_;
// Whether we are currently updating preferences, this is used to ignore
// notifications from the preferences service that we triggered ourself.
bool updating_preferences_;
bool initializing_;
DISALLOW_COPY_AND_ASSIGN(PrefDefaultProvider);
};
// Content settings provider that provides content settings from the user
// preference.
class PrefProvider : public BaseProvider,
public NotificationObserver {
public:
static void RegisterUserPrefs(PrefService* prefs);
explicit PrefProvider(Profile* profile);
virtual ~PrefProvider();
// ContentSettingsProvider implementation.
virtual bool ContentSettingsTypeIsManaged(
ContentSettingsType content_type);
virtual void SetContentSetting(
const ContentSettingsPattern& requesting_pattern,
const ContentSettingsPattern& embedding_pattern,
ContentSettingsType content_type,
const ResourceIdentifier& resource_identifier,
ContentSetting content_setting);
virtual void ClearAllContentSettingsRules(
ContentSettingsType content_type);
virtual void ResetToDefaults();
// BaseProvider implementations.
virtual void Init();
// NotificationObserver implementation.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
private:
void ReadExceptions(bool overwrite);
// Various migration methods (old cookie, popup and per-host data gets
// migrated to the new format).
void MigrateObsoletePerhostPref(PrefService* prefs);
void MigrateObsoletePopupsPref(PrefService* prefs);
void CanonicalizeContentSettingsExceptions(
DictionaryValue* all_settings_dictionary);
void GetSettingsFromDictionary(
const DictionaryValue* dictionary,
ContentSettings* settings);
void GetResourceSettingsFromDictionary(
const DictionaryValue* dictionary,
ResourceContentSettings* settings);
void NotifyObservers(const ContentSettingsDetails& details);
void UnregisterObservers();
Profile* profile_;
PrefChangeRegistrar pref_change_registrar_;
NotificationRegistrar notification_registrar_;
// Whether we are currently updating preferences, this is used to ignore
// notifications from the preferences service that we triggered ourself.
bool updating_preferences_;
// Do not fire any Notifications as long as we are in the constructor.
bool initializing_;
DISALLOW_COPY_AND_ASSIGN(PrefProvider);
};
} // namespace content_settings
#endif // CHROME_BROWSER_CONTENT_SETTINGS_CONTENT_SETTINGS_PREF_PROVIDER_H_