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

ESPHome external component #25

Open
nholloh opened this issue Jun 9, 2024 · 21 comments
Open

ESPHome external component #25

nholloh opened this issue Jun 9, 2024 · 21 comments
Labels
enhancement New feature or request

Comments

@nholloh
Copy link

nholloh commented Jun 9, 2024

Currently, home assistant integration is done through MQTT with auto discovery. However, in my opinion, the integration in home assistant still offers potential for optimisation:

  1. Identifying bus messages to trigger various functions (door open, light, ...) is rather tedious, having to search through logbook, or by connecting the device via serial to a PC.
  2. Triggering the functions currently has to be done by performing a service call to either echo something through the serial connection or perform a service call to send an MQTT message to a predefined topic, which carries just the bus message that was previously recorded.
  3. The esp32 chip cannot be used for anything else, even though it might have resources to spare. That is, some people may find it useful to have it set up as bluetooth proxy for BLE devices, to extend home assistant's bluetooth coverage.

I believe there are multiple ways to address these issues.

I am currently exploring one of them, creating an external_component for esphome based on the gdoor code. In my opinion, esphome offers several advantages:

  1. it provides an easy way to configure the rx related settings in the device's yml
  2. it can provide an out-of-the-box feature to switch into a learning mode, where bus messages for certain actions (door open, light, ...) can be recorded
  3. we can distinct buttons and states for these actions
  4. the esp32 chip may additionally be used for something other than just being the gdoor adapter, by simply including that functionality in the device's yml.

For openHAB users I believe there is also a binding to include esphome devices, if desired.

Of course, most of this is also possible with the current firmware and MQTT based approach. However, I personally find the MQTT approach to be more verbose and it may require more knowledge on the user-side to get things up and running. Using esphome, we could reduce it to a couple of lines of yml code, which will be used by esphome to automatically compile the most recent firmware with default settings (of course you can override them) and flash that to the device.

I'd be keen to know any other Home Assistant user's take on this.

@DaSchaef
Copy link
Contributor

DaSchaef commented Jun 9, 2024

I think OpenHAB will work with either solution, as a OpenHAB user, I'm used to set it up more complicated.
My understanding of esphome is not good enough to judge, but GDoor currently needs multiple timers and interrupt,
don't know how good these low level needs will integrate into a framework.

@nholloh nholloh changed the title Options for Home Assistant integration ESPHome external component Jun 9, 2024
@nholloh
Copy link
Author

nholloh commented Jun 9, 2024

I am just getting into this, however esphome can use esp-idf or the arduino framework to compile, and compilation happens using platformio under the hood.

In the esphome component, you can implement a setup and a loop function, from which you have quite granular control over whatever it is you need to do. So from an API level perspective, I do not see an issue, actually the API looks quite similar to the main.cpp from gdoor. I took an attempt at porting:

void GDoorSensor::setup() {
    ESP_LOGI(TAG, "Setting up GDoorSensor");
    
    // TODO: Make sensitivity configurable.
    GDOOR::setRxThreshold(PIN_RX_THRESH, RX_SENS_MED_NUM);

    // TODO: Make RX PIN configurable.
    GDOOR::setup(PIN_TX, PIN_TX_EN, RX_PIN_22_NUM);

    // Publish initial idle state.
    publish_state(gdoor_data_idle.action);
}

void GDoorSensor::dump_config() { 
    ESP_LOGCONFIG(TAG, "GDoor text sensor");
}

void GDoorSensor::loop() {
    GDOOR::loop();

    GDOOR_DATA* rx_data = GDOOR::read();
    if(rx_data != NULL) {
        ESP_LOGI(TAG, "Received data from bus");
        GDOOR_DATA_PROTOCOL busmessage = GDOOR_DATA_PROTOCOL(rx_data);
        
        ESP_LOGD(TAG, "Data: ", busmessage);

        // Set sensor state.
        publish_state(busmessage.action);
        
        ESP_LOGD(TAG, "Sensor state set. Back to idle.");
        
        // TODO: Set sensor state back to idle.
        publish_state(gdoor_data_idle.action);
    }
}

From what I understand, timers and interrupts are part of the Arduino framework. Since you can configure esphome to build off the Arduino framework, this should(TM) theoretically work pretty much out of the box.

