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

Side by Side Diff: chrome/browser/extensions/api/hid/hid_device_manager.cc

Issue 419713002: Support permission_broker for chrome.hid devices. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add NOTIMPLEMENTED to default GetHidService implementation. Created 6 years, 5 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
« no previous file with comments | « chrome/browser/extensions/api/hid/hid_api.cc ('k') | device/hid/hid_connection_linux.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/extensions/api/hid/hid_device_manager.h" 5 #include "chrome/browser/extensions/api/hid/hid_device_manager.h"
6
Reilly Grant (use Gerrit) 2014/07/25 19:57:09 Leave this whitespace.
7 #include <limits> 6 #include <limits>
8 #include <vector> 7 #include <vector>
9 8
10 #include "base/lazy_instance.h" 9 #include "base/lazy_instance.h"
11 #include "device/hid/hid_service.h" 10 #include "device/hid/hid_service.h"
11 #include "extensions/browser/api/extensions_api_client.h"
12 12
13 using device::HidService; 13 using device::HidService;
14 using device::HidUsageAndPage; 14 using device::HidUsageAndPage;
15 15
16 namespace extensions { 16 namespace extensions {
17 17
18 HidDeviceManager::HidDeviceManager(content::BrowserContext* context) 18 HidDeviceManager::HidDeviceManager(content::BrowserContext* context)
19 : next_resource_id_(0) {} 19 : next_resource_id_(0) {}
20 20
21 HidDeviceManager::~HidDeviceManager() {} 21 HidDeviceManager::~HidDeviceManager() {}
22 22
23 // static 23 // static
24 BrowserContextKeyedAPIFactory<HidDeviceManager>* 24 BrowserContextKeyedAPIFactory<HidDeviceManager>*
25 HidDeviceManager::GetFactoryInstance() { 25 HidDeviceManager::GetFactoryInstance() {
26 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> > 26 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> >
27 factory = LAZY_INSTANCE_INITIALIZER; 27 factory = LAZY_INSTANCE_INITIALIZER;
28 return &factory.Get(); 28 return &factory.Get();
29 } 29 }
30 30
31 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices( 31 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices(
32 uint16_t vendor_id, 32 uint16_t vendor_id,
33 uint16_t product_id) { 33 uint16_t product_id) {
34 UpdateDevices(); 34 UpdateDevices();
35 35
36 HidService* hid_service = HidService::GetInstance(); 36 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
37 DCHECK(hid_service); 37 DCHECK(hid_service);
38 base::ListValue* api_devices = new base::ListValue(); 38 base::ListValue* api_devices = new base::ListValue();
39 for (ResourceIdToDeviceIdMap::const_iterator device_iter = 39 for (ResourceIdToDeviceIdMap::const_iterator device_iter =
40 device_ids_.begin(); 40 device_ids_.begin();
41 device_iter != device_ids_.end(); 41 device_iter != device_ids_.end();
42 ++device_iter) { 42 ++device_iter) {
43 int resource_id = device_iter->first; 43 int resource_id = device_iter->first;
44 device::HidDeviceId device_id = device_iter->second; 44 device::HidDeviceId device_id = device_iter->second;
45 device::HidDeviceInfo device_info; 45 device::HidDeviceInfo device_info;
46 46
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 } 89 }
90 } 90 }
91 } 91 }
92 92
93 return scoped_ptr<base::ListValue>(api_devices); 93 return scoped_ptr<base::ListValue>(api_devices);
94 } 94 }
95 95
96 bool HidDeviceManager::GetDeviceInfo(int resource_id, 96 bool HidDeviceManager::GetDeviceInfo(int resource_id,
97 device::HidDeviceInfo* device_info) { 97 device::HidDeviceInfo* device_info) {
98 UpdateDevices(); 98 UpdateDevices();
99 HidService* hid_service = HidService::GetInstance(); 99 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
100 DCHECK(hid_service); 100 DCHECK(hid_service);
101 101
102 ResourceIdToDeviceIdMap::const_iterator device_iter = 102 ResourceIdToDeviceIdMap::const_iterator device_iter =
103 device_ids_.find(resource_id); 103 device_ids_.find(resource_id);
104 if (device_iter == device_ids_.end()) 104 if (device_iter == device_ids_.end())
105 return false; 105 return false;
106 106
107 return hid_service->GetDeviceInfo(device_iter->second, device_info); 107 return hid_service->GetDeviceInfo(device_iter->second, device_info);
108 } 108 }
109 109
110 void HidDeviceManager::UpdateDevices() { 110 void HidDeviceManager::UpdateDevices() {
111 thread_checker_.CalledOnValidThread(); 111 thread_checker_.CalledOnValidThread();
112 HidService* hid_service = HidService::GetInstance(); 112 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
113 DCHECK(hid_service); 113 DCHECK(hid_service);
114 114
115 std::vector<device::HidDeviceInfo> devices; 115 std::vector<device::HidDeviceInfo> devices;
116 hid_service->GetDevices(&devices); 116 hid_service->GetDevices(&devices);
117 117
118 // Build an updated bidi mapping between resource ID and underlying device ID. 118 // Build an updated bidi mapping between resource ID and underlying device ID.
119 DeviceIdToResourceIdMap new_resource_ids; 119 DeviceIdToResourceIdMap new_resource_ids;
120 ResourceIdToDeviceIdMap new_device_ids; 120 ResourceIdToDeviceIdMap new_device_ids;
121 for (std::vector<device::HidDeviceInfo>::const_iterator iter = 121 for (std::vector<device::HidDeviceInfo>::const_iterator iter =
122 devices.begin(); 122 devices.begin();
(...skipping 10 matching lines...) Expand all
133 new_id = next_resource_id_++; 133 new_id = next_resource_id_++;
134 } 134 }
135 new_resource_ids[device_info.device_id] = new_id; 135 new_resource_ids[device_info.device_id] = new_id;
136 new_device_ids[new_id] = device_info.device_id; 136 new_device_ids[new_id] = device_info.device_id;
137 } 137 }
138 device_ids_.swap(new_device_ids); 138 device_ids_.swap(new_device_ids);
139 resource_ids_.swap(new_resource_ids); 139 resource_ids_.swap(new_resource_ids);
140 } 140 }
141 141
142 } // namespace extensions 142 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/browser/extensions/api/hid/hid_api.cc ('k') | device/hid/hid_connection_linux.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698