core/homeassistant/components/wake_on_lan/switch.py

94 lines
2.9 KiB
Python
Raw Normal View History

"""Support for wake on lan."""
2016-03-18 14:01:53 +00:00
import logging
import platform
import subprocess as sp
2016-08-25 04:36:41 +00:00
import voluptuous as vol
2018-09-10 14:07:31 +00:00
from homeassistant.components.switch import PLATFORM_SCHEMA, SwitchDevice
from homeassistant.const import CONF_HOST, CONF_NAME
2016-08-25 04:36:41 +00:00
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.script import Script
2016-03-18 14:01:53 +00:00
2016-08-25 04:36:41 +00:00
_LOGGER = logging.getLogger(__name__)
2018-09-10 14:07:31 +00:00
CONF_BROADCAST_ADDRESS = 'broadcast_address'
2016-08-25 04:36:41 +00:00
CONF_MAC_ADDRESS = 'mac_address'
CONF_OFF_ACTION = 'turn_off'
2016-08-25 04:36:41 +00:00
DEFAULT_NAME = 'Wake on LAN'
2016-03-18 14:01:53 +00:00
DEFAULT_PING_TIMEOUT = 1
2016-08-25 04:36:41 +00:00
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_MAC_ADDRESS): cv.string,
vol.Optional(CONF_BROADCAST_ADDRESS): cv.string,
2018-09-10 14:07:31 +00:00
vol.Optional(CONF_HOST): cv.string,
2016-08-25 04:36:41 +00:00
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
vol.Optional(CONF_OFF_ACTION): cv.SCRIPT_SCHEMA,
2016-08-25 04:36:41 +00:00
})
2016-03-18 14:01:53 +00:00
def setup_platform(hass, config, add_entities, discovery_info=None):
"""Set up a wake on lan switch."""
2018-09-10 14:07:31 +00:00
broadcast_address = config.get(CONF_BROADCAST_ADDRESS)
2016-08-25 04:36:41 +00:00
host = config.get(CONF_HOST)
mac_address = config.get(CONF_MAC_ADDRESS)
2018-09-10 14:07:31 +00:00
name = config.get(CONF_NAME)
off_action = config.get(CONF_OFF_ACTION)
2016-08-25 04:36:41 +00:00
2018-09-10 14:07:31 +00:00
add_entities([WOLSwitch(
hass, name, host, mac_address, off_action, broadcast_address)], True)
2016-03-18 14:01:53 +00:00
class WOLSwitch(SwitchDevice):
"""Representation of a wake on lan switch."""
2018-09-10 14:07:31 +00:00
def __init__(
self, hass, name, host, mac_address, off_action,
broadcast_address):
2016-03-18 14:01:53 +00:00
"""Initialize the WOL switch."""
2018-02-06 00:04:31 +00:00
import wakeonlan
2016-03-18 14:01:53 +00:00
self._hass = hass
self._name = name
self._host = host
self._mac_address = mac_address
self._broadcast_address = broadcast_address
self._off_script = Script(hass, off_action) if off_action else None
2016-03-18 14:01:53 +00:00
self._state = False
2018-02-06 00:04:31 +00:00
self._wol = wakeonlan
2016-03-18 14:01:53 +00:00
@property
def is_on(self):
"""Return true if switch is on."""
2016-03-18 14:01:53 +00:00
return self._state
@property
def name(self):
"""Return the name of the switch."""
2016-03-18 14:01:53 +00:00
return self._name
def turn_on(self, **kwargs):
2016-03-18 14:01:53 +00:00
"""Turn the device on."""
if self._broadcast_address:
self._wol.send_magic_packet(
self._mac_address, ip_address=self._broadcast_address)
else:
self._wol.send_magic_packet(self._mac_address)
2016-03-18 14:01:53 +00:00
def turn_off(self, **kwargs):
"""Turn the device off if an off action is present."""
if self._off_script is not None:
self._off_script.run()
2016-03-18 14:01:53 +00:00
def update(self):
"""Check if device is on and update the state."""
if platform.system().lower() == 'windows':
ping_cmd = ['ping', '-n', '1', '-w',
str(DEFAULT_PING_TIMEOUT * 1000), str(self._host)]
2016-03-18 14:01:53 +00:00
else:
ping_cmd = ['ping', '-c', '1', '-W',
str(DEFAULT_PING_TIMEOUT), str(self._host)]
2016-03-18 14:01:53 +00:00
status = sp.call(ping_cmd, stdout=sp.DEVNULL, stderr=sp.DEVNULL)
2016-03-18 14:01:53 +00:00
self._state = not bool(status)