Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RFM95 (LoRa) support #356

Closed
knopserl opened this issue Feb 10, 2019 · 8 comments
Closed

RFM95 (LoRa) support #356

knopserl opened this issue Feb 10, 2019 · 8 comments
Milestone

Comments

@knopserl
Copy link

Hello, great project! I'm trying to integrate a couple of Xiaomi Mijia Temp/Hum BLE sensors with LCD display (link dbelow). I think people have alreayd tested it with this project.
Finally I wanted to connect it with OpenHAB (via MQQT).
SInce I have also other devces (LoRA) using RFM95, it would be great to have that in addition to the RFM69.
The reason is, that I have a couple of ESP32 boards, which have the RFM95 (SX1276) on-baord (not the RFM69).
A couple of that product are availbel (very cheap).
Another quick question: If I want to use the W5500 instead of the W5100, does that work? Oth do we need another W500 library? Or should I use the ESP32 WiFI together wit Bluetooth instead of Ethernet? Does that work in parallel?

Here is the sensor I wanted to connect:
https://www.banggood.com/Xiaomi-Mijia-Bluetooth-Thermometer-Hygrometer-with-LCD-Screen-Magnetic-Suction-Wall-Stickers-p-1232396.html?cur_warehouse=CN

@1technophile
Copy link
Owner

1technophile commented Feb 10, 2019

Hello, great project! I'm trying to integrate a couple of Xiaomi Mijia Temp/Hum BLE sensors with LCD display (link dbelow). I think people have alreayd tested it with this project.

Thanks, It is tested and working since V0.8

SInce I have also other devces (LoRA) using RFM95, it would be great to have that in addition to the RFM69. The reason is, that I have a couple of ESP32 boards, which have the RFM95 (SX1276) on-baord (not the RFM69).

I agree, it could be an interesting feature

Another quick question: If I want to use the W5500 instead of the W5100, does that work? Oth do we need another W500 library? Or should I use the ESP32 WiFI together wit Bluetooth instead of Ethernet? Does that work in parallel?

If you have the choice between ethernet and wifi I would go for ethernet, you will get faster response time.
Regarding the w5500 I never tested it, it could be interesting to have your feedback if you have one.

For questions and support I advise you to go to the forum/community, github issues are didicated to bug/feature request (and on per issue)

@knopserl
Copy link
Author

thanks for the quick response. I'll test it later with the W5500 (which I have at home).

@knopserl
Copy link
Author

I have seen, that I ran out of W5500, so I ordered W5500 and W5100 (the W5500 are the newer actually better LAN chips). However, the main request was rather the RFM95 (LoRa) support, as a couple of the ESP32 modules have it on-board (RFM95 or SX1276 which is the same), thus it would be a more interesting Radio than the RFM69 and has even longer range.

1technophile added a commit that referenced this issue Feb 21, 2019
first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module #356
Sending and receiving working
@1technophile 1technophile added this to the V0.9.1 milestone Feb 21, 2019
@1technophile
Copy link
Owner

A first implementation tested on 2 TTGO LORA32 V2.0

1technophile added a commit that referenced this issue Feb 21, 2019
first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module #356
Sending and receiving working
1technophile added a commit that referenced this issue Feb 21, 2019
first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module #356
Sending and receiving working
@1technophile
Copy link
Owner

1technophile commented Feb 22, 2019

If you mean to use the ttgo integrated transceiver for basics protocols supported by ZgatewayRF, the answer is not with the current code and I don't if we can hack the transceiver to do others protocols than Lora. By the way why do you think RF modules are crappy ?
May I advise you to continue this discussion on the community forum, i don't want to hijack this issue.

@knopserl
Copy link
Author

