How do I Unify thread networks?

One of my SmartThings Station hubs has updated to Firmware 58.10 so now I have the option to unify my Thread networks.

At home I currently have 2 Thread Networks. One created by a ST Station and 1 created by an Alexa Echo Gen. 4 speaker.

My question is how do I combine them?

In the ST mobile app I go to the Station > Settings > Manage Thread Networks. It only shows the network created by the Station. If I click the “Unify Thread network” I get and option to “Share this hubs Thread network and allow other Border Routers to join it”. When I hit next I get a “Start Sharing” button. When I press the button I get a 9 digit code or I can generate a QR code. It says to use in in the “other service app.

This is where I get stuck. What do I do with this code? I don’t see a way to add it in the Alexa App.

Thread 1.4 credential sharing must be implemented only by SmartThings at the moment.

The only way to unify networks would be the old Thread 1.3 way which implies using the preferred network in Android/iPhone and factory reset one of the hubs so it hopefully joins it.

Check if SmartThings is the preferred Thread network in Android settings (or the equivalent in iPhone) and then factory reset the Echo so hopefully will join SmartThings. Or viceversa, but I guess you don’t want to factory reset ST hehe (maybe just removing Thread devices will do though and reset is not needed)

Anyway, are you sure you want to include a WiFi based Thread border router in the mix? Well, the Station is too so never mind.

So my Echo gen. 4 is the preferred thread network. I only have 2 Nanoleaf bulbs connected to it so I could easily reset it. The should make my Station the preferred network. Then I can try re-adding the Echo Gen. 4.

Is that a logical approach?

I don’t think it works that way, back in the day SmartThings didn’t store the credentials so they’re probably not there.

Do you have many Thread devices in SmartThings? You could try removing them and in the Unify button select Join network, ST should be able to read the Echo credentials and join it.

There’s a third option which is what I used but that involves a Home Assistant virtual machine.

I only have 3 thread devices, 2 connected to Echo, and 1 connected to Station. So I could delete them and start over.

The Station has lots of Zigbee and Matter devices connected to it, so I don’t want to reset it. Echo reset would be fairly easy.

I do have Home Assistant set up and have been using it for 8 or 9 months.

I don’t think you need to reset the Station, but for the Unify - Join it says there cannot be devices connected (I assume Thread?).

Since you have Home Assistant you can make the ST network your preferred one even if ST didn’t write it. And then you could try the Echo reset. But maybe try first removing the one Thread device from ST and see if the Join option enables or not.

1 Like

Strange how the Station is left out in this article.

1 Like

Ok Thread wizards, I could use some guidance. I know have 4 different Thread Networks and TBRs in 3 ecosystems:

  • Eero Pro 7 Thread 1.3
  • Alexa/Echo Show 8 Thread 1.3
  • Smartthings Fridge Family Hub Thread 1.?
  • Smartthings Station Thread 1.4

From my Android phone, I see that I have 4 different Thread networks:

  • eero-thread-9409
  • ST-3KWW (Station)
  • ST-Tizen (Family Hub)
  • AMZN-Thread-55db

From a server on my network, I see I have 5 different TBRs on both IPv4 and IPv6:

bep@debian12:~$ dns-sd  _meshcop._udp -r
+  ens33 IPv6 Samsung SmartThings-Station #A2DF             _meshcop._udp        local
+  ens33 IPv6 amazon #D4B4 (3126)                           _meshcop._udp        local
+  ens33 IPv6 eero_thread #6FE0                             _meshcop._udp        local
+  ens33 IPv6 eero_thread #A103                             _meshcop._udp        local
+  ens33 IPv6 OpenThread BorderRouter #0B28                 _meshcop._udp        local
+  ens33 IPv4 OpenThread BorderRouter #0B28                 _meshcop._udp        local
+  ens33 IPv4 Samsung SmartThings-Station #A2DF             _meshcop._udp        local
+  ens33 IPv4 amazon #D4B4 (3126)                           _meshcop._udp        local
+  ens33 IPv4 eero_thread #6FE0                             _meshcop._udp        local
+  ens33 IPv4 eero_thread #A103                             _meshcop._udp        local
=  ens33 IPv6 OpenThread BorderRouter #0B28                 _meshcop._udp        local
   hostname = [Samsung-FamilyHub.local]
   address = [192.168.1.148]
   port = [49154]
   txt = ["omr=@\253\024\227\216\018\166\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=." "pt=^g\130Y" "at=\000\000h\219\187F\000\000" "sb=\000\000\001\177" "xa=\230;\223\002\031\164\011(" "tv=1.3.0" "xp=\163\247Ng\236\205B\001" "nn=ST-TIZEN" "mn=BorderRouter" "vn=OpenThread" "id=\178A\249\253\138\1887c\161ZQ\131\222\195\134\208" "rv=1"]
