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

Matter support #2871

Open
derpate1989 opened this issue Nov 6, 2022 · 16 comments
Open

Matter support #2871

derpate1989 opened this issue Nov 6, 2022 · 16 comments

Comments

@derpate1989
Copy link

Hi, is a Matter Update possible? :) That would be a huge gain for Wled and various smart home systems.

@Aircoookie Aircoookie changed the title Matter Update possible? Matter support Nov 6, 2022
@Aircoookie
Copy link
Owner

Aircoookie commented Nov 6, 2022

Matter support would definitely be great as it might just be the missing link to make WLED devices work locally with all common smart speakers.
Right now I see three main issues, which I hope can be solved:

  • There should be an Arduino library for it (this seems like a starting point already)
  • It requires encryption, and unless the matter specification allows self-signed certs (which I doubt), it will be a pain to have a PKI infrastructure. Also, due to memory constraints, this will rule out matter ever working on ESP8266.
  • I am not sure whether Bluetooth provisioning is optional or a core requirement of the Matter specification. Bluetooth on ESP32 is supported, but uses an extreme amount of memory and storage, which is why we steered clear of using it within WLED thus far.

Still I am enthusiastic for the Matter standard, if only for realizing that a unified smart home standard is necessary and that mandatory device vendor clouds are a terrible idea.

@derpate1989
Copy link
Author

Thank you for this detailed explanation! I have a lot of hope in Matter and look forward to this standard. Maybe someday there will be a way for Wled and Matter :)

@DoomHammer
Copy link

Matter support would definitely be great as it might just be the missing link to make WLED devices work locally with all common smart speakers. Right now I see three main issues, which I hope can be solved:

  • There should be an Arduino library for it (this seems like a starting point already)
  • It requires encryption, and unless the matter specification allows self-signed certs (which I doubt), it will be a pain to have a PKI infrastructure. Also, due to memory constraints, this will rule out matter ever working on ESP8266.
  • I am not sure whether Bluetooth provisioning is optional or a core requirement of the Matter specification. Bluetooth on ESP32 is supported, but uses an extreme amount of memory and storage, which is why we steered clear of using it within WLED thus far.

Still I am enthusiastic for the Matter standard, if only for realizing that a unified smart home standard is necessary and that mandatory device vendor clouds are a terrible idea.

If it's not possible to do entirely on a device, maybe a bridge could help here?

@Aircoookie
Copy link
Owner

That's a nice idea, it should definitely be feasible to make some software to act as a bridge between the JSON API and Matter protocol(s), and it would even support ESP8266 units. Native support would be ideal though.

@jasta
Copy link

jasta commented Nov 25, 2022

  • I am not sure whether Bluetooth provisioning is optional or a core requirement of the Matter specification. Bluetooth on ESP32 is supported, but uses an extreme amount of memory and storage, which is why we steered clear of using it within WLED thus far.

I don't believe it is. The spec says that there are 3 methods, BLE, WiFi SoftAp (which no one is using today unfortunately), but also existing DNS-SD if you're already on the local network. This last case seems perfect for WLED which is already so easy to get setup to connect to WiFi.

It seems that it just needs to register some mDNS records like _matter._udp/_tcp maybe? I'm still trying to get full access to the spec to read the details myself and start playing around with this a bit.

@Chase295
Copy link

Chase295 commented Jul 4, 2023

Is there any new stuff or soultion a "bridge" or any think else becous i would like to add it in the nanoleaf app for the new Nanoleaf 4D

@blazoncek
Copy link
Collaborator

Unless someone with knowledge and programming skills joins in there will be no progress.

@heho0011
Copy link

heho0011 commented Jul 10, 2023

Hi,
maybe Matter can be implemented the same way as in tasmota for esp32?
https://github.com/arendst/Tasmota/discussions/17872?sort=new

@Stoffe
Copy link

Stoffe commented Aug 9, 2023

Seems like Espressif has a new esp32 with support?
https://www.espressif.com/en/news/ESP32-C6_Available

