Bunch of YAML styling improvements (#16372)

This commit is contained in:
Franck Nijhof 2021-02-01 10:42:12 +01:00 committed by GitHub
parent bf2909228f
commit 7910d17c08
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
85 changed files with 436 additions and 416 deletions

View File

@ -24,7 +24,7 @@ automation:
- alias: Enable First Morning Trigger - alias: Enable First Morning Trigger
trigger: trigger:
- platform: time - platform: time
at: '05:00:00' at: "05:00:00"
action: action:
service: homeassistant.turn_on service: homeassistant.turn_on
entity_id: input_boolean.trigger_first_morning entity_id: input_boolean.trigger_first_morning
@ -47,12 +47,12 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: binary_sensor.livingroom_motion entity_id: binary_sensor.livingroom_motion
to: 'on' to: "on"
# only complete the automation if we're still waiting for the first motion # only complete the automation if we're still waiting for the first motion
condition: condition:
condition: state condition: state
entity_id: input_boolean.trigger_first_morning entity_id: input_boolean.trigger_first_morning
state: 'on' state: "on"
action: action:
# turn off the "waiting" boolean regardless of whether lights will turn on # turn off the "waiting" boolean regardless of whether lights will turn on

View File

@ -13,42 +13,42 @@ For flashing regular lights in case an alarm is triggered.
# AlmSnd1 - switch for a buzzer # AlmSnd1 - switch for a buzzer
automation: automation:
- alias: 'Alarm_PIR_Room1' - alias: "Alarm_PIR_Room1"
trigger: trigger:
platform: state platform: state
entity_id: binary_sensor.PIR1 entity_id: binary_sensor.PIR1
to: 'on' to: "on"
condition: condition:
- condition: state - condition: state
entity_id: switch.AlmAct1 entity_id: switch.AlmAct1
state: 'on' state: "on"
- condition: state - condition: state
entity_id: script.alarm_room1 entity_id: script.alarm_room1
state: 'off' state: "off"
action: action:
# start alarm on movement if alarm activated # start alarm on movement if alarm activated
# and the alarm is not triggered # and the alarm is not triggered
service: script.turn_on service: script.turn_on
entity_id: script.alarm_room1 entity_id: script.alarm_room1
- alias: 'flash_room1_start' - alias: "flash_room1_start"
trigger: trigger:
platform: state platform: state
entity_id: switch.AlmSnd1 entity_id: switch.AlmSnd1
to: 'on' to: "on"
action: action:
service: script.turn_on service: script.turn_on
entity_id: script.flash_room1 entity_id: script.flash_room1
- alias: 'flash_room1_stop' - alias: "flash_room1_stop"
trigger: trigger:
platform: state platform: state
entity_id: switch.REL1 entity_id: switch.REL1
to: 'off' to: "off"
condition: condition:
condition: state condition: state
entity_id: switch.AlmSnd1 entity_id: switch.AlmSnd1
state: 'off' state: "off"
action: action:
service: script.turn_off service: script.turn_off
entity_id: script.flash_room1 entity_id: script.flash_room1
@ -68,7 +68,7 @@ script:
- alias: email_Room1 - alias: email_Room1
service: notify.email service: notify.email
data: data:
message: 'Movement alarm in Room1' message: "Movement alarm in Room1"
- delay: - delay:
# time interval for alarm sound and light flashing # time interval for alarm sound and light flashing
seconds: 60 seconds: 60

View File

@ -10,18 +10,18 @@ Turn on a light in the living room when it starts raining, someone is home, and
```yaml ```yaml
automation: automation:
- alias: 'Rainy Day' - alias: "Rainy Day"
trigger: trigger:
- platform: state - platform: state
entity_id: sensor.precip_intensity entity_id: sensor.precip_intensity
to: 'rain' to: "rain"
condition: condition:
- condition: state - condition: state
entity_id: all entity_id: all
state: 'home' state: "home"
- condition: time - condition: time
after: '14:00' after: "14:00"
before: '23:00' before: "23:00"
action: action:
service: light.turn_on service: light.turn_on
entity_id: light.couch_lamp entity_id: light.couch_lamp
@ -30,15 +30,15 @@ automation:
And then of course turn off the lamp when it stops raining but only if it's within an hour before sunset. And then of course turn off the lamp when it stops raining but only if it's within an hour before sunset.
```yaml ```yaml
- alias: 'Rain is over' - alias: "Rain is over"
trigger: trigger:
- platform: state - platform: state
entity_id: sensor.precip_intensity entity_id: sensor.precip_intensity
to: 'None' to: "None"
condition: condition:
- condition: sun - condition: sun
after: 'sunset' after: "sunset"
after_offset: '-01:00:00' after_offset: "-01:00:00"
action: action:
service: light.turn_off service: light.turn_off
entity_id: light.couch_lamp entity_id: light.couch_lamp

View File

@ -44,24 +44,24 @@ Send notifications through [PushBullet](/integrations/pushbullet) when the sun s
```yaml ```yaml
automation: automation:
- alias: 'Send notification when sun rises' - alias: "Send notification when sun rises"
trigger: trigger:
platform: sun platform: sun
event: sunrise event: sunrise
offset: '+00:00:00' offset: "+00:00:00"
action: action:
service: notify.pushbullet service: notify.pushbullet
data: data:
message: 'The sun is up.' message: "The sun is up."
- alias: 'Send notification when sun sets' - alias: "Send notification when sun sets"
trigger: trigger:
platform: sun platform: sun
event: sunset event: sunset
offset: '+00:00:00' offset: "+00:00:00"
action: action:
service: notify.pushbullet service: notify.pushbullet
data: data:
message: 'The sun is down.' message: "The sun is down."
``` ```
#### Automations for lights and blinds based on solar elevation #### Automations for lights and blinds based on solar elevation
@ -69,7 +69,7 @@ automation:
Solar elevation automations can cope with offsets from sunset / sunrise as the seasons change better than using a time based offsets. Solar elevation automations can cope with offsets from sunset / sunrise as the seasons change better than using a time based offsets.
```yaml ```yaml
- alias: 'Turn a few lights on when the sun gets dim' - alias: "Turn a few lights on when the sun gets dim"
trigger: trigger:
platform: numeric_state platform: numeric_state
entity_id: sun.sun entity_id: sun.sun
@ -79,7 +79,7 @@ Solar elevation automations can cope with offsets from sunset / sunrise as the s
service: scene.turn_on service: scene.turn_on
entity_id: scene.background_lights entity_id: scene.background_lights
- alias: 'Turn more lights on as the sun gets dimmer' - alias: "Turn more lights on as the sun gets dimmer"
trigger: trigger:
platform: numeric_state platform: numeric_state
entity_id: sun.sun entity_id: sun.sun
@ -89,7 +89,7 @@ Solar elevation automations can cope with offsets from sunset / sunrise as the s
service: scene.turn_on service: scene.turn_on
entity_id: scene.more_lights entity_id: scene.more_lights
- alias: 'Close blind at dusk' - alias: "Close blind at dusk"
trigger: trigger:
platform: numeric_state platform: numeric_state
entity_id: sun.sun entity_id: sun.sun

View File

@ -23,10 +23,10 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: device_tracker.device_name_here entity_id: device_tracker.device_name_here
from: 'not_home' from: "not_home"
to: 'home' to: "home"
action: action:
service: notify.Telegram service: notify.Telegram
data: data:
message: 'Person is now home' message: "Person is now home"
``` ```

View File

@ -17,14 +17,14 @@ input_boolean:
automation: automation:
# Changes Hue light every two minutes to random color if input boolean is set to on # Changes Hue light every two minutes to random color if input boolean is set to on
- alias: 'Set LivingColors to random color' - alias: "Set LivingColors to random color"
trigger: trigger:
platform: time_pattern platform: time_pattern
minutes: '/2' minutes: "/2"
condition: condition:
condition: state condition: state
entity_id: input_boolean.loop_livingcolors entity_id: input_boolean.loop_livingcolors
state: 'on' state: "on"
action: action:
service: light.turn_on service: light.turn_on
entity_id: light.woonkamer_livingcolors entity_id: light.woonkamer_livingcolors

View File

@ -13,8 +13,8 @@ For the controller this was written for scene ID 13 was sent when the up button
```yaml ```yaml
automation: automation:
- alias: 'Make the lights go bright' - alias: "Make the lights go bright"
initial_state: 'on' initial_state: "on"
trigger: trigger:
- platform: event - platform: event
event_type: zwave.scene_activated event_type: zwave.scene_activated
@ -29,8 +29,8 @@ automation:
direction: up direction: up
light: light.YOUR_LIGHT light: light.YOUR_LIGHT
- alias: 'Make the lights go dim' - alias: "Make the lights go dim"
initial_state: 'on' initial_state: "on"
trigger: trigger:
- platform: event - platform: event
event_type: zwave.scene_activated event_type: zwave.scene_activated
@ -45,8 +45,8 @@ automation:
direction: down direction: down
light: light.YOUR_LIGHT light: light.YOUR_LIGHT
- alias: 'Stop the light just there' - alias: "Stop the light just there"
initial_state: 'on' initial_state: "on"
trigger: trigger:
- platform: event - platform: event
event_type: zwave.scene_activated event_type: zwave.scene_activated
@ -73,28 +73,28 @@ To allow flexibility all four variables are controlled by [Input Number](/integr
```yaml ```yaml
input_number: input_number:
light_step: light_step:
name: 'Step the lights this much' name: "Step the lights this much"
initial: 20 initial: 20
min: 1 min: 1
max: 64 max: 64
step: 1 step: 1
light_minimum: light_minimum:
name: 'No dimmer than this' name: "No dimmer than this"
initial: 5 initial: 5
min: 1 min: 1
max: 255 max: 255
step: 1 step: 1
light_maximum: light_maximum:
name: 'No brighter than this' name: "No brighter than this"
initial: 255 initial: 255
min: 50 min: 50
max: 255 max: 255
step: 1 step: 1
light_delay_ms: light_delay_ms:
name: 'Step the lights this often (ms)' name: "Step the lights this often (ms)"
initial: 500 initial: 500
min: 100 min: 100
max: 5000 max: 5000

View File

@ -45,12 +45,12 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: media_player.htpc entity_id: media_player.htpc
from: 'playing' from: "playing"
to: 'idle' to: "idle"
condition: condition:
- condition: state - condition: state
entity_id: sun.sun entity_id: sun.sun
state: 'below_horizon' state: "below_horizon"
action: action:
service: scene.turn_on service: scene.turn_on
entity_id: scene.livingroom_normal entity_id: scene.livingroom_normal
@ -59,12 +59,12 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: media_player.htpc entity_id: media_player.htpc
to: 'playing' to: "playing"
from: 'idle' from: "idle"
condition: condition:
- condition: state - condition: state
entity_id: sun.sun entity_id: sun.sun
state: 'below_horizon' state: "below_horizon"
action: action:
service: scene.turn_on service: scene.turn_on
entity_id: scene.livingroom_dim entity_id: scene.livingroom_dim

View File

@ -19,7 +19,7 @@ switch:
switches: switches:
#Switch for Foscam Motion Detection #Switch for Foscam Motion Detection
foscam_motion: foscam_motion:
command_on: 'curl -k --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=setMotionDetectConfig&isEnable=1&usr=admin&pwd=password"' command_on: "curl -k --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=setMotionDetectConfig&isEnable=1&usr=admin&pwd=password""
command_off: 'curl -k --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=setMotionDetectConfig&isEnable=0&usr=admin&pwd=password"' command_off: 'curl -k --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=setMotionDetectConfig&isEnable=0&usr=admin&pwd=password"'
command_state: 'curl -k --silent --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=getMotionDetectConfig&usr=admin&pwd=password" | grep "isEnable" | cut -b 15' command_state: 'curl -k --silent --tls-max 1.2 "https://ipaddress:443/cgi-bin/CGIProxy.fcgi?cmd=getMotionDetectConfig&usr=admin&pwd=password" | grep "isEnable" | cut -b 15'
value_template: '{% raw %}{{ value == "1" }}{% endraw %}' value_template: '{% raw %}{{ value == "1" }}{% endraw %}'
@ -64,14 +64,14 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: group.family entity_id: group.family
from: 'home' from: "home"
action: action:
service: script.foscam_on service: script.foscam_on
- alias: Set Foscam to Home Mode when I arrive Home - alias: Set Foscam to Home Mode when I arrive Home
trigger: trigger:
platform: state platform: state
entity_id: group.family entity_id: group.family
to: 'home' to: "home"
action: action:
service: script.foscam_off service: script.foscam_off
``` ```

View File

@ -50,7 +50,7 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: device_tracker.me entity_id: device_tracker.me
to: 'home' to: "home"
action: action:
service: script.notify_mqtt service: script.notify_mqtt
data: data:

View File

@ -19,12 +19,12 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: binary_sensor.updater entity_id: binary_sensor.updater
from: 'off' from: "off"
to: 'on' to: "on"
action: action:
- service: notify.jabber - service: notify.jabber
data: data:
message: 'There is a new Home Assistant release available.' message: "There is a new Home Assistant release available."
``` ```
You can use [templates](/topics/templating/) to include the release number of Home Assistant if you prefer. The following example sends a notification via [Pushbullet](/integrations/pushbullet) with the Home Assistant version in the message. You can use [templates](/topics/templating/) to include the release number of Home Assistant if you prefer. The following example sends a notification via [Pushbullet](/integrations/pushbullet) with the Home Assistant version in the message.
@ -32,7 +32,7 @@ You can use [templates](/topics/templating/) to include the release number of Ho
```yaml ```yaml
notify: notify:
- platform: pushbullet - platform: pushbullet
api_key: 'YOUR_KEY_HERE' api_key: "YOUR_KEY_HERE"
name: pushbullet name: pushbullet
automation: automation:
@ -40,13 +40,13 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: binary_sensor.updater entity_id: binary_sensor.updater
from: 'off' from: "off"
to: 'on' to: "on"
action: action:
- service: notify.pushbullet - service: notify.pushbullet
data: data:
title: 'New Home Assistant Release' title: "New Home Assistant Release"
target: 'YOUR_TARGET_HERE' #See Pushbullet integration for usage target: "YOUR_TARGET_HERE" #See Pushbullet integration for usage
message: "Home Assistant {% raw %} {{ state_attr('binary_sensor.updater', 'newest_version') }} {% endraw %} is now available." message: "Home Assistant {% raw %} {{ state_attr('binary_sensor.updater', 'newest_version') }} {% endraw %} is now available."
``` ```

View File

@ -160,5 +160,5 @@ automation:
{% else %}{% endraw %} {% else %}{% endraw %}
none{% raw %} none{% raw %}
{% endif %}{% endraw %} {% endif %}{% endraw %}
media_content_type: 'music' media_content_type: "music"
``` ```

View File

@ -51,7 +51,7 @@ script:
minutes: 15 minutes: 15
- service: notify.pushbullet - service: notify.pushbullet
data: data:
message: 'WeMo not found, restarting HA' message: "WeMo not found, restarting HA"
- service: switch.turn_on - service: switch.turn_on
data: data:
entity_id: switch.killhass entity_id: switch.killhass
@ -61,32 +61,32 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: device_tracker.wemo entity_id: device_tracker.wemo
from: 'not_home' from: "not_home"
to: 'home' to: "home"
condition: condition:
- condition: template - condition: template
value_template: {% raw %}'{% if states.switch.wemo %}false{% else %}true{% endif %}'{% endraw %} value_template: {% raw %}'{% if states.switch.wemo %}false{% else %}true{% endif %}'{% endraw %}
- condition: state - condition: state
entity_id: script.restarthawemo entity_id: script.restarthawemo
state: 'off' state: "off"
action: action:
service: homeassistant.turn_on service: homeassistant.turn_on
entity_id: script.restarthawemo entity_id: script.restarthawemo
- alias: 'Stop HA' - alias: "Stop HA"
trigger: trigger:
- platform: state - platform: state
entity_id: switch.KillHass entity_id: switch.KillHass
to: 'on' to: "on"
action: action:
service: homeassistant.stop service: homeassistant.stop
- alias: 'Stop restarting HA is WeMo is found' - alias: "Stop restarting HA is WeMo is found"
trigger: trigger:
platform: template platform: template
value_template: {% raw %}'{% if states.switch.wemo %}true{% else %}false{% endif %}'{% endraw %} value_template: {% raw %}'{% if states.switch.wemo %}true{% else %}false{% endif %}'{% endraw %}
condition: condition:
condition: state condition: state
entity_id: script.restarthawemo entity_id: script.restarthawemo
state: 'on' state: "on"
action: action:
service: homeassistant.turn_off service: homeassistant.turn_off
entity_id: script.restarthawemo entity_id: script.restarthawemo

View File

@ -24,9 +24,9 @@ automation:
- alias: Send message at a given time - alias: Send message at a given time
trigger: trigger:
platform: time platform: time
at: '12:15:00' at: "12:15:00"
action: action:
service: notify.jabber service: notify.jabber
data: data:
message: 'Time for lunch' message: "Time for lunch"
``` ```

View File

@ -36,7 +36,7 @@ script:
We call this now with: We call this now with:
```yaml ```yaml
automation: automation:
- alias: 'test' - alias: "test"
trigger: trigger:
- platform: state - platform: state
entity_id: input_boolean.mytest entity_id: input_boolean.mytest
@ -45,8 +45,8 @@ automation:
data: data:
sonos_entity: media_player.office sonos_entity: media_player.office
volume: 0.5 volume: 0.5
message: 'Your husband coming home!' message: "Your husband coming home!"
delay: '00:00:05' delay: "00:00:05"
``` ```
Note that this example uses the `voicerss` text-to-speech platform. There are many platforms that can be used. The one installed by default with Home Assistant is Google TTS. This appears in your `configuration.yaml` file as: Note that this example uses the `voicerss` text-to-speech platform. There are many platforms that can be used. The one installed by default with Home Assistant is Google TTS. This appears in your `configuration.yaml` file as:

View File

@ -20,7 +20,7 @@ sensor:
sensors: sensors:
battery_iphone: battery_iphone:
friendly_name: iPhone Battery friendly_name: iPhone Battery
unit_of_measurement: '%' unit_of_measurement: "%"
value_template: >- value_template: >-
{%- if state_attr('device_tracker.iphone', 'battery') %} {%- if state_attr('device_tracker.iphone', 'battery') %}
{{ state_attr('device_tracker.iphone', 'battery')|round }} {{ state_attr('device_tracker.iphone', 'battery')|round }}
@ -44,7 +44,7 @@ sensor:
sensors: sensors:
battery_phone: battery_phone:
friendly_name: AndroidPhone Battery friendly_name: AndroidPhone Battery
unit_of_measurement: '%' unit_of_measurement: "%"
value_template: >- value_template: >-
{%- if state_attr('device_tracker.xxxxx', 'battery_level') %} {%- if state_attr('device_tracker.xxxxx', 'battery_level') %}
{{ state_attr('device_tracker.xxxxx', 'battery_level')|round }} {{ state_attr('device_tracker.xxxxx', 'battery_level')|round }}
@ -71,7 +71,7 @@ sensor:
state_topic: "owntracks/username/deviceid" state_topic: "owntracks/username/deviceid"
name: "Battery Tablet" name: "Battery Tablet"
unit_of_measurement: "%" unit_of_measurement: "%"
value_template: '{{ value_json.batt }}' value_template: "{{ value_json.batt }}"
device_class: battery device_class: battery
``` ```
@ -90,7 +90,7 @@ sensor:
sensors: sensors:
your_battery_sensor_name: your_battery_sensor_name:
value_template: "{{ state_attr('device_tracker.deviceid', 'battery_level') }}" value_template: "{{ state_attr('device_tracker.deviceid', 'battery_level') }}"
unit_of_measurement: '%' unit_of_measurement: "%"
``` ```
{% endraw %} {% endraw %}

View File

@ -14,7 +14,7 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: sensor.motion_sensor entity_id: sensor.motion_sensor
to: 'on' to: "on"
action: action:
service: light.turn_on service: light.turn_on
entity_id: light.kitchen_light entity_id: light.kitchen_light
@ -23,7 +23,7 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: sensor.motion_sensor entity_id: sensor.motion_sensor
to: 'off' to: "off"
for: for:
minutes: 10 minutes: 10
action: action:
@ -39,7 +39,7 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: sensor.motion_sensor, binary_sensor.front_door, binary_sensor.doorbell entity_id: sensor.motion_sensor, binary_sensor.front_door, binary_sensor.doorbell
to: 'on' to: "on"
action: action:
- service: light.turn_on - service: light.turn_on
data: data:
@ -65,7 +65,7 @@ automation:
timer: timer:
hallway: hallway:
duration: '00:10:00' duration: "00:10:00"
``` ```
You can also restrict lights from turning on based on time of day and implement transitions for fading lights on and off. You can also restrict lights from turning on based on time of day and implement transitions for fading lights on and off.
@ -75,11 +75,11 @@ You can also restrict lights from turning on based on time of day and implement
trigger: trigger:
platform: state platform: state
entity_id: binary_sensor.ecolink_pir_motion_sensor_sensor entity_id: binary_sensor.ecolink_pir_motion_sensor_sensor
to: 'on' to: "on"
condition: condition:
condition: time condition: time
after: '07:30' after: "07:30"
before: '23:30' before: "23:30"
action: action:
service: homeassistant.turn_on service: homeassistant.turn_on
entity_id: group.office_lights entity_id: group.office_lights
@ -91,7 +91,7 @@ You can also restrict lights from turning on based on time of day and implement
trigger: trigger:
- platform: state - platform: state
entity_id: binary_sensor.ecolink_pir_motion_sensor_sensor entity_id: binary_sensor.ecolink_pir_motion_sensor_sensor
to: 'off' to: "off"
for: for:
minutes: 15 minutes: 15
action: action:

View File

@ -34,11 +34,11 @@ automation 2:
# Actions are scripts so can also be a list of actions # Actions are scripts so can also be a list of actions
- service: "{{ notification_service }}" - service: "{{ notification_service }}"
data: data:
message: Beautiful sunset! message: "Beautiful sunset!"
- delay: 0:35 - delay: 0:35
- service: notify.notify - service: notify.notify
data: data:
message: Oh wow you really missed something great. message: "Oh wow you really missed something great."
``` ```
Conditions can also be part of an action. You can combine multiple service calls and conditions in a single action, and they will be processed in the order you put them in. If the result of a condition is false, the action will stop there so any service calls after that condition will not be executed. Conditions can also be part of an action. You can combine multiple service calls and conditions in a single action, and they will be processed in the order you put them in. If the result of a condition is false, the action will stop there so any service calls after that condition will not be executed.
@ -49,17 +49,20 @@ automation:
trigger: trigger:
platform: state platform: state
entity_id: sensor.office_occupancy entity_id: sensor.office_occupancy
to: 'on' to: "on"
action: action:
- service: notify.notify - service: notify.notify
data: data:
message: Testing conditional actions message: Testing conditional actions
- condition: or - condition: or
conditions: conditions:
- condition: template - condition: numeric_state
value_template: '{% raw %}{{ state_attr('sun.sun', 'elevation') < 4 }}{% endraw %}' entity_id: sun.sun
- condition: template attribute: elevation
value_template: '{% raw %}{{ states('sensor.office_illuminance') < 10 }}{% endraw %}' below: 4
- condition: state
entity_id: sensor.office_illuminance
below: 10
- service: scene.turn_on - service: scene.turn_on
entity_id: scene.office_at_evening entity_id: scene.office_at_evening
``` ```

View File

@ -46,7 +46,7 @@ automation my_lights:
# with a '-'' to enter multiple # with a '-'' to enter multiple
- condition: state - condition: state
entity_id: all entity_id: all
state: 'home' state: "home"
- condition: time - condition: time
after: '16:00:00' after: '16:00:00'
before: '23:00:00' before: '23:00:00'

View File

@ -108,7 +108,7 @@ homeassistant:
light: light:
icon: mdi:home icon: mdi:home
automation: automation:
initial_state: 'on' initial_state: "on"
# Customize entities matching a pattern # Customize entities matching a pattern
customize_glob: customize_glob:
"light.kitchen_*": "light.kitchen_*":

View File

@ -18,7 +18,7 @@ script:
entity_id: light.ceiling entity_id: light.ceiling
- service: notify.notify - service: notify.notify
data: data:
message: 'Turned on the ceiling light!' message: "Turned on the ceiling light!"
``` ```
- [Call a Service](#call-a-service) - [Call a Service](#call-a-service)
@ -68,7 +68,9 @@ The variables command allows you to set/override variables that will be accessib
```yaml ```yaml
- variables: - variables:
entities: light.kitchen, light.living_room entities:
- light.kitchen
- light.living_room
brightness: 100 brightness: 100
- alias: Control lights - alias: Control lights
service: light.turn_on service: light.turn_on
@ -87,7 +89,7 @@ While executing a script you can add a condition to stop further execution. When
# If paulus is home, continue to execute the script below these lines # If paulus is home, continue to execute the script below these lines
- condition: state - condition: state
entity_id: device_tracker.paulus entity_id: device_tracker.paulus
state: 'home' state: "home"
``` ```
## Delay ## Delay
@ -95,6 +97,7 @@ While executing a script you can add a condition to stop further execution. When
Delays are useful for temporarily suspending your script and start it at a later moment. We support different syntaxes for a delay as shown below. Delays are useful for temporarily suspending your script and start it at a later moment. We support different syntaxes for a delay as shown below.
{% raw %} {% raw %}
```yaml ```yaml
# Seconds # Seconds
# Waits 5 seconds # Waits 5 seconds
@ -120,15 +123,18 @@ Delays are useful for temporarily suspending your script and start it at a later
- delay: - delay:
minutes: 1 minutes: 1
``` ```
{% endraw %} {% endraw %}
All forms accept templates. All forms accept templates.
{% raw %} {% raw %}
```yaml ```yaml
# Waits however many minutes input_number.minute_delay is set to # Waits however many minutes input_number.minute_delay is set to
- delay: "{{ states('input_number.minute_delay') | multiply(60) | int }}" - delay: "{{ states('input_number.minute_delay') | multiply(60) | int }}"
``` ```
{% endraw %} {% endraw %}
## Wait ## Wait
@ -145,15 +151,18 @@ The template is re-evaluated whenever an entity ID that it references changes st
{% raw %} {% raw %}
```yaml ```yaml
# Wait until media player have stop the playing # Wait until media player have stop the playing
- wait_template: "{{ is_state('media_player.floor', 'stop') }}" - wait_template: "{{ is_state('media_player.floor', 'stop') }}"
``` ```
{% endraw %} {% endraw %}
### Wait for Trigger ### Wait for Trigger
This action can use the same triggers that are available in an automation's `trigger` section. See [Automation Trigger](/docs/automation/trigger). The script will continue whenever any of the triggers fires. This action can use the same triggers that are available in an automation's `trigger` section. See [Automation Trigger](/docs/automation/trigger). The script will continue whenever any of the triggers fires.
{% raw %} {% raw %}
```yaml ```yaml
# Wait for a custom event or light to turn on and stay on for 10 sec # Wait for a custom event or light to turn on and stay on for 10 sec
- wait_for_trigger: - wait_for_trigger:
@ -164,6 +173,7 @@ This action can use the same triggers that are available in an automation's `tri
to: 'on' to: 'on'
for: 10 for: 10
``` ```
{% endraw %} {% endraw %}
### Wait Timeout ### Wait Timeout
@ -171,17 +181,20 @@ This action can use the same triggers that are available in an automation's `tri
With both types of waits it is possible to set a timeout after which the script will continue its execution if the condition/event is not satisfied. Timeout has the same syntax as `delay`, and like `delay`, also accepts templates. With both types of waits it is possible to set a timeout after which the script will continue its execution if the condition/event is not satisfied. Timeout has the same syntax as `delay`, and like `delay`, also accepts templates.
{% raw %} {% raw %}
```yaml ```yaml
# Wait for sensor to change to 'on' up to 1 minute before continuing to execute. # Wait for sensor to change to 'on' up to 1 minute before continuing to execute.
- wait_template: "{{ is_state('binary_sensor.entrance', 'on') }}" - wait_template: "{{ is_state('binary_sensor.entrance', 'on') }}"
timeout: '00:01:00' timeout: '00:01:00'
``` ```
{% endraw %} {% endraw %}
You can also get the script to abort after the timeout by using optional `continue_on_timeout: false`. You can also get the script to abort after the timeout by using optional `continue_on_timeout: false`.
{% raw %} {% raw %}
```yaml ```yaml
# Wait for IFTTT event or abort after specified timeout. # Wait for IFTTT event or abort after specified timeout.
- wait_for_trigger: - wait_for_trigger:
- platform: event - platform: event
@ -192,6 +205,7 @@ You can also get the script to abort after the timeout by using optional `contin
minutes: "{{ timeout_minutes }}" minutes: "{{ timeout_minutes }}"
continue_on_timeout: false continue_on_timeout: false
``` ```
{% endraw %} {% endraw %}
Without `continue_on_timeout: false` the script will always continue since the default for `continue_on_timeout` is `true`. Without `continue_on_timeout: false` the script will always continue since the default for `continue_on_timeout` is `true`.
@ -209,14 +223,13 @@ Variable | Description
This can be used to take different actions based on whether or not the condition was met, or to use more than one wait sequentially while implementing a single timeout overall. This can be used to take different actions based on whether or not the condition was met, or to use more than one wait sequentially while implementing a single timeout overall.
{% raw %} {% raw %}
```yaml ```yaml
# Take different actions depending on if condition was met. # Take different actions depending on if condition was met.
- wait_template: "{{ is_state('binary_sensor.door', 'on') }}" - wait_template: "{{ is_state('binary_sensor.door', 'on') }}"
timeout: 10 timeout: 10
- choose: - choose:
- conditions: - conditions: "{{ not wait.completed }}"
- condition: template
value_template: "{{ not wait.completed }}"
sequence: sequence:
- service: script.door_did_not_open - service: script.door_did_not_open
default: default:
@ -234,7 +247,7 @@ This can be used to take different actions based on whether or not the condition
- wait_for_trigger: - wait_for_trigger:
- platform: state - platform: state
entity_id: binary_sensor.door_2 entity_id: binary_sensor.door_2
to: 'on' to: "on"
for: 2 for: 2
timeout: "{{ wait.remaining }}" timeout: "{{ wait.remaining }}"
continue_on_timeout: false continue_on_timeout: false
@ -260,35 +273,36 @@ You can also use event_data to fire an event with custom data. This could be use
an event trigger. an event trigger.
{% raw %} {% raw %}
```yaml ```yaml
- event: MY_EVENT - event: MY_EVENT
event_data: event_data:
name: myEvent name: myEvent
customData: "{{ myCustomVariable }}" customData: "{{ myCustomVariable }}"
``` ```
{% endraw %} {% endraw %}
### Raise and Consume Custom Events ### Raise and Consume Custom Events
The following automation shows how to raise a custom event called `event_light_state_changed` with `entity_id` as the event data. The action part could be inside a script or an automation. The following automation shows how to raise a custom event called `event_light_state_changed` with `entity_id` as the event data. The action part could be inside a script or an automation.
{% raw %}
```yaml ```yaml
- alias: Fire Event - alias: Fire Event
trigger: trigger:
- platform: state - platform: state
entity_id: switch.kitchen entity_id: switch.kitchen
to: 'on' to: "on"
action: action:
- event: event_light_state_changed - event: event_light_state_changed
event_data: event_data:
state: 'on' state: "on"
``` ```
{% endraw %}
The following automation shows how to capture the custom event `event_light_state_changed`, and retrieve corresponding `entity_id` that was passed as the event data. The following automation shows how to capture the custom event `event_light_state_changed`, and retrieve corresponding `entity_id` that was passed as the event data.
{% raw %} {% raw %}
```yaml ```yaml
- alias: Capture Event - alias: Capture Event
trigger: trigger:
@ -299,6 +313,7 @@ The following automation shows how to capture the custom event `event_light_stat
data: data:
message: "kitchen light is turned {{ trigger.event.data.state }}" message: "kitchen light is turned {{ trigger.event.data.state }}"
``` ```
{% endraw %} {% endraw %}
## Repeat a Group of Actions ## Repeat a Group of Actions
@ -312,6 +327,7 @@ This form accepts a count value. The value may be specified by a template, in wh
the template is rendered when the repeat step is reached. the template is rendered when the repeat step is reached.
{% raw %} {% raw %}
```yaml ```yaml
script: script:
flash_light: flash_light:
@ -334,6 +350,7 @@ script:
light: hallway light: hallway
count: 3 count: 3
``` ```
{% endraw %} {% endraw %}
### While Loop ### While Loop
@ -353,7 +370,7 @@ script:
while: while:
- condition: state - condition: state
entity_id: input_boolean.do_something entity_id: input_boolean.do_something
state: 'on' state: "on"
# Don't do it too many times # Don't do it too many times
- condition: template - condition: template
value_template: "{{ repeat.index <= 20 }}" value_template: "{{ repeat.index <= 20 }}"
@ -393,7 +410,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: binary_sensor.something entity_id: binary_sensor.something
state: 'off' state: "off"
mode: single mode: single
action: action:
- alias: Repeat the sequence UNTIL the conditions are true - alias: Repeat the sequence UNTIL the conditions are true
@ -408,7 +425,7 @@ automation:
# Did it work? # Did it work?
- condition: state - condition: state
entity_id: binary_sensor.something entity_id: binary_sensor.something
state: 'on' state: "on"
``` ```
{% endraw %} {% endraw %}

View File

@ -17,7 +17,7 @@ condition:
conditions: conditions:
- condition: state - condition: state
entity_id: 'device_tracker.paulus' entity_id: 'device_tracker.paulus'
state: 'home' state: "home"
- condition: numeric_state - condition: numeric_state
entity_id: 'sensor.temperature' entity_id: 'sensor.temperature'
below: 20 below: 20
@ -31,7 +31,7 @@ The following configuration works the same as the one listed above:
condition: condition:
- condition: state - condition: state
entity_id: 'device_tracker.paulus' entity_id: 'device_tracker.paulus'
state: 'home' state: "home"
- condition: numeric_state - condition: numeric_state
entity_id: 'sensor.temperature' entity_id: 'sensor.temperature'
below: 20 below: 20
@ -49,7 +49,7 @@ condition:
conditions: conditions:
- condition: state - condition: state
entity_id: 'device_tracker.paulus' entity_id: 'device_tracker.paulus'
state: 'home' state: "home"
- condition: numeric_state - condition: numeric_state
entity_id: 'sensor.temperature' entity_id: 'sensor.temperature'
below: 20 below: 20
@ -66,12 +66,12 @@ condition:
conditions: conditions:
- condition: state - condition: state
entity_id: 'device_tracker.paulus' entity_id: 'device_tracker.paulus'
state: 'home' state: "home"
- condition: or - condition: or
conditions: conditions:
- condition: state - condition: state
entity_id: sensor.weather_precip entity_id: sensor.weather_precip
state: 'rain' state: "rain"
- condition: numeric_state - condition: numeric_state
entity_id: 'sensor.temperature' entity_id: 'sensor.temperature'
below: 20 below: 20
@ -87,7 +87,7 @@ condition:
conditions: conditions:
- condition: state - condition: state
entity_id: device_tracker.paulus entity_id: device_tracker.paulus
state: 'home' state: "home"
- condition: state - condition: state
entity_id: alarm_control_panel.home_alarm entity_id: alarm_control_panel.home_alarm
state: disarmed state: disarmed
@ -167,7 +167,7 @@ Tests if an entity is a specified state.
condition: condition:
condition: state condition: state
entity_id: device_tracker.paulus entity_id: device_tracker.paulus
state: 'not_home' state: "not_home"
# optional: trigger only if state was this for last X time. # optional: trigger only if state was this for last X time.
for: for:
hours: 1 hours: 1
@ -184,7 +184,7 @@ condition:
entity_id: entity_id:
- light.kitchen - light.kitchen
- light.living_room - light.living_room
state: 'on' state: "on"
``` ```
Testing if an entity is matching a set of possible conditions; Testing if an entity is matching a set of possible conditions;
@ -245,14 +245,14 @@ The sun state can be used to test if the sun has set or risen.
condition: condition:
condition: state # 'day' condition: from sunrise until sunset condition: state # 'day' condition: from sunrise until sunset
entity_id: sun.sun entity_id: sun.sun
state: 'above_horizon' state: "above_horizon"
``` ```
```yaml ```yaml
condition: condition:
condition: state # from sunset until sunrise condition: state # from sunset until sunrise
entity_id: sun.sun entity_id: sun.sun
state: 'below_horizon' state: "below_horizon"
``` ```
### Sun elevation condition ### Sun elevation condition
@ -532,13 +532,13 @@ condition:
below: 1 below: 1
- condition: state - condition: state
entity_id: light.living_room entity_id: light.living_room
state: 'off' state: "off"
- condition: time - condition: time
before: '23:00:00' before: '23:00:00'
after: '14:00:00' after: '14:00:00'
- condition: state - condition: state
entity_id: script.light_turned_off_5min entity_id: script.light_turned_off_5min
state: 'off' state: "off"
``` ```
{% endraw %} {% endraw %}

View File

@ -47,7 +47,7 @@ alarm_control_panel:
disarm: disarm:
- condition: state - condition: state
entity_id: device_tracker.paulus entity_id: device_tracker.paulus
state: 'home' state: "home"
- service: alarm_control_panel.alarm_arm_home - service: alarm_control_panel.alarm_arm_home
data: data:
entity_id: alarm_control_panel.real_alarm entity_id: alarm_control_panel.real_alarm

View File

@ -38,7 +38,7 @@ alert:
name: Garage is open name: Garage is open
done_message: Garage is closed done_message: Garage is closed
entity_id: input_boolean.garage_door entity_id: input_boolean.garage_door
state: 'on' state: "on"
repeat: 30 repeat: 30
can_acknowledge: true can_acknowledge: true
skip_first: true skip_first: true
@ -137,7 +137,7 @@ alert:
freshwater_temp_alert: freshwater_temp_alert:
name: "Warning: I have detected a problem with the freshwater tank temperature" name: "Warning: I have detected a problem with the freshwater tank temperature"
entity_id: binary_sensor.freshwater_temperature_status entity_id: binary_sensor.freshwater_temperature_status
state: 'on' state: "on"
repeat: 5 repeat: 5
can_acknowledge: true can_acknowledge: true
skip_first: false skip_first: false
@ -194,7 +194,7 @@ alert:
garage_door: garage_door:
name: Garage is open name: Garage is open
entity_id: input_boolean.garage_door entity_id: input_boolean.garage_door
state: 'on' # Optional, 'on' is the default value state: "on" # Optional, 'on' is the default value
repeat: repeat:
- 15 - 15
- 30 - 30
@ -228,7 +228,7 @@ alert:
office_plant: office_plant:
name: Plant in office needs help name: Plant in office needs help
entity_id: plant.plant_office entity_id: plant.plant_office
state: 'problem' state: "problem"
repeat: 30 repeat: 30
can_acknowledge: true can_acknowledge: true
skip_first: true skip_first: true
@ -254,7 +254,7 @@ alert:
garage_door: garage_door:
name: Garage is open name: Garage is open
entity_id: input_boolean.garage_door entity_id: input_boolean.garage_door
state: 'on' # Optional, 'on' is the default value state: "on" # Optional, 'on' is the default value
repeat: repeat:
- 15 - 15
- 30 - 30

View File

@ -54,7 +54,7 @@ The Arlo integration also provides a camera service to enable/disable the motion
```yaml ```yaml
#automation.yaml #automation.yaml
- alias: Enable Arlo upon HA start' - alias: Enable Arlo upon HA start'
initial_state: 'on' initial_state: "on"
trigger: trigger:
platform: homeassistant platform: homeassistant
event: start event: start

View File

@ -28,7 +28,7 @@ binary_sensor:
prob_given_true: 0.6 prob_given_true: 0.6
prob_given_false: 0.2 prob_given_false: 0.2
platform: 'state' platform: 'state'
to_state: 'on' to_state: "on"
``` ```
{% configuration %} {% configuration %}
@ -99,20 +99,20 @@ binary_sensor:
entity_id: 'sensor.living_room_motion' entity_id: 'sensor.living_room_motion'
prob_given_true: 0.4 prob_given_true: 0.4
prob_given_false: 0.2 prob_given_false: 0.2
to_state: 'off' to_state: "off"
- platform: 'state' - platform: 'state'
entity_id: 'sensor.basement_motion' entity_id: 'sensor.basement_motion'
prob_given_true: 0.5 prob_given_true: 0.5
prob_given_false: 0.4 prob_given_false: 0.4
to_state: 'off' to_state: "off"
- platform: 'state' - platform: 'state'
entity_id: 'sensor.bedroom_motion' entity_id: 'sensor.bedroom_motion'
prob_given_true: 0.5 prob_given_true: 0.5
to_state: 'on' to_state: "on"
- platform: 'state' - platform: 'state'
entity_id: 'sun.sun' entity_id: 'sun.sun'
prob_given_true: 0.7 prob_given_true: 0.7
to_state: 'below_horizon' to_state: "below_horizon"
``` ```
Next up an example which targets the `numeric_state` observation platform, Next up an example which targets the `numeric_state` observation platform,

View File

@ -108,7 +108,7 @@ The requirement is that you have setup the [`xiaomi aqara` integration](/integra
condition: condition:
- condition: state - condition: state
entity_id: group.family entity_id: group.family
state: 'not_home' state: "not_home"
action: action:
- service: notify.notify_person - service: notify.notify_person
data: data:

View File

@ -171,5 +171,5 @@ calendar:
condition: condition:
- condition: state - condition: state
entity_id: calendar.work_holiday entity_id: calendar.work_holiday
state: 'off' state: "off"
``` ```

View File

@ -186,7 +186,7 @@ Requesting support for additional devices requires the device model (can be acqu
```yaml ```yaml
automation: automation:
- alias: 'Toggle lamp from dimmer' - alias: 'Toggle lamp from dimmer'
initial_state: 'on' initial_state: "on"
trigger: trigger:
platform: event platform: event
event_type: deconz_event event_type: deconz_event
@ -198,7 +198,7 @@ automation:
entity_id: light.lamp entity_id: light.lamp
- alias: 'Increase brightness of lamp from dimmer' - alias: 'Increase brightness of lamp from dimmer'
initial_state: 'on' initial_state: "on"
trigger: trigger:
platform: event platform: event
event_type: deconz_event event_type: deconz_event
@ -214,7 +214,7 @@ automation:
{{ [bri+30, 249] | min }} {{ [bri+30, 249] | min }}
- alias: 'Decrease brightness of lamp from dimmer' - alias: 'Decrease brightness of lamp from dimmer'
initial_state: 'on' initial_state: "on"
trigger: trigger:
platform: event platform: event
event_type: deconz_event event_type: deconz_event
@ -230,7 +230,7 @@ automation:
{{ [bri-30, 0] | max }} {{ [bri-30, 0] | max }}
- alias: 'Turn lamp on when turning cube clockwise' - alias: 'Turn lamp on when turning cube clockwise'
initial_state: 'on' initial_state: "on"
trigger: trigger:
platform: event platform: event
event_type: deconz_event event_type: deconz_event

View File

@ -139,7 +139,7 @@ You can also use the `homeassistant.update_entity` service to update the sensor
```yaml ```yaml
- id: update_morning_commute_sensor - id: update_morning_commute_sensor
alias: "Commute - Update morning commute sensor" alias: "Commute - Update morning commute sensor"
initial_state: 'on' initial_state: "on"
trigger: trigger:
- platform: time_pattern - platform: time_pattern
minutes: '/2' minutes: '/2'

View File

@ -157,7 +157,7 @@ You can also use the `homeassistant.update_entity` service to update the sensor
automation: automation:
- id: update_morning_commute_sensor - id: update_morning_commute_sensor
alias: "Commute - Update morning commute sensor" alias: "Commute - Update morning commute sensor"
initial_state: 'on' initial_state: "on"
trigger: trigger:
- platform: time_pattern - platform: time_pattern
minutes: '/2' minutes: '/2'

View File

@ -32,7 +32,7 @@ sensor:
- platform: history_stats - platform: history_stats
name: Lamp ON today name: Lamp ON today
entity_id: light.my_lamp entity_id: light.my_lamp
state: 'on' state: "on"
type: time type: time
start: '{{ now().replace(hour=0, minute=0, second=0) }}' start: '{{ now().replace(hour=0, minute=0, second=0) }}'
end: '{{ now() }}' end: '{{ now() }}'

View File

@ -79,7 +79,7 @@ automation:
condition: condition:
condition: state condition: state
entity_id: input_boolean.notify_home entity_id: input_boolean.notify_home
state: 'on' state: "on"
action: action:
service: notify.pushbullet service: notify.pushbullet
data: data:

View File

@ -129,7 +129,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: light.some_light entity_id: light.some_light
state: 'off' state: "off"
action: action:
- service: light.turn_on - service: light.turn_on
entity_id: light.some_light entity_id: light.some_light
@ -145,7 +145,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: light.some_light entity_id: light.some_light
state: 'off' state: "off"
action: action:
- service: light.turn_on - service: light.turn_on
entity_id: light.some_light entity_id: light.some_light
@ -390,7 +390,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: light.some_light entity_id: light.some_light
state: 'off' state: "off"
action: action:
- service: light.turn_on - service: light.turn_on
entity_id: light.some_light entity_id: light.some_light
@ -406,7 +406,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: light.some_light entity_id: light.some_light
state: 'off' state: "off"
action: action:
- service: light.turn_on - service: light.turn_on
entity_id: light.some_light entity_id: light.some_light

View File

@ -204,7 +204,7 @@ Example automation using these IR codes to toggle a Sonoff plug.
```yaml ```yaml
# Example kira_sensor # Example kira_sensor
- id: '1583339338363' - id: "1583339338363"
alias: Panasonic On alias: Panasonic On
description: Turn on sonoff s20 relay description: Turn on sonoff s20 relay
trigger: trigger:
@ -217,8 +217,8 @@ Example automation using these IR codes to toggle a Sonoff plug.
domain: switch domain: switch
entity_id: switch.plug2_relay entity_id: switch.plug2_relay
type: turn_on type: turn_on
- id: '1584035716024' - id: "1584035716024"
alias: 'Panaxonic Off ' alias: "Panaxonic Off "
description: Turn off sonoff s20 relay description: Turn off sonoff s20 relay
trigger: trigger:
- entity_id: sensor.kira_wireless - entity_id: sensor.kira_wireless

View File

@ -72,7 +72,7 @@ Alternatively, if you want to use the [XKNX](https://xknx.io/) library abstracti
```yaml ```yaml
knx: knx:
config_file: '/path/to/xknx.yaml' config_file: "/path/to/xknx.yaml"
``` ```
{% configuration %} {% configuration %}
@ -107,9 +107,9 @@ If the auto detection of the KNX/IP device does not work, you can specify IP and
```yaml ```yaml
knx: knx:
tunneling: tunneling:
host: '192.168.2.23' host: "192.168.2.23"
port: 3671 port: 3671
local_ip: '192.168.2.109' local_ip: "192.168.2.109"
``` ```
{% configuration %} {% configuration %}
@ -132,7 +132,7 @@ Explicit connection to a KNX/IP routing device:
```yaml ```yaml
knx: knx:
routing: routing:
local_ip: '192.168.2.109' local_ip: "192.168.2.109"
``` ```
{% configuration %} {% configuration %}
@ -197,28 +197,28 @@ KNX integration is able to expose entity states or attributes to KNX bus. The in
# Example configuration.yaml entry # Example configuration.yaml entry
knx: knx:
expose: expose:
- type: 'temperature' - type: "temperature"
entity_id: 'sensor.owm_temperature' entity_id: "sensor.owm_temperature"
address: '0/0/2' address: "0/0/2"
- type: 'string' - type: "string"
address: '0/6/4' address: "0/6/4"
entity_id: "sensor.owm_weather" entity_id: "sensor.owm_weather"
- type: 'binary' - type: "binary"
entity_id: 'binary_sensor.kitchen_window' entity_id: "binary_sensor.kitchen_window"
address: '0/6/5' address: "0/6/5"
- type: 'binary' - type: "binary"
entity_id: 'light.office' entity_id: "light.office"
address: '0/3/0' address: "0/3/0"
default: false default: false
- type: 'percentU8' - type: "percentU8"
entity_id: 'light.office' entity_id: "light.office"
attribute: 'brightness' attribute: "brightness"
default: 0 default: 0
address: '0/3/1' address: "0/3/1"
- type: 'time' - type: "time"
address: '0/0/1' address: "0/0/1"
- type: 'datetime' - type: "datetime"
address: '0/0/23' address: "0/0/23"
``` ```
{% configuration %} {% configuration %}
@ -261,7 +261,7 @@ To use your binary sensors please add the relevant configuration to your top lev
knx: knx:
binary_sensor: binary_sensor:
- name: sensor1 - name: sensor1
state_address: '6/0/2' state_address: "6/0/2"
``` ```
{% configuration %} {% configuration %}
@ -321,7 +321,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: binary_sensor.cover_abstell entity_id: binary_sensor.cover_abstell
state: 'on' state: "on"
action: action:
- entity_id: light.hue_color_lamp_1 - entity_id: light.hue_color_lamp_1
service: light.turn_on service: light.turn_on
@ -334,7 +334,7 @@ automation:
condition: condition:
- condition: state - condition: state
entity_id: binary_sensor.cover_abstell entity_id: binary_sensor.cover_abstell
state: 'on' state: "on"
action: action:
- entity_id: light.hue_bloom_1 - entity_id: light.hue_bloom_1
service: homeassistant.turn_on service: homeassistant.turn_on
@ -374,12 +374,12 @@ To use your KNX thermostats in your installation, add the following lines to you
knx: knx:
climate: climate:
- name: HASS-Kitchen.Temperature - name: HASS-Kitchen.Temperature
temperature_address: '5/1/1' temperature_address: "5/1/1"
setpoint_shift_address: '5/1/2' setpoint_shift_address: "5/1/2"
setpoint_shift_state_address: '5/1/3' setpoint_shift_state_address: "5/1/3"
target_temperature_state_address: '5/1/4' target_temperature_state_address: "5/1/4"
operation_mode_address: '5/1/5' operation_mode_address: "5/1/5"
operation_mode_state_address: '5/1/6' operation_mode_state_address: "5/1/6"
``` ```
Alternatively, if your device has dedicated binary group addresses for frost/night/comfort mode: Alternatively, if your device has dedicated binary group addresses for frost/night/comfort mode:
@ -389,14 +389,14 @@ Alternatively, if your device has dedicated binary group addresses for frost/nig
knx: knx:
climate: climate:
- name: HASS-Kitchen.Temperature - name: HASS-Kitchen.Temperature
temperature_address: '5/1/1' temperature_address: "5/1/1"
setpoint_shift_address: '5/1/2' setpoint_shift_address: "5/1/2"
setpoint_shift_state_address: '5/1/3' setpoint_shift_state_address: "5/1/3"
target_temperature_state_address: '5/1/4' target_temperature_state_address: "5/1/4"
operation_mode_frost_protection_address: '5/1/5' operation_mode_frost_protection_address: "5/1/5"
operation_mode_night_address: '5/1/6' operation_mode_night_address: "5/1/6"
operation_mode_comfort_address: '5/1/7' operation_mode_comfort_address: "5/1/7"
operation_mode_state_address: '5/1/8' operation_mode_state_address: "5/1/8"
``` ```
If your device doesn't support setpoint_shift calculations (i.e., if you don't provide a `setpoint_shift_address` value) please set the `min_temp` and `max_temp` If your device doesn't support setpoint_shift calculations (i.e., if you don't provide a `setpoint_shift_address` value) please set the `min_temp` and `max_temp`
@ -407,14 +407,14 @@ attributes of the climate device to avoid issues with exceeding valid temperatur
knx: knx:
climate: climate:
- name: HASS-Kitchen.Temperature - name: HASS-Kitchen.Temperature
temperature_address: '5/1/2' temperature_address: "5/1/2"
target_temperature_address: '5/1/4' target_temperature_address: "5/1/4"
target_temperature_state_address: '5/1/1' target_temperature_state_address: "5/1/1"
operation_mode_frost_protection_address: '5/1/5' operation_mode_frost_protection_address: "5/1/5"
operation_mode_night_address: '5/1/6' operation_mode_night_address: "5/1/6"
operation_mode_comfort_address: '5/1/7' operation_mode_comfort_address: "5/1/7"
operation_mode_state_address: '5/1/8' operation_mode_state_address: "5/1/8"
operation_mode_standby_address: '5/1/9' operation_mode_standby_address: "5/1/9"
min_temp: 7.0 min_temp: 7.0
max_temp: 32.0 max_temp: 32.0
``` ```
@ -431,13 +431,13 @@ Example:
knx: knx:
climate: climate:
- name: HASS-Kitchen.Temperature - name: HASS-Kitchen.Temperature
temperature_address: '5/1/1' temperature_address: "5/1/1"
setpoint_shift_address: '5/1/2' setpoint_shift_address: "5/1/2"
setpoint_shift_state_address: '5/1/3' setpoint_shift_state_address: "5/1/3"
setpoint_shift_mode: 'DPT9002' setpoint_shift_mode: "DPT9002"
target_temperature_state_address: '5/1/4' target_temperature_state_address: "5/1/4"
operation_mode_address: '5/1/5' operation_mode_address: "5/1/5"
operation_mode_state_address: '5/1/6' operation_mode_state_address: "5/1/6"
``` ```
`operation_mode_frost_protection_address` / `operation_mode_night_address` / `operation_mode_comfort_address` / `operation_mode_standby_address` are not necessary if `operation_mode_address` is specified. `operation_mode_frost_protection_address` / `operation_mode_night_address` / `operation_mode_comfort_address` / `operation_mode_standby_address` are not necessary if `operation_mode_address` is specified.
@ -601,11 +601,11 @@ To use your KNX covers in your installation, add the following lines to your top
knx: knx:
cover: cover:
- name: "Kitchen.Shutter" - name: "Kitchen.Shutter"
move_long_address: '3/0/0' move_long_address: "3/0/0"
move_short_address: '3/0/1' move_short_address: "3/0/1"
stop_address: '3/0/4' stop_address: "3/0/4"
position_address: '3/0/3' position_address: "3/0/3"
position_state_address: '3/0/2' position_state_address: "3/0/2"
travelling_time_down: 51 travelling_time_down: 51
travelling_time_up: 61 travelling_time_up: 61
``` ```
@ -687,8 +687,8 @@ To use your KNX light in your installation, add the following lines to your top
# Example configuration.yaml entry # Example configuration.yaml entry
knx: knx:
light: light:
- name: 'kitchen' - name: "kitchen"
address: '1/0/9' address: "1/0/9"
``` ```
{% configuration %} {% configuration %}
@ -766,36 +766,36 @@ knx:
light: light:
# dimmable light # dimmable light
- name: Bedroom-Light-1 - name: Bedroom-Light-1
address: '1/0/9' address: "1/0/9"
state_address: '1/1/9' state_address: "1/1/9"
brightness_address: '1/2/9' brightness_address: "1/2/9"
brightness_state_address: '1/3/9' brightness_state_address: "1/3/9"
# #
# RGB light # RGB light
- name: Bathroom-Light-1 - name: Bathroom-Light-1
address: '1/0/9' address: "1/0/9"
state_address: '1/1/9' state_address: "1/1/9"
brightness_address: '1/2/9' brightness_address: "1/2/9"
brightness_state_address: '1/3/9' brightness_state_address: "1/3/9"
color_address: '1/4/9' color_address: "1/4/9"
color_state_address: '1/5/9' color_state_address: "1/5/9"
# #
# tunable white light # tunable white light
- name: Office-Light-1 - name: Office-Light-1
address: '1/0/21' address: "1/0/21"
state_address: '1/1/21' state_address: "1/1/21"
brightness_address: '1/2/21' brightness_address: "1/2/21"
brightness_state_address: '1/3/21' brightness_state_address: "1/3/21"
color_temperature_address: '1/4/21' color_temperature_address: "1/4/21"
color_temperature_state_address: '1/5/21' color_temperature_state_address: "1/5/21"
color_temperature_mode: absolute color_temperature_mode: absolute
min_kelvin: 2550 min_kelvin: 2550
max_kelvin: 6200 max_kelvin: 6200
# #
# actuator without dedicated state communication object # actuator without dedicated state communication object
- name: Cellar-Light-1 - name: Cellar-Light-1
address: '1/0/5' address: "1/0/5"
state_address: '1/0/5' state_address: "1/0/5"
``` ```
## Notify ## Notify
@ -810,7 +810,7 @@ To use your KNX switch in your installation, add the following lines to your top
knx: knx:
notify: notify:
- name: Alarm - name: Alarm
address: '5/1/10' address: "5/1/10"
``` ```
{% configuration %} {% configuration %}
@ -872,7 +872,7 @@ To use your KNX sensor in your installation, add the following lines to your top
knx: knx:
sensor: sensor:
- name: Heating.Valve1 - name: Heating.Valve1
state_address: '2/0/0' state_address: "2/0/0"
``` ```
In order to actively read the sensor data from the bus all 30 minutes you can add the following lines to your `configuration.yaml`: In order to actively read the sensor data from the bus all 30 minutes you can add the following lines to your `configuration.yaml`:
@ -882,7 +882,7 @@ In order to actively read the sensor data from the bus all 30 minutes you can ad
knx: knx:
sensor: sensor:
- name: Heating.Valve1 - name: Heating.Valve1
state_address: '2/0/0' state_address: "2/0/0"
sync_state: every 30 sync_state: every 30
``` ```
@ -1058,13 +1058,13 @@ always_callback:
knx: knx:
sensor: sensor:
- name: Heating.Valve1 - name: Heating.Valve1
state_address: '2/0/0' state_address: "2/0/0"
sync_state: init sync_state: init
type: 'percent' type: "percent"
- name: Kitchen.Temperature - name: Kitchen.Temperature
state_address: '6/2/1' state_address: "6/2/1"
sync_state: every 60 sync_state: every 60
type: 'temperature' type: "temperature"
``` ```
## Switch ## Switch
@ -1079,7 +1079,7 @@ To use your KNX switch in your installation, add the following lines to your top
knx: knx:
switch: switch:
- name: Kitchen.Coffee - name: Kitchen.Coffee
address: '1/1/6' address: "1/1/6"
``` ```
{% configuration %} {% configuration %}

View File

@ -261,19 +261,19 @@ konnected:
binary_sensors: binary_sensors:
- zone: 1 - zone: 1
type: door type: door
name: 'Front Door' name: "Front Door"
- zone: 2 - zone: 2
type: smoke type: smoke
name: 'Bedroom Smoke Detector' name: "Bedroom Smoke Detector"
inverse: true inverse: true
- zone: 3 - zone: 3
type: motion type: motion
name: 'Test Motion' name: "Test Motion"
switches: switches:
- zone: out - zone: out
name: siren name: siren
- zone: 5 - zone: 5
name: 'Beep Beep' name: "Beep Beep"
momentary: 65 momentary: 65
pause: 55 pause: 55
repeat: 4 repeat: 4

View File

@ -115,18 +115,18 @@ To add a notification sound, icon, cycles, or priority override, it has to be do
trigger: trigger:
platform: state platform: state
entity_id: device_tracker.son_mobile entity_id: device_tracker.son_mobile
from: 'not_home' from: "not_home"
to: 'school' to: "school"
action: action:
service: notify.lametric service: notify.lametric
data: data:
message: "Son has arrived at school!" message: "Son has arrived at school!"
data: data:
sound: 'notification' sound: "notification"
icon: 'i51' icon: "i51"
cycles: 0 cycles: 0
priority: 'critical' priority: "critical"
icon_type: 'none' icon_type: "none"
``` ```
### Only notify specific device ### Only notify specific device
@ -140,8 +140,8 @@ If you have more than one La Metric device, you can specify which will receive t
message: "Son has arrived at school!" message: "Son has arrived at school!"
target: "Office LaMetric" target: "Office LaMetric"
data: data:
sound: 'notification' sound: "notification"
icon: 'i51' icon: "i51"
``` ```
If target is not specified, all LaMetric devices will be notified. If target is not specified, all LaMetric devices will be notified.

View File

@ -183,7 +183,7 @@ climates:
description: "Measurement unit ([VAR_UNIT](#variables-and-units))." description: "Measurement unit ([VAR_UNIT](#variables-and-units))."
required: false required: false
type: string type: string
default: 'celsius' default: "celsius"
min_temp: min_temp:
description: "Minimum target temperature." description: "Minimum target temperature."
required: false required: false
@ -302,7 +302,7 @@ sensors:
description: "Measurement unit ([VAR_UNIT](#variables-and-units))." description: "Measurement unit ([VAR_UNIT](#variables-and-units))."
required: false required: false
type: string type: string
default: 'native' default: "native"
switches: switches:
description: List of your switches. description: List of your switches.

View File

@ -53,7 +53,7 @@ However, if you want to fully control a light effect, you have to use its dedica
```yaml ```yaml
script: script:
colorloop_start: colorloop_start:
alias: 'Start colorloop' alias: "Start colorloop"
sequence: sequence:
- service: lifx.effect_colorloop - service: lifx.effect_colorloop
data: data:

View File

@ -118,9 +118,9 @@ entity_id: media_player.chromecast
service: media_player.play_media service: media_player.play_media
data: data:
media_content_type: music media_content_type: music
media_content_id: 'https://fake-home-assistant.io.stream/aac' media_content_id: "https://fake-home-assistant.io.stream/aac"
extra: extra:
thumb: 'https://brands.home-assistant.io/_/homeassistant/logo.png' thumb: "https://brands.home-assistant.io/_/homeassistant/logo.png"
title: HomeAssitantRadio title: HomeAssitantRadio
``` ```

View File

@ -42,8 +42,8 @@ To add Météo-France to your installation, add the following to your `configura
```yaml ```yaml
# Example configuration.yaml entry for 2 cities # Example configuration.yaml entry for 2 cities
meteo_france: meteo_france:
- city: '76000' - city: "76000"
- city: 'Auch' - city: "Auch"
``` ```
{% configuration %} {% configuration %}

View File

@ -21,8 +21,8 @@ To enable this binary sensor, add the following lines to your `configuration.yam
```yaml ```yaml
binary_sensor: binary_sensor:
- platform: meteoalarm - platform: meteoalarm
country: 'NL' country: "NL"
province: 'Groningen' province: "Groningen"
``` ```
{% configuration %} {% configuration %}
@ -43,7 +43,7 @@ language:
description: "The 2 letters of your language, please be aware that this is only possible in the current country. So 'ne' is only possible in Netherlands. Possible options are: bu, bs, ce, da, de, ee, en, es, ga, ca, su, fr, gr, he, hr, ma, is, it, li, la, sr, mk, ma, ne, no, po, pt, ro, cp, sv, sl, eu." description: "The 2 letters of your language, please be aware that this is only possible in the current country. So 'ne' is only possible in Netherlands. Possible options are: bu, bs, ce, da, de, ee, en, es, ga, ca, su, fr, gr, he, hr, ma, is, it, li, la, sr, mk, ma, ne, no, po, pt, ro, cp, sv, sl, eu."
required: false required: false
type: string type: string
default: 'en' default: "en"
{% endconfiguration %} {% endconfiguration %}

View File

@ -67,7 +67,7 @@ via the Frontend, a script, or the REST API.
```yaml ```yaml
service: microsoft_face.create_group service: microsoft_face.create_group
data: data:
name: 'Family' name: "Family"
``` ```
- *microsoft_face.create_person* - *microsoft_face.create_person*
@ -77,7 +77,7 @@ data:
service: microsoft_face.create_person service: microsoft_face.create_person
data: data:
group: family group: family
name: 'Hans Maier' name: "Hans Maier"
``` ```
You need to add an image of a person. You can add multiple images for every You need to add an image of a person. You can add multiple images for every
@ -90,7 +90,7 @@ send a local image to your Azure resource.
service: microsoft_face.face_person service: microsoft_face.face_person
data: data:
group: family group: family
name: 'Hans Maier' name: "Hans Maier"
camera_entity: camera.door camera_entity: camera.door
``` ```

View File

@ -57,7 +57,7 @@ To use your Mi Flora plant sensor in your installation, add the following to you
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: miflora - platform: miflora
mac: 'xx:xx:xx:xx:xx:xx' mac: "xx:xx:xx:xx:xx:xx"
monitored_conditions: monitored_conditions:
- moisture - moisture
``` ```
@ -122,7 +122,7 @@ A full configuration example could look like the one below:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: miflora - platform: miflora
mac: 'xx:xx:xx:xx:xx:xx' mac: "xx:xx:xx:xx:xx:xx"
name: Flower 1 name: Flower 1
force_update: true force_update: true
median: 3 median: 3

View File

@ -92,13 +92,13 @@ automation:
event_data: event_data:
event_type: created event_type: created
action: action:
- delay: '00:00:01' - delay: "00:00:01"
- service: minio.put - service: minio.put
data: data:
file_path: "{{ trigger.event.data.path }}" file_path: "{{ trigger.event.data.path }}"
bucket: "camera-image-object-detection" bucket: "camera-image-object-detection"
key: "input/{{ now().year }}/{{ (now().month | string).zfill(2) }}/{{ (now().day | string).zfill(2) }}/{{ trigger.event.data.file }}" key: "input/{{ now().year }}/{{ (now().month | string).zfill(2) }}/{{ (now().day | string).zfill(2) }}/{{ trigger.event.data.file }}"
- delay: '00:00:01' - delay: "00:00:01"
- service: shell_command.remove_file - service: shell_command.remove_file
data: data:
file: "{{ trigger.event.data.path }}" file: "{{ trigger.event.data.path }}"

View File

@ -49,7 +49,7 @@ To use your Mi Temperature and Humidity sensor in your installation, add the fol
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: mitemp_bt - platform: mitemp_bt
mac: 'xx:xx:xx:xx:xx:xx' mac: "xx:xx:xx:xx:xx:xx"
monitored_conditions: monitored_conditions:
- temperature - temperature
``` ```
@ -118,7 +118,7 @@ A full configuration example could look like the one below:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: mitemp_bt - platform: mitemp_bt
mac: 'xx:xx:xx:xx:xx:xx' mac: "xx:xx:xx:xx:xx:xx"
name: Kids Room Temp name: Kids Room Temp
force_update: true force_update: true
median: 1 median: 1

View File

@ -77,7 +77,7 @@ automation:
action: action:
service: notify.notify service: notify.notify
data: data:
message: 'Call from {{ state_attr('sensor.modem_callerid', 'cid_name') }} at {{ state_attr('sensor.modem_callerid', 'cid_number') }} ' message: "Call from {{ state_attr('sensor.modem_callerid', 'cid_name') }} at {{ state_attr('sensor.modem_callerid', 'cid_number') }} "
- alias: Notify CallerID webui - alias: Notify CallerID webui
trigger: trigger:
platform: state platform: state
@ -87,7 +87,7 @@ automation:
service: persistent_notification.create service: persistent_notification.create
data: data:
title: "Call from" title: "Call from"
message: '{{ state_attr('sensor.modem_callerid', 'cid_time').strftime("%I:%M %p") }} {{ state_attr('sensor.modem_callerid', 'cid_name') }} {{ state_attr('sensor.modem_callerid', 'cid_number') }} ' message: "{{ state_attr('sensor.modem_callerid', 'cid_time').strftime("%I:%M %p") }} {{ state_attr('sensor.modem_callerid', 'cid_name') }} {{ state_attr('sensor.modem_callerid', 'cid_number') }} "
- alias: Say CallerID - alias: Say CallerID
trigger: trigger:
platform: state platform: state
@ -96,7 +96,7 @@ automation:
action: action:
service: tts.google_say service: tts.google_say
data: data:
message: 'Call from {{ state_attr('sensor.modem_callerid', 'cid_name') }}' message: "Call from {{ state_attr('sensor.modem_callerid', 'cid_name') }}"
``` ```
{% endraw %} {% endraw %}

View File

@ -74,14 +74,14 @@ sensor:
- station: Hauptbahnhof - station: Hauptbahnhof
name: Hbf name: Hbf
destinations: ['München Flughafen Terminal','Markt Schwaben'] destinations: ['München Flughafen Terminal','Markt Schwaben']
products: 'S-Bahn' products: "S-Bahn"
timeoffset: 2 timeoffset: 2
- station: Sendlinger Tor - station: Sendlinger Tor
lines: ['U2','U8'] lines: ['U2','U8']
number: 5 number: 5
- station: Scheidplatz - station: Scheidplatz
products: ['U-Bahn'] products: ['U-Bahn']
directions: '1' directions: "1"
``` ```
The first sensor will return S-Bahn departures to Munich Airport or Markt Schwaben that are at least 2 minutes away. The first sensor will return S-Bahn departures to Munich Airport or Markt Schwaben that are at least 2 minutes away.

View File

@ -20,7 +20,7 @@ Integrate your Serial, Ethernet (LAN) or MQTT MySensors Gateway by adding the fo
# Example configuration.yaml entry # Example configuration.yaml entry
mysensors: mysensors:
gateways: gateways:
- device: '/dev/ttyUSB0' - device: "/dev/ttyUSB0"
``` ```
{% configuration %} {% configuration %}
@ -52,12 +52,12 @@ mysensors:
description: Set the prefix of the MQTT topic for messages coming from the MySensors gateway in to Home Assistant. description: Set the prefix of the MQTT topic for messages coming from the MySensors gateway in to Home Assistant.
required: false required: false
type: string type: string
default: '' default: ""
topic_out_prefix: topic_out_prefix:
description: Set the prefix of the MQTT topic for messages going from Home Assistant out to the MySensors gateway. description: Set the prefix of the MQTT topic for messages going from Home Assistant out to the MySensors gateway.
required: false required: false
type: string type: string
default: '' default: ""
nodes: nodes:
description: A mapping of node ids to node settings, e.g., custom name. description: A mapping of node ids to node settings, e.g., custom name.
required: false required: false
@ -76,7 +76,7 @@ mysensors:
description: Specifies the MySensors protocol version to use. Supports versions 1.4 to 2.3. description: Specifies the MySensors protocol version to use. Supports versions 1.4 to 2.3.
required: false required: false
type: string type: string
default: '1.4' default: "1.4"
optimistic: optimistic:
description: Enable or disable optimistic mode for actuators (switch/light). Set this to true if no state feedback from actuators is possible. Home Assistant will assume that the command succeeded and change state. description: Enable or disable optimistic mode for actuators (switch/light). Set this to true if no state feedback from actuators is possible. Home Assistant will assume that the command succeeded and change state.
required: false required: false
@ -116,28 +116,28 @@ The MQTT gateway requires MySensors version 2.0+ and only the MQTT client gatewa
# Example configuration.yaml entry # Example configuration.yaml entry
mysensors: mysensors:
gateways: gateways:
- device: '/dev/ttyUSB0' - device: "/dev/ttyUSB0"
persistence_file: 'path/mysensors.json' persistence_file: "path/mysensors.json"
baud_rate: 38400 baud_rate: 38400
nodes: nodes:
1: 1:
name: 'kitchen' name: "kitchen"
3: 3:
name: 'living_room' name: "living_room"
- device: '/dev/ttyACM0' - device: "/dev/ttyACM0"
persistence_file: 'path/mysensors2.json' persistence_file: "path/mysensors2.json"
baud_rate: 115200 baud_rate: 115200
- device: '192.168.1.18' - device: "192.168.1.18"
persistence_file: 'path/mysensors3.json' persistence_file: "path/mysensors3.json"
tcp_port: 5003 tcp_port: 5003
- device: mqtt - device: mqtt
persistence_file: 'path/mysensors4.json' persistence_file: "path/mysensors4.json"
topic_in_prefix: 'mygateway1-out' topic_in_prefix: "mygateway1-out"
topic_out_prefix: 'mygateway1-in' topic_out_prefix: "mygateway1-in"
optimistic: false optimistic: false
persistence: true persistence: true
retain: true retain: true
version: '2.0' version: "2.0"
``` ```
### Presentation ### Presentation

View File

@ -93,6 +93,6 @@ media_player:
min_volume: -60 min_volume: -60
max_volume: -20 max_volume: -20
sources: sources:
1: 'Kodi' 1: "Kodi"
2: 'TV' 2: "TV"
``` ```

View File

@ -29,10 +29,10 @@ sensor:
from: Gn from: Gn
to: Mt to: Mt
via: Zl via: Zl
- name: 'AlmereBuiten-Duivendrecht-the-08h06m-train' - name: "AlmereBuiten-Duivendrecht-the-08h06m-train"
from: Almb from: Almb
to: Dvd to: Dvd
time: '08:06:00' time: "08:06:00"
``` ```
{% configuration %} {% configuration %}

View File

@ -55,7 +55,7 @@ port:
scan_interval: scan_interval:
description: "Time interval between updates. Supported formats: `scan_interval: 'HH:MM:SS'`, `scan_interval: 'HH:MM'` and Time period dictionary (see example below)." description: "Time interval between updates. Supported formats: `scan_interval: 'HH:MM:SS'`, `scan_interval: 'HH:MM'` and Time period dictionary (see example below)."
required: false required: false
default: '00:01:00' default: "00:01:00"
type: time type: time
infer_arming_state: infer_arming_state:
description: Infer the disarmed arming state only via system status events. This works around a bug with some panels (`<v5.8`) which emit `update.status = []` when they are armed. description: Infer the disarmed arming state only via system status events. This works around a bug with some panels (`<v5.8`) which emit `update.status = []` when they are armed.

View File

@ -130,15 +130,15 @@ resources:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: netdata - platform: netdata
host: '192.168.1.2' host: "192.168.1.2"
port: '19999' port: "19999"
name: SomeHostName name: SomeHostName
resources: resources:
system_load: system_load:
data_group: system.load data_group: system.load
element: load15 element: load15
core0_freq: core0_freq:
data_group: 'cpu.cpufreq' data_group: "cpu.cpufreq"
element: 'cpu0' element: "cpu0"
icon: mdi:chip icon: mdi:chip
``` ```

View File

@ -193,11 +193,11 @@ automation:
action: action:
- service: conversation.process - service: conversation.process
data: data:
text: '{{ trigger.event.data.message }}' text: "{{ trigger.event.data.message }}"
- service: netgear_lte.delete_sms - service: netgear_lte.delete_sms
data: data:
host: '{{ trigger.event.data.host }}' host: "{{ trigger.event.data.host }}"
sms_id: '{{ trigger.event.data.sms_id }}' sms_id: "{{ trigger.event.data.sms_id }}"
``` ```
{% endraw %} {% endraw %}

View File

@ -35,16 +35,16 @@ The state is the last reading from Nightscout, and you can see other information
### Example Automation ### Example Automation
```yaml ```yaml
- id: '1234567890123' - id: "1234567890123"
alias: overnight_low_kitchen_lights alias: overnight_low_kitchen_lights
description: Turn on the lights in the kitchen if my blood sugar drops low overnight description: Turn on the lights in the kitchen if my blood sugar drops low overnight
trigger: trigger:
- below: '65' - below: "65"
entity_id: sensor.blood_glucose entity_id: sensor.blood_glucose
platform: numeric_state platform: numeric_state
condition: time condition: time
after: '22:00:00' after: "22:00:00"
before: '06:00:00' before: "06:00:00"
action: action:
- service: light.turn_on - service: light.turn_on
data: data:

View File

@ -83,7 +83,7 @@ You can use the `nissan_leaf.start_charge` service to send a request to the Niss
```yaml ```yaml
- service: nissan_leaf.start_charge - service: nissan_leaf.start_charge
data: data:
vin: '1HGBH41JXMN109186' # replace vin: "1HGBH41JXMN109186" # replace
``` ```
## Updating on-demand using Automation ## Updating on-demand using Automation
@ -92,19 +92,19 @@ You can also use the `nissan_leaf.update` service to request an on-demand update
```yaml ```yaml
- id: update_when_driver_not_home - id: update_when_driver_not_home
alias: 'Update when driver not home' alias: "Update when driver not home"
initial_state: on initial_state: on
trigger: trigger:
- platform: time_pattern - platform: time_pattern
minutes: '/30' minutes: "/30"
condition: condition:
- condition: state - condition: state
entity_id: device_tracker.drivername # replace entity_id: device_tracker.drivername # replace
state: 'not_home' state: "not_home"
action: action:
- service: nissan_leaf.update - service: nissan_leaf.update
data: data:
vin: '1HGBH41JXMN109186' # replace vin: "1HGBH41JXMN109186" # replace
``` ```
## Hints ## Hints

View File

@ -21,7 +21,7 @@ action:
service: notify.mysensors service: notify.mysensors
data: data:
message: Welcome home! message: Welcome home!
target: 'TextSensor 254 1' target: "TextSensor 254 1"
``` ```
The following sensor types are supported: The following sensor types are supported:

View File

@ -80,15 +80,15 @@ Now you can use the `notify.events` service inside your Home Assistant to:
```yaml ```yaml
- service: notify.events - service: notify.events
data: data:
message: 'Backyard motion detected!' message: "Backyard motion detected!"
data: data:
level: 'warning' level: "warning"
priority: 'high' priority: "high"
images: images:
- name: 'local_photo.jpg' - name: "local_photo.jpg"
path: '/tmp/backyard_cam/motion.jpg' path: "/tmp/backyard_cam/motion.jpg"
- name: 'remote_photo.jpg' - name: "remote_photo.jpg"
url: 'https://i.ibb.co/Jt1845X/motion.jpg' url: "https://i.ibb.co/Jt1845X/motion.jpg"
``` ```
### Message optional parameters ### Message optional parameters

View File

@ -87,7 +87,7 @@ Depending on your personal circumstances with regards to bush fire risk you may
# Example configuration.yaml entry # Example configuration.yaml entry
geo_location: geo_location:
- platform: nsw_rural_fire_service_feed - platform: nsw_rural_fire_service_feed
entity_namespace: 'nsw_fire_service_feed' entity_namespace: "nsw_fire_service_feed"
radius: 10 radius: 10
categories: categories:
- 'Emergency Warning' - 'Emergency Warning'

View File

@ -20,7 +20,7 @@ Add a sensor to your `configuration.yaml` file as shown in the example:
sensor: sensor:
- platform: oasa_telematics - platform: oasa_telematics
route_id: YOUR_ROUTE_ID route_id: YOUR_ROUTE_ID
stop_id: 'YOUR_STOP_ID' stop_id: "YOUR_STOP_ID"
``` ```
The `route_id` can be obtained by looking up the "LineCode" of the route you want at this link: The `route_id` can be obtained by looking up the "LineCode" of the route you want at this link:
@ -60,5 +60,5 @@ A more extensive example on how to use this sensor:
sensor: sensor:
- platform: oasa_telematics - platform: oasa_telematics
route_id: 1965 route_id: 1965
stop_id: '090006' stop_id: "090006"
``` ```

View File

@ -23,7 +23,7 @@ media_player:
host: 192.168.1.2 host: 192.168.1.2
name: receiver name: receiver
sources: sources:
pc: 'HTPC' pc: "HTPC"
``` ```
If your receiver has second or third zones available, they are displayed as additional media players with the same functionality as the main zone. If your receiver has second or third zones available, they are displayed as additional media players with the same functionality as the main zone.

View File

@ -97,7 +97,7 @@ sensor:
platform: template platform: template
sensors: sensors:
garage_status: garage_status:
friendly_name: 'Honda Door Status' friendly_name: "Honda Door Status"
value_template: '{% if states.cover.honda %} value_template: '{% if states.cover.honda %}
{% if states.cover.honda.attributes["door_state"] == "open" %} {% if states.cover.honda.attributes["door_state"] == "open" %}
Open Open

View File

@ -45,14 +45,14 @@ To receive notifications of the entering flights using the [Home Assistant Compa
```yaml ```yaml
automation: automation:
- alias: 'Flight entry notification' - alias: "Flight entry notification"
trigger: trigger:
platform: event platform: event
event_type: opensky_entry event_type: opensky_entry
action: action:
service: notify.mobile_app_<device_name> service: notify.mobile_app_<device_name>
data: data:
message: 'Flight entry of {{ trigger.event.data.callsign }}' message: "Flight entry of {{ trigger.event.data.callsign }}"
``` ```
{% endraw %} {% endraw %}

View File

@ -94,7 +94,7 @@ automation:
- alias: Update OpenUV every 30 minutes during the daytime - alias: Update OpenUV every 30 minutes during the daytime
trigger: trigger:
platform: time_pattern platform: time_pattern
minutes: '/30' minutes: "/30"
condition: condition:
condition: and condition: and
conditions: conditions:
@ -115,11 +115,11 @@ automation:
- alias: Update OpenUV every 20 minutes while the sun is at least 10 degrees above the horizon - alias: Update OpenUV every 20 minutes while the sun is at least 10 degrees above the horizon
trigger: trigger:
platform: time_pattern platform: time_pattern
minutes: '/20' minutes: "/20"
condition: condition:
condition: numeric_state condition: numeric_state
entity_id: sun.sun entity_id: sun.sun
value_template: '{{ state.attributes.elevation }}' value_template: "{{ state.attributes.elevation }}"
above: 10 above: 10
action: action:
service: openuv.update_uv_index_data service: openuv.update_uv_index_data
@ -148,7 +148,7 @@ automation:
- alias: Update OpenUV every hour (24 of 50 calls per day) - alias: Update OpenUV every hour (24 of 50 calls per day)
trigger: trigger:
platform: time_pattern platform: time_pattern
minutes: '/60' minutes: "/60"
action: action:
service: openuv.update_data service: openuv.update_data
``` ```

View File

@ -23,14 +23,14 @@ To enable Panel iFrames in your installation, add the following to your `configu
# Example configuration.yaml entry # Example configuration.yaml entry
panel_iframe: panel_iframe:
router: router:
title: 'Router' title: "Router"
url: 'http://192.168.1.1' url: "http://192.168.1.1"
fridge: fridge:
title: 'Fridge' title: "Fridge"
url: 'http://192.168.1.5' url: "http://192.168.1.5"
otherapp: otherapp:
title: 'Other App' title: "Other App"
url: '/otherapp' url: "/otherapp"
``` ```
{% configuration %} {% configuration %}

View File

@ -70,7 +70,7 @@ action:
This automation example shows a notification when the Z-Wave network is starting and removes it when the network is ready. This automation example shows a notification when the Z-Wave network is starting and removes it when the network is ready.
```yaml ```yaml
- alias: 'Z-Wave network is starting' - alias: "Z-Wave network is starting"
trigger: trigger:
- platform: event - platform: event
event_type: zwave.network_start event_type: zwave.network_start
@ -81,7 +81,7 @@ This automation example shows a notification when the Z-Wave network is starting
message: "Z-Wave network is starting..." message: "Z-Wave network is starting..."
notification_id: zwave notification_id: zwave
- alias: 'Z-Wave network is ready' - alias: "Z-Wave network is ready"
trigger: trigger:
- platform: event - platform: event
event_type: zwave.network_ready event_type: zwave.network_ready

View File

@ -68,23 +68,23 @@ Single Pi-hole running via Home Assistant add-on:
```yaml ```yaml
pi_hole: pi_hole:
- host: 'localhost:4865' - host: "localhost:4865"
``` ```
Multiple Pi-holes: Multiple Pi-holes:
```yaml ```yaml
pi_hole: pi_hole:
- host: '192.168.0.2' - host: "192.168.0.2"
- host: '192.168.0.3' - host: "192.168.0.3"
name: 'Secondary Pi-hole' name: "Secondary Pi-hole"
``` ```
Pi-hole with a self-signed certificate: Pi-hole with a self-signed certificate:
```yaml ```yaml
pi_hole: pi_hole:
- host: 'pi.hole' - host: "pi.hole"
ssl: true ssl: true
verify_ssl: false verify_ssl: false
``` ```
@ -93,7 +93,7 @@ Pi-hole with an `api_key` that allows it to be enabled or disabled:
```yaml ```yaml
pi_hole: pi_hole:
- host: 'pi.hole' - host: "pi.hole"
api_key: !secret pi_hole_api_key api_key: !secret pi_hole_api_key
``` ```

View File

@ -46,5 +46,5 @@ The configuration sample below shows how an entry can look like:
# Example configuration.yaml entry # Example configuration.yaml entry
tts: tts:
- platform: picotts - platform: picotts
language: 'fr-FR' language: "fr-FR"
``` ```

View File

@ -85,7 +85,7 @@ To enable a Pilight binary sensor in your installation, add the following to you
# Example configuration.yaml entry # Example configuration.yaml entry
binary_sensor: binary_sensor:
- platform: pilight - platform: pilight
variable: 'state' variable: "state"
``` ```
{% configuration %} {% configuration %}
@ -133,11 +133,11 @@ A full configuration example could look like this:
# Example configuration.yaml entry # Example configuration.yaml entry
binary_sensor: binary_sensor:
- platform: pilight - platform: pilight
name: 'Motion' name: "Motion"
variable: 'state' variable: "state"
payload: payload:
unitcode: 371399 unitcode: 371399
payload_on: 'closed' payload_on: "closed"
disarm_after_trigger: true disarm_after_trigger: true
reset_delay_sec: 30 reset_delay_sec: 30
``` ```
@ -154,7 +154,7 @@ sensor:
- platform: pilight - platform: pilight
variable: temperature variable: temperature
payload: payload:
uuid: '0000-b8-27-eb-f447d3' uuid: "0000-b8-27-eb-f447d3"
``` ```
{% configuration %} {% configuration %}
@ -185,23 +185,23 @@ This section shows a real life example how to use values of a weather station.
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: pilight - platform: pilight
name: 'Temperature' name: "Temperature"
variable: 'temperature' variable: "temperature"
payload: payload:
uuid: 0000-b8-27-eb-f1f72e uuid: 0000-b8-27-eb-f1f72e
unit_of_measurement: '°C' unit_of_measurement: "°C"
- platform: pilight - platform: pilight
name: 'Humidity' name: "Humidity"
variable: 'humidity' variable: "humidity"
payload: payload:
uuid: 0000-b8-27-eb-f1f72e uuid: 0000-b8-27-eb-f1f72e
unit_of_measurement: '%' unit_of_measurement: "%"
- platform: pilight - platform: pilight
name: 'Battery' name: "Battery"
variable: 'battery' variable: "battery"
payload: payload:
uuid: 0000-b8-27-eb-f1f72e uuid: 0000-b8-27-eb-f1f72e
unit_of_measurement: '%' unit_of_measurement: "%"
``` ```
## Switch ## Switch
@ -298,13 +298,13 @@ switch:
systemcode: 14462 systemcode: 14462
unit: 6 unit: 6
id: 34 id: 34
state: 'on' state: "on"
off_code_receive: off_code_receive:
protocol: daycom protocol: daycom
systemcode: 14462 systemcode: 14462
unit: 6 unit: 6
id: 34 id: 34
state: 'off' state: "off"
``` ```
## Light ## Light
@ -349,12 +349,12 @@ light:
protocol: kaku_dimmer protocol: kaku_dimmer
id: 23298822 id: 23298822
unit: 10 unit: 10
state: 'on' state: "on"
off_code_receive: off_code_receive:
protocol: kaku_dimmer protocol: kaku_dimmer
id: 23298822 id: 23298822
unit: 10 unit: 10
state: 'off' state: "off"
``` ```
## Troubleshooting ## Troubleshooting

View File

@ -142,28 +142,28 @@ sensor:
- platform: mqtt - platform: mqtt
name: my_plant_moisture name: my_plant_moisture
state_topic: my_plant_topic state_topic: my_plant_topic
value_template: '{{ value_json.moisture | int }}' value_template: "{{ value_json.moisture | int }}"
unit_of_measurement: '%' unit_of_measurement: "%"
- platform: mqtt - platform: mqtt
name: my_plant_battery name: my_plant_battery
state_topic: my_plant_topic state_topic: my_plant_topic
value_template: '{{ value_json.battery | int }}' value_template: "{{ value_json.battery | int }}"
unit_of_measurement: '%' unit_of_measurement: "%"
- platform: mqtt - platform: mqtt
name: my_plant_temperature name: my_plant_temperature
state_topic: my_plant_topic state_topic: my_plant_topic
value_template: '{{ value_json.temperature | float }}' value_template: "{{ value_json.temperature | float }}"
unit_of_measurement: '°C' unit_of_measurement: "°C"
- platform: mqtt - platform: mqtt
name: my_plant_conductivity name: my_plant_conductivity
state_topic: my_plant_topic state_topic: my_plant_topic
value_template: '{{ value_json.conductivity | int }}' value_template: "{{ value_json.conductivity | int }}"
unit_of_measurement: 'µS/cm' unit_of_measurement: "µS/cm"
- platform: mqtt - platform: mqtt
name: my_plant_brightness name: my_plant_brightness
state_topic: my_plant_topic state_topic: my_plant_topic
value_template: '{{ value_json.brightness | int }}' value_template: "{{ value_json.brightness | int }}"
unit_of_measurement: 'Lux' unit_of_measurement: "Lux"
``` ```
{% endraw %} {% endraw %}

View File

@ -247,17 +247,17 @@ play_plex_on_tv:
- service: media_player.select_source - service: media_player.select_source
entity_id: media_player.smart_tv entity_id: media_player.smart_tv
data: data:
source: 'Plex' source: "Plex"
- wait_template: "{{ is_state('media_player.smart_tv', 'On') }}" - wait_template: "{{ is_state('media_player.smart_tv', 'On') }}"
timeout: '00:00:10' timeout: "00:00:10"
- service: plex.scan_for_clients - service: plex.scan_for_clients
- wait_template: "{{ not is_state('media_player.plex_smart_tv', 'unavailable') }}" - wait_template: "{{ not is_state('media_player.plex_smart_tv', 'unavailable') }}"
timeout: '00:00:10' timeout: "00:00:10"
continue_on_timeout: false continue_on_timeout: false
- service: media_player.play_media - service: media_player.play_media
data: data:
entity_id: media_player.plex_smart_tv entity_id: media_player.plex_smart_tv
media_content_id: '{"library_name": "Movies", "title": "Zoolander"}' media_content_id: "{"library_name": "Movies", "title": "Zoolander"}"
media_content_type: movie media_content_type: movie
``` ```

View File

@ -100,7 +100,7 @@ automation:
trigger: trigger:
- platform: state - platform: state
entity_id: binary_sensor.point_button_press # Change this accordingly entity_id: binary_sensor.point_button_press # Change this accordingly
to: 'on' to: "on"
action: action:
- service: persistent_notification.create - service: persistent_notification.create
data: data:

View File

@ -157,7 +157,7 @@ You can then configure Prometheus to fetch metrics from Home Assistant by adding
```yaml ```yaml
# Example Prometheus scrape_configs entry # Example Prometheus scrape_configs entry
- job_name: 'hass' - job_name: "hass"
scrape_interval: 60s scrape_interval: 60s
metrics_path: /api/prometheus metrics_path: /api/prometheus
@ -166,7 +166,7 @@ You can then configure Prometheus to fetch metrics from Home Assistant by adding
api_password: ['PASSWORD'] api_password: ['PASSWORD']
# Long-Lived Access Token # Long-Lived Access Token
bearer_token: 'your.longlived.token' bearer_token: "your.longlived.token"
scheme: https scheme: https
static_configs: static_configs:

View File

@ -58,21 +58,21 @@ sensor:
- platform: template - platform: template
sensors: sensors:
power_consumption: power_consumption:
value_template: '{% if is_state_attr("sensor.pvoutput", "power_consumption", "NaN") %}0{% else %}{{ state_attr("sensor.pvoutput", "power_consumption") }}{% endif %}' value_template: "{% if is_state_attr("sensor.pvoutput", "power_consumption", "NaN") %}0{% else %}{{ state_attr("sensor.pvoutput", "power_consumption") }}{% endif %}"
friendly_name: 'Using' friendly_name: "Using"
unit_of_measurement: 'Watt' unit_of_measurement: "Watt"
energy_consumption: energy_consumption:
value_template: '{{ "%0.1f"|format(state_attr("sensor.pvoutput", "energy_consumption")|float/1000) }}' value_template: '{{ "%0.1f"|format(state_attr("sensor.pvoutput", "energy_consumption")|float/1000) }}'
friendly_name: 'Used' friendly_name: "Used"
unit_of_measurement: 'kWh' unit_of_measurement: "kWh"
power_generation: power_generation:
value_template: '{% if is_state_attr("sensor.pvoutput", "power_generation", "NaN") %}0{% else %}{{ state_attr("sensor.pvoutput", "power_generation") }}{% endif %}' value_template: '{% if is_state_attr("sensor.pvoutput", "power_generation", "NaN") %}0{% else %}{{ state_attr("sensor.pvoutput", "power_generation") }}{% endif %}'
friendly_name: 'Generating' friendly_name: "Generating"
unit_of_measurement: 'Watt' unit_of_measurement: "Watt"
energy_generation: energy_generation:
value_template: '{% if is_state_attr("sensor.pvoutput", "energy_generation", "NaN") %}0{% else %}{{ "%0.2f"|format(state_attr("sensor.pvoutput", "energy_generation")|float/1000) }}{% endif %}' value_template: '{% if is_state_attr("sensor.pvoutput", "energy_generation", "NaN") %}0{% else %}{{ "%0.2f"|format(state_attr("sensor.pvoutput", "energy_generation")|float/1000) }}{% endif %}'
friendly_name: 'Generated' friendly_name: "Generated"
unit_of_measurement: 'kWh' unit_of_measurement: "kWh"
``` ```
{% endraw %} {% endraw %}

View File

@ -24,7 +24,7 @@ To enable this sensor, add the following lines to your `configuration.yaml`:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: qbittorrent - platform: qbittorrent
url: 'http://<hostname>:<port>' url: "http://<hostname>:<port>"
username: YOUR_USERNAME username: YOUR_USERNAME
password: YOUR_PASSWORD password: YOUR_PASSWORD
``` ```

View File

@ -123,7 +123,7 @@ automation:
- alias: Turn irrigation on - alias: Turn irrigation on
trigger: trigger:
platform: time platform: time
at: '5:30:00' at: "5:30:00"
action: action:
service: rainbird.start_irrigation service: rainbird.start_irrigation
entity_id: switch.sprinkler_1 entity_id: switch.sprinkler_1

View File

@ -24,8 +24,8 @@ To enable this switch, add the following lines to your `configuration.yaml`:
# Example configuration.yaml entry # Example configuration.yaml entry
switch: switch:
- platform: recswitch - platform: recswitch
host: 'IP_ADDRESS' host: "IP_ADDRESS"
mac: 'MAC_ADDRESS' mac: "MAC_ADDRESS"
``` ```
{% configuration %} {% configuration %}

View File

@ -20,7 +20,7 @@ Add a sensor to your `configuration.yaml` file as shown in the example:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: rejseplanen - platform: rejseplanen
stop_id: 'YOUR_STOP_ID' stop_id: "YOUR_STOP_ID"
``` ```
{% configuration %} {% configuration %}
@ -94,7 +94,7 @@ A working example on how to use this sensor with direction:
# Example configuration.yaml entry with the correct use of direction. # Example configuration.yaml entry with the correct use of direction.
sensor: sensor:
- platform: rejseplanen - platform: rejseplanen
stop_id: '713000702' stop_id: "713000702"
direction: direction:
- 'Bjergegårdsvej/Rylevej (Favrskov Kom)' - 'Bjergegårdsvej/Rylevej (Favrskov Kom)'
- 'Skanderborg Busterminal (Skanderborg Kom)' - 'Skanderborg Busterminal (Skanderborg Kom)'
@ -126,9 +126,9 @@ A more extensive example on how to use this sensor:
# Example configuration.yaml entry # Example configuration.yaml entry
sensor: sensor:
- platform: rejseplanen - platform: rejseplanen
name: 'Elmegade 350S' name: "Elmegade 350S"
stop_id: '000045740' stop_id: "000045740"
route: 'Bus 350S' route: "Bus 350S"
direction: direction:
- 'Herlev St.' - 'Herlev St.'
- 'Ballerup St.' - 'Ballerup St.'

View File

@ -27,7 +27,7 @@ sensor:
- platform: rest - platform: rest
resource: http://IP_ADDRESS/ENDPOINT resource: http://IP_ADDRESS/ENDPOINT
method: POST method: POST
payload: '{ "device" : "heater" }' payload: "{ "device" : "heater" }"
``` ```
or a template based request: or a template based request:

View File

@ -19,7 +19,7 @@ To use this component, add the following lines to your `configuration.yaml` file
# Example configuration.yaml entry # Example configuration.yaml entry
rest_command: rest_command:
example_request: example_request:
url: 'http://example.com/' url: "http://example.com/"
``` ```
{% configuration %} {% configuration %}
@ -105,7 +105,7 @@ rest_command:
method: POST method: POST
headers: headers:
authorization: !secret rest_headers_secret authorization: !secret rest_headers_secret
accept: 'application/json, text/html' accept: "application/json, text/html"
user-agent: 'Mozilla/5.0 {{ useragent }}' user-agent: 'Mozilla/5.0 {{ useragent }}'
payload: '{"profile":{"status_text": "{{ status }}","status_emoji": "{{ emoji }}"}}' payload: '{"profile":{"status_text": "{{ status }}","status_emoji": "{{ emoji }}"}}'
content_type: 'application/json; charset=utf-8' content_type: 'application/json; charset=utf-8'
@ -129,7 +129,7 @@ Call the new service from [developer tools](/docs/tools/dev-tools/) in the sideb
```yaml ```yaml
automation: automation:
- alias: 'Arrive at Work' - alias: "Arrive at Work"
trigger: trigger:
platform: zone platform: zone
entity_id: device_tracker.my_device entity_id: device_tracker.my_device

View File

@ -210,7 +210,7 @@ script:
sequence: sequence:
- condition: state - condition: state
entity_id: switch.pushover_notifications entity_id: switch.pushover_notifications
state: 'on' state: "on"
- service: notify.pushover - service: notify.pushover
data: data:
title: "{% raw %}{{ title }}{% endraw %}" title: "{% raw %}{{ title }}{% endraw %}"

View File

@ -125,18 +125,18 @@ The actual linking can be realized by two automation rules. One rule to control
conditions: conditions:
- condition: state - condition: state
entity_id: light.led_push_button_10 entity_id: light.led_push_button_10
state: 'on' state: "on"
- condition: state - condition: state
entity_id: light.living entity_id: light.living
state: 'off' state: "off"
- condition: and - condition: and
conditions: conditions:
- condition: state - condition: state
entity_id: light.led_push_button_10 entity_id: light.led_push_button_10
state: 'off' state: "off"
- condition: state - condition: state
entity_id: light.living entity_id: light.living
state: 'on' state: "on"
- entity_id: light.led_push_button_10 - entity_id: light.led_push_button_10
service: light.toggle service: light.toggle
``` ```

View File

@ -138,7 +138,7 @@ automation:
condition: condition:
condition: state condition: state
entity_id: 'binary_sensor.workday_sensor' entity_id: 'binary_sensor.workday_sensor'
state: 'on' state: "on"
action: action:
service: switch.turn_on service: switch.turn_on
entity_id: switch.heater entity_id: switch.heater

View File

@ -591,9 +591,9 @@ elements:
- type: conditional - type: conditional
conditions: conditions:
- entity: sensor.presence_daughter - entity: sensor.presence_daughter
state: 'home' state: "home"
- entity: sensor.presence_dad - entity: sensor.presence_dad
state: 'not_home' state: "not_home"
elements: elements:
- type: state-icon - type: state-icon
entity: switch.tv entity: switch.tv