ma bureautomation: enable schlechteluft, matrix publisher
This commit is contained in:
parent
1a5bda9a39
commit
efdcce0ad7
65
2configs/bureautomation/combination/matrix.nix
Normal file
65
2configs/bureautomation/combination/matrix.nix
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
{ lib, ... }:
|
||||||
|
#matrix:
|
||||||
|
# password: supersecurepassword
|
||||||
|
# rooms:
|
||||||
|
# - "#hasstest:matrix.org"
|
||||||
|
# commands:
|
||||||
|
# - word: my_command
|
||||||
|
# name: my_command
|
||||||
|
let
|
||||||
|
mom_room = "!kTQjvTQvfVsvfEtmth:thales.citadel.team";
|
||||||
|
in {
|
||||||
|
matrix =
|
||||||
|
{
|
||||||
|
# secrets:
|
||||||
|
# homeserver, username, password
|
||||||
|
homeserver = "https://ext01.citadel.team";
|
||||||
|
rooms = [
|
||||||
|
mom_room
|
||||||
|
];
|
||||||
|
commands = [
|
||||||
|
{
|
||||||
|
# alternative: expression for regexp
|
||||||
|
word = "version";
|
||||||
|
name = "version";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
word = "luftqualität";
|
||||||
|
name = "luftqualitaet";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
} // (builtins.fromJSON (builtins.readFile
|
||||||
|
<secrets/hass/citadel-bot.json>));
|
||||||
|
automation = [
|
||||||
|
{
|
||||||
|
alias = "React to !version";
|
||||||
|
trigger = {
|
||||||
|
platform = "event";
|
||||||
|
event_type = "matrix_command";
|
||||||
|
event_data.command = "version";
|
||||||
|
};
|
||||||
|
action = {
|
||||||
|
service = "notify.matrix_notify";
|
||||||
|
data_template.message = "Running home-assistant {{states.sensor.current_version.state}}";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
{
|
||||||
|
alias = "React to !luftqualität";
|
||||||
|
trigger = {
|
||||||
|
platform = "event";
|
||||||
|
event_type = "matrix_command";
|
||||||
|
event_data.command = "luftqualitaet";
|
||||||
|
};
|
||||||
|
action = {
|
||||||
|
service = "notify.matrix_notify";
|
||||||
|
data_template.message = "Temp: {{states.sensor.easy2_dht22_temperature.state_with_unit}} Hum:{{states.sensor.easy2_dht22_humidity.state_with_unit}} airquality:{{states.sensor.air_quality.state_with_unit}}";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
];
|
||||||
|
notify = [{
|
||||||
|
name = "matrix_notify";
|
||||||
|
platform = "matrix";
|
||||||
|
default_room = mom_room;
|
||||||
|
}];
|
||||||
|
}
|
|
@ -5,6 +5,9 @@ let
|
||||||
mittagessen = import ./combination/mittagessen.nix { inherit lib; }; # provides: automation script
|
mittagessen = import ./combination/mittagessen.nix { inherit lib; }; # provides: automation script
|
||||||
matrix = import ./combination/matrix.nix { inherit lib; }; # provides: matrix automation
|
matrix = import ./combination/matrix.nix { inherit lib; }; # provides: matrix automation
|
||||||
in {
|
in {
|
||||||
|
imports = [
|
||||||
|
./ota.nix
|
||||||
|
];
|
||||||
networking.firewall.allowedTCPPorts = [ 8123 ];
|
networking.firewall.allowedTCPPorts = [ 8123 ];
|
||||||
state = [ "/var/lib/hass/known_devices.yaml" ];
|
state = [ "/var/lib/hass/known_devices.yaml" ];
|
||||||
services.home-assistant = let
|
services.home-assistant = let
|
||||||
|
@ -214,6 +217,7 @@ in {
|
||||||
"timer.frank_10h"
|
"timer.frank_10h"
|
||||||
"sensor.easy2_dht22_humidity"
|
"sensor.easy2_dht22_humidity"
|
||||||
"sensor.easy2_dht22_temperature"
|
"sensor.easy2_dht22_temperature"
|
||||||
|
"sensor.air_quality"
|
||||||
# "binary_sensor.redbutton"
|
# "binary_sensor.redbutton"
|
||||||
];
|
];
|
||||||
outside = [
|
outside = [
|
||||||
|
@ -233,6 +237,7 @@ in {
|
||||||
# home-assistant
|
# home-assistant
|
||||||
automation = (import ./automation/bureau-shutdown.nix) ++
|
automation = (import ./automation/bureau-shutdown.nix) ++
|
||||||
(import ./automation/nachtlicht.nix) ++
|
(import ./automation/nachtlicht.nix) ++
|
||||||
|
(import ./automation/schlechteluft.nix) ++
|
||||||
(import ./automation/hass-restart.nix) ++
|
(import ./automation/hass-restart.nix) ++
|
||||||
ten_hours.automation ++
|
ten_hours.automation ++
|
||||||
matrix.automation ++
|
matrix.automation ++
|
||||||
|
|
Loading…
Reference in a new issue