And using Yacubane esp32 lib, you could maybe implement matter in esp32 or take ideas from...
https://github.com/Yacubane/esp32-arduino-matter
Here is a video of the install, https://www.youtube.com/watch?v=HpACspFygUI

might be something to look into...
I would also upvote this feature for sure.

@marcoscv-work
Copy link
Contributor

I have seen that tasmota already has support for Matter. I've been testing and works fine in homekit. it's interesting because they provide ESP8266 support by ESP32, Looks promising and a really good idea.
https://tasmota.github.io/docs/Matter/

Right now all solutions to integrate WLED in homekit are pretty painful, implementing matter in some way would be awesome.

@jonahnm
Copy link

jonahnm commented Sep 29, 2023

I will be attempting to implement this soon.

@khimaros
Copy link

@Aircoookie thank you for the detailed breakdown, a few questions inline:

* There should be an Arduino library for it ([this](https://github.com/jakubdybczak/esp32-arduino-matter) seems like a starting point already)

what sort of signal would you look for in this library to consider it ready for use in WLED?

i filed Yacubane/esp32-arduino-matter#44 re: publishing to platformio registry, but i'm not sure if you consider this a blocker.

* It requires encryption, and unless the matter specification allows self-signed certs (which I doubt), it will be a pain to have a PKI infrastructure. Also, due to memory constraints, this will rule out matter ever working on ESP8266.

from what i've been able to find, there is no restriction placed on which CAs are used or any other verbiage limiting use of self-signed certificates in the spec.

if this were restricted, a workaround is to use LetsEncrypt with real domain name the user controls, or to trust/use a services such as https://sslip.io/ or https://backname.io/ to get valid certs with any IP address (including private blocks).

* I am not sure whether Bluetooth provisioning is optional or a core requirement of the Matter specification. Bluetooth on ESP32 is supported, but uses an extreme amount of memory and storage, which is why we steered clear of using it within WLED thus far.

the library you linked (https://github.com/jakubdybczak/esp32-arduino-matter) "comes with precompiled NimBLE, because default Bluedroid shipped with arduino-esp32 takes too much RAM memory", does that resolve your concern?

Still I am enthusiastic for the Matter standard, if only for realizing that a unified smart home standard is necessary and that mandatory device vendor clouds are a terrible idea.

it would be awesome for users to be able to use their existing apps and assistants to also control their WLED devices. great for spouse approval of these devices :)

@chikko80
Copy link

chikko80 commented Oct 27, 2024

@khimaros @Aircoookie

espressif/arduino-esp32#10467

Maybe i am wrong here, i am relatively new to this space, but i stumbled across this merge request from espressif which was merged very recently and seems to add matter support for esp32.
Can you work with that?

There is also an example:

https://github.com/espressif/arduino-esp32/tree/master/idf_component_examples/esp_matter_light

@softhack007
Copy link
Collaborator

softhack007 commented Oct 27, 2024

@chikko80 thanks for the hint 👍

Its a PR for arduino-esp32 v3.1, so unfortunately it's still far away from us - we are using v2.0.9 right now for some boards.

At the moment we cannot upgrade a newer arduino version for several reasons

  • bugs in the new arduino framework - espressif needed 2 years to make v2.0.x usable and stable, then declared it unsupported once it was usable. So I expect the same for v3.1 which is not released yet.
  • WLED does not compile with the new arduino framework v3.0.x - to many breaking changes introduced by espressif
  • flash size - 4MB boards would be too small for WLED if using the latest framework.
  • PlatformIO does not support the new v3.0.x arduino framework, and it's questionable if this will change.

But time will tell, and maybe in a few years from now we can use matter support provided by arduino-esp32 v3.1.x.

@jonahnm
Copy link

jonahnm commented Nov 22, 2024

I will be attempting to implement this soon.

And then I forgot!

@khimaros
Copy link

there is a community supported PlatformIO module with support for arduino core 3.0.x: https://github.com/pioarduino/platform-espressif32 -- see also espressif/arduino-esp32#10039

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