Krishnaik06 commited on
Commit
87aa8cf
·
1 Parent(s): bbd996b

Basicv Chatbot

Browse files
app.py CHANGED
@@ -0,0 +1,5 @@
 
 
 
 
 
 
1
+ from src.langgraphagenticai.main import load_langgraph_agenticai_app
2
+
3
+
4
+ if __name__=="__main__":
5
+ load_langgraph_agenticai_app()
src/__pycache__/__init__.cpython-312.pyc ADDED
Binary file (132 Bytes). View file
 
src/langgraphagenticai/LLMS/groqllm.py CHANGED
@@ -0,0 +1,20 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import os
2
+ import streamlit as st
3
+ from langchain_groq import ChatGroq
4
+
5
+ class GroqLLM:
6
+ def __init__(self,user_controls_input):
7
+ self.user_controls_input=user_controls_input
8
+
9
+ def get_llm_model(self):
10
+ try:
11
+ groq_api_key=self.user_controls_input['GROQ_API_KEY']
12
+ selected_groq_model=self.user_controls_input['selected_groq_models']
13
+ if groq_api_key=='' and os.environ["GROQ_API_KEY"] =='':
14
+ st.error("Please Enter the Groq API KEY")
15
+
16
+ llm = ChatGroq(api_key =groq_api_key, model=selected_groq_model)
17
+
18
+ except Exception as e:
19
+ raise ValueError(f"Error Occurred with Exception : {e}")
20
+ return llm
src/langgraphagenticai/__pycache__/__init__.cpython-312.pyc ADDED
Binary file (151 Bytes). View file
 
src/langgraphagenticai/__pycache__/main.cpython-312.pyc ADDED
Binary file (1.39 kB). View file
 
src/langgraphagenticai/graph/graph_builder.py ADDED
@@ -0,0 +1,39 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from langgraph.graph import StateGraph, START,END, MessagesState
2
+ from langgraph.prebuilt import tools_condition,ToolNode
3
+ from langchain_core.prompts import ChatPromptTemplate
4
+ from src.langgraphagenticai.state.state import State
5
+ from src.langgraphagenticai.nodes.basic_chatbot_node import BasicChatbotNode
6
+
7
+
8
+
9
+
10
+ class GraphBuilder:
11
+
12
+ def __init__(self,model):
13
+ self.llm=model
14
+ self.graph_builder=StateGraph(State)
15
+
16
+ def basic_chatbot_build_graph(self):
17
+ """
18
+ Builds a basic chatbot graph using LangGraph.
19
+ This method initializes a chatbot node using the `BasicChatbotNode` class
20
+ and integrates it into the graph. The chatbot node is set as both the
21
+ entry and exit point of the graph.
22
+ """
23
+ self.basic_chatbot_node=BasicChatbotNode(self.llm)
24
+ self.graph_builder.add_node("chatbot",self.basic_chatbot_node.process)
25
+ self.graph_builder.add_edge(START,"chatbot")
26
+ self.graph_builder.add_edge("chatbot",END)
27
+
28
+ def setup_graph(self, usecase: str):
29
+ """
30
+ Sets up the graph for the selected use case.
31
+ """
32
+ if usecase == "Basic Chatbot":
33
+ self.basic_chatbot_build_graph()
34
+ return self.graph_builder.compile()
35
+
36
+
37
+
38
+
39
+
src/langgraphagenticai/main.py CHANGED
@@ -0,0 +1,63 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import streamlit as st
2
+ import json
3
+ from src.langgraphagenticai.ui.streamlitui.loadui import LoadStreamlitUI
4
+ from src.langgraphagenticai.LLMS.groqllm import GroqLLM
5
+ from src.langgraphagenticai.graph.graph_builder import GraphBuilder
6
+
7
+ # MAIN Function START
8
+ def load_langgraph_agenticai_app():
9
+ """
10
+ Loads and runs the LangGraph AgenticAI application with Streamlit UI.
11
+ This function initializes the UI, handles user input, configures the LLM model,
12
+ sets up the graph based on the selected use case, and displays the output while
13
+ implementing exception handling for robustness.
14
+ """
15
+
16
+ # Load UI
17
+ ui = LoadStreamlitUI()
18
+ user_input = ui.load_streamlit_ui()
19
+
20
+ if not user_input:
21
+ st.error("Error: Failed to load user input from the UI.")
22
+ return
23
+
24
+ # Text input for user message
25
+ if st.session_state.IsFetchButtonClicked:
26
+ user_message = st.session_state.timeframe
27
+ else :
28
+ user_message = st.chat_input("Enter your message:")
29
+
30
+ if user_message:
31
+ try:
32
+ # Configure LLM
33
+ obj_llm_config = GroqLLM(user_controls_input=user_input)
34
+ model = obj_llm_config.get_llm_model()
35
+
36
+ if not model:
37
+ st.error("Error: LLM model could not be initialized.")
38
+ return
39
+
40
+ # Initialize and set up the graph based on use case
41
+ usecase = user_input.get('selected_usecase')
42
+ if not usecase:
43
+ st.error("Error: No use case selected.")
44
+ return
45
+
46
+
47
+ ### Graph Builder
48
+ graph_builder=GraphBuilder(model)
49
+ try:
50
+ graph = graph_builder.setup_graph(usecase)
51
+ except Exception as e:
52
+ st.error(f"Error: Graph setup failed - {e}")
53
+ return
54
+
55
+ except Exception as e:
56
+ raise ValueError(f"Error Occurred with Exception : {e}")
57
+
58
+
59
+
60
+
61
+
62
+
63
+
src/langgraphagenticai/nodes/basic_chatbot_node.py ADDED
@@ -0,0 +1,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from src.langgraphagenticai.state.state import State
2
+
3
+ class BasicChatbotNode:
4
+ """
5
+ Basic chatbot logic implementation.
6
+ """
7
+ def __init__(self,model):
8
+ self.llm = model
9
+
10
+ def process(self, state: State) -> dict:
11
+ """
12
+ Processes the input state and generates a chatbot response.
13
+ """
14
+ return {"messages":self.llm.invoke(state['messages'])}
src/langgraphagenticai/state/state.py ADDED
@@ -0,0 +1,11 @@
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from typing import Annotated, Literal, Optional
2
+ from typing_extensions import TypedDict
3
+ from langgraph.graph.message import add_messages
4
+ from typing import TypedDict, Annotated, List
5
+ from langchain_core.messages import HumanMessage, AIMessage
6
+
7
+ class State(TypedDict):
8
+ """
9
+ Represents the structure of the state used in the graph.
10
+ """
11
+ messages: Annotated[list, add_messages]
src/langgraphagenticai/ui/__pycache__/__init__.cpython-312.pyc ADDED
Binary file (154 Bytes). View file
 
