// 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_NOTIFICATIONS_DESKTOP_NOTIFICATION_SERVICE_H_ #define CHROME_BROWSER_NOTIFICATIONS_DESKTOP_NOTIFICATION_SERVICE_H_ #pragma once #include <string> #include <vector> #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "base/string16.h" #include "chrome/browser/content_settings/content_settings_notification_provider.h" #include "chrome/browser/content_settings/content_settings_provider.h" #include "chrome/browser/prefs/pref_change_registrar.h" #include "chrome/browser/profiles/profile_keyed_service.h" #include "chrome/common/content_settings.h" #include "content/common/notification_observer.h" #include "content/common/notification_registrar.h" #include "googleurl/src/gurl.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebTextDirection.h" class Notification; class NotificationUIManager; class NotificationsPrefsCache; class PrefService; class Profile; class TabContents; struct DesktopNotificationHostMsg_Show_Params; // The DesktopNotificationService is an object, owned by the Profile, // which provides the creation of desktop "toasts" to web pages and workers. class DesktopNotificationService : public NotificationObserver, public ProfileKeyedService { public: enum DesktopNotificationSource { PageNotification, WorkerNotification }; DesktopNotificationService(Profile* profile, NotificationUIManager* ui_manager); virtual ~DesktopNotificationService(); // Requests permission (using an info-bar) for a given origin. // |callback_context| contains an opaque value to pass back to the // requesting process when the info-bar finishes. A NULL tab can be given if // none exist (i.e. background tab), in which case the currently selected tab // will be used. void RequestPermission(const GURL& origin, int process_id, int route_id, int callback_context, TabContents* tab); // ShowNotification is called on the UI thread handling IPCs from a child // process, identified by |process_id| and |route_id|. |source| indicates // whether the script is in a worker or page. |params| contains all the // other parameters supplied by the worker or page. bool ShowDesktopNotification( const DesktopNotificationHostMsg_Show_Params& params, int process_id, int route_id, DesktopNotificationSource source); // Cancels a notification. If it has already been shown, it will be // removed from the screen. If it hasn't been shown yet, it won't be // shown. bool CancelDesktopNotification(int process_id, int route_id, int notification_id); // Methods to setup and modify permission preferences. void GrantPermission(const GURL& origin); void DenyPermission(const GURL& origin); // NotificationObserver implementation. virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); NotificationsPrefsCache* prefs_cache() { return prefs_cache_; } // Creates a data:xxxx URL which contains the full HTML for a notification // using supplied icon, title, and text, run through a template which contains // the standard formatting for notifications. static string16 CreateDataUrl(const GURL& icon_url, const string16& title, const string16& body, WebKit::WebTextDirection dir); // Creates a data:xxxx URL which contains the full HTML for a notification // using resource template which contains the standard formatting for // notifications. static string16 CreateDataUrl(int resource, const std::vector<std::string>& subst); // The default content setting determines how to handle origins that haven't // been allowed or denied yet. ContentSetting GetDefaultContentSetting(); void SetDefaultContentSetting(ContentSetting setting); bool IsDefaultContentSettingManaged() const; // NOTE: This should only be called on the UI thread. void ResetToDefaultContentSetting(); // Returns all origins that explicitly have been allowed. std::vector<GURL> GetAllowedOrigins(); // Returns all origins that explicitly have been denied. std::vector<GURL> GetBlockedOrigins(); // Removes an origin from the "explicitly allowed" set. void ResetAllowedOrigin(const GURL& origin); // Removes an origin from the "explicitly denied" set. void ResetBlockedOrigin(const GURL& origin); // Clears the sets of explicitly allowed and denied origins. void ResetAllOrigins(); static void RegisterUserPrefs(PrefService* user_prefs); ContentSetting GetContentSetting(const GURL& origin); private: void InitPrefs(); void StartObserving(); void StopObserving(); void OnPrefsChanged(const std::string& pref_name); // Takes a notification object and shows it in the UI. void ShowNotification(const Notification& notification); // Returns a display name for an origin, to be used in permission infobar // or on the frame of the notification toast. Different from the origin // itself when dealing with extensions. string16 DisplayNameForOrigin(const GURL& origin); // Notifies the observers when permissions settings change. void NotifySettingsChange(); // The profile which owns this object. Profile* profile_; // A cache of preferences which is accessible only on the IO thread // to service synchronous IPCs. scoped_refptr<NotificationsPrefsCache> prefs_cache_; // Non-owned pointer to the notification manager which manages the // UI for desktop toasts. NotificationUIManager* ui_manager_; scoped_ptr<content_settings::NotificationProvider> provider_; PrefChangeRegistrar prefs_registrar_; NotificationRegistrar notification_registrar_; DISALLOW_COPY_AND_ASSIGN(DesktopNotificationService); }; #endif // CHROME_BROWSER_NOTIFICATIONS_DESKTOP_NOTIFICATION_SERVICE_H_