Git Product home page Git Product logo

balena-airthingswave's Introduction

โ˜ข๏ธ
Airthings Wave radon detector bridge
a balena and Docker container ๐Ÿณ

GitHub Release Price AirthingsWave-to-MQTT Version balena.io Code Climate maintainability Maintainer All Contributors PRs Welcome License Tweet

Turn a single-board computer (Raspberry Pi) into a plug-in appliance to bridge your Bluetooth Airthings Wave radon detector to an MQTT broker.

Useful if your radon detector is located too far from your home automation hub, or if you need to use your hub's Bluetooth antenna for something else.

This project creates Docker/balena images based on Alpine Linux that weigh less than 120 MiB on a Raspberry Pi. ๐ŸŽˆ

Be sure to โญ๏ธ this repo if you find it useful! ๐Ÿ˜ƒ

Radon alpha decay in a diffusion cloud chamber

Alpha decay. Inside your lungs. ๐Ÿ˜ฑ

Why use the balena ecosystem?
All the goodness of Docker, plus security handling, IoT hardware optimized images, read-only rootFS, a build pipeline, a device management interface, and continuous deployment, for free (well, first 10 devices on balenaCloud โ€ฆor unlimited if you run your own OpenBalena platform).

Of course you could do all of this on your own, but do you really want to micro-manage, keep secure, always perform clean shutdowns, and generally baby something that should really be just plug-in, set-and-forget hardware? ๐Ÿค” I surely don't! ๐Ÿ˜…

๐Ÿ”

Table of contents ๐Ÿ“‘

  1. Prerequisites
  2. balena
    1. Preparation
    2. Installation
    3. Configuration
  3. Docker
  4. Alternatives
  5. Contributors
  6. Thanks

๐Ÿ”

Prerequisites โœ…

  1. At least one Airthings Wave radon detector.
  2. Your favourite Internet of Things (IoT) device that offers both Bluetooth Low Energy (BLE) and network access, like the inexpensive Raspberry Pi Zero W.
  3. Working access to an MQTT broker, either a public one, your own hosted Mosquitto instance or the Home Assistant add-on.
  4. (Recommended) A free-tier account on balenaCloud along with a properly set SSH public key into your account.
  5. (Recommended) The balena command-line tools. Do read up on their friendly development guidelines.

Let's play! ๐Ÿค 

๐Ÿ”

balena ๐Ÿ“ฆ

Follow these simple steps to quickly get your app running on a dedicated device using balenaCloud. If you want more control, try the Docker solution instead.

For reference, the balena framework will build the container using the ./Dockerfile.template which employs placeholders so that the correct system architecture is picked for you during installation. Easy!

Preparation ๐Ÿ”

  1. Create a new application on balenaCloud dashboard and select the appropriate IoT hardware.

  2. Add a new device to your app. Start with development mode for local testing, or go directly for production mode if you know what you're doing.

  3. (Optionally) Configure the downloaded image to give your device a custom hostname instead of the generic balena:

    sudo balena local configure /path/to/downloaded/image.img
  4. Burn the image to a disk and boot your IoT device.

Your hardware is ready; it's now time to install the project! โฌ‡๏ธ

๐Ÿ”

Installation ๐Ÿ’ป

  1. Git clone this project's repository:

    git clone [email protected]:renemarc/balena-airthingswave.git
  2. Add your balena application as a secondary remote to the cloned repo:

    git remote add balena <username>@git.balena-cloud.com:<username>/<appname>.git
  3. Push the code to balenaCloud and wait for it to build and provision your device:

    git push balena master

Great! You are now ready to configure the project. โฌ‡๏ธ

๐Ÿ”

Configuration โš™

Either modify the ./docker/config.yaml file with your MQTT and Airthings Wave(s) information, or ideally declare environment variables that will then be automatically replaced in the said configuration file.

I strongly suggest simply using environment variables, either at the whole fleet level, at the single device level, or at a mix of both. Configuration is easier to update this way and if you live in a McMansion you can provision multiple devices with the same codebase. Yay!

MQTT_BROKER   192.168.1.1
MQTT_PORT     1883
MQTT_USERNAME user
MQTT_PASSWORD super-secret-password

WAVES_NAME_1  radon/basement
WAVES_ADDR_1  cc:78:ab:00:00:0a
WAVES_NAME_2  radon/bedroom
WAVES_ADDR_2  cc:78:ab:00:00:0b
WAVES_NAME_3  radon/garage
WAVES_ADDR_3  cc:78:ab:00:00:0c

The Waves names are used as MQTT topic prefixes, so name them however you prefer. If you have more than one Wave that you want to query, do modify the ./docker/config.yaml file to add more entries.

Which MAC address to use? Leave that empty for now and proceed to the first run below. โฌ‡๏ธ

First run ๐Ÿƒ

There can be only one controller paired at a time, so do make sure that your Airthings Wave is "forgotten" from your mobile device by opening Airthings' mobile app and unpairing from there.

There can be only one

There should have only been one Highlander movie tooโ€ฆ

SSH into your device (only if development mode was selected earlier) or use the balenaCloud app dashboard terminal to find your Wave's MAC address by issuing this command:

python /usr/src/app/find_wave.py

Press Ctrl+C when scanning seems to be done. Take note of the MAC address for the Wave that you want to use, and either modify ./docker/config.yaml or ideally create sets of environment variables for each Wave that you want to use.

Once configured, either git push your changes or restart the device.

Cron job โฒ

If your above parameters are correct, you should be receiving new MQTT messages every hour. Keep an eye on the streaming device logs in the balenaCloud dashboard and use an MQTT client to debug incoming messages.

