summaryrefslogtreecommitdiff
path: root/modules/responses/response_manager.py
diff options
context:
space:
mode:
authorBotond Hende <nettingman@gmail.com>2024-12-04 15:22:10 +0100
committerBotond Hende <nettingman@gmail.com>2024-12-04 15:22:10 +0100
commit99243bd33a63c076d16bd08914bd1808d4a4112c (patch)
tree3cd7615401ac1f2a4dac44c51de7b21e27f7b60a /modules/responses/response_manager.py
parent6168323b858a1eeeafdf9a4e2528df3205d6c2da (diff)
response manager and libnotify response handler
Diffstat (limited to 'modules/responses/response_manager.py')
-rw-r--r--modules/responses/response_manager.py32
1 files changed, 32 insertions, 0 deletions
diff --git a/modules/responses/response_manager.py b/modules/responses/response_manager.py
new file mode 100644
index 0000000..34c0a41
--- /dev/null
+++ b/modules/responses/response_manager.py
@@ -0,0 +1,32 @@
+import yaml
+
+from pathlib import Path
+
+from ..config import Config
+from ..responses.responses import Responses
+from ..hassil.util import merge_dict
+from .response_handler import ResponseHandler
+from .libnotify import LibNotify
+
+class ResponseManager:
+ def __init__(self, config: Config):
+ response_dict = {"responses": {}}
+
+ response_yaml_path = Path(config.responses_dir)
+ response_yaml_file_paths = response_yaml_path.glob("*.yaml")
+ for yaml_file_path in response_yaml_file_paths:
+ with open(yaml_file_path, "r", encoding="utf-8") as yaml_file:
+ merge_dict(response_dict, yaml.safe_load(yaml_file))
+
+ self.responses = Responses.from_dict(response_dict)
+ self.respond_handlers: list[ResponseHandler] = [LibNotify(config)]
+
+ def respond(self, response: str, intent_name: str):
+ response_key = intent_name if response == "default" else response
+ if response_key not in self.responses.responses:
+ print(f"No response found for: {response_key}")
+ return
+
+ response_text = self.responses.responses[response_key].sentence_texts[0]
+ for handler in self.respond_handlers:
+ handler.respond(response_text)