mirror of
https://github.com/Laxilef/OTGateway.git
synced 2026-03-29 13:48:37 +05:00
Compare commits
37 Commits
069ba8e864
...
passive_bl
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e4cbc687ae | ||
|
|
43fe5765f7 | ||
|
|
5482e0b70a | ||
|
|
3fdb48e016 | ||
|
|
11747dd8bd | ||
|
|
af1a9b59c4 | ||
|
|
9c86ad4427 | ||
|
|
5f8ca61d79 | ||
|
|
67adb3b9cf | ||
|
|
ced0385d5b | ||
|
|
7fcca3c4aa | ||
|
|
2f6bd237c7 | ||
|
|
e4d1ba7d7b | ||
|
|
aae53d605a | ||
|
|
de9276d04e | ||
|
|
cb8cd7c26e | ||
|
|
74e321cc1e | ||
|
|
80e2d8e939 | ||
|
|
b70c212235 | ||
|
|
781b2a1f9c | ||
|
|
1e83f284cb | ||
|
|
27baf675e5 | ||
|
|
1fdc06fce6 | ||
|
|
725185beba | ||
|
|
c6518db0d3 | ||
|
|
10ab75c055 | ||
|
|
c39eeee9cf | ||
|
|
f2fe6036c2 | ||
|
|
40dc863530 | ||
|
|
a40413aeac | ||
|
|
9a045bfc40 | ||
|
|
c78d2d0c0b | ||
|
|
b7825111bb | ||
|
|
d5691ef8f7 | ||
|
|
0213582464 | ||
|
|
396dc7f7e3 | ||
|
|
9d38525251 |
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,4 +1,5 @@
|
|||||||
.pio
|
.pio
|
||||||
|
.dummy
|
||||||
.vscode
|
.vscode
|
||||||
.PVS-Studio
|
.PVS-Studio
|
||||||
build/*
|
build/*
|
||||||
@@ -10,5 +11,4 @@ package-lock.json
|
|||||||
*.lock
|
*.lock
|
||||||
sdkconfig.*
|
sdkconfig.*
|
||||||
CMakeLists.txt
|
CMakeLists.txt
|
||||||
!sdkconfig.defaults
|
|
||||||
!.gitkeep
|
!.gitkeep
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
# Blueprint for reporting indoor/outdoor temperature to OpenTherm Gateway from any home assistant sensor
|
# Blueprint for reporting indoor/outdoor temperature to OpenTherm Gateway from any home assistant sensor
|
||||||
# Updated: 03.09.2024
|
# Updated: 26.01.2026
|
||||||
|
|
||||||
blueprint:
|
blueprint:
|
||||||
name: Report temp to OpenTherm Gateway
|
name: Report temp to OpenTherm Gateway
|
||||||
@@ -15,7 +15,6 @@ blueprint:
|
|||||||
multiple: false
|
multiple: false
|
||||||
filter:
|
filter:
|
||||||
- domain: sensor
|
- domain: sensor
|
||||||
device_class: temperature
|
|
||||||
target_entity:
|
target_entity:
|
||||||
name: Target entity
|
name: Target entity
|
||||||
description: "Usually ``number.opentherm_indoor_temp`` or ``number.opentherm_outdoor_temp``"
|
description: "Usually ``number.opentherm_indoor_temp`` or ``number.opentherm_outdoor_temp``"
|
||||||
@@ -38,8 +37,12 @@ condition:
|
|||||||
value_template: "{{ states(source_entity) != 'unavailable' and states(target_entity) != 'unavailable' }}"
|
value_template: "{{ states(source_entity) != 'unavailable' and states(target_entity) != 'unavailable' }}"
|
||||||
action:
|
action:
|
||||||
- if:
|
- if:
|
||||||
- condition: template
|
- condition: or
|
||||||
value_template: "{{ (states(source_entity)|float(0) - states(target_entity)|float(0)) | abs | round(2) >= 0.01 }}"
|
conditions:
|
||||||
|
- condition: template
|
||||||
|
value_template: "{{ (states(source_entity)|float(0) - states(target_entity)|float(0)) | abs | round(2) >= 0.01 }}"
|
||||||
|
- condition: template
|
||||||
|
value_template: "{{ (as_timestamp(now()) - as_timestamp(states[target_entity].last_updated)) | int(0) > 300 }}"
|
||||||
then:
|
then:
|
||||||
- service: number.set_value
|
- service: number.set_value
|
||||||
data:
|
data:
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
# Blueprint for reporting temperature to OpenTherm Gateway from home assistant weather integration
|
# Blueprint for reporting temperature to OpenTherm Gateway from home assistant weather integration
|
||||||
# Updated: 03.09.2024
|
# Updated: 26.01.2026
|
||||||
|
|
||||||
blueprint:
|
blueprint:
|
||||||
name: Report temp to OpenTherm Gateway from Weather
|
name: Report temp to OpenTherm Gateway from Weather
|
||||||
@@ -37,8 +37,12 @@ condition:
|
|||||||
value_template: "{{ states(source_entity) != 'unavailable' and states(target_entity) != 'unavailable' }}"
|
value_template: "{{ states(source_entity) != 'unavailable' and states(target_entity) != 'unavailable' }}"
|
||||||
action:
|
action:
|
||||||
- if:
|
- if:
|
||||||
- condition: template
|
- condition: or
|
||||||
value_template: "{{ (state_attr(source_entity, 'temperature')|float(0) - states(target_entity)|float(0)) | abs | round(2) >= 0.1 }}"
|
conditions:
|
||||||
|
- condition: template
|
||||||
|
value_template: "{{ (state_attr(source_entity, 'temperature')|float(0) - states(target_entity)|float(0)) | abs | round(2) >= 0.1 }}"
|
||||||
|
- condition: template
|
||||||
|
value_template: "{{ (as_timestamp(now()) - as_timestamp(states[target_entity].last_updated)) | int(0) > 300 }}"
|
||||||
then:
|
then:
|
||||||
- service: number.set_value
|
- service: number.set_value
|
||||||
data:
|
data:
|
||||||
|
|||||||
567
platformio.ini
567
platformio.ini
@@ -1,386 +1,229 @@
|
|||||||
; PlatformIO Project Configuration File
|
|
||||||
;
|
|
||||||
; Build options: build flags, source filter
|
|
||||||
; Upload options: custom upload port, speed and extra flags
|
|
||||||
; Library options: dependencies, extra library storages
|
|
||||||
; Advanced options: extra scripting
|
|
||||||
;
|
|
||||||
; Please visit documentation for the other options and examples
|
|
||||||
; https://docs.platformio.org/page/projectconf.html
|
|
||||||
|
|
||||||
[platformio]
|
[platformio]
|
||||||
;extra_configs = secrets.ini
|
;extra_configs = secrets.ini
|
||||||
extra_configs = secrets.default.ini
|
extra_configs = secrets.default.ini
|
||||||
core_dir = .pio
|
core_dir = .pio
|
||||||
|
|
||||||
[env]
|
[env]
|
||||||
version = 1.6.0
|
version = 1.6.0-passiveble
|
||||||
framework = arduino
|
framework = arduino
|
||||||
lib_deps =
|
lib_deps = ESP32Async/AsyncTCP@^3.4.10
|
||||||
ESP32Async/AsyncTCP
|
ESP32Async/ESPAsyncWebServer@^3.9.4
|
||||||
;ESP32Async/ESPAsyncWebServer
|
mathieucarbou/MycilaWebSerial@^8.2.0
|
||||||
https://github.com/ESP32Async/ESPAsyncWebServer#main
|
bblanchon/ArduinoJson@^7.4.2
|
||||||
mathieucarbou/MycilaWebSerial@^8.2.0
|
;ihormelnyk/OpenTherm Library@^1.1.5
|
||||||
bblanchon/ArduinoJson@^7.4.2
|
https://github.com/Laxilef/opentherm_library#esp32_timer
|
||||||
;ihormelnyk/OpenTherm Library@^1.1.5
|
arduino-libraries/ArduinoMqttClient@^0.1.8
|
||||||
https://github.com/Laxilef/opentherm_library#esp32_timer
|
gyverlibs/FileData@^1.0.3
|
||||||
arduino-libraries/ArduinoMqttClient@^0.1.8
|
gyverlibs/GyverPID@^3.3.2
|
||||||
gyverlibs/FileData@^1.0.3
|
gyverlibs/GyverBlinker@^1.1.1
|
||||||
gyverlibs/GyverPID@^3.3.2
|
pstolarz/OneWireNg@^0.14.1
|
||||||
gyverlibs/GyverBlinker@^1.1.1
|
milesburton/DallasTemperature@^4.0.6
|
||||||
https://github.com/pstolarz/Arduino-Temperature-Control-Library.git#OneWireNg
|
https://github.com/Laxilef/esp32DHT#idf5
|
||||||
;laxilef/TinyLogger@^1.1.1
|
;laxilef/TinyLogger@^1.1.1
|
||||||
https://github.com/Laxilef/TinyLogger#custom_handlers
|
https://github.com/Laxilef/TinyLogger#custom_handlers
|
||||||
build_type = ${secrets.build_type}
|
lib_ignore = OneWire
|
||||||
build_flags =
|
build_type = ${secrets.build_type}
|
||||||
-mtext-section-literals
|
build_flags = ;-mtext-section-literals
|
||||||
-D MQTT_CLIENT_STD_FUNCTION_CALLBACK=1
|
-O2
|
||||||
;-D DEBUG_ESP_CORE -D DEBUG_ESP_WIFI -D DEBUG_ESP_HTTP_SERVER -D DEBUG_ESP_PORT=Serial
|
-Wno-deprecated-declarations
|
||||||
-D BUILD_VERSION='"${this.version}"'
|
-D MQTT_CLIENT_STD_FUNCTION_CALLBACK=1
|
||||||
-D BUILD_ENV='"$PIOENV"'
|
;-D DEBUG_ESP_CORE -D DEBUG_ESP_WIFI -D DEBUG_ESP_HTTP_SERVER -D DEBUG_ESP_PORT=Serial
|
||||||
-D CONFIG_ASYNC_TCP_STACK_SIZE=4096
|
-D BUILD_VERSION='"${this.version}"'
|
||||||
-D ARDUINOJSON_USE_DOUBLE=0
|
-D BUILD_ENV='"$PIOENV"'
|
||||||
-D ARDUINOJSON_USE_LONG_LONG=0
|
-D CONFIG_ASYNC_TCP_STACK_SIZE=4096
|
||||||
-D TINYLOGGER_GLOBAL
|
-D ARDUINOJSON_USE_DOUBLE=0
|
||||||
-D DEFAULT_SERIAL_ENABLED=${secrets.serial_enabled}
|
-D ARDUINOJSON_USE_LONG_LONG=0
|
||||||
-D DEFAULT_SERIAL_BAUD=${secrets.serial_baud}
|
-D TINYLOGGER_GLOBAL
|
||||||
-D DEFAULT_WEBSERIAL_ENABLED=${secrets.webserial_enabled}
|
-D DHT_TASK_STACK_SIZE=4096
|
||||||
-D DEFAULT_LOG_LEVEL=${secrets.log_level}
|
-D DEFAULT_SERIAL_ENABLED=${secrets.serial_enabled}
|
||||||
-D DEFAULT_HOSTNAME='"${secrets.hostname}"'
|
-D DEFAULT_SERIAL_BAUD=${secrets.serial_baud}
|
||||||
-D DEFAULT_AP_SSID='"${secrets.ap_ssid}"'
|
-D DEFAULT_WEBSERIAL_ENABLED=${secrets.webserial_enabled}
|
||||||
-D DEFAULT_AP_PASSWORD='"${secrets.ap_password}"'
|
-D DEFAULT_LOG_LEVEL=${secrets.log_level}
|
||||||
-D DEFAULT_STA_SSID='"${secrets.sta_ssid}"'
|
-D DEFAULT_HOSTNAME='"${secrets.hostname}"'
|
||||||
-D DEFAULT_STA_PASSWORD='"${secrets.sta_password}"'
|
-D DEFAULT_AP_SSID='"${secrets.ap_ssid}"'
|
||||||
-D DEFAULT_PORTAL_LOGIN='"${secrets.portal_login}"'
|
-D DEFAULT_AP_PASSWORD='"${secrets.ap_password}"'
|
||||||
-D DEFAULT_PORTAL_PASSWORD='"${secrets.portal_password}"'
|
-D DEFAULT_STA_SSID='"${secrets.sta_ssid}"'
|
||||||
-D DEFAULT_MQTT_ENABLED=${secrets.mqtt_enabled}
|
-D DEFAULT_STA_PASSWORD='"${secrets.sta_password}"'
|
||||||
-D DEFAULT_MQTT_SERVER='"${secrets.mqtt_server}"'
|
-D DEFAULT_PORTAL_LOGIN='"${secrets.portal_login}"'
|
||||||
-D DEFAULT_MQTT_PORT=${secrets.mqtt_port}
|
-D DEFAULT_PORTAL_PASSWORD='"${secrets.portal_password}"'
|
||||||
-D DEFAULT_MQTT_USER='"${secrets.mqtt_user}"'
|
-D DEFAULT_MQTT_ENABLED=${secrets.mqtt_enabled}
|
||||||
-D DEFAULT_MQTT_PASSWORD='"${secrets.mqtt_password}"'
|
-D DEFAULT_MQTT_SERVER='"${secrets.mqtt_server}"'
|
||||||
-D DEFAULT_MQTT_PREFIX='"${secrets.mqtt_prefix}"'
|
-D DEFAULT_MQTT_PORT=${secrets.mqtt_port}
|
||||||
upload_speed = 921600
|
-D DEFAULT_MQTT_USER='"${secrets.mqtt_user}"'
|
||||||
monitor_speed = 115200
|
-D DEFAULT_MQTT_PASSWORD='"${secrets.mqtt_password}"'
|
||||||
;monitor_filters = direct
|
-D DEFAULT_MQTT_PREFIX='"${secrets.mqtt_prefix}"'
|
||||||
monitor_filters =
|
upload_speed = 921600
|
||||||
esp32_exception_decoder
|
monitor_speed = 115200
|
||||||
esp8266_exception_decoder
|
;monitor_filters = direct
|
||||||
board_build.flash_mode = dio
|
monitor_filters = esp32_exception_decoder
|
||||||
board_build.filesystem = littlefs
|
board_build.flash_mode = dio
|
||||||
check_tool = ; pvs-studio
|
board_build.filesystem = littlefs
|
||||||
check_flags =
|
check_tool = ;pvs-studio
|
||||||
; pvs-studio:
|
check_flags = ;pvs-studio: --analysis-mode=4 --exclude-path=./.pio/libdeps
|
||||||
; --analysis-mode=4
|
|
||||||
; --exclude-path=./.pio/libdeps
|
|
||||||
|
|
||||||
; Defaults
|
; Defaults
|
||||||
[esp8266_defaults]
|
|
||||||
platform = espressif8266@^4.2.1
|
|
||||||
platform_packages = ${env.platform_packages}
|
|
||||||
lib_deps =
|
|
||||||
${env.lib_deps}
|
|
||||||
nrwiersma/ESP8266Scheduler@^1.2
|
|
||||||
lib_ignore =
|
|
||||||
extra_scripts =
|
|
||||||
post:tools/build.py
|
|
||||||
build_type = ${env.build_type}
|
|
||||||
build_flags =
|
|
||||||
${env.build_flags}
|
|
||||||
-D PIO_FRAMEWORK_ARDUINO_LWIP2_LOW_MEMORY
|
|
||||||
;-D PIO_FRAMEWORK_ARDUINO_LWIP2_HIGHER_BANDWIDTH_LOW_FLASH
|
|
||||||
-D PIO_FRAMEWORK_ARDUINO_ESPRESSIF_SDK305
|
|
||||||
board_build.ldscript = eagle.flash.4m1m.ld
|
|
||||||
check_tool = ${env.check_tool}
|
|
||||||
check_flags = ${env.check_flags}
|
|
||||||
|
|
||||||
[esp32_defaults]
|
[esp32_defaults]
|
||||||
;platform = espressif32@^6.7
|
platform = https://github.com/pioarduino/platform-espressif32/releases/download/55.03.37/platform-espressif32.zip
|
||||||
;platform = https://github.com/platformio/platform-espressif32.git
|
platform_packages = ${env.platform_packages}
|
||||||
;platform_packages =
|
board_build.partitions = esp32_partitions.csv
|
||||||
; framework-arduinoespressif32 @ https://github.com/espressif/arduino-esp32.git#3.0.5
|
lib_deps = ${env.lib_deps}
|
||||||
; framework-arduinoespressif32-libs @ https://github.com/espressif/esp32-arduino-lib-builder/releases/download/idf-release_v5.1/esp32-arduino-libs-idf-release_v5.1-33fbade6.zip
|
laxilef/ESP32Scheduler@^1.0.1
|
||||||
platform = https://github.com/pioarduino/platform-espressif32/releases/download/55.03.35/platform-espressif32.zip
|
nimble_lib = https://github.com/h2zero/NimBLE-Arduino
|
||||||
platform_packages = ${env.platform_packages}
|
lib_ignore = ${env.lib_ignore}
|
||||||
board_build.partitions = esp32_partitions.csv
|
BluetoothSerial
|
||||||
lib_deps =
|
SimpleBLE
|
||||||
${env.lib_deps}
|
ESP RainMaker
|
||||||
laxilef/ESP32Scheduler@^1.0.1
|
RainMaker
|
||||||
nimble_lib = https://github.com/h2zero/NimBLE-Arduino
|
ESP Insights
|
||||||
lib_ignore =
|
Insights
|
||||||
extra_scripts =
|
Zigbee
|
||||||
post:tools/esp32.py
|
Matter
|
||||||
post:tools/build.py
|
OpenThread
|
||||||
build_type = ${env.build_type}
|
dsp
|
||||||
build_flags =
|
custom_component_remove = espressif/esp_hosted
|
||||||
${env.build_flags}
|
espressif/esp_wifi_remote
|
||||||
-D CORE_DEBUG_LEVEL=0
|
espressif/esp-dsp
|
||||||
-Wl,--wrap=esp_panic_handler
|
espressif/esp_modem
|
||||||
check_tool = ${env.check_tool}
|
espressif/esp_rainmaker
|
||||||
check_flags = ${env.check_flags}
|
espressif/rmaker_common
|
||||||
|
espressif/esp_insights
|
||||||
|
espressif/esp_diag_data_store
|
||||||
|
espressif/esp_diagnostics
|
||||||
|
espressif/libsodium
|
||||||
|
espressif/esp-modbus
|
||||||
|
espressif/esp-cbor
|
||||||
|
espressif/esp-sr
|
||||||
|
espressif/esp32-camera
|
||||||
|
espressif/qrcode
|
||||||
|
espressif/esp-zboss-lib
|
||||||
|
espressif/esp-zigbee-lib
|
||||||
|
chmorgan/esp-libhelix-mp3
|
||||||
|
extra_scripts = pre:tools/add_build_commit.py
|
||||||
|
post:tools/esp32.py
|
||||||
|
post:tools/build.py
|
||||||
|
build_type = ${env.build_type}
|
||||||
|
build_flags = ${env.build_flags}
|
||||||
|
-D MYNEWT_VAL_BLE_ROLE_CENTRAL=0
|
||||||
|
-D CORE_DEBUG_LEVEL=0
|
||||||
|
-Wl,--wrap=esp_panic_handler
|
||||||
|
check_tool = ${env.check_tool}
|
||||||
|
check_flags = ${env.check_flags}
|
||||||
|
|
||||||
|
|
||||||
; Boards
|
; Boards
|
||||||
[env:d1_mini]
|
|
||||||
platform = ${esp8266_defaults.platform}
|
|
||||||
platform_packages = ${esp8266_defaults.platform_packages}
|
|
||||||
board = d1_mini
|
|
||||||
lib_deps = ${esp8266_defaults.lib_deps}
|
|
||||||
lib_ignore = ${esp8266_defaults.lib_ignore}
|
|
||||||
extra_scripts = ${esp8266_defaults.extra_scripts}
|
|
||||||
board_build.ldscript = ${esp8266_defaults.board_build.ldscript}
|
|
||||||
build_type = ${esp8266_defaults.build_type}
|
|
||||||
build_flags =
|
|
||||||
${esp8266_defaults.build_flags}
|
|
||||||
-D DEFAULT_OT_IN_GPIO=4
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=5
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=14
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=13
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=15
|
|
||||||
check_tool = ${esp8266_defaults.check_tool}
|
|
||||||
check_flags = ${esp8266_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:d1_mini_lite]
|
|
||||||
platform = ${esp8266_defaults.platform}
|
|
||||||
platform_packages = ${esp8266_defaults.platform_packages}
|
|
||||||
board = d1_mini_lite
|
|
||||||
lib_deps = ${esp8266_defaults.lib_deps}
|
|
||||||
lib_ignore = ${esp8266_defaults.lib_ignore}
|
|
||||||
extra_scripts = ${esp8266_defaults.extra_scripts}
|
|
||||||
board_build.ldscript = ${esp8266_defaults.board_build.ldscript}
|
|
||||||
build_type = ${esp8266_defaults.build_type}
|
|
||||||
build_flags =
|
|
||||||
${esp8266_defaults.build_flags}
|
|
||||||
-D DEFAULT_OT_IN_GPIO=4
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=5
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=14
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=13
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=15
|
|
||||||
check_tool = ${esp8266_defaults.check_tool}
|
|
||||||
check_flags = ${esp8266_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:d1_mini_pro]
|
|
||||||
platform = ${esp8266_defaults.platform}
|
|
||||||
platform_packages = ${esp8266_defaults.platform_packages}
|
|
||||||
board = d1_mini_pro
|
|
||||||
lib_deps = ${esp8266_defaults.lib_deps}
|
|
||||||
lib_ignore = ${esp8266_defaults.lib_ignore}
|
|
||||||
extra_scripts = ${esp8266_defaults.extra_scripts}
|
|
||||||
board_build.ldscript = ${esp8266_defaults.board_build.ldscript}
|
|
||||||
build_type = ${esp8266_defaults.build_type}
|
|
||||||
build_flags =
|
|
||||||
${esp8266_defaults.build_flags}
|
|
||||||
-D DEFAULT_OT_IN_GPIO=4
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=5
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=14
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=13
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=15
|
|
||||||
check_tool = ${esp8266_defaults.check_tool}
|
|
||||||
check_flags = ${esp8266_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:nodemcu_8266]
|
|
||||||
platform = ${esp8266_defaults.platform}
|
|
||||||
platform_packages = ${esp8266_defaults.platform_packages}
|
|
||||||
board = nodemcuv2
|
|
||||||
lib_deps = ${esp8266_defaults.lib_deps}
|
|
||||||
lib_ignore = ${esp8266_defaults.lib_ignore}
|
|
||||||
extra_scripts = ${esp8266_defaults.extra_scripts}
|
|
||||||
board_build.ldscript = ${esp8266_defaults.board_build.ldscript}
|
|
||||||
build_type = ${esp8266_defaults.build_type}
|
|
||||||
build_flags =
|
|
||||||
${esp8266_defaults.build_flags}
|
|
||||||
-D DEFAULT_OT_IN_GPIO=13
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=15
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=4
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=2
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=16
|
|
||||||
check_tool = ${esp8266_defaults.check_tool}
|
|
||||||
check_flags = ${esp8266_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:s2_mini]
|
[env:s2_mini]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = lolin_s2_mini
|
||||||
board = lolin_s2_mini
|
build_unflags = -DARDUINO_USB_MODE=1
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
lib_deps = ${esp32_defaults.lib_deps}
|
-D ARDUINO_USB_MODE=0
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D ARDUINO_USB_CDC_ON_BOOT=1
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D DEFAULT_OT_IN_GPIO=33
|
||||||
build_unflags =
|
-D DEFAULT_OT_OUT_GPIO=35
|
||||||
-DARDUINO_USB_MODE=1
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=9
|
||||||
build_type = ${esp32_defaults.build_type}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=7
|
||||||
build_flags =
|
-D DEFAULT_STATUS_LED_GPIO=11
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_OT_RX_LED_GPIO=12
|
||||||
-D ARDUINO_USB_MODE=0
|
|
||||||
-D ARDUINO_USB_CDC_ON_BOOT=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=33
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=35
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=9
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=7
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=11
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=12
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:s3_mini]
|
[env:s3_mini]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = lolin_s3_mini
|
||||||
board = lolin_s3_mini
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
${esp32_defaults.nimble_lib}
|
||||||
lib_deps =
|
build_unflags = -DARDUINO_USB_MODE=1
|
||||||
${esp32_defaults.lib_deps}
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
${esp32_defaults.nimble_lib}
|
-D ARDUINO_USB_MODE=0
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D ARDUINO_USB_CDC_ON_BOOT=1
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
||||||
build_unflags =
|
-D USE_BLE=1
|
||||||
-DARDUINO_USB_MODE=1
|
-D DEFAULT_OT_IN_GPIO=35
|
||||||
build_type = ${esp32_defaults.build_type}
|
-D DEFAULT_OT_OUT_GPIO=36
|
||||||
build_flags =
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=13
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=12
|
||||||
-D ARDUINO_USB_MODE=0
|
-D DEFAULT_STATUS_LED_GPIO=11
|
||||||
-D ARDUINO_USB_CDC_ON_BOOT=1
|
-D DEFAULT_OT_RX_LED_GPIO=10
|
||||||
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=35
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=36
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=13
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=12
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=11
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=10
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:c3_mini]
|
[env:c3_mini]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = lolin_c3_mini
|
||||||
board = lolin_c3_mini
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
${esp32_defaults.nimble_lib}
|
||||||
lib_deps =
|
;build_unflags = -mtext-section-literals
|
||||||
${esp32_defaults.lib_deps}
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
${esp32_defaults.nimble_lib}
|
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D USE_BLE=1
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D DEFAULT_OT_IN_GPIO=8
|
||||||
build_unflags =
|
-D DEFAULT_OT_OUT_GPIO=10
|
||||||
-mtext-section-literals
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
||||||
build_type = ${esp32_defaults.build_type}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=1
|
||||||
build_flags =
|
-D DEFAULT_STATUS_LED_GPIO=4
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_OT_RX_LED_GPIO=5
|
||||||
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=8
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=10
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=1
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=4
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=5
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:nodemcu_32]
|
[env:nodemcu_32]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = nodemcu-32s
|
||||||
board = nodemcu-32s
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
${esp32_defaults.nimble_lib}
|
||||||
lib_deps =
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
${esp32_defaults.lib_deps}
|
-D USE_BLE=1
|
||||||
${esp32_defaults.nimble_lib}
|
-D DEFAULT_OT_IN_GPIO=16
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D DEFAULT_OT_OUT_GPIO=4
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=15
|
||||||
build_type = ${esp32_defaults.build_type}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=26
|
||||||
build_flags =
|
-D DEFAULT_STATUS_LED_GPIO=2
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_OT_RX_LED_GPIO=19
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=16
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=4
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=15
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=26
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=2
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=19
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:nodemcu_32_160mhz]
|
[env:nodemcu_32_160mhz]
|
||||||
extends = env:nodemcu_32
|
extends = env:nodemcu_32
|
||||||
board_build.f_cpu = 160000000L ; set frequency to 160MHz
|
board_build.f_cpu = 160000000L ; set frequency to 160MHz
|
||||||
|
|
||||||
[env:d1_mini32]
|
[env:d1_mini32]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = wemos_d1_mini32
|
||||||
board = wemos_d1_mini32
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
${esp32_defaults.nimble_lib}
|
||||||
lib_deps =
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
${esp32_defaults.lib_deps}
|
-D USE_BLE=1
|
||||||
${esp32_defaults.nimble_lib}
|
-D DEFAULT_OT_IN_GPIO=21
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D DEFAULT_OT_OUT_GPIO=22
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
||||||
build_type = ${esp32_defaults.build_type}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=18
|
||||||
build_flags =
|
-D DEFAULT_STATUS_LED_GPIO=2
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_OT_RX_LED_GPIO=19
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=21
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=22
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=12
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=18
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=2
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=19
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:esp32_c6]
|
[env:esp32_c6]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
framework = arduino, espidf
|
board = esp32-c6-devkitc-1
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board = esp32-c6-devkitm-1
|
${esp32_defaults.nimble_lib}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
;build_unflags = -mtext-section-literals
|
||||||
board_build.embed_txtfiles =
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
managed_components/espressif__esp_insights/server_certs/https_server.crt
|
-D USE_BLE=1
|
||||||
managed_components/espressif__esp_rainmaker/server_certs/rmaker_mqtt_server.crt
|
-D DEFAULT_OT_IN_GPIO=15
|
||||||
managed_components/espressif__esp_rainmaker/server_certs/rmaker_claim_service_server.crt
|
-D DEFAULT_OT_OUT_GPIO=23
|
||||||
managed_components/espressif__esp_rainmaker/server_certs/rmaker_ota_server.crt
|
-D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
||||||
lib_deps = ${esp32_defaults.lib_deps}
|
-D DEFAULT_SENSOR_INDOOR_GPIO=0
|
||||||
lib_ignore =
|
-D DEFAULT_STATUS_LED_GPIO=11
|
||||||
${esp32_defaults.lib_ignore}
|
-D DEFAULT_OT_RX_LED_GPIO=10
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
custom_sdkconfig = '# CONFIG_OPENTHREAD_ENABLED is not set'
|
||||||
build_unflags =
|
'# CONFIG_ESP_WIFI_ENTERPRISE_SUPPORT is not set'
|
||||||
-mtext-section-literals
|
'# CONFIG_LWIP_IPV6 is not set'
|
||||||
build_type = ${esp32_defaults.build_type}
|
'# CONFIG_LWIP_IPV6_AUTOCONFIG is not set'
|
||||||
build_flags =
|
'# CONFIG_LWIP_PPP_SUPPORT is not set'
|
||||||
${esp32_defaults.build_flags}
|
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=15
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=23
|
|
||||||
-D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
|
||||||
-D DEFAULT_SENSOR_INDOOR_GPIO=0
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=11
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=10
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|
||||||
[env:otthing]
|
[env:otthing]
|
||||||
platform = ${esp32_defaults.platform}
|
extends = esp32_defaults
|
||||||
platform_packages = ${esp32_defaults.platform_packages}
|
board = lolin_c3_mini
|
||||||
board = lolin_c3_mini
|
lib_deps = ${esp32_defaults.lib_deps}
|
||||||
board_build.partitions = ${esp32_defaults.board_build.partitions}
|
${esp32_defaults.nimble_lib}
|
||||||
lib_deps =
|
;build_unflags = -mtext-section-literals
|
||||||
${esp32_defaults.lib_deps}
|
build_flags = ${esp32_defaults.build_flags}
|
||||||
${esp32_defaults.nimble_lib}
|
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
||||||
lib_ignore = ${esp32_defaults.lib_ignore}
|
-D USE_BLE=1
|
||||||
extra_scripts = ${esp32_defaults.extra_scripts}
|
-D DEFAULT_OT_IN_GPIO=3
|
||||||
build_unflags =
|
-D DEFAULT_OT_OUT_GPIO=1
|
||||||
-mtext-section-literals
|
;-D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
||||||
build_type = ${esp32_defaults.build_type}
|
;-D DEFAULT_SENSOR_INDOOR_GPIO=1
|
||||||
build_flags =
|
-D DEFAULT_STATUS_LED_GPIO=8
|
||||||
${esp32_defaults.build_flags}
|
-D DEFAULT_OT_RX_LED_GPIO=2
|
||||||
-D MYNEWT_VAL_BLE_EXT_ADV=1
|
-D OT_BYPASS_RELAY_GPIO=20
|
||||||
-D USE_BLE=1
|
|
||||||
-D DEFAULT_OT_IN_GPIO=3
|
|
||||||
-D DEFAULT_OT_OUT_GPIO=1
|
|
||||||
; -D DEFAULT_SENSOR_OUTDOOR_GPIO=0
|
|
||||||
; -D DEFAULT_SENSOR_INDOOR_GPIO=1
|
|
||||||
-D DEFAULT_STATUS_LED_GPIO=8
|
|
||||||
-D DEFAULT_OT_RX_LED_GPIO=2
|
|
||||||
-D OT_BYPASS_RELAY_GPIO=20
|
|
||||||
check_tool = ${esp32_defaults.check_tool}
|
|
||||||
check_flags = ${esp32_defaults.check_flags}
|
|
||||||
|
|||||||
@@ -1,33 +0,0 @@
|
|||||||
# Source:
|
|
||||||
# https://github.com/pioarduino/platform-espressif32/tree/main/examples/espidf-arduino-h2zero-BLE_scan
|
|
||||||
|
|
||||||
CONFIG_FREERTOS_HZ=1000
|
|
||||||
CONFIG_MBEDTLS_PSK_MODES=y
|
|
||||||
CONFIG_MBEDTLS_KEY_EXCHANGE_PSK=y
|
|
||||||
CONFIG_BOOTLOADER_COMPILER_OPTIMIZATION_SIZE=y
|
|
||||||
CONFIG_COMPILER_OPTIMIZATION_SIZE=y
|
|
||||||
CONFIG_ESPTOOLPY_FLASHSIZE_4MB=y
|
|
||||||
CONFIG_ESPTOOLPY_HEADER_FLASHSIZE_UPDATE=y
|
|
||||||
|
|
||||||
#
|
|
||||||
# BT config
|
|
||||||
CONFIG_BT_ENABLED=y
|
|
||||||
CONFIG_BTDM_CTRL_MODE_BLE_ONLY=y
|
|
||||||
CONFIG_BTDM_CTRL_MODE_BR_EDR_ONLY=n
|
|
||||||
CONFIG_BTDM_CTRL_MODE_BTDM=n
|
|
||||||
CONFIG_BT_BLUEDROID_ENABLED=n
|
|
||||||
CONFIG_BT_NIMBLE_ENABLED=y
|
|
||||||
|
|
||||||
#
|
|
||||||
# Arduino Configuration
|
|
||||||
CONFIG_AUTOSTART_ARDUINO=y
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_COMPILATION=y
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_Zigbee=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_Matter=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_WiFiProv=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_BLE=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_BluetoothSerial=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_SimpleBLE=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_RainMaker=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_OpenThread=n
|
|
||||||
CONFIG_ARDUINO_SELECTIVE_Insights=n
|
|
||||||
@@ -176,9 +176,10 @@ public:
|
|||||||
objId.c_str()
|
objId.c_str()
|
||||||
);
|
);
|
||||||
|
|
||||||
// set device class, name, value template for bluetooth sensors
|
// set device class, name, value template for Bluetooth/DHT sensors
|
||||||
// or name & value template for another sensors
|
// or name & value template for another sensors
|
||||||
if (sSensor.type == Sensors::Type::BLUETOOTH) {
|
if (sSensor.type == Sensors::Type::BLUETOOTH ||
|
||||||
|
sSensor.type == Sensors::Type::DHT11 || sSensor.type == Sensors::Type::DHT22) {
|
||||||
// available state topic
|
// available state topic
|
||||||
doc[FPSTR(HA_AVAILABILITY)][1][FPSTR(HA_TOPIC)] = doc[FPSTR(HA_STATE_TOPIC)];
|
doc[FPSTR(HA_AVAILABILITY)][1][FPSTR(HA_TOPIC)] = doc[FPSTR(HA_STATE_TOPIC)];
|
||||||
doc[FPSTR(HA_AVAILABILITY)][1][FPSTR(HA_VALUE_TEMPLATE)] = JsonString(AVAILABILITY_SENSOR_CONN, true);
|
doc[FPSTR(HA_AVAILABILITY)][1][FPSTR(HA_VALUE_TEMPLATE)] = JsonString(AVAILABILITY_SENSOR_CONN, true);
|
||||||
|
|||||||
@@ -49,6 +49,10 @@ protected:
|
|||||||
return "Main";
|
return "Main";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t getTaskStackSize() override {
|
||||||
|
return 6000;
|
||||||
|
}
|
||||||
|
|
||||||
/*BaseType_t getTaskCore() override {
|
/*BaseType_t getTaskCore() override {
|
||||||
return 1;
|
return 1;
|
||||||
}*/
|
}*/
|
||||||
@@ -128,8 +132,6 @@ protected:
|
|||||||
tMqtt->disable();
|
tMqtt->disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
Sensors::setConnectionStatusByType(Sensors::Type::MANUAL, !settings.mqtt.enabled || vars.mqtt.connected, false);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (this->ntpStarted) {
|
if (this->ntpStarted) {
|
||||||
this->ntpStarted = false;
|
this->ntpStarted = false;
|
||||||
|
|||||||
@@ -292,6 +292,14 @@ protected:
|
|||||||
this->haHelper->deleteDynamicSensor(prevSettings, Sensors::ValueType::RSSI);
|
this->haHelper->deleteDynamicSensor(prevSettings, Sensors::ValueType::RSSI);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case Sensors::Type::DHT11:
|
||||||
|
case Sensors::Type::DHT22:
|
||||||
|
this->haHelper->deleteConnectionDynamicSensor(prevSettings);
|
||||||
|
this->haHelper->deleteSignalQualityDynamicSensor(prevSettings);
|
||||||
|
this->haHelper->deleteDynamicSensor(prevSettings, Sensors::ValueType::TEMPERATURE);
|
||||||
|
this->haHelper->deleteDynamicSensor(prevSettings, Sensors::ValueType::HUMIDITY);
|
||||||
|
break;
|
||||||
|
|
||||||
case Sensors::Type::DALLAS_TEMP:
|
case Sensors::Type::DALLAS_TEMP:
|
||||||
this->haHelper->deleteConnectionDynamicSensor(prevSettings);
|
this->haHelper->deleteConnectionDynamicSensor(prevSettings);
|
||||||
this->haHelper->deleteSignalQualityDynamicSensor(prevSettings);
|
this->haHelper->deleteSignalQualityDynamicSensor(prevSettings);
|
||||||
@@ -319,6 +327,14 @@ protected:
|
|||||||
this->haHelper->publishDynamicSensor(sSettings, Sensors::ValueType::RSSI, settings.system.unitSystem, false);
|
this->haHelper->publishDynamicSensor(sSettings, Sensors::ValueType::RSSI, settings.system.unitSystem, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case Sensors::Type::DHT11:
|
||||||
|
case Sensors::Type::DHT22:
|
||||||
|
this->haHelper->publishConnectionDynamicSensor(sSettings);
|
||||||
|
this->haHelper->publishSignalQualityDynamicSensor(sSettings, false);
|
||||||
|
this->haHelper->publishDynamicSensor(sSettings, Sensors::ValueType::TEMPERATURE, settings.system.unitSystem);
|
||||||
|
this->haHelper->publishDynamicSensor(sSettings, Sensors::ValueType::HUMIDITY, settings.system.unitSystem);
|
||||||
|
break;
|
||||||
|
|
||||||
case Sensors::Type::DALLAS_TEMP:
|
case Sensors::Type::DALLAS_TEMP:
|
||||||
this->haHelper->publishConnectionDynamicSensor(sSettings);
|
this->haHelper->publishConnectionDynamicSensor(sSettings);
|
||||||
this->haHelper->publishSignalQualityDynamicSensor(sSettings, false);
|
this->haHelper->publishSignalQualityDynamicSensor(sSettings, false);
|
||||||
|
|||||||
@@ -38,8 +38,12 @@ protected:
|
|||||||
return "OpenTherm";
|
return "OpenTherm";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t getTaskStackSize() override {
|
||||||
|
return 7500;
|
||||||
|
}
|
||||||
|
|
||||||
BaseType_t getTaskCore() override {
|
BaseType_t getTaskCore() override {
|
||||||
return 1;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int getTaskPriority() override {
|
int getTaskPriority() override {
|
||||||
|
|||||||
@@ -172,8 +172,19 @@ protected:
|
|||||||
sensorSettingsToJson(sensorId, Sensors::settings[sensorId], sensorsettingsDoc);
|
sensorSettingsToJson(sensorId, Sensors::settings[sensorId], sensorsettingsDoc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char filename[64];
|
||||||
|
getFilename(filename, sizeof(filename), "backup");
|
||||||
|
|
||||||
|
char contentDispositionValue[128];
|
||||||
|
snprintf_P(
|
||||||
|
contentDispositionValue,
|
||||||
|
sizeof(contentDispositionValue),
|
||||||
|
PSTR("attachment; filename=\"%s\""),
|
||||||
|
filename
|
||||||
|
);
|
||||||
|
|
||||||
// send response
|
// send response
|
||||||
response->addHeader("Content-Disposition", "attachment; filename=\"backup.json\"");
|
response->addHeader("Content-Disposition", contentDispositionValue);
|
||||||
response->setLength();
|
response->setLength();
|
||||||
request->send(response);
|
request->send(response);
|
||||||
}).addMiddleware(&authMiddleware);
|
}).addMiddleware(&authMiddleware);
|
||||||
@@ -541,6 +552,7 @@ protected:
|
|||||||
|
|
||||||
auto docBuild = doc[FPSTR(S_BUILD)].to<JsonObject>();
|
auto docBuild = doc[FPSTR(S_BUILD)].to<JsonObject>();
|
||||||
docBuild[FPSTR(S_VERSION)] = BUILD_VERSION;
|
docBuild[FPSTR(S_VERSION)] = BUILD_VERSION;
|
||||||
|
docBuild[FPSTR(S_COMMIT)] = BUILD_COMMIT;
|
||||||
docBuild[FPSTR(S_DATE)] = __DATE__ " " __TIME__;
|
docBuild[FPSTR(S_DATE)] = __DATE__ " " __TIME__;
|
||||||
docBuild[FPSTR(S_ENV)] = BUILD_ENV;
|
docBuild[FPSTR(S_ENV)] = BUILD_ENV;
|
||||||
docBuild[FPSTR(S_CORE)] = ESP.getCoreVersion();
|
docBuild[FPSTR(S_CORE)] = ESP.getCoreVersion();
|
||||||
@@ -581,6 +593,7 @@ protected:
|
|||||||
|
|
||||||
auto docBuild = doc[FPSTR(S_BUILD)].to<JsonObject>();
|
auto docBuild = doc[FPSTR(S_BUILD)].to<JsonObject>();
|
||||||
docBuild[FPSTR(S_VERSION)] = BUILD_VERSION;
|
docBuild[FPSTR(S_VERSION)] = BUILD_VERSION;
|
||||||
|
docBuild[FPSTR(S_COMMIT)] = BUILD_COMMIT;
|
||||||
docBuild[FPSTR(S_DATE)] = __DATE__ " " __TIME__;
|
docBuild[FPSTR(S_DATE)] = __DATE__ " " __TIME__;
|
||||||
docBuild[FPSTR(S_ENV)] = BUILD_ENV;
|
docBuild[FPSTR(S_ENV)] = BUILD_ENV;
|
||||||
docBuild[FPSTR(S_CORE)] = ESP.getCoreVersion();
|
docBuild[FPSTR(S_CORE)] = ESP.getCoreVersion();
|
||||||
@@ -624,8 +637,19 @@ protected:
|
|||||||
docCrash[FPSTR(S_EPC)] = epcStr;
|
docCrash[FPSTR(S_EPC)] = epcStr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
char filename[64];
|
||||||
|
getFilename(filename, sizeof(filename), "debug");
|
||||||
|
|
||||||
|
char contentDispositionValue[128];
|
||||||
|
snprintf_P(
|
||||||
|
contentDispositionValue,
|
||||||
|
sizeof(contentDispositionValue),
|
||||||
|
PSTR("attachment; filename=\"%s\""),
|
||||||
|
filename
|
||||||
|
);
|
||||||
|
|
||||||
// send response
|
// send response
|
||||||
response->addHeader("Content-Disposition", "attachment; filename=\"debug.json\"");
|
response->addHeader("Content-Disposition", contentDispositionValue);
|
||||||
response->setLength();
|
response->setLength();
|
||||||
request->send(response);
|
request->send(response);
|
||||||
}).addMiddleware(&authMiddleware);
|
}).addMiddleware(&authMiddleware);
|
||||||
@@ -783,4 +807,12 @@ protected:
|
|||||||
this->dnsServer->stop();
|
this->dnsServer->stop();
|
||||||
this->dnsServerEnabled = false;
|
this->dnsServerEnabled = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void getFilename(char* filename, size_t maxSizeFilename, const char* type) {
|
||||||
|
const time_t now = time(nullptr);
|
||||||
|
const tm* localNow = localtime(&now);
|
||||||
|
char localNowValue[20];
|
||||||
|
strftime(localNowValue, sizeof(localNowValue), PSTR("%Y-%m-%d-%H-%M-%S"), localNow);
|
||||||
|
snprintf_P(filename, maxSizeFilename, PSTR("%s_%s_%s.json"), networkSettings.hostname, localNowValue, type);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
@@ -20,6 +20,10 @@ protected:
|
|||||||
return "Regulator";
|
return "Regulator";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t getTaskStackSize() override {
|
||||||
|
return 5000;
|
||||||
|
}
|
||||||
|
|
||||||
/*BaseType_t getTaskCore() override {
|
/*BaseType_t getTaskCore() override {
|
||||||
return 1;
|
return 1;
|
||||||
}*/
|
}*/
|
||||||
|
|||||||
@@ -39,6 +39,8 @@ public:
|
|||||||
NTC_10K_TEMP = 50,
|
NTC_10K_TEMP = 50,
|
||||||
DALLAS_TEMP = 51,
|
DALLAS_TEMP = 51,
|
||||||
BLUETOOTH = 52,
|
BLUETOOTH = 52,
|
||||||
|
DHT11 = 53,
|
||||||
|
DHT22 = 54,
|
||||||
|
|
||||||
HEATING_SETPOINT_TEMP = 253,
|
HEATING_SETPOINT_TEMP = 253,
|
||||||
MANUAL = 254,
|
MANUAL = 254,
|
||||||
|
|||||||
1050
src/SensorsTask.h
1050
src/SensorsTask.h
File diff suppressed because it is too large
Load Diff
@@ -30,6 +30,10 @@
|
|||||||
#define BUILD_VERSION "0.0.0"
|
#define BUILD_VERSION "0.0.0"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef BUILD_COMMIT
|
||||||
|
#define BUILD_COMMIT "undefined"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef BUILD_ENV
|
#ifndef BUILD_ENV
|
||||||
#define BUILD_ENV "undefined"
|
#define BUILD_ENV "undefined"
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
dependencies:
|
|
||||||
idf: ">=5.3.2"
|
|
||||||
h2zero/esp-nimble-cpp: ">=2.2.1"
|
|
||||||
@@ -24,6 +24,7 @@ const char L_OT_CH2[] PROGMEM = "OT.CH2";
|
|||||||
const char L_SENSORS[] PROGMEM = "SENSORS";
|
const char L_SENSORS[] PROGMEM = "SENSORS";
|
||||||
const char L_SENSORS_SETTINGS[] PROGMEM = "SENSORS.SETTINGS";
|
const char L_SENSORS_SETTINGS[] PROGMEM = "SENSORS.SETTINGS";
|
||||||
const char L_SENSORS_DALLAS[] PROGMEM = "SENSORS.DALLAS";
|
const char L_SENSORS_DALLAS[] PROGMEM = "SENSORS.DALLAS";
|
||||||
|
const char L_SENSORS_DHT[] PROGMEM = "SENSORS.DHT";
|
||||||
const char L_SENSORS_NTC[] PROGMEM = "SENSORS.NTC";
|
const char L_SENSORS_NTC[] PROGMEM = "SENSORS.NTC";
|
||||||
const char L_SENSORS_BLE[] PROGMEM = "SENSORS.BLE";
|
const char L_SENSORS_BLE[] PROGMEM = "SENSORS.BLE";
|
||||||
const char L_REGULATOR[] PROGMEM = "REGULATOR";
|
const char L_REGULATOR[] PROGMEM = "REGULATOR";
|
||||||
@@ -56,6 +57,7 @@ const char S_CHANNEL[] PROGMEM = "channel";
|
|||||||
const char S_CH2_ALWAYS_ENABLED[] PROGMEM = "ch2AlwaysEnabled";
|
const char S_CH2_ALWAYS_ENABLED[] PROGMEM = "ch2AlwaysEnabled";
|
||||||
const char S_CHIP[] PROGMEM = "chip";
|
const char S_CHIP[] PROGMEM = "chip";
|
||||||
const char S_CODE[] PROGMEM = "code";
|
const char S_CODE[] PROGMEM = "code";
|
||||||
|
const char S_COMMIT[] PROGMEM = "commit";
|
||||||
const char S_CONNECTED[] PROGMEM = "connected";
|
const char S_CONNECTED[] PROGMEM = "connected";
|
||||||
const char S_CONTINUES[] PROGMEM = "continues";
|
const char S_CONTINUES[] PROGMEM = "continues";
|
||||||
const char S_COOLING[] PROGMEM = "cooling";
|
const char S_COOLING[] PROGMEM = "cooling";
|
||||||
|
|||||||
28
src/utils.h
28
src/utils.h
@@ -1927,6 +1927,8 @@ bool jsonToSensorSettings(const uint8_t sensorId, const JsonVariantConst src, Se
|
|||||||
case static_cast<uint8_t>(Sensors::Type::NTC_10K_TEMP):
|
case static_cast<uint8_t>(Sensors::Type::NTC_10K_TEMP):
|
||||||
case static_cast<uint8_t>(Sensors::Type::DALLAS_TEMP):
|
case static_cast<uint8_t>(Sensors::Type::DALLAS_TEMP):
|
||||||
case static_cast<uint8_t>(Sensors::Type::BLUETOOTH):
|
case static_cast<uint8_t>(Sensors::Type::BLUETOOTH):
|
||||||
|
case static_cast<uint8_t>(Sensors::Type::DHT11):
|
||||||
|
case static_cast<uint8_t>(Sensors::Type::DHT22):
|
||||||
case static_cast<uint8_t>(Sensors::Type::HEATING_SETPOINT_TEMP):
|
case static_cast<uint8_t>(Sensors::Type::HEATING_SETPOINT_TEMP):
|
||||||
case static_cast<uint8_t>(Sensors::Type::MANUAL):
|
case static_cast<uint8_t>(Sensors::Type::MANUAL):
|
||||||
case static_cast<uint8_t>(Sensors::Type::NOT_CONFIGURED):
|
case static_cast<uint8_t>(Sensors::Type::NOT_CONFIGURED):
|
||||||
@@ -1943,7 +1945,8 @@ bool jsonToSensorSettings(const uint8_t sensorId, const JsonVariantConst src, Se
|
|||||||
|
|
||||||
// gpio
|
// gpio
|
||||||
if (!src[FPSTR(S_GPIO)].isNull()) {
|
if (!src[FPSTR(S_GPIO)].isNull()) {
|
||||||
if (dst.type != Sensors::Type::DALLAS_TEMP && dst.type != Sensors::Type::NTC_10K_TEMP) {
|
if (dst.type != Sensors::Type::DALLAS_TEMP && dst.type != Sensors::Type::NTC_10K_TEMP &&
|
||||||
|
dst.type != Sensors::Type::DHT11 && dst.type != Sensors::Type::DHT22) {
|
||||||
if (dst.gpio != GPIO_IS_NOT_CONFIGURED) {
|
if (dst.gpio != GPIO_IS_NOT_CONFIGURED) {
|
||||||
dst.gpio = GPIO_IS_NOT_CONFIGURED;
|
dst.gpio = GPIO_IS_NOT_CONFIGURED;
|
||||||
changed = true;
|
changed = true;
|
||||||
@@ -2084,6 +2087,10 @@ void sensorResultToJson(const uint8_t sensorId, JsonVariant dst) {
|
|||||||
dst[FPSTR(S_BATTERY)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::BATTERY)], 1);
|
dst[FPSTR(S_BATTERY)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::BATTERY)], 1);
|
||||||
dst[FPSTR(S_RSSI)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::RSSI)], 0);
|
dst[FPSTR(S_RSSI)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::RSSI)], 0);
|
||||||
|
|
||||||
|
} else if (sSensor.type == Sensors::Type::DHT11 || sSensor.type == Sensors::Type::DHT22) {
|
||||||
|
dst[FPSTR(S_TEMPERATURE)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::TEMPERATURE)], 3);
|
||||||
|
dst[FPSTR(S_HUMIDITY)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::HUMIDITY)], 3);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
dst[FPSTR(S_VALUE)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::PRIMARY)], 3);
|
dst[FPSTR(S_VALUE)] = roundf(rSensor.values[static_cast<uint8_t>(Sensors::ValueType::PRIMARY)], 3);
|
||||||
}
|
}
|
||||||
@@ -2099,21 +2106,18 @@ bool jsonToSensorResult(const uint8_t sensorId, const JsonVariantConst src) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto& dst = Sensors::results[sensorId];
|
|
||||||
bool changed = false;
|
|
||||||
|
|
||||||
// value
|
// value
|
||||||
if (!src[FPSTR(S_VALUE)].isNull()) {
|
if (!src[FPSTR(S_VALUE)].isNull()) {
|
||||||
float value = src[FPSTR(S_VALUE)].as<float>();
|
return Sensors::setValueById(
|
||||||
|
sensorId,
|
||||||
uint8_t vType = static_cast<uint8_t>(Sensors::ValueType::PRIMARY);
|
src[FPSTR(S_VALUE)].as<float>(),
|
||||||
if (fabsf(value - dst.values[vType]) > 0.0001f) {
|
Sensors::ValueType::PRIMARY,
|
||||||
dst.values[vType] = roundf(value, 2);
|
true,
|
||||||
changed = true;
|
true
|
||||||
}
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return changed;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void varsToJson(const Variables& src, JsonVariant dst) {
|
void varsToJson(const Variables& src, JsonVariant dst) {
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"title": "Build",
|
"title": "Build",
|
||||||
"version": "固件版本",
|
"version": "固件版本",
|
||||||
|
"commit": "Commit",
|
||||||
"date": "日期",
|
"date": "日期",
|
||||||
"core": "内核版本",
|
"core": "内核版本",
|
||||||
"sdk": "SDK"
|
"sdk": "SDK"
|
||||||
@@ -248,6 +249,8 @@
|
|||||||
"ntcTemp": "NTC 传感器",
|
"ntcTemp": "NTC 传感器",
|
||||||
"dallasTemp": "DALLAS 传感器",
|
"dallasTemp": "DALLAS 传感器",
|
||||||
"bluetooth": "BLE 传感器",
|
"bluetooth": "BLE 传感器",
|
||||||
|
"dht11": "DHT11 传感器",
|
||||||
|
"dht22": "DHT22 传感器",
|
||||||
"heatSetpointTemp": "Heating, setpoint temp",
|
"heatSetpointTemp": "Heating, setpoint temp",
|
||||||
"manual": "通过 MQTT/API 手动配置",
|
"manual": "通过 MQTT/API 手动配置",
|
||||||
"notConfigured": "未配置"
|
"notConfigured": "未配置"
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"title": "Build",
|
"title": "Build",
|
||||||
"version": "Version",
|
"version": "Version",
|
||||||
|
"commit": "Commit",
|
||||||
"date": "Date",
|
"date": "Date",
|
||||||
"core": "Core",
|
"core": "Core",
|
||||||
"sdk": "SDK"
|
"sdk": "SDK"
|
||||||
@@ -248,6 +249,8 @@
|
|||||||
"ntcTemp": "NTC sensor",
|
"ntcTemp": "NTC sensor",
|
||||||
"dallasTemp": "DALLAS sensor",
|
"dallasTemp": "DALLAS sensor",
|
||||||
"bluetooth": "BLE sensor",
|
"bluetooth": "BLE sensor",
|
||||||
|
"dht11": "DHT11 sensor",
|
||||||
|
"dht22": "DHT22 sensor",
|
||||||
"heatSetpointTemp": "Heating, setpoint temp",
|
"heatSetpointTemp": "Heating, setpoint temp",
|
||||||
"manual": "Manual via MQTT/API",
|
"manual": "Manual via MQTT/API",
|
||||||
"notConfigured": "Not configured"
|
"notConfigured": "Not configured"
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"title": "Build",
|
"title": "Build",
|
||||||
"version": "Versione",
|
"version": "Versione",
|
||||||
|
"commit": "Commit",
|
||||||
"date": "Data",
|
"date": "Data",
|
||||||
"core": "Core",
|
"core": "Core",
|
||||||
"sdk": "SDK"
|
"sdk": "SDK"
|
||||||
@@ -248,6 +249,8 @@
|
|||||||
"ntcTemp": "Sensore NTC",
|
"ntcTemp": "Sensore NTC",
|
||||||
"dallasTemp": "Sensore DALLAS",
|
"dallasTemp": "Sensore DALLAS",
|
||||||
"bluetooth": "Sensore BLE",
|
"bluetooth": "Sensore BLE",
|
||||||
|
"dht11": "Sensore DHT11",
|
||||||
|
"dht22": "Sensore DHT22",
|
||||||
"heatSetpointTemp": "Riscaldamento, temp impostata",
|
"heatSetpointTemp": "Riscaldamento, temp impostata",
|
||||||
"manual": "Manuale via MQTT/API",
|
"manual": "Manuale via MQTT/API",
|
||||||
"notConfigured": "Non configurato"
|
"notConfigured": "Non configurato"
|
||||||
|
|||||||
@@ -40,6 +40,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"title": "Build",
|
"title": "Build",
|
||||||
"version": "Versie",
|
"version": "Versie",
|
||||||
|
"commit": "Commit",
|
||||||
"date": "Datum",
|
"date": "Datum",
|
||||||
"core": "Core",
|
"core": "Core",
|
||||||
"sdk": "SDK"
|
"sdk": "SDK"
|
||||||
@@ -227,6 +228,8 @@
|
|||||||
"ntcTemp": "NTC-sensor",
|
"ntcTemp": "NTC-sensor",
|
||||||
"dallasTemp": "DALLAS-sensor",
|
"dallasTemp": "DALLAS-sensor",
|
||||||
"bluetooth": "BLE-sensor",
|
"bluetooth": "BLE-sensor",
|
||||||
|
"dht11": "DHT11-sensor",
|
||||||
|
"dht22": "DHT22-sensor",
|
||||||
"heatSetpointTemp": "Verwarming, insteltemperatuur",
|
"heatSetpointTemp": "Verwarming, insteltemperatuur",
|
||||||
"manual": "Handmatig via MQTT/API",
|
"manual": "Handmatig via MQTT/API",
|
||||||
"notConfigured": "Niet geconfigureerd"
|
"notConfigured": "Niet geconfigureerd"
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"title": "Билд",
|
"title": "Билд",
|
||||||
"version": "Версия",
|
"version": "Версия",
|
||||||
|
"commit": "Коммит",
|
||||||
"date": "Дата",
|
"date": "Дата",
|
||||||
"core": "Ядро",
|
"core": "Ядро",
|
||||||
"sdk": "SDK"
|
"sdk": "SDK"
|
||||||
@@ -248,6 +249,8 @@
|
|||||||
"ntcTemp": "NTC датчик",
|
"ntcTemp": "NTC датчик",
|
||||||
"dallasTemp": "DALLAS датчик",
|
"dallasTemp": "DALLAS датчик",
|
||||||
"bluetooth": "BLE датчик",
|
"bluetooth": "BLE датчик",
|
||||||
|
"dht11": "DHT11 датчик",
|
||||||
|
"dht22": "DHT22 датчик",
|
||||||
"heatSetpointTemp": "Отопление, температура уставки",
|
"heatSetpointTemp": "Отопление, температура уставки",
|
||||||
"manual": "Вручную через MQTT/API",
|
"manual": "Вручную через MQTT/API",
|
||||||
"notConfigured": "Не сконфигурировано"
|
"notConfigured": "Не сконфигурировано"
|
||||||
|
|||||||
@@ -104,6 +104,7 @@
|
|||||||
<th scope="row" data-i18n>index.system.build.title</th>
|
<th scope="row" data-i18n>index.system.build.title</th>
|
||||||
<td>
|
<td>
|
||||||
Env: <b id="build-env"></b><br />
|
Env: <b id="build-env"></b><br />
|
||||||
|
<span data-i18n>index.system.build.commit</span>: <b id="build-commit"></b><br />
|
||||||
<span data-i18n>index.system.build.date</span>: <b id="build-date"></b><br />
|
<span data-i18n>index.system.build.date</span>: <b id="build-date"></b><br />
|
||||||
<span data-i18n>index.system.build.core</span>: <b id="build-core"></b><br />
|
<span data-i18n>index.system.build.core</span>: <b id="build-core"></b><br />
|
||||||
<span data-i18n>index.system.build.sdk</span>: <b id="build-sdk"></b>
|
<span data-i18n>index.system.build.sdk</span>: <b id="build-sdk"></b>
|
||||||
@@ -206,6 +207,7 @@
|
|||||||
setBusy('#main-busy', '#main-table', false);
|
setBusy('#main-busy', '#main-table', false);
|
||||||
|
|
||||||
setValue('#build-version', result.build.version);
|
setValue('#build-version', result.build.version);
|
||||||
|
setValue('#build-commit', result.build.commit);
|
||||||
setValue('#build-date', result.build.date);
|
setValue('#build-date', result.build.date);
|
||||||
setValue('#build-env', result.build.env);
|
setValue('#build-env', result.build.env);
|
||||||
setValue('#build-core', result.build.core);
|
setValue('#build-core', result.build.core);
|
||||||
|
|||||||
@@ -118,6 +118,8 @@
|
|||||||
<option value="50" data-i18n>sensors.types.ntcTemp</option>
|
<option value="50" data-i18n>sensors.types.ntcTemp</option>
|
||||||
<option value="51" data-i18n>sensors.types.dallasTemp</option>
|
<option value="51" data-i18n>sensors.types.dallasTemp</option>
|
||||||
<option value="52" data-i18n>sensors.types.bluetooth</option>
|
<option value="52" data-i18n>sensors.types.bluetooth</option>
|
||||||
|
<option value="53" data-i18n>sensors.types.dht11</option>
|
||||||
|
<option value="54" data-i18n>sensors.types.dht22</option>
|
||||||
<option value="253" data-i18n>sensors.types.heatSetpointTemp</option>
|
<option value="253" data-i18n>sensors.types.heatSetpointTemp</option>
|
||||||
<option value="254" data-i18n>sensors.types.manual</option>
|
<option value="254" data-i18n>sensors.types.manual</option>
|
||||||
<option value="255" data-i18n>sensors.types.notConfigured</option>
|
<option value="255" data-i18n>sensors.types.notConfigured</option>
|
||||||
@@ -271,27 +273,35 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch(parseInt(event.target.value)) {
|
switch(parseInt(event.target.value)) {
|
||||||
// ntc
|
// NTC10K
|
||||||
case 50:
|
case 50:
|
||||||
parentGpio.classList.remove("hidden");
|
parentGpio.classList.remove("hidden");
|
||||||
parentAddress.classList.add("hidden");
|
parentAddress.classList.add("hidden");
|
||||||
address.removeAttribute("pattern");
|
address.removeAttribute("pattern");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// dallas
|
// OneWire
|
||||||
case 51:
|
case 51:
|
||||||
parentGpio.classList.remove("hidden");
|
parentGpio.classList.remove("hidden");
|
||||||
parentAddress.classList.remove("hidden");
|
parentAddress.classList.remove("hidden");
|
||||||
address.setAttribute("pattern", "([A-Fa-f0-9]{2}:){7}[A-Fa-f0-9]{2}");
|
address.setAttribute("pattern", "([A-Fa-f0-9]{2}:){7}[A-Fa-f0-9]{2}");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// ble
|
// Bluetooth
|
||||||
case 52:
|
case 52:
|
||||||
parentGpio.classList.add("hidden");
|
parentGpio.classList.add("hidden");
|
||||||
parentAddress.classList.remove("hidden");
|
parentAddress.classList.remove("hidden");
|
||||||
address.setAttribute("pattern", "([A-Fa-f0-9]{2}:){5}[A-Fa-f0-9]{2}");
|
address.setAttribute("pattern", "([A-Fa-f0-9]{2}:){5}[A-Fa-f0-9]{2}");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
// DHT
|
||||||
|
case 53:
|
||||||
|
case 54:
|
||||||
|
parentGpio.classList.remove("hidden");
|
||||||
|
parentAddress.classList.add("hidden");
|
||||||
|
address.removeAttribute("pattern");
|
||||||
|
break;
|
||||||
|
|
||||||
// other
|
// other
|
||||||
default:
|
default:
|
||||||
parentGpio.classList.add("hidden");
|
parentGpio.classList.add("hidden");
|
||||||
|
|||||||
16
tools/add_build_commit.py
Normal file
16
tools/add_build_commit.py
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
import subprocess
|
||||||
|
Import("env")
|
||||||
|
|
||||||
|
try:
|
||||||
|
commit_hash = "undefined"
|
||||||
|
result = subprocess.check_output(
|
||||||
|
["git", "rev-parse", "--short", "HEAD"]
|
||||||
|
)
|
||||||
|
commit_hash = result.decode("utf-8").strip()
|
||||||
|
env.Append(
|
||||||
|
CPPDEFINES=[
|
||||||
|
("BUILD_COMMIT", '\\"{}\\"'.format(commit_hash))
|
||||||
|
]
|
||||||
|
)
|
||||||
|
except Exception as error:
|
||||||
|
print("Failed to get commit hash: {}".format(error))
|
||||||
Reference in New Issue
Block a user