2015-11-25 16:21:11 +00:00
|
|
|
"""
|
|
|
|
Support for myStrom switches.
|
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/switch.mystrom/
|
|
|
|
"""
|
|
|
|
import logging
|
2016-02-19 05:27:50 +00:00
|
|
|
|
2015-11-25 16:21:11 +00:00
|
|
|
import requests
|
|
|
|
|
|
|
|
from homeassistant.components.switch import SwitchDevice
|
|
|
|
|
|
|
|
DEFAULT_NAME = 'myStrom Switch'
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Find and return myStrom switch."""
|
2015-11-26 15:37:00 +00:00
|
|
|
host = config.get('host')
|
2015-11-25 16:21:11 +00:00
|
|
|
|
2015-11-26 15:37:00 +00:00
|
|
|
if host is None:
|
|
|
|
_LOGGER.error('Missing required variable: host')
|
2015-11-25 16:21:11 +00:00
|
|
|
return False
|
|
|
|
|
2015-11-26 15:37:00 +00:00
|
|
|
resource = 'http://{}'.format(host)
|
|
|
|
|
2015-11-25 16:21:11 +00:00
|
|
|
try:
|
|
|
|
requests.get(resource, timeout=10)
|
|
|
|
except requests.exceptions.ConnectionError:
|
2015-11-26 15:37:00 +00:00
|
|
|
_LOGGER.error("No route to device %s. "
|
|
|
|
"Please check the IP address in the configuration file",
|
|
|
|
host)
|
2015-11-25 16:21:11 +00:00
|
|
|
return False
|
|
|
|
|
|
|
|
add_devices([MyStromSwitch(
|
|
|
|
config.get('name', DEFAULT_NAME),
|
2015-11-26 15:37:00 +00:00
|
|
|
resource)])
|
2015-11-25 16:21:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MyStromSwitch(SwitchDevice):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Representation of a myStrom switch."""
|
|
|
|
|
2015-11-25 16:21:11 +00:00
|
|
|
def __init__(self, name, resource):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Initialize the myStrom switch."""
|
2015-11-25 17:07:29 +00:00
|
|
|
self._state = False
|
2015-11-25 16:21:11 +00:00
|
|
|
self._name = name
|
|
|
|
self._resource = resource
|
|
|
|
self.consumption = 0
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Return the name of the switch."""
|
2015-11-25 16:21:11 +00:00
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Return true if switch is on."""
|
2015-11-25 16:21:11 +00:00
|
|
|
return self._state
|
|
|
|
|
|
|
|
@property
|
|
|
|
def current_power_mwh(self):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Return the urrent power consumption in mWh."""
|
2015-11-25 16:21:11 +00:00
|
|
|
return self.consumption
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Turn the switch on."""
|
2015-11-25 17:07:29 +00:00
|
|
|
try:
|
|
|
|
request = requests.get('{}/relay'.format(self._resource),
|
|
|
|
params={'state': '1'},
|
|
|
|
timeout=10)
|
|
|
|
if request.status_code == 200:
|
|
|
|
self._state = True
|
|
|
|
except requests.exceptions.ConnectionError:
|
2015-11-25 16:21:11 +00:00
|
|
|
_LOGGER.error("Can't turn on %s. Is device offline?",
|
|
|
|
self._resource)
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Turn the switch off."""
|
2015-11-25 17:07:29 +00:00
|
|
|
try:
|
|
|
|
request = requests.get('{}/relay'.format(self._resource),
|
|
|
|
params={'state': '0'},
|
|
|
|
timeout=10)
|
|
|
|
if request.status_code == 200:
|
|
|
|
self._state = False
|
|
|
|
except requests.exceptions.ConnectionError:
|
|
|
|
_LOGGER.error("Can't turn on %s. Is device offline?",
|
2015-11-25 16:21:11 +00:00
|
|
|
self._resource)
|
|
|
|
|
|
|
|
def update(self):
|
2016-03-08 12:35:39 +00:00
|
|
|
"""Get the latest data from REST API and update the state."""
|
2015-11-25 16:21:11 +00:00
|
|
|
try:
|
|
|
|
request = requests.get('{}/report'.format(self._resource),
|
|
|
|
timeout=10)
|
2015-11-29 21:49:05 +00:00
|
|
|
data = request.json()
|
|
|
|
self._state = bool(data['relay'])
|
|
|
|
self.consumption = data['power']
|
2015-11-25 16:21:11 +00:00
|
|
|
except requests.exceptions.ConnectionError:
|
|
|
|
_LOGGER.error("No route to device '%s'. Is device offline?",
|
|
|
|
self._resource)
|