Supported Targets ESP32 ESP32-C3 ESP32-C6 ESP32-H2 ESP32-S3

Remote Provisioning

(See the README.md file in the upper level 'examples' directory for more information about examples.)

The example is primarily used to demonstrate the new Remote Provisioning feature added in Mesh Protocol v1.1.

How to use example

Please refer to this tutorial for detailed instructions on how to run it.

Hardware Required

You need prepare at least three ESP series development boards. We recommend using the ESP32-C3-DevKitM-1 or ESP32-C6-DevKitC-1. Alternatively, you can use other development boards, but ensure that each board has at least one LED and one button for operation.

Configure the project

idf.py menuconfig

Build and Flash

Build the project and flash it to the board, then run monitor tool to view serial output:

idf.py -p PORT flash monitor

(Replace PORT with the name of the serial port to use.)

(To exit the serial monitor, type Ctrl-].)

See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects.

Example Output

When a device that runs the rpr_server joins the network, the device that runs the rpr_client will have the following log output:

The Remote Provisioning Server have been provisioned, You could click button to start remote provisioning

After seeing this output log, you can press the button on the device running rpr_client to initiate the Remote Provisioning process.

After successfully joining the network through Remote Provisioning, the device running rpr_client will have the following log output:

Remote Prov Client Prov Complete
Net Idx: `net index`
Node addr: `node address`
Node element num: `element num`
Node UUID: `UUID`

(The content wrapped with will vary depending on the device you are actually using.)

Afterwards, you can press the button on the device running rpr_client to toggle the LED settings of other devices in the network.

Troubleshooting

See common troubleshooting for Directed Forwarding examples from ESP-BLE-MESH FAQ.

(For any technical queries, please open an issue on GitHub. We will get back to you as soon as possible.)