// 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_