blob: 8bf2fecd2f240bb6cfede417f5ac9c0d140dee2a [file] [log] [blame]
miguelg23cd2dd72016-04-21 15:24:031// Copyright 2016 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_DISPLAY_SERVICE_H_
6#define CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_DISPLAY_SERVICE_H_
7
miguelgabf610a2017-06-02 17:31:438#include <map>
miguelgbfe768352017-03-20 15:34:319#include <memory>
miguelg23cd2dd72016-04-21 15:24:0310#include <set>
11#include <string>
miguelg87e986d2016-07-08 18:04:4412
miguelgbfe768352017-03-20 15:34:3113#include "base/callback_forward.h"
miguelg23cd2dd72016-04-21 15:24:0314#include "base/macros.h"
Peter Beverlooae64ba92017-09-08 21:02:4515#include "base/optional.h"
16#include "base/strings/string16.h"
miguelg87e986d2016-07-08 18:04:4417#include "chrome/browser/notifications/notification_common.h"
miguelg23cd2dd72016-04-21 15:24:0318#include "components/keyed_service/core/keyed_service.h"
19
miguelgabf610a2017-06-02 17:31:4320class NotificationHandler;
miguelg23cd2dd72016-04-21 15:24:0321class Profile;
22
Evan Stade4755cf22017-10-17 18:35:4323namespace message_center {
24class Notification;
25}
26
miguelg23cd2dd72016-04-21 15:24:0327// Profile-bound service that enables notifications to be displayed and
28// interacted with on the user's screen, orthogonal of whether this
29// functionality is provided by the browser or by the operating system. An
30// instance can be retrieved through the NotificationDisplayServiceFactory.
31//
32// TODO(peter): Add a NotificationHandler mechanism for registering listeners.
miguelg23cd2dd72016-04-21 15:24:0333class NotificationDisplayService : public KeyedService {
34 public:
miguelgbfe768352017-03-20 15:34:3135 using DisplayedNotificationsCallback =
36 base::Callback<void(std::unique_ptr<std::set<std::string>>,
37 bool /* supports_synchronization */)>;
miguelgabf610a2017-06-02 17:31:4338 explicit NotificationDisplayService(Profile* profile);
39 ~NotificationDisplayService() override;
miguelg23cd2dd72016-04-21 15:24:0340
41 // Displays the |notification| identified by |notification_id|.
Evan Stade4ebefdf42017-09-21 23:50:1842 virtual void Display(
43 NotificationCommon::Type notification_type,
44 const std::string& notification_id,
Evan Stade4755cf22017-10-17 18:35:4345 const message_center::Notification& notification,
Evan Stade4ebefdf42017-09-21 23:50:1846 std::unique_ptr<NotificationCommon::Metadata> metadata = nullptr) = 0;
miguelg23cd2dd72016-04-21 15:24:0347
48 // Closes the notification identified by |notification_id|.
miguelg87e986d2016-07-08 18:04:4449 virtual void Close(NotificationCommon::Type notification_type,
50 const std::string& notification_id) = 0;
miguelg23cd2dd72016-04-21 15:24:0351
miguelgbfe768352017-03-20 15:34:3152 // Writes the ids of all currently displaying notifications and
53 // invokes |callback| with the result once known.
peterb5298ae2017-04-11 21:52:5154 virtual void GetDisplayed(const DisplayedNotificationsCallback& callback) = 0;
miguelg23cd2dd72016-04-21 15:24:0355
miguelgabf610a2017-06-02 17:31:4356 // Used to propagate back events originate from the user (click, close...).
57 // The events are received and dispatched to the right consumer depending on
58 // the type of notification. Consumers include, service workers, pages,
59 // extensions...
60 void ProcessNotificationOperation(NotificationCommon::Operation operation,
61 NotificationCommon::Type notification_type,
62 const std::string& origin,
63 const std::string& notification_id,
Peter Beverlooae64ba92017-09-08 21:02:4564 const base::Optional<int>& action_index,
65 const base::Optional<base::string16>& reply,
66 const base::Optional<bool>& by_user);
miguelgabf610a2017-06-02 17:31:4367
miguelg30dfc2e2017-06-14 18:18:0968 // Return whether a notification of |notification_type| should be displayed
69 // for |origin| when the browser is in full screen mode.
70 bool ShouldDisplayOverFullscreen(const GURL& origin,
71 NotificationCommon::Type notification_type);
72
Evan Stadecc63b182017-09-26 16:05:1273 // Returns the notification handler that was registered for the given type.
74 // May return null.
miguelgabf610a2017-06-02 17:31:4375 NotificationHandler* GetNotificationHandler(
76 NotificationCommon::Type notification_type);
77
miguelgabf610a2017-06-02 17:31:4378 // Registers an implementation object to handle notification operations
79 // for |notification_type|.
80 void AddNotificationHandler(NotificationCommon::Type notification_type,
81 std::unique_ptr<NotificationHandler> handler);
82
Evan Stade0bf465e52017-10-03 18:12:0083 // Removes an implementation object added via AddNotificationHandler.
84 void RemoveNotificationHandler(NotificationCommon::Type notification_type);
85
Evan Stadecc63b182017-09-26 16:05:1286 private:
miguelgabf610a2017-06-02 17:31:4387 std::map<NotificationCommon::Type, std::unique_ptr<NotificationHandler>>
88 notification_handlers_;
89 Profile* profile_;
90
miguelg23cd2dd72016-04-21 15:24:0391 DISALLOW_COPY_AND_ASSIGN(NotificationDisplayService);
92};
93
94#endif // CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_DISPLAY_SERVICE_H_