-
-
Notifications
You must be signed in to change notification settings - Fork 361
General Configuration
This section is optional, and default values will be used if you don't use it.
Option | Key | Default | Type | Description |
---|---|---|---|---|
Invoke setup mode | "b" |
none | array | Inputs that can be used to enter setup mode |
Boot delay | "v" |
0 |
float | Set delay in seconds at boot |
Initial delay | "cd" |
0 |
float | Set delay in seconds before first service creation |
HomeKit Device Category | "ct" |
none | integer | Customized device category |
Gratuitous ARP Period | "e" |
285 |
float | Set a custom Gratuitous ARP packet period |
Binary Software Input Filter | "f" |
10 |
integer | Binary input debounce filter |
Flex Input Filter | "fl" |
none | array | Flex Input Hardware Filter |
Binary Input Continuous Mode | "c" |
0 |
integer | Binary input continuous mode setting |
HomeKit Clients | "h" |
12 |
integer | Maximum number of simultaneous HomeKit Clients |
Invert Status LED | "i" |
1 |
integer | Invert status LED GPIO and open-drain options |
I2C Bus | "ic" |
none | array | I2C bus declaration |
I/O Expanders | "mc" |
none | array | I/O GPIO Expansion interfaces |
GPIOs Configuration Array | "io" |
none | array | Array to declare all GPIO behaviors |
NTP Server | "ntp" |
Gateway IP Address | string | NTP Server to get current date and time |
Timezone | "tz" |
"UTC0" |
string | Timezone to set internal clock |
Timetable Actions | "tt" |
none | array | Actions that occur when configured time and date |
Status LED GPIO | "l" |
none | integer | GPIO pin for status LED |
Setup mode timeout | "m" |
0 |
integer | Time after boot setup mode can be invoked |
Hostname | "n" |
"HAA-XXXXXX" |
string | Set a custom hostname in DHCP option |
Log output | "o" |
0 |
integer | UART and network log output type |
Log server | "ot" |
"255.255.255.255:45678" |
string | Host and port to send UDP network logs |
Ping Action Period | "pt" |
5 |
float | Time between ping actions |
Ping Gateway Watchdog | "w" |
disabled | integer | Network watchdog action |
Software PWM Frequency | "q" |
305 |
integer | Set a custom software PWM frequency |
Hardware PWM Frequency | "y" |
[5000,5000,...] |
array | Set custom hardware PWM frequencies |
Zero Cross GPIO for PWM | "zc" |
none | array | Configure Zero-Cross GPIO to use with PWM |
Trigger GPIO Interrupt Delay | "zd" |
0 |
float | Configure Trigger GPIO Interrupt delay for Binary Outputs |
HAA Setup Service | "s" |
1 |
integer | Set accessory number where HAA Setup Service will be |
UART Configuration | "r" |
none | array | UART configuration settings |
IR Configuration |
"t" "j" "x" "p"
|
none | integer integer integer string |
Infra-red configuration settings |
Serial Number Prefix | "sn" |
XXXXXX-<Acc#> |
string | Customise serial number provided to HomeKit on pairing |
WiFi Sleep Mode | "d" |
1 |
integer | Select WiFi Sleep mode for power save (Only ESP32 models) |
WiFi Bandwidth 40MHz | "dt" |
0 |
integer | Enable Wifi bandwidth 40MHz (Only ESP32 models) |
mDNS TTL | "ttl" |
[4500,2250] |
array | mDNS configuration |
Unsecure HomeKit Rest API | "u" |
0 |
integer | Enable / Disable HomeKit unencrypted Rest API |
Setup Mode Toggle Count | "z" |
8 |
integer | Count of times I/O must be toggled to enter setup mode |
Each of the above configuration options are described below, along with their default values.
Additional to the above list of configuration options a set of Device Actions can be configured to be taken when specific device events occur.
Key | Value | Description |
---|---|---|
"o" |
0 |
Disable log output (default) |
1 |
Enable UART0 log output | |
2 |
Enable UART1 log output | |
3 |
Enable UART2 log output (Only ESP32 models) | |
4 |
Enable Network log output. View with nc -kulnw0 45678
|
|
5 |
Enable UART0 & Network log output | |
6 |
Enable UART1 & Network log output | |
7 |
Enable UART2 & Network log output (Only ESP32 models) | |
8 |
Enable Network log output with buffer | |
9 |
Enable UART0 & Network log output with buffer | |
10 |
Enable UART1 & Network log output with buffer | |
11 |
Enable UART2 & Network log output with buffer (Only ESP32 models) |
The new Advanced Logger Library was implemented in HAA v2.4.0. This library provides additional options for outputting log information and supports the new UART configurations added in v2.1.0. You can now choose to disable logs, output them to serial ports, the network, or both.
If you are not intending to view or capture logs then it is recommended to
leave the option as the default ("o":0
) i.e. disable log output.
Enabling log output is only useful if you need to see what the firmware is doing.
When enabling serial port logging ensure that you have a terminal attached to the UART output. In order to view the output.
Remember to configure used UART when enabling serial port logging.
If network logging is enabled then the log output can be captured and viewed using the following command on macOS or GNU/Linux:
nc -kulnw0 45678
NOTE: Network logs can impact system stability. If you want to use network logs for a long time, buffered options are recommended (8, 9, 10 and 11), but they take more RAM memory.
Key | Value | Description |
---|---|---|
"ot" |
"255.255.255.255:45678" |
Server and port to send UDP logs (default) |
"<server>:<port>" |
Override default server and port to send UDP logs |
Use "ot":"<server>:<port>"
option to specify destination address for network logs,
and port. A FQDN hostname can be used.
Key | Value | Description |
---|---|---|
"l" |
none | No status LED (default) |
GPIO # |
GPIO line the status LED is connected to |
Set the GPIO pin used for LED status information. If you are using Sonoff
devices, the LED is usually connected to GPIO 13 e.g. {"l": 13}
Remember to declare used GPIO as Output into "io":[...]
array. See GPIOs Configuration
Blinks | Description |
---|---|
1 |
Accessory changes status |
2 |
End of initial boot process |
3 |
WiFi disconnected |
4 |
Connected to WiFi |
5 |
Reboot / TH sensor error |
6 |
Identify |
Key | Value | Description |
---|---|---|
"i" |
0 |
Do not invert |
1 |
Invert (default) |
Set the activation level for the LED GPIO output. On a Sonoff device the LED
GPIO is usually active low, so you will need to invert the output of the GPIO
in order to ensure the LED lights when enabling the output e.g. {"i": 1}
,
but since the default is 1
this option can be omitted from the string to save
device memory.
Key | Value | Description |
---|---|---|
"b" |
none | No button array (default) |
If your device has one or more buttons and you want to use any of them to have
a physical means of invoking the setup mode then you will need to define "b"
to contain a list of those buttons and the action that will cause setup mode
to be entered e.g.
{
"c": {
"io": [ [ [ 13 ], 2 ], [ [ 0 ], 6 ] ],
"l": 13,
"b": [ [ 0, 5 ] ]
}
}
In this example the binary input "b"
key contains a single definition of a
button connected to GPIO 0 and configured with a press type 5, of
Hold for 8 seconds
.
See here for more examples of different press types.
To understand more about defining binary inputs refer to binary input declarations.
Key | Value | Description |
---|---|---|
"f" | 10 | Soft debounce (default) |
The binary software input filter "f"
can be set to any integer value between 10 (soft)
and 2550 (hard) to avoid interference such as debounce from the input when a button
pressed.
NOTE: The binary software input filter value is used for all binary inputs defined in the MEPLHAA script.
Only available in ESP32-C6.
Chip provides 8 hardware flexible input filters, whose duration is configurable. Each of them can be applied to any input GPIO. However, applying multiple filters to the same GPIO does not make difference from one.
Key | Value | Description |
---|---|---|
"fl" |
[ [ GPIO, Threshold, Width ], [ ... ] ] |
Array of flex input filters |
-
GPIO
: Number of GPIO to apply filter. -
Threshold
: Threshold time in nanoseconds (Integer). -
Width
: Width time in nanoseconds (Integer).
During window Width, any pulse whose width is shorter than window Threshold will be discarded. Please note that you can not set Threshold time bigger than Width time.
Please note, the glitch filter and flex filter are independent. You can enable both of them for the same GPIO.
Key | Value | Description |
---|---|---|
"c" |
0 |
Disable (default) |
1 |
Enable |
By default, Binary Input Continuous Mode is not used because HAA uses ISRs (Hardware interruptions) to detect changes in input GPIOs. But there are some GPIOs that don't allow hardware interruptions, like GPIO 16 of ESP8266. Use of I/O expanders as input are incompatible with interruptions too, and GPIOs using pulse mode. In these cases, it is needed to enable Continuous Mode to avoid use of hardware interruptions.
To summarize, Binary Input Continuous Mode must be enable for any of these cases:
- Using a GPIO as input button/switch that doesn't allow ISR, like GPIO 16 of ESP8266.
- Using a GPIO as input button/switch with pulse mode.
- Using an expansion interface as inputs buttons/switches.
Key | Value | Description |
---|---|---|
"n" | string | Custom hostname to use for the device |
This option enables you to change the hostname of a device. By default the
hostname is set to HAA-XXXXXX
where "XXXXXX" are the last 6 characters of the
Ethernet MAC address of the device.
If you want to use a friendly name to identify your device in your router's DHCP list etc. then put it in this option.
{
"c": {
"io": [ [ [ 13 ], 2 ], [ [ 0 ], 6 ] ],
"l": 13,
"b": [ [ 0, 5 ] ],
"n": "sonoff-laptop"
}
}
In the above example the device hostname has been set to a friendly name of "sonoff-laptop". The custom hostname must be in quotes and and must not use special characters or blank spaces. Refer to Hostnames to get more details on valid hostnames.
NOTE: During initial device setup i.e. after factory reset or very first
boot, the name will be HAA-XXXXXX
.
Key | Value | Description |
---|---|---|
"e" |
1.5 to 382.5
|
285 Seconds (default) |
0 |
Disable Gratuitous ARP |
HAA sends a Gratuitous ARP packet (GARP) each 285 seconds, by default, to prevent ARP spoofing attacks and keep WiFi connectivity. Normally, switches and routers have an ARP TTL of 300 seconds. Using a very low value, like "e":3
, could help to keep WiFi connectivity and avoid disconnections in noise environments.
Key | Value | Description |
---|---|---|
"q" |
1 to 2000
|
305 Hz (default) |
This option enables the setting of a custom software PWM frequency in Hz. The value can be set from 1 to 2000. The default is 305 Hz.
A custom PWM frequency is predominantly used when controlling lighting. Setting "q"
to lower values may result in lights blinking very fast.
Only for ESP32 models.
Key | Value | Description |
---|---|---|
"y" |
[ freq_0, freq_1, ... ] |
Array of frequencies for each PWM timer |
1 to 29000
|
5000 Hz (default) |
This option enables the setting of custom hardware PWM frequencies in Hz for each PWM timer. The value can be set from 1Hz to 29KHz. The default is 5KHz.
A custom PWM frequency is predominantly used when controlling lighting. Setting "y"
to lower values may result in lights blinking very fast.
Enables Software PWM to be used by Zero-Cross detection. PWM Frequency should be double of AC frequency, and even a bit more (Double + 10%). For example, for AC 50Hz, a right value of PWM Frequency could be "q" : 110
.
Key | Value | Description |
---|---|---|
"zc" |
array | [ GPIO, Interruption type ] |
- GPIO: Number of GPIO where Zero-Cross pin is connected.
Remember to declare used GPIO as Input into "io":[...]
array. See GPIOs Configuration
- Interrupt type:
Depending of how Zero-Cross hardware works, it is necessary to select correct interrupt. Normally,
HIGH to LOW
is the recommended value.
Type | Description |
---|---|
1 |
LOW to HIGH |
2 |
HIGH to LOW |
3 |
Both |
Time, in milliseconds, used as delay for Binary Output Actions when a trigger GPIO is used. The declared delay is the same for all Trigger GPIO Interrupts (ISR).
This is very useful to synchronize GPIOs changes with the 0V of an AC wave.
Example: "zd":3.6
Key | Value | Description |
---|---|---|
"zd" |
0 |
Disable (default) |
float | Delay, in milliseconds |
Determines Accessory number (not Service) where HAA Setup Service will be placed. This service is only compatible with HAA Home Manager App, to update, enable setup mode, reboot...
Key | Value | Description |
---|---|---|
"s" |
1 |
Put at first Accessory(default) |
0 |
Removes HAA Setup Service | |
N |
Put at Accessory number N |
By default, service is placed at first accessory. But in some cases it is useful to put it in other accessory, for example, when first accessory has a TV Service, that is not showed in HomeKit third-party Apps.
A value of 0
will disable HAA Setup Service. Useful to save DRAM when HAA Home Manager App is not used.
You can declare up to 2 different I2C buses. To declare them, you must use "ic"
key in configuration section. It contains an array of I2C buses.
Each bus must have these settings:
[ SCL, SDA, Frequency, SCL pull-up, SDA pull-up ]
-
SCL
: SCL GPIO. -
SDA
: SDA GPIO. -
Frequency
: Bus frequency in KiloHertz. -
SCL pull-up
: Internal SCL GPIO pull-up resistor.0
disable,1
enable. -
SDA pull-up
: Internal SDA GPIO pull-up resistor.0
disable,1
enable.
SCL pull-up
and SDA pull-up
are optional. Default value is 0
for both.
First declared bus will be bus 0, and second will be bus 1.
Example:
"ic" : [ [ 3, 2, 80, 1, 1 ], [ 13, 14, 500 ] ]
IO Expansion interfaces are used to add extra GPIOs for inputs and outputs. They must declare in configuration section using "mc"
key. It is an array that contains all connected expansion interfaces.
MCP23017 and Shift Registers are supported:
You can connect up to 16 MCP23017 interfaces (8 per I2C bus), having up to 256 extra GPIOs for binary inputs and outputs. I2C bus must be declared to use these interfaces.
Each MCP23017 interface must be declared with an array:
[ Bus, Address, Channel A, Channel B ]
Example of 2 MCPs declaration (first for inputs and second for outputs):
"mc" : [ [ 0, 32, 256, 256 ], [ 0, 33, 0, 0 ] ]
Channel A and B are optional. If they are missed, default value is 258
.
-
Bus
: I2C Bus. -
Address
: Access address. First MCP23017 begins at 32. MCP address is configured usingA2
,A1
andA0
pines. FInal address will be32 + (A2, A1, A0)
; where A2, A1 and A0 represent a binary number of 3 bits, and each bit is 0 or 1 depending is pin is connected to GND or VCC. -
Channel A
: from 0 to 259. Mode and initial state of all channel A GPIOs. -
Channel B
: from 0 to 259. Mode and initial state of all channel B GPIOs.
Channel config values (Default 0
):
-
0 - 255
: OUTPUT. Values are the result of convert 8 bits binary string to decimal.
For example, to set all channel A GPIOs to LOW, but second GPIO to HIGH, you must
use 00000010
in decimal: 2
.
-
256 - 259
: INPUTs-
256
: INPUT with internal pull-up resistor. -
257
: INPUT with internal pull-up resistor, inverted logic. -
258
: INPUT without internal pull-up resistor. Use this if channel is not used. -
259
: INPUT without internal pull-up resistor, inverted logic.
-
Remember to activate Binary Input Continuous Mode in order to work with INPUTs.
You can connect one shift register, or a daisy-chained group of them, for each 3 GPIOs (or 2 if shift register does not use latch pin). Each shift register can manage up to 100 OUTPUTs (from 0 to 99).
To declare a shift register as OUTPUT, declare it as:
[ Clock GPIO + 100, Data GPIO, Latch GPIO, Length, Initial values 1, Initial values 2, ... ]
-
Clock GPIO + 100
: Signal clock. If you want to use GPIO 5, this will be105
. By default, it is declared as OUTPUT. -
Data GPIO
: Pin to send bit states to shift register. By default, it is declared as OUTPUT. -
Latch GPIO
: Pin to send order to activate sent data. IfLatch GPIO
is not needed, set this as-1
. By default, it is declared as OUTPUT. -
Length
: Numbers of bits/outputs of shift register of daisy-chained group. Maximum value is100
(from 0 to 99). -
Initial values
: Each default value is a 8 bits number that correspondes to initial output states. Default value is0
.
You can connect one shift register, or a daisy-chained group of them, for each 2 GPIOs. Each shift register can manage up to 100 INPUTs (from 0 to 99).
Remember to activate Binary Input Continuous Mode in order to work with INPUTs.
To declare a shift register as INPUT, declare it as:
[ Clock GPIO + 100, Data GPIO, -2, Length ]
-
Clock GPIO + 100
: Signal clock. If you want to use GPIO 5, this will be105
. By default, it is declared as OUTPUT. -
Data GPIO
: Pin to read bit states to shift register. By default, it is declared as INPUT, floating. -
Length
: Numbers of bits/outputs of shift register of daisy-chained group. Maximum value is100
(from 0 to 99).
It is possible to override shift registers default GPIOs type declarations in "io":[ ... ]
GPIOs Configuration Array.
Use "r":[ pin, value ]
with I/O expander index and GPIO number. For example: GPIO 12 of first declared IO expander will be 112
.
To call a GPIO from a expansion interface, you must use normal "r":[ pin, value ]
array.
ESP8266 GPIOs are from 0 to 16, but expander GPIOs are used in this format: XYY
- X: is the index of expansion interface in MEPLHAA script.
- YY: is the number of GPIO. (For MCP23017, Channel A GPIOs are from 00 to 07; and channel B, from 08 to 15).
For example, to set to HIGH GPIO 4 of third declared expansion interface:
"r" : [ [ 304 , 1 ] ]
Since HAA V12 Merlin, used GPIOs must be declared into an array with needed options, initial values, and behaviors.
See GPIOs Configuration page to know details.
HAA has an internal software clock to write a timestamp in logs and to perform timedate based actions. Because ESP8266 has not a RTC with a battery, it is needed to get date and time information from a NTP server.
Key | Value | Description |
---|---|---|
"ntp" | Gateway IP Address | Gateway IP address provided by DHCP server (default) |
"0" |
Disable NTP entirely. This will disable TimeTable Actions too. | |
Any | String with desired NTP server (IP Address or FQDN) |
Example:
"ntp" : "time.apple.com"
If configured or default NTP server fails twice, HAA will use pool.ntp.org
as fallback server.
Key | Value | Description |
---|---|---|
"tz" | "UTC0" | ** Default** |
Any | String with timezone in UNIX style |
Timezone for Europe/Paris with daylight saving time:
"tz" : "CET-1CEST-2,M3.5.0/2,M10.5.0/3"
These actions will occur only if there is a working NTP server to get current date and time.
Key | Value | Description |
---|---|---|
"tt" | [ [ A, h, m, W, D, M ], ... ] | Array of arrays with all device actions and timetable declarations |
A |
Device action to exec, from 0 to 50
|
|
h | Hour, from 0 to 23 | |
m | Minute, from 0 to 59 | |
W | Day of the week, from 0 (Sunday) to 6 (Saturday) | |
D | Day of the month, from 1 to 31 | |
M | Month, from 0 (January) to 11 (December) |
If action must occur in all units, value of -1
must be used.
There is not needed to declare all timedate units. Missing units will take default value of -1
.
Setup mode toggle count was introduced in firmware version 0.8.7
Key | Value | Description |
---|---|---|
"z" | 8 | Number of times I/O line needs to be toggled (default) |
0 - 127 | Integer value specifying number of togglations |
One way to enter setup mode is to toggle the I/O line of one of the buttons defined for entering setup mode.
This option allows the configuration of the number of times to toggle the I/O.
A value of 0
will disable this method of entering setup mode.
Key | Value | Description |
---|---|---|
"m" | 0 | Disable. Always respond to setup mode requests (default) |
1 - 65535 | Integer value specifying number of seconds |
This option specifies the time in seconds that the user has to enter setup mode
after a device boot. Any value between 0
(disable) and 65535
can be set.
See Setup Mode for details on how to enter
the mode.
If this option is set then once the time has passed after a reset the user will not be able to enter setup mode without rebooting the device.
{
"c": {
"io": [ [ [ 13 ], 2 ], [ [ 0 ], 6 ] ],
"l": 13,
"b": [ [ 0, 5 ] ],
"m": 10
}
}
In this example the Setup Mode Timer has been set to 10 seconds
("m": 10
).
Beware not to set it to a value to less than 8 if you are using option "b"
with a long press button of 8 seconds ("t": 5
)...
The Delay at boot option, before any hardware configuration or GPIO setup has been done, is defined by the "v"
key.
Key | Default | Type | Description |
---|---|---|---|
"v" | 0 | float | Time in seconds to delay before first accessory creation |
Useful when peripherals and external hardware need more time to boot than ESP chip.
The Delay before services creation option is defined by the "cd"
key.
Key | Default | Type | Description |
---|---|---|---|
"cd" | 0 | float | Time in seconds to delay before first accessory creation |
By default accessories are created within HAA immediately after boot. There are times when a delay is required to allow some hardware to be ready.
When this is required the "cd"
option can be used. Set it to a positive value
in seconds and a delay of that time will occur once the device has booted.
The option only needs to be added if a delay is required. If it is not present then no delay will be executed.
Key | Value | Description |
---|---|---|
"h" | 12 | Maximum number of simultaneous Homekit Clients (default) |
0 | Disable HomeKit Server | |
2 - 12 |
The "h"
option allows you to change maximum number of simultaneous HomeKit clients that
can connect to device, or completely disable the HomeKit server component.
HomeKit clients are iPhones, iPads, Macs, HomePods, AppleTVs and AppleWatches.
By default, up to 20 concurrent clients can be connected; and allowing to connect new clients while dropping others. Then, there is not limit of clients to connect, but new clients access will be a bit slower than connected clients. If there are many HomeKit clients, it is possible to increase this limit to let more clients to connect before dropping others, but this will use more DRAM.
Key | Value | Description |
---|---|---|
"u" | 0 | Disable Unsecure Rest API (default) |
1 | Enable Unsecure Rest API |
This option enables the use of HomeKit third-party tools without an encrypted connection or authentication.
Enabling this is NOT recommended for security reasons, because your accessory will be exposed without any security mechanism, but you can use this feature to manage it under other domestic systems.
You can use commands like these:
Get current accessory status:
curl -X GET http://device_ip_address:5556
Set a "turn on" status of accessory with aid 1 and iid 9:
curl -X PUT -d '{"characteristics":[{"aid":1,"iid":9,"value":true}]}' http://device_ip_address:5556/characteristic
You can download HomeKit specifications to know how to build its JSON from here: https://developer.apple.com/homekit/specification/
Only ESP32 models. ESP8266 has not wifi sleep DTIM mode.
Option to enable or disable WiFi Modem sleep. By default, WiFi driver will use router DTIM beacon to transmit and receive data; but some networks can be incompatible with this, and disable WiFi sleep modem is needed.
Key | Value | Description |
---|---|---|
"d" |
1 |
Enable WiFi Modem Sleep (default) |
0 | Disable WiFi Sleep |
Only ESP32 models. ESP8266 has not wifi bandwidth 40MHz.
By default, wifi bandwidth is 20MHz. It is enough for all HAA network traffic, and to mitigate interferences.
It is possible to select 40MHz, but only for HAA Main firmware running in normal mode.
Installer firmwares and setup modes will use only 20MHz to maximize compatibility and minimize interferences.
Key | Value | Description |
---|---|---|
"dt" |
0 |
Wifi Bandwidth 20MHz (default) |
1 | Wifi Bandwidth 40MHz |
Configurable option to set the TTL value of the mDNS entry held for the device.
This option was implemented in firmware version 2.2.0
Key | Format | Type | Description |
---|---|---|---|
"ttl" |
[ TTL, period ] |
array | HomeKit mDNS Time To Live and period |
16 - 65535 |
seconds | Min - Max values for TTL and period |
Default: "ttl" : [ 4500, 2250 ]
If period is not given, it will be same value as TTL.
Setting period to a very low value such as "ttl" : [ 4500, 120 ]
could be used as a workaround
for networks without a good mDNS support.
This option was implemented in firmware version 3.5.0
Key | Default | Type | Description |
---|---|---|---|
"sn" | XXXXXX-<Acc#> | string | Serial Number Prefix |
This option enables you to add a prefix to the serial number supplied to HomeKit when pairing a device.
Prior to release 3.5.0
the serial number provided for each accessory when
pairing a device was of the format HAA-XXXXXX
where the XXXXXX part
consists of the last 6 characters of the devices MAC address e.g. HAA-669CD4
.
From 3.5.0
onwards the serial number provided is of the format
XXXXXX-<Acc#>
. Where <Acc#> is the configured accessory number e.g. 669CD4-1
.
This change enables applications such as Home Assistant
to recognise the multiple accessories within a device (NOTE: the Apple Home App has
always been lenient on the serial number, but recommends a unique serial number
for each device/accessory).
The user also has the option to prefix the serial number provided with their own
string e.g. { "sn": "ABC" }
. This would result in a serial number of
ABC-669CD4-1
Additionally, if you specify a prefix of { "sn": "cn" }
the HomeKit config
number will be used as the prefix. The config number will be incremented each
time the Save button is pressed in the Setup page and after the device's
firmware is updated e.g. 1-669CD4-1
, 2-669CD4-1
Setting this option in the General Configuration section will apply it to all accessories.
NOTE This option can also be placed in an accessory's configuration section. If used in the Accessory Configuration section then it will override any value that has been set as part of the General Configuration.
This option was implemented in firmware version 2.2.0
Key | Default | Type | Description |
---|---|---|---|
"pt" | 5 | float | Period between pings |
This option enables you to configure the period between pings being transmitted by an accessory that determine actions to take or statuses to set.
The value is a float and so fractions of a second can be specified e.g. "pt": 0.5
This option was implemented in firmware version 2.5.0
Key | Default | Type | Description |
---|---|---|---|
"w" | disabled | integer | Number of consecutive ping failures before reconnection |
When this option is added to the general configuration the device will monitor the network by performing an ICMP ping to the gateway every second. If the configurable number of consecutive ping failures occur then the device will start the connection process again.
This feature is disabled by default. If enable, default Gratuitous ARP will be disabled. To enable Gratuitous ARP, it must be declare explicitly.
NOTE: If a value of 0 is used ("w":0
) then the device will attempt to
reconnect after the first ping failure.
Key | Default | Type | Description |
---|---|---|---|
"t" | none | integer | GPIO used by the IR Tx LED (Mandatory) |
"j" | 0 | integer | Use to invert IR Tx LED state (default: 0) |
"x" | 38 | integer | Frequency (in KHz) of IR marks |
"p" | none | integer | IR protocol to use |
When using your device to transmit infra-red commands to control other devices
you need to, as a minimum, set the "t"
option to define the GPIO
pin that the infra-red transmitter is connected to.
Remember to declare used GPIO as Output into "io":[...]
array. See GPIOs Configuration
The "j"
option is used to invert the state of the IR Tx LED GPIO pin and configure open-drain HIGH output.
Key | Value | Description |
---|---|---|
"j" |
0 |
Do not invert (default) |
1 |
Invert | |
2 |
Do not invert and set as open-drain | |
3 |
Invert and set as open-drain |
The "x"
option allows you to define the frequency in Kilohertz (KHz) that the
IR LED flashes. The default is 38KHz.
This frequency is used by the majority of infra-red controllers on the market
today.
The "p"
option allows you to define the default IR protocol.
This protocol will be used by any IR Code Actions unless the action specifies
an alternate protocol using the "p"
option in the action object.
Protocol | Setting |
---|---|
2 bits | "p":"HHHH00001111FF" |
4 bits | "p":"HHHH0000111122223333FF" |
6 bits | "p":"HHHH000011112222333344445555FF" |
Refer to the IR Code Actions section in the Accessory Configuration details for information on defining IR code actions.
Refer to the Using Infra-red in HAA for details on defining the protocol and protocol codes.
Key | Default | Type | Description |
---|---|---|---|
"r" | none | array | Array of UARTs for use with UART Actions |
Your device can use up to two UART ports to control accessories. To use UART ports you must configure them within the General Configuration and then use UART Actions to send commands, but can not get status from your attached accessory.
{
"c":{
"io": [ [ [ 13 ], 2 ], [ [ 0 ], 6 ] ],
"l": 13,
"b": [ [ 0, 5 ] ],
"r": [
{ "n":0, "s":9600, "p":0, "b":0 }
]
}
}
In this example UART0 has been set up to communicate at 9600 baud, no parity and 0 stop bits.
In esp8266, the UART will use GPIO lines 1 & 3 for communication.
This option was implemented in firmware version 2.1.0
The "n"
key is used to define up to two UARTs can be configured and used to
control accessories.
In ESP8266, there are 2 UARTs. UART0 supports both receive and transmit, UART1 supports only transmit.
Key | Value | Description |
---|---|---|
"n" |
0 |
UART0, using GPIO 1 (Tx) & 3 (Rx) |
1 |
UART1, using GPIO 2 (Tx) | |
2 |
UART0, using GPIO 15 (Tx) & 13 (Rx) | |
10 |
Same as 0 , but enabling Free Monitor Receiver
|
|
12 |
Same as 2 , but enabling Free Monitor Receiver
|
In ESP32 models, there are 3 UARTs with receive and transmit support.
Key | Value | Description |
---|---|---|
"n" | 0 | UART0 |
1 | UART1 | |
2 | UART2 | |
10 | Same as 0 , but enabling Free Monitor Receiver
|
|
11 | Same as 1 , but enabling Free Monitor Receiver
|
|
12 | Same as 2 , but enabling Free Monitor Receiver
|
ESP32 can use any combination of GPIOs with UARTs. There is not default GPIOs, then it is mandatory to declare used GPIOs into
an array "g":
for each UART port.
"g" : [ TX, RX, RTS, CTS ]
Pins that are not used must be declared with -1
, or don't declare them, using a shorter array.
For example, if you only want to use UART TX pin with GPIO 1, because it will be only used for output, you can declare array as:
"g" : [1]
Or if only RX pin will be used at GPIO 3:
"g" : [ -1, 3]
UART supports different modes.
Key | Value | Description |
---|---|---|
"m" | 0 | UART/RS232 default |
1 | RS485 Half duplex | |
2 | IrDA |
The "s"
key is used to set the baudrate of the UART.
The following baudrates are supported:
Key | Value | Description |
---|---|---|
"s" |
460800 | Only ESP32 models |
230400 | Only ESP32 models | |
115200 | default | |
57600 | ||
38400 | ||
19200 | ||
14400 | ||
9600 | ||
4800 | ||
2400 | ||
1200 | ||
600 | ||
300 |
The "p"
key is used to set the parity of the UART.
The following options are supported:
Key | Value | Description |
---|---|---|
"p" | 0 | None (default) |
1 | Even | |
2 | Odd |
The "b"
key is used to set the stop bits of the UART.
The following options are supported:
Key | Value | Description |
---|---|---|
"b" | 0 | 0 bits |
1 | 1 bit (default) | |
2 | 1.5 bits | |
3 | 2 bits |
Option to configure minimum and maximum length of received UART commands when UART Receiver is used.
"l" : [ min , max ]
Values must be between 1
and 255
. And min
value can not be greater than max
value.
This option was implemented in firmware version 3.3.0
Certain actions can occur when specific events happen within the device. These actions are called Device Actions and are documented below.
Available Device events are:
Event | Key | Description |
---|---|---|
Boot | "0" | Actions to occur at the boot of a device |
Post Accessory Declaration | "1" | Actions to occur after accessory declaration |
First WiFi Connection | "2" | Actions to occur after first WiFi connection |
WiFi Reconnection | "3" | Actions to occur on a WiFi reconnection |
WiFi Disconnection | "4" | Actions to occur on a WiFi disconnection |
WiFi Disconnection After Retry | "5" | Actions to occur after about 5 minutes without a WiFi reconnection |
New WiFi Channel | "6" | Actions to occur when WiFi channel has changed |
New IP Address | "7" | Actions to occur when IP address has changed |
See Actions for details on the actions that can be defined for each of the above events.
Additional device actions can be declared to use with Timetable Actions, up to action "50"
.
In this example the device is configured to turn on an LED (GPIO 14) when the device has WiFi connectivity and turn it off when connectivity is lost.
{
"c": {
"io": [ [ [ 13, 12, 14 ], 2 ], [ [ 0 ], 6 ] ],
"l": 13,
"2": { "r": [ [ 14, 1 ] ] },
"3": { "r": [ [ 14, 1 ] ] },
"4": { "r": [ [ 14, 0 ] ] },
"5": { "r": [ [ 14, 0 ] ] }
},
"a": [{
"t": 1,
"0": { "r": [ [ 12, 0 ] ] },
"1": { "r": [ [ 12, 1 ] ] },
"b": [ [ 0, 1 ] ]
}]
}
This option was implemented in firmware version 3.2.0
The "ct"
option enables the HomeKit device category to be overwritten or
customised.
If this option is not specified then the device category that is presented to
HomeKit when a device is added is taken from the first accessory in the
accessory definitions list.
Device categories available are:
Value | Category |
---|---|
1 | Other |
2 | Bridge |
3 | Fan |
4 | Garage Door Opener |
5 | Lightbulb |
6 | Door Lock |
7 | Outlet |
8 | Switch |
9 | Thermostat |
10 | Sensor |
11 | Security System |
12 | Door |
13 | Window |
14 | Window Covering |
15 | Programmable Switch |
16 | Range Extender |
17 | IP Camera |
18 | Video Doorbell |
19 | Air Purifier |
20 | Heater |
21 | Air Conditioner |
22 | Humidifier |
23 | Dehumidifier |
24 | Apple TV |
25 | HomePod |
26 | Speaker |
27 | Airport |
28 | Sprinkler |
29 | Faucet |
30 | Shower Head |
31 | Television |
32 | Remote Controller |
33 | Wifi Router |
34 | Audio Receiver |
35 | TV Set Top Box |
36 | TV Streaming Stick |
Home Accessory Architect
Home Accessory
Installation
Setup Mode
HAA Home Manager App
Configuration
About
General
| GPIOs Configuration
Accessory
| Actions
Service Types
Air Quality
Battery
Data History
Fan
Free Monitor
Garage Door
HAA iAirZoning
Heater Cooler
Humidifier
Light Sensor
Lightbulb
Lock Mechanism
Sensors
Power Monitor
Security System
Stateless Button & Doorbell
Switch & Outlet
Temperature & Humidity
TV
Water Valve
Window Covering