# matter-rs: The Rust Implementation of Matter ![experimental](https://img.shields.io/badge/status-Experimental-red) [![license](https://img.shields.io/badge/license-Apache2-green.svg)](https://raw.githubusercontent.com/project-chip/matter-rs/main/LICENSE) [![Test Linux (OpenSSL)](https://github.com/project-chip/matter-rs/actions/workflows/test-linux-openssl.yml/badge.svg)](https://github.com/project-chip/matter-rs/actions/workflows/test-linux-openssl.yml) [![Test Linux (mbedTLS)](https://github.com/project-chip/matter-rs/actions/workflows/test-linux-mbedtls.yml/badge.svg)](https://github.com/project-chip/matter-rs/actions/workflows/test-linux-mbedtls.yml) ## Build Building the library: ``` $ cd matter $ cargo build ``` Building the example: ``` $ cd matter $ RUST_LOG="matter" cargo run --example onoff_light ``` With the chip-tool (the current tool for testing Matter) use the Ethernet commissioning mechanism: ``` $ chip-tool pairing ethernet 12344321 123456 0 5540 ``` Interact with the device ``` # Read server-list $ chip-tool descriptor read server-list 12344321 0 # Read On/Off status $ chip-tool onoff read on-off 12344321 1 # Toggle On/Off by invoking the command $ chip-tool onoff on 12344321 1 ``` ## Functionality - Secure Channel: - PASE - CASE - Interactions: - Invoke Command(s), Read Attribute(s), Write Attribute(s) - Commissioning: - over Ethernet - Network Commissioning Cluster - General Commissioning Cluster - Operational Certificates Cluster - Some [TODO](TODO.md) are captured here ## Notes The matter-rs project is a work-in-progress and does NOT yet fully implement Matter.