npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

blead2mqtt

v0.3.3

Published

Command-line tool that scans for BLE (Bluetooth Low Energy) advertisements and publishes them as completely customizable MQTT messages

Downloads

5

Readme

blead2mqtt

A command-line tool that scans for BLE (Bluetooth Low Energy) advertisements and publishes them as (fully customizable) MQTT messages.

This can for example be used for...

  • presence detection: If there's an advertising Bluetooth LE peripheral you always take with you when leaving your home (like a smartwatch or a key fob), the information if that peripheral is in range could be used by a smart home system, for example to turn the radiators off when you leave your home
  • collecting information from certain Bluetooth LE peripherals: The Xiaomi thermometer/hydrometer MJ_HT_V1 for example publishes the temperature and humidity as part of its advertising packets, so blead2mqtt can be used to collect that information from all such devices nearby and publish it to your MQTT broker

BLE advertisements? What's that?

BLE peripherals that one can connect to periodically send small information packets (called advertisements) to inform others about their presence. BLE devices that want to connect to such BLE peripherals scan for these packets (similar to how you can scan for nearby WiFi networks). Apart from providing the required information to connect to these BLE peripherals (their unique address etc.), their advertisement packets may also contain further information - like their name, a list of services they provide, or the current temperature/humidity in case of the Xiaomi sensor mentioned above.

Requirements

Furthermore, you of course need Bluetooth LE-capable hardware (like a Bluetooth 4 USB adapter or the Bluetooth hardware built into newer Raspberry Pis) and access to a MQTT broker.

Installation

To install blead2mqtt, install the blead2mqtt Node.js package, for example via the npm package manager. There are two ways to install it:

Global installation

Global installation of npm packages is meant for standalone command-line tools that shall be available on the PATH.

npm install --global blead2mqtt

On Linux systems, installing the blead2mqtt packages globally usually requires root permissions as well as using the --unsafe-perm flag, so the install command will rather be something like this:

sudo npm install --global --unsafe-perm blead2mqtt

Local installation

Local installation installes npm packages right in the current working directory. When installing locally, the blead2mqtt command-line tool will not instantly be available on your PATH.

npm install blead2mqtt

In case of a local installation, the above command works for Linux systems as well.

Setting up permissions on Linux systems

On Linux systems, if you want to run blead2mqtt as a normal user, you need to run the following command after installing blead2mqtt:

sudo setcap cap_net_raw+eip $(eval readlink -f `which node`)

See here. You will probably need to run this command whenever you upgrade/reinstall Node.js.

Usage

(ToDo)

Configuration

To configure/customize blead2mqtt, start by creating a copy of file default_configuration.mjs (in the directory where blead2mqtt was installed to) named configuration.mjs in the same directory. This is the configuration file you should edit - do not alter the default_configuration.mjs file, as changes to this file will be overwritten by program upgrades.

The actual configuration being used is obtained by merging the configurations stored in configuration.mjs and default_configuration.mjs, with settings specified in configuration.mjs overriding their default values in file configuration.mjs. So you only need to specify those settings in configuration.mjs where the default value is wrong, all other settings can be removed or commented out.

A simple custom configuration.mjs that uses all defaults except for the MQTT broker hostname might look like this:

export default {
  mqtt: {
    host: '192.168.0.9',
  },
};

Customizing the MQTT messages

Customizing the MQTT messages being published requires basic JavaScript programming skills, as you need to change the JavaScript code that converts a BLE advertisement into one or more MQTT messages.

Customization of the MQTT messages is done by changing the create_transform_function setting in the configuration.mjs file. The value of this setting must be a JavaScript function that...

  • is being called once at startup with (utils, configuration) arguments and
  • must return the actual transform function that...
    • will be called for every received BLE advertisement with (advertisement) arguments, and
    • must return zero or more MQTT messages to be published for this particular advertisement

The advertisement parameter that your transform function will be called with for every advertisement is a Javascript object similar to this:

{
  "address": "12:34:56:78:9A:BC", // The peripheral's Bluetooth (MAC) address
  "address_type": "public", // The address type, either "public" or "random"
  "connectable": false, // True if the device is connectable, false otherwise
  "manufacturer_data": [234, 17, 2, 4], // An array of uint8 values, or null if no manufacturer data is present
  "name": "LYWSD03MMC", // The name of the peripheral, or null if not known
  "rssi": -74, // The RSSI / signal strength
  "service_data": { // An object with canonical service UUIDs as keys and arrays of uint8 values (=the data of that service) as values
    "0000FE95-0000-1000-8000-00805F9B34FB": [48,88,91,5,1,188,154,120,86,52,18,40,1,0]
  },
  "service_uuids": [ // An array of canonical service UUIDs that the peripheral advertises
    "0000FE95-0000-1000-8000-00805F9B34FB",
    "00001234-0000-1000-8000-00805F9B34FB",
  ],
  "solicitation_service_uuids":[ // An array of canonical solicitation service UUIDs (hardly ever used)
    "00002345-0000-1000-8000-00805F9B34FB",
    "00005678-0000-1000-8000-00805F9B34FB",
  ],
  "timestamp": 1613388810338, // Timestamp when the advertisement was received, in milliseconds since the epoch
  "tx_power_level": null, // The TX power level, as an integer, but usually this will be null
}

For each MQTT message that shall be published when an advertisement was received, the transform function must return an object with topic and payload properties (and optional qos and retain properties), wrapped in an array. For example:

[
  {topic:"blead2mqtt/scanned_peripheral_address", payload:"12:45:56:78:9A:BC"},
  {topic:"blead2mqtt/last_advertisement_timestamp", payload:123456789, retain:true},
]

The default behaviour is defined by the create_transform_function setting in the default_configuration.mjs file, so you might want to take that function as a starting point.

Utility functions

The utils argument passed to the create_transform_function function provides access to a number of utility functions that can be used by your "transform" function. See here for more information on these functions.