From 8b54a960f19e10d3fdd24703b476b9f77ced8350 Mon Sep 17 00:00:00 2001 From: fahad_shaikh Date: Thu, 12 Dec 2024 15:27:36 +0530 Subject: [PATCH 1/2] added secret and bot_id in config --- kairon/nlu/classifiers/llm.py | 10 +++++----- kairon/train.py | 7 +++++++ 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/kairon/nlu/classifiers/llm.py b/kairon/nlu/classifiers/llm.py index f438c36de..39cec4b8c 100644 --- a/kairon/nlu/classifiers/llm.py +++ b/kairon/nlu/classifiers/llm.py @@ -82,9 +82,9 @@ def load_api_key(self, bot_id: Text): if bot_id: from kairon.shared.admin.processor import Sysadmin llm_secret = Sysadmin.get_llm_secret("openai", bot_id) - self.api_key = llm_secret.get('api_key') + self.secret = llm_secret.get('api_key') elif os.environ.get("LLM_API_KEY"): - self.api_key = os.environ.get("LLM_API_KEY") + self.secret = {'api_key': os.environ.get("LLM_API_KEY")} else: raise KeyError( f"either set bot_id'in LLMClassifier config or set LLM_API_KEY in environment variables" @@ -92,7 +92,7 @@ def load_api_key(self, bot_id: Text): def get_embeddings(self, text): embeddings = litellm.embedding( - model="text-embedding-3-small", input=text, api_key=self.api_key, max_retries=3 + model="text-embedding-3-small", input=text, max_retries=3, **self.secret ) return [ embedding['embedding'] for embedding in embeddings['data']] @@ -188,8 +188,8 @@ def predict(self, text): top_p=1, frequency_penalty=0, presence_penalty=0, - api_key=self.api_key, - max_retries=3 + max_retries=3, + **self.secret ) logger.debug(response) responses = json.loads(response.choices[0]["message"]["content"]) diff --git a/kairon/train.py b/kairon/train.py index aa19943cb..f4346a350 100644 --- a/kairon/train.py +++ b/kairon/train.py @@ -38,6 +38,11 @@ def train_model_for_bot(bot: str): stories = stories.merge(multiflow_stories[0]) config = processor.load_config(bot) config['assistant_id'] = bot + + index = next((index for (index, d) in enumerate(config['pipeline']) if d["name"] == "kairon.nlu.LLMClassifier"), None) + if index: + config[index]['bot_id']= bot + rules = processor.get_rules_for_training(bot) rules = rules.merge(multiflow_stories[1]) @@ -124,3 +129,5 @@ def start_training(bot: str, user: str, token: str = None): exception=exception, ) return model_file + + From 7daa2f92abda2684f847fc4e007ce889b415b1e6 Mon Sep 17 00:00:00 2001 From: fahad_shaikh Date: Thu, 12 Dec 2024 19:14:43 +0530 Subject: [PATCH 2/2] config corrected --- kairon/train.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/kairon/train.py b/kairon/train.py index f4346a350..285bd7aa7 100644 --- a/kairon/train.py +++ b/kairon/train.py @@ -41,7 +41,7 @@ def train_model_for_bot(bot: str): index = next((index for (index, d) in enumerate(config['pipeline']) if d["name"] == "kairon.nlu.LLMClassifier"), None) if index: - config[index]['bot_id']= bot + config['pipeline'][index]['bot_id']= bot rules = processor.get_rules_for_training(bot) rules = rules.merge(multiflow_stories[1])