Generate static websites for ESPHome firmware distribution using ESP Web Tools
Project description
ewt-gen
Generate static websites for ESPHome firmware distribution using ESP Web Tools. Example output.
Quick Start
# From a local file
uvx ewt-gen config.yaml
# From a URL
uvx ewt-gen https://github.com/esphome/firmware/blob/main/esphome-web/esp32.factory.yaml
# Multiple configurations
uvx ewt-gen esp32.yaml esp32c3.yaml
Installation
# Run directly without installing (recommended)
uvx ewt-gen config.yaml
# Or install globally
uv tool install ewt-gen
ewt-gen config.yaml
# Or with pip
pip install ewt-gen
Usage
# From a local file
uvx ewt-gen config.yaml
# From a GitHub file URL
uvx ewt-gen https://github.com/user/repo/blob/main/config.yaml
# From a GitHub Gist
uvx ewt-gen https://gist.github.com/user/abc123
# From any URL
uvx ewt-gen https://example.com/config.yaml
Options
ewt-gen [OPTIONS] YAML_SOURCE
Options:
--version Show version
--skip-compile Skip ESPHome compilation (use existing firmware)
-f, --firmware PATH Path to firmware binary
-c, --chip-family [esp32|esp32-c3|esp32-s2|esp32-s3|esp8266]
Chip family (auto-detected from YAML)
-o, --output PATH Output directory (defaults to YAML filename)
-t, --title TEXT Page title (defaults to name from YAML)
--pre-release Use pre-release ESPHome version via uvx
--publish-url TEXT URL where firmware will be published (enables OTA)
--fw-version TEXT Firmware version (read from esphome.project.version if not specified)
--help Show help
Examples
# Basic usage - compiles and generates site
ewt-gen my-device.yaml
# Custom output directory and title
ewt-gen my-device.yaml -o ./dist -t "My Smart Device"
# Use pre-release ESPHome
ewt-gen my-device.yaml --pre-release
# Skip compilation, use existing firmware
ewt-gen my-device.yaml --skip-compile -f firmware.bin
# Enable OTA updates and dashboard import
ewt-gen my-device.yaml --publish-url https://firmware.example.com/my-device
# Specify version explicitly
ewt-gen my-device.yaml --publish-url https://firmware.example.com/my-device --fw-version 1.0.0
OTA Updates and Dashboard Import
When using --publish-url, the tool generates a factory firmware that includes:
- OTA updates via HTTP - Devices can check for and install firmware updates
- Dashboard import - Users can adopt the device in ESPHome Dashboard (if source is a GitHub URL)
The tool creates two YAML files in the output:
{name}.yaml- The original configuration (for users to customize){name}.factory.yaml- Factory firmware that imports the original and adds OTA support
The version is required for OTA updates to work correctly. It can be specified via:
--fw-versioncommand line optionesphome.project.versionfield in the YAML configuration
If no version is found, a warning is shown and OTA components are omitted (dashboard import still works).
Generated Site
The tool generates a static website containing:
- ESP Web Tools install button - One-click firmware installation (requires HTTPS)
- Alternative install section - Link to download binary and use with ESPHome Web
- ESPHome configuration section - Download links and expandable view of the YAML configuration
- Manual installation instructions - For non-HTTPS contexts, with link to web.esphome.io
HTTPS Requirement
Browser-based installation using ESP Web Tools requires a secure context (HTTPS or localhost). When served over HTTP, the page automatically shows manual installation instructions instead.
ESPHome Detection
The tool automatically:
- Detects chip family from the YAML configuration
- Finds compiled firmware in
.esphome/build/directory - Uses local
esphomeif available, falls back touvx esphome
License
Apache 2.0
Credits
- ESP Web Tools - Browser-based firmware installation
- ESPHome - Easy ESP8266/ESP32 firmware configuration
- Open Home Foundation
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ewt_gen-1.4.2.tar.gz.
File metadata
- Download URL: ewt_gen-1.4.2.tar.gz
- Upload date:
- Size: 23.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
74d51c135d5b941c9e21bbe5268f7bb2a3d8ad3a4d88f89d9d201a2e8433104a
|
|
| MD5 |
4e431d82d7856933a6fca19f0d2af035
|
|
| BLAKE2b-256 |
d5e48526137df510dc9241a9b2ab4da4564de7c860a6d5d5fc99badbf0c3753e
|
Provenance
The following attestation bundles were made for ewt_gen-1.4.2.tar.gz:
Publisher:
publish.yml on esphome/ewt-gen
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ewt_gen-1.4.2.tar.gz -
Subject digest:
74d51c135d5b941c9e21bbe5268f7bb2a3d8ad3a4d88f89d9d201a2e8433104a - Sigstore transparency entry: 1499007275
- Sigstore integration time:
-
Permalink:
esphome/ewt-gen@e6b372023a983b4057afd01ac0e7b6ebd238244e -
Branch / Tag:
refs/tags/1.4.2 - Owner: https://github.com/esphome
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e6b372023a983b4057afd01ac0e7b6ebd238244e -
Trigger Event:
release
-
Statement type:
File details
Details for the file ewt_gen-1.4.2-py3-none-any.whl.
File metadata
- Download URL: ewt_gen-1.4.2-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d6251b241bbbdff58d08396c80f1b03c285d2676a2960cc7bdeecf7067fcc073
|
|
| MD5 |
99a17fee566850e7182d00978d566f21
|
|
| BLAKE2b-256 |
c7f3cab96f6f84ea42dcec2b60077ba58b2e27329fa61b534e6a1d0f9242f52f
|
Provenance
The following attestation bundles were made for ewt_gen-1.4.2-py3-none-any.whl:
Publisher:
publish.yml on esphome/ewt-gen
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ewt_gen-1.4.2-py3-none-any.whl -
Subject digest:
d6251b241bbbdff58d08396c80f1b03c285d2676a2960cc7bdeecf7067fcc073 - Sigstore transparency entry: 1499007398
- Sigstore integration time:
-
Permalink:
esphome/ewt-gen@e6b372023a983b4057afd01ac0e7b6ebd238244e -
Branch / Tag:
refs/tags/1.4.2 - Owner: https://github.com/esphome
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e6b372023a983b4057afd01ac0e7b6ebd238244e -
Trigger Event:
release
-
Statement type: