Files
esphome-templates-dlitz/waveshare-esp32-s3-zero_btproxy.yaml
2025-10-16 12:56:56 -06:00

256 lines
5.8 KiB
YAML

# Ref: https://next.esphome.io/guides/creators/?highlight=dashboard_import
# Waveshare ESP32-S3-Zero used as a bluetooth beacon proxy
# TODO: Need to geenrate a unique minor number for the bluetooth
substitutions:
name: "project-template"
#friendly_name: "Project Template"
ibeacon_minor_number: 65535
#wifi_ap_password: "CHANGE-ME-INSECURE-PASSWORD-e7bMQb9hDbVmUT3U"
packgaes:
esphome_templates_dlitz:
url: https://gitea.dlitz.net/scratch/esphome-templates-dlitz
ref: main
files:
- "waveshare-esp32-s3-zero_btproxy.yaml"
refresh: id
dashboard_import:
package_import_url: https://gitea.dlitz.net/scratch/esphome-templates-dlitz.git/waveshare-esp32-s3-zero_btproxy.yaml
import_full_config: false
esphome:
name: "${name}"
name_add_mac_suffix: true
#friendly_name: "${friendly_name}"
#project:
# name: "${project_name}"
# version: "${project_version}"
# Board: Waveshare ESP32-S3-Zero
# Chip: ESP32-S3FH4R2
# CPU speed: 240MHz
# Flash: 4MB
# PSRAM: 2MB, Quad, 80MHz
esp32:
variant: esp32s3
flash_size: 4MB
cpu_frequency: 240MHz
framework:
type: esp-idf
psram:
speed: 80MHz
# Enable logging
logger:
level: DEBUG
# Enable Home Assistant API
api:
ota:
- platform: esphome
wifi:
#ssid: !secret wifi_ssid
#password: !secret wifi_password
fast_connect: true
enable_btm: true
enable_rrm: true
# Enable fallback hotspot (captive portal) in case wifi connection fails
ap:
ssid: "${friendly_name} fallback"
#password: "${wifi_ap_password}"
captive_portal:
network:
enable_ipv6: true
min_ipv6_addr_count: 2
safe_mode:
reboot_timeout: 10min
esp32_ble_tracker:
bluetooth_proxy:
active: true
esp32_ble_beacon:
type: iBeacon
uuid: 'c3c4fcfa-de20-44d5-98e3-686f2dc47875'
major: 10159
minor: "${ibeacon_minor_number}"
#measured_power: -51
# "Buttons" created in home-assistant
button:
- platform: restart
id: button_restart
name: Restart
- platform: safe_mode
id: button_safe_mode
name: Safe Mode Boot
# - platform: factory_reset
# id: factory_reset_btn
# name: Factory reset
binary_sensor:
- platform: gpio
name: "BOOT button"
entity_category: diagnostic
pin:
number: GPIO0
mode:
input: true
pullup: true
inverted: true
filters:
- delayed_on: 10ms
- delayed_off: 10ms
on_click:
- button.press: button_safe_mode
light:
- platform: esp32_rmt_led_strip
id: rgb_led
name: RGB LED
#entity_category: config
pin: GPIO21
rgb_order: RGB
chipset: WS2812
num_leds: 1
restore_mode: ALWAYS_ON
initial_state: # XXX This doesn't seem to work for some rason
state: true
red: 0%
green: 100%
blue: 0%
brightness: 30%
effects:
- strobe:
- strobe:
name: Identify
colors:
- state: true
brightness: 30%
red: 0%
green: 0%
blue: 100%
duration: 250ms
- state: true
brightness: 100%
red: 0%
green: 0%
blue: 100%
duration: 250ms
- state: true
brightness: 100%
red: 0%
green: 100%
blue: 100%
duration: 250ms
- state: true
brightness: 30%
red: 0%
green: 100%
blue: 100%
duration: 250ms
- platform: status_led
internal: true
id: status_led_id
output: status_led_output
output:
- platform: template
id: status_led_output
type: binary
write_action:
- lambda: |-
static int prev_state = -1;
//ESP_LOGD("my_status", "prev_state: %d, state: %d, state size: %d", prev_state, (int)state, sizeof(state));
if (prev_state <= 0 && state > 0) {
prev_state = state;
auto call = id(rgb_led).turn_on();
call.set_brightness(0.30);
call.set_rgb(1.0, 0.0, 0.0); // red
call.set_transition_length(0);
call.set_publish(false); // Don't spam the logs
call.perform();
} else if (prev_state > 0 && state == 0) {
prev_state = state;
auto call = id(rgb_led).make_call();
call.from_light_color_values(id(rgb_led).remote_values);
call.set_transition_length(0);
call.set_publish(false); // Don't spam the logs
call.perform();
}
switch:
- platform: template
name: Identify
entity_category: config
optimistic: true
turn_on_action:
- light.turn_on:
id: rgb_led
effect: Identify
- logger.log:
format: "identify ON"
level: INFO
turn_off_action:
- light.turn_off:
id: rgb_led
- logger.log:
format: "identify OFF"
level: INFO
- platform: template
id: trig_warning
name: Trigger warning
entity_category: diagnostic
disabled_by_default: true
optimistic: true
turn_on_action:
- lambda: |-
id(trig_warning).status_set_warning("foo");
turn_off_action:
- lambda: |-
id(trig_warning).status_clear_warning();
- platform: template
id: trig_error
name: Trigger error
entity_category: diagnostic
disabled_by_default: true
optimistic: true
turn_on_action:
- lambda: |-
id(trig_error).status_set_error("foo");
turn_off_action:
- lambda: |-
id(trig_error).status_clear_error();
#- platform: color_status_led
# name: Color Status LED
sensor:
- platform: uptime
type: seconds
name: Uptime
#- platform: template
# name: App state (uint8)
# lambda: |-
# return App.get_app_state();
# update_interval: 1s