File size: 3,544 Bytes
cfa124c
 
 
5eae7c2
 
cfa124c
 
78a42dd
9064b67
a31fc9a
4ea00c6
 
 
9064b67
764e0ce
3270a0d
764e0ce
 
 
 
 
 
 
 
 
d1f4761
766f004
764e0ce
 
 
34e885b
39b2ad4
a5f2386
50ddfc1
 
a548b77
34e885b
50ddfc1
5d3a7fe
37a1f88
37fa698
 
5d3a7fe
 
37fa698
 
5d3a7fe
37a1f88
 
 
5da2b8f
a548b77
 
188583e
37a1f88
5d62e53
 
9064b67
f2a5223
 
 
 
f422c9f
f2a5223
29d58d0
29028c0
7ddca6e
188583e
 
a2df0ee
c15560f
b89a040
39b2ad4
 
ac5b26b
 
1057e6a
5e0acb9
c40c2ce
8b35ca4
edd99e4
70bf8f7
18eed82
7fe3430
 
 
3f12f24
bb05240
 
 
 
901e011
bb05240
 
3f12f24
d08307a
34e885b
12fba10
a5f2386
952a213
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# Reference:
#
# https://vimeo.com/990334325/56b552bc7a
# https://platform.openai.com/playground/assistants
# https://cookbook.openai.com/examples/assistants_api_overview_python
# https://platform.openai.com/docs/api-reference/assistants/createAssistant
# https://platform.openai.com/docs/assistants/tools

import gradio as gr

import os

from openai import OpenAI

from assistants import (
    openai_client,
    assistant,
    thread,
    create_assistant,
    load_assistant,
    create_thread,
    create_message,
    create_run,
    wait_on_run,
    get_run_steps,
    recurse_execute_tool_calls,
    get_messages,
    extract_content_values,
)

def chat(message, history, openai_api_key):
    if not openai_api_key:
        raise gr.Error("OpenAI API Key is required (see additional inputs below).")
    if not message:
        raise gr.Error("Message is required.")

    #raise gr.Error("Please clone and bring your own credentials.")
    
    global openai_client, assistant, thread

    print("openai_client=")
    print(openai_client)
    if openai_client == None:
        openai_client = OpenAI(api_key=openai_api_key)
    print("openai_client=")
    print(openai_client)
    
    # On first run, create assistant and update assistant_id,
    # see https://platform.openai.com/playground/assistants.
    # On subsequent runs, load assistant.
    if assistant == None:
        #assistant = create_assistant()
        assistant = load_assistant()

    # TODO: Use Gradio session to support multiple users
    if thread == None or len(history) == 0:
        thread = create_thread()
        
    create_message(thread, message)
    run = create_run(assistant, thread)
    run = wait_on_run(thread, run)
    run_steps = get_run_steps(thread, run)
    recurse_execute_tool_calls(thread, run, run_steps, 0)
    messages = get_messages(thread)
    text_values, image_values = extract_content_values(messages)

    download_link = ""

    # TODO: Handle multiple images and other file types
    if len(image_values) > 0:
        download_link = f"<hr>[Download](https://platform.openai.com/storage/files/{image_values[0]})"

    del os.environ["OPENAI_API_KEY"]
    
    #return f"{'<hr>'.join(list(reversed(text_values))[1:])}{download_link}"
    return f"{text_values[0]}{download_link}"

gr.ChatInterface(
        fn=chat,
        chatbot=gr.Chatbot(height=250),
        textbox=gr.Textbox(placeholder="Ask anything", container=False, scale=7),
        title="Python Coding Assistant",
        description=os.environ.get("DESCRIPTION"),
        clear_btn="Clear",
        retry_btn=None,
        undo_btn=None,
        examples=[
                  ["Generate: Code to fine-tune model meta-llama/Meta-Llama-3.1-8B on dataset gretelai/synthetic_text_to_sql using QLoRA"],
                  ["Explain: r\"^(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*[\\W]).{8,}$\""],
                  ["Fix: x = [5, 2, 1, 3, 4]; print(x.sort())"],
                  ["Optimize: x = []; for i in range(0, 10000): x.append(i)"],
                  ["1. Execute: Calculate the first 25 Fibbonaci numbers. 2. Show the code."],
                  ["1. Execute with tools: Create a plot showing stock gain QTD for NVDA and AMD, x-axis is \"Day\" and y-axis is \"Gain %\". 2. Show the code."],
                  ["1. Execute with tools: Get key announcements from latest OpenAI Dev Day. 2. Show the web references."]
                 ],
        cache_examples=False,
        additional_inputs=[
            gr.Textbox("", label="OpenAI API Key")
        ],
    ).launch()