summaryrefslogtreecommitdiffstats
path: root/makefu/2configs/home/ham/automation
diff options
context:
space:
mode:
authorlassulus <lassulus@lassul.us>2022-08-23 11:28:30 +0200
committerlassulus <lassulus@lassul.us>2022-08-23 11:28:30 +0200
commit90cd7e6050b1c73cfb8deb3aaf2686312dc1dda7 (patch)
treea4a869cc3af6dd27bc0cee78ab388070a00ef68d /makefu/2configs/home/ham/automation
parent9ae4a08ccc07964decc51fb1e92bc35d49e4691c (diff)
parent739fad41da87d206f76bc3db9861d8b2bd0a5639 (diff)
Merge remote-tracking branch 'gum/master'
Diffstat (limited to 'makefu/2configs/home/ham/automation')
-rw-r--r--makefu/2configs/home/ham/automation/project_tracker.nix68
1 files changed, 68 insertions, 0 deletions
diff --git a/makefu/2configs/home/ham/automation/project_tracker.nix b/makefu/2configs/home/ham/automation/project_tracker.nix
new file mode 100644
index 000000000..cb279b2fe
--- /dev/null
+++ b/makefu/2configs/home/ham/automation/project_tracker.nix
@@ -0,0 +1,68 @@
+{ lib, ... }:
+# uses:
+#
+let
+ at_work = "input_boolean.felix_at_work";
+ dice_action = "sensor.arbeitszimmer_cube_action";
+ project_sensor = "sensor.felix_project";
+ hlib = import ../lib;
+ say = hlib.say.office;
+ sides = [ "BDK" "LBS6" "random" "BNO" "CyberShield" "ILBS" ];
+ hist_stat = state: {
+ platform = "history_stats";
+ name = "Felix Project ${state}";
+ entity_id = project_sensor;
+ inherit state;
+ type = "time";
+ start = "{{ now().replace(hour=0, minute=0, second=0) }}";
+ end = "{{ now() }}";
+ };
+
+in
+ {
+ services.home-assistant.config.sensor = map hist_stat (sides ++ ["not at work" "unknown"]);
+ services.home-assistant.config.automation = [
+ { alias = "Felix Project Change";
+ trigger =
+ {
+ platform = "state";
+ entity_id = project_sensor;
+ # ignore login and log out
+ not_from = [ "not at work" ];
+ not_to = [ "not at work" ];
+ };
+
+ action = (say "Wechsel auf Projekt {{ trigger.to_state.state }}");
+ }
+ ];
+ services.home-assistant.config.template = [
+ {
+ trigger = [
+ {
+ platform = "state";
+ entity_id = at_work;
+ }
+ {
+ platform = "state";
+ attribute = "side";
+ entity_id = dice_action;
+ not_from = "";
+ }
+ ];
+ sensor = [
+ { name = "Felix Project";
+ state = ''
+ {% set at_work = states('${at_work}') == 'on' %}
+ {% set side = state_attr('${dice_action}','side') %}
+ {% if not at_work %}not at work
+ '' + (lib.concatImapStringsSep "\n" (i: project:
+ "{% elif side == ${toString (i - 1)} %}${project}") sides) +
+ ''
+ {% else %}unknown
+ {% endif %}
+ '';
+ }
+ ];
+ }
+ ];
+ }