Want to receive quicker updates? Modify the ./Dockerfile.template and change the CRON_PERIOD argument from hourly to 15min or to something else.

Butters awarding himself a sunshine sticker

โ˜€๏ธ Good job! ๐Ÿ˜ƒ

๐Ÿ”

Docker ๐Ÿณ

Want more control or wish to run this container on some multi-purpose shared hardware? Here are some useful steps.

Compared to the balena solution, here the regular ./Dockerfile is used.

Containers being moved in a yard

Build and run ๐Ÿ—๏ธ

  1. Fork or clone this project's repository.

  2. Edit the ./docker/env.list file to setup your environment variables. See configuration above โฌ†๏ธ for details.

  3. Build the image:

    For a Raspberry Pi or Zero:

    docker build --tag=airthingswave .

    For everything else, specify the DEVICE_NAME argument with the relevant lowercase machine name from balena base images. For a Raspberry Pi 3 for instance:

    docker build --build-arg DEVICE_NAME=raspberrypi3 \
      --tag=airthingswave .
  4. Run the project as an auto-starting container:

    docker run --detach --restart=unless-stopped \
      --env-file=docker/env.list \
      --net=host --cap-add=NET_ADMIN \
      --name=airthingswave \
      airthingswave

    --net=host gives the container access to the host's network devices, including Bluetooth.
    --cap-add=NET_ADMIN gives the container network privileges.

  5. Perform the steps outlined in first run above โฌ†๏ธ using while inside the container:

    docker exec -it airthingswave bash
  6. Should you wish to change the cron job frequency, you can pass the CRON_PERIOD (default: hourly) argument while first building the image:

    docker build --build-arg CRON_PERIOD=15min \
      --tag=airthingswave .

Once ready and working, you can alternatively use this example one-liner to build and run the project:

docker run --detach --restart=unless-stopped \
  --env-file=docker/env.list \
  --net=host --cap-add=NET_ADMIN \
  --name=airthingswave $(docker build --quiet .)
Buzz Lightyear saying Containers everywhere!

๐Ÿ”

Alternatives โš›

Other options exist, should you wish to try something else:

Community projects ๐ŸŒฑ

Official solutions ๐Ÿ‘ฎ

R is for radiophobia: the fear of radiation

๐Ÿ”

Contributors โœจ

Renรฉ-Marc Simard
Renรฉ-Marc Simard

๐Ÿ’ป ๐Ÿ“–
Herb Peyerl
Herb Peyerl

๐Ÿค” ๐Ÿ”Œ
grangemd
grangemd

๐Ÿ›
Robin
Robin

๐Ÿ›

This project follows the all-contributors specification (emoji key available here). Found a bug, want to suggest an idea or share some improvements? Contributions of any kind are welcome! ๐Ÿ˜ƒ

๐Ÿ”

Thanks ๐Ÿ’•

This Docker container is based on airthingswave-mqtt [MIT License] by Herb Peyerl (@hpeyerl) and the discovery code [MIT License] by Airthings.

Copyright ยฉ 2018, Renรฉ-Marc Simard. Project released under Apache Licence 2.0 with additional notices available here.

๐Ÿ”

Don't forget to โญ๏ธ this repo! ๐Ÿ˜ƒ
Assembled with โค๏ธ in Montrรฉal.

balena-airthingswave's People

Contributors

allcontributors[bot] avatar renemarc avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar

balena-airthingswave's Issues

Regroup Docker support files

User Story

As a developer, I want to see all Docker support files in a simple place so that I can quickly know which files will be copied over to the image.

Acceptance Criteria

  1. It's done when all Docker support files (except Dockerfiles) are grouped together.

Additional Details (if any)

Bug: Traceback from bluetooth on Pi 3b+

Bug Report

Hi, is this able to run on a 3b+? That's all I have lying around, but balena only has an image for 3, not specifically 3b+. It seems to be having problems accessing the bluetooth.

Steps to Reproduce (unless obvious)

  1. Install
  2. Configure
  3. Run

Environment Info

Pulled it 2 days ago.

Debug Log (if any)

29.07.20 13:00:01 (+0200)  main  radon/upstairs a1:db:22:28:cf:e4
29.07.20 13:00:03 (+0200)  main  Traceback (most recent call last):
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/runpy.py", line 174, in _run_module_as_main
29.07.20 13:00:03 (+0200)  main      "__main__", fname, loader, pkg_name)
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/runpy.py", line 72, in _run_code
29.07.20 13:00:03 (+0200)  main      exec code in run_globals
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/airthingswave-mqtt/__main__.py", line 32, in <module>
29.07.20 13:00:03 (+0200)  main      main()
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/airthingswave-mqtt/__main__.py", line 25, in main
29.07.20 13:00:03 (+0200)  main      r = atw.get_readings(handle)
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/airthingswave-mqtt/airthingswave.py", line 96, in get_readings
29.07.20 13:00:03 (+0200)  main      ch  = p.getCharacteristics(uuid=s.uuid)[0]
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/bluepy/btle.py", line 508, in getCharacteristics
29.07.20 13:00:03 (+0200)  main      rsp = self._getResp('find')
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/bluepy/btle.py", line 407, in _getResp
29.07.20 13:00:03 (+0200)  main      resp = self._waitResp(wantType + ['ntfy', 'ind'], timeout)
29.07.20 13:00:03 (+0200)  main    File "/usr/local/lib/python2.7/site-packages/bluepy/btle.py", line 368, in _waitResp
29.07.20 13:00:03 (+0200)  main      raise BTLEGattError("Bluetooth command failed", resp)
29.07.20 13:00:03 (+0200)  main  bluepy.btle.BTLEGattError: Bluetooth command failed (code: 10, error: No attribute found within the given range)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.