feat: esphome updates
This commit is contained in:
@@ -6,4 +6,4 @@ https://github.com/tasmota/mgos32-to-tasmota32/releases
|
|||||||
In Tasmota make OTA Update to minimal:
|
In Tasmota make OTA Update to minimal:
|
||||||
http://ota.tasmota.com/tasmota/release/tasmota-minimal.bin.gz
|
http://ota.tasmota.com/tasmota/release/tasmota-minimal.bin.gz
|
||||||
Make ESPHome Configuration in Dashboard:
|
Make ESPHome Configuration in Dashboard:
|
||||||
docker run --rm -p 6052:6052 -e ESPHOME_DASHBOARD_USE_PING=true -v "${PWD}":/config -it ghcr.io/esphome/esphome
|
docker run --rm -p 6052:6052 -e ESPHOME_DASHBOARD_USE_PING=true -v "${PWD}":/config -it ghcr.io/esphome/esphome:latest
|
||||||
|
|||||||
19
esphome/archive/install.yaml
Normal file
19
esphome/archive/install.yaml
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
substitutions:
|
||||||
|
device_name: "install"
|
||||||
|
friendly_name: "Esphome Install"
|
||||||
|
|
||||||
|
esphome:
|
||||||
|
name: ${device_name}
|
||||||
|
comment: ${friendly_name}
|
||||||
|
platform: ESP8266
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
|
web_server:
|
||||||
|
port: 80
|
||||||
|
|
||||||
|
ota:
|
||||||
|
platform: esphome
|
||||||
|
|
||||||
|
wifi:
|
||||||
|
ssid: Cloonar-Smart
|
||||||
|
password: 0m6sY7Ue3G31
|
||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
priority: 300
|
priority: 300
|
||||||
then:
|
then:
|
||||||
@@ -24,6 +22,9 @@ esphome:
|
|||||||
blue: 0%
|
blue: 0%
|
||||||
white: 100%
|
white: 100%
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
then:
|
then:
|
||||||
@@ -37,6 +38,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
@@ -56,13 +56,14 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: false
|
fast_connect: True
|
||||||
domain: "${dns_domain}"
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
# Your hidden network
|
# Your hidden network
|
||||||
@@ -84,7 +85,6 @@ wifi:
|
|||||||
ssid: "${name}_AP"
|
ssid: "${name}_AP"
|
||||||
password: "bulb_fallback_pw"
|
password: "bulb_fallback_pw"
|
||||||
ap_timeout: 2min # after 2 min of failed join, enable AP
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
reboot_timeout: 5min # if still not joined after 5 min, reboot and retry
|
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ substitutions:
|
|||||||
sntp_server_1: "0.pool.ntp.org"
|
sntp_server_1: "0.pool.ntp.org"
|
||||||
sntp_server_2: "1.pool.ntp.org"
|
sntp_server_2: "1.pool.ntp.org"
|
||||||
sntp_server_3: "2.pool.ntp.org"
|
sntp_server_3: "2.pool.ntp.org"
|
||||||
log_level: "WARN"
|
|
||||||
|
|
||||||
esphome:
|
esphome:
|
||||||
name: "${name}"
|
name: "${name}"
|
||||||
@@ -43,7 +42,7 @@ interval:
|
|||||||
then:
|
then:
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
api.connected: # check if api connected
|
api.connected:
|
||||||
else:
|
else:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
id: rgbww_light
|
id: rgbww_light
|
||||||
@@ -57,22 +56,35 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
domain: .cloonar.smart
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: False
|
fast_connect: True
|
||||||
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
|
# Your hidden network
|
||||||
networks:
|
networks:
|
||||||
- ssid: !secret wifi_ssid
|
- ssid: !secret wifi_ssid
|
||||||
password: !secret wifi_password
|
password: !secret wifi_password
|
||||||
channel: 1
|
channel: 1
|
||||||
hidden: True
|
hidden: true
|
||||||
|
|
||||||
manual_ip:
|
manual_ip:
|
||||||
static_ip: 10.42.100.12
|
static_ip: 10.42.100.12
|
||||||
gateway: 10.42.100.1
|
gateway: 10.42.100.1
|
||||||
subnet: 255.255.255.0
|
subnet: 255.255.255.0
|
||||||
|
dns1: 8.8.8.8
|
||||||
|
dns2: 1.1.1.1
|
||||||
|
|
||||||
|
# Fallback access point if Wi-Fi fails
|
||||||
|
ap:
|
||||||
|
ssid: "${name}_AP"
|
||||||
|
password: "bulb_fallback_pw"
|
||||||
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
@@ -90,7 +102,7 @@ sensor:
|
|||||||
name: "WiFi Signal dB"
|
name: "WiFi Signal dB"
|
||||||
id: wifi_signal_db
|
id: wifi_signal_db
|
||||||
update_interval: 60s
|
update_interval: 60s
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
|
|
||||||
- platform: copy
|
- platform: copy
|
||||||
source_id: wifi_signal_db
|
source_id: wifi_signal_db
|
||||||
@@ -98,8 +110,7 @@ sensor:
|
|||||||
filters:
|
filters:
|
||||||
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
||||||
unit_of_measurement: "Signal %"
|
unit_of_measurement: "Signal %"
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
device_class: ""
|
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
@@ -153,26 +164,23 @@ text_sensor:
|
|||||||
name: "Mac Address"
|
name: "Mac Address"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
|
|
||||||
# Creates a sensor showing when the device was last restarted
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: 'Last Restart'
|
name: 'Last Restart'
|
||||||
id: device_last_restart
|
id: device_last_restart
|
||||||
icon: mdi:clock
|
icon: mdi:clock
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
# device_class: timestamp
|
|
||||||
|
|
||||||
# Creates a sensor of the uptime of the device, in formatted days, hours, minutes and seconds
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: "Uptime"
|
name: "Uptime"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
lambda: |-
|
lambda: |-
|
||||||
int seconds = (id(uptime_sensor).state);
|
int seconds = (id(uptime_sensor).state);
|
||||||
int days = seconds / (24 * 3600);
|
int days = seconds / (24 * 3600);
|
||||||
seconds = seconds % (24 * 3600);
|
seconds %= (24 * 3600);
|
||||||
int hours = seconds / 3600;
|
int hours = seconds / 3600;
|
||||||
seconds = seconds % 3600;
|
seconds %= 3600;
|
||||||
int minutes = seconds / 60;
|
int minutes = seconds / 60;
|
||||||
seconds = seconds % 60;
|
seconds %= 60;
|
||||||
if (days > 3650) {
|
if (days > 3650) {
|
||||||
return { "Starting up" };
|
return { "Starting up" };
|
||||||
} else if (days) {
|
} else if (days) {
|
||||||
@@ -189,19 +197,14 @@ text_sensor:
|
|||||||
time:
|
time:
|
||||||
- platform: sntp
|
- platform: sntp
|
||||||
id: sntp_time
|
id: sntp_time
|
||||||
# Define the timezone of the device
|
|
||||||
timezone: "${timezone}"
|
timezone: "${timezone}"
|
||||||
# Change sync interval from default 5min to 6 hours (or as set in substitutions)
|
|
||||||
update_interval: ${sntp_update_interval}
|
update_interval: ${sntp_update_interval}
|
||||||
# Set specific sntp servers to use
|
|
||||||
servers:
|
servers:
|
||||||
- "${sntp_server_1}"
|
- "${sntp_server_1}"
|
||||||
- "${sntp_server_2}"
|
- "${sntp_server_2}"
|
||||||
- "${sntp_server_3}"
|
- "${sntp_server_3}"
|
||||||
# Publish the time the device was last restarted
|
|
||||||
on_time_sync:
|
on_time_sync:
|
||||||
then:
|
then:
|
||||||
# Update last restart time, but only once.
|
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
lambda: 'return id(device_last_restart).state == "";'
|
lambda: 'return id(device_last_restart).state == "";'
|
||||||
|
|||||||
@@ -10,18 +10,6 @@ substitutions:
|
|||||||
sntp_server_1: "0.pool.ntp.org"
|
sntp_server_1: "0.pool.ntp.org"
|
||||||
sntp_server_2: "1.pool.ntp.org"
|
sntp_server_2: "1.pool.ntp.org"
|
||||||
sntp_server_3: "2.pool.ntp.org"
|
sntp_server_3: "2.pool.ntp.org"
|
||||||
log_level: "WARN"
|
|
||||||
|
|
||||||
globals:
|
|
||||||
- id: fast_boot
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: '0'
|
|
||||||
|
|
||||||
- id: restore_mode
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: "1"
|
|
||||||
|
|
||||||
esphome:
|
esphome:
|
||||||
name: "${name}"
|
name: "${name}"
|
||||||
@@ -54,7 +42,7 @@ interval:
|
|||||||
then:
|
then:
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
api.connected: # check if api connected
|
api.connected:
|
||||||
else:
|
else:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
id: rgbww_light
|
id: rgbww_light
|
||||||
@@ -68,22 +56,35 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
domain: .cloonar.smart
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: False
|
fast_connect: True
|
||||||
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
|
# Your hidden network
|
||||||
networks:
|
networks:
|
||||||
- ssid: !secret wifi_ssid
|
- ssid: !secret wifi_ssid
|
||||||
password: !secret wifi_password
|
password: !secret wifi_password
|
||||||
hidden: True
|
|
||||||
channel: 1
|
channel: 1
|
||||||
|
hidden: true
|
||||||
|
|
||||||
manual_ip:
|
manual_ip:
|
||||||
static_ip: 10.42.100.13
|
static_ip: 10.42.100.13
|
||||||
gateway: 10.42.100.1
|
gateway: 10.42.100.1
|
||||||
subnet: 255.255.255.0
|
subnet: 255.255.255.0
|
||||||
|
dns1: 8.8.8.8
|
||||||
|
dns2: 1.1.1.1
|
||||||
|
|
||||||
|
# Fallback access point if Wi-Fi fails
|
||||||
|
ap:
|
||||||
|
ssid: "${name}_AP"
|
||||||
|
password: "bulb_fallback_pw"
|
||||||
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
@@ -101,7 +102,7 @@ sensor:
|
|||||||
name: "WiFi Signal dB"
|
name: "WiFi Signal dB"
|
||||||
id: wifi_signal_db
|
id: wifi_signal_db
|
||||||
update_interval: 60s
|
update_interval: 60s
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
|
|
||||||
- platform: copy
|
- platform: copy
|
||||||
source_id: wifi_signal_db
|
source_id: wifi_signal_db
|
||||||
@@ -109,8 +110,7 @@ sensor:
|
|||||||
filters:
|
filters:
|
||||||
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
||||||
unit_of_measurement: "Signal %"
|
unit_of_measurement: "Signal %"
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
device_class: ""
|
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
@@ -164,26 +164,23 @@ text_sensor:
|
|||||||
name: "Mac Address"
|
name: "Mac Address"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
|
|
||||||
# Creates a sensor showing when the device was last restarted
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: 'Last Restart'
|
name: 'Last Restart'
|
||||||
id: device_last_restart
|
id: device_last_restart
|
||||||
icon: mdi:clock
|
icon: mdi:clock
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
# device_class: timestamp
|
|
||||||
|
|
||||||
# Creates a sensor of the uptime of the device, in formatted days, hours, minutes and seconds
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: "Uptime"
|
name: "Uptime"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
lambda: |-
|
lambda: |-
|
||||||
int seconds = (id(uptime_sensor).state);
|
int seconds = (id(uptime_sensor).state);
|
||||||
int days = seconds / (24 * 3600);
|
int days = seconds / (24 * 3600);
|
||||||
seconds = seconds % (24 * 3600);
|
seconds %= (24 * 3600);
|
||||||
int hours = seconds / 3600;
|
int hours = seconds / 3600;
|
||||||
seconds = seconds % 3600;
|
seconds %= 3600;
|
||||||
int minutes = seconds / 60;
|
int minutes = seconds / 60;
|
||||||
seconds = seconds % 60;
|
seconds %= 60;
|
||||||
if (days > 3650) {
|
if (days > 3650) {
|
||||||
return { "Starting up" };
|
return { "Starting up" };
|
||||||
} else if (days) {
|
} else if (days) {
|
||||||
@@ -200,19 +197,14 @@ text_sensor:
|
|||||||
time:
|
time:
|
||||||
- platform: sntp
|
- platform: sntp
|
||||||
id: sntp_time
|
id: sntp_time
|
||||||
# Define the timezone of the device
|
|
||||||
timezone: "${timezone}"
|
timezone: "${timezone}"
|
||||||
# Change sync interval from default 5min to 6 hours (or as set in substitutions)
|
|
||||||
update_interval: ${sntp_update_interval}
|
update_interval: ${sntp_update_interval}
|
||||||
# Set specific sntp servers to use
|
|
||||||
servers:
|
servers:
|
||||||
- "${sntp_server_1}"
|
- "${sntp_server_1}"
|
||||||
- "${sntp_server_2}"
|
- "${sntp_server_2}"
|
||||||
- "${sntp_server_3}"
|
- "${sntp_server_3}"
|
||||||
# Publish the time the device was last restarted
|
|
||||||
on_time_sync:
|
on_time_sync:
|
||||||
then:
|
then:
|
||||||
# Update last restart time, but only once.
|
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
lambda: 'return id(device_last_restart).state == "";'
|
lambda: 'return id(device_last_restart).state == "";'
|
||||||
|
|||||||
@@ -10,18 +10,6 @@ substitutions:
|
|||||||
sntp_server_1: "0.pool.ntp.org"
|
sntp_server_1: "0.pool.ntp.org"
|
||||||
sntp_server_2: "1.pool.ntp.org"
|
sntp_server_2: "1.pool.ntp.org"
|
||||||
sntp_server_3: "2.pool.ntp.org"
|
sntp_server_3: "2.pool.ntp.org"
|
||||||
log_level: "WARN"
|
|
||||||
|
|
||||||
globals:
|
|
||||||
- id: fast_boot
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: '0'
|
|
||||||
|
|
||||||
- id: restore_mode
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: "1"
|
|
||||||
|
|
||||||
esphome:
|
esphome:
|
||||||
name: "${name}"
|
name: "${name}"
|
||||||
@@ -54,7 +42,7 @@ interval:
|
|||||||
then:
|
then:
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
api.connected: # check if api connected
|
api.connected:
|
||||||
else:
|
else:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
id: rgbww_light
|
id: rgbww_light
|
||||||
@@ -68,21 +56,35 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
domain: .cloonar.smart
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: False
|
fast_connect: True
|
||||||
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
|
# Your hidden network
|
||||||
networks:
|
networks:
|
||||||
- ssid: !secret wifi_ssid
|
- ssid: !secret wifi_ssid
|
||||||
password: !secret wifi_password
|
password: !secret wifi_password
|
||||||
hidden: True
|
channel: 1
|
||||||
|
hidden: true
|
||||||
|
|
||||||
manual_ip:
|
manual_ip:
|
||||||
static_ip: 10.42.100.14
|
static_ip: 10.42.100.14
|
||||||
gateway: 10.42.100.1
|
gateway: 10.42.100.1
|
||||||
subnet: 255.255.255.0
|
subnet: 255.255.255.0
|
||||||
|
dns1: 8.8.8.8
|
||||||
|
dns2: 1.1.1.1
|
||||||
|
|
||||||
|
# Fallback access point if Wi-Fi fails
|
||||||
|
ap:
|
||||||
|
ssid: "${name}_AP"
|
||||||
|
password: "bulb_fallback_pw"
|
||||||
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
@@ -100,7 +102,7 @@ sensor:
|
|||||||
name: "WiFi Signal dB"
|
name: "WiFi Signal dB"
|
||||||
id: wifi_signal_db
|
id: wifi_signal_db
|
||||||
update_interval: 60s
|
update_interval: 60s
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
|
|
||||||
- platform: copy
|
- platform: copy
|
||||||
source_id: wifi_signal_db
|
source_id: wifi_signal_db
|
||||||
@@ -108,8 +110,7 @@ sensor:
|
|||||||
filters:
|
filters:
|
||||||
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
||||||
unit_of_measurement: "Signal %"
|
unit_of_measurement: "Signal %"
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
device_class: ""
|
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
@@ -163,26 +164,23 @@ text_sensor:
|
|||||||
name: "Mac Address"
|
name: "Mac Address"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
|
|
||||||
# Creates a sensor showing when the device was last restarted
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: 'Last Restart'
|
name: 'Last Restart'
|
||||||
id: device_last_restart
|
id: device_last_restart
|
||||||
icon: mdi:clock
|
icon: mdi:clock
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
# device_class: timestamp
|
|
||||||
|
|
||||||
# Creates a sensor of the uptime of the device, in formatted days, hours, minutes and seconds
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: "Uptime"
|
name: "Uptime"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
lambda: |-
|
lambda: |-
|
||||||
int seconds = (id(uptime_sensor).state);
|
int seconds = (id(uptime_sensor).state);
|
||||||
int days = seconds / (24 * 3600);
|
int days = seconds / (24 * 3600);
|
||||||
seconds = seconds % (24 * 3600);
|
seconds %= (24 * 3600);
|
||||||
int hours = seconds / 3600;
|
int hours = seconds / 3600;
|
||||||
seconds = seconds % 3600;
|
seconds %= 3600;
|
||||||
int minutes = seconds / 60;
|
int minutes = seconds / 60;
|
||||||
seconds = seconds % 60;
|
seconds %= 60;
|
||||||
if (days > 3650) {
|
if (days > 3650) {
|
||||||
return { "Starting up" };
|
return { "Starting up" };
|
||||||
} else if (days) {
|
} else if (days) {
|
||||||
@@ -199,19 +197,14 @@ text_sensor:
|
|||||||
time:
|
time:
|
||||||
- platform: sntp
|
- platform: sntp
|
||||||
id: sntp_time
|
id: sntp_time
|
||||||
# Define the timezone of the device
|
|
||||||
timezone: "${timezone}"
|
timezone: "${timezone}"
|
||||||
# Change sync interval from default 5min to 6 hours (or as set in substitutions)
|
|
||||||
update_interval: ${sntp_update_interval}
|
update_interval: ${sntp_update_interval}
|
||||||
# Set specific sntp servers to use
|
|
||||||
servers:
|
servers:
|
||||||
- "${sntp_server_1}"
|
- "${sntp_server_1}"
|
||||||
- "${sntp_server_2}"
|
- "${sntp_server_2}"
|
||||||
- "${sntp_server_3}"
|
- "${sntp_server_3}"
|
||||||
# Publish the time the device was last restarted
|
|
||||||
on_time_sync:
|
on_time_sync:
|
||||||
then:
|
then:
|
||||||
# Update last restart time, but only once.
|
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
lambda: 'return id(device_last_restart).state == "";'
|
lambda: 'return id(device_last_restart).state == "";'
|
||||||
|
|||||||
@@ -10,18 +10,6 @@ substitutions:
|
|||||||
sntp_server_1: "0.pool.ntp.org"
|
sntp_server_1: "0.pool.ntp.org"
|
||||||
sntp_server_2: "1.pool.ntp.org"
|
sntp_server_2: "1.pool.ntp.org"
|
||||||
sntp_server_3: "2.pool.ntp.org"
|
sntp_server_3: "2.pool.ntp.org"
|
||||||
log_level: "WARN"
|
|
||||||
|
|
||||||
globals:
|
|
||||||
- id: fast_boot
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: '0'
|
|
||||||
|
|
||||||
- id: restore_mode
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: "1"
|
|
||||||
|
|
||||||
esphome:
|
esphome:
|
||||||
name: "${name}"
|
name: "${name}"
|
||||||
@@ -54,7 +42,7 @@ interval:
|
|||||||
then:
|
then:
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
api.connected: # check if api connected
|
api.connected:
|
||||||
else:
|
else:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
id: rgbww_light
|
id: rgbww_light
|
||||||
@@ -68,21 +56,35 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
domain: .cloonar.smart
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: False
|
fast_connect: True
|
||||||
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
|
# Your hidden network
|
||||||
networks:
|
networks:
|
||||||
- ssid: !secret wifi_ssid
|
- ssid: !secret wifi_ssid
|
||||||
password: !secret wifi_password
|
password: !secret wifi_password
|
||||||
hidden: True
|
channel: 1
|
||||||
|
hidden: true
|
||||||
|
|
||||||
manual_ip:
|
manual_ip:
|
||||||
static_ip: 10.42.100.15
|
static_ip: 10.42.100.15
|
||||||
gateway: 10.42.100.1
|
gateway: 10.42.100.1
|
||||||
subnet: 255.255.255.0
|
subnet: 255.255.255.0
|
||||||
|
dns1: 8.8.8.8
|
||||||
|
dns2: 1.1.1.1
|
||||||
|
|
||||||
|
# Fallback access point if Wi-Fi fails
|
||||||
|
ap:
|
||||||
|
ssid: "${name}_AP"
|
||||||
|
password: "bulb_fallback_pw"
|
||||||
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
@@ -100,7 +102,7 @@ sensor:
|
|||||||
name: "WiFi Signal dB"
|
name: "WiFi Signal dB"
|
||||||
id: wifi_signal_db
|
id: wifi_signal_db
|
||||||
update_interval: 60s
|
update_interval: 60s
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
|
|
||||||
- platform: copy
|
- platform: copy
|
||||||
source_id: wifi_signal_db
|
source_id: wifi_signal_db
|
||||||
@@ -108,8 +110,7 @@ sensor:
|
|||||||
filters:
|
filters:
|
||||||
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
||||||
unit_of_measurement: "Signal %"
|
unit_of_measurement: "Signal %"
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
device_class: ""
|
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
@@ -163,26 +164,23 @@ text_sensor:
|
|||||||
name: "Mac Address"
|
name: "Mac Address"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
|
|
||||||
# Creates a sensor showing when the device was last restarted
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: 'Last Restart'
|
name: 'Last Restart'
|
||||||
id: device_last_restart
|
id: device_last_restart
|
||||||
icon: mdi:clock
|
icon: mdi:clock
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
# device_class: timestamp
|
|
||||||
|
|
||||||
# Creates a sensor of the uptime of the device, in formatted days, hours, minutes and seconds
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: "Uptime"
|
name: "Uptime"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
lambda: |-
|
lambda: |-
|
||||||
int seconds = (id(uptime_sensor).state);
|
int seconds = (id(uptime_sensor).state);
|
||||||
int days = seconds / (24 * 3600);
|
int days = seconds / (24 * 3600);
|
||||||
seconds = seconds % (24 * 3600);
|
seconds %= (24 * 3600);
|
||||||
int hours = seconds / 3600;
|
int hours = seconds / 3600;
|
||||||
seconds = seconds % 3600;
|
seconds %= 3600;
|
||||||
int minutes = seconds / 60;
|
int minutes = seconds / 60;
|
||||||
seconds = seconds % 60;
|
seconds %= 60;
|
||||||
if (days > 3650) {
|
if (days > 3650) {
|
||||||
return { "Starting up" };
|
return { "Starting up" };
|
||||||
} else if (days) {
|
} else if (days) {
|
||||||
@@ -199,19 +197,14 @@ text_sensor:
|
|||||||
time:
|
time:
|
||||||
- platform: sntp
|
- platform: sntp
|
||||||
id: sntp_time
|
id: sntp_time
|
||||||
# Define the timezone of the device
|
|
||||||
timezone: "${timezone}"
|
timezone: "${timezone}"
|
||||||
# Change sync interval from default 5min to 6 hours (or as set in substitutions)
|
|
||||||
update_interval: ${sntp_update_interval}
|
update_interval: ${sntp_update_interval}
|
||||||
# Set specific sntp servers to use
|
|
||||||
servers:
|
servers:
|
||||||
- "${sntp_server_1}"
|
- "${sntp_server_1}"
|
||||||
- "${sntp_server_2}"
|
- "${sntp_server_2}"
|
||||||
- "${sntp_server_3}"
|
- "${sntp_server_3}"
|
||||||
# Publish the time the device was last restarted
|
|
||||||
on_time_sync:
|
on_time_sync:
|
||||||
then:
|
then:
|
||||||
# Update last restart time, but only once.
|
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
lambda: 'return id(device_last_restart).state == "";'
|
lambda: 'return id(device_last_restart).state == "";'
|
||||||
|
|||||||
@@ -10,18 +10,6 @@ substitutions:
|
|||||||
sntp_server_1: "0.pool.ntp.org"
|
sntp_server_1: "0.pool.ntp.org"
|
||||||
sntp_server_2: "1.pool.ntp.org"
|
sntp_server_2: "1.pool.ntp.org"
|
||||||
sntp_server_3: "2.pool.ntp.org"
|
sntp_server_3: "2.pool.ntp.org"
|
||||||
log_level: "WARN"
|
|
||||||
|
|
||||||
globals:
|
|
||||||
- id: fast_boot
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: '0'
|
|
||||||
|
|
||||||
- id: restore_mode
|
|
||||||
type: int
|
|
||||||
restore_value: yes
|
|
||||||
initial_value: "1"
|
|
||||||
|
|
||||||
esphome:
|
esphome:
|
||||||
name: "${name}"
|
name: "${name}"
|
||||||
@@ -54,7 +42,7 @@ interval:
|
|||||||
then:
|
then:
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
api.connected: # check if api connected
|
api.connected:
|
||||||
else:
|
else:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
id: rgbww_light
|
id: rgbww_light
|
||||||
@@ -68,22 +56,35 @@ preferences:
|
|||||||
flash_write_interval: 1min
|
flash_write_interval: 1min
|
||||||
|
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
- platform: esphome
|
- platform: esphome
|
||||||
|
|
||||||
wifi:
|
wifi:
|
||||||
domain: .cloonar.smart
|
# Disable fast_connect so we do a full scan (required for hidden SSIDs)
|
||||||
fast_connect: False
|
fast_connect: True
|
||||||
|
domain: "${dns_domain}"
|
||||||
|
|
||||||
|
# Your hidden network
|
||||||
networks:
|
networks:
|
||||||
- ssid: !secret wifi_ssid
|
- ssid: !secret wifi_ssid
|
||||||
password: !secret wifi_password
|
password: !secret wifi_password
|
||||||
hidden: True
|
|
||||||
channel: 1
|
channel: 1
|
||||||
|
hidden: true
|
||||||
|
|
||||||
manual_ip:
|
manual_ip:
|
||||||
static_ip: 10.42.100.16
|
static_ip: 10.42.100.16
|
||||||
gateway: 10.42.100.1
|
gateway: 10.42.100.1
|
||||||
subnet: 255.255.255.0
|
subnet: 255.255.255.0
|
||||||
|
dns1: 8.8.8.8
|
||||||
|
dns2: 1.1.1.1
|
||||||
|
|
||||||
|
# Fallback access point if Wi-Fi fails
|
||||||
|
ap:
|
||||||
|
ssid: "${name}_AP"
|
||||||
|
password: "bulb_fallback_pw"
|
||||||
|
ap_timeout: 2min # after 2 min of failed join, enable AP
|
||||||
|
|
||||||
binary_sensor:
|
binary_sensor:
|
||||||
- platform: status
|
- platform: status
|
||||||
@@ -101,7 +102,7 @@ sensor:
|
|||||||
name: "WiFi Signal dB"
|
name: "WiFi Signal dB"
|
||||||
id: wifi_signal_db
|
id: wifi_signal_db
|
||||||
update_interval: 60s
|
update_interval: 60s
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
|
|
||||||
- platform: copy
|
- platform: copy
|
||||||
source_id: wifi_signal_db
|
source_id: wifi_signal_db
|
||||||
@@ -109,8 +110,7 @@ sensor:
|
|||||||
filters:
|
filters:
|
||||||
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
- lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
|
||||||
unit_of_measurement: "Signal %"
|
unit_of_measurement: "Signal %"
|
||||||
entity_category: "diagnostic"
|
entity_category: diagnostic
|
||||||
device_class: ""
|
|
||||||
|
|
||||||
output:
|
output:
|
||||||
- platform: esp8266_pwm
|
- platform: esp8266_pwm
|
||||||
@@ -164,26 +164,23 @@ text_sensor:
|
|||||||
name: "Mac Address"
|
name: "Mac Address"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
|
|
||||||
# Creates a sensor showing when the device was last restarted
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: 'Last Restart'
|
name: 'Last Restart'
|
||||||
id: device_last_restart
|
id: device_last_restart
|
||||||
icon: mdi:clock
|
icon: mdi:clock
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
# device_class: timestamp
|
|
||||||
|
|
||||||
# Creates a sensor of the uptime of the device, in formatted days, hours, minutes and seconds
|
|
||||||
- platform: template
|
- platform: template
|
||||||
name: "Uptime"
|
name: "Uptime"
|
||||||
entity_category: diagnostic
|
entity_category: diagnostic
|
||||||
lambda: |-
|
lambda: |-
|
||||||
int seconds = (id(uptime_sensor).state);
|
int seconds = (id(uptime_sensor).state);
|
||||||
int days = seconds / (24 * 3600);
|
int days = seconds / (24 * 3600);
|
||||||
seconds = seconds % (24 * 3600);
|
seconds %= (24 * 3600);
|
||||||
int hours = seconds / 3600;
|
int hours = seconds / 3600;
|
||||||
seconds = seconds % 3600;
|
seconds %= 3600;
|
||||||
int minutes = seconds / 60;
|
int minutes = seconds / 60;
|
||||||
seconds = seconds % 60;
|
seconds %= 60;
|
||||||
if (days > 3650) {
|
if (days > 3650) {
|
||||||
return { "Starting up" };
|
return { "Starting up" };
|
||||||
} else if (days) {
|
} else if (days) {
|
||||||
@@ -200,19 +197,14 @@ text_sensor:
|
|||||||
time:
|
time:
|
||||||
- platform: sntp
|
- platform: sntp
|
||||||
id: sntp_time
|
id: sntp_time
|
||||||
# Define the timezone of the device
|
|
||||||
timezone: "${timezone}"
|
timezone: "${timezone}"
|
||||||
# Change sync interval from default 5min to 6 hours (or as set in substitutions)
|
|
||||||
update_interval: ${sntp_update_interval}
|
update_interval: ${sntp_update_interval}
|
||||||
# Set specific sntp servers to use
|
|
||||||
servers:
|
servers:
|
||||||
- "${sntp_server_1}"
|
- "${sntp_server_1}"
|
||||||
- "${sntp_server_2}"
|
- "${sntp_server_2}"
|
||||||
- "${sntp_server_3}"
|
- "${sntp_server_3}"
|
||||||
# Publish the time the device was last restarted
|
|
||||||
on_time_sync:
|
on_time_sync:
|
||||||
then:
|
then:
|
||||||
# Update last restart time, but only once.
|
|
||||||
- if:
|
- if:
|
||||||
condition:
|
condition:
|
||||||
lambda: 'return id(device_last_restart).state == "";'
|
lambda: 'return id(device_last_restart).state == "";'
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ substitutions:
|
|||||||
esphome:
|
esphome:
|
||||||
name: ${device_name}
|
name: ${device_name}
|
||||||
comment: ${friendly_name}
|
comment: ${friendly_name}
|
||||||
platform: ESP8266
|
|
||||||
board: esp01_1m
|
|
||||||
on_boot:
|
on_boot:
|
||||||
then:
|
then:
|
||||||
- light.turn_on:
|
- light.turn_on:
|
||||||
@@ -20,7 +18,8 @@ esphome:
|
|||||||
id: my_light
|
id: my_light
|
||||||
color_temperature: 2700 K
|
color_temperature: 2700 K
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: esp01_1m
|
||||||
|
|
||||||
interval:
|
interval:
|
||||||
- interval: 15s
|
- interval: 15s
|
||||||
@@ -40,6 +39,7 @@ interval:
|
|||||||
|
|
||||||
# Enable Home Assistant API
|
# Enable Home Assistant API
|
||||||
api:
|
api:
|
||||||
|
batch_delay: 0ms
|
||||||
|
|
||||||
ota:
|
ota:
|
||||||
platform: esphome
|
platform: esphome
|
||||||
|
|||||||
49
hosts/nb/users/codex-cli.nix
Normal file
49
hosts/nb/users/codex-cli.nix
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
let
|
||||||
|
user = "dominik";
|
||||||
|
home = "/home/${user}";
|
||||||
|
npmPrefix = "${home}/.npm-global";
|
||||||
|
node = pkgs.nodejs; # or pkgs.nodejs_20
|
||||||
|
in {
|
||||||
|
home-manager.users.dominik = { lib, pkgs, ... }: {
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
node
|
||||||
|
gnutar # provides `tar`
|
||||||
|
gzip # provides `gzip` used by tar
|
||||||
|
unzip
|
||||||
|
python314 # useful for codex model use
|
||||||
|
jq # useful for JSON processing
|
||||||
|
];
|
||||||
|
|
||||||
|
# Ensure ~/.npmrc with a user prefix (no sudo needed)
|
||||||
|
home.file.".npmrc"= {
|
||||||
|
text = ''
|
||||||
|
prefix=${npmPrefix}
|
||||||
|
'';
|
||||||
|
force = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
# Ensure the npm bin dir is on PATH for all shells
|
||||||
|
home.sessionPath = [
|
||||||
|
"${npmPrefix}/bin"
|
||||||
|
];
|
||||||
|
|
||||||
|
# Nice-to-have: visible variables in the shell
|
||||||
|
home.sessionVariables = {
|
||||||
|
NPM_CONFIG_PREFIX = npmPrefix;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Auto-install @openai/codex if it's not already there
|
||||||
|
# (idempotent on each `home-manager switch`)
|
||||||
|
home.activation.installCodexCli = lib.hm.dag.entryAfter [ "writeBoundary" ] ''
|
||||||
|
export PATH=${node}/bin:${pkgs.gnutar}/bin:${pkgs.gzip}/bin:${pkgs.unzip}/bin:${pkgs.curl}/bin:$PATH
|
||||||
|
mkdir -p ${npmPrefix}
|
||||||
|
if ! command -v codex >/dev/null 2>&1; then
|
||||||
|
echo "Installing @openai/codex globally..."
|
||||||
|
# --global uses prefix from ~/.npmrc; PATH has node for postinstall
|
||||||
|
${node}/bin/npm install -g @openai/codex
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -147,6 +147,9 @@ let
|
|||||||
persistHome = "/home/dominik";
|
persistHome = "/home/dominik";
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
imports = [
|
||||||
|
./codex-cli.nix
|
||||||
|
];
|
||||||
|
|
||||||
sops.secrets.openai_api_key = {
|
sops.secrets.openai_api_key = {
|
||||||
owner = "dominik";
|
owner = "dominik";
|
||||||
|
|||||||
Reference in New Issue
Block a user