From 38c24fd100ead2b39d7679f4012e7af1567da7d6 Mon Sep 17 00:00:00 2001 From: sherbang Date: Sat, 5 Jan 2019 14:08:25 -0500 Subject: [PATCH] Add support for MAX31855 sensor (#258) * Add support for MAX31855 sensor * Update for latest core changes * Update max31855.py --- esphomeyaml/components/sensor/max31855.py | 43 +++++++++++++++++++++++ tests/test1.yaml | 4 +++ 2 files changed, 47 insertions(+) create mode 100644 esphomeyaml/components/sensor/max31855.py diff --git a/esphomeyaml/components/sensor/max31855.py b/esphomeyaml/components/sensor/max31855.py new file mode 100644 index 0000000000..d656445cf1 --- /dev/null +++ b/esphomeyaml/components/sensor/max31855.py @@ -0,0 +1,43 @@ +import voluptuous as vol + +import esphomeyaml.config_validation as cv +from esphomeyaml import pins +from esphomeyaml.components import sensor, spi +from esphomeyaml.components.spi import SPIComponent +from esphomeyaml.const import CONF_CS_PIN, CONF_MAKE_ID, CONF_NAME, CONF_SPI_ID, \ + CONF_UPDATE_INTERVAL +from esphomeyaml.cpp_helpers import gpio_output_pin_expression, setup_component +from esphomeyaml.cpp_generator import get_variable, variable +from esphomeyaml.cpp_types import Application, App + +MakeMAX31855Sensor = Application.struct('MakeMAX31855Sensor') +MAX31855Sensor = sensor.sensor_ns.class_('MAX31855Sensor', sensor.PollingSensorComponent, + spi.SPIDevice) + +PLATFORM_SCHEMA = cv.nameable(sensor.SENSOR_PLATFORM_SCHEMA.extend({ + cv.GenerateID(): cv.declare_variable_id(MAX31855Sensor), + cv.GenerateID(CONF_MAKE_ID): cv.declare_variable_id(MakeMAX31855Sensor), + cv.GenerateID(CONF_SPI_ID): cv.use_variable_id(SPIComponent), + vol.Required(CONF_CS_PIN): pins.gpio_output_pin_schema, + vol.Optional(CONF_UPDATE_INTERVAL): cv.update_interval, +}).extend(cv.COMPONENT_SCHEMA.schema)) + + +def to_code(config): + for spi_ in get_variable(config[CONF_SPI_ID]): + yield + for cs in gpio_output_pin_expression(config[CONF_CS_PIN]): + yield + rhs = App.make_max31855_sensor(config[CONF_NAME], spi_, cs, + config.get(CONF_UPDATE_INTERVAL)) + make = variable(config[CONF_MAKE_ID], rhs) + max31855 = make.Pmax31855 + sensor.setup_sensor(max31855, make.Pmqtt, config) + setup_component(max31855, config) + + +BUILD_FLAGS = '-DUSE_MAX31855_SENSOR' + + +def to_hass_config(data, config): + return sensor.core_to_hass_config(data, config) diff --git a/tests/test1.yaml b/tests/test1.yaml index 64ae7cd28d..cd60299dd7 100644 --- a/tests/test1.yaml +++ b/tests/test1.yaml @@ -371,6 +371,10 @@ sensor: name: "Living Room Temperature" cs_pin: GPIO23 update_interval: 15s + - platform: max31855 + name: "Den Temperature" + cs_pin: GPIO23 + update_interval: 15s - platform: mhz19 co2: name: "MH-Z19 CO2 Value"