An example of automating modes with Appdaemon to set suitable lights using the Lightwand Appdaemon app and automate other entities and appliances based on presence. Lightwand listens to the event "MODE_CHANGE" in Home Assistant to set different light modes with 'normal' mode as the default setting.
- Download the
ModeManagement
directory from inside theapps
directory here to your Appdaemonapps
directory. - Add the configuration to a .yaml or .toml file to enable the
ModeManagement
module.
Tip
All sections and configurations are optional, so you can use only what is applicable. This app was written to meet my family's needs and is only meant as an example, but can act as a good baseline for automating presence and day/night shifts in your home. All times is now configurable so it could be a little bit easier to adapt. See definitions below on app behaviour and adjust accordingly.
Set a main vacation switch with vacation
to prevent the app from changing modes while you are away for the night or longer.
This app uses a Workday sensor configured with workday
to change light to Normal and not Morning on weekends and on holidays, when sensor is off. It will look for binary_sensor.workday_sensor
if none is defined. To install the sensor in HA visit Home Assistant Workday integration
You can receive notifications on your devices by listing them under notify_receiver
. When certain conditions are met, like when sensors are triggered and no one is home, you will receive notifications.
You can also configure ClimateCommander to use your own Notification app instead with notify_app
. You'll need to have a function in your app to receive. ClimateCommander sends one notification pr notify_receiver entry.
def send_notification(self,
message:str,
message_title:str,
message_recipient:str
) -> None:
Search for "Test your notification app" in .py file and uncomment to test your own notification app.
Use a Home Assistant input_text helper to display current Light Mode configured with HALightModeText
.
manageModes:
module: modeManagement
class: ModeManagement
workday: binary_sensor.workday_sensor
vacation: input_boolean.vacation
HALightModeText: input_text.lightmode
notify_reciever:
- mobile_app_my_phone
This app's behavior is based on listening to sensors and some automated times if sensors are not triggered. Modes will not change with vacation switch on.
The app starts listening for morning sensors at time configured with morning_start_listen_time
and runs until execute_morning_at
.
To define Home Assistant sensors that trigger the morning mode, input them as a list under morning_sensors
in configuration.
You have the option to define a time the morning is changed to normal mode with morning_to_normal
. This defaults to the time provided with execute_morning_at
.
If your mode is still night or morning at execute_morning_at
, the mode will be set to normal.
You have the option to turn on entities that have the state off with turn_on_in_the_morning
. This only applies to entities with state on
and off
.
morning_sensors:
- binary_sensor.motion_detection
- binary_sensor.presence_sensor
morning_start_listen_time: '06:00:00'
morning_to_normal: '09:00:00'
execute_morning_at: '10:00:00'
turn_on_in_the_morning:
- switch.coffee_machine
Night is basically a reverse of morning. Define your sensors with night_sensors
in configuration. This will change the mode to night and turn off entities defined with turn_off_at_night
. Only entities with state on
will be turned off.
The app starts listening at the sensors at night_start_listen_time
and stops listening and changes mode to night at time configured with execute_night_at
.
night_sensors:
- binary_sensor.window_door_is_open
night_start_listen_time: '22:00:00'
execute_night_at: '02:00:00'
turn_off_at_night:
- media_player.tv
I have a Nimly door lock that I set to auto lock, when no adults are home and during nighttime.
Note
The Nimly MQTT module seems buggy / not reporting correct user in the MQTT message. Use at own risk
MQTT_door_lock:
- zigbee2mqtt/NimlyDoor
Trackers/persons are configured with person
and assign a role
to each tracker, which can be 'adult' (default), 'kid' or 'housekeeper'.
Each person can have an outside
HA helper to manually set person away. This is useful when you are in close proximity and want the doors to auto lock.
If no adults or kids are home, the mode will be set to away
.
If you define persons with a housekeeper role and only the housekeeper is present, the mode will be set to 'wash'. In Lightwand, the standard setting for 'wash' is 100% brightness.
If you have a nimly door lock you can also spesify the lock ID for each person with lock_user
.
The unlock with id is programmed to set wash mode if person unlocking is defined as a "housekeeper" It is also programmed to reset the "outside" switch for person unlocking.
presence:
- person: person.me
outside: input_boolean.outside_me
role: adult
lock_user: 0
In additon to the outside switch pr person you can configure one switch that prevents the app from setting away with keep_mode_when_outside
. This is reset at the time defined with morning_start_listen_time
.
If no adults are home, vacuum
cleaners will start. They will return to their dock if an adult returns home. You can prevent them to start with sensors in the list prevent_vacuum
.
vacuum:
- vacuum.roomba
- vacuum.roborock
prevent_vacuum:
- media_player.tv
Set up sensors that will send you a notification if triggered. It only fires if no one is home and the vaccum cleaners is not running.
alarmsensors:
- binary_sensor.entrance_motion_motion_detection
- cover.garage_door
- binary_sensor.door_window_door_is_open
You can start a playlist in addition to sending notifications when a sensor is triggered.
alarm_media: # Play a playlist if alarmsensors is triggered
- amp: media_player.denon_avr_x3000 # Device to turn on
source: Roon
volume: 0.5
normal_volume: 0.33
player: media_player.yourplayer # Device to start playing from
playlist: 'Library/Artists/Alarm/Alarm'
If you have defined a namespace for MQTT other than default you need to define your namespace with MQTT_namespace
. Same for HASS you need to define your namespace with HASS_namespace
.
Easisest to start off with is to copy this example and update with your sensors and lights and build from that.
manageModes:
module: modeManagement
class: ModeManagement
workday: binary_sensor.workday_sensor
vacation: input_boolean.vacation
HALightModeText: input_text.lightmode
notify_reciever:
- mobile_app_my_phone
morning_sensors:
- binary_sensor.motion_detection
- binary_sensor.presence_sensor
morning_start_listen_time: '06:00:00'
morning_to_normal: '09:00:00'
execute_morning_at: '10:00:00'
night_sensors:
- binary_sensor.window_door_is_open
night_start_listen_time: '22:00:00'
execute_night_at: '02:00:00'
turn_off_at_night:
- media_player.tv
MQTT_door_lock:
- zigbee2mqtt/NimlyDoor
presence:
- person: person.me
outside: input_boolean.outside_me
role: adult
lock_user: 0
vacuum:
- vacuum.roomba
- vacuum.roborock
prevent_vacuum:
- media_player.tv
alarmsensors:
- binary_sensor.entrance_motion_motion_detection
- cover.garage_door
- binary_sensor.door_window_door_is_open
alarm_media: # Play a playlist if alarmsensors is triggered
- amp: media_player.denon_avr_x3000 # Device to turn on
source: Roon
volume: 0.5
normal_volume: 0.33
player: media_player.yourplayer # Device to start playing from
playlist: 'Library/Artists/Alarm/Alarm'
key | optional | type | default | description |
---|---|---|---|---|
module |
False | string | The module name of the app. | |
class |
False | string | The name of the Class. | |
workday |
True | string | binary_sensor.workday_sensor |
HA workday sensor: https://www.home-assistant.io/integrations/workday/ |
vacation |
True | string | input_boolean.vacation |
HA input_boolean for vacations to not setting morning/normal/night mode when away |
turn_off_at_night |
True | list | Items to turn off automatically at night | |
morning_sensors |
True | list | Sensors to trigger morning mode or normal mode if not workday | |
night_sensors |
True | list | Sensors to trigger night mode and turn off items | |
presence |
False | dictionary | Tracking of who is home | |
vacuum |
True | list | Vacuum cleaners | |
alarmsensors |
True | list | HA sensors for notification and start media playing | |
notify_reciever |
True | list | Receivers for notifications | |
alarm_media |
True | dictionary | Play a playlist if alarmsensor is triggered |