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

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: fix licenses 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/ref_counted.h" 10 #include "base/memory/ref_counted.h"
11 #include "base/memory/scoped_vector.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 discovered_devices_.clear();
126 }
127
101 DispatchBooleanValueEvent( 128 DispatchBooleanValueEvent(
102 extensions::event_names::kBluetoothOnDiscoveringChanged, 129 extensions::event_names::kBluetoothOnDiscoveringChanged,
103 discovering); 130 discovering);
104 } 131 }
105 132
106 void ExtensionBluetoothEventRouter::DeviceAdded( 133 void ExtensionBluetoothEventRouter::DeviceAdded(
107 chromeos::BluetoothAdapter* adapter, chromeos::BluetoothDevice* device) { 134 chromeos::BluetoothAdapter* adapter, chromeos::BluetoothDevice* device) {
135 if (adapter != adapter_.get()) {
136 DVLOG(1) << "Ignoring event for adapter " << adapter->address();
137 return;
138 }
139
140 experimental_bluetooth::Device* extension_device =
141 new experimental_bluetooth::Device();
142 experimental_bluetooth::BluetoothDeviceToApiDevice(*device, extension_device);
143 discovered_devices_.push_back(extension_device);
144
108 if (!send_discovery_events_) 145 if (!send_discovery_events_)
109 return; 146 return;
110 147
111 DCHECK(adapter == adapter_.get()); 148 DispatchDeviceEvent(*extension_device);
149 }
112 150
113 extensions::api::experimental_bluetooth::Device extension_device; 151 void ExtensionBluetoothEventRouter::DispatchBooleanValueEvent(
114 extensions::api::experimental_bluetooth::BluetoothDeviceToApiDevice( 152 const char* event_name, bool value) {
115 *device, &extension_device); 153 scoped_ptr<ListValue> args(new ListValue());
154 args->Append(Value::CreateBooleanValue(value));
155 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
156 event_name, args.Pass(), NULL, GURL());
157 }
116 158
159 void ExtensionBluetoothEventRouter::DispatchDeviceEvent(
160 const experimental_bluetooth::Device& device) {
117 scoped_ptr<ListValue> args(new ListValue()); 161 scoped_ptr<ListValue> args(new ListValue());
118 args->Append(extension_device.ToValue().release()); 162 args->Append(device.ToValue().release());
119
120 profile_->GetExtensionEventRouter()->DispatchEventToRenderers( 163 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
121 extensions::event_names::kBluetoothOnDeviceDiscovered, 164 extensions::event_names::kBluetoothOnDeviceDiscovered,
122 args.Pass(), 165 args.Pass(),
123 NULL, 166 NULL,
124 GURL()); 167 GURL());
125 } 168 }
126 169
127 void ExtensionBluetoothEventRouter::DispatchBooleanValueEvent(
128 const char* event_name, bool value) {
129 scoped_ptr<ListValue> args(new ListValue());
130 args->Append(Value::CreateBooleanValue(value));
131
132 // TODO(bryeung): only dispatch the event to interested renderers
133 // crbug.com/133179
134 profile_->GetExtensionEventRouter()->DispatchEventToRenderers(
135 event_name, args.Pass(), NULL, GURL());
136 }
137
138 } // namespace chromeos 170 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/extensions/bluetooth_event_router.h ('k') | chrome/browser/extensions/api/bluetooth/bluetooth_api.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698