examples

Simple code snippets to work with flespi

View project on GitHub

MQTT Client examples

All provided examples follow a simple but complete MQTT client workflow:

  • connect to mqtt broker
  • subscribe to “test” topic
  • publish a message to the “test” topic
  • receive published message in a separate callback
  • disconnect from the mqtt broker

The expected stdout output will be like this:

mqtt client created, connecting...
connected, subscribing to "test" topic...
subscribed to "test" topic, publishing message...
received message in topic "test": "hello from flespi mqtt client example script!"
disconnecting...
disconnected

Requirements: flespi token

To connect to flespi mqtt broker you have to obtain a flespi token.

Please refer here to read how to do it (don’t worry, it’s fast and simple).

To run these examples you need a flespi token allowing to publish and subscribe to “test” topic. That may be a Standard token, a Master token (although using it in the example may be excessive) or an ACL token (see the “Token for MQTT broker” section).

nodejs

Example source code is located at ./nodejs/ and ./nodejs-paho-ws/

To run the example you need to install the dependencies (mqtt package):

npm install

And then run the example script with the flespi token passed through the process environment:

FlespiToken=XXXXXXXXXXXXXXX node ./example.js

python

Example source code is located at ./python/

To run the example you need to install the dependencies (gmqtt package):

# optionally create and activate the virtualenv
virtualenv venv
. venv/bin/activate

# install requirements
pip install -r requirements.txt

And then run the example script with the flespi token passed through the process environment:

# optionally use created virtualenv
. venv/bin/activate

# run example
FlespiToken=XXXXXXXXXXXXXXX python ./example.py

python-windows

Example source code is located at ./python-windows/. The only difference in the windows version is missing the uvloop module and not handling signals (windows does not have them).

To run the example you need to install the dependencies (gmqtt package):

rem   optionally create and activate the virtualenv
python -m venv venv
venv\Scripts\activate.bat

rem   install requirements
pip install -r requirements.txt

And then run the example script with the flespi token passed through the process environment:

rem   optionally use created virtualenv
venv\Scripts\activate.bat

rem   run example
set FlespiToken=XXXXXXXXXXXXXXX
python example.py

micropython (esp8266)

Example source code is located at ./micropython/

esp8266 micropython mqtt

We used a NodeMCU(esp8266) board with preinstalled light sensor that sends sensor value to topic “myesp/light”.

To run the example you need to flash micropython firmware

Manual: https://docs.micropython.org/en/latest/esp8266/tutorial/intro.html

To flash you should install esptool:

pip install esptool

Now you can flash firmware

# clear flash
esptool.py --port /dev/ttyUSB0 erase_flash
# deploy downloaded firmware
esptool.py --port /dev/ttyUSB0 --baud 460800 write_flash --flash_size=detect 0 esp8266-20191220-v1.12.bin

If everything is ok, please edit boot.py file and provide valid data:

# Your flespi token
token = "YourFlespiTokenHere"
topic = "myesp/light"

# Wi-Fi settings
wifissid = "test"
wifipassword = "12345678"

Now you can load the example to your board:

ampy --port /dev/ttyUSB0 put boot.py
ampy --port /dev/ttyUSB0 put mqtt.py
ampy --port /dev/ttyUSB0 put wifi.py

Then just unplug then plug power cable from your board. And check result for example in your favorite UI MQTT client (we love to use MQTT-Board)

lua

Example source code is located at ./lua/

To run the example you need to install the dependencies (luamqtt package):

# optionally create local environment using hererocks (https://github.com/mpeterv/hererocks):
hererocks venv -l5.3 -rlatest
. venv/bin/activate

# install requirements
luarocks install luasocket
luarocks install luasec
luarocks install luamqtt

And then run the example script with the flespi token passed through the process environment:

# optionally use created local environment
. venv/bin/activate

# run example
FlespiToken=XXXXXXXXXXXXXXX lua ./example.lua

browser

Example source code is located at ./browser/

You may run the example in your browser from GitHub Pages or open the example.html file from your local file system.

This example uses the browser-version of the mqtt.js library.

dart

Example source code is located at ./dart/

Setup and Run

  1. Navigate to the Dart project directory:
    cd dart
    
  2. Ensure you have Dart SDK installed, then initialize the project:
    dart pub get
    
  3. Set the Flespi token environment variable: On Linux/macOS:
    export FlespiToken=your_flespi_token
    

    On Windows:

    set FlespiToken=your_flespi_token
    
  4. Run the Dart script:
    dart run lib/example.dart