forked from home-assistant/core
- Added support for getting power on SP2101W devices (returns None on SP1101W)
This commit is contained in:
@@ -53,6 +53,7 @@ omit =
|
|||||||
homeassistant/components/sensor/systemmonitor.py
|
homeassistant/components/sensor/systemmonitor.py
|
||||||
homeassistant/components/sensor/time_date.py
|
homeassistant/components/sensor/time_date.py
|
||||||
homeassistant/components/sensor/transmission.py
|
homeassistant/components/sensor/transmission.py
|
||||||
|
homeassistant/components/sensor/edimax.py
|
||||||
homeassistant/components/switch/hikvisioncam.py
|
homeassistant/components/switch/hikvisioncam.py
|
||||||
homeassistant/components/switch/wemo.py
|
homeassistant/components/switch/wemo.py
|
||||||
homeassistant/components/thermostat/nest.py
|
homeassistant/components/thermostat/nest.py
|
||||||
|
@@ -9,6 +9,7 @@ import logging
|
|||||||
from homeassistant.components.switch import SwitchDevice
|
from homeassistant.components.switch import SwitchDevice
|
||||||
from homeassistant.const import CONF_HOST, CONF_USERNAME, CONF_PASSWORD
|
from homeassistant.const import CONF_HOST, CONF_USERNAME, CONF_PASSWORD
|
||||||
|
|
||||||
|
|
||||||
# pylint: disable=unused-argument
|
# pylint: disable=unused-argument
|
||||||
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
||||||
""" Find and return Edimax Smart Plugs. """
|
""" Find and return Edimax Smart Plugs. """
|
||||||
@@ -24,14 +25,14 @@ def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
|||||||
return
|
return
|
||||||
|
|
||||||
host = config.get(CONF_HOST)
|
host = config.get(CONF_HOST)
|
||||||
auth=(config.get(CONF_USERNAME, 'admin'),
|
auth = (config.get(CONF_USERNAME, 'admin'),
|
||||||
config.get(CONF_PASSWORD, '1234'))
|
config.get(CONF_PASSWORD, '1234'))
|
||||||
|
|
||||||
if not host:
|
if not host:
|
||||||
logging.getLogger(__name__).error('Missing config variable %s', CONF_HOST)
|
logging.getLogger(__name__).error(
|
||||||
|
'Missing config variable %s', CONF_HOST)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
add_devices_callback([SmartPlugSwitch(SmartPlug(host, auth))])
|
add_devices_callback([SmartPlugSwitch(SmartPlug(host, auth))])
|
||||||
|
|
||||||
|
|
||||||
@@ -46,6 +47,22 @@ class SmartPlugSwitch(SwitchDevice):
|
|||||||
#TODO: dynamically get name from device using requests
|
#TODO: dynamically get name from device using requests
|
||||||
return 'Edimax Smart Plug'
|
return 'Edimax Smart Plug'
|
||||||
|
|
||||||
|
@property
|
||||||
|
def current_power_mwh(self):
|
||||||
|
""" Current power usage in mwh. """
|
||||||
|
try:
|
||||||
|
return float(self.smartplug.now_power) / 1000000.0
|
||||||
|
except ValueError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def today_power_mw(self):
|
||||||
|
""" Today total power usage in mw. """
|
||||||
|
try:
|
||||||
|
return float(self.smartplug.now_energy_day) / 1000.0
|
||||||
|
except ValueError:
|
||||||
|
return None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_on(self):
|
def is_on(self):
|
||||||
""" True if switch is on. """
|
""" True if switch is on. """
|
||||||
|
2
homeassistant/external/netdisco
vendored
2
homeassistant/external/netdisco
vendored
Submodule homeassistant/external/netdisco updated: b2cad7c2b9...0e2a4d4e3e
2
homeassistant/external/pyedimax
vendored
2
homeassistant/external/pyedimax
vendored
Submodule homeassistant/external/pyedimax updated: 3815f3bd99...674ada04c4
2
homeassistant/external/pymysensors
vendored
2
homeassistant/external/pymysensors
vendored
Submodule homeassistant/external/pymysensors updated: cd5ef892ee...7fb5c0ef87
2
homeassistant/external/pynetgear
vendored
2
homeassistant/external/pynetgear
vendored
Submodule homeassistant/external/pynetgear updated: e946ecf792...8863fdd356
2
homeassistant/external/pywemo
vendored
2
homeassistant/external/pywemo
vendored
Submodule homeassistant/external/pywemo updated: ca94e41faa...eef7dae12a
Reference in New Issue
Block a user