@jschroeter
Copy link
Collaborator

As a HA user, I do like the idea with ESPHome. I haven't done much with it yet but I do like the general concept and I expect it to work nicely. Further, I have the impression that the WifiManager is a bit buggy (e.g. it's leaking the Wifi password in the UI, I tried fixing it but couldn't get it to work) and not so well maintained. Mostly from a gut-feeling a think ESPHome is the more future-proof solution.

@nholloh
Copy link
Author

nholloh commented Jun 9, 2024

ESPHome is a first party add-on developed by the company that also develops home assistant and HAOS (nabucasa). That is, I expect this to be most future-proof.

image

@nholloh
Copy link
Author

nholloh commented Jun 9, 2024

So quick status report: I do have the first version of the firmware compiling, but I did need to make some changes to the gdoor code. The most significant being reverting from the v3 arduino framework apis (timer, ledc) to the v2 ones, since, for some reason, platformio has only published v2 versions.

I'll do a test run on my esp tomorrow evening and see if it succeeds in reading messages from the bus.

INFO ESPHome 2024.5.5
INFO Reading configuration /config/esphome/gdoor-test.yaml...
INFO Updating https://github.com/nholloh/gdoor-esphome.git@main
INFO Generating C++ source...
INFO Compiling app...
Processing gdoor-test (board: wemos_d1_mini32; framework: arduino; platform: platformio/[email protected])
--------------------------------------------------------------------------------
HARDWARE: ESP32 240MHz, 320KB RAM, 4MB Flash
 - toolchain-xtensa-esp32 @ 8.4.0+2021r2-patch5
Dependency Graph
|-- WiFi @ 2.0.0
|-- ESPmDNS @ 2.0.0
|-- Update @ 2.0.0
|-- noise-c @ 0.1.4
RAM:   [=         ]  12.8% (used 41792 bytes from 327680 bytes)
Flash: [=====     ]  48.1% (used 882081 bytes from 1835008 bytes)
========================= [SUCCESS] Took 15.15 seconds =========================
INFO Successfully compiled program.

@sim-san
Copy link

sim-san commented Jun 10, 2024

Reference to #27 (comment)

In the last Release of ESPHome, they also support Events on the ESPHome: ESPHome HA Events

@nholloh
Copy link
Author

nholloh commented Jun 10, 2024

image

The integration with esphome itself for just reporting the current bus status seems to be working, however during reverting to the v2 arduino APIs I probably killed the timers involved in decoding the bus signal. I'm rather busy this week so I don't expect to make a whole lot of progress until the weekend. In the meantime, if anybody wants to take a look, feel free to check out my code here: https://github.com/nholloh/gdoor-esphome. If you want to make some changes for testing, let me know and I can set permissions accordingly.

Here's the yml I use for testing:

esphome:
  name: gdoor-test
  friendly_name: GDoor_Test

esp32:
  board: wemos_d1_mini32
  framework:
    type: arduino

# Enable logging
logger:

# Enable Home Assistant API
api:

ota:

wifi:
  ssid: !secret wifi_ssid
  password: !secret wifi_password

external_components:
  - source: github://nholloh/gdoor-esphome@main
    refresh: 0s
    components: [ gdoor ]

text_sensor:
  - platform: gdoor
    name: 'BUS Status'
    id: gdoor_bus_status

@mrtnkhl
Copy link

mrtnkhl commented Jun 11, 2024

Side note: ESPHome would also potentially allow for audio support using the ESP32's internal ADC, see https://esphome.io/components/microphone/i2s_audio.html and https://esphome.io/components/speaker/i2s_audio for reference (I2S and internal ADC described under the same links).

@nholloh
Copy link
Author

nholloh commented Jun 11, 2024

Side note: ESPHome would also potentially allow for audio support using the ESP32's internal ADC, see https://esphome.io/components/microphone/i2s_audio.html and https://esphome.io/components/speaker/i2s_audio for reference (I2S and internal ADC described under the same links).

Might still require changes to the pcb, but it may make development of the component a lot easier.

There are three other things, which also come to mind with an i2s audio based speaker and mic configuration:

  1. you may play music to the person outside waiting, or use text to speech to give them a proper announcement (waiting, the door cannot be answered at the moment, …)
  2. You may add a voice mailbox sort of feature so that people can leave behind a message if you are unable to open the door.
  3. Speaker and mic are also the base for any assist pipeline in home assistant. Who wouldn‘t want their doorbell to be a voiced, interactive personal assistant? 😆

