2019-02-13 20:21:14 +00:00
|
|
|
"""Interfaces with Egardia/Woonveilig alarm control panel."""
|
2018-03-02 11:50:00 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
import requests
|
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.const import (
|
2019-02-13 20:21:14 +00:00
|
|
|
CONF_HOST, CONF_NAME, CONF_PASSWORD, CONF_PORT, CONF_USERNAME,
|
2018-03-02 11:50:00 +00:00
|
|
|
EVENT_HOMEASSISTANT_STOP)
|
2019-02-13 20:21:14 +00:00
|
|
|
from homeassistant.helpers import discovery
|
|
|
|
import homeassistant.helpers.config_validation as cv
|
2018-03-02 11:50:00 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-02-13 20:21:14 +00:00
|
|
|
ATTR_DISCOVER_DEVICES = 'egardia_sensor'
|
|
|
|
|
2018-03-02 11:50:00 +00:00
|
|
|
CONF_REPORT_SERVER_CODES = 'report_server_codes'
|
|
|
|
CONF_REPORT_SERVER_ENABLED = 'report_server_enabled'
|
|
|
|
CONF_REPORT_SERVER_PORT = 'report_server_port'
|
|
|
|
CONF_VERSION = 'version'
|
|
|
|
|
|
|
|
DEFAULT_NAME = 'Egardia'
|
|
|
|
DEFAULT_PORT = 80
|
|
|
|
DEFAULT_REPORT_SERVER_ENABLED = False
|
|
|
|
DEFAULT_REPORT_SERVER_PORT = 52010
|
|
|
|
DEFAULT_VERSION = 'GATE-01'
|
|
|
|
DOMAIN = 'egardia'
|
2019-02-13 20:21:14 +00:00
|
|
|
|
2018-03-02 11:50:00 +00:00
|
|
|
EGARDIA_DEVICE = 'egardiadevice'
|
|
|
|
EGARDIA_NAME = 'egardianame'
|
|
|
|
EGARDIA_REPORT_SERVER_CODES = 'egardia_rs_codes'
|
2019-02-13 20:21:14 +00:00
|
|
|
EGARDIA_REPORT_SERVER_ENABLED = 'egardia_rs_enabled'
|
|
|
|
EGARDIA_SERVER = 'egardia_server'
|
|
|
|
|
2018-03-02 11:50:00 +00:00
|
|
|
NOTIFICATION_ID = 'egardia_notification'
|
|
|
|
NOTIFICATION_TITLE = 'Egardia'
|
2019-02-13 20:21:14 +00:00
|
|
|
|
|
|
|
REPORT_SERVER_CODES_IGNORE = 'ignore'
|
2018-03-02 11:50:00 +00:00
|
|
|
|
|
|
|
SERVER_CODE_SCHEMA = vol.Schema({
|
|
|
|
vol.Optional('arm'): vol.All(cv.ensure_list_csv, [cv.string]),
|
|
|
|
vol.Optional('disarm'): vol.All(cv.ensure_list_csv, [cv.string]),
|
|
|
|
vol.Optional('armhome'): vol.All(cv.ensure_list_csv, [cv.string]),
|
|
|
|
vol.Optional('triggered'): vol.All(cv.ensure_list_csv, [cv.string]),
|
2019-02-13 20:21:14 +00:00
|
|
|
vol.Optional('ignore'): vol.All(cv.ensure_list_csv, [cv.string]),
|
2018-03-02 11:50:00 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
CONFIG_SCHEMA = vol.Schema({
|
|
|
|
DOMAIN: vol.Schema({
|
|
|
|
vol.Required(CONF_HOST): cv.string,
|
|
|
|
vol.Required(CONF_PASSWORD): cv.string,
|
|
|
|
vol.Required(CONF_USERNAME): cv.string,
|
|
|
|
vol.Optional(CONF_VERSION, default=DEFAULT_VERSION): cv.string,
|
|
|
|
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
|
|
|
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
|
|
|
vol.Optional(CONF_REPORT_SERVER_CODES, default={}): SERVER_CODE_SCHEMA,
|
|
|
|
vol.Optional(CONF_REPORT_SERVER_ENABLED,
|
|
|
|
default=DEFAULT_REPORT_SERVER_ENABLED): cv.boolean,
|
|
|
|
vol.Optional(CONF_REPORT_SERVER_PORT,
|
|
|
|
default=DEFAULT_REPORT_SERVER_PORT): cv.port,
|
|
|
|
}),
|
|
|
|
}, extra=vol.ALLOW_EXTRA)
|
|
|
|
|
|
|
|
|
|
|
|
def setup(hass, config):
|
|
|
|
"""Set up the Egardia platform."""
|
|
|
|
from pythonegardia import egardiadevice
|
|
|
|
from pythonegardia import egardiaserver
|
|
|
|
conf = config[DOMAIN]
|
|
|
|
username = conf.get(CONF_USERNAME)
|
|
|
|
password = conf.get(CONF_PASSWORD)
|
|
|
|
host = conf.get(CONF_HOST)
|
|
|
|
port = conf.get(CONF_PORT)
|
|
|
|
version = conf.get(CONF_VERSION)
|
|
|
|
rs_enabled = conf.get(CONF_REPORT_SERVER_ENABLED)
|
|
|
|
rs_port = conf.get(CONF_REPORT_SERVER_PORT)
|
|
|
|
try:
|
|
|
|
device = hass.data[EGARDIA_DEVICE] = egardiadevice.EgardiaDevice(
|
|
|
|
host, port, username, password, '', version)
|
|
|
|
except requests.exceptions.RequestException:
|
2018-07-17 17:34:29 +00:00
|
|
|
_LOGGER.error("An error occurred accessing your Egardia device. "
|
2019-02-13 20:21:14 +00:00
|
|
|
"Please check configuration")
|
2018-03-02 11:50:00 +00:00
|
|
|
return False
|
|
|
|
except egardiadevice.UnauthorizedError:
|
2019-02-13 20:21:14 +00:00
|
|
|
_LOGGER.error("Unable to authorize. Wrong password or username")
|
2018-03-02 11:50:00 +00:00
|
|
|
return False
|
|
|
|
# Set up the egardia server if enabled
|
|
|
|
if rs_enabled:
|
|
|
|
_LOGGER.debug("Setting up EgardiaServer")
|
|
|
|
try:
|
|
|
|
if EGARDIA_SERVER not in hass.data:
|
|
|
|
server = egardiaserver.EgardiaServer('', rs_port)
|
|
|
|
bound = server.bind()
|
|
|
|
if not bound:
|
|
|
|
raise IOError("Binding error occurred while " +
|
|
|
|
"starting EgardiaServer.")
|
|
|
|
hass.data[EGARDIA_SERVER] = server
|
|
|
|
server.start()
|
|
|
|
|
|
|
|
def handle_stop_event(event):
|
2019-02-13 20:21:14 +00:00
|
|
|
"""Handle Home Assistant stop event."""
|
2018-03-02 11:50:00 +00:00
|
|
|
server.stop()
|
|
|
|
|
|
|
|
# listen to home assistant stop event
|
|
|
|
hass.bus.listen_once(EVENT_HOMEASSISTANT_STOP, handle_stop_event)
|
|
|
|
|
|
|
|
except IOError:
|
2019-02-13 20:21:14 +00:00
|
|
|
_LOGGER.error(
|
|
|
|
"Binding error occurred while starting EgardiaServer")
|
2018-03-02 11:50:00 +00:00
|
|
|
return False
|
|
|
|
|
|
|
|
discovery.load_platform(hass, 'alarm_control_panel', DOMAIN,
|
|
|
|
discovered=conf, hass_config=config)
|
|
|
|
|
2019-02-13 20:21:14 +00:00
|
|
|
# Get the sensors from the device and add those
|
2018-03-02 11:50:00 +00:00
|
|
|
sensors = device.getsensors()
|
|
|
|
discovery.load_platform(hass, 'binary_sensor', DOMAIN,
|
|
|
|
{ATTR_DISCOVER_DEVICES: sensors}, config)
|
|
|
|
|
|
|
|
return True
|