Module3 / app.py
alibicer's picture
Update app.py
aff9c1d verified
raw
history blame
2.1 kB
import os
import gradio as gr
from openai import OpenAI
from prompts.main_prompt import MAIN_PROMPT # βœ… Import Main Prompt Correctly
from prompts.initial_prompt import INITIAL_PROMPT # βœ… Import Initial Prompt
# βœ… Ensure OpenAI API Key is Set (Use Secrets in Hugging Face)
OPENAI_API_KEY = os.getenv("OPENAI_API_KEY")
if not OPENAI_API_KEY:
raise ValueError("⚠️ Missing OpenAI API Key! Set it in Hugging Face 'Settings' β†’ 'Secrets'.")
client = OpenAI(api_key=OPENAI_API_KEY)
def respond(user_message, history):
if not user_message:
return "", history
try:
assistant_reply = client.chat.completions.create(
model="gpt-4o",
messages=[
{"role": "system", "content": MAIN_PROMPT}, # βœ… Ensures MAIN_PROMPT is used first
*[
{"role": "user", "content": u} if i % 2 == 0 else {"role": "assistant", "content": a}
for i, (u, a) in enumerate(history)
],
{"role": "user", "content": user_message}
],
max_tokens=512,
temperature=0.7,
).choices[0].message.content
except Exception as e:
assistant_reply = f"⚠️ Error: {str(e)}"
history.append((user_message, assistant_reply))
return "", history
# βœ… Gradio UI
with gr.Blocks() as demo:
gr.Markdown("# **AI-Guided Math PD Chatbot**")
# βœ… Start Chatbot with MAIN_PROMPT Instead of Initial Reflection
chatbot = gr.Chatbot(
value=[("", MAIN_PROMPT)], # βœ… Ensures chatbot begins with the math problems
height=500
)
state_history = gr.State([("", MAIN_PROMPT)]) # βœ… Makes sure history starts correctly
user_input = gr.Textbox(placeholder="Type your message here...", label="Your Input")
user_input.submit(
respond,
inputs=[user_input, state_history],
outputs=[user_input, chatbot]
).then(
fn=lambda _, h: h,
inputs=[user_input, chatbot],
outputs=[state_history]
)
if __name__ == "__main__":
demo.launch()