User Tools

Site Tools


projets:fuz:presence_button

Presence button

Goals

  • Notifying that the Hackerspace is open/closed on different channels (Matrix, Fuz.re homepage), while respecting the privacy of attendants

Hardware

  • some glorious esp8266 in a Sonoff S20 power plug (NodeMCU v0.9 for development)

To flash a Sonoff S20, solder the pins on the left of the push button, connect your USB-to-Serial convertor (RobotDyn CH340G in this case) to the headers like in the image below (from top to bottom, GND, TX, RX, 3.3v VCC), push Sonoff button while plugging in your USB-to-Serial convertor in your PC and then release the push button after a few seconds (check out this link and that one). Don't forget about the SPIFFS setting in Arduino IDE as we are using it to store custom settings via WifiManager (see step 6 below).

Unplug the 3V3 VCC cable to be able to watch the serial monitor when the Sonoff is powered on through main else you will fry the esp. You can also flash Sonoff's esp like this (be careful to not touch main current through the Sonoff when manipulating it).
It also looks like when the program is of a given size, the USB/serial adapter (CH340G at least) is not able to give enough current for the esp to run properly (crashes in loop with stacktraces). An FTDI adapter looks more reliable.
You can also use screen /dev/ttyUSB0 115200 to watch the serial monitor, but Arduino IDE serial monitor is more practical to use as it is relaunched each time it detects when the USB/serial adapter is plugged to a running chip.

Using a FTDI as below is more practical and safer as it's able to properly power the Sonoff S20. Don't forget to set the jumper to 3.3V or you will fry the ESP.

Software

See Lomanic/presence-button on Github.

See presence-button project on glitch.com for the remote server part (sourcecode mirror).

Roadmap

  1. make the LED blink (GPIO 13 is the green LED, not 12 as it's the relay and blue LED)
  2. define how to detect the Fuz is open
  3. check out ArduinoOTA or similar for easy iterations
  4. connect to Fuz WiFi, would be great to use https://github.com/tzapu/WiFiManager
  5. send (reply?) message on Matrix (work is already done)
  6. make things easily configurable via internal webserver (WiFi, Matrix login/channel/message). I think tzapu/WiFiManager is able to do that, check out examples
  7. react to @mentions on Matrix
  8. handle long press for reset
  9. handle multiple Matrix rooms
  10. resolve HTTPS on the esp8266 directly
  11. properly notify when the Fuz is closed
  12. notify if the Fuz is open or closed on https://fuz.re
  13. investigate random crashes after some time, integrate the awesome EspSaveCrash library, maybe do as this dude here, but sending crash to HTTP server. See also https://arduino-esp8266.readthedocs.io/en/latest/faq/a02-my-esp-crashes.html
  14. ??
  15. profit!

Current status

  1. DONE the Fuz is open when there is electricity in the basement and someone pushes the button. Someone wants to push the button because the rotating light is lightened up by the Sonoff S20 when it is powered up and also each time someone mentions the Matrix account on Matrix ; the S20 disables the rotating light when the button is pressed
  2. DONE sonoff_s20_wifimanager_with_custom_settings_and_led_status_and_reset_button_and_aruinoota_and_matrix_message.ino, in case of Authenticating…FAIL 18:43:52 [ERROR]: ERR: ERROR[4]: Not Enough Space :-(https://www.esp8266.com/viewtopic.php?f=32&t=19064#p80107 (see also step 6) Sonoff S20 is not compatible with its only 1M flash
  3. DOING, currently struggling with HTTPS, try using httpUpdateSecure.ino (includes some NTP!!, see also esp8266/Arduino#4749 as it's not instant) or BearSSL_CertStore.ino DONE (HTTP only through proxy though)! See sonoff_s20_wifimanager_with_custom_settings_and_led_status_and_reset_button_and_matrix_message.ino
  4. DONE Yup sonoff_s20_wifimanager_with_custom_settings_and_led_status_and_reset_button.ino, but you have to properly set up your Arduino IDE like this
  5. DONE following matrix-esp8266.ino#L70-L109 sonoff_s20_multiwifi_matrix_events.ino (also implemented read receipts in sonoff_s20_wifimanager_longpress_matrix_events.ino so even if nobody mentions the Matrix account, we see it running) REMOVED in 4c74d44d02f1, to limit runtime crashes, useless feature
  6. DONE (only useful when using WifiManager) sonoff_s20_wifimanager_longpress_matrix_events.ino
  7. WON'T DO implemented in multiroom branch, but of little use
  8. DONE making the S20 regularly ping a remote server. This remote server would then send a message on Matrix saying Fuz is closed if it's not ping-ed after some delay. Implementing the latter using MQTT (PubSubClient library) HTTP polling. simpler, have an HTTP server on the S20 indicating if the button has been pushed once, and have an always-on esp8266 poll this webserver and notify the Matrix channel and a remote server when it's gone after a few minutes. S20 webserver done in sonoff_s20_wifimanager_longpress_matrix_events_webserver_admin.ino (with an admin interface as a bonus), S20 part done in 450fdfcddf5a187fb261470427bf255231f175d5, server side on the Glitch platform also done (via a JSON log file as container gets killed after a while and to be able to recover after being killed)
  9. “DONE” Unfortunately, EspSaveCrash is not able to save crash information on flash and was removed. Maybe a completely rework is needed as we may use too much RAM or something, where the ESP would only be pinging a remote server about its state and all the logic would be on this server (it would be the server that tells the ESP to turn on or off the rotating light). Maybe also remove @mentions handling as it's not used before a complete rework (removed.
  10. ??
  11. DOING, when people push the button and the button doesn't crash after some time

Today the button can notify on Matrix when it's pressed after initialization or after being notified on Matrix, and a server registers pings from the button to notify on Matrix that the Fuz is closed when it's not pinged anymore.

Next steps:

  1. huge refactoring of the code is needed, it's a huge pile of hacks, hard to work on, follow how it's done in this similar project (separate files?), also fix button reset with a ticker like in this project
  2. resolve HTTPS locally instead of relying on an HTTP/HTTPS proxy

Resources

Follow-up

  • Project created on Thu 19-09-19 by lomanic
projets/fuz/presence_button.txt · Last modified: 2020/05/11 00:02 by lomanic