Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(154)

Side by Side Diff: chrome/browser/chromeos/extensions/bluetooth_event_router.cc

Issue 10815072: Bluetooth API: improve discovery (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review comments Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/chromeos/extensions/bluetooth_event_router.h" 5 #include "chrome/browser/chromeos/extensions/bluetooth_event_router.h"
6 6
7 #include <map> 7 #include <map>
8 8
9 #include "base/json/json_writer.h" 9 #include "base/json/json_writer.h"
10 #include "base/memory/linked_ptr.h"
10 #include "base/memory/ref_counted.h" 11 #include "base/memory/ref_counted.h"
11 #include "base/utf_string_conversions.h" 12 #include "base/utf_string_conversions.h"
12 #include "chrome/browser/chromeos/bluetooth/bluetooth_adapter.h" 13 #include "chrome/browser/chromeos/bluetooth/bluetooth_adapter.h"
13 #include "chrome/browser/chromeos/bluetooth/bluetooth_device.h" 14 #include "chrome/browser/chromeos/bluetooth/bluetooth_device.h"
14 #include "chrome/browser/chromeos/bluetooth/bluetooth_socket.h" 15 #include "chrome/browser/chromeos/bluetooth/bluetooth_socket.h"
15 #include "chrome/browser/extensions/api/bluetooth/bluetooth_api_utils.h" 16 #include "chrome/browser/extensions/api/bluetooth/bluetooth_api_utils.h"
16 #include "chrome/browser/extensions/event_names.h" 17 #include "chrome/browser/extensions/event_names.h"
17 #include "chrome/browser/extensions/event_router.h" 18 #include "chrome/browser/extensions/event_router.h"
18 #include "chrome/common/extensions/api/experimental_bluetooth.h" 19 #include "chrome/common/extensions/api/experimental_bluetooth.h"
19 20
21 namespace experimental_bluetooth = extensions::api::experimental_bluetooth;
22
20 namespace chromeos { 23 namespace chromeos {
21 24
22 ExtensionBluetoothEventRouter::ExtensionBluetoothEventRouter(Profile* profile) 25 ExtensionBluetoothEventRouter::ExtensionBluetoothEventRouter(Profile* profile)
23 : profile_(profile), 26 : profile_(profile),
24 adapter_(chromeos::BluetoothAdapter::DefaultAdapter()), 27 adapter_(chromeos::BluetoothAdapter::DefaultAdapter()),
25 next_socket_id_(1) { 28 next_socket_id_(1) {
26 DCHECK(profile_); 29 DCHECK(profile_);
27 DCHECK(adapter_.get()); 30 DCHECK(adapter_.get());
28 adapter_->AddObserver(this); 31 adapter_->AddObserver(this);
29 } 32 }
(...skipping 26 matching lines...) Expand all
56 } 59 }
57 60
58 scoped_refptr<BluetoothSocket> ExtensionBluetoothEventRouter::GetSocket( 61 scoped_refptr<BluetoothSocket> ExtensionBluetoothEventRouter::GetSocket(
59 int id) { 62 int id) {
60 SocketMap::iterator socket_entry = socket_map_.find(id); 63 SocketMap::iterator socket_entry = socket_map_.find(id);
61 if (socket_entry == socket_map_.end()) 64 if (socket_entry == socket_map_.end())
62 return NULL; 65 return NULL;
63 return socket_entry->second; 66 return socket_entry->second;
64 } 67 }
65 68
69 void ExtensionBluetoothEventRouter::SetResponsibleForDiscovery(
70 bool responsible) {
71 responsible_for_discovery_ = responsible;
72 }
73
74 bool ExtensionBluetoothEventRouter::IsResponsibleForDiscovery() const {
75 return responsible_for_discovery_;
76 }
77
66 void ExtensionBluetoothEventRouter::SetSendDiscoveryEvents(bool should_send) { 78 void ExtensionBluetoothEventRouter::SetSendDiscoveryEvents(bool should_send) {
79 // At the transition into sending devices, also send past devices that
80 // were discovered as they will not be discovered again.
81 if (should_send && !send_discovery_events_) {
82 for (DeviceList::const_iterator i = discovered_devices_.begin();
83 i != discovered_devices_.end(); ++i) {
84 DispatchDeviceEvent(**i);
85 }
86 }
87
67 send_discovery_events_ = should_send; 88 send_discovery_events_ = should_send;
68 } 89 }
69 90
70 void ExtensionBluetoothEventRouter::AdapterPresentChanged( 91 void ExtensionBluetoothEventRouter::AdapterPresentChanged(
71 chromeos::BluetoothAdapter* adapter, bool present) { 92 chromeos::BluetoothAdapter* adapter, bool present) {
72 if (adapter != adapter_.get()) { 93 if (adapter != adapter_.get()) {
73 DVLOG(1) << "Ignoring event for adapter " << adapter->address(); 94 DVLOG(1) << "Ignoring event for adapter " << adapter->address();
74 return; 95 return;
75 } 96 }
76 97
(...skipping 14 matching lines...) Expand all
91 has_power); 112 has_power);
92 } 113 }
93 114
94 void ExtensionBluetoothEventRouter::AdapterDiscoveringChanged( 115 void ExtensionBluetoothEventRouter::AdapterDiscoveringChanged(
95 chromeos::BluetoothAdapter* adapter, bool discovering) { 116 chromeos::BluetoothAdapter* adapter, bool discovering) {
96 if (adapter != adapter_.get()) { 117 if (adapter != adapter_.get()) {
97 DVLOG(1) << "Ignoring event for adapter " << adapter->address(); 118 DVLOG(1) << "Ignoring event for adapter " << adapter->address();
98 return; 119 return;
99 } 120 }
100 121
122 if (!discovering) {
123 send_discovery_events_ = false;
124 responsible_for_discovery_ = false;
125
126 STLClearObject(&discovered_devices_);
127 }
128
101 DispatchBooleanValueEvent( 129 DispatchBooleanValueEvent(
102 extensions::event_names::kBluetoothOnDiscoveringChanged, 130 extensions::event_names::kBluetoothOnDiscoveringChanged,
103 discovering); 131 discovering);
104 } 132 }
105 133
106 void ExtensionBluetoothEventRouter::DeviceAdded( 134 void ExtensionBluetoothEventRouter::DeviceAdded(
107 chromeos::BluetoothAdapter* adapter, chromeos::BluetoothDevice* device) { 135 chromeos::BluetoothAdapter* adapter, chromeos::BluetoothDevice* device) {
136 if (adapter != adapter_.get()) {
137 DVLOG(1) << "Ignoring event for adapter " << adapter->address();
138 return;
139 }
140
141 experimental_bluetooth::Device* extension_device =
142 new experimental_bluetooth::Device();
143 experimental_bluetooth::BluetoothDeviceToApiDevice(*device, extension_device);
144 discovered_devices_.push_back(make_linked_ptr(extension_device));
145
108 if (!send_discovery_events_) 146 if (!send_discovery_events_)
109 return; 147 return;
110 148
111 DCHECK(adapter == adapter_.get()); 149 DispatchDeviceEvent(*extension_device);
150 }
112 151
113 extensions::api::experimental_bluetooth::Device extension_device; 152 void ExtensionBluetoothEventRouter::DispatchBooleanValueEvent(
114 extensions::api::experimental_bluetooth::BluetoothDeviceToApiDevice( 153 const char* event_name, bool value) {
115 *device, &extension_device); 154 ListValue args;
155 args.Append(Value::CreateBooleanValue(value));
156 std::string json_args;
157 base::JSONWriter::Write(&args, &json_args);
116 158
159 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
160 event_name, json_args, NULL, GURL());
161 }
162
163 void ExtensionBluetoothEventRouter::DispatchDeviceEvent(
164 const experimental_bluetooth::Device& device) {
asargent_no_longer_on_chrome 2012/08/03 23:35:23 Can you call HasEventListener on the extension eve
bryeung 2012/08/07 14:22:12 I'd prefer to leave it out, if you don't mind. Th
asargent_no_longer_on_chrome 2012/08/07 15:32:48 Ok, no problem.
117 ListValue args; 165 ListValue args;
118 args.Append(extension_device.ToValue().release()); 166 args.Append(device.ToValue().release());
119 std::string json_args; 167 std::string json_args;
120 base::JSONWriter::Write(&args, &json_args); 168 base::JSONWriter::Write(&args, &json_args);
121 169
122 profile_->GetExtensionEventRouter()->DispatchEventToRenderers( 170 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
123 extensions::event_names::kBluetoothOnDeviceDiscovered, 171 extensions::event_names::kBluetoothOnDeviceDiscovered,
124 json_args, 172 json_args,
125 NULL, 173 NULL,
126 GURL()); 174 GURL());
127 } 175 }
128 176
129 void ExtensionBluetoothEventRouter::DispatchBooleanValueEvent(
130 const char* event_name, bool value) {
131 ListValue args;
132 args.Append(Value::CreateBooleanValue(value));
133 std::string json_args;
134 base::JSONWriter::Write(&args, &json_args);
135
136 // TODO(bryeung): only dispatch the event to interested renderers
137 // crbug.com/133179
138 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
139 event_name, json_args, NULL, GURL());
140 }
141
142 } // namespace chromeos 177 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698