core/homeassistant/components/myq/cover.py

114 lines
3.1 KiB
Python
Raw Normal View History

"""Support for MyQ-Enabled Garage Doors."""
import logging
from pymyq import login
from pymyq.errors import MyQError
import voluptuous as vol
from homeassistant.components.cover import (
2019-07-31 19:25:30 +00:00
PLATFORM_SCHEMA,
SUPPORT_CLOSE,
SUPPORT_OPEN,
CoverDevice,
)
from homeassistant.const import (
2019-07-31 19:25:30 +00:00
CONF_PASSWORD,
CONF_TYPE,
CONF_USERNAME,
STATE_CLOSED,
STATE_CLOSING,
STATE_OPEN,
STATE_OPENING,
)
from homeassistant.helpers import aiohttp_client, config_validation as cv
_LOGGER = logging.getLogger(__name__)
MYQ_TO_HASS = {
2019-07-31 19:25:30 +00:00
"closed": STATE_CLOSED,
"closing": STATE_CLOSING,
"open": STATE_OPEN,
"opening": STATE_OPENING,
}
2019-07-31 19:25:30 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
{
vol.Required(CONF_USERNAME): cv.string,
vol.Required(CONF_PASSWORD): cv.string,
# This parameter is no longer used; keeping it to avoid a breaking change in
# a hotfix, but in a future main release, this should be removed:
vol.Optional(CONF_TYPE): cv.string,
2019-07-31 19:25:30 +00:00
}
)
2019-07-31 19:25:30 +00:00
async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
"""Set up the platform."""
websession = aiohttp_client.async_get_clientsession(hass)
username = config[CONF_USERNAME]
password = config[CONF_PASSWORD]
try:
myq = await login(username, password, websession)
except MyQError as err:
2019-07-31 19:25:30 +00:00
_LOGGER.error("There was an error while logging in: %s", err)
return
async_add_entities([MyQDevice(device) for device in myq.covers.values()], True)
class MyQDevice(CoverDevice):
"""Representation of a MyQ cover."""
def __init__(self, device):
"""Initialize with API object, device id."""
self._device = device
@property
def device_class(self):
"""Define this cover as a garage door."""
2019-07-31 19:25:30 +00:00
return "garage"
@property
def name(self):
"""Return the name of the garage door if any."""
return self._device.name
@property
def is_closed(self):
"""Return true if cover is closed, else False."""
return MYQ_TO_HASS.get(self._device.state) == STATE_CLOSED
@property
def is_closing(self):
"""Return if the cover is closing or not."""
return MYQ_TO_HASS.get(self._device.state) == STATE_CLOSING
@property
def is_opening(self):
"""Return if the cover is opening or not."""
return MYQ_TO_HASS.get(self._device.state) == STATE_OPENING
@property
def supported_features(self):
"""Flag supported features."""
return SUPPORT_OPEN | SUPPORT_CLOSE
2018-08-31 14:47:37 +00:00
@property
def unique_id(self):
"""Return a unique, Home Assistant friendly identifier for this entity."""
return self._device.device_id
async def async_close_cover(self, **kwargs):
"""Issue close command to cover."""
await self._device.close()
async def async_open_cover(self, **kwargs):
"""Issue open command to cover."""
await self._device.open()
2018-08-31 14:47:37 +00:00
async def async_update(self):
"""Update status of cover."""
await self._device.update()