blob: 1b545ce36ead2749061dfb735919c3dfef1ab1f6 [file] [log] [blame] [view]
# Fabric Synchronization Guide
- [Fabric Synchronization Guide](#fabric-synchronization-guide)
- [Fabric Sync Example Applications](#fabric-sync-example-applications)
- [Run Fabric Sync Demo on RP4](#run-fabric-sync-demo-on-rp4)
## Fabric Sync Example Applications
Fabric-Admin and Fabric-Bridge example applications are provided to demonstrate
Fabric Synchronization feature. You can find them in the examples.
![matter_fabric_synchronization](images/matter_fabric_synchronization.png)
Fabric-Admin example app implements the Fabric Administrator role and
communicates with the Fabric-Bridge-App on the other side, facilitating the
Fabric Synchronization process.
Fabric-Bridge-App example app implements the Aggregator device type with Fabric
Synchronization condition met and demonstrates the end-to-end Fabric
Synchronization feature using dynamic endpoints.
The Fabric-Admin and Fabric-Bridge-App example applications must be executed on
the same physical device and communicate with each other using RPC.
Fabric Synchronization can be triggered from either side. The initiator of the
Fabric Synchronization process, who shares their devices, takes on the
Commissioner role. The recipient of the Fabric Synchronization request, who
receives the shared devices, assumes the Commissionee role. This flexibility
enables a seamless and efficient synchronization process.
### Building the Example Application
- Building the Fabric-Admin Application
[Fabric-Admin](https://github.com/project-chip/connectedhomeip/tree/master/examples/fabric-admin/README.md)
* Building the Fabric-Bridge Application
[Fabric-Bridge](https://github.com/project-chip/connectedhomeip/tree/master/examples/fabric-bridge-app/linux/README.md)
## Run Fabric Sync Demo on RP4
### Setup Fabric Source
Connect to the Fabric Source server:
```
ssh ubuntu@xxx.xxx.xxx.xxx
```
Password: <password>
Run the Fabric Source script:
```
./run_fabric_source.sh
```
### Setup Fabric Sink
Connect to the Fabric Sink server:
```
ssh ubuntu@xxx.xxx.xxx.xxx
```
Password: <password>
Run the Fabric Sink script:
```
./run_fabric_sink.sh
```
### Fabric Sync Setup
Enable Fabric Auto Sync:
In Fabric-Sync console:
```
fabricsync enable-auto-sync 1
```
Pair the Fabric-Source bridge to Fabric-Sync with node ID 1:
```
fabricsync add-bridge 1 <fabric-source-bridge-ip>
```
### Pair Light Example to Fabric-Source
Since Fabric-Bridge also functions as a Matter server, running it alongside the
Light Example app on the same machine would cause conflicts. Therefore, you need
to run the Matter Light Example app on a separate physical machine from the one
hosting Fabric-Admin and Fabric-Bridge. You can then commission the Matter Light
Example app using Fabric-Admin on the source side.
There is a workaround to avoid conflicts when running multiple Matter server
applications on the same machine, you can use different ports and unique
Key-Value Store (KVS) paths for each app. Here's an example of how to launch a
Light App with custom settings:
Light App with yet another set of different discriminator/passcode, ports and
KVS
```
./out/linux-x64-light-clang/chip-lighting-app --discriminator 3843 --passcode 20202023 --secured-device-port 5543 --unsecured-commissioner-port 5553 --KVS /tmp/chip_kvs_lighting_app
```
Pair the Light Example with node ID 3 using its payload number:
```
pairing already-discovered 3 20202021 <ip> 5540
```
After the Light Example is successfully paired in Fabric-Source, it will be
synced to Fabric-Sink with a new assigned node ID.
Toggle the Light Example:
From Fabric-Source:
```
onoff on <node-id> 1
onoff off <node-id> 1
```
From Fabric-Sink: (Use the node ID assigned)
```
onoff on x 1
onoff off x 1
```
### Remove Light Example from Fabric-Source
Unpair the Light Example:
```
pairing unpair <node-id>
```
After the Light Example is successfully unpaired from Fabric-Source, it will
also be removed from the Fabric-Sink.
### Pair Commercial Switch to Fabric-Source
Pair the switch using its payload number:
In Fabric-Source console:
```
pairing code-wifi <node-id> <ssid> <passwd> <payload>
```
After the switch is successfully paired in Fabric-Source, it will be synced to
Fabric-Sink with a new assigned node ID.
Toggle the switch:
From Fabric-Source:
```
onoff on <node-id> 1
onoff off <node-id> 1
```
From Fabric-Sink: (Use the node ID assigned)
```
onoff on <node-id> 1
onoff off <node-id> 1
```
### Remove Switch from Fabric-Source
Unpair the switch:
```
pairing unpair <node-id>
```
After the switch is successfully unpaired from Fabric-Source, it will also be
removed from the Fabric-Sink.