2015-07-21 03:16:54 +00:00
|
|
|
"""
|
|
|
|
homeassistant.components.switch.edimax
|
2015-08-06 16:44:48 +00:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-07-21 03:16:54 +00:00
|
|
|
Support for Edimax switches.
|
2015-08-06 16:44:48 +00:00
|
|
|
|
2015-10-21 20:54:42 +00:00
|
|
|
For more details about this platform, please refer to the documentation at
|
2015-11-09 12:12:18 +00:00
|
|
|
https://home-assistant.io/components/switch.edimax/
|
2015-07-21 03:16:54 +00:00
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
|
2015-07-30 07:10:16 +00:00
|
|
|
from homeassistant.helpers import validate_config
|
|
|
|
from homeassistant.components.switch import SwitchDevice, DOMAIN
|
2015-07-31 04:05:00 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_USERNAME, CONF_PASSWORD,\
|
|
|
|
CONF_NAME
|
2015-07-21 03:16:54 +00:00
|
|
|
|
2015-07-30 07:10:16 +00:00
|
|
|
# constants
|
|
|
|
DEFAULT_USERNAME = 'admin'
|
|
|
|
DEFAULT_PASSWORD = '1234'
|
|
|
|
DEVICE_DEFAULT_NAME = 'Edimax Smart Plug'
|
2015-09-09 02:49:27 +00:00
|
|
|
REQUIREMENTS = ['https://github.com/rkabadi/pyedimax/archive/'
|
|
|
|
'365301ce3ff26129a7910c501ead09ea625f3700.zip#pyedimax==0.1']
|
2015-07-30 07:10:16 +00:00
|
|
|
|
|
|
|
# setup logger
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2015-07-26 01:46:47 +00:00
|
|
|
|
2015-07-31 04:05:00 +00:00
|
|
|
|
2015-07-21 03:16:54 +00:00
|
|
|
# pylint: disable=unused-argument
|
|
|
|
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
|
|
|
""" Find and return Edimax Smart Plugs. """
|
|
|
|
try:
|
|
|
|
# pylint: disable=no-name-in-module, import-error
|
2015-07-29 07:24:42 +00:00
|
|
|
from pyedimax.smartplug import SmartPlug
|
2015-07-21 03:16:54 +00:00
|
|
|
except ImportError:
|
2015-07-30 07:10:16 +00:00
|
|
|
_LOGGER.error('Failed to import pyedimax')
|
|
|
|
return False
|
2015-07-21 03:16:54 +00:00
|
|
|
|
2015-07-30 07:10:16 +00:00
|
|
|
# pylint: disable=global-statement
|
|
|
|
# check for required values in configuration file
|
|
|
|
if not validate_config({DOMAIN: config},
|
|
|
|
{DOMAIN: [CONF_HOST]},
|
|
|
|
_LOGGER):
|
|
|
|
return False
|
2015-07-21 03:16:54 +00:00
|
|
|
|
2015-07-21 06:27:25 +00:00
|
|
|
host = config.get(CONF_HOST)
|
2015-07-30 07:10:16 +00:00
|
|
|
auth = (config.get(CONF_USERNAME, DEFAULT_USERNAME),
|
|
|
|
config.get(CONF_PASSWORD, DEFAULT_PASSWORD))
|
|
|
|
name = config.get(CONF_NAME, DEVICE_DEFAULT_NAME)
|
2015-07-21 06:27:25 +00:00
|
|
|
|
2015-07-30 07:10:16 +00:00
|
|
|
add_devices_callback([SmartPlugSwitch(SmartPlug(host, auth), name)])
|
2015-07-21 03:16:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
class SmartPlugSwitch(SwitchDevice):
|
2015-08-06 16:44:48 +00:00
|
|
|
""" Represents an Edimax Smart Plug switch. """
|
2015-07-30 07:10:16 +00:00
|
|
|
def __init__(self, smartplug, name):
|
2015-07-21 03:16:54 +00:00
|
|
|
self.smartplug = smartplug
|
2015-07-30 07:10:16 +00:00
|
|
|
self._name = name
|
2015-07-21 03:16:54 +00:00
|
|
|
|
2015-07-21 06:27:25 +00:00
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
""" Returns the name of the Smart Plug, if any. """
|
2015-07-30 07:10:16 +00:00
|
|
|
return self._name
|
2015-07-21 06:27:25 +00:00
|
|
|
|
2015-07-26 01:46:47 +00:00
|
|
|
@property
|
|
|
|
def current_power_mwh(self):
|
2015-09-07 17:39:16 +00:00
|
|
|
""" Current power usage in mWh. """
|
2015-07-26 01:46:47 +00:00
|
|
|
try:
|
|
|
|
return float(self.smartplug.now_power) / 1000000.0
|
|
|
|
except ValueError:
|
|
|
|
return None
|
|
|
|
|
|
|
|
@property
|
|
|
|
def today_power_mw(self):
|
2015-09-07 17:39:16 +00:00
|
|
|
""" Today total power usage in mW. """
|
2015-07-26 01:46:47 +00:00
|
|
|
try:
|
|
|
|
return float(self.smartplug.now_energy_day) / 1000.0
|
|
|
|
except ValueError:
|
|
|
|
return None
|
|
|
|
|
2015-07-21 03:16:54 +00:00
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
""" True if switch is on. """
|
2015-07-21 06:27:25 +00:00
|
|
|
return self.smartplug.state == 'ON'
|
2015-07-21 03:16:54 +00:00
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
""" Turns the switch on. """
|
|
|
|
self.smartplug.state = 'ON'
|
|
|
|
|
|
|
|
def turn_off(self):
|
|
|
|
""" Turns the switch off. """
|
2015-07-26 01:46:47 +00:00
|
|
|
self.smartplug.state = 'OFF'
|