Skip to content

tjfsteele/RFLink32

Folders and files

NameName
Last commit message
Last commit date

Latest commit

3b6e8a7 · Feb 17, 2021
Feb 17, 2021
Feb 17, 2021
May 2, 2020
Apr 14, 2020
Feb 12, 2021
Jan 19, 2021
Feb 17, 2021
Feb 11, 2021
Jan 5, 2017
Feb 17, 2021
Jan 5, 2017
Feb 17, 2021

Repository files navigation

RFLink ESP

This is an RF to MQTT gateway build for an ESP8266 board (see #MCU for more).

It receive OOK 433MHz signals, then it identifies, decodes and push them over MQTT.

Projet is based on RFlink project "R29" (see rflink.nl, latest known open source shard version).

1. MCU

We use extensively Wemos ESP8266 D1 mini clone.

This is default settings in Platformio.ini and RFLink.h files.

You may use:

  • Other ESP8266/ESP8255 based boards, when no pins limitations. NodeMCUv2 is known working.
  • ESP32 based boards should work too. Although we need feedbacks there.
  • Arduino board (Uno, Pro Mini, Mega) are working too, of course without WiFi/MQTT part.

2. Receiver / Transmitter / Transceiver

We mainly use RXB6 receiver. It is simple, steady, running on 3.3v, easy to find and cheap.

Many other receivers will do! Simply *** Please avoid generic noname receiver ***

Receivers

3. OLED display

You can use an OLED display! We used SSD1306 128x64 I2C screen for our testings.

*** This is highly experimental ***, and thus not activated by default.

OLED

4. IDE

5. Framework

We use Arduino Core for ESP8266 https://github.com/esp8266/Arduino

6. Libraries

So far, in addition of core libraries, we use:

7. COMPILE OPTIONS AND FLAGS

Many features are not enabled by default or can be disabled for various reasons : firmware size, compability etc etc. Here is a listing with some instructions:

MQTT Server (disabled by default)

  • Define compilation flag MQTT_ENABLED or define it in 6_WIFI_MQTT.h
  • If you have not enabled WifiManager, make sure you update Wifi settings in 6_Credentials.h

WifiManager (disabled by default)

  • RFLINK_WIFIMANAGER_ENABLED
  • RFLINK_SHOW_CONFIG_PORTAL_PIN_BUTTON defines the PIN used to start the Config Portal on demand. This portal can be used to reconfigure MQTT, Wifi and various others settings.
  • WM_NODEBUG it is recommended to define this flag if you want WifiManager to leak your Wifi password over Serial

OTA (disabled by default)

There are 3 types of OTA tp update your firwware

Arduino/ESP's classic push over UDP (disabled by default)

  • RFLINK_OTA_ENABLED we recommaend that you enable a password for this method or anyone on your network could push a new firmware
  • RFLINK_OTA_PASSWORD="my_password_here" or RFLINK_OTA_PASSWORD='"'${sysenv.OTA_SEC}'"' in platforomio.ini with an environement variable called OTA_SEC

AutoOTA

Your device will download new firmware from a specific URL you specify.

  • RFLINK_AUTOOTA_ENABLED
  • AutoOTA_URL in Credentials.h or in platformio.ini

Config Portal Web Upload

Via WifiManager's Config Portal you can upload a new firmware insert screenshot here

8. Additional info

Pinout

  • When WebServer is active (which is default), pin setup has to be done there.
  • For safety & simplicity, default WebServer setup is : all pin inactive.
  • You may add decoupling capacitors and antenna to improve results.
  • This is a simple RX pin wiring :
Name D1 mini RXB6
PIN_RF_TX_VCC D5 5 VCC
PIN_RF_TX_NA D6 6 DER
PIN_RF_TX_DATA D7 7 DAT
PIN_RF_TX_GND D8 8 GND

Pinout

Alternative Pinout

  • ESP8266 can't draw more than 12mA on a GPIO pin.
  • Some receivers have current spikes bigger than that (eg RXB12).
  • This lead to a non working receiver / non starting ESP.
  • Here is a more safe wiring
Name (Alt) D1 mini RXB6
PIN_RF_TX_VCC 3v3 5 VCC
PIN_RF_TX_NA N/A 6 DER
PIN_RF_TX_DATA D7 7 DAT
PIN_RF_TX_GND GND 8 GND

Thanks

Special thanks to: Axellum, Etimou, Schmurtz, Zoomx

About

RFLink for ESP, with MQTT client

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 62.5%
  • C++ 37.3%
  • Other 0.2%