blob: 70aa1935a231b8a1e28df5ab4d6e2873a1f09ed6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
// Copyright (c) 2009 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_NOTIFICATION_OBJECT_PROXY_H_
#define CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_
#pragma once
#include <string>
#include "chrome/browser/notifications/notification_delegate.h"
class MessageLoop;
namespace IPC {
class Message;
}
// A NotificationObjectProxy stands in for the JavaScript Notification object
// which corresponds to a notification toast on the desktop. It can be signaled
// when various events occur regarding the desktop notification, and the
// attached JS listeners will be invoked in the renderer or worker process.
class NotificationObjectProxy
: public NotificationDelegate {
public:
// Creates a Proxy object with the necessary callback information.
NotificationObjectProxy(int process_id, int route_id,
int notification_id, bool worker);
// NotificationDelegate implementation.
virtual void Display();
virtual void Error();
virtual void Close(bool by_user);
virtual std::string id() const;
protected:
friend class base::RefCountedThreadSafe<NotificationObjectProxy>;
virtual ~NotificationObjectProxy() {}
private:
// Called on UI thread to schedule a message for sending.
void DeliverMessage(IPC::Message* message);
// Called via Task on IO thread to actually send a message to a notification.
void Send(IPC::Message* message);
// Callback information to find the JS Notification object where it lives.
int process_id_;
int route_id_;
int notification_id_;
bool worker_;
};
#endif // CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_
|