diff -r 000000000000 -r 6474c204b198 dom/bluetooth/BluetoothAdapter.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dom/bluetooth/BluetoothAdapter.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,196 @@ +/* -*- Mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; tab-width: 40 -*- */ +/* vim: set ts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this file, + * You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef mozilla_dom_bluetooth_bluetoothadapter_h__ +#define mozilla_dom_bluetooth_bluetoothadapter_h__ + +#include "mozilla/Attributes.h" +#include "mozilla/DOMEventTargetHelper.h" +#include "BluetoothCommon.h" +#include "BluetoothPropertyContainer.h" +#include "nsCOMPtr.h" + +namespace mozilla { +namespace dom { +class DOMRequest; +struct MediaMetaData; +struct MediaPlayStatus; +} +} + +BEGIN_BLUETOOTH_NAMESPACE + +class BluetoothDevice; +class BluetoothSignal; +class BluetoothNamedValue; +class BluetoothValue; + +class BluetoothAdapter : public DOMEventTargetHelper + , public BluetoothSignalObserver + , public BluetoothPropertyContainer +{ +public: + NS_DECL_ISUPPORTS_INHERITED + + NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS_INHERITED(BluetoothAdapter, + DOMEventTargetHelper) + + static already_AddRefed + Create(nsPIDOMWindow* aOwner, const BluetoothValue& aValue); + + void Notify(const BluetoothSignal& aParam); + + void Unroot(); + virtual void SetPropertyByValue(const BluetoothNamedValue& aValue) MOZ_OVERRIDE; + + virtual void DisconnectFromOwner() MOZ_OVERRIDE; + + void GetAddress(nsString& aAddress) const + { + aAddress = mAddress; + } + + uint32_t + Class() const + { + return mClass; + } + + void + GetName(nsString& aName) const + { + aName = mName; + } + + bool + Discovering() const + { + return mDiscovering; + } + + bool + Discoverable() const + { + return mDiscoverable; + } + + uint32_t + DiscoverableTimeout() const + { + return mDiscoverableTimeout; + } + + void GetDevices(JSContext* aContext, JS::MutableHandle aDevices, + ErrorResult& aRv); + void GetUuids(JSContext* aContext, JS::MutableHandle aUuids, + ErrorResult& aRv); + + already_AddRefed + SetName(const nsAString& aName, ErrorResult& aRv); + + already_AddRefed + SetDiscoverable(bool aDiscoverable, ErrorResult& aRv); + already_AddRefed + SetDiscoverableTimeout(uint32_t aTimeout, ErrorResult& aRv); + already_AddRefed StartDiscovery(ErrorResult& aRv); + already_AddRefed StopDiscovery(ErrorResult& aRv); + + already_AddRefed + Pair(const nsAString& aDeviceAddress, ErrorResult& aRv); + already_AddRefed + Unpair(const nsAString& aDeviceAddress, ErrorResult& aRv); + already_AddRefed + GetPairedDevices(ErrorResult& aRv); + already_AddRefed + SetPinCode(const nsAString& aDeviceAddress, const nsAString& aPinCode, + ErrorResult& aRv); + already_AddRefed + SetPasskey(const nsAString& aDeviceAddress, uint32_t aPasskey, + ErrorResult& aRv); + already_AddRefed + SetPairingConfirmation(const nsAString& aDeviceAddress, bool aConfirmation, + ErrorResult& aRv); + already_AddRefed + SetAuthorization(const nsAString& aDeviceAddress, bool aAllow, + ErrorResult& aRv); + + already_AddRefed + Connect(BluetoothDevice& aDevice, + const Optional& aServiceUuid, ErrorResult& aRv); + already_AddRefed + Disconnect(BluetoothDevice& aDevice, + const Optional& aServiceUuid, + ErrorResult& aRv); + already_AddRefed + GetConnectedDevices(uint16_t aServiceUuid, ErrorResult& aRv); + + already_AddRefed + SendFile(const nsAString& aDeviceAddress, nsIDOMBlob* aBlob, + ErrorResult& aRv); + already_AddRefed + StopSendingFile(const nsAString& aDeviceAddress, ErrorResult& aRv); + already_AddRefed + ConfirmReceivingFile(const nsAString& aDeviceAddress, bool aConfirmation, + ErrorResult& aRv); + + already_AddRefed ConnectSco(ErrorResult& aRv); + already_AddRefed DisconnectSco(ErrorResult& aRv); + already_AddRefed IsScoConnected(ErrorResult& aRv); + + already_AddRefed AnswerWaitingCall(ErrorResult& aRv); + already_AddRefed IgnoreWaitingCall(ErrorResult& aRv); + already_AddRefed ToggleCalls(ErrorResult& aRv); + + already_AddRefed + SendMediaMetaData(const MediaMetaData& aMediaMetaData, ErrorResult& aRv); + already_AddRefed + SendMediaPlayStatus(const MediaPlayStatus& aMediaPlayStatus, ErrorResult& aRv); + + IMPL_EVENT_HANDLER(devicefound); + IMPL_EVENT_HANDLER(a2dpstatuschanged); + IMPL_EVENT_HANDLER(hfpstatuschanged); + IMPL_EVENT_HANDLER(pairedstatuschanged); + IMPL_EVENT_HANDLER(requestmediaplaystatus); + IMPL_EVENT_HANDLER(scostatuschanged); + + nsPIDOMWindow* GetParentObject() const + { + return GetOwner(); + } + + virtual JSObject* + WrapObject(JSContext* aCx) MOZ_OVERRIDE; + +private: + BluetoothAdapter(nsPIDOMWindow* aOwner, const BluetoothValue& aValue); + ~BluetoothAdapter(); + + void Root(); + + already_AddRefed + StartStopDiscovery(bool aStart, ErrorResult& aRv); + already_AddRefed + PairUnpair(bool aPair, const nsAString& aDeviceAddress, ErrorResult& aRv); + + JS::Heap mJsUuids; + JS::Heap mJsDeviceAddresses; + nsString mAddress; + nsString mName; + bool mDiscoverable; + bool mDiscovering; + bool mPairable; + bool mPowered; + uint32_t mPairableTimeout; + uint32_t mDiscoverableTimeout; + uint32_t mClass; + nsTArray mDeviceAddresses; + nsTArray mUuids; + bool mIsRooted; +}; + +END_BLUETOOTH_NAMESPACE + +#endif