Incorporating Matter

Good point.

FWIW I know that both Philips Hue API v2 bridges and HD Powerview Gen 3 gateways do support Matter. However as we already have OH integrations for those systems, the Matter integration is moot.

I took a peek at the Matter example for a Java controller. Itā€™s NOT a Java example. It is a Kotlin JNI wrapper around the C++ Matter reference implementation for what I surmise is for Android.

Would wraping this in an OH OSGI binding be accepted? Reversing/Decompiling the Kotlin to Java and refactoring it to an OH OSGI JNI wrapper?

Wrapping the Matter C++ makes me :face_vomiting:
But the level of effort for a pure java implementation is daunting.

I think the Bluetooth binding does something like that. If Iā€™m correct that means there is precedence. The challenge I think will be making it cross platform.

Hey guys, found something interesting over on AliExpress choice:

What I see is a 9 euro matter smart rgb bulb from zenismart with free shipping. Might be a good test case if anyone is willing to start looking at this matter thing.

Adding kotlin runtime library will increase weight of addon by significant amount. Yet it could be a smooth start for doing something. Making it an OSGi bundle may not be trivial, but definitely possible. We do have bunch of JNI libs such as rxtx/nrjavaserial and tinyb until it was maintained.

Was you able to confirm that library is functional?

Handling native libs in Java sucks, thatā€™s something which looks much more compact in Python. :wink:

I have not tried

I have not tried. The only Matter device I have is an Apple TV 4k, which is only a border router.

Yale Assure SL locks, of which I have 2, is supposed to be getting a Matter module (~$50 usd) which is supposed to be able to replace my Zigbee module, the only item on sale is the full lock. I am constantly checking for the module to be available.

1 Like

Github slapped me with this one: GitHub - Samsung/ioter: Ioter released by Samsung is an open-source implementation of the Matter Thread Emulator. Looks like there is software emulator. Since Thread stack will result in a new net interface I suppose it might be possible to attach to it without a RF dongle. All examples in README.md point to phone making an action, which means that whole thing probably goes via wifi to emulator.

Sorry i have missed this thread for so long! I have been casually pursuing a matter strategy for a little while, its probably a good time to share what iā€™m thinking and how I plan to spend my free time.

this is very tl;dr , just warning yaā€¦

So around Christmas I took a long weekend and was able to get a pure, non android build of the connectedhome (project chip) java client working, the basis of this can be found at https://github.com/project-chip/connectedhomeip/tree/master/examples/java-matter-controller, although i had to make a few tweaks.

While i did manage to get this working after a few long days, the road was not easy and it discovered many issues which ultimately led me to abandon using the main connectedhomeip (chip) project at all. Some of the issue i encountered:

  1. Thee project is painful to build, i mean really painful. I had to make several tweaks to the Make files to get this working, hand build several sub modules and dependent sub modules, and other build related changes, this is for the pure java version. Now, this could probably fixed with more time spent hardening the build and Make files, but thats no small feat. For anyone else who wants to try, I strongly recommend using their container (docker) based build system, trying to do it manually is difficult.

  2. Building anything in the project requires a full build of mostly everythingā€¦which is a lot! See point 3.

  3. The project is HUGE, the source alone is gigantic, by the time you download and build your working directory is over 20G+. This also means builds are SLOWā€¦

  4. The project is not entirely cross platform, it really wants to run on unix/linux/android and not windows. Not a problem for my system, but thinking about this for our community it seems like an issue. Also not all architectures are supported for the sub projects or example applications. This of course can be fixed through changing the build system / Make files in most cases, but that actually proved difficult ( i had a x86 build, was trying to get arm working which was not supported in the java app out of the box)

  5. The actual Java example app was buggy and missing a lot of features. In fact i experienced many issues which seem to plague some of the other CLI and wrapper apps, so i was not convinced this was strictly an issue with the Java example app.

  6. Its not clear that the non core example apps and libraries will be maintained over time. Development is sporadic on them, the main focus of this project is really around hardware manufacturers and embedded devices.

So again, i left with a pretty bad taste in my mouth, the idea of trying to maintain an integration using a java wrapper around the main project was not something i was interested in doing, and i think would be a maintenance nightmare over time.

So, i started to look else whereā€¦ and found another project written in pure Typescript.

