Skip to main content

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)
  --release-url TEXT              Release notes URL for the manifest OTA entry (auto-detected from the GitHub Actions trigger: release page or triggering commit)
  --release-summary TEXT          Short release summary for the manifest OTA entry
  --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 ("Take Control") in ESPHome Dashboard

ESPHome's dashboard import requires a git shorthand URL (github://owner/repo/config.yaml@ref) — a plain published URL is not accepted. The import URL is determined, in order, from:

  1. --import-url if provided (e.g. github://user/repo/config.yaml@main)
  2. The GitHub source URL, when the config is fetched from one
  3. The GitHub Actions context (GITHUB_REPOSITORY, GITHUB_REF_NAME and the config's path in the checkout) when generated by a workflow

If none of these apply, dashboard import is omitted (OTA updates still work).

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-version command line option
  • esphome.project.version field in the YAML configuration

If no version is found, a warning is shown and OTA components are omitted (dashboard import still works).

When OTA is enabled, each manifest.json build also gets an ota entry that ESPHome's update.http_request platform uses to update already-running devices:

{
  "chipFamily": "ESP32-S3",
  "parts": [{ "path": "firmware-esp32s3-2026.6.0.bin", "offset": 0 }],
  "ota": {
    "path": "firmware-esp32s3-2026.6.0.ota.bin",
    "md5": "...",
    "sha256": "...",
    "summary": "ESPHome 2026.6.0",
    "release_url": "https://github.com/owner/repo/releases/tag/2026.6.0"
  }
}

The OTA (app-only) image is copied alongside the factory image and its checksums are computed automatically. The optional summary and release_url fields, shown by the firmware update entity, are set with:

  • --release-summary - short text describing the release
  • --release-url - link to the release notes. When not specified and running in GitHub Actions, this is auto-detected from the trigger: the release page for release events, otherwise a link to the triggering commit (since not every workflow publishes a GitHub Release)

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 esphome if available, falls back to uvx esphome

License

Apache 2.0

Credits

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

ewt_gen-1.5.0.tar.gz (25.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ewt_gen-1.5.0-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file ewt_gen-1.5.0.tar.gz.

File metadata

  • Download URL: ewt_gen-1.5.0.tar.gz
  • Upload date:
  • Size: 25.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ewt_gen-1.5.0.tar.gz
Algorithm Hash digest
SHA256 ada859537cc663d75518beb49c7893944d0ca5004553bf833dc0b43c4680e032
MD5 427b59e85dd1456cc5ba002d3263c8e7
BLAKE2b-256 6a1fb52e8f36d8f75276151345f69248068f43a0598340295fb23b19c1b9cb0a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ewt_gen-1.5.0.tar.gz:

Publisher: publish.yml on esphome/ewt-gen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ewt_gen-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: ewt_gen-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 16.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ewt_gen-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2654fa39cd1e4b00962966563567b1ffe7d1d2a21129730324a3342ef4b162d
MD5 1532f2fe0c516fe69cab73b5a0b109fc
BLAKE2b-256 20e0ba5a2cbf285edf670f3e24d19776cd6ab29fffe8b19ed3ae61c7f84d0b9a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ewt_gen-1.5.0-py3-none-any.whl:

Publisher: publish.yml on esphome/ewt-gen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page