2018-08-13 19:11:33 +02:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2018-11-12 23:30:31 +01:00
|
|
|
from esphomeyaml.components import i2c, sensor
|
2018-08-13 19:11:33 +02:00
|
|
|
import esphomeyaml.config_validation as cv
|
2018-11-12 23:30:31 +01:00
|
|
|
from esphomeyaml.const import CONF_ADDRESS, CONF_ID, CONF_MAKE_ID, CONF_NAME, CONF_PRESSURE, \
|
2018-08-13 19:11:33 +02:00
|
|
|
CONF_TEMPERATURE, CONF_UPDATE_INTERVAL
|
2019-01-06 19:38:23 +01:00
|
|
|
from esphomeyaml.cpp_generator import Pvariable, add, variable
|
|
|
|
from esphomeyaml.cpp_helpers import setup_component
|
|
|
|
from esphomeyaml.cpp_types import App, Application, PollingComponent
|
2018-08-13 19:11:33 +02:00
|
|
|
|
|
|
|
DEPENDENCIES = ['i2c']
|
|
|
|
|
2018-11-12 23:30:31 +01:00
|
|
|
MakeMS5611Sensor = Application.struct('MakeMS5611Sensor')
|
|
|
|
MS5611Component = sensor.sensor_ns.class_('MS5611Component', PollingComponent, i2c.I2CDevice)
|
|
|
|
MS5611TemperatureSensor = sensor.sensor_ns.class_('MS5611TemperatureSensor',
|
|
|
|
sensor.EmptyPollingParentSensor)
|
|
|
|
MS5611PressureSensor = sensor.sensor_ns.class_('MS5611PressureSensor',
|
|
|
|
sensor.EmptyPollingParentSensor)
|
2018-08-13 19:11:33 +02:00
|
|
|
|
|
|
|
PLATFORM_SCHEMA = sensor.PLATFORM_SCHEMA.extend({
|
2018-11-12 23:30:31 +01:00
|
|
|
cv.GenerateID(): cv.declare_variable_id(MS5611Component),
|
2018-08-13 19:11:33 +02:00
|
|
|
cv.GenerateID(CONF_MAKE_ID): cv.declare_variable_id(MakeMS5611Sensor),
|
|
|
|
vol.Optional(CONF_ADDRESS): cv.i2c_address,
|
2018-11-12 23:30:31 +01:00
|
|
|
vol.Required(CONF_TEMPERATURE): cv.nameable(sensor.SENSOR_SCHEMA.extend({
|
|
|
|
cv.GenerateID(): cv.declare_variable_id(MS5611TemperatureSensor),
|
|
|
|
})),
|
|
|
|
vol.Required(CONF_PRESSURE): cv.nameable(sensor.SENSOR_SCHEMA.extend({
|
|
|
|
cv.GenerateID(): cv.declare_variable_id(MS5611PressureSensor),
|
|
|
|
})),
|
2018-08-24 22:44:15 +02:00
|
|
|
vol.Optional(CONF_UPDATE_INTERVAL): cv.update_interval,
|
2018-11-12 23:30:31 +01:00
|
|
|
}).extend(cv.COMPONENT_SCHEMA.schema)
|
2018-08-13 19:11:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def to_code(config):
|
|
|
|
rhs = App.make_ms5611_sensor(config[CONF_TEMPERATURE][CONF_NAME],
|
|
|
|
config[CONF_PRESSURE][CONF_NAME],
|
|
|
|
config.get(CONF_UPDATE_INTERVAL))
|
|
|
|
make = variable(config[CONF_MAKE_ID], rhs)
|
2018-11-12 23:30:31 +01:00
|
|
|
ms5611 = make.Pms5611
|
|
|
|
Pvariable(config[CONF_ID], ms5611)
|
2018-08-13 19:11:33 +02:00
|
|
|
|
|
|
|
if CONF_ADDRESS in config:
|
2018-11-12 23:30:31 +01:00
|
|
|
add(ms5611.set_address(config[CONF_ADDRESS]))
|
2018-08-13 19:11:33 +02:00
|
|
|
|
2018-11-12 23:30:31 +01:00
|
|
|
sensor.setup_sensor(ms5611.Pget_temperature_sensor(), make.Pmqtt_temperature,
|
2018-08-13 19:11:33 +02:00
|
|
|
config[CONF_TEMPERATURE])
|
2018-11-12 23:30:31 +01:00
|
|
|
sensor.setup_sensor(ms5611.Pget_pressure_sensor(), make.Pmqtt_pressure,
|
2018-08-13 19:11:33 +02:00
|
|
|
config[CONF_PRESSURE])
|
2018-11-12 23:30:31 +01:00
|
|
|
setup_component(ms5611, config)
|
2018-08-13 19:11:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
BUILD_FLAGS = '-DUSE_MS5611'
|
2018-11-03 14:08:31 +01:00
|
|
|
|
|
|
|
|
|
|
|
def to_hass_config(data, config):
|
|
|
|
return [sensor.core_to_hass_config(data, config[CONF_TEMPERATURE]),
|
|
|
|
sensor.core_to_hass_config(data, config[CONF_PRESSURE])]
|