@1technophile wow, I'm impressed, you did it! I will test it tomorrow. I have ESP32 Heltec and TTGo modules with SX1276 (equal to RFM95) on board which are the 868MHz versions of LoRa. I also have own modules with ESP32 and RFM95 modules (which are really good).
Now with LoRa we have the longest and reliable range, a really good enhancement!
With BLE I had the problem, that from my office to the kitchen (less then 8meters but 2 walls, I loose the connection to the Xiaomi BLE sensors.
I'll give you feedack soon and thanks a lot. I hope that also others will like it!

https://de.aliexpress.com/item/2-st-cke-868-mhz-915-mhz-SX1276-ESP32-LoRa-0-96-zoll-Blau-OLED-Display/32882205132.html?spm=a2g0x.search0104.3.2.124838c42uobD7&ws_ab_test=searchweb0_0,searchweb201602_10_10065_10068_10547_319_317_10548_10696_10084_453_10083_454_10618_10304_10307_10820_10821_537_10302_536_10902_10059_10884_10887_321_322_10103,searchweb201603_51,ppcSwitch_0&algo_pvid=5f63627f-d246-441e-a373-0843398b29cb&algo_expid=5f63627f-d246-441e-a373-0843398b29cb-0

https://de.aliexpress.com/item/RFM95-RFM95W-868-915-RFM95-868MHz-RFM95-915MHz-LORA-SX1276-wireless-transceiver-module-Best-quality/32832739318.html?spm=a2g0x.search0104.3.29.4a2660e1M3R6Mt&ws_ab_test=searchweb0_0,searchweb201602_10_10065_10068_10547_319_317_10548_10696_10084_453_10083_454_10618_10304_10307_10820_10821_537_10302_536_10902_10059_10884_10887_321_322_10103,searchweb201603_51,ppcSwitch_0&algo_expid=1266facc-103d-4c7f-9b7c-627f372785a8-4&algo_pvid=1266facc-103d-4c7f-9b7c-627f372785a8

https://de.aliexpress.com/item/TTGO-SX1276-SX1278-LoRa-ESP32-868-915-mhz-433-mhz-Bluetooth-WI-FI-Internet-Antenne-Development/32844017936.html?spm=a2g0x.search0104.3.39.124838c4Pq6TGQ&ws_ab_test=searchweb0_0,searchweb201602_10_10065_10068_10547_319_317_10548_10696_10084_453_10083_454_10618_10304_10307_10820_10821_537_10302_536_10902_10059_10884_10887_321_322_10103,searchweb201603_51,ppcSwitch_0&algo_pvid=5f63627f-d246-441e-a373-0843398b29cb&algo_expid=5f63627f-d246-441e-a373-0843398b29cb-5

@1technophile
Copy link
Owner

Indeed it is an interesting add to OMG ! I wait for your feedback, at this time this a first implementation. There is place for improvments (like adding sender and receiver adresses) but I need to go in deep with lora protocol.

1technophile added a commit that referenced this issue Apr 14, 2019
* Update IRRemoteESP8266 version to 2.5.5
factorize IR send signal function between the 2 types of receiving
Add new IRRemoteESP8266 protocols
replace pins on mega according schema
remove unecessaries spaces

* Update ESPilight library to 0.16.0

tfa protocol
kerui protocol

* Enable to switch HM1X led by a macro

#357
if //#define HM_BLUE_LED_STOP true uncommented
the HM1X led is off

* add log output through mqtt

#135
//#define subjectTRACEtoMQTT Base_Topic Gateway_Name "/log" //uncomment if you want to see traces on /log topic

* change default pin for rf receiver on ESP32

13 seems to don't work

* Add LORA gateway

first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module #356
Sending and receiving working

* Update README.md

* Update README.md

* add LORA gateway parameters

following lora api library def
https://github.com/sandeepmistry/arduino-LoRa/blob/master/API.md

* a first try for mi flora and mi jia auto discovery on hass

#361

* add LORA gateway auto discovery

* Some memory optimization for Arduino UNO following this thread:
https://community.openmqttgateway.com/t/arduino-uno-ethernet-shield-reboots-on-receiving-rf-signal-on-v-0-9/346/22
Rework led management to avoid use of global variables
and specify special JSON_MSG_BUFFER for arduino UNO
led can now be used for all the boards

generalize use of F macro
for memory optimization
change jsonbuffer calculation method
reduce pubsubclient max packet size for uno and nano

* Update README.md

* no need of going >67 as the code can handle only unsigned long at this time

* Add "repeat" field to RF JSON messages. (#372)

* update pubsubclient release to 2.7

* update irremote ESP8266 to 2.5.6

* publish discovery for sensors BLE once per run, add ble white and black list
Avoid publishing auto discovery on a time basis
publish auto discovery only one time per BLE sensor
add BLE white and black list implementation
set black list
mosquitto_pub -t home/OpenMQTTGateway/commands/MQTTtoBT/set -m '{"black-list":["012314551615","4C6577889C79","edfrgtyjulik"]}'
set white list
mosquitto_pub -t home/OpenMQTTGateway/commands/MQTTtoBT/set -m '{"white-list":["012314551615","4C65A5553C79","edfrgtyjulik"]}'

* remove optimistic and retain flag from auto discovery

#361

and add some json buffer size to avoid identifier lost

* correct json buffer size optimizations

* correct switch between modes raw versus message   protocol and add raw error codes (#374)

has been discussed here:
puuu/ESPiLight#39

* Add pilight repeater function

#369
set
#define repeatPilightwMQTT true
into config_RF.h to activate it

* add comment for sonoff rf bridge IR add

* Separate list of contributors for main file reading improvment

add also missing contributors

* correct deduplication issue with SRFB and improve OMG performance

by reducing the receivingMQTT call numbers
https://community.openmqttgateway.com/t/seeing-duplicated-messages/398/7

* Correct return always false when using HM10 and return number instead of char array for sensors values

* add message if wrong pubsubclient library used

* correct isue with using a different receiver with RFM69 than the default and ack issue

#376 #375

* revert thigh and tlow for sonoff rf bridge SRFBtoMQTT

#366

* correct wrong json object name

* change actuator default assignment

* change default input gpio pin

* add comment for sonoff pin

* Prepare 0.9.1 release

* Update CONTRIBUTING.md (#381)
1technophile added a commit that referenced this issue Apr 22, 2019
first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module #356
Sending and receiving working
ettiennegous added a commit to ettiennegous/OpenMQTTGateway that referenced this issue May 24, 2019
* ESPilight support

Support for ESPilight - only recieve at the moment

* Adjustments for sending Pilight messages including RAW messages

https://manual.pilight.org/programs/debug.html
https://manual.pilight.org/programs/raw.html

Considering a RAW receive handler

* Fixup callback and loop for Pilight - catches all messages per loop

* Update Test_config.h

* Added ESPilight libs

* change default DHT pin for ESP32

following user feedback pin 16 works and 35 doesn't works

* correct impossibility to read value with HM10

1technophile#281 and make the code more flexible (deduct an offset from a key value instead of fixed offset)

*  Increased size of mqtt_pass to char[30]  (1technophile#288)

* Increased size of mqtt_pass to char[30]

* modified test_config.h too

* Fixed typo and added a little formatting (1technophile#290)

* Introduced WifiManager_ssid variable and documented user_config.h (1technophile#289)

* Commented user_config.h to clarify usage of WifiManager

* Introduced WifiManager_ssid variable

* Added changes to Test_config.h too

* multi gpio input module (1technophile#278)


* GPIOKeyCode module added

* Add Home Assistant MQTT room presence support (ESP32 only) (1technophile#294)

* Add Home Assistant MQTT room presence support

ESP32 only

* Publish refactoring (1technophile#298)

* factoring of the publishing function
* integration of json publishing to MQTT
* receiving and transcode json messages from mqtt
* replace the TRACE runtime condition by a buildtime one so as to decrease program size
* remove retainFlag parameter not necessary for the moment
* Increase the scope of tests for arduino mega and esp32
* Update arduinojson library to 5.13.3
* add macros to choose between simple or json publishing or both
* differentiate build test for ATmega2560
* correct wrong sprintf definition
* change IDE version for continuous integration
* let default warning level in arduino ide
* correct pins for ESP32
* reorganize user_config

* remove unecessary variable and PilighttoMQTT call

* Update README.md

* remove redundant code for home presence (1technophile#303)

* correct duplicate comments and code

* fix ESP32 ble (1technophile#304)

* remove redundant code for home presence

* hopefully fix ESP32 BLE hangs

* basic support for duplicate detection when JSON publishing is active

* correct double variable declaration and use arduino json implicit cast

* Update ZgatewayRF2.ino (1technophile#309)

Small fix for dimming with JSON payload.
switchType 0 OFF
switchType 1 ON
switchType 2 DIM
{
"switchType": 2,
"adress": "26494598",
"unit": 10,
"dim": 8
}

* correct sonoff rf bridge issue not communicating with RF module

1technophile#310

* update rc-switch (1technophile#313)

* more repeatSRFBwMQTT macro to pertinent config file

1technophile#295

* Update contributor list

* Add images

* add missing macro

* update esppilight lib

content of the library is not filtered on 433mhz only

* Mqtt discovery (1technophile#320)

* add mqtt discovery (compatibile with home assistant) with omg status binary sensor & bme280 sensor

* added mqtt discovery to Test_config.h for ESP32 (ESP8266 & other boards was not tested)

* include support for ESP8266 & arduino mega

* fix getting MAC for esp8266

* esp8266 fix

* make mqtt discovery functions functions more generic, readable and easy to use & extend

* make mqtt discovery functions functions more generic, readable and easy to use & extend PART 2

* remove the macro for each attribute and supposing that if there is a bme280 we expose all

* remove unecessaries files from pilight lib

* move MQTT_MAX_PACKET_SIZE to pubsubclient library

* per default deactivate mqtt ha discovery

* wdt tip add and presence detection improvments

-improve distance measurement
-add wdt prevent tip
-add conditional macro haroompresence

* Mqtt discovery for ha (1technophile#323)

* MQTT discovery factoring

* add DHT discovery

* BME topic macro change

* add sensors to ha discovery

* correct a comment typo 1technophile#327

* let the possibility at buildtime to don't publish service data

* reduce string usage

* change MQTT ONOFF actuator to ON OFF commands instead of true false

* add ZactuatorONOFF discovery

* add simple publishing for GPIO input

* Add RF switch and gateway discovery

* fix typo mistake

1technophile#324

* Fix compile error (1technophile#330) on rcswitch

Introduced with 1technophile#313

* Default pin for ESP8266 should be RX (1technophile#332)

* code cleanup and improvment (1technophile#339)

* replace string by char array comparison

* take mac adress from user_config for arduino ethernet shield

* remove code for managing HM10 with version < v6xx

* add sys measure call for arduino mega

* code size decrease and optim

* differentiate receiving and publishing mqtt for the new json option in user_config.h

1technophile#318 so as to avoid user with non modified controllers to have regression on receiving (per default receiving is activated for both json and simple and prioritary analysed for json)

* Storevalue after pub to avoid duplicates publishing in slow environment

* add per default Irremote protocol for arduino mega

as the mega can handle the list without memory issue (contrary to the uno)
set default mega pinout

* set default protocol with to IR NEC when no protocol is set on json

* differentiate ON OFF pin depending on board

* remove cleanFS macro and correct reseting when mqtt fail at start

clean FS now available from Arduino IDE tools menu (erase flash)

* add some image ressources

* add wifimanager config portal timeout

1technophile#350 in case of power outage so as to avoid to pop up the web page before the mqtt server restart

* add specific pinout for RF on arduino mega

* traces improvements, and code refactoring (RF315)

* enable the link between OMG status and its components

enable to have the link between OMG status and its sensors/gateways on the same place for HASS
https://community.openmqttgateway.com/t/v0-9beta-testers-needed/242/2?u=1technophile

* Update OpenMQTTGateway.ino

* put RF EMITTER PIN according to doc

* Update CONTRIBUTING.md

* Update IRRemoteESP8266 version to 2.5.5
factorize IR send signal function between the 2 types of receiving
Add new IRRemoteESP8266 protocols
replace pins on mega according schema
remove unecessaries spaces

* Update ESPilight library to 0.16.0

tfa protocol
kerui protocol

* Enable to switch HM1X led by a macro

1technophile#357
if //#define HM_BLUE_LED_STOP true uncommented
the HM1X led is off

* add log output through mqtt

1technophile#135
//#define subjectTRACEtoMQTT Base_Topic Gateway_Name "/log" //uncomment if you want to see traces on /log topic

* change default pin for rf receiver on ESP32

13 seems to don't work

* Add LORA gateway

first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module 1technophile#356
Sending and receiving working

* Update README.md

* Update README.md

* add LORA gateway parameters

following lora api library def
https://github.com/sandeepmistry/arduino-LoRa/blob/master/API.md

* a first try for mi flora and mi jia auto discovery on hass

1technophile#361

* add LORA gateway auto discovery

* Some memory optimization for Arduino UNO following this thread:
https://community.openmqttgateway.com/t/arduino-uno-ethernet-shield-reboots-on-receiving-rf-signal-on-v-0-9/346/22
Rework led management to avoid use of global variables
and specify special JSON_MSG_BUFFER for arduino UNO
led can now be used for all the boards

generalize use of F macro
for memory optimization
change jsonbuffer calculation method
reduce pubsubclient max packet size for uno and nano

* Update README.md

* no need of going >67 as the code can handle only unsigned long at this time

* Add "repeat" field to RF JSON messages. (1technophile#372)

* update pubsubclient release to 2.7

* update irremote ESP8266 to 2.5.6

* publish discovery for sensors BLE once per run, add ble white and black list
Avoid publishing auto discovery on a time basis
publish auto discovery only one time per BLE sensor
add BLE white and black list implementation
set black list
mosquitto_pub -t home/OpenMQTTGateway/commands/MQTTtoBT/set -m '{"black-list":["012314551615","4C6577889C79","edfrgtyjulik"]}'
set white list
mosquitto_pub -t home/OpenMQTTGateway/commands/MQTTtoBT/set -m '{"white-list":["012314551615","4C65A5553C79","edfrgtyjulik"]}'

* remove optimistic and retain flag from auto discovery

1technophile#361

and add some json buffer size to avoid identifier lost

* correct json buffer size optimizations

* correct switch between modes raw versus message   protocol and add raw error codes (1technophile#374)

has been discussed here:
puuu/ESPiLight#39

* Add pilight repeater function

1technophile#369
set
#define repeatPilightwMQTT true
into config_RF.h to activate it

* add comment for sonoff rf bridge IR add

* Separate list of contributors for main file reading improvment

add also missing contributors

* correct deduplication issue with SRFB and improve OMG performance

by reducing the receivingMQTT call numbers
https://community.openmqttgateway.com/t/seeing-duplicated-messages/398/7

* Correct return always false when using HM10 and return number instead of char array for sensors values

* add message if wrong pubsubclient library used

* correct isue with using a different receiver with RFM69 than the default and ack issue

1technophile#376 1technophile#375

* revert thigh and tlow for sonoff rf bridge SRFBtoMQTT

1technophile#366

* correct wrong json object name

* change actuator default assignment

* change default input gpio pin

* add comment for sonoff pin

* Prepare 0.9.1 release

* Add LORA to functions schema
sh1970 pushed a commit to sh1970/OpenMQTTGateway that referenced this issue Aug 23, 2024
first implementation of a lora gateway integration, tested on ttgo heltec boards with embedded lora module 1technophile#356
Sending and receiving working


Former-commit-id: a25d2e2
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants