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
3 // found in the LICENSE file.
5 // Messages for Web Bluetooth API.
6 // Multiply-included message file, hence no include guard.
8 // Web Bluetooth Security
9 // The security mechanisms of Bluetooth are described in the specification:
10 // https://webbluetoothchrome.github.io/web-bluetooth
14 // From: Security and privacy considerations
15 // http://webbluetoothchrome.github.io/web-bluetooth/#security-and-privacy-considerations
17 // When a website requests access to devices using requestDevice, it gets the
18 // ability to access all GATT services mentioned in the call. The UA must inform
19 // the user what capabilities these services give the website before asking
20 // which devices to entrust to it. If any services in the list aren't known to
21 // the UA, the UA must assume they give the site complete control over the
22 // device and inform the user of this risk. The UA must also allow the user to
23 // inspect what sites have access to what devices and revoke these pairings.
25 // The UA must not allow the user to pair entire classes of devices with a
26 // website. It is possible to construct a class of devices for which each
27 // individual device sends the same Bluetooth-level identifying information. UAs
28 // are not required to attempt to detect this sort of forgery and may let a user
29 // pair this pseudo-device with a website.
31 // To help ensure that only the entity the user approved for access actually has
32 // access, this specification requires that only authenticated environments can
33 // access Bluetooth devices (requestDevice).
36 // From: Per-origin Bluetooth device properties:
38 // For each origin, the UA must maintain an allowed devices map, whose keys are
39 // the Bluetooth devices the origin is allowed to access, and whose values are
40 // pairs of a DOMString device id and an allowed services list consisting of
41 // UUIDs for GATT Primary Services the origin is allowed to access on the
44 // The UA may remove devices from the allowed devices map at any time based on
45 // signals from the user. This needs a definition involving removing
46 // BluetoothDevice instances from device instance maps and clearing out their
47 // [[representedDevice]] fields. For example, if the user chooses not to
48 // remember access, the UA might remove a device when the tab that was granted
49 // access to it is closed. Or the UA might provide a revocation UI that allows
50 // the user to explicitly remove a device even while a tab is actively using
51 // that device. If a device is removed from this list while a Promise is pending
52 // to do something with the device, it must be treated the same as if the device
53 // moved out of Bluetooth range.
56 // From: Device Discovery: requestDevice
57 // http://webbluetoothchrome.github.io/web-bluetooth/#device-discovery
59 // Even if scanResult is empty, display a prompt to the user requesting that the
60 // user select a device from it. The UA should show the user the human-readable
61 // name of each device. If this name is not available because the UA's Bluetooth
62 // system doesn't support privacy-enabled scans, the UA should allow the user to
63 // indicate interest and then perform a privacy-disabled scan to retrieve the
66 // The UA may allow the user to select a nearby device that does not match
69 // Wait for the user to have selected a device or cancelled the prompt.
71 // If the user cancels the prompt, reject promise with a NotFoundError and abort
74 // Add device to the origin's allowed devices map. with the union of the service
75 // UUIDs from filters and options.optionalServices as allowed services.
77 // Get the BluetoothDevice representing device and resolve promise with the
81 #include "ipc/ipc_message_macros.h"
82 #include "content/common/bluetooth/bluetooth_device.h"
83 #include "content/common/bluetooth/bluetooth_scan_filter.h"
84 #include "third_party/WebKit/public/platform/modules/bluetooth/WebBluetoothError.h"
86 #define IPC_MESSAGE_START BluetoothMsgStart
88 IPC_ENUM_TRAITS_MAX_VALUE(
89 device::BluetoothDevice::VendorIDSource
,
90 device::BluetoothDevice::VendorIDSource::VENDOR_ID_MAX_VALUE
)
92 IPC_STRUCT_TRAITS_BEGIN(content::BluetoothDevice
)
93 IPC_STRUCT_TRAITS_MEMBER(instance_id
)
94 IPC_STRUCT_TRAITS_MEMBER(name
)
95 IPC_STRUCT_TRAITS_MEMBER(device_class
)
96 IPC_STRUCT_TRAITS_MEMBER(vendor_id_source
)
97 IPC_STRUCT_TRAITS_MEMBER(vendor_id
)
98 IPC_STRUCT_TRAITS_MEMBER(product_id
)
99 IPC_STRUCT_TRAITS_MEMBER(product_version
)
100 IPC_STRUCT_TRAITS_MEMBER(paired
)
101 IPC_STRUCT_TRAITS_MEMBER(uuids
)
102 IPC_STRUCT_TRAITS_END()
104 IPC_ENUM_TRAITS_MAX_VALUE(blink::WebBluetoothError
,
105 blink::WebBluetoothError::ENUM_MAX_VALUE
)
107 IPC_STRUCT_TRAITS_BEGIN(content::BluetoothScanFilter
)
108 IPC_STRUCT_TRAITS_MEMBER(services
)
109 IPC_STRUCT_TRAITS_END()
111 // Messages sent from the browser to the renderer.
113 // Informs the renderer that the device request |request_id| succeeded.
114 IPC_MESSAGE_CONTROL3(BluetoothMsg_RequestDeviceSuccess
,
116 int /* request_id */,
117 content::BluetoothDevice
/* device */)
119 // Informs the renderer that the device request |request_id| failed.
120 IPC_MESSAGE_CONTROL3(BluetoothMsg_RequestDeviceError
,
122 int /* request_id */,
123 blink::WebBluetoothError
/* result */)
125 // Informs the renderer that the connection request |request_id| succeeded.
126 IPC_MESSAGE_CONTROL3(BluetoothMsg_ConnectGATTSuccess
,
128 int /* request_id */,
129 std::string
/* device_instance_id */)
131 // Informs the renderer that the connection request |request_id| failed.
132 IPC_MESSAGE_CONTROL3(BluetoothMsg_ConnectGATTError
,
134 int /* request_id */,
135 blink::WebBluetoothError
/* result */)
137 // Informs the renderer that primary service request |request_id| succeeded.
138 IPC_MESSAGE_CONTROL3(BluetoothMsg_GetPrimaryServiceSuccess
,
140 int /* request_id */,
141 std::string
/* service_instance_id */)
143 // Informs the renderer that the primary service request |request_id| failed.
144 IPC_MESSAGE_CONTROL3(BluetoothMsg_GetPrimaryServiceError
,
146 int /* request_id */,
147 blink::WebBluetoothError
/* result */)
149 // Informs the renderer that characteristic request |request_id| succeeded.
150 IPC_MESSAGE_CONTROL3(BluetoothMsg_GetCharacteristicSuccess
,
152 int /* request_id */,
153 std::string
/* characteristic_instance_id */)
155 // Informs the renderer that the characteristic request |request_id| failed.
156 IPC_MESSAGE_CONTROL3(BluetoothMsg_GetCharacteristicError
,
158 int /* request_id */,
159 blink::WebBluetoothError
/* result */)
161 // Informs the renderer that the value has been read.
162 IPC_MESSAGE_CONTROL3(BluetoothMsg_ReadCharacteristicValueSuccess
,
164 int /* request_id */,
165 std::vector
<uint8_t> /* value */)
167 // Informs the renderer that an error occurred while reading the value.
168 IPC_MESSAGE_CONTROL3(BluetoothMsg_ReadCharacteristicValueError
,
170 int /* request_id */,
171 blink::WebBluetoothError
/* result */)
173 // Informs the renderer that the value has been successfully written to
174 // the characteristic.
175 IPC_MESSAGE_CONTROL2(BluetoothMsg_WriteCharacteristicValueSuccess
,
177 int /* request_id */)
179 // Informs the renderer that an error occurred while writing a value to a
181 IPC_MESSAGE_CONTROL3(BluetoothMsg_WriteCharacteristicValueError
,
183 int /* request_id */,
184 blink::WebBluetoothError
/* result */)
186 // Messages sent from the renderer to the browser.
188 // Requests a bluetooth device from the browser.
189 // TODO(scheib): UI to select and permit access to a device crbug.com/436280.
190 // This will include refactoring messages to be associated with an origin
191 // and making this initial requestDevice call with an associated frame.
192 // This work is deferred to simplify initial prototype patches.
193 // The Bluetooth feature, and the BluetoothDispatcherHost are behind
194 // the --enable-experimental-web-platform-features flag.
195 IPC_MESSAGE_CONTROL4(BluetoothHostMsg_RequestDevice
,
197 int /* request_id */,
198 std::vector
<content::BluetoothScanFilter
>,
199 std::vector
<device::BluetoothUUID
> /* optional_services */)
201 // Connects to a bluetooth device.
202 IPC_MESSAGE_CONTROL3(BluetoothHostMsg_ConnectGATT
,
204 int /* request_id */,
205 std::string
/* device_instance_id */)
207 // Gets primary service from bluetooth device.
208 IPC_MESSAGE_CONTROL4(BluetoothHostMsg_GetPrimaryService
,
210 int /* request_id */,
211 std::string
/* device_instance_id */,
212 std::string
/* service_uuid */)
214 // Gets a GATT Characteristic within a GATT Service.
215 IPC_MESSAGE_CONTROL4(BluetoothHostMsg_GetCharacteristic
,
217 int /* request_id */,
218 std::string
/* service_instance_id */,
219 std::string
/* characteristic_uuid */)
221 // Reads the characteristics value from a bluetooth device.
222 IPC_MESSAGE_CONTROL3(BluetoothHostMsg_ReadValue
,
224 int /* request_id */,
225 std::string
/* characteristic_instance_id */)
227 // Writes a value to a bluetooth device's characteristic.
228 IPC_MESSAGE_CONTROL4(BluetoothHostMsg_WriteValue
,
230 int /* request_id */,
231 std::string
/* characteristic_instance_id */,
232 std::vector
<uint8_t> /* value */)