=  ens33 IPv4 OpenThread BorderRouter #0B28                 _meshcop._udp        local
   hostname = [Samsung-FamilyHub.local]
   address = [192.168.1.148]
   port = [49154]
   txt = ["omr=@\253\024\227\216\018\166\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=." "pt=^g\130Y" "at=\000\000h\219\187F\000\000" "sb=\000\000\001\177" "xa=\230;\223\002\031\164\011(" "tv=1.3.0" "xp=\163\247Ng\236\205B\001" "nn=ST-TIZEN" "mn=BorderRouter" "vn=OpenThread" "id=\178A\249\253\138\1887c\161ZQ\131\222\195\134\208" "rv=1"]
=  ens33 IPv4 Samsung SmartThings-Station #A2DF             _meshcop._udp        local
   hostname = [smartthings-station-3KWW-2.local]
   address = [192.168.1.177]
   port = [49154]
   txt = ["omr=@\253\015w\238D\224\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=p" "pt=\202&SZ" "at=\000\000h\230\186e\000\000" "sb=\000\000\013\177" "xa=R\019\031GN\229\162\223" "tv=1.4.0" "xp=s8\164ic>\251\191" "nn=ST-3KWW" "mn=SmartThings-Station" "vn=Samsung" "id=su\2406tm\210\221u[\194\01774'\255" "rv=1"]
=  ens33 IPv4 amazon #D4B4 (3126)                           _meshcop._udp        local
   hostname = [none-106.local]
   address = [192.168.1.121]
   port = [49154]
   txt = ["omr=@\253T\232;\135m\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=6" "pt=Y\192\254m" "at=\000\000\000\000f\144P%" "sb=\000\000\001\177" "xa=\014\003(\156\237^\212\180" "tv=1.3.0" "xp=\234\239\001N/\149\240" "nn=AMZN-Thread-55db" "mn=echo" "vn=amazon" "id=Yju;q\238\171q\155}\011\252(/\206\234" "rv=1"]
=  ens33 IPv4 eero_thread #6FE0                             _meshcop._udp        local
   hostname = [eero-pro-7-09ge.local]
   address = [192.168.1.163]
   port = [49155]
   txt = ["omr=@\253,\003j\009I\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=~" "pt=2\195\200o" "at=\000\000h\226\169`\000\000" "sb=\000\000\015\177" "xa=\130\204\247\165F\167o\224" "tv=1.4.0" "xp=\029c$#l{\240." "nn=eero-thread-9409" "mn=thread" "vn=eero" "id=82ccf7a546a76fe0" "rv=1"]
=  ens33 IPv4 eero_thread #A103                             _meshcop._udp        local
   hostname = [eero-pro-7-08kx.local]
   address = [192.168.1.126]
   port = [49155]
   txt = ["omr=@\253,\003j\009I\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=\\" "pt=2\195\200o" "at=\000\000h\226\169`\000\000" "sb=\000\000\012\177" "xa=\138;\247\194[3\161\003" "tv=1.4.0" "xp=\029c$#l{\240." "nn=eero-thread-9409" "mn=thread" "vn=eero" "id=8a3bf7c25b33a103" "rv=1"]
=  ens33 IPv6 eero_thread #A103                             _meshcop._udp        local
   hostname = [eero-pro-7-08kx.local]
   address = [2600:1700:dce0:4790:1aa9:edff:fe7d:8092]
   port = [49155]
   txt = ["omr=@\253,\003j\009I\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=\\" "pt=2\195\200o" "at=\000\000h\226\169`\000\000" "sb=\000\000\012\177" "xa=\138;\247\194[3\161\003" "tv=1.4.0" "xp=\029c$#l{\240." "nn=eero-thread-9409" "mn=thread" "vn=eero" "id=8a3bf7c25b33a103" "rv=1"]
=  ens33 IPv6 amazon #D4B4 (3126)                           _meshcop._udp        local
   hostname = [none-106.local]
   address = [2600:1700:dce0:4790:64d9:e7ce:9212:c05]
   port = [49154]
   txt = ["omr=@\253T\232;\135m\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=6" "pt=Y\192\254m" "at=\000\000\000\000f\144P%" "sb=\000\000\001\177" "xa=\014\003(\156\237^\212\180" "tv=1.3.0" "xp=\234\239\001N/\149\240" "nn=AMZN-Thread-55db" "mn=echo" "vn=amazon" "id=Yju;q\238\171q\155}\011\252(/\206\234" "rv=1"]