@mrtnkhl
Copy link

mrtnkhl commented Jun 11, 2024

Best thing is you don't even need any I2S hardware, other then some bus coupling per @DaSchaef AFAIK. See also: #20 for sample circuits.

From the ESPHome documentation, applies to both ADC and DAC:

adc_type (Required, enum):
internal: Use the internal ADC of the ESP32. Only supported on ESP32, no variant support.

Given that the door station audio is not hifi, we might get away with using the internal ESP32 ADC and DAC!

@mrtnkhl
Copy link

mrtnkhl commented Jun 11, 2024

@nholloh

  1. Speaker and mic are also the base for any assist pipeline in home assistant. Who wouldn‘t want their doorbell to be a voiced, interactive personal assistant? 😆

gdoor, HA assist pipeline and ChatGPT powered GIRA door station upon someone unauthorized trying to get into the building: "I'm sorry, Dave. I'm afraid I can't do that."

I cannot wait, this will be grand!

@nholloh
Copy link
Author

nholloh commented Jun 13, 2024

So the draft integration for ESPHome is working. I exposed the current bus state as text_sensor and was able to see events in the logbook as I pressed buttons on my doorbell.

The next step is to split the bus communication from the text sensor, separate them into individual components and add buttons for all the actions. Unfortunately all this work is far from simple as there is zero documentation on ESPHome custom components, so you have to dig through tons of python and cpp code in search for relevant example code that you can use as template. I'll try to get it done over the weekend.

image

@jschroeter
Copy link
Collaborator

Wow, that looks very promising, can't wait! Thanks for your efforts!

@DaSchaef
Copy link
Contributor

Very cool.

When it is working I suggest that we:

  • set the gdoor logic to a lib folder
  • make a abstraction layer (HAL) for both Arduino IDE versions
  • Then we can pull in the ESPhome and the ESP32 version, and let the ESP32 version get deprecated.

@DaSchaef DaSchaef mentioned this issue Jun 16, 2024
@DaSchaef DaSchaef added the enhancement New feature or request label Jun 19, 2024
@github-k8n
Copy link

Would be great to have this as an esphome component. @nholloh let me know if you have questions reg. this, i also had to teach myself esphome external components from scratch, maybe you can have a look at my component for vallox ventilation, it uses multiple different entities (buttons, numbers, sensors, selectors) so maybe it can help you a bit in understanding things...
https://github.com/kotope/valloxesp/tree/esphome

@nholloh
Copy link
Author

nholloh commented Jun 21, 2024

Hey @github-k8n, thanks for bringing this up. The documentation of esphome external components, or rather the lack thereof, really is frustrating. I'll take a look at your repo over the weekend.

I proposed to meet on discord to discuss some of the open topics here, since many of them seem to be connected to some extent. I believe your input could be super valuable, considering you probably have the most knowledge around esphome of all of us. Let me know if thats something you'd be interested in, then I'll send you the invite link.

@github-k8n
Copy link

@nholloh , sure, send me the link.

@nholloh
Copy link
Author

nholloh commented Jun 21, 2024

@allgrinder
Copy link

@nholloh
Is there already a new version regarding this? How far have you gotten?

@dtill
Copy link

dtill commented Dec 17, 2024

@nholloh how far is the esphome integration /custom_component? is your github component the last state? or did it go any further on hidden secret places ? would be highly interested - as soon as i get hands on some of these boards i want to try my luck in esphome as well. have some esphome experience but not much and willing to contribute.

@nholloh
Copy link
Author

nholloh commented Dec 18, 2024

Hi all, sorry for being a bit unresponsive lately. So I was unable to complete the esphome integration due to the lack of time on my side. Also I was having a hard time figuring out a proper way to get the esphome yaml validation to work with the structure I imagined. The lack of documentation on the development side of esphome is definitely not helpful. If anyone wants to give it a go I'd be happy to provide my last working version and the non-working version that aims for proper yaml structure. @dtill lets connect somehow once you have received your board and see if we can tinker together to make some progress here.

I'll provide the code latest on the weekend - not sure I'll get to it before that.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

8 participants