473 lines
23 KiB
XML
473 lines
23 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
||
<feed xmlns="http://www.w3.org/2005/Atom">
|
||
|
||
<title><![CDATA[Category: How-To | Home Assistant]]></title>
|
||
<link href="https://home-assistant.io/blog/categories/how-to/atom.xml" rel="self"/>
|
||
<link href="https://home-assistant.io/"/>
|
||
<updated>2017-09-03T11:39:35+00:00</updated>
|
||
<id>https://home-assistant.io/</id>
|
||
<author>
|
||
<name><![CDATA[Home Assistant]]></name>
|
||
|
||
</author>
|
||
<generator uri="http://octopress.org/">Octopress</generator>
|
||
|
||
|
||
<entry>
|
||
<title type="html"><![CDATA[Home Assistant on an Orange Pi Zero]]></title>
|
||
<link href="https://home-assistant.io/blog/2017/05/13/home-assistant-on-orange-pi-zero/"/>
|
||
<updated>2017-05-13T09:00:00+00:00</updated>
|
||
<id>https://home-assistant.io/blog/2017/05/13/home-assistant-on-orange-pi-zero</id>
|
||
<content type="html"><. Like the setup on a [Raspberry Pi Zero](/blog/2017/05/01/home-assistant-on-raspberry-pi-zero-in-30-minutes/) it will only take a couple of minutes to get a fully functional super cheap (less than 18 Euro incl. casing and power supply) Home Assistant hub. The reasons to use an Orange Pi Zero beside the prize are the built-in Ethernet port and the availability.
|
||
|
||
<p class="img">
|
||
<img src="/images/blog/2017-05-orangepi/orangie-pi-setup.png" />
|
||
</p>
|
||
|
||
<!--more-->
|
||
|
||
Download the [Armbian](https://www.armbian.com/orange-pi-zero/) and create the SD card with [Etcher](https://etcher.io/). There is no possibility to connect a display to the Orange Pi Zero. This means that you need a wired network setup with DHCP server. After your Orange Pi Zero is running, give it some time, and look for its IP address. The hostname is `orangepizero`.
|
||
|
||
If you found the IP address then use your SSH client to connect to the Orange Pi Zero. The default password is `1234`.
|
||
|
||
```bash
|
||
$ ssh root@192.168.0.151
|
||
[...]
|
||
root@192.168.0.151's password:
|
||
You are required to change your password immediately (root enforced)
|
||
___ ____ _ _____
|
||
/ _ \ _ __ __ _ _ __ __ _ ___ | _ \(_) |__ /___ _ __ ___
|
||
| | | | '__/ _` | '_ \ / _` |/ _ \ | |_) | | / // _ \ '__/ _ \
|
||
| |_| | | | (_| | | | | (_| | __/ | __/| | / /| __/ | | (_) |
|
||
\___/|_| \__,_|_| |_|\__, |\___| |_| |_| /____\___|_| \___/
|
||
|___/
|
||
|
||
Welcome to ARMBIAN 5.27.170514 nightly Ubuntu 16.04.2 LTS 4.11.0-sun8i
|
||
System load: 0.86 0.35 0.13 Up time: 9 min
|
||
Memory usage: 5 % of 496MB IP: 192.168.0.151
|
||
CPU temp: 39°C
|
||
Usage of /: 16% of 7.1G
|
||
|
||
[ General system configuration: armbian-config ]
|
||
New to Armbian? Check the documentation first: https://docs.armbian.com
|
||
|
||
Changing password for root.
|
||
(current) UNIX password:
|
||
Enter new UNIX password:
|
||
Retype new UNIX password:
|
||
|
||
You are using Armbian nightly build.
|
||
|
||
It is provided AS IS with NO WARRANTY and NO END USER SUPPORT.
|
||
|
||
Creating a new user account. Press <Ctrl-C> to abort
|
||
|
||
Please provide a username (eg. your forename): ha
|
||
Trying to add user ha
|
||
perl: warning: Setting locale failed.
|
||
perl: warning: Please check that your locale settings:
|
||
LANGUAGE = "en_US.UTF-8",
|
||
LC_ALL = (unset),
|
||
LC_PAPER = "de_CH.UTF-8",
|
||
LC_MONETARY = "de_CH.UTF-8",
|
||
LC_NUMERIC = "de_CH.UTF-8",
|
||
LC_MESSAGES = "en_US.UTF-8",
|
||
LC_MEASUREMENT = "de_CH.UTF-8",
|
||
LC_TIME = "de_CH.UTF-8",
|
||
LANG = "en_US.UTF-8"
|
||
are supported and installed on your system.
|
||
perl: warning: Falling back to a fallback locale ("en_US.UTF-8").
|
||
Adding user `ha' ...
|
||
Adding new group `ha' (1000) ...
|
||
Adding new user `ha' (1000) with group `ha' ...
|
||
Creating home directory `/home/ha' ...
|
||
Copying files from `/etc/skel' ...
|
||
Enter new UNIX password:
|
||
Retype new UNIX password:
|
||
passwd: password updated successfully
|
||
Changing the user information for ha
|
||
Enter the new value, or press ENTER for the default
|
||
Full Name []: homeassistant
|
||
Room Number []:
|
||
Work Phone []:
|
||
Home Phone []:
|
||
Other []:
|
||
Is the information correct? [Y/n] y
|
||
|
||
Dear homeassistant, your account ha has been created and is sudo enabled.
|
||
Please use this account for your daily work from now on.
|
||
|
||
root@orangepizero:~#
|
||
```
|
||
Get the latest details about the packages.
|
||
|
||
```bash
|
||
root@orangepizero:~# apt-get update
|
||
Hit:1 http://ports.ubuntu.com xenial InRelease
|
||
Get:2 http://ports.ubuntu.com xenial-security InRelease [102 kB]
|
||
Hit:3 http://beta.armbian.com xenial InRelease
|
||
Get:4 http://ports.ubuntu.com xenial-updates InRelease [102 kB]
|
||
Get:5 http://ports.ubuntu.com xenial-backports InRelease [102 kB]
|
||
Get:6 http://ports.ubuntu.com xenial-updates/main armhf Packages [479 kB]
|
||
Get:7 http://ports.ubuntu.com xenial-updates/universe armhf Packages [419 kB]
|
||
Fetched 1205 kB in 7s (158 kB/s)
|
||
Reading package lists... Done
|
||
```
|
||
Let's run an upgrade to make sure that all available packages are up-to-date.
|
||
|
||
```bash
|
||
root@orangepizero:~# apt-get upgrade
|
||
```
|
||
Now, we are installing the requirements for Home Assistant.
|
||
|
||
```bash
|
||
root@orangepizero:~# apt-get install python3-dev python3-pip python3-venv
|
||
```
|
||
|
||
Those steps to install Home Assistant are described in the [documentation](/docs/installation/armbian/) and the guide for [`venv`](/docs/installation/virtualenv/) as well. Switch to the create user `ha` and perform the remaining installation steps which are reduced to the minimum below:
|
||
|
||
```bash
|
||
ha@orangepizero:~$ pyvenv-3.5 homeassistant
|
||
ha@orangepizero:~$ cd homeassistant && source bin/activate
|
||
(homeassistant) ha@orangepizero:~/homeassistant$ pip3 install --upgrade pip
|
||
(homeassistant) ha@orangepizero:~/homeassistant$ pip3 install homeassistant
|
||
(homeassistant) ha@orangepizero:~/homeassistant$ hass
|
||
```
|
||
|
||
<p class="img">
|
||
<img src="/images/blog/2017-05-orangepi/orange-pi-running.png" />
|
||
</p>
|
||
|
||
To make it ready for daily usage, don't forget to enable [autostart](/docs/autostart/).
|
||
]]></content>
|
||
</entry>
|
||
|
||
<entry>
|
||
<title type="html"><![CDATA[Home Assistant on a Pi Zero W in 30 minutes]]></title>
|
||
<link href="https://home-assistant.io/blog/2017/05/01/home-assistant-on-raspberry-pi-zero-in-30-minutes/"/>
|
||
<updated>2017-05-01T09:00:00+00:00</updated>
|
||
<id>https://home-assistant.io/blog/2017/05/01/home-assistant-on-raspberry-pi-zero-in-30-minutes</id>
|
||
<content type="html">< yesterday for HASSbian 1.21 and got super excited?
|
||
|
||
Today we'll flash the latest HASSbian to a [Raspbery Pi Zero W](https://www.raspberrypi.org/products/pi-zero/).
|
||
**With an added bonus** that besides for an USB cable for power, there's no need for any cables!
|
||
|
||
What you'll need:
|
||
- a Raspberry Pi Zero W (an amazing tiny computer with built-in wifi)
|
||
- a microSD card
|
||
- some source of USB power
|
||
- Wifi
|
||
- a desktop or laptop
|
||
|
||
Let's get to it!
|
||
|
||
First, download the HASSbian 1.21 image from [here](https://github.com/home-assistant/pi-gen/releases/tag/v1.21).
|
||
|
||
Unzip it.
|
||
|
||
Flash it to the microSD card. If you need a flash tool, try [Etcher](https://etcher.io/)
|
||
|
||
When the flashing finishes, remove it and plug it back in. You should see a drive called "boot".
|
||
|
||
Right in there, not in any folders, create a file called `wpa_supplicant.conf`.
|
||
|
||
The contents of the configuration file should be something like this:
|
||
(You may have to adjust for your configuration, hints [here](https://www.raspberrypi.org/documentation/configuration/wireless/wireless-cli.md) )
|
||
|
||
```
|
||
network={
|
||
ssid="YOUR_WIFI_NETWORK_NAME_HERE"
|
||
psk="YOUR_WIFI_PASSWORD_HERE"
|
||
key_mgmt=WPA-PSK
|
||
}
|
||
```
|
||
|
||
Next stick your SD card into the Raspberry Pi Zero W, and plug it in.
|
||
|
||
After about a minute, use your SSH client to connect to HASSbian (or `hassbian.local` from a Mac), with the username `pi`. The default password is `raspberry`.
|
||
|
||
It's a good idea to change the password. To do so, use the `passwd` command.
|
||
|
||
Next, type the following two commands into the SSH console:
|
||
|
||
```
|
||
$ sudo systemctl enable install_homeassistant.service
|
||
$ sudo systemctl start install_homeassistant.service
|
||
```
|
||
|
||
Wait about 15-20 minutes and voilà you have your Home Assistant on your Raspberry Pi Zero W in 30 minutes.
|
||
|
||
To try it out, go to [http://hassbian:8123](http://hassbian:8123) or [http://hassbian.local:8123](http://hassbian.local:8123) if you're using Mac.
|
||
|
||
For further details about HASSbian, take a look at the [documentation](https://home-assistant.io/docs/hassbian/).
|
||
|
||
]]></content>
|
||
</entry>
|
||
|
||
<entry>
|
||
<title type="html"><![CDATA[Setting up InfluxDB and Grafana using Docker]]></title>
|
||
<link href="https://home-assistant.io/blog/2017/04/25/influxdb-grafana-docker/"/>
|
||
<updated>2017-04-25T08:04:05+00:00</updated>
|
||
<id>https://home-assistant.io/blog/2017/04/25/influxdb-grafana-docker</id>
|
||
<content type="html">< component provides some nice plots, I am sure you have always wanted those fancy [Grafana](https://grafana.com/) plots. The problem, however, is that low-powered device such as Raspberry Pi that most of us use for our Home Assistant setup are not well suited for such operation.
|
||
|
||
Instead of running [InfluxDB](https://www.influxdata.com/) and Grafana on a Raspberry Pi or a different system and go through the [classic approach of installing both tools separately](/blog/2015/12/07/influxdb-and-grafana/), you can run them in a Docker container on another machine. For this tutorial, I am using a Synology NAS, but the instructions should apply to other devices that can run Docker. Just follow the steps below:
|
||
|
||
1. SSH into your NAS. You may have to run `sudo su` if you are getting permission errors.
|
||
2. Download the [docker-statsd-influxdb-grafana]( https://hub.docker.com/r/samuelebistoletti/docker-statsd-influxdb-grafana/) image using the command:
|
||
`docker pull samuelebistoletti/docker-statsd-influxdb-grafana`
|
||
3. To start the container for the first-time launch:
|
||
```
|
||
docker run -d \
|
||
--name docker-statsd-influxdb-grafana \
|
||
-p 3003:3003 \
|
||
-p 3004:8083 \
|
||
-p 8086:8086 \
|
||
-p 22022:22 \
|
||
-p 8125:8125/udp \
|
||
samuelebistoletti/docker-statsd-influxdb-grafana:latest
|
||
```
|
||
4. The image should now be running and both InfluxBD and Grafana should be now up and running.
|
||
5. You can access InfluxDB at http://NAS_IP_ADDRESS:3004/ and Grafana at http://NAS_IP_ADDRESS:3003/
|
||
6. Navigate to http://NAS_IP_ADDRESS:3004/ and create the database `home_assistant` using the command `CREATE DATABASE home_assistant`.
|
||
<p class='img'>
|
||
<img src='/images/blog/2017-04-influxdb-grafana/create_HA_database.png' />
|
||
</p>
|
||
7. Now, you need to configure Home Assistant to use InfluxDB. Since, we did not add any username/password to our database, we can simply add the following to our configuration.yaml (replace the IP address with that of the device running Docker) and restart Home Assistant to setup InfluxDB (you will have to fine tune it based on your preferences):
|
||
```
|
||
influxdb:
|
||
host: 192.168.2.113
|
||
```
|
||
8. Next, we need to configure Grafana to use InfluxDB. Navigate to http://NAS_IP_ADDRESS:3003/ to access Grafana (login with username and password `root`) and add your first data source. Here’s how you can configure Grafana to use InfluxDB database. Note that 192.168.2.113 is the IP address of my NAS.
|
||
<p class='img'>
|
||
<img src='/images/blog/2017-04-influxdb-grafana/add_data_source.png' />
|
||
</p>
|
||
9. You should see `Data source is working` if you have configured everything correctly.
|
||
10. With all that configured, you are now ready for the fun stuff. You can create as many dashboards as you want and then import the same in Home Assistant.
|
||
11. To add the Grafana dashboard in HA, use the following config:
|
||
```
|
||
panel_iframe:
|
||
router:
|
||
title: 'Temperature'
|
||
url: 'http://192.168.2.113:3003/dashboard/db/temperature?edit&tab=time%20range'
|
||
```
|
||
The URL can be obtained by clicking Share Dashboard link on your dashboard:
|
||
<p class='img'>
|
||
<img src='/images/blog/2017-04-influxdb-grafana/share_dashboard.png' />
|
||
</p>
|
||
]]></content>
|
||
</entry>
|
||
|
||
<entry>
|
||
<title type="html"><![CDATA[HTTP to MQTT bridge]]></title>
|
||
<link href="https://home-assistant.io/blog/2017/03/28/http-to-mqtt-bridge/"/>
|
||
<updated>2017-03-28T06:00:00+00:00</updated>
|
||
<id>https://home-assistant.io/blog/2017/03/28/http-to-mqtt-bridge</id>
|
||
<content type="html">< appeared when I was trying to integrate Google Assistant with my Home Assistant after watching [BRUH Automation](https://youtu.be/087tQ7Ly7f4?t=265) video. Right now there is no MQTT service available in [IFTTT](https://ifttt.com/about). Existing integration solution uses [Maker Webhooks](https://ifttt.com/maker_webhooks) which requires that your Home Assistant instance is publically accessible, which I think brings some security concerns or simply not always possible to set up.
|
||
|
||
The HTTP to MQTT bridge should fill that gap. The idea is to receive messages using HTTP requests and transfer them to your MQTT broker, which can be contacted by Home Assistant. The HTTP to MQTT bridge is written using Node.js with [Express](https://expressjs.com/) for the server part and [MQTT.js](https://www.npmjs.com/package/mqtt) for the client.
|
||
|
||
<!--more-->
|
||
|
||
The app could be hosted on any Node.js hosting. I prefer [Heroku: Cloud Application Platform](https://www.heroku.com/home) for its simplicity.
|
||
|
||
### <a class='title-link' name='bringing-pieces-together' href='#bringing-pieces-together'></a> Bringing pieces together
|
||
|
||
1. Configure the Home Assistant [MQTT trigger](https://home-assistant.io/docs/automation/trigger/#mqtt-trigger).
|
||
1. Configure [CloudMQTT](https://www.cloudmqtt.com/). Check this [video tutorial](https://www.youtube.com/watch?v=VaWdvVVYU3A) for details.
|
||
1. [](https://heroku.com/deploy?template=https://github.com/petkov/http_to_mqtt) HTTP to MQTT bridge app.
|
||
1. Add the [Configuration Variables](https://devcenter.heroku.com/articles/config-vars#setting-up-config-vars-for-a-deployed-application) to your Heroku app mentioned here.
|
||
* AUTH_KEY: Can be any string, eg. `912ec803b2ce49e4a541068d495ab570`.
|
||
* MQTT_HOST: The host of your MQTT broker, eg. mqtts://k99.cloudmqtt.com:21234.
|
||
* MQTT_USER: MQTT username
|
||
* MQTT_PASS: MQTT password
|
||
1. Create an IFTTT applet the same way as described in [BRUH Automation](https://youtu.be/087tQ7Ly7f4?t=265) video.
|
||
1. Configure [Maker Webhooks](https://ifttt.com/maker_webhooks) service with below parameters.
|
||
* URL: `https://<app_name>.herokuapp.com/post/`
|
||
* Method: `POST`
|
||
* Content Type: `application/json`
|
||
* Body: `{"topic":"<mqtt_topic>","message":"<mqtt_message>","key":"<AUTH_KEY>"}`
|
||
|
||
### <a class='title-link' name='subscribe-to-latest-version' href='#subscribe-to-latest-version'></a> Subscribe to latest version
|
||
|
||
Additionally you can make Heroku to update the HTTP to MQTT bridge app to the latest available version from the GitHub repository automatically. To do this follow the instruction on the [Heroku help page](https://devcenter.heroku.com/articles/github-integration#automatic-deploys).
|
||
|
||
### <a class='title-link' name='improve-response-time' href='#improve-response-time'></a> Improve response time
|
||
|
||
After 30 minutes of inactivity Heroku will put your app into sleep mode. This will result in ~10 seconds response time. To prevent Heroku from putting your app into sleep mode, ping it every 10 minutes. You can do that by sending regular HTTP GET request to http://your_app/keep_alive/. But be careful. Heroku free quota is 550 hours per month. Without sleeping your app will be allowed to run only 22 days a month. Additionally the `keep_alive` method will send a simple MQTT message to prevent the broker from sleeping as well. The topic and message can be configured using Heroku environment variables `KEEP_ALIVE_TOPIC` and `KEEP_ALIVE_MESSAGE` and both are set to "keep_alive" by default.
|
||
|
||
You can even configure Home Assistant to ping HTTP to MQTT bridge every 10 minutes during daytime. Below is an example of how to do that:
|
||
|
||
```yaml
|
||
rest_command:
|
||
http_to_mqtt_keep_alive:
|
||
url: https://<your_app_address>/keep_alive/
|
||
method: get
|
||
|
||
automation:
|
||
alias: HTTP to MQTT keep alive
|
||
trigger:
|
||
platform: time
|
||
minutes: '/10'
|
||
seconds: 00
|
||
condition:
|
||
condition: time
|
||
after: '7:30:00'
|
||
before: '23:59:59'
|
||
action:
|
||
service: rest_command.http_to_mqtt_keep_alive
|
||
```
|
||
|
||
### <a class='title-link' name='thanks' href='#thanks'></a> Thanks
|
||
|
||
Special thanks to Ben from [BRUH Automation](https://www.youtube.com/channel/UCLecVrux63S6aYiErxdiy4w/featured) for awesome tutorials which inspired me to do this project.
|
||
]]></content>
|
||
</entry>
|
||
|
||
<entry>
|
||
<title type="html"><![CDATA[Smart Baby Monitor]]></title>
|
||
<link href="https://home-assistant.io/blog/2017/02/03/babyphone/"/>
|
||
<updated>2017-02-03T01:00:00+00:00</updated>
|
||
<id>https://home-assistant.io/blog/2017/02/03/babyphone</id>
|
||
<content type="html">< server for playing over speakers integrated with Home Assistant. We can use the binary sensor in our automation. You can ignore the icecast2 setup if you don't want to play the audio after the noise sensor trigger.
|
||
|
||
<p class='note'>
|
||
We change the platform name for binary sensor in 0.38 from `ffmpeg` to `ffmpeg_noise`. Also all service going to component and was rename from `binary_sensor.ffmpeg_xy` to `ffmpeg.xy`.
|
||
</p>
|
||
|
||
On Raspbian Jessie, you can setup [FFmpeg](/components/ffmpeg) and install a [icecast2](http://icecast.org/) server using:
|
||
|
||
```bash
|
||
$ sudo echo "deb http://ftp.debian.org/debian jessie-backports main" >> /etc/apt/sources.list
|
||
$ sudo apt-get update
|
||
$ sudo apt-get -t jessie-backports install ffmpeg
|
||
$ sudo apt-get install icecast2
|
||
```
|
||
|
||
We setup a icecast mount point for our babyphone and update `/etc/icecast2/icecast.xml`:
|
||
|
||
```
|
||
<mount>
|
||
<mount-name>/babyphone.mp3</mount-name>
|
||
<stream-name>Babyphone</stream-name>
|
||
|
||
<username>stream_user</username>
|
||
<password>stream_pw</password>
|
||
</mount>
|
||
```
|
||
|
||
Now we can add the noise sensor to Home Assistant. We lower the sensitivity of the sensor (so that you are not inundated with notifications for every cough of the baby) to 2 seconds using the `duration` option. The sensor should wait 60 seconds before restoring and it prevent us that a wine break will triggering a new alarm.
|
||
|
||
We can optimize the audio stream for human voice by using a highpass filter with 300 Hz and a lowpass filter with 2500 Hz. This filters out all non-human sounds such as background noise. We can even add a volume amplifier if the microphone volume is too low (you can remove it from `extra_arguments`). For icecast2 we convert the audio stream to mp3 with samplerate of 16000 (which is the minimum for Sonos speakers). We use `peak` to set the threshold for noise detection, where 0 dB is very loud and -100 dB is low.
|
||
|
||
```yaml
|
||
binary_sensor:
|
||
- platform: ffmpeg_noise
|
||
input: rtsp://user:pw@my_input/video
|
||
extra_arguments: -filter:a highpass=f=300,lowpass=f=2500,volume=volume=2 -codec:a libmp3lame -ar 16000
|
||
output: -f mp3 icecast://stream_user:stream_pw@127.0.0.1:8000/babyphone.mp3
|
||
initial_state: false
|
||
duration: 2
|
||
reset: 60
|
||
peak: -32
|
||
```
|
||
|
||
We use the option `initial_state` to prevent the FFmpeg process from starting with Home Assistant and only start it when needed. We use an `input_boolean` to control the state of FFmpeg services using the following automation.
|
||
|
||
```yaml
|
||
input_boolean:
|
||
babyphone:
|
||
name: babyphone
|
||
initial: off
|
||
|
||
automation:
|
||
- alias: 'Babyphone on'
|
||
trigger:
|
||
platform: state
|
||
entity_id: input_boolean.babyphone
|
||
from: 'off'
|
||
to: 'on'
|
||
action:
|
||
service: ffmpeg.start
|
||
entity_id: binary_sensor.ffmpeg_noise
|
||
|
||
- alias: 'Babyphone off'
|
||
trigger:
|
||
platform: state
|
||
entity_id: input_boolean.babyphone
|
||
from: 'on'
|
||
to: 'off'
|
||
action:
|
||
service: ffmpeg.stop
|
||
entity_id: binary_sensor.ffmpeg_noise
|
||
```
|
||
|
||
### <a class='title-link' name='trigger-a-alarm' href='#trigger-a-alarm'></a> Trigger a alarm
|
||
|
||
Now we can make a lot stuff. Here is a simple example of an automation what should be possible with Sonos speakers.
|
||
|
||
```yaml
|
||
automation:
|
||
- alias: 'Babyphone alarm on'
|
||
trigger:
|
||
platform: state
|
||
entity_id: binary_sensor.ffmpeg_noise
|
||
from: 'off'
|
||
to: 'on'
|
||
action:
|
||
- service: media_player.sonos_snapshot
|
||
entity_id: media_player.bedroom
|
||
- service: media_player.sonos_unjoin
|
||
entity_id: media_player.bedroom
|
||
- service: media_player.volume_set
|
||
entity_id: media_player.bedroom
|
||
data:
|
||
volume_level: 0.4
|
||
- service: media_player.play_media
|
||
entity_id: media_player.bedroom
|
||
data:
|
||
media_content_type: 'music'
|
||
media_content_id: http://my_ip_icecast:8000/babyphone.mp3
|
||
- service: light.turn_on:
|
||
entity_id:
|
||
- light.floor
|
||
- light.bedroom
|
||
data:
|
||
brightness: 150
|
||
|
||
- alias: 'Babyphone alarm off'
|
||
trigger:
|
||
platform: state
|
||
entity_id: binary_sensor.ffmpeg_noise
|
||
from: 'on'
|
||
to: 'off'
|
||
action:
|
||
- service: media_player.sonos_restore
|
||
entity_id: media_player.bedroom
|
||
- service: light.turn_off:
|
||
entity_id:
|
||
- light.floor
|
||
- light.bedroom
|
||
```
|
||
|
||
### <a class='title-link' name='thanks' href='#thanks'></a> Thanks
|
||
|
||
Special thanks to [arsaboo](https://github.com/arsaboo) for assistance in writing this blogpost.
|
||
]]></content>
|
||
</entry>
|
||
|
||
</feed>
|