diff options
author | Botond Hende <nettingman@gmail.com> | 2024-12-04 15:22:10 +0100 |
---|---|---|
committer | Botond Hende <nettingman@gmail.com> | 2024-12-04 15:22:10 +0100 |
commit | 99243bd33a63c076d16bd08914bd1808d4a4112c (patch) | |
tree | 3cd7615401ac1f2a4dac44c51de7b21e27f7b60a /modules/responses/response_manager.py | |
parent | 6168323b858a1eeeafdf9a4e2528df3205d6c2da (diff) |
response manager and libnotify response handler
Diffstat (limited to 'modules/responses/response_manager.py')
-rw-r--r-- | modules/responses/response_manager.py | 32 |
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) |