Matter Controller Java App Example

This is a Matter Controller Java app that can be used to commission and control Matter accessory devices. It offers the following features: - Commission a Matter device - Send echo requests to the Matter echo server - Send on/off cluster requests to a Matter device

Requirements for building

You need to have the following two software installed on your Ubuntu system:

  1. Java Runtime Environment (JRE)
  2. Java Development Kit (JDK)
java -version

This will ensure either Java Runtime Environment is already installed on your system or not. In order to install the Java Runtime Environment on your system, run the following command as root:

sudo apt install default-jre Install Java default JRE

After installing the JRE, let us check if we have the Java Development Kit installed on our system or not.

javac -version

The above output shows that I need to install the Java compiler or the JDK on my system. You can install it through the following command as root:

sudo apt install default-jdk

You also need to install kotlin compiler on your Ubuntu system:

kotlin compiler version 1.8.10 or above is needed to compile java-matter-controller, if you already have lower version kotlin compiler installed on your Ubuntu from apt,
you need to remove the Kotlin compiler package, run the following command:

sudo apt-get remove kotlin

Wait for the removal process to complete. Once it's done, the Kotlin compiler will be removed from your system.

(Optional) If you want to remove any configuration files associated with Kotlin, run the following command:

sudo apt-get purge kotlin

Install kotlin compiler 1.8.10 or above, such as kotlin-compiler-1.8.10-url

cd /usr/lib \
&& sudo wget -q [kotlin-compiler-1.8.10-url] \
&& sudo unzip kotlin-compiler-*.zip \
&& sudo rm kotlin-compiler-*.zip \
&& sudo rm -f kotlinc/bin/*.bat

Add a directory to PATH permanently by editing the .bashrc file located in the Home directory. Follow these steps:

  1. Open the .bashrc file using a text editor.
  2. Go to the end of the file.
  3. Paste the export syntax at the end of the file.
export PATH="/usr/lib/kotlinc/bin:$PATH"

Linux

export JAVA_PATH=[JDK path]

Preparing for build

Complete the following steps to prepare the Matter build:

  1. Check out the Matter repository.

  2. Run bootstrap (only required first time)

    source scripts/bootstrap.sh
    

Building & Running the app

This is the simplest option. In the command line, run the following command from the top Matter directory:

./scripts/build/build_examples.py --target linux-x64-java-matter-controller build

The Java executable file java-matter-controller will be generated at out/linux-x64-java-matter-controller/bin/

Run the java-matter-controller

java -Djava.library.path=../lib/jni -jar java-matter-controller