react-native-ble-plx
Version:
React Native Bluetooth Low Energy library
272 lines (249 loc) • 11.9 kB
JavaScript
'use strict';
import { ConnectionPriority } from './TypeDefinition';
/**
* Device instance which can be retrieved only by calling
* {@link #blemanagerstartdevicescan|bleManager.startDeviceScan()}.
*/
export class Device {
/**
* Internal BLE Manager handle
* @private
*/
/**
* Device identifier: MAC address on Android and UUID on iOS.
*/
/**
* Device name if present
*/
/**
* Current Received Signal Strength Indication of device
*/
/**
* Current Maximum Transmission Unit for this device. When device is not connected
* default value of 23 is used.
*/
// Advertisement
/**
* Device's custom manufacturer data. Its format is defined by manufacturer.
*/
/**
* Map of service UUIDs (as keys) with associated data (as values).
*/
/**
* List of available services visible during scanning.
*/
/**
* User friendly name of device.
*/
/**
* Transmission power level of device.
*/
/**
* List of solicited service UUIDs.
*/
/**
* Is device connectable. [iOS only]
*/
/**
* List of overflow service UUIDs. [iOS only]
*/
/**
* Private constructor used to create {@link Device} object.
*
* @param {NativeDevice} nativeDevice Native device properties
* @param {BleManager} manager {@link BleManager} handle
* @private
*/
constructor(nativeDevice, manager) {
Object.assign(this, nativeDevice, {
_manager: manager
});
}
/**
* {@link #blemanagerrequestconnectionpriorityfordevice|bleManager.requestConnectionPriorityForDevice()} with partially filled arguments.
*
* @param {ConnectionPriority} connectionPriority: Connection priority.
* @param {?TransactionId} transactionId Transaction handle used to cancel operation.
* @returns {Promise<Device>} Connected device.
*/
requestConnectionPriority(connectionPriority, transactionId) {
return this._manager.requestConnectionPriorityForDevice(this.id, connectionPriority, transactionId);
}
/**
* {@link #blemanagerreadrssifordevice|bleManager.readRSSIForDevice()} with partially filled arguments.
*
* @param {?TransactionId} transactionId Transaction handle used to cancel operation.
* @returns {Promise<Device>} This device with updated RSSI value.
*/
readRSSI(transactionId) {
return this._manager.readRSSIForDevice(this.id, transactionId);
}
/**
* {@link #blemanagerrequestmtufordevice|bleManager.requestMTUForDevice()} with partially filled arguments.
*
* @param {?TransactionId} transactionId Transaction handle used to cancel operation.
* @returns {Promise<Device>} Device with updated MTU size. Default value is 23.
*/
requestMTU(mtu, transactionId) {
return this._manager.requestMTUForDevice(this.id, mtu, transactionId);
}
/**
* {@link #blemanagerconnecttodevice|bleManager.connectToDevice()} with partially filled arguments.
*
* @param {?ConnectionOptions} options Platform specific options for connection establishment. Not used currently.
* @returns {Promise<Device>} Connected {@link Device} object if successful.
*/
connect(options) {
return this._manager.connectToDevice(this.id, options);
}
/**
* {@link #blemanagercanceldeviceconnection|bleManager.cancelDeviceConnection()} with partially filled arguments.
*
* @returns {Promise<Device>} Returns closed {@link Device} when operation is successful.
*/
cancelConnection() {
return this._manager.cancelDeviceConnection(this.id);
}
/**
* {@link #blemanagerisdeviceconnected|bleManager.isDeviceConnected()} with partially filled arguments.
*
* @returns {Promise<boolean>} Promise which emits `true` if device is connected, and `false` otherwise.
*/
isConnected() {
return this._manager.isDeviceConnected(this.id);
}
/**
* {@link #blemanagerondevicedisconnected|bleManager.onDeviceDisconnected()} with partially filled arguments.
*
* @param {function(error: ?BleError, device: Device)} listener callback returning error as a reason of disconnection
* if available and {@link Device} object. If an error is null, that means the connection was terminated by
* {@link #blemanagercanceldeviceconnection|bleManager.cancelDeviceConnection()} call.
* @returns {Subscription} Subscription on which `remove()` function can be called to unsubscribe.
*/
onDisconnected(listener) {
return this._manager.onDeviceDisconnected(this.id, listener);
}
/**
* {@link #blemanagerdiscoverallservicesandcharacteristicsfordevice|bleManager.discoverAllServicesAndCharacteristicsForDevice()} with partially filled arguments.
*
* @param {?TransactionId} transactionId Transaction handle used to cancel operation
* @returns {Promise<Device>} Promise which emits {@link Device} object if all available services and
* characteristics have been discovered.
*/
discoverAllServicesAndCharacteristics(transactionId) {
return this._manager.discoverAllServicesAndCharacteristicsForDevice(this.id, transactionId);
}
/**
* {@link #blemanagerservicesfordevice|bleManager.servicesForDevice()} with partially filled arguments.
*
* @returns {Promise<Service[]>} Promise which emits array of {@link Service} objects which are discovered by this
* device.
*/
services() {
return this._manager.servicesForDevice(this.id);
}
/**
* {@link #blemanagercharacteristicsfordevice|bleManager.characteristicsForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @returns {Promise<Characteristic[]>} Promise which emits array of {@link Characteristic} objects which are
* discovered for a {@link Device} in specified {@link Service}.
*/
characteristicsForService(serviceUUID) {
return this._manager.characteristicsForDevice(this.id, serviceUUID);
}
/**
* {@link #blemanagerdescriptorsfordevice|bleManager.descriptorsForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @returns {Promise<Array<Descriptor>>} Promise which emits array of {@link Descriptor} objects which are
* discovered for this {@link Characteristic}.
*/
descriptorsForService(serviceUUID, characteristicUUID) {
return this._manager.descriptorsForDevice(this.id, serviceUUID, characteristicUUID);
}
/**
* {@link #blemanagerreadcharacteristicfordevice|bleManager.readCharacteristicForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits first {@link Characteristic} object matching specified
* UUID paths. Latest value of {@link Characteristic} will be stored inside returned object.
*/
readCharacteristicForService(serviceUUID, characteristicUUID, transactionId) {
return this._manager.readCharacteristicForDevice(this.id, serviceUUID, characteristicUUID, transactionId);
}
/**
* {@link #blemanagerwritecharacteristicwithresponsefordevice|bleManager.writeCharacteristicWithResponseForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @param {Base64} valueBase64 Value in Base64 format.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits first {@link Characteristic} object matching specified
* UUID paths. Latest value of characteristic may not be stored inside returned object.
*/
writeCharacteristicWithResponseForService(serviceUUID, characteristicUUID, valueBase64, transactionId) {
return this._manager.writeCharacteristicWithResponseForDevice(this.id, serviceUUID, characteristicUUID, valueBase64, transactionId);
}
/**
* {@link #blemanagerwritecharacteristicwithoutresponsefordevice|bleManager.writeCharacteristicWithoutResponseForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @param {Base64} valueBase64 Value in Base64 format.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Promise<Characteristic>} Promise which emits first {@link Characteristic} object matching specified
* UUID paths. Latest value of characteristic may not be stored inside returned object.
*/
writeCharacteristicWithoutResponseForService(serviceUUID, characteristicUUID, valueBase64, transactionId) {
return this._manager.writeCharacteristicWithoutResponseForDevice(this.id, serviceUUID, characteristicUUID, valueBase64, transactionId);
}
/**
* {@link #blemanagermonitorcharacteristicfordevice|bleManager.monitorCharacteristicForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @param {function(error: ?BleError, characteristic: ?Characteristic)} listener - callback which emits
* {@link Characteristic} objects with modified value for each notification.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|bleManager.cancelTransaction()} function.
* @returns {Subscription} Subscription on which `remove()` function can be called to unsubscribe.
*/
monitorCharacteristicForService(serviceUUID, characteristicUUID, listener, transactionId) {
return this._manager.monitorCharacteristicForDevice(this.id, serviceUUID, characteristicUUID, listener, transactionId);
}
/**
* {@link #blemanagerreaddescriptorfordevice|bleManager.readDescriptorForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID {@link Characteristic} UUID.
* @param {UUID} descriptorUUID {@link Descriptor} UUID.
* @param {?TransactionId} transactionId optional `transactionId` which can be used in
* {@link #blemanagercanceltransaction|cancelTransaction()} function.
* @returns {Promise<Descriptor>} Promise which emits first {@link Descriptor} object matching specified
* UUID paths. Latest value of {@link Descriptor} will be stored inside returned object.
*/
async readDescriptorForService(serviceUUID, characteristicUUID, descriptorUUID, transactionId) {
return this._manager.readDescriptorForDevice(this.id, serviceUUID, characteristicUUID, descriptorUUID, transactionId);
}
/**
* {@link #blemanagerwritedescriptorfordevice|bleManager.writeDescriptorForDevice()} with partially filled arguments.
*
* @param {UUID} serviceUUID {@link Service} UUID.
* @param {UUID} characteristicUUID Characteristic UUID
* @param {UUID} descriptorUUID Descriptor UUID
* @param {Base64} valueBase64 Value to be set coded in Base64
* @param {?TransactionId} transactionId Transaction handle used to cancel operation
* @returns {Promise<Descriptor>} Descriptor which saved passed value.
*/
async writeDescriptorForService(serviceUUID, characteristicUUID, descriptorUUID, valueBase64, transactionId) {
return this._manager.writeDescriptorForDevice(this.id, serviceUUID, characteristicUUID, descriptorUUID, valueBase64, transactionId);
}
}
//# sourceMappingURL=Device.js.map