=  ens33 IPv6 eero_thread #6FE0                             _meshcop._udp        local
   hostname = [eero-pro-7-09ge.local]
   address = [2600:1700:dce0:4790:1aa9:edff:fe7c:da92]
   port = [49155]
   txt = ["omr=@\253,\003j\009I\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=~" "pt=2\195\200o" "at=\000\000h\226\169`\000\000" "sb=\000\000\015\177" "xa=\130\204\247\165F\167o\224" "tv=1.4.0" "xp=\029c$#l{\240." "nn=eero-thread-9409" "mn=thread" "vn=eero" "id=82ccf7a546a76fe0" "rv=1"]
=  ens33 IPv6 Samsung SmartThings-Station #A2DF             _meshcop._udp        local
   hostname = [smartthings-station-3KWW-2.local]
   address = [2600:1700:dce0:4790:13fb:e77f:7f16:57a1]
   port = [49154]
   txt = ["omr=@\253\015w\238D\224\000\001" "dn=DefaultDomain" "bb=\240\191" "sq=p" "pt=\202&SZ" "at=\000\000h\230\186e\000\000" "sb=\000\000\013\177" "xa=R\019\031GN\229\162\223" "tv=1.4.0" "xp=s8\164ic>\251\191" "nn=ST-3KWW" "mn=SmartThings-Station" "vn=Samsung" "id=su\2406tm\210\221u[\194\01774'\255" "rv=1"]

If I go to the ST app and look at “Manage Thread network” for my Station, the only network I see is the one from the Station and the only option I have to Unify is to “Share this hub’s Thread network…”.

A little research with our friend chatGPT leads me to believe 1) there is no way to unify my Thread networks because they are all not at Thread 1.4; and 2) there is no way for the non-ST TBRs to be TBRs in ST.

So, am I stuck with 4 Thread networks and 4 disparate sets of TBRs until the other ecosystems catch up to ST?

I have had no luck unifying my thread networks and have given up for the time being.

1 Like

When I was trying this I chose my google thread network but it ignored that and I ended up with my ST V3 primary and Aeotec Hub secondary unified with the same ST thread network.

Both my Eero router and Tuya bridge show as 1.4 on Discovery (iPhone) and on Matter Utilities. The result when I try to unify from my V3 is the same as yours……

Would seem to be the case, borne out by @Andrew_Bartlett post where both are ST/Aeotec.

I take it that is still in the context of unifying networks? ST can, of course, use Thread networks formed by other TBRs and other TBRs can join the ST hub formed network. How much heavy lifting can is doing in that sentence (twice) is another matter.

I think of the terms primary and secondary as referring to hubs in ST hub groups and if so then they should have been in the same thread network to start with. All the hubs end up in the thread network that the original primary was in. They stay that way even when you remove them from the hub group.

Since at the moment nobody but SmartThings is supporting the one time passcodes of Thread 1.4 credential sharing you have to use the old methods relying on the Android/iOS credential storage to make others join SmartThings network or allow SmartThings to join them.

It’s how my DIRIGERA joined my SmartThings Thread network before the recent Thread 1.4 credential sharing updates. I had to previously set ST network as the preferred one in my Android phone with the help of Home Assistant since the preferred one was Google Home and I didn’t really want to join that.

1 Like

If you don’t mind: Reddit Thread thread.

I was able to combine my ST Station thread network with my Apple Home one after removing any Thread devices connected to it. I don’t know exactly how or why it worked, but the utility in the SmartThings app worked first try. I do run Home Assistant as my primary smart home platform, so maybe something there helped.

I removed the secondary hub (aeotec) from the hub group and it created a seperate ST thread network.

I then unified it with my Aqara hub which was already using my nest thread network and it joined that.

I then added the aeotec to a hub group and it left the nest thread network and joined the ST V3 thread network and became a secondary hub.

How did you do that? There are no Thread devices attached to my Eero, my ST Family Hub, or my Echo Show Thread networks and yet none of those show up in the “Manage Thread Network” in the mobile app for my ST Station. And, as far as I can tell, there is no provision for Eero devices to do anything other than have their own Thread network. I also can’t find anything that says how you can make an Echo device join another Thread network.

That’s interesting. When I first messed around with hub groups I am sure that is how it worked for me, and it was the reason I stuck with hub groups for far longer than I wanted to (I didn’t want the hub group, but I did want all the hubs on the same thread network). Then when the last firmware update came along I removed the hubs from the group and found they had kept the same thread network.

I should note that all my secondary hubs would have spent some time acting as the primary hub in the intervening period.

I don’t know, I guess Aqara are following the specs properly.

Yup. Same experience I had with Aqara and my Apple Home thread network.