This article describes how to use CHIPTool for Android smartphones to commission a Nordic Semiconductor nRF52840 DK running nRF Connect Lock Example Application onto a CHIP-enabled Thread network. The instructions are also valid for nRF Connect Lighting Example Application.
The commissioning process is composed of the following main stages:
Bluetooth LE is only used during the commissioning phase. Afterwards, only the IPv6 connectivity between the smartphone and the accessory device is needed to send operational messages. The IPv6 address of the device is not exchanged during the commissioning process and CHIPTool must use DNS Service Discovery (DNS-SD) to learn or refresh the address before the controller initiates the IPv6-based communication.
Since a typical smartphone does not have a Thread radio built-in, extra effort is needed to prepare a fully-fledged testing environment. Refer to the OpenThread Border Router article to set up a Thread Border Router on a Raspberry Pi.
The following diagram shows the connectivity between network components required to allow communication between devices running the CHIPTool and Lock applications:
You need the following hardware and software for commissioning the nRF Connect accessory using Android CHIPTool:
Two nRF52840 DK (PCA10056)
Smartphone compatible with Android 8.0 or later
Raspberry Pi Model 3B+ or newer (along with an SD card with at least 8 GB of memory)
Wi-Fi Access Point supporting IPv6 (without the IPv6 Router Advertisement Guard enabled on the router)
Follow the OpenThread Border Router article to set up OpenThread Border Router on the Raspberry Pi, with either the nRF52840 DK or the nRF52840 Dongle acting as the OpenThread Radio Co-Processor.
See nRF Connect Lock Example Application README to learn how to build and program the example onto an nRF52840 DK.
To build the CHIPTool application for your smartphone, read Android CHIPTool README.
After building, install the application by completing the following steps:
Install the Android Debug Bridge (adb) package by running the following command:
$ sudo apt install android-tools-adb
Enable USB debugging on the smartphone. See the Configure on-device developer options guide on the Android Studio hub for detailed information.
If the Install via USB option is supported for your Android version, turn it on.
Plug the smartphone into a USB port on your PC.
Run the following command to install the application, with chip-dir replaced with the path to the CHIP source directory:
$ adb install -r chip-dir/src/android/CHIPTool/app/build/outputs/apk/debug/app-debug.apk
Navigate to settings on your smartphone and grant Camera and Location permissions to CHIPTool.
CHIPTool is now ready to be used for commissioning.
To prepare the accessory device for commissioning, complete the following steps:
Use a terminal emulator to connect to the UART console of the accessory device. For details, see the Using CLI in nRF Connect examples guide. This will grant you access to the application logs.
Hold Button 1 on the accessory device for more than 6 s to trigger the factory reset of the device.
Find a message similar to the following one in the application logs:
I: 615 [SVR]Copy/paste the below URL in a browser to see the QR Code: I: 621 [SVR]https://dhrishi.github.io/connectedhomeip/qrcode.html?data=MT%3AW0GU2OTB00KA0648G00
Open the URL in a web browser to have the commissioning QR code generated.
Press Button 4 on the device to start Bluetooth LE advertising.
To commission the accessory device onto the Thread network created in the Setting up Thread Border Router section, complete the following steps:
You will see the “Network provisioning completed” message when the accessory device successfully joins the Thread network.
Once the device is commissioned, the following screen appears:
The two textboxes at the top contain Fabric ID and Node ID of the last commissioned device.
Check the IPv6 connectivity with the device using the following steps:
Tap UPDATE ADDRESS to learn or refresh the IPv6 address of the device. CHIPTool will use a built-in DNS-SD client to resolve Fabric ID and Node ID of the device to its IPv6 address. The result of the operation, be it the address or an error message, will be displayed at the bottom of the screen.
Tap the following buttons to change the lock state:
The LED 2 on the device turns on or off based on the changes of the lock state.