Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
DOMAIN = "input_boolean"
ENTITY_ID_FORMAT = DOMAIN + ".{}"
_LOGGER = logging.getLogger(__name__)
CONF_INITIAL = "initial"
CONFIG_SCHEMA = vol.Schema(
{
DOMAIN: cv.schema_with_slug_keys(
vol.Any(
{
vol.Optional(CONF_NAME): cv.string,
vol.Optional(CONF_INITIAL): cv.boolean,
vol.Optional(CONF_ICON): cv.icon,
},
None,
)
)
},
extra=vol.ALLOW_EXTRA,
)
RELOAD_SERVICE_SCHEMA = vol.Schema({})
@bind_hass
def is_on(hass, entity_id):
"""Test if input_boolean is True."""
return hass.states.is_state(entity_id, STATE_ON)
'pmd': '',
'restafval': '',
}
COLLECTOR_WASTE_ID = {}
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_RESOURCES, default=[]): cv.ensure_list,
vol.Required(CONF_POSTCODE, default='1111AA'): cv.string,
vol.Required(CONF_STREET_NUMBER, default='1'): cv.string,
vol.Optional(CONF_WASTE_COLLECTOR, default='Cure'): cv.string,
vol.Optional(CONF_DATE_FORMAT, default='%d-%m-%Y'): cv.string,
vol.Optional(CONF_TODAY_TOMORROW, default=False): cv.boolean,
vol.Optional(CONF_DATE_ONLY, default=False): cv.boolean,
vol.Optional(CONF_NAME_PREFIX, default=True): cv.boolean,
vol.Optional(CONF_BUILT_IN_ICONS, default=False): cv.boolean,
})
def setup_platform(hass, config, add_entities, discovery_info=None):
_LOGGER.debug('Setup Rest API retriever')
postcode = config.get(CONF_POSTCODE)
street_number = config.get(CONF_STREET_NUMBER)
waste_collector = config.get(CONF_WASTE_COLLECTOR).lower()
date_format = config.get(CONF_DATE_FORMAT)
sensor_today = config.get(CONF_TODAY_TOMORROW)
date_only = config.get(CONF_DATE_ONLY)
name_prefix = config.get(CONF_NAME_PREFIX)
built_in_icons = config.get(CONF_BUILT_IN_ICONS)
try:
["first", "latest", "all"]
),
}
)
CONFIG_SCHEMA = vol.Schema(
{
DOMAIN: vol.Schema(
{
vol.Required(CONF_HOST): cv.string,
vol.Required(CONF_USERNAME): cv.string,
vol.Exclusive(CONF_API_KEY, "auth"): cv.string,
vol.Exclusive(CONF_PASSWORD, "auth"): cv.string,
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
vol.Optional(CONF_URLBASE, default=DEFAULT_URLBASE): urlbase,
vol.Optional(CONF_SSL, default=DEFAULT_SSL): cv.boolean,
},
cv.has_at_least_one_key("auth"),
)
},
extra=vol.ALLOW_EXTRA,
)
def setup(hass, config):
"""Set up the Ombi component platform."""
ombi = pyombi.Ombi(
ssl=config[DOMAIN][CONF_SSL],
host=config[DOMAIN][CONF_HOST],
port=config[DOMAIN][CONF_PORT],
urlbase=config[DOMAIN][CONF_URLBASE],
__version__ = '0.2.3'
_LOGGER = logging.getLogger(__name__)
CONF_DAYS = 'days'
CONF_URLBASE = 'urlbase'
CONF_THEATERS = 'theaters'
CONF_MAX = 'max'
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_API_KEY): cv.string,
vol.Optional(CONF_DAYS, default='60'): cv.string,
vol.Optional(CONF_HOST, default='localhost'): cv.string,
vol.Optional(CONF_PORT, default=7878): cv.port,
vol.Optional(CONF_SSL, default=False): cv.boolean,
vol.Optional(CONF_URLBASE, default=''): cv.string,
vol.Optional(CONF_THEATERS, default=True): cv.boolean,
vol.Optional(CONF_MAX, default=5): cv.string,
})
def setup_platform(hass, config, add_devices, discovery_info=None):
add_devices([RadarrUpcomingMediaSensor(hass, config)], True)
class RadarrUpcomingMediaSensor(Entity):
def __init__(self, hass, conf):
from pytz import timezone
self._tz = timezone(str(hass.config.time_zone))
self.now = str(get_date(self._tz))
SERVICE_ALEXA_TTS = 'alexa_tts'
ATTR_MESSAGE = 'message'
ALEXA_TTS_SCHEMA = MEDIA_PLAYER_SCHEMA.extend({
vol.Required(ATTR_MESSAGE): cv.string,
})
CONF_DEBUG = 'debug'
CONF_INCLUDE_DEVICES = 'include_devices'
CONF_EXCLUDE_DEVICES = 'exclude_devices'
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_EMAIL): cv.string,
vol.Required(CONF_PASSWORD): cv.string,
vol.Required(CONF_URL): cv.string,
vol.Optional(CONF_DEBUG, default=False): cv.boolean,
vol.Optional(CONF_INCLUDE_DEVICES, default=[]):
vol.All(cv.ensure_list, [cv.string]),
vol.Optional(CONF_EXCLUDE_DEVICES, default=[]):
vol.All(cv.ensure_list, [cv.string]),
})
def request_configuration(hass, config, setup_platform_callback,
status=None):
"""Request configuration steps from the user."""
configurator = hass.components.configurator
async def configuration_callback(callback_data):
"""Handle the submitted configuration."""
hass.async_add_job(setup_platform_callback, callback_data)
DEFAULT_NAME = 'HA Dockermon'
CONTAINTER_NAME = '{} {}'
CONF_CONTAINERS = 'containers'
ATTR_CONTAINER = 'container'
ATTR_STATUS = 'status'
ATTR_IMAGE = 'image'
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_HOST): cv.string,
vol.Required(CONF_PORT, default=8126): cv.port,
vol.Optional(CONF_NAME): cv.string,
vol.Optional(CONF_USERNAME): cv.string,
vol.Optional(CONF_PASSWORD): cv.string,
vol.Optional(CONF_SSL, default=False): cv.boolean,
vol.Optional(CONF_VERIFY_SSL, default=False): cv.boolean,
vol.Optional(CONF_CONTAINERS, default=None):
vol.All(cv.ensure_list, [cv.string]),
})
async def async_setup_platform(hass, config, async_add_entities,
discovery_info=None):
"""Set up the device."""
from pydockermon.api import API
host = config[CONF_HOST]
port = config[CONF_PORT]
username = config.get(CONF_USERNAME)
password = config.get(CONF_PASSWORD)
ssl = config[CONF_SSL]
ATTR_USER = "username"
SCAN_INTERVAL = timedelta(minutes=1)
PLATFORM_NAME = "authenticated"
LOGFILE = "home-assistant.log"
OUTFILE = ".ip_authenticated.yaml"
PROVIDERS = ["ipapi", "extreme", "ipvigilante"]
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
{
vol.Optional(CONF_PROVIDER, default="ipapi"): vol.In(PROVIDERS),
vol.Optional(CONF_LOG_LOCATION, default=""): cv.string,
vol.Optional(CONF_NOTIFY, default=True): cv.boolean,
vol.Optional(CONF_EXCLUDE, default=[]): vol.All(cv.ensure_list, [cv.string]),
}
)
PROVIDERS = {}
def register_provider(classname):
"""Decorator used to register providers."""
PROVIDERS[classname.name] = classname
return classname
def setup_platform(hass, config, add_devices, discovery_info=None):
"""Create the sensor"""
notify = config.get(CONF_NOTIFY)
):
cleaning = self._templates[
CONF_CLEANING_TEMPLATE
].async_render_with_possible_json_value(msg.payload, error_value=None)
if cleaning:
self._cleaning = cv.boolean(cleaning)
if (
msg.topic == self._state_topics[CONF_DOCKED_TOPIC]
and self._templates[CONF_DOCKED_TEMPLATE]
):
docked = self._templates[
CONF_DOCKED_TEMPLATE
].async_render_with_possible_json_value(msg.payload, error_value=None)
if docked:
self._docked = cv.boolean(docked)
if (
msg.topic == self._state_topics[CONF_ERROR_TOPIC]
and self._templates[CONF_ERROR_TEMPLATE]
):
error = self._templates[
CONF_ERROR_TEMPLATE
].async_render_with_possible_json_value(msg.payload, error_value=None)
if error is not None:
self._error = cv.string(error)
if self._docked:
if self._charging:
self._status = "Docked & Charging"
else:
self._status = "Docked"
'download_rate': ['DownloadRate', 'Speed', 'MB/s'],
'download_size': ['DownloadedSizeMB', 'Size', 'MB'],
'free_disk_space': ['FreeDiskSpaceMB', 'Disk Free', 'MB'],
'post_paused': ['PostPaused', 'Post Processing Paused', None],
'remaining_size': ['RemainingSizeMB', 'Queue Size', 'MB'],
'uptime': ['UpTimeSec', 'Uptime', 'min'],
}
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_HOST): cv.string,
vol.Optional(CONF_MONITORED_VARIABLES, default=['download_rate']):
vol.All(cv.ensure_list, [vol.In(SENSOR_TYPES)]),
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
vol.Optional(CONF_PASSWORD): cv.string,
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
vol.Optional(CONF_SSL, default=False): cv.boolean,
vol.Optional(CONF_USERNAME): cv.string,
})
def setup_platform(hass, config, add_entities, discovery_info=None):
"""Set up the NZBGet sensors."""
host = config.get(CONF_HOST)
port = config.get(CONF_PORT)
ssl = 's' if config.get(CONF_SSL) else ''
name = config.get(CONF_NAME)
username = config.get(CONF_USERNAME)
password = config.get(CONF_PASSWORD)
monitored_types = config.get(CONF_MONITORED_VARIABLES)
url = "http{}://{}:{}/jsonrpc".format(ssl, host, port)
CONFIG_SCHEMA = vol.Schema(
{
DOMAIN: vol.All(
ensure_list,
[
vol.Schema(
{
vol.Required(CONF_ADDRESS): cv.string,
vol.Required(CONF_IDENTIFIER): cv.string,
vol.Required(CONF_PROTOCOL): vol.In(
[PROTOCOL_DMAP, PROTOCOL_MRP]
),
vol.Required(CONF_CREDENTIALS): CREDENTIALS_SCHEMA,
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
vol.Optional(CONF_START_OFF, default=False): cv.boolean,
}
)
],
)
},
extra=vol.ALLOW_EXTRA,
)
async def async_setup(hass, config):
"""Set up the Apple TV integration."""
if DOMAIN not in config:
return True
for conf in config[DOMAIN]:
hass.async_create_task(