mirror of
https://github.com/esphome/esphome.git
synced 2025-01-19 20:34:06 +00:00
15331edb78
* Allow overriding setup priority * Add inheritance tree * Global variables * Tests and better validation * Fix * Lint
54 lines
2.4 KiB
Python
54 lines
2.4 KiB
Python
import voluptuous as vol
|
|
|
|
from esphomeyaml.components import esp32_ble_tracker, sensor
|
|
from esphomeyaml.components.esp32_ble_tracker import CONF_ESP32_BLE_ID, ESP32BLETracker, \
|
|
make_address_array
|
|
import esphomeyaml.config_validation as cv
|
|
from esphomeyaml.const import CONF_BATTERY_LEVEL, CONF_CONDUCTIVITY, CONF_ID, CONF_ILLUMINANCE, \
|
|
CONF_MAC_ADDRESS, CONF_MOISTURE, CONF_NAME, CONF_TEMPERATURE
|
|
from esphomeyaml.helpers import Pvariable, get_variable
|
|
|
|
DEPENDENCIES = ['esp32_ble_tracker']
|
|
|
|
PLATFORM_SCHEMA = sensor.PLATFORM_SCHEMA.extend({
|
|
cv.GenerateID(): cv.declare_variable_id(esp32_ble_tracker.XiaomiDevice),
|
|
cv.GenerateID(CONF_ESP32_BLE_ID): cv.use_variable_id(ESP32BLETracker),
|
|
vol.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
|
vol.Optional(CONF_TEMPERATURE): cv.nameable(esp32_ble_tracker.XIAOMI_SENSOR_SCHEMA),
|
|
vol.Optional(CONF_MOISTURE): cv.nameable(esp32_ble_tracker.XIAOMI_SENSOR_SCHEMA),
|
|
vol.Optional(CONF_ILLUMINANCE): cv.nameable(esp32_ble_tracker.XIAOMI_SENSOR_SCHEMA),
|
|
vol.Optional(CONF_CONDUCTIVITY): cv.nameable(esp32_ble_tracker.XIAOMI_SENSOR_SCHEMA),
|
|
vol.Optional(CONF_BATTERY_LEVEL): cv.nameable(esp32_ble_tracker.XIAOMI_SENSOR_SCHEMA),
|
|
})
|
|
|
|
|
|
def to_code(config):
|
|
for hub in get_variable(config[CONF_ESP32_BLE_ID]):
|
|
yield
|
|
rhs = hub.make_xiaomi_device(make_address_array(config[CONF_MAC_ADDRESS]))
|
|
dev = Pvariable(config[CONF_ID], rhs)
|
|
if CONF_TEMPERATURE in config:
|
|
conf = config[CONF_TEMPERATURE]
|
|
sensor.register_sensor(dev.Pmake_temperature_sensor(conf[CONF_NAME]), conf)
|
|
if CONF_MOISTURE in config:
|
|
conf = config[CONF_MOISTURE]
|
|
sensor.register_sensor(dev.Pmake_moisture_sensor(conf[CONF_NAME]), conf)
|
|
if CONF_ILLUMINANCE in config:
|
|
conf = config[CONF_ILLUMINANCE]
|
|
sensor.register_sensor(dev.Pmake_illuminance_sensor(conf[CONF_NAME]), conf)
|
|
if CONF_CONDUCTIVITY in config:
|
|
conf = config[CONF_CONDUCTIVITY]
|
|
sensor.register_sensor(dev.Pmake_conductivity_sensor(conf[CONF_NAME]), conf)
|
|
if CONF_BATTERY_LEVEL in config:
|
|
conf = config[CONF_BATTERY_LEVEL]
|
|
sensor.register_sensor(dev.Pmake_battery_level_sensor(conf[CONF_NAME]), conf)
|
|
|
|
|
|
def to_hass_config(data, config):
|
|
ret = []
|
|
for key in (CONF_TEMPERATURE, CONF_MOISTURE, CONF_ILLUMINANCE, CONF_CONDUCTIVITY,
|
|
CONF_BATTERY_LEVEL):
|
|
if key in config:
|
|
ret.append(sensor.core_to_hass_config(data, config[key]))
|
|
return ret
|