Last Updated on : 2024-06-24 06:18:10download
This topic describes how to interface your MCU with Tuya’s Wi-Fi module that can be connected to both the Tuya Developer Platform and the Apple HomeKit platform. After implementing the serial protocol, your product can communicate with Tuya’s Wi-Fi module and interact with ‘Powered by Tuya’ products and HomeKit-compatible products.
Field | Bytes | Description |
---|---|---|
Header | 2 | It is fixed to 0x55aa . |
Version | 1 | It is used for updates and extensions. |
Command | 1 | Frame type |
Data length | 2 | Big-endian |
Data | N | Entity data |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
All data greater than one byte is transmitted in big-endian format.
Generally, one command is sent by one party and received by the other party synchronously. That is, one party sends a command and waits for a response from the other party. If the sender does not receive a correct response packet within a specified time period, the transmission times out, as shown in the following figure.
For specific communication modes, see the protocol list in this topic.
The module sends control commands and the MCU reports data point (DP) status, which occurs asynchronously. Assume that the module sends a command x
and the MCU reports a command y
. The data transmission is as follows.
The module sends a control command:
The MCU reports status:
The DP command and status data unit are defined as follows:
Data segment | Bytes | Description |
---|---|---|
dpid | 1 | The ID of a DP. |
type | 1 | The data type of a DP is defined on the Tuya Developer Platform. For more information, see the table of type fields below. |
len | 2 | The length is the number of bytes of a value. |
Value | 1/2/4/N | Represented in hexadecimal format. Data greater than one byte is transmitted in big-endian format. |
Type fields
type | Type | Data length (byte) | Description |
---|---|---|---|
0x00 | Raw | N | Represents a DP of raw data type. The data is passed through the module to the cloud. |
0x01 | Boolean | 1 | Represents a DP of Boolean data type. Valid values include 0x00 and 0x01 . |
0x02 | Value | 4 | Represents a DP of integer type. The data is represented in big-endian format. |
0x03 | String | N | Represents a DP of string type. |
0x04 | Enum | 1 | Represents a DP of enum type, ranging from 0 to 255. |
0x05 | Bitmap | 1/2/4 | Represents a DP of fault type. Data greater than one byte is represented in big-endian format. |
raw
data type, all others belong to the object type.After the Wi-Fi module is powered on, it sends heartbeats to the MCU every 15 seconds. If the MCU does not respond within the 3-second timeout period, the module considers the MCU is offline.
The MCU can determine whether the module works properly according to the heartbeat. If the module fails to send a heartbeat, the MCU can use the reset pin to reset the module.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x00 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 00 00 00 00 ff
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x00 |
Data length | 2 | 0x0001 |
Data | 1 | 0x00: The MCU returns this value only one time after a restart. The module uses this value to determine whether the MCU restarts during operation. 0x01: The MCU returns this value except for the first response after a restart. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, the MCU returns 55 aa 03 00 00 01 00 03
after a restart.
The MCU returns 55 aa 03 00 00 01 01 04
except for the first response after a restart.
Product information consists of the product ID and MCU software version number.
x.x.x
(0 ≤ x ≤ 99), and x
is a decimal digit.To use the HomeKit capabilities, the Wi-Fi module will send a HomeKit configuration on receiving the response to the production information query. If the MCU is restarted after an OTA update, the Wi-Fi module will send a command to query the MCU and set the working mode of the Wi-Fi module instead of the HomeKit configuration.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x01 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 00 01 00 00 00
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x01 |
Data length | 2 | N |
Data | N | {“p”:“AIp08kLIftb8x***”,“v”:“1.0.0”,“pt”:19} |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, {"p":"AIp08kLIftb8x***","v":"1.0.0","pt":19}
Field description:
p
indicates the product ID is AIp08kLIftb8x***
, mapping the PID of a product created on the Tuya Developer Platform. (Required)
v
indicates the MCU version is 1.0.0. The version number must be defined in the format x.x.x
. (Required)
pt
indicates the accessory category in HomeKit. For more information, see Appendix 1. (Required)
The working mode indicates how the network status is indicated and the way to trigger module reset. The Wi-Fi module can work in the following two modes.
When the module detects a low level on the GPIO input pin for more than five seconds, it will trigger a reset action. The following command specifies the GPIO pins of the LED indicator and the reset button.
For cross-module I/O configuration, the pin number plus 32 makes the pin number we need. For example, the pin number to be set for PB20 is 52 (20 + 32 = 52).
The active level setting when the module processes network events itself.
Active low for button press and LED indicator.
Tuya-defined network status
Network status | Description | Status value |
---|---|---|
Status 1 | Waiting for connection | The LED flickers at an interval of 250 milliseconds. |
Status 2 | The Wi-Fi network has been set up but not connected to the router. | The LED indicator is steady off. |
Status 3 | The Wi-Fi module has been connected to the router but not to the cloud. | The LED indicator is steady off. |
Status 4 | The Wi-Fi module has been connected to the cloud. | The LED indicator is steady on. |
HomeKit-defined network status
Network status | Description | Status value |
---|---|---|
Status 1 | To be bound or being bound | The LED flickers at an interval of 250 milliseconds. |
Status 2 | Not connected | The LED indicator is steady off. |
Status 3 | Connected | The LED indicator is steady on. |
Status 4 (special) | A prompt for HomeKit connection, which is fire-and-forget. | The LED indicator flickers three times. |
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x02 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 0x55aa 00 02 0000 01
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x02 |
Data length | 2 | 0x0000: The module works with the MCU to process network events. 0x0003: The module processes network events itself. |
Data | 0/3 | The data length is 3 bytes: The first byte represents the GPIO pin used to indicate Tuya-defined network status. The second byte represents the GPIO pin used to indicate HomeKit-defined network status. The third byte represents the GPIO pin used to reset the network connection. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, the MCU returns 0x55aa 03 02 0000 04
when the module works with the MCU to process network events.
The MCU returns 0x55aa 03 02 0003 0c 0d 0e 2e
when the module processes network events itself. 0x0c
indicates the LED that signals Tuya-defined network status is connected to GPIO12. 0x0d
indicates the LED that signals HomeKit-defined network status is connected to GPIO13. 0x0e
indicates the reset button is connected to GPIO14.
Tuya-defined network status:
Network status | Description | Status value |
---|---|---|
Status 1 | Waiting for connection | 0x00 |
Status 2 | The Wi-Fi network has been set up but not connected to the router. | 0x01 |
Status 3 | The Wi-Fi module has been connected to the router but not to the cloud. | 0x02 |
Status 4 | The Wi-Fi module has been connected to the cloud. | 0x03 |
HomeKit-defined network status
Network status | Description | Status value |
---|---|---|
Status 1 | To be bound or being bound | 0x00 |
Status 2 | Not connected | 0x01 |
Status 3 | Connected | 0x02 |
Status 4 (special) | A prompt for HomeKit connection, which is fire-and-forget. | 0x03 |
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x03 |
Data length | 2 | 0x0002 |
Data | 1 | The network status flag: 0x00: Tuya-defined network status 0x01: HomeKit-defined network status |
1 | For Tuya-defined network status: 0x00: status 1 0x01: status 2 0x02: status 3 0x03: status 4 For HomeKit-defined network status: 0x00: status 1 0x01: status 2 0x02: status 3 0x03: status 4 (special) |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x03 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
A HomeKit accessory that has been added to the Tuya Smart app still can be added to the Home app on an iOS device that is connected to the same LAN. If a HomeKit accessory has been added to the Home app, it can only be added to the Tuya Smart app over Bluetooth.
About binding and reset
If a HomeKit accessory is removed from the Home app, this accessory is still connected to the LAN and can be bound again without the pairing process.
If a HomeKit accessory is added to the Home app and then bound with the Tuya Smart app, both apps can control this accessory. If this accessory is removed from the Tuya Smart app and restarted, it can still be bound with the Tuya Smart app because the pairing with the Home app is still established.
If a HomeKit accessory is added to the Home app and then bound with the Tuya Smart app, both apps can control this accessory. If this accessory is removed from the Home app and not restarted, it can still be bound with the Home app because the pairing with Tuya Smart app is still established.
If a HomeKit accessory is removed from the Tuya Smart app on an Android device, it enters the status of waiting for a connection.
If a HomeKit accessory is added to the Tuya Smart app on an Android device and then added to the Home app, this accessory can still be controlled with the Home app even if it is removed from the Tuya Smart app.
When the module detects a low level on the GPIO input pin for more than five seconds, it will trigger a reset action. If you choose the module self-processing mode, implementing this protocol for your MCU is not necessary.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x04 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 03 04 00 00 06
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x04 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 00 04 00 00 03
The command sent by the module can contain status data units of multiple DPs.
The module sends control commands and the MCU reports DP status, which occurs asynchronously.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x06 |
Data length | 2 | Depends on the type and number of command data units. |
Data | N | Status data units |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, the DP 3 of on/off control is of Boolean data type. If the value is 1, it indicates switching on the device.
55 aa 00 06 00 05 03 01 00 01 01 10
For more information about the data unit, see Status data unit.
The MCU asynchronously reports DP status, which can be triggered by three mechanisms.
The MCU can report status data units of multiple DPs.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x07 |
Data length | 2 | It depends on types and the number of status data units. |
Data | N | Status data units |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, the DP 5 of humidity is of value data type. If the current humidity is 30%, the MCU sends the following command to the module.
55 aa 03 07 00 08 05 02 00 04 00 00 00 1e 3a
Report status data units of multiple DPs
The DP 109 is of Boolean data type, and its value is 1
.
The DP 102 is of string data type, and its value is 201804121507
. The value is transferred in ASCII mode.
55 aa 03 07 00 15 6d 01 00 01 01 66 03 00 0c 32 30 31 38 30 34 31 32 31 35 30 37 62
The module asynchronously queries the status of all object DPs. When the MCU receives queries, it sends the status of DPs to the module. For more information, see Report status.
When the MCU receives this command, it must report status to both the Tuya Smart app and the Home app. Otherwise, the device status on these two apps will not be consistent.
The module sends DP status queries when the following two events occur.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x08 |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 00 08 00 00 07
You can specify the update method for OTA MCU firmware updates. The module only serves as the channel for OTA data transmission, without any data parsing operation.
The Tuya Developer Platform provides four update methods.
The following flowchart shows how the OTA firmware update works.
After the module has sent all update packages, it will send the command 0x01
to query the product information. The MCU must reply with the new MCU firmware version number within one minute. The new version number should be consistent with that configured on the Tuya Developer Platform.
Start OTA update
The OTA update can be initiated automatically or manually. For automatic updates, when the module detects MCU firmware updates from the cloud, the transmission of the update package automatically starts. For manual updates, the module initiates updates only when updates are confirmed on the app.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x0a |
Data length | 2 | 0x0004 |
Data | 4 | The size of the update package. The data type is an unsigned integer, and the data is stored in big-endian format. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 00 0a 00 04 00 00 68 00 75
It indicates the size of the update package is 26624 bytes, namely 26 KB.
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x0a |
Data length | 2 | 0x0001 |
Data | 1 | The update package size of a single packet: 0x00: 256 bytes by default, compatible with legacy firmware 0x01: 512 bytes 0x02: 1024 bytes |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 03 0a 00 01 00 0d
Transmit update package
The data format of update package transmission: packet offset + packet data.
If the MCU receives the frame with a data length equal to 4 bytes and the packet offset is equal to or greater than the size of firmware, the transmission ends.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x0b |
Data length | 2 | The data length is the sum of 0x0004 and the packet length. |
Data | N | The first four bytes are fixed as packet offset, and the latter bytes are the packet data. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example,
The size of the update file is 530 bytes. The MCU can skip the response to the last packet.
0x00000000
, and the packet length is 256 bytes.55 aa 00 0b 01 04 00000000 xx…xx XX
0x00000100
, and the packet length is 256 bytes.55 aa 00 0b 01 04 00000100 xx…xx XX
0x00000200
, and the packet length is 18 bytes.55 aa 00 0b 00 16 00000200 xx…xx XX
0x00000212
, and the packet length is 0 bytes.55 aa 00 0b 00 04 00000212 xx…xx XX
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x0b |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 03 0b 00 00 0d
As the international standard of civil time, GMT is independent of the time zone and DST.
After connecting to the network, the module returns success and valid time data after the local timestamp is synced.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x0c |
Data length | 2 | 0x0000 |
Data | 0 | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 aa 03 0c 00 00 0e
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x0c |
Data length | 2 | 0x0007 |
Data | 7 | The data length is 7 bytes. Data[0]: indicates whether the system time is obtained successfully. 0 : failure. 1 : success. Data[1]: indicates the year. For example, 0x00 indicates the year 2000. Data[2]: indicates the month, ranging from 1 to 12. Data[3]: indicates the day, ranging from 1 to 31. Data[4]: indicates the hour, ranging from 0 to 23. Data[5]: indicates the minute, ranging from 0 to 59. Data[6]: indicates the second, ranging from 0 to 59. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, if the system time is 05:06:07 on April 19, 2016 (GMT), the module will return the following command.
55 aa 00 0c 00 07 01 10 04 13 05 06 07 4c
The local time is calculated by adding the time zone offset and DST to the GMT. The time zone is where the device is activated.
After connecting to the network, the module returns success and valid time data after the local timestamp is synced.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x1c |
Data length | 2 | 0x0000 |
Data | xxxx | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x1c |
Data length | 2 | 0x0008 |
Data | Data | The data length is 8 bytes. Data[0]: indicates whether the local time is obtained successfully. 0 : failure. 1 : success. Data[1]: indicates the year. For example, 0X00 indicates the year 2000. Data[2]: indicates the month, ranging from 1 to 12. Data[3]: indicates the day, ranging from 1 to 31. Data[4]: indicates the hour, ranging from 0 to 23. Data[5]: indicates the minute, ranging from 0 to 59. Data[6]: indicates the second, ranging from 0 to 59. Data[7]: indicates the week, ranging from 1 to 7. 1 indicates Monday. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
If the device is activated in mainland China, the local time is Beijing time (GMT+08:00).
For example, if the local time is 05:06:07 on April 19, 2016 (GMT+08:00), the module will return the following command.
55 aa 00 1c 00 08 01 10 04 13 05 06 07 02 5f
If the device is activated in other countries or regions, the local time is the time zone in which the device is located.
The module scans the router whose SSID is tuya_mdev_test
and returns the result and signal strength in percentage.
To prevent quality defects, it is recommended that the distance between the router and the device under test should be about 5 meters. If the signal strength is greater than or equal to 60%, the device is acceptable. The specific testing conditions depend on your production line and environment.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x0e |
Data length | 2 | 0x0000 |
Data | Data | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x0e |
Data length | 2 | 0x0002 |
Data | 2 | The data length is 2 bytes. Data[0]: 0x00 indicates failure and 0x01 indicates success. If Data[0] is 0x01 , Data[1] indicates the signal strength, ranging from 0 to 100, 0 for the weakest and 100 for the strongest. If Data[0] is 0x00 , Data[1] indicates failure reasons. 0x00 indicates the specified SSID is not found. 0x01 indicates the authorization key is not flashed to the module. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
Get the remaining memory of the Wi-Fi module.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x0f |
Data length | 2 | 0x0000 |
Data | Data | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x0f |
Data length | 2 | 0x0004 |
Data | 4 | The data length is 4 bytes. The value is represented in big-endian format. For example, 0x00 0x00 0x28 0x00 represents 10240 bytes remaining memory. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x24 |
Data length | 2 | 0 |
Data | N | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x24 |
Data length | 2 | 0x0001 |
Data | Data | 0x00: failure. A value less than 0: indicates signal strength, such as -60 dB. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x25 |
Data length | 2 | 0 |
Data | N | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x25 |
Data length | 2 | 0 |
Data | N | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
Before the module goes to sleep for reducing power consumption, the MCU can send this command to notify the module to disable the heartbeat. Because heartbeats are required for building communication between the module and the MCU, this command must not be sent when the device is just powered on.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x2B |
Data length | 2 | 0x0000 |
Data | Data | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x2B |
Data length | 2 | 0x0001 |
Data | 1 | The protocol must be consistent with that described in Report network status. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x2d |
Data length | 2 | 0x0000 |
Data | Data | None |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x2d |
Data length | 2 | 0x0007 |
Data | Data | Data[0]: indicates whether the MAC address is obtained successfully. 0x00 indicates success and the next 6 bytes denote a valid MAC address. 0x01 indicates failure and the next 6 bytes denote an invalid MAC address. Data[1] to Data[6]: indicates the valid MAC address of the module on a success. |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The running data of the Wi-Fi module is required for some products. This field is used to get the required information.
The MCU can send a specified code to the module to get the required information. If the MCU requires multiple types of information, the codes must be sent in order.
If the MCU requires all the information available, it can use the code 0xff
.
The MCU sends the following command.
Field | Length | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x34 |
Data length | 2 | 0x01+0x01+…N |
Data | 1 | Sub-command: 0x07 |
Data(1) | 0x01: reserved 0x02: the country code 0x03: the serial number of the module …… 0xFF: get all the information available. This code is valid only when it is set as the first byte and enjoys the highest priority. When the module receives this code, it will return all the information available. |
|
Data(2) | 0x01: reserved 0x02: the country code 0x03: the serial number of the module …… |
|
Data(N) | 0x01: reserved 0x02: the country code 0x03: the serial number of the module …… |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, 55 AA 03 34 00 02 07 02 41
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x34 |
Data length | 2 | 0x02+N |
Data | 1 | 0x07 (sub-command) |
1 | The result: 0x00: success. 0x01: failure. No subsequent data will be returned. |
|
{ “cc” :xx, “sn”:“xxx” } |
cc : country code (optional) sn : the serial number of the module (optional) |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
This section and the followings describe commands specific to the HomeKit accessory.
Initialization process
The time from sending a heartbeat to receiving working mode should not exceed three seconds.
HomeKit status data unit
Data segment | Bytes | Description | |
---|---|---|---|
Service serial number | 1 | The MCU sends the service serial number to the module when the service configuration is performed. | |
Length of the characteristic string identifier | 1 | Length of the characteristic string identifier | |
Characteristic string identifier | n | For more information about the characteristic string identifier, see Appendix 3. | |
type | 1 | The data type. For more information, see the table of Type fields below. | |
len | 2 | The length is the number of bytes of a value. | |
Value | 1/2/4/N | Represented in hexadecimal format. Data greater than one byte is transmitted in big-endian format. |
Type fields
Type | Value | Length (byte) | Description |
---|---|---|---|
Boolean | 0x00 | 1 | Represents Boolean data type. Valid values include 0x00 and 0x01 . |
uint | 0x01 | 4 | Represents unsigned integer type (uint8, uint16, and uint32) in big-endian format. |
int | 0x02 | 4 | Represents signed integer type in big-endian format. |
64bit uint | 0x03 | 8 | Represents unsigned integer type (uint64) in big-endian format. |
float | 0x04 | 4 | Represents floating point data type. The first two bytes contain the integer and the last two bytes contain the decimal. |
String | 0x05 | N | Represents string data type. |
Raw | 0x06 | N | Represents raw data for transparent transmission. |
The module sends this command to flag the start of the HomeKit configuration. When the MCU receives this command, it sends the required information for configuring HomeKit services and characteristics.
After sending all the required information, the MCU returns the response to this command.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x36 |
Data length | 2 | 0x0001 |
Data | 1 | 0x01 (sub-command) |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x36 |
Data length | 2 | 0x0001 |
Data | 1 | 0x01 (sub-command) |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU must send this command before the module working mode query and after the product information query.
You can configure multiple identical HomeKit services for one accessory and use the service serial number to distinguish between them. The service serial number is also used to manage different HomeKit services.
An accessory can have multiple different services, which might be linked to each other. You should specify one of the available services as the primary service that must match the primary function of the accessory and also match with the accessory category. The primary service must be stored first in the service array.
The service serial number is used for sending or reporting HomeKit commands.
Each service contains one or more characteristics. A characteristic is a feature that represents data or an associated behavior of a service. The Wi-Fi module will add the required characteristic automatically. For more information about HomeKit characteristics, see Appendix 3. To add the optional characteristics, the MCU should send the command Optional characteristic configuration.
The MCU sends the following command.
Field | Bytes | Description | |
---|---|---|---|
Header | 2 | 0x55aa | |
Version | 1 | 0x03 | |
Command | 1 | 0x36 | |
Data length | 2 | 0x0001+2N+M1+M2+…+Mn | |
Data | 1 | 0x02 (sub-command) | |
The first service. | 1 | The service serial number. It can start with zero, with an increment of 1 for each newly added service. | |
1 | |||
M1 | The service string identifier. For more information, see Appendix 2. | ||
The second service. | 1 | Service serial number | |
1 | The length of service string identifier | ||
M2 | The service string identifier. For more information, see Appendix 2. | ||
- | - | - | |
The Nth service. | 1 | Service serial number | |
1 | The length of service string identifier | ||
Mn | The service string identifier. For more information, see Appendix 2. | ||
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x36 |
Data length | 2 | 0x0002+N or 0x0002 |
Data | 1 | 0x02 (sub-command) |
1 | The result of data processing. 0x00: success. The returned result of subsequent service configuration is valid. 0x01: failure. No result of service configuration will be returned. |
|
N | The result of configuring the first service. 0x00: success. 0x01: failure. |
|
The result of configuring the second service. | ||
- | ||
The result of configuring the Nth service. | ||
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For more information about HomeKit commands, see HomeKit status data unit.
The module sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x36 |
Data length | 2 | 0x0001+N |
Data | 1 | 0x03 (sub-command) |
N | HomeKit status data unit | |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For more information about HomeKit commands, see HomeKit status data unit.
The MCU asynchronously reports HomeKit status, which can be triggered by three mechanisms.
The MCU can report the status of multiple HomeKit status data units at a time.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x36 |
Data length | 2 | 0x0001+N |
Data | 1 | 0x04 (sub-command) |
N | HomeKit status data unit | |
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
Each HomeKit service includes required and optional characteristics. The Wi-Fi module adds the required characteristic automatically. To add the optional characteristic, the MCU must send this command.
If the MCU receives a result of successful service configuration from the Wi-Fi module, it can send this command to configure the optional characteristics.
If the MCU does not send this command, the registered services only include the required characteristics.
This command must be sent before the MCU sends a response to the HomeKit service configuration query.
The MCU sends the following command.
Field | Bytes | Description | |
---|---|---|---|
Header | 2 | 0x55aa | |
Version | 1 | 0x03 | |
Command | 1 | 0x36 | |
Data length | 2 | 0x0001+2N+M1+M2+…+Mn | |
Data | 1 | 0x05 (sub-command) | |
1 | The service serial number. Corresponds to HomeKit service configuration. | ||
The first optional characteristic. | 1 | Length of the optional characteristic string identifier | |
M1 | For more information about the characteristic string identifier, see Appendix 3. | ||
The second optional characteristic. | 1 | Length of the optional characteristic string identifier | |
M2 | For more information about the characteristic string identifier, see Appendix 3. | ||
- | - | - | |
The Nth optional characteristic. | 1 | Length of the optional characteristic string identifier | |
Mn | For more information about the characteristic string identifier, see Appendix 3. | ||
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x36 |
Data length | 2 | 0x0002+N or 0x0002 |
Data | 1 | 0x05 (sub-command) |
1 | The result of data processing. 0x00: success. The returned result of subsequent optional characteristic configuration is valid. 0x01: failure. No result of optional characteristic configuration will be returned. |
|
N | The result of configuring the first optional characteristic. 0x00: success. 0x01: failure. |
|
The result of configuring the second optional characteristic. | ||
- | ||
The result of configuring the Nth optional characteristic. | ||
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
You can use this command to configure valid values of characteristics.
For example, the characteristic of the current air purifier state has three valid values by default, namely 0 Inactive
, 1 Idle
, and 2 Purifying Air
. If 1 Idle
is not needed, the MCU can send this command to configure the valid values as 0 Inactive
and 2 Purifying Air
.
This command must be sent after service and characteristic configuration and before the MCU sends a response to the command 36-01
.
If the MCU does not send this command, the Wi-Fi module will register the default valid values.
This command only applies to HomeKit characteristics of uint8 format.
If a characteristic does not contain a valid value that has not been removed through the configuration process, the test for HomeKit certification might fail.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x36 |
Data length | 2 | 0x0001+N |
Data | 1 | 0x06 (sub-command) |
{ “service_serial”:xx, “char_str”:“xx”, “val_type”:xx, “valid_val”:[xx,xx,xx] } |
service_serial : the serial number of the service that the characteristic belongs to. char_str : the string identifier of the characteristic. val_type : the value type of the characteristic. 0 : The valid value can be changed. This type applies to characteristics such as current air purifier state and air quality. 1 : The range of the valid value can be changed. This type applies to characteristics such as rotation speed and PM2.5 density. Others: reserved. valid_value : stored in an array. If val_type is set to 0 , the element in an array is the list of valid values. The number of elements depends on the number of valid values. If val_type is set to 1 , the elements in an array are the minimum value and maximum value of the updated value range. There are two elements: the first one is the minimum value and the second one is the maximum value. |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
For example, if the service_serial
of the air purifier is 0
, to remove the valid value of 1 Idle
, the MCU sends the following command.
55 AA 03 36 00 44 06 7B 22 73 65 72 76 69 63 65 5F 73 65 72 69 61 6C 22 3A 30 2C 22 63 68 61 72 5F 73 74 72 22 3A 22 41 39 22 2C 22 76 61 6C 5F 74 79 70 65 22 3A 30 2C 22 76 61 6C 69 64 5F 76 61 6C 22 3A 5B 30 2C 32 5D 7D 96
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x36 |
Data length | 2 | 0x0002 |
Data | 1 | 0x06 (sub-command) |
1 | The result of data processing. 0x00: success. 0x01: failure. service_serial not found. 0x02: failure. char_str not found. 0x03: failure. val_type not supported. 0x04: failure. valid_val not configured correctly. 0x05: failure. Incorrect parameter. 0x06: failure. Configuration is not available currently. 0x07: failure. Failed to process data. Others: reserved |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The MCU sends this command to notify the module of the new feature configuration after the accessory is powered on and before the command 0x02
is sent.
The MCU must send this command each time after the accessory is powered on or the Wi-Fi module is restarted.
If no new feature configuration is required, the MCU does not need to send this command.
The fields of this command will be added as the service is extended.
The MCU sends the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x03 |
Command | 1 | 0x37 |
Data length | 2 | 0x0001+N |
Data | 1 | Sub-command: 0x00 |
{“mcu_ota”:xx} | mcu_ota : specify how the OTA MCU firmware updates are executed. 0 : The MCU has a scratchpad. 1 : The MCU does not have a scratchpad. |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
The module returns the following command.
Field | Bytes | Description |
---|---|---|
Header | 2 | 0x55aa |
Version | 1 | 0x00 |
Command | 1 | 0x37 |
Data length | 2 | 0x0002 |
Data | 1 | Sub-command: 0x00 |
1 | Ret : 0x00: success. 0x01: invalid content. 0x02: failure. |
|
Checksum | 1 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. |
Field description
mcu_ota
: specify how the OTA MCU firmware updates are executed.
OTA updates without scratchpad
The Wi-Fi module acts as the scratchpad for the MCU firmware updates. It can store the update file of up to 1.5 MB (1572864 bytes). The Wi-Fi module will download and store the update file and when the download is completed, it notifies the MCU to start the update.
During the update process, do not power off or unplug the accessory. If any power failure occurs, the Wi-Fi module will keep trying until the update succeeds. The Wi-Fi module will check the update status each time it is started. If a failed update is detected, the module will initiate an update request from the command 0x0A
until the update succeeds.
For more information, see the OTA update flowchart.
0x0A
and 0x0B
commands.Category | Value |
---|---|
Bridges | 2 |
Fans | 3 |
Garage Door Openers | 4 |
Lighting | 5 |
Locks | 6 |
Outlets | 7 |
Switches | 8 |
Thermostats | 9 |
Sensors | 10 |
Security Systems | 11 |
Doors | 12 |
Windows | 13 |
Window Coverings | 14 |
Programmable Switches | 15 |
Reserved | 16 |
IP Cameras | 17 |
Video Doorbells | 18 |
Air Purifiers | 19 |
Heaters | 20 |
Air Conditioners | 21 |
Humidifiers | 22 |
Dehumidifiers | 23 |
Sprinklers | 28 |
Faucets | 29 |
Shower Systems | 30 |
Service | Service string identifier |
---|---|
Accessory Information | “3E” |
HAP Protocol Information | “A2” |
Garage Door Opener | “41” |
Light Bulb | “43” |
Lock Management | “44” |
Lock Mechanism | “45” |
Switch | “49” |
Outlet | “47” |
Thermostat | “4A” |
Air Quality Sensor | “8D” |
Security System | “7E” |
Carbon Monoxide Sensor | “7F” |
Contact Sensor | “80” |
Door | “81” |
Humidity Sensor | “82” |
Leak Sensor | “83” |
Light Sensor | “84” |
Motion Sensor | “85” |
Occupancy Sensor | “86” |
Smoke Sensor | “87” |
Stateless Programmable Switch | “89” |
Temperature Sensor | “8A” |
Window | “8B” |
Window Covering | “8C” |
Battery Service | “96” |
Carbon Dioxide Sensor | “97” |
Fan | “B7” |
Slat | “B9” |
Filter Maintenance | “BA” |
Air Purifier | “BB” |
Heater Cooler | “BC” |
Humidifier Dehumidifier | “BD” |
Service Label | “CC” |
Irrigation System | “CF” |
Valve | “D0” |
Faucet | “D7” |
Characteristic | String identifier | Description |
---|---|---|
Administrator Only Access | “1” | When this mode is enabled, the accessory only accepts administrator access. |
Brightness | “8” | This characteristic describes a perceived level of brightness. |
Cooling Threshold Temperature | “D” | This characteristic describes the cooling threshold in Celsius for accessories that support simultaneous heating and cooling. |
Current Door State | “E” | This characteristic describes the current state of a door. |
Current Heating Cooling State | “F” | This characteristic describes the current mode of an accessory that supports cooling or heating its environment. |
Current Relative Humidity | “10” | This characteristic describes the current relative humidity of the accessory’s environment. |
Current Temperature | “11” | This characteristic describes the current temperature of the environment. |
Firmware Revision | “52” | This characteristic describes a firmware revision string. |
Hardware Revision | “53” | This characteristic describes a hardware revision string. |
Heating Threshold Temperature | “12” | This characteristic describes the heating threshold in Celsius for accessories that support simultaneous heating and cooling. |
Hue | “13” | This characteristic describes hue or color. |
Identify | “14” | This characteristic enables the accessory to run its identify routine. |
Lock Control Point | “19” | The accessory accepts writes to this characteristic to perform vendor-specific actions. |
Lock Current State | “1D” | The current state of the physical security mechanism. |
Lock Last Known Action | “1C” | The last known action of the lock mechanism. |
Lock Management Auto Security Timeout | “1A” | A value greater than 0 indicates if the lock mechanism enters the unsecured state, it will automatically attempt to enter the secured state after n seconds, where n is the value provided in the write. A value of 0 indicates this feature is disabled. |
Lock Target State | “1E” | The target state of the physical security mechanism. |
Logs | “1F” | Read from this characteristic to get timestamped logs from the accessory. |
Manufacturer | “20” | This characteristic contains the name of the company whose brand will appear on the accessory. |
Model | “21” | This characteristic contains the manufacturer-specific model of the accessory. |
Motion Detected | “22” | This characteristic indicates if a motion was detected. |
Name | “23” | This characteristic describes a name and must not be a null value. |
Obstruction Detected | “24” | This characteristic describes the current state of an obstruction sensor. |
On | “25” | This characteristic represents the states for on and off . |
Outlet In Use | “26” | This characteristic describes if the power outlet has an appliance physically plugged in. |
Rotation Direction | “28” | This characteristic describes the direction of rotation of a fan. |
Rotation Speed | “29” | This characteristic describes the rotation speed of a fan. |
Saturation | “2F” | This characteristic describes color saturation. |
Serial Number | “30” | This characteristic contains the manufacturer-specific serial number of the accessory. The |
length must be greater than 1. | ||
Target Door State | “32” | This characteristic describes the target state of a door. |
Target Heating Cooling State | “33” | This characteristic describes the target mode of an accessory that supports heating/cooling. |
Target Relative Humidity | “34” | This characteristic describes the target relative humidity that the accessory is actively attempting to reach. |
Target Temperature | “35” | This characteristic describes the target temperature in Celsius that the accessory is actively attempting to reach. |
Temperature Display Units | “36” | This characteristic describes units of temperature used for presentation purposes. |
Version | “37” | This characteristic contains a version string. |
Air Particulate Density | “64” | This characteristic indicates the current air particulate matter density in micrograms/m3. |
Air Particulate Size | “65” | This characteristic indicates the size of air particulate matter in micrometers. |
Security System Current State | “66” | This characteristic describes the state of a security system. |
Security System Target State | “67” | This characteristic describes the target state of the security system. |
Battery Level | “68” | This characteristic describes the current level of the battery. |
Carbon Dioxide Detected | “69” | This characteristic indicates if a sensor detects abnormal levels of Carbon Dioxide. |
Contact Sensor State | “6A” | This characteristic describes the state of a door/window contact sensor. |
Current Ambient Light Level | “6B” | This characteristic indicates the current light level. |
Current Horizontal Tilt Angle | “6C” | This characteristic describes the current angle of horizontal slats for accessories such as windows, fans, and more. |
Current Position | “6D” | This characteristic describes the current position of accessories. |
Current Vertical Tilt Angle | “6E” | This characteristic describes the current angle of vertical slats for accessories such as windows, fans, and more. |
Hold Position | “6F” | This characteristic causes the service such as door or window covering to stop at its current position. |
Leak Detected | “70” | This characteristic indicates if a sensor detected a leak. |
Occupancy Detected | “71” | This characteristic indicates if occupancy was detected. |
Position State | “72” | This characteristic describes the state of the position of accessories. |
Programmable Switch Event | “73” | This characteristic describes an event generated by a programmable switch. |
Status Active | “75” | This characteristic describes an accessory’s current working status. |
Smoke Detected | “76” | This characteristic indicates if a sensor detects abnormal levels of smoke. |
Status Fault | “77” | This characteristic describes an accessory that has a fault. |
Status Jammed | “78” | This characteristic describes an accessory that is in a jammed state. |
Status Low Battery | “79” | This characteristic describes an accessory’s battery status. |
Status Tampered | “7A” | This characteristic describes an accessory that has been tampered with. |
Target Horizontal Tilt Angle | “7B” | This characteristic describes the target angle of horizontal slats for accessories such as windows, fans, and more. |
Target Position | “7C” | This characteristic describes the target position of accessories. |
Target Vertical Tilt Angle | “7D” | This characteristic describes the target angle of vertical slats for accessories such as windows, fans, and more. |
Security System Alarm Type | “8E” | This characteristic describes the type of alarm triggered by a security system. |
Charging State | “8F” | This characteristic describes the charging state of a battery or an accessory. |
Carbon Monoxide Level | “90” | This characteristic indicates the Carbon Monoxide levels detected in parts per million (ppm). |
Carbon Monoxide Peak Level | “91” | This characteristic indicates the highest detected level (ppm) of Carbon Monoxide detected by a sensor. |
Carbon Dioxide Detected | “92” | This characteristic indicates if a sensor detects abnormal levels of Carbon Dioxide. |
Carbon Dioxide Level | “93” | This characteristic indicates the detected level of Carbon Dioxide in parts per million (ppm). |
Carbon Dioxide Peak Level | “94” | This characteristic indicates the highest detected level (ppm) of carbon dioxide detected by a sensor. |
Air Quality | “95” | This characteristic describes the subject assessment of air quality by an accessory. |
Accessory Flags | “A6” | When set indicates accessory requires additional setup. |
Lock Physical Controls | “A7” | This characteristic describes a way to lock a set of physical controls on an accessory. |
Current Air Purifier State | “A9” | This characteristic describes the current state of the air purifier. |
Current Slat State | “AA” | This characteristic describes the current state of the slats. |
Slat Type | “C0” | This characteristic describes the type of the slats. |
Filter Life Level | “AB” | This characteristic describes the current filter life level. |
Filter Change Indication | “AC” | This characteristic describes if a filter needs to be changed. |
Reset Filter Indication | “AD” | This characteristic allows a user to reset the filter indication. |
Target Air Purifier State | “A8” | This characteristic describes the target state of the air purifier. |
Target Fan State | “BF” | This characteristic describes the target state of the fan. |
Current Fan State | “AF” | This characteristic describes the current state of the fan. |
Active | “B0” | The Active characteristic indicates whether the service is currently active. |
Swing Mode | “B6” | This characteristic describes if swing mode is enabled. |
Current Tilt Angle | “C1” | This characteristic describes the current angle of slats for accessories such as windows, fans, and more. |
Target Tilt Angle | “C2” | This characteristic describes the target angle of slats for accessories such as windows, fans, and more. |
Ozone Density | “C3” | This characteristic indicates the current ozone density in micrograms/m3. |
Nitrogen Dioxide Density | “C4” | This characteristic indicates the current NO2 density in micrograms/m3. |
Sulphur Dioxide Density | “C5” | This characteristic indicates the current SO2 density in micrograms/m3. |
PM2.5 Density | “C6” | This characteristic indicates the current PM2.5 micrometer particulate density in micrograms/m3. |
PM10 Density | “C7” | This characteristic indicates the current PM10 micrometer particulate density in micrograms/m3. |
VOC Density | “C8” | This characteristic indicates the current volatile organic compound density in micrograms/m3. |
Service Label Index | “CB” | This characteristic should be used to identify the index of the label that maps to Service Label Namespace used by the accessory. |
Service Label Namespace | “CD” | This characteristic describes the naming schema for an accessory. |
Color Temperature | “CE” | This characteristic describes color temperature. |
Current Heater Cooler State | “B1” | This characteristic describes the current state of a heater cooler. |
Target Heater Cooler State | “B2” | This characteristic describes the target state of a heater cooler. |
Current Humidifier Dehumidifier State | “B3” | This characteristic describes the current state of a humidifier or/and a dehumidifier. |
Target Humidifier Dehumidifier State | “B4” | This characteristic describes the target state of a humidifier or/and a dehumidifier. |
Water Level | “B5” | This characteristic describes the current water level. |
Relative Humidity Dehumidifier Threshold | “C9” | This characteristic describes the relative humidity dehumidifier threshold. |
Relative Humidity Humidifier Threshold | “CA” | This characteristic describes the relative humidity humidifier threshold. |
Program Mode | “D1” | This characteristic describes if there are programs scheduled on the accessory. |
In Use | “D2” | This characteristic describes if the service is in use. |
Set Duration | “D3” | This characteristic describes the set duration. |
Remaining Duration | “D4” | This characteristic describes the remaining duration on the accessory. |
Valve Type | “D5” | This characteristic describes the type of valve. |
Is Configured | “D6” | This characteristic describes if the service is configured for use. |
Product Data | “220” | This characteristic describes product data. |
Name | Description | Options | Read | Write |
---|---|---|---|---|
cc | Country code | 0: applies to China, Korea, Singapore, Australia, Japan (1-13), and others 1: applies to the United States, Taiwan (China), and Canada 2: applies to Japan (1-14) 3: applies to Europe |
Supported | Not supported |
Description | Date | Note |
---|---|---|
Create | September 15, 2020 | The first release. |
Amendment | November 18, 2020 | Added the command to read the country code from the Wi-Fi module. |
Amendment | December 21, 2020 | 1. Added three categories including sprinklers, faucets, and shower systems. 2. Modified the description of service configuration. |
Amendment | January 7, 2021 | 1. Added the command to notify the module of the new feature configuration. 2. Added support for single backup of OTA MCU firmware updates. |
Amendment | February 4, 2021 | 1. Added the prompt of HomeKit compatibility. 2. Added the command to configure the valid values of HomeKit characteristics. |
Amendment | April 15, 2021 | Added the command to read the serial number of the Wi-Fi module. |
Is this page helpful?
YesFeedbackIs this page helpful?
YesFeedback