2019-02-13 20:21:14 +00:00
|
|
|
"""Offer sun based automation rules."""
|
2015-09-15 07:02:54 +00:00
|
|
|
from datetime import timedelta
|
2016-04-04 19:18:58 +00:00
|
|
|
|
|
|
|
import voluptuous as vol
|
2015-09-15 07:02:54 +00:00
|
|
|
|
2016-05-03 05:05:09 +00:00
|
|
|
from homeassistant.const import (
|
2019-07-31 19:25:30 +00:00
|
|
|
CONF_EVENT,
|
|
|
|
CONF_OFFSET,
|
|
|
|
CONF_PLATFORM,
|
|
|
|
SUN_EVENT_SUNRISE,
|
|
|
|
)
|
2020-10-08 07:44:34 +00:00
|
|
|
from homeassistant.core import HassJob, callback
|
2016-04-04 19:18:58 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2019-12-08 16:29:39 +00:00
|
|
|
from homeassistant.helpers.event import async_track_sunrise, async_track_sunset
|
2019-08-12 03:38:18 +00:00
|
|
|
|
|
|
|
# mypy: allow-untyped-defs, no-check-untyped-defs
|
|
|
|
|
2021-06-11 07:51:12 +00:00
|
|
|
TRIGGER_SCHEMA = cv.TRIGGER_BASE_SCHEMA.extend(
|
2019-07-31 19:25:30 +00:00
|
|
|
{
|
|
|
|
vol.Required(CONF_PLATFORM): "sun",
|
|
|
|
vol.Required(CONF_EVENT): cv.sun_event,
|
|
|
|
vol.Required(CONF_OFFSET, default=timedelta(0)): cv.time_period,
|
|
|
|
}
|
|
|
|
)
|
2015-09-15 07:02:54 +00:00
|
|
|
|
|
|
|
|
2019-09-24 21:57:05 +00:00
|
|
|
async def async_attach_trigger(hass, config, action, automation_info):
|
2016-04-04 19:18:58 +00:00
|
|
|
"""Listen for events based on configuration."""
|
2021-06-14 15:09:20 +00:00
|
|
|
trigger_data = automation_info.get("trigger_data", {}) if automation_info else {}
|
2016-04-04 19:18:58 +00:00
|
|
|
event = config.get(CONF_EVENT)
|
|
|
|
offset = config.get(CONF_OFFSET)
|
2020-08-28 15:02:12 +00:00
|
|
|
description = event
|
|
|
|
if offset:
|
|
|
|
description = f"{description} with offset"
|
2020-10-08 07:44:34 +00:00
|
|
|
job = HassJob(action)
|
2015-09-15 07:02:54 +00:00
|
|
|
|
2016-10-05 03:44:32 +00:00
|
|
|
@callback
|
2016-04-21 20:59:42 +00:00
|
|
|
def call_action():
|
|
|
|
"""Call action with right context."""
|
2020-10-08 07:44:34 +00:00
|
|
|
hass.async_run_hass_job(
|
|
|
|
job,
|
2020-08-28 15:02:12 +00:00
|
|
|
{
|
|
|
|
"trigger": {
|
2021-06-14 15:09:20 +00:00
|
|
|
**trigger_data,
|
2020-08-28 15:02:12 +00:00
|
|
|
"platform": "sun",
|
|
|
|
"event": event,
|
|
|
|
"offset": offset,
|
|
|
|
"description": description,
|
|
|
|
}
|
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2016-04-21 20:59:42 +00:00
|
|
|
|
2016-05-03 05:05:09 +00:00
|
|
|
if event == SUN_EVENT_SUNRISE:
|
2016-10-01 08:22:13 +00:00
|
|
|
return async_track_sunrise(hass, call_action, offset)
|
2017-07-06 03:02:16 +00:00
|
|
|
return async_track_sunset(hass, call_action, offset)
|