This repository provides a step-by-step guide to developing HomeKit accessories using ESP32 and the ESP-IDF framework.
Ensure you have the necessary software installed before proceeding:
- Install Docker Desktop for Mac.
- Sign in to your Docker account.
- Pull the latest ESP-IDF version:
docker pull espressif/idf:v5.3
Check if Python 3 is installed:
python3 --version
If not installed:
xcode-select --install # Install Xcode
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" # Install Homebrew
brew install python3 # Install Python 3
python3 -m ensurepip
Ensure Python 3.10.1 or newer is installed, then run:
pip3 install esptool
git clone --recursive https://github.com/AchimPieters/esp32-homekit-demo.git
docker run -it -v ~/esp32-homekit-demo:/project -w /project espressif/idf:v5.3
cd examples/led
idf.py set-target esp32
idf.py menuconfig
Configure Wi-Fi credentials under StudioPieters
:
- Wi-Fi SSID:
(mysid)
- Wi-Fi Password:
(mypassword)
Save and exit.
idf.py build
esptool.py erase_flash
python -m esptool --chip esp32 -b 460800 --before default_reset --after hard_reset write_flash \
--flash_mode dio --flash_size 4MB --flash_freq 40m \
0x1000 build/bootloader/bootloader.bin \
0x8000 build/partition_table/partition-table.bin \
0x10000 build/main.bin
screen /dev/tty.usbserial-01FD1166 115200
Replace /dev/tty.usbserial-01FD1166
with your USB port.
Launch your HomeKit app on your smartphone.
Scan the generated QR code to add your ESP32 device.
Accept the uncertified accessory prompt and add the device.
Toggle the LED on/off directly from the HomeKit app.
Set up HomeKit automations for advanced functionality.
The HomeKit setup code must be an 8-digit number, formatted as XXX-XX-XXX
(e.g., 101-48-005
).
Each accessory needs a unique 4-character setup ID (e.g., 1QJ8
).
homekit_server_config_t config = {
.accessories = accessories,
.password = "123-45-678",
.setupId = "1QJ8",
};
Ensure Python and required libraries are installed:
python3 -m pip install --upgrade pip Pillow qrcode
Generate the QR code:
tools/gen_qrcode 5 123-45-678 1QJ8 qrcode.png
5
: HomeKit accessory category (Lighting)123-45-678
: Setup code1QJ8
: Setup IDqrcode.png
: Output file
Category | Number |
---|---|
Other | 1 |
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 |
Range extenders | 16 |
IP cameras | 17 |
Video doorbells | 18 |
Air purifiers | 19 |
Heaters | 20 |
Air conditioners | 21 |
Humidifiers | 22 |
Dehumidifiers | 23 |
Apple TV | 24 |
Speakers | 26 |
Airport | 27 |
Sprinklers | 28 |
Faucets | 29 |
Shower heads | 30 |
Televisions | 31 |
Target remotes | 32 |
For the full list, refer to the official HomeKit documentation.
By following this guide, you've successfully set up an ESP32-based HomeKit accessory using ESP-IDF. Happy coding!
__________________________________________________________________________________________
Copyright © 2025 StudioPieters© | Achim Pieters
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
__________________________________________________________________________________________
The Works with Apple Home badge can be used to visually communicate that your accessory is compatible with the Apple Home and Siri on Apple devices. If you plan to develop or manufacture a HomeKit accessory that will be distributed or sold, your company needs to be enrolled in the MFi Program.
__________________________________________________________________________________________
HomeKit Accessory Protocol (HAP) is Apple’s proprietary protocol that enables third-party accessories in the home (e.g., lights, thermostats and door locks) and Apple products to communicate with each other. HAP supports two transports, IP and Bluetooth LE. The information provided in the HomeKit Accessory Protocol Specification (Non-Commercial Version) describes how to implement HAP in an accessory that you create for non-commercial use and that will not be distributed or sold.
The HomeKit Accessory Protocol Specification (Non-Commercial Version) can be downloaded from the HomeKit Apple Developer page.