Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
bluetoothle-explorer
Advanced tools
Command line explorer for Bluetooth Low Energy (BLE) devices
bluetoothle-explorer
is a Node.js package for logging information about available Bluetooth Low Energy (BLE) devices, and the data they generate, at the command line.
It is a tool for debugging / exploration, building on top of the noble
library, and not intended for consumption from other applications.
git clone https://github.com/chbrown/BluetoothLE-Explorer
cd BluetoothLE-Explorer
npm install
node server.js
By default, that will limit discovery to devices advertising recognized service UUIDs (those listed in services.js
).
To specify a different filter, set the BLE_SERVICES
environment variable to a :
-separated list of UUIDs.
E.g., BLE_SERVICES=180a:1821 node server.js
will only connect to devices that advertise the "Device Information" or "Indoor Positioning" services.
Use an empty value, e.g., BLE_SERVICES= node server.js
, to discover all BLE devices.
noble
noble
objectconst noble = require('noble')
That's the noble
controller you start with.
You can't do anything with it until it's "powered on", which happens automatically,
so you have to listen for its stateChange
event,
check that noble.state
is poweredOn
, and then do stuff.
noble.startScanning(serviceUUIDs, allowDuplicates)
is the main entry point.
noble
object's discover
event, once (assuming allowDuplicates
is set to false
) for each new deviceserviceUUIDs
(a list of hexadecimal strings),
it will only trigger discover events for devices ("peripherals") that advertise having that serviceUUID.peripheral
objectsPeripherals are Bluetooth LE devices acting as servers that your machine, the client, is connecting to.
id
attribute (duplicated as uuid
), and sometimes an address
and addressType
, as identifying features.advertisement
is a descriptive object with more information about the peripheral.
It has some handy attributes, like:
localName
: a high-level name for the deviceserviceUuids
: which lists the the service UUIDs it will matchrssi
indicates the strength of signal from the peripheral; it's negative, and maxes out at 0.
So, the closer to 0 it is, the stronger the signal is.Besides that chunk of information, you can't do much with the peripheral until you "connect" to it.
Assuming the connectable
attribute is true
, and the current state
is "disconnected"
,
you "connect" to the peripheral with peripheral.connect(error => { ... })
.
At this point you can call peripheral.discoverServices(serviceUUIDs, (error, services) => { ... })
,
which as with the noble
global's startScanning
method, can supply an array of serviceUUIDs
to filter,
or []
to discover all services.
These are all returned in a single batch, via the callback's services
argument.
The discoverServices
method will likely return many more services than the device directly advertises (though it includes those),
but these are probably metadata, like battery level -- not as integral to the function of the device as what it advertises.
service
objectsA service object represents a service as conceptualized by the Bluetooth LE standard.
These are mostly just data; using them is negotiated via the peripheral, though the noble package's interface has the relevant methods attached to the service objects.
Calling service.discoverCharacteristics(characteristicUUIDs, (error, characteristics) => { ... })
triggers discovery of the peripherals characteristics for that service, filtered by characteristicUUIDs
,
or returning all characteristics if characteristicUUIDs
is []
.
These are all returned in a single batch, via the callback's characteristics
argument.
characteristic
objectsCharacteristic objects represent various sources of data that the device can produce, which are specified in the Bluetooth LE standard.
Again, these are mostly data, but the noble interface provides helper methods on the characteristic
objects.
Most of the information you'll need to parse/interpret characteristics comes from the corresponding Bluetooth LE specification,
but it provides one handy attribute that determines what you can do with it via noble: properties
, which is an array of strings.
If properties
contains the string "notify"
, you can "subscribe" to the characteristic,
which will start triggering data
events on the characteristic object, as sent by the device.
If properties
contains the string "read"
, you can "read" from the characteristic to get the current value.
You cannot "subscribe" to characteristics with a "read"
property hoping to get continual updates whenever it changes;
instead, you'd have to set up an interval of your own and poll the characteristic as often as you suspect it might change.
The data structures returned by characteristic.read
or emitted as the characteristic's data
events are Buffer
instances.
characteristics.js
;
when a characteristic defined in that file matches a characteristic received from a device,
the command line tool will use that definition's parse(data: Buffer)
function to process the data structure.
Otherwise, the command line tool will display the raw Buffer.Copyright 2018 Christopher Brown. MIT Licensed.
FAQs
Command line explorer for Bluetooth Low Energy (BLE) devices
The npm package bluetoothle-explorer receives a total of 1 weekly downloads. As such, bluetoothle-explorer popularity was classified as not popular.
We found that bluetoothle-explorer demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.