2019-01-05 14:08:25 -05:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from esphomeyaml import pins
|
|
|
|
from esphomeyaml.components import sensor, spi
|
|
|
|
from esphomeyaml.components.spi import SPIComponent
|
2019-01-29 17:29:21 +01:00
|
|
|
import esphomeyaml.config_validation as cv
|
|
|
|
from esphomeyaml.const import CONF_CS_PIN, CONF_ID, CONF_NAME, CONF_SPI_ID, CONF_UPDATE_INTERVAL
|
|
|
|
from esphomeyaml.cpp_generator import Pvariable, get_variable
|
2019-01-05 14:08:25 -05:00
|
|
|
from esphomeyaml.cpp_helpers import gpio_output_pin_expression, setup_component
|
2019-01-29 17:29:21 +01:00
|
|
|
from esphomeyaml.cpp_types import App
|
2019-01-05 14:08:25 -05:00
|
|
|
|
|
|
|
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_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))
|
2019-01-29 17:29:21 +01:00
|
|
|
max31855 = Pvariable(config[CONF_ID], rhs)
|
|
|
|
sensor.setup_sensor(max31855, config)
|
2019-01-05 14:08:25 -05:00
|
|
|
setup_component(max31855, config)
|
|
|
|
|
|
|
|
|
|
|
|
BUILD_FLAGS = '-DUSE_MAX31855_SENSOR'
|
|
|
|
|
|
|
|
|
|
|
|
def to_hass_config(data, config):
|
|
|
|
return sensor.core_to_hass_config(data, config)
|