mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 11:17:21 +00:00
Minor changes to the config validation (#17808)
This commit is contained in:
parent
cfbd84f450
commit
8a4c78b69f
@ -5,33 +5,41 @@ For more details about this platform, please refer to the documentation at
|
|||||||
https://home-assistant.io/components/sensor.sma/
|
https://home-assistant.io/components/sensor.sma/
|
||||||
"""
|
"""
|
||||||
import asyncio
|
import asyncio
|
||||||
import logging
|
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
|
import logging
|
||||||
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
EVENT_HOMEASSISTANT_STOP, CONF_HOST, CONF_PASSWORD, CONF_SCAN_INTERVAL,
|
CONF_HOST, CONF_PASSWORD, CONF_SCAN_INTERVAL, CONF_SSL,
|
||||||
CONF_SSL)
|
EVENT_HOMEASSISTANT_STOP)
|
||||||
from homeassistant.helpers.event import async_track_time_interval
|
|
||||||
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
|
from homeassistant.helpers.event import async_track_time_interval
|
||||||
|
|
||||||
REQUIREMENTS = ['pysma==0.2']
|
REQUIREMENTS = ['pysma==0.2']
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
CONF_GROUP = 'group'
|
|
||||||
CONF_SENSORS = 'sensors'
|
|
||||||
CONF_CUSTOM = 'custom'
|
CONF_CUSTOM = 'custom'
|
||||||
|
CONF_FACTOR = 'factor'
|
||||||
|
CONF_GROUP = 'group'
|
||||||
|
CONF_KEY = 'key'
|
||||||
|
CONF_SENSORS = 'sensors'
|
||||||
|
CONF_UNIT = 'unit'
|
||||||
|
|
||||||
GROUP_INSTALLER = 'installer'
|
GROUP_INSTALLER = 'installer'
|
||||||
GROUP_USER = 'user'
|
GROUP_USER = 'user'
|
||||||
GROUPS = [GROUP_USER, GROUP_INSTALLER]
|
GROUPS = [GROUP_USER, GROUP_INSTALLER]
|
||||||
SENSOR_OPTIONS = ['current_consumption', 'current_power', 'total_consumption',
|
|
||||||
'total_yield']
|
SENSOR_OPTIONS = [
|
||||||
|
'current_consumption',
|
||||||
|
'current_power',
|
||||||
|
'total_consumption',
|
||||||
|
'total_yield',
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
def _check_sensor_schema(conf):
|
def _check_sensor_schema(conf):
|
||||||
@ -48,23 +56,26 @@ def _check_sensor_schema(conf):
|
|||||||
return conf
|
return conf
|
||||||
|
|
||||||
|
|
||||||
|
CUSTOM_SCHEMA = vol.Any({
|
||||||
|
vol.Required(CONF_KEY):
|
||||||
|
vol.All(cv.string, vol.Length(min=13, max=13)),
|
||||||
|
vol.Required(CONF_UNIT): cv.string,
|
||||||
|
vol.Optional(CONF_FACTOR, default=1): vol.Coerce(float),
|
||||||
|
})
|
||||||
|
|
||||||
PLATFORM_SCHEMA = vol.All(PLATFORM_SCHEMA.extend({
|
PLATFORM_SCHEMA = vol.All(PLATFORM_SCHEMA.extend({
|
||||||
vol.Required(CONF_HOST): str,
|
vol.Required(CONF_HOST): cv.string,
|
||||||
vol.Optional(CONF_SSL, default=False): cv.boolean,
|
vol.Optional(CONF_SSL, default=False): cv.boolean,
|
||||||
vol.Required(CONF_PASSWORD): str,
|
vol.Required(CONF_PASSWORD): cv.string,
|
||||||
vol.Optional(CONF_GROUP, default=GROUPS[0]): vol.In(GROUPS),
|
vol.Optional(CONF_GROUP, default=GROUPS[0]): vol.In(GROUPS),
|
||||||
vol.Required(CONF_SENSORS): vol.Schema({cv.slug: cv.ensure_list}),
|
vol.Required(CONF_SENSORS): vol.Schema({cv.slug: cv.ensure_list}),
|
||||||
vol.Optional(CONF_CUSTOM, default={}): vol.Schema({
|
vol.Optional(CONF_CUSTOM, default={}):
|
||||||
cv.slug: {
|
vol.Schema({cv.slug: CUSTOM_SCHEMA}),
|
||||||
vol.Required('key'): vol.All(str, vol.Length(min=13, max=13)),
|
|
||||||
vol.Required('unit'): str,
|
|
||||||
vol.Optional('factor', default=1): vol.Coerce(float),
|
|
||||||
}})
|
|
||||||
}, extra=vol.PREVENT_EXTRA), _check_sensor_schema)
|
}, extra=vol.PREVENT_EXTRA), _check_sensor_schema)
|
||||||
|
|
||||||
|
|
||||||
async def async_setup_platform(hass, config, async_add_entities,
|
async def async_setup_platform(
|
||||||
discovery_info=None):
|
hass, config, async_add_entities, discovery_info=None):
|
||||||
"""Set up SMA WebConnect sensor."""
|
"""Set up SMA WebConnect sensor."""
|
||||||
import pysma
|
import pysma
|
||||||
|
|
||||||
@ -146,7 +157,7 @@ async def async_setup_platform(hass, config, async_add_entities,
|
|||||||
|
|
||||||
|
|
||||||
class SMAsensor(Entity):
|
class SMAsensor(Entity):
|
||||||
"""Representation of a Bitcoin sensor."""
|
"""Representation of a SMA sensor."""
|
||||||
|
|
||||||
def __init__(self, sensor_name, attr, sensor_defs):
|
def __init__(self, sensor_name, attr, sensor_defs):
|
||||||
"""Initialize the sensor."""
|
"""Initialize the sensor."""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user