src/langgraphagenticai/ui/__pycache__/uiconfigfile.cpython-312.pyc ADDED
Binary file (1.8 kB). View file
 
src/langgraphagenticai/ui/streamlitui/__pycache__/loadui.cpython-312.pyc ADDED
Binary file (4.15 kB). View file
 
src/langgraphagenticai/ui/streamlitui/loadui.py CHANGED
@@ -9,4 +9,56 @@ from src.langgraphagenticai.ui.uiconfigfile import Config
9
  class LoadStreamlitUI:
10
  def __init__(self):
11
  self.config = Config() # config
12
- self.user_controls = {}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9
  class LoadStreamlitUI:
10
  def __init__(self):
11
  self.config = Config() # config
12
+ self.user_controls = {}
13
+
14
+ def initialize_session(self):
15
+ return {
16
+ "current_step": "requirements",
17
+ "requirements": "",
18
+ "user_stories": "",
19
+ "po_feedback": "",
20
+ "generated_code": "",
21
+ "review_feedback": "",
22
+ "decision": None
23
+ }
24
+
25
+
26
+
27
+ def load_streamlit_ui(self):
28
+ st.set_page_config(page_title= "🤖 " + self.config.get_page_title(), layout="wide")
29
+ st.header("🤖 " + self.config.get_page_title())
30
+ st.session_state.timeframe = ''
31
+ st.session_state.IsFetchButtonClicked = False
32
+ st.session_state.IsSDLC = False
33
+
34
+
35
+
36
+ with st.sidebar:
37
+ # Get options from config
38
+ llm_options = self.config.get_llm_options()
39
+ usecase_options = self.config.get_usecase_options()
40
+
41
+ # LLM selection
42
+ self.user_controls["selected_llm"] = st.selectbox("Select LLM", llm_options)
43
+
44
+ if self.user_controls["selected_llm"] == 'Groq':
45
+ # Model selection
46
+ model_options = self.config.get_groq_model_options()
47
+ self.user_controls["selected_groq_model"] = st.selectbox("Select Model", model_options)
48
+ # API key input
49
+ self.user_controls["GROQ_API_KEY"] = st.session_state["GROQ_API_KEY"] = st.text_input("API Key",
50
+ type="password")
51
+ # Validate API key
52
+ if not self.user_controls["GROQ_API_KEY"]:
53
+ st.warning("⚠️ Please enter your GROQ API key to proceed. Don't have? refer : https://console.groq.com/keys ")
54
+
55
+
56
+ # Use case selection
57
+ self.user_controls["selected_usecase"] = st.selectbox("Select Usecases", usecase_options)
58
+
59
+ if "state" not in st.session_state:
60
+ st.session_state.state = self.initialize_session()
61
+
62
+
63
+
64
+ return self.user_controls
src/langgraphagenticai/ui/uiconfigfile.py CHANGED
@@ -5,7 +5,7 @@ class Config:
5
  self.config=ConfigParser()
6
  self.config.read(config_file)
7
 
8
- def get_llm_option(self):
9
  return self.config["DEFAULT"].get("LLM_OPTIONS").split(", ")
10
 
11
  def get_usecase_options(self):
 
5
  self.config=ConfigParser()
6
  self.config.read(config_file)
7
 
8
+ def get_llm_options(self):
9
  return self.config["DEFAULT"].get("LLM_OPTIONS").split(", ")
10
 
11
  def get_usecase_options(self):