This was interesting to me as we have a very high performance Javascript runtime engine in our core based on Graalvm. Looking more into this project reveled a lot of positives as a potential candidateā€¦in fact i would say it almost seemed designed to be embedded and checked a lot of boxes for me. The main developer is actually a member of the ioBroker project, another home automation system.

  1. The code is clean, easy to read, easy to build, easy to run.

  2. The project is split into 2 modules, a pure Typescript core and then a NodeJS implementation which provides the native bits for running like network, storage and crypto. This is done in a clean and pluggable architecture.

  3. It implements both a server and client , so not only can we control matter devices, we can expose local devices to other matter servers (like Alexa, Google Home or Apple Home).

  4. Very, very active project

  5. I was able to contribute and have my first PR accepted quickly :wink:
    Implements ManualPairingCodeSchema.decodeInternal() by digitaldan Ā· Pull Request #124 Ā· project-chip/matter.js Ā· GitHub , try that with the main chip project!

  6. The project has been adopted by the project-chip organization and lives in their github space, but is not run by the very big guys (apple, google, amazon, zensys) . This is actually a big deal, and really legitimizes the importance of this project, but still makes it easy to work with.

The lead dev and i have had a few conversations about this integration and he was very positive about supporting us and this use case, even suggesting we contribute a Java implementation to the project.

My plan is to get a proof of concept working, which requires loading the matter.js core along with a small sample typescript app and then providing it with Java implementations of the required network, storage and crypto , which so far seems very doable.

This is also still in the prototype / discovery phase, so of course lots could go wrong, and maybe it wonā€™t work, but iā€™m optimistic about it.

The only thing holding me back right now is time. Life has become very busy for me and i have not been able to break away and work on openHAB related stuff which has been super disappointing.

26 Likes

Youā€™re awesome, Dan. Per my earlier comments, this is exactly the scenario Iā€™ve been hoping for: openHAB connecting to a Matter network over WiFi, while other border routers provide onboarding/access to Thread devices.

I will optimistically look forward to hearing more. :wink:

2 Likes

Have you gotten anywhere?
Do you have a repo started?
I would LOVE to collaborate!

1 Like

Well, i have a messy POC actually working and talking with Matter devices. Iā€™m a little shocked its actually working, and working well !

25 Likes

Great news!
Any way to help? Maybe testing?
I was able to run matter-node.js and connect with devices from Alexa and Google Home ecosystems I have at home.
I also develop on OH (on Windows mainly)

Thatā€™s awesome, Dan.
I also have a few Nanoleaf devices that are supposed to work with matter and Development system where I could try out and provide feedback. Let me know if you need support.

Any progress on this?

Matter seems to have settled in, so it should be about time for openhab to incorporate it.

6 Likes

@digitaldan any news? :wink:

Yes actually. I have a working Matter binding here:

Currently it only supports IP based matter devicesā€¦ which at the moment is most matter devices. Thread based devices (those using a thread radio similar to zigbee) i plan on supporting through thread border routers, which include Apple TVs, Amazon Echos and Google homes (made in the last few years) as well the OpenThread Router. Its likely many users already have a thread router in their home.

I have tested this with the a Hue bridge as well as Leviton Wifi v2 dimmers and switches. Currently OnOff, Level Control (so dimmers) and Color control is implemented.

Iā€™ll do a formal write up on it soon, just cleaning up a few things. I plan on replacing about 50+ of my z-wave lights with matter in the next 12 months (i currently have 10 right now).

24 Likes

Thatā€™s exciting news, Dan! Iā€™m looking forward to your first release.

I guess Iā€™ll start adding some Matter devices to my Amazon wish list for testing purposes.

2 Likes

Fantastic news! Three Cheers for DigitalDan! :grin:

I would be interested to hear about which Zwave devices youā€™ve replaced and with what Matter devices. Also interested to hear of youā€™ve noticed any difference in responsiveness from the switches? Occasionally I still get a lag in response from my Zwave devices

1 Like

My main goal is to replace the around ~60 leviton z-wave dimmer and switches i have. I actually have 3 z-wave dongles spread across my house, and even then, my house makes it hard to get great coverage, so messages can take several hops, and on top of a heavily congested network, which means the delays can be significant for commands or updates.

On the other hand, i have a very robust Unifi wifi network with a lot of access points, so the tradeoff is having a lot more wifi clients and IPV6 traffic vs a dedicated radio network like z-wave, but i think thats going to be ok. There is always matter thread (like zigbee) devices, but there are not many on the market and i think i would suffer similar issues that i had with z-wave.

So i have 9 Levition Matter Wifi Dimmers and 2 Leviton Switches right now that iā€™m testing with, these replaced a bunch of Leviton z-wave dimmers i had in a troublesome part of the house.

Responsiveness is excellent so far.

I still plan on keeping my z-wave locks and somfy bridges, and probably a few other z-wave devices, but on a much smaller z-wave network.

2 Likes