| // Copyright 2013 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 DEVICE_BLUETOOTH_BLUETOOTH_DEVICE_CHROMEOS_H |
| #define DEVICE_BLUETOOTH_BLUETOOTH_DEVICE_CHROMEOS_H |
| |
| #include <string> |
| |
| #include "base/memory/ref_counted.h" |
| #include "base/memory/scoped_ptr.h" |
| #include "base/memory/weak_ptr.h" |
| #include "base/observer_list.h" |
| #include "base/sequenced_task_runner.h" |
| #include "chromeos/dbus/bluetooth_device_client.h" |
| #include "chromeos/dbus/bluetooth_gatt_service_client.h" |
| #include "dbus/object_path.h" |
| #include "device/bluetooth/bluetooth_device.h" |
| |
| namespace device { |
| class BluetoothSocketThread; |
| } // namespace device |
| |
| namespace chromeos { |
| |
| class BluetoothAdapterChromeOS; |
| class BluetoothPairingChromeOS; |
| |
| // The BluetoothDeviceChromeOS class implements BluetoothDevice for the |
| // Chrome OS platform. |
| class BluetoothDeviceChromeOS |
| : public device::BluetoothDevice, |
| public BluetoothGattServiceClient::Observer { |
| public: |
| // BluetoothDevice override |
| virtual void AddObserver( |
| device::BluetoothDevice::Observer* observer) OVERRIDE; |
| virtual void RemoveObserver( |
| device::BluetoothDevice::Observer* observer) OVERRIDE; |
| virtual uint32 GetBluetoothClass() const OVERRIDE; |
| virtual std::string GetAddress() const OVERRIDE; |
| virtual VendorIDSource GetVendorIDSource() const OVERRIDE; |
| virtual uint16 GetVendorID() const OVERRIDE; |
| virtual uint16 GetProductID() const OVERRIDE; |
| virtual uint16 GetDeviceID() const OVERRIDE; |
| virtual int GetRSSI() const OVERRIDE; |
| virtual int GetCurrentHostTransmitPower() const OVERRIDE; |
| virtual int GetMaximumHostTransmitPower() const OVERRIDE; |
| virtual bool IsPaired() const OVERRIDE; |
| virtual bool IsConnected() const OVERRIDE; |
| virtual bool IsConnectable() const OVERRIDE; |
| virtual bool IsConnecting() const OVERRIDE; |
| virtual UUIDList GetUUIDs() const OVERRIDE; |
| virtual bool ExpectingPinCode() const OVERRIDE; |
| virtual bool ExpectingPasskey() const OVERRIDE; |
| virtual bool ExpectingConfirmation() const OVERRIDE; |
| virtual void Connect( |
| device::BluetoothDevice::PairingDelegate* pairing_delegate, |
| const base::Closure& callback, |
| const ConnectErrorCallback& error_callback) OVERRIDE; |
| virtual void SetPinCode(const std::string& pincode) OVERRIDE; |
| virtual void SetPasskey(uint32 passkey) OVERRIDE; |
| virtual void ConfirmPairing() OVERRIDE; |
| virtual void RejectPairing() OVERRIDE; |
| virtual void CancelPairing() OVERRIDE; |
| virtual void Disconnect( |
| const base::Closure& callback, |
| const ErrorCallback& error_callback) OVERRIDE; |
| virtual void Forget(const ErrorCallback& error_callback) OVERRIDE; |
| virtual void ConnectToProfile( |
| device::BluetoothProfile* profile, |
| const base::Closure& callback, |
| const ConnectToProfileErrorCallback& error_callback) OVERRIDE; |
| virtual void ConnectToService( |
| const device::BluetoothUUID& uuid, |
| const ConnectToServiceCallback& callback, |
| const ConnectToServiceErrorCallback& error_callback) OVERRIDE; |
| virtual void SetOutOfBandPairingData( |
| const device::BluetoothOutOfBandPairingData& data, |
| const base::Closure& callback, |
| const ErrorCallback& error_callback) OVERRIDE; |
| virtual void ClearOutOfBandPairingData( |
| const base::Closure& callback, |
| const ErrorCallback& error_callback) OVERRIDE; |
| |
| // Creates a pairing object with the given delegate |pairing_delegate| and |
| // establishes it as the pairing context for this device. All pairing-related |
| // method calls will be forwarded to this object until it is released. |
| BluetoothPairingChromeOS* BeginPairing( |
| BluetoothDevice::PairingDelegate* pairing_delegate); |
| |
| // Releases the current pairing object, any pairing-related method calls will |
| // be ignored. |
| void EndPairing(); |
| |
| // Returns the current pairing object or NULL if no pairing is in progress. |
| BluetoothPairingChromeOS* GetPairing() const; |
| |
| protected: |
| // BluetoothDevice override |
| virtual std::string GetDeviceName() const OVERRIDE; |
| |
| private: |
| friend class BluetoothAdapterChromeOS; |
| |
| BluetoothDeviceChromeOS( |
| BluetoothAdapterChromeOS* adapter, |
| const dbus::ObjectPath& object_path, |
| scoped_refptr<base::SequencedTaskRunner> ui_task_runner, |
| scoped_refptr<device::BluetoothSocketThread> socket_thread); |
| virtual ~BluetoothDeviceChromeOS(); |
| |
| // BluetoothGattServiceClient::Observer overrides. |
| virtual void GattServiceAdded(const dbus::ObjectPath& object_path) OVERRIDE; |
| virtual void GattServiceRemoved(const dbus::ObjectPath& object_path) OVERRIDE; |
| |
| // Internal method to initiate a connection to this device, and methods called |
| // by dbus:: on completion of the D-Bus method call. |
| void ConnectInternal(bool after_pairing, |
| const base::Closure& callback, |
| const ConnectErrorCallback& error_callback); |
| void OnConnect(bool after_pairing, |
| const base::Closure& callback); |
| void OnConnectError(bool after_pairing, |
| const ConnectErrorCallback& error_callback, |
| const std::string& error_name, |
| const std::string& error_message); |
| |
| // Called by dbus:: on completion of the D-Bus method call to pair the device. |
| void OnPair(const base::Closure& callback, |
| const ConnectErrorCallback& error_callback); |
| void OnPairError(const ConnectErrorCallback& error_callback, |
| const std::string& error_name, |
| const std::string& error_message); |
| |
| // Called by dbus:: on failure of the D-Bus method call to cancel pairing, |
| // there is no matching completion call since we don't do anything special |
| // in that case. |
| void OnCancelPairingError(const std::string& error_name, |
| const std::string& error_message); |
| |
| // Internal method to set the device as trusted. Trusted devices can connect |
| // to us automatically, and we can connect to them after rebooting; it also |
| // causes the device to be remembered by the stack even if not paired. |
| // |success| to the callback indicates whether or not the request succeeded. |
| void SetTrusted(); |
| void OnSetTrusted(bool success); |
| |
| // Called by dbus:: on completion of the D-Bus method call to disconnect the |
| // device. |
| void OnDisconnect(const base::Closure& callback); |
| void OnDisconnectError(const ErrorCallback& error_callback, |
| const std::string& error_name, |
| const std::string& error_message); |
| |
| // Called by dbus:: on failure of the D-Bus method call to unpair the device; |
| // there is no matching completion call since this object is deleted in the |
| // process of unpairing. |
| void OnForgetError(const ErrorCallback& error_callback, |
| const std::string& error_name, |
| const std::string& error_message); |
| |
| // Called by dbus:: on completion of the D-Bus method call to |
| // connect a peofile. |
| void OnConnectProfile(device::BluetoothProfile* profile, |
| const base::Closure& callback); |
| void OnConnectProfileError( |
| device::BluetoothProfile* profile, |
| const ConnectToProfileErrorCallback& error_callback, |
| const std::string& error_name, |
| const std::string& error_message); |
| |
| // Returns the object path of the device; used by BluetoothAdapterChromeOS |
| const dbus::ObjectPath& object_path() const { return object_path_; } |
| |
| // The adapter that owns this device instance. |
| BluetoothAdapterChromeOS* adapter_; |
| |
| // The dbus object path of the device object. |
| dbus::ObjectPath object_path_; |
| |
| // List of observers interested in event notifications from us. |
| ObserverList<device::BluetoothDevice::Observer> observers_; |
| |
| // Number of ongoing calls to Connect(). |
| int num_connecting_calls_; |
| |
| // UI thread task runner and socket thread object used to create sockets. |
| scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; |
| scoped_refptr<device::BluetoothSocketThread> socket_thread_; |
| |
| // During pairing this is set to an object that we don't own, but on which |
| // we can make method calls to request, display or confirm PIN Codes and |
| // Passkeys. Generally it is the object that owns this one. |
| scoped_ptr<BluetoothPairingChromeOS> pairing_; |
| |
| // Note: This should remain the last member so it'll be destroyed and |
| // invalidate its weak pointers before any other members are destroyed. |
| base::WeakPtrFactory<BluetoothDeviceChromeOS> weak_ptr_factory_; |
| |
| DISALLOW_COPY_AND_ASSIGN(BluetoothDeviceChromeOS); |
| }; |
| |
| } // namespace chromeos |
| |
| #endif // DEVICE_BLUETOOTH_BLUETOOTH_DEVICE_CHROMEOS_H |