Add testing stuff

This commit is contained in:
Joshua Boniface 2023-11-22 18:35:09 -05:00
parent 8c592b3a6b
commit 4c04042aeb
3 changed files with 659 additions and 68 deletions

View File

@ -20,6 +20,16 @@
#
###############################################################################
#
# Compile-time Substitutions
#
substitutions:
ignored_radar_ranges: |-
{
{ 2.20, 3.30 },
{ 2.20, 2.75 }
}
#
# Core configuration
#
@ -27,7 +37,16 @@ esphome:
name: supersensor
name_add_mac_suffix: true
on_boot:
- priority: 200
- priority: 600
then:
- light.turn_on:
id: output_led
effect: flash
red: 1
green: 1
blue: 1
- priority: 100
then:
# Configure LD1125H via UART
- uart.write:
@ -65,20 +84,18 @@ esphome:
data: !lambda |-
std::string rmaxst = "rmax=" + str_sprintf("%.1f",id(LD1125H_rmax).state) + "\r\n";
return std::vector<uint8_t>(rmaxst.begin(), rmaxst.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string omst = "opt_mode=1\r\n";
return std::vector<uint8_t>(omst.begin(), omst.end());
- priority: -100
- priority: -500
then:
- light.turn_on:
id: output_led
effect: flash
red: 1
green: 1
blue: 1
- wait_until: api.connected
- delay: 3s
- switch.turn_on: use_wake_word
- delay: 2s
- switch.turn_off: use_wake_word
- delay: 2s
- switch.turn_on: use_wake_word
- light.turn_off:
id: output_led
esp32:
board: esp32dev
@ -94,6 +111,12 @@ esp32:
CONFIG_ESP32S3_DATA_CACHE_64KB: "y"
CONFIG_ESP32S3_DATA_CACHE_LINE_64B: "y"
external_components:
- source:
type: git
url: https://github.com/ssieb/custom_components
components: [ serial ]
logger:
level: VERBOSE
baud_rate: 115200
@ -104,6 +127,7 @@ api:
ota:
password: !secret ota_password
safe_mode: false
web_server:
port: 80
@ -120,8 +144,9 @@ wifi:
uart:
id: LD1125H_UART_BUS
rx_pin: GPIO16
tx_pin: GPIO17
rx_pin: GPIO18
tx_pin: GPIO19
setup_priority: 200
baud_rate: 115200
data_bits: 8
stop_bits: 1
@ -132,6 +157,31 @@ i2c:
scl: GPIO22
scan: true
#
# Radar Globals
#
globals:
- id: LD1125H_Last_Update_Time
type: uint32_t
restore_value: no
initial_value: millis()
- id: LD1125H_Last_Time
type: time_t
restore_value: no
initial_value: time(NULL)
- id: LD1125H_Last_Mov_Time
type: time_t
restore_value: no
initial_value: time(NULL)
- id: LD1125H_Clearance_Status
type: bool
restore_value: no
initial_value: "false"
- id: ignored_ranges
type: std::vector<std::vector<float>>
restore_value: no
initial_value: ${ignored_radar_ranges}
#
# Voice Control
#
@ -153,30 +203,6 @@ voice_assistant:
auto_gain: 31dBFS
volume_multiplier: 5.0
id: assist
on_client_connected:
- if:
condition:
switch.is_on: use_wake_word
then:
- voice_assistant.start_continuous:
- wait_until: voice_assistant.is_running
- delay: 1s
- lambda: id(assist).set_use_wake_word(true);
- light.turn_off:
id: output_led
on_client_disconnected:
- if:
condition:
switch.is_on: use_wake_word
then:
- light.turn_on:
id: output_led
effect: flash
red: 1
green: 1
blue: 1
- lambda: id(assist).set_use_wake_word(false);
- voice_assistant.stop:
on_wake_word_detected:
- light.turn_off:
id: output_led
@ -268,11 +294,11 @@ button:
#
switch:
- platform: template
name: "Enable Wake Word"
name: "Voice Enable Wake Word"
icon: mdi:account-voice
id: use_wake_word
optimistic: true
restore_mode: RESTORE_DEFAULT_ON
restore_mode: ALWAYS_OFF
entity_category: config
on_turn_on:
- lambda: id(assist).set_use_wake_word(true);
@ -295,25 +321,97 @@ binary_sensor:
name: "PIR Motion"
device_class: motion
- platform: gpio
pin: GPIO32
name: "Radar Motion"
- platform: template
name: "LD1125H Occupancy & Movement"
id: LD1125H_MovOcc_Binary
device_class: occupancy
- platform: template
name: "LD1125H Motion"
id: LD1125H_Mov_Binary
device_class: motion
#
# LD1125H Text Sensors
#
text_sensor:
- platform: serial
uart_id: LD1125H_UART_BUS
name: "LD1125H UART Text"
id: LD1125H_UART_Text
icon: mdi:format-text
internal: true
on_value:
then:
- lambda: |-
if ((millis() - id(LD1125H_Last_Update_Time)) < 1000) {
return;
} else {
id(LD1125H_Last_Update_Time) = millis();
}
for (const auto& row : id(ignored_ranges)) {
if ( ( atof(id(LD1125H_UART_Text).state.substr(9).c_str()) > row[0] ) && ( atof(id(LD1125H_UART_Text).state.substr(9).c_str()) < row[1] ) ) {
break;
} else {
if (id(LD1125H_UART_Text).state.substr(0,3) == "occ") {
id(LD1125H_Distance).publish_state(atof(id(LD1125H_UART_Text).state.substr(9).c_str()));
if ((time(NULL)-id(LD1125H_Last_Mov_Time))>id(LD1125H_Mov_Time).state) {
id(LD1125H_Occupancy).publish_state("Occupied");
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
if (id(LD1125H_Mov_Binary).state == true) {
id(LD1125H_Mov_Binary).publish_state(false);
}
}
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
id(LD1125H_Last_Time) = time(NULL);
if (id(LD1125H_Clearance_Status) == true) {
id(LD1125H_Clearance_Status) = false;
}
}
else if (id(LD1125H_UART_Text).state.substr(0,3) == "mov") {
id(LD1125H_Distance).publish_state(atof(id(LD1125H_UART_Text).state.substr(9).c_str()));
id(LD1125H_Occupancy).publish_state("Movement");
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
if (id(LD1125H_Mov_Binary).state == false) {
id(LD1125H_Mov_Binary).publish_state(true);
}
id(LD1125H_Last_Mov_Time) = time(NULL);
id(LD1125H_Last_Time) = time(NULL);
if (id(LD1125H_Clearance_Status) == true) {
id(LD1125H_Clearance_Status) = false;
}
}
}
}
- platform: template
name: "LD1125H Occupancy Status"
id: LD1125H_Occupancy
icon: "mdi:motion-sensor"
#
# Other Sensors
#
sensor:
# BME280 Temperature/Humidity/Pressure sensor
- platform: bme280
temperature:
name: "BME280 Temperature"
pressure:
name: "BME280 Pressure"
humidity:
name: "BME280 Humidity"
pressure:
name: "BME280 Pressure"
update_interval: 15s
address: 0x76
# BMP280 Temperature/Pressure sensor (TEMPORARY)
- platform: bmp280
temperature:
name: "BMP280 Temperature"
@ -322,6 +420,15 @@ sensor:
update_interval: 15s
address: 0x76
# LD1125H Distance
- platform: template
name: LD1125H Detect Distance
id: LD1125H_Distance
icon: mdi:signal-distance-variant
unit_of_measurement: "m"
accuracy_decimals: 2
# Internal sensors
- platform: uptime
name: "ESP32 Uptime"
icon: mdi:clock-alert
@ -499,26 +606,46 @@ number:
std::string rmaxst = "rmax=" + str_sprintf("%.1f",x) +"\r\n";
return std::vector<uint8_t>(rmaxst.begin(), rmaxst.end());
# - platform: template
# name: "LD1125H Clear Time"
# id: LD1125H_Clearance_Time
# icon: mdi:cogs
# entity_category: "config"
# optimistic: true
# restore_value: true
# initial_value: "15"
# min_value: 0
# max_value: 60
# step: 1
- platform: template
name: "LD1125H Clear Time"
id: LD1125H_Clearance_Time
icon: mdi:cogs
entity_category: "config"
optimistic: true
restore_value: true
initial_value: "15"
min_value: 0
max_value: 60
step: 1
# - platform: template
# name: "LD1125H Detect Time"
# id: LD1125H_Mov_Time
# icon: mdi:cogs
# entity_category: "config"
# optimistic: true
# restore_value: true
# initial_value: "0.1"
# min_value: 0.1
# max_value: 10
# step: 0.1
- platform: template
name: "LD1125H Detect Time"
id: LD1125H_Mov_Time
icon: mdi:cogs
entity_category: "config"
optimistic: true
restore_value: true
initial_value: "0.1"
min_value: 0.1
max_value: 10
step: 0.1
#
# Radar Clear Scan Time Interval
#
interval:
- interval: 1s
then:
lambda: |-
if ((time(NULL)-id(LD1125H_Last_Time))>id(LD1125H_Clearance_Time).state) {
if ((id(LD1125H_Clearance_Status) == false) || (id(LD1125H_Occupancy).state != "Clear")) {
id(LD1125H_Occupancy).publish_state("Clear");
id(LD1125H_Clearance_Status) = true;
}
if (id(LD1125H_MovOcc_Binary).state == true) {
id(LD1125H_MovOcc_Binary).publish_state(false);
}
if (id(LD1125H_Mov_Binary).state == true) {
id(LD1125H_Mov_Binary).publish_state(false);
}
}

365
LD1125.yaml Normal file
View File

@ -0,0 +1,365 @@
substitutions:
devicename: "supersensor" #Rename the device what you want.
upper_devicename: ESP Radar #Rename the device what you want.
entity_name_prefix: ""
ignored_radar_ranges: |-
{
{2.20,3.30},
{2.20,2.75}
}
esp32:
board: esp32dev
framework:
type: esp-idf
sdkconfig_options:
CONFIG_ESP32_DEFAULT_CPU_FREQ_240: "y"
CONFIG_ESP32_DEFAULT_CPU_FREQ_MHZ: "240"
CONFIG_ESP32_DATA_CACHE_64KB: "y"
CONFIG_ESP32_DATA_CACHE_LINE_64B: "y"
CONFIG_ESP32S3_DEFAULT_CPU_FREQ_240: "y"
CONFIG_ESP32S3_DEFAULT_CPU_FREQ_MHZ: "240"
CONFIG_ESP32S3_DATA_CACHE_64KB: "y"
CONFIG_ESP32S3_DATA_CACHE_LINE_64B: "y"
api:
encryption:
key: !secret api_encryption_key
ota:
password: !secret ota_password
web_server:
port: 80
auth:
username: !secret web_auth_username
password: !secret web_auth_password
wifi:
ssid: !secret wifi_ssid
password: !secret wifi_password
domain: !secret wifi_domain
power_save_mode: LIGHT
reboot_timeout: 5min
logger:
level: DEBUG
baud_rate: 115200
logs:
text_sensor: INFO
esphome:
name: supersensor
name_add_mac_suffix: false
on_boot:
priority: 200
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth1_mov_st = "mth1_mov=" + str_sprintf("%.0f",id(LD1125H_mth1_mov).state) +"\r\n";
return std::vector<uint8_t>(mth1_mov_st.begin(), mth1_mov_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth2_mov_st = "mth2_mov=" + str_sprintf("%.0f",id(LD1125H_mth2_mov).state) +"\r\n";
return std::vector<uint8_t>(mth2_mov_st.begin(), mth2_mov_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth3_mov_st = "mth3_mov=" + str_sprintf("%.0f",id(LD1125H_mth3_mov).state) +"\r\n";
return std::vector<uint8_t>(mth3_mov_st.begin(), mth3_mov_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth1_occ_st = "mth1_occ=" + str_sprintf("%.0f",id(LD1125H_mth1_occ).state) +"\r\n";
return std::vector<uint8_t>(mth1_occ_st.begin(), mth1_occ_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth2_occ_st = "mth2_occ=" + str_sprintf("%.0f",id(LD1125H_mth2_occ).state) +"\r\n";
return std::vector<uint8_t>(mth2_occ_st.begin(), mth2_occ_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth3_occ_st = "mth3_occ=" + str_sprintf("%.0f",id(LD1125H_mth3_occ).state) +"\r\n";
return std::vector<uint8_t>(mth3_occ_st.begin(), mth3_occ_st.end());
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string rmaxst = "rmax=" + str_sprintf("%.1f",id(LD1125H_rmax).state) +"\r\n";
return std::vector<uint8_t>(rmaxst.begin(), rmaxst.end());
external_components:
- source:
type: git
url: https://github.com/ssieb/custom_components #Thanks for @ssieb components.
components: [ serial ]
uart:
id: LD1125H_UART_BUS
rx_pin: GPIO16
tx_pin: GPIO17
baud_rate: 115200
data_bits: 8
stop_bits: 1
parity: NONE
# debug:
# direction: BOTH
# dummy_receiver: false
# after:
# delimiter: "\n"
# sequence:
# - lambda: UARTDebug::log_string(direction, bytes);
status_led:
pin:
number: GPIO2
inverted: false
globals:
- id: LD1125H_Last_Time
type: time_t
restore_value: no
initial_value: time(NULL)
- id: LD1125H_Last_Mov_Time
type: time_t
restore_value: no
initial_value: time(NULL)
- id: LD1125H_Clearance_Status
type: bool
restore_value: no
initial_value: "false"
- id: ignored_ranges
type: std::vector<std::vector<float>>
restore_value: no
initial_value: ${ignored_radar_ranges}
interval:
- interval: 1s #Clearance Scan Time
setup_priority: 200
then:
lambda: |-
if ((time(NULL)-id(LD1125H_Last_Time))>id(LD1125H_Clearance_Time).state) {
if ((id(LD1125H_Clearance_Status) == false) || (id(LD1125H_Occupancy).state != "Clear")) {
id(LD1125H_Occupancy).publish_state("Clear");
id(LD1125H_Clearance_Status) = true;
}
if (id(LD1125H_MovOcc_Binary).state == true) {
id(LD1125H_MovOcc_Binary).publish_state(false);
}
if (id(LD1125H_Mov_Binary).state == true) {
id(LD1125H_Mov_Binary).publish_state(false);
}
}
number:
- platform: template
name: ${entity_name_prefix} 0-2.8m Movement Minimum Signal
id: LD1125H_mth1_mov
icon: "mdi:cogs"
optimistic: true
restore_value: true
initial_value: "80"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth1_mov_st = "mth1_mov=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth1_mov_st.begin(), mth1_mov_st.end());
- platform: template
name: ${entity_name_prefix} 2.8m-8m Movement Minimum Signal
id: LD1125H_mth2_mov
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "50"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth2_mov_st = "mth2_mov=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth2_mov_st.begin(), mth2_mov_st.end());
- platform: template
name: ${entity_name_prefix} 8m-∞ Movement Minimum Signal
id: LD1125H_mth3_mov
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "20"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth3_mov_st = "mth3_mov=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth3_mov_st.begin(), mth3_mov_st.end());
- platform: template
name: ${entity_name_prefix} 0-2.8m Occupancy Minimum Signal
id: LD1125H_mth1_occ
icon: "mdi:cogs"
optimistic: true
restore_value: true
initial_value: "60"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth1_occ_st = "mth1_occ=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth1_occ_st.begin(), mth1_occ_st.end());
- platform: template
name: ${entity_name_prefix} 2.8m-8m Occupancy Minimum Signal
id: LD1125H_mth2_occ
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "55"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth2_occ_st = "mth2_occ=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth2_occ_st.begin(), mth2_occ_st.end());
- platform: template
name: ${entity_name_prefix} 8m-∞ Occupancy Minimum Signal
id: LD1125H_mth3_occ
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "20"
min_value: 0
max_value: 1500
step: 1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string mth3_occ_st = "mth3_occ=" + str_sprintf("%.0f",x) +"\r\n";
return std::vector<uint8_t>(mth3_occ_st.begin(), mth3_occ_st.end());
- platform: template
name: ${entity_name_prefix} Max Detection Distance (m) #rmax is max detection distance.
id: LD1125H_rmax
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "8" #Default rmax Setting
min_value: 0.0
max_value: 60
step: 0.1
set_action:
then:
- uart.write:
id: LD1125H_UART_BUS
data: !lambda |-
std::string rmaxst = "rmax=" + str_sprintf("%.1f",x) +"\r\n";
return std::vector<uint8_t>(rmaxst.begin(), rmaxst.end());
- platform: template
name: ${entity_name_prefix} Seconds to Clear Mov/Occ
id: LD1125H_Clearance_Time
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "20" #LD1125H Mov/Occ > Clearance Time Here
min_value: 0
max_value: 60
step: 1
- platform: template
name: ${entity_name_prefix} Seconds to Detection
id: LD1125H_Mov_Time
icon: "mdi:cogs"
optimistic: true
restore_value: true #If you don't want to store the setting at ESP, set it to false.
initial_value: "1" #LD1125H Mov > Occ Time Here
min_value: 0.1
max_value: 10
step: 0.1
sensor:
- platform: template
name: ${entity_name_prefix} Objects Distance
id: LD1125H_Distance
icon: "mdi:signal-distance-variant"
unit_of_measurement: "m"
accuracy_decimals: 2
filters: # Use Filter To Debounce
- sliding_window_moving_average:
window_size: 200
send_every: 10
- heartbeat: 0.2s
text_sensor:
- platform: serial
uart_id: LD1125H_UART_BUS
name: ${entity_name_prefix} UART Text
id: LD1125H_UART_Text
icon: "mdi:format-text"
internal: True
on_value:
lambda: |-
for (const auto& row : id(ignored_ranges)) {
if ( ( atof(id(LD1125H_UART_Text).state.substr(9).c_str()) > row[0] ) && ( atof(id(LD1125H_UART_Text).state.substr(9).c_str()) < row[1] ) ) {
break;
} else {
if (id(LD1125H_UART_Text).state.substr(0,3) == "occ") {
id(LD1125H_Distance).publish_state(atof(id(LD1125H_UART_Text).state.substr(9).c_str()));
if ((time(NULL)-id(LD1125H_Last_Mov_Time))>id(LD1125H_Mov_Time).state) {
id(LD1125H_Occupancy).publish_state("Occupied");
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
if (id(LD1125H_Mov_Binary).state == true) {
id(LD1125H_Mov_Binary).publish_state(false);
}
}
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
id(LD1125H_Last_Time) = time(NULL);
if (id(LD1125H_Clearance_Status) == true) {
id(LD1125H_Clearance_Status) = false;
}
}
else if (id(LD1125H_UART_Text).state.substr(0,3) == "mov") {
id(LD1125H_Distance).publish_state(atof(id(LD1125H_UART_Text).state.substr(9).c_str()));
id(LD1125H_Occupancy).publish_state("Movement");
if (id(LD1125H_MovOcc_Binary).state == false) {
id(LD1125H_MovOcc_Binary).publish_state(true);
}
if (id(LD1125H_Mov_Binary).state == false) {
id(LD1125H_Mov_Binary).publish_state(true);
}
id(LD1125H_Last_Mov_Time) = time(NULL);
id(LD1125H_Last_Time) = time(NULL);
if (id(LD1125H_Clearance_Status) == true) {
id(LD1125H_Clearance_Status) = false;
}
}
}
}
- platform: template
name: ${entity_name_prefix} Occupancy Status
id: LD1125H_Occupancy
icon: "mdi:motion-sensor"
binary_sensor:
- platform: template
name: ${entity_name_prefix} Occupancy or Movement
id: LD1125H_MovOcc_Binary
device_class: occupancy
- platform: template
name: ${entity_name_prefix} Motion
id: LD1125H_Mov_Binary
device_class: motion

99
pirtester.yaml Normal file
View File

@ -0,0 +1,99 @@
---
###############################################################################
# SuperSensor v1.0 ESPHome configuration
###############################################################################
#
# Copyright (C) 2023 Joshua M. Boniface <joshua@boniface.me>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
###############################################################################
esphome:
name: pirtester
friendly_name: "PIRTester"
esp32:
board: esp32dev
framework:
type: esp-idf
sdkconfig_options:
CONFIG_ESP32_DEFAULT_CPU_FREQ_240: "y"
CONFIG_ESP32_DEFAULT_CPU_FREQ_MHZ: "240"
CONFIG_ESP32_DATA_CACHE_64KB: "y"
CONFIG_ESP32_DATA_CACHE_LINE_64B: "y"
CONFIG_ESP32S3_DEFAULT_CPU_FREQ_240: "y"
CONFIG_ESP32S3_DEFAULT_CPU_FREQ_MHZ: "240"
CONFIG_ESP32S3_DATA_CACHE_64KB: "y"
CONFIG_ESP32S3_DATA_CACHE_LINE_64B: "y"
# Enable logging only via web
logger:
level: DEBUG
baud_rate: 115200
api:
encryption:
key: !secret api_encryption_key
ota:
password: !secret ota_password
safe_mode: false
web_server:
port: 80
auth:
username: !secret web_auth_username
password: !secret web_auth_password
wifi:
ssid: !secret wifi_ssid
password: !secret wifi_password
domain: !secret wifi_domain
power_save_mode: LIGHT
reboot_timeout: 5min
binary_sensor:
- platform: gpio
pin: GPIO32
name: "PIR 32"
device_class: motion
- platform: gpio
pin: GPIO33
name: "PIR 33"
device_class: motion
- platform: gpio
pin: GPIO25
name: "PIR 25"
device_class: motion
- platform: gpio
pin: GPIO26
name: "PIR 26"
device_class: motion
- platform: gpio
pin: GPIO27
name: "PIR 27"
device_class: motion
- platform: gpio
pin: GPIO14
name: "PIR 14"
device_class: motion
- platform: gpio
pin: GPIO12
name: "PIR 12"
device_class: motion
- platform: gpio
pin: GPIO13
name: "PIR 13"
device_class: motion