Spaces:
Runtime error
Runtime error
cleanup structure
Browse files- app.py +74 -29
- functions.py +129 -81
- home_depot_data.csv +0 -0
- home_depot_result.py +225 -0
- requirements.txt +4 -1
app.py
CHANGED
@@ -4,13 +4,13 @@ from openai import AzureOpenAI
|
|
4 |
|
5 |
from functions import call_function
|
6 |
|
7 |
-
st.title("
|
8 |
# when will my order be delivered?, [email protected] W123123
|
9 |
|
10 |
functions = [
|
11 |
{
|
12 |
-
"name": "
|
13 |
-
"description": "Retrieves the status of an order based on **both** the email address and order number.",
|
14 |
"parameters": {
|
15 |
"type": "object",
|
16 |
"properties": {
|
@@ -26,17 +26,45 @@ functions = [
|
|
26 |
"required": ["email_address", "order_number"]
|
27 |
}
|
28 |
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
29 |
{
|
30 |
"name": "refer_to_human_agent",
|
31 |
"description": "Use this to refer the customer's question to a human agent. You should only call this "
|
32 |
-
"function if
|
33 |
"parameters": {
|
34 |
"type": "object",
|
35 |
"properties": {
|
36 |
"conversation_summary": {
|
37 |
"type": "string",
|
38 |
-
"description": "A short summary of the current conversation so the agent can quickly get up
|
39 |
-
"speed. Make sure you include all relevant details.
|
40 |
},
|
41 |
},
|
42 |
"required": ["conversation_summary"]
|
@@ -54,9 +82,8 @@ if "openai_model" not in st.session_state:
|
|
54 |
st.session_state["openai_model"] = "gpt-35-turbo"
|
55 |
|
56 |
if "messages" not in st.session_state:
|
57 |
-
st.session_state.messages = [{"role": "system", "content": "You are a helpful customer support agent for
|
58 |
-
"
|
59 |
-
"functions when necessary."},]
|
60 |
|
61 |
for message in st.session_state.messages:
|
62 |
if message["role"] == "assistant" or message["role"] == "user":
|
@@ -76,16 +103,46 @@ if prompt := st.chat_input("How can we help you today?"):
|
|
76 |
"arguments": "",
|
77 |
}
|
78 |
|
79 |
-
|
80 |
-
|
81 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
82 |
for response in client.chat.completions.create(
|
83 |
model=st.session_state["openai_model"],
|
84 |
messages=[
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
functions=functions,
|
90 |
function_call="auto",
|
91 |
stream=True,
|
@@ -100,19 +157,7 @@ if prompt := st.chat_input("How can we help you today?"):
|
|
100 |
if delta.function_call.arguments is not None:
|
101 |
func_call["arguments"] += delta.function_call.arguments
|
102 |
|
103 |
-
message_placeholder.markdown(full_message + "
|
104 |
-
|
105 |
-
if func_call["name"] is not None:
|
106 |
-
print(f"Function generation requested, calling function")
|
107 |
-
function_response = call_function(st.session_state.messages, func_call)
|
108 |
-
print("function response")
|
109 |
-
print(function_response)
|
110 |
-
st.session_state.messages.append(function_response)
|
111 |
-
called_function = True
|
112 |
-
func_call = {
|
113 |
-
"name": None,
|
114 |
-
"arguments": "",
|
115 |
-
}
|
116 |
|
117 |
message_placeholder.markdown(full_message)
|
118 |
|
|
|
4 |
|
5 |
from functions import call_function
|
6 |
|
7 |
+
st.title("SupportFlow Demo")
|
8 |
# when will my order be delivered?, [email protected] W123123
|
9 |
|
10 |
functions = [
|
11 |
{
|
12 |
+
"name": "lookup_order_status",
|
13 |
+
"description": "Retrieves the status, location, etc. of an order based on **both** the email address and order number.",
|
14 |
"parameters": {
|
15 |
"type": "object",
|
16 |
"properties": {
|
|
|
26 |
"required": ["email_address", "order_number"]
|
27 |
}
|
28 |
},
|
29 |
+
# {
|
30 |
+
# "name": "lookup_product",
|
31 |
+
# "description": "Returns a detailed list of products based on a product query.",
|
32 |
+
# "parameters": {
|
33 |
+
# "type": "object",
|
34 |
+
# "properties": {
|
35 |
+
# "query": {
|
36 |
+
# "type": "string",
|
37 |
+
# "description": "Product query to search for like drills, lights, or hammers"
|
38 |
+
# },
|
39 |
+
# },
|
40 |
+
# "required": ["query"]
|
41 |
+
# }
|
42 |
+
# },
|
43 |
+
# {
|
44 |
+
# "name": "get_product_listing",
|
45 |
+
# "description": "Returns information about the product based on the SKU.",
|
46 |
+
# "parameters": {
|
47 |
+
# "type": "object",
|
48 |
+
# "properties": {
|
49 |
+
# "sku": {
|
50 |
+
# "type": "integer",
|
51 |
+
# "description": "Product sku to search for like 123123"
|
52 |
+
# },
|
53 |
+
# },
|
54 |
+
# "required": ["sku"]
|
55 |
+
# }
|
56 |
+
# },
|
57 |
{
|
58 |
"name": "refer_to_human_agent",
|
59 |
"description": "Use this to refer the customer's question to a human agent. You should only call this "
|
60 |
+
"function if there is no way for you to answer their question.",
|
61 |
"parameters": {
|
62 |
"type": "object",
|
63 |
"properties": {
|
64 |
"conversation_summary": {
|
65 |
"type": "string",
|
66 |
+
"description": "A short summary of the current conversation so the human agent can quickly get up "
|
67 |
+
"to speed. Make sure you include all relevant details."
|
68 |
},
|
69 |
},
|
70 |
"required": ["conversation_summary"]
|
|
|
82 |
st.session_state["openai_model"] = "gpt-35-turbo"
|
83 |
|
84 |
if "messages" not in st.session_state:
|
85 |
+
st.session_state.messages = [{"role": "system", "content": "You are a helpful customer support agent for The Home "
|
86 |
+
"Depot. Your goal is to answer as many questions as possible without escalating to a human agent."},]
|
|
|
87 |
|
88 |
for message in st.session_state.messages:
|
89 |
if message["role"] == "assistant" or message["role"] == "user":
|
|
|
103 |
"arguments": "",
|
104 |
}
|
105 |
|
106 |
+
for response in client.chat.completions.create(
|
107 |
+
model=st.session_state["openai_model"],
|
108 |
+
messages=[
|
109 |
+
{"role": m["role"], "content": m["content"], "name": m["name"]} if "name" in m else
|
110 |
+
{"role": m["role"], "content": m["content"]}
|
111 |
+
for m in st.session_state.messages
|
112 |
+
],
|
113 |
+
functions=functions,
|
114 |
+
function_call="auto",
|
115 |
+
stream=True,
|
116 |
+
):
|
117 |
+
if len(response.choices) > 0:
|
118 |
+
delta = response.choices[0].delta
|
119 |
+
|
120 |
+
full_message += (delta.content or "")
|
121 |
+
if delta.function_call is not None:
|
122 |
+
if delta.function_call.name is not None:
|
123 |
+
func_call["name"] = delta.function_call.name
|
124 |
+
if delta.function_call.arguments is not None:
|
125 |
+
func_call["arguments"] += delta.function_call.arguments
|
126 |
+
|
127 |
+
message_placeholder.markdown(full_message + "")
|
128 |
+
|
129 |
+
if func_call["name"] is not None and func_call["arguments"] != "":
|
130 |
+
print(f"Function generation requested, calling function")
|
131 |
+
function_response = call_function(st.session_state.messages, func_call)
|
132 |
+
print("function response")
|
133 |
+
print(function_response)
|
134 |
+
st.session_state.messages.append(function_response)
|
135 |
+
|
136 |
+
message_placeholder = st.empty()
|
137 |
+
full_message = ""
|
138 |
+
|
139 |
for response in client.chat.completions.create(
|
140 |
model=st.session_state["openai_model"],
|
141 |
messages=[
|
142 |
+
{"role": m["role"], "content": m["content"], "name": m["name"]} if "name" in m else
|
143 |
+
{"role": m["role"], "content": m["content"]}
|
144 |
+
for m in st.session_state.messages
|
145 |
+
],
|
146 |
functions=functions,
|
147 |
function_call="auto",
|
148 |
stream=True,
|
|
|
157 |
if delta.function_call.arguments is not None:
|
158 |
func_call["arguments"] += delta.function_call.arguments
|
159 |
|
160 |
+
message_placeholder.markdown(full_message + "")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
161 |
|
162 |
message_placeholder.markdown(full_message)
|
163 |
|
functions.py
CHANGED
@@ -1,6 +1,9 @@
|
|
1 |
import json
|
2 |
-
|
3 |
import requests
|
|
|
|
|
|
|
4 |
|
5 |
|
6 |
def call_function(messages, function_call):
|
@@ -8,13 +11,13 @@ def call_function(messages, function_call):
|
|
8 |
Currently extended by adding clauses to this if statement."""
|
9 |
print(function_call)
|
10 |
|
11 |
-
if function_call["name"] == "
|
12 |
try:
|
13 |
parsed_output = json.loads(
|
14 |
function_call["arguments"]
|
15 |
)
|
16 |
print("Looking up order status")
|
17 |
-
results =
|
18 |
return {
|
19 |
"role": "function",
|
20 |
"name": function_call["name"],
|
@@ -24,7 +27,39 @@ def call_function(messages, function_call):
|
|
24 |
# print(parsed_output)
|
25 |
print(f"Function execution failed")
|
26 |
print(f"Error message: {e}")
|
27 |
-
return {"role": "function", "content": "call failed", "name": "
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
28 |
elif function_call["name"] == "refer_to_human_agent":
|
29 |
try:
|
30 |
parsed_output = json.loads(
|
@@ -46,96 +81,109 @@ def call_function(messages, function_call):
|
|
46 |
raise Exception("Function does not exist and cannot be called")
|
47 |
|
48 |
|
49 |
-
def
|
50 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
51 |
|
52 |
-
payload =
|
53 |
-
"masterOrderNumber": f"{order_number}",
|
54 |
-
"emailId": f"{email_address}",
|
55 |
-
"type": "online",
|
56 |
-
"storeNumber": "1875"
|
57 |
-
})
|
58 |
headers = {
|
59 |
'authority': 'www.lowes.com',
|
60 |
-
'accept': 'application/
|
61 |
'accept-language': 'en-US,en;q=0.9',
|
62 |
-
'
|
63 |
-
'
|
64 |
-
'origin': 'https://www.lowes.com',
|
65 |
-
'referer': 'https://www.lowes.com/mylowes/orders/checkorderstatus',
|
66 |
'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
67 |
'sec-ch-ua-mobile': '?0',
|
68 |
'sec-ch-ua-platform': '"Windows"',
|
69 |
-
'sec-fetch-dest': '
|
70 |
-
'sec-fetch-mode': '
|
71 |
'sec-fetch-site': 'same-origin',
|
72 |
-
'user
|
73 |
-
'
|
74 |
-
|
75 |
-
|
76 |
-
response = requests.request("POST", url, headers=headers, data=payload)
|
77 |
-
|
78 |
-
return response.text
|
79 |
-
|
80 |
-
def find_product_info(query: str) -> Dict[str, Any]:
|
81 |
-
url = "https://brickseek.com/api/brickseek-public"
|
82 |
-
|
83 |
-
payload = "{\"params\":{\"search\":\"Wireless Earbuds\",\"store_type\":10},\"url\":\"ajax/product_search\"}"
|
84 |
-
headers = {
|
85 |
-
'authority': 'brickseek.com',
|
86 |
-
'accept': '*/*',
|
87 |
-
'accept-language': 'en-US,en;q=0.9',
|
88 |
-
'baggage': 'sentry-environment=vercel-production,sentry-release=ca34a251f847fd72e72bf9f0656cea41aec74315,sentry-public_key=cdad1d45449541899fbf219ad1d6ebdb,sentry-trace_id=d9fb3a828b3045b688a444c93ebe25a0',
|
89 |
-
'content-type': 'text/plain;charset=UTF-8',
|
90 |
-
'cookie': '__cf_bm=HU3YnfBsggOePLMQc2lMbpEGvRS6XGg7aPex5VNdJ3Q-1700341559-0-AWvI96ju3QZHuINgeCgWv4wciLY8puzHv0o+iAitfuZARVg+dp4RAKSG/Pr0Gey2lUWsJj0ORKBaphLMq51IHpc=; cf_clearance=1Bd418eBhJTFAfAAdoK8d3I3EFpST.1ler5y0XFXf8k-1700341561-0-1-389cfab0.3c4718a5.6f9da550-0.2.1700341561',
|
91 |
-
'origin': 'https://brickseek.com',
|
92 |
-
'referer': 'https://brickseek.com/lowes-inventory-checker',
|
93 |
-
'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
94 |
-
'sec-ch-ua-mobile': '?0',
|
95 |
-
'sec-ch-ua-platform': '"Windows"',
|
96 |
-
'sec-fetch-dest': 'empty',
|
97 |
-
'sec-fetch-mode': 'cors',
|
98 |
-
'sec-fetch-site': 'same-origin',
|
99 |
-
'sentry-trace': 'd9fb3a828b3045b688a444c93ebe25a0-874f3c7351675e10-1',
|
100 |
-
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0'
|
101 |
-
}
|
102 |
-
|
103 |
-
response = requests.request("POST", url, headers=headers, data=payload)
|
104 |
-
|
105 |
-
print(response.text)
|
106 |
-
|
107 |
-
# The output is a JSON object
|
108 |
-
# Turn it into a python dictionary
|
109 |
-
response_dict = json.loads(response.text)
|
110 |
-
|
111 |
-
return response_dict
|
112 |
-
|
113 |
-
def get_product_listing(sku: int):
|
114 |
-
url = f"https://www.lowes.com/search?searchTerm={sku}"
|
115 |
-
|
116 |
-
payload = {}
|
117 |
-
headers = {
|
118 |
-
'authority': 'www.lowes.com',
|
119 |
-
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
120 |
-
'accept-language': 'en-US,en;q=0.9',
|
121 |
-
'cookie': 'dbidv2=56b2862a-8fa1-4476-ae09-6368c4fab002; al_sess=FuA4EWsuT07UWryyq/3foEQIwIqOxmho8CAP0qIisJkWP6yrEciiDxJiF8HPZ/09; region=east; AKA_A2=A; EPID=NTZiMjg2MmEtOGZhMS00NDc2LWFlMDktNjM2OGM0ZmFiMDAy; bm_sz=FD2C6C9185843B61533705694D14EF09~YAAQTCXRFy7EGs+LAQAA9Cok5BVOqBRlOAkc2ibX247znTkInxYHj4yFBMY+lWEGSucc9Vag1mzB5owd7ujrIa8Tt+k8M+uWh6wPPUWz3QF7RpyIyxsA4NOmjVwds1rEkGCtXtnhtxNvg9eoBeVW2rKmOI+Wo6eeyG5ZD/Be3I8J0Mw859Xt03pOB7zh2NviHhi1rTbZLCqj7ihbL4OpgQWv4gd8p5JX2VOFHAjWA3xPtGEVZuPn3tcMJTKbETxO4xHmmO+ER0l6Pgsk+hDYu/G6s71XDkkcDyR2XosdOhO9sIYljoBjBCGktjJird6wvK8WJEC+9WFKdeY=~3486278~4604217; ph_aid=3c68acb4-b3eb-487a-fc03-1cd3fc616418-7080571749703-454eb8c121d15-bf29dec353e8d; sn=1875; sd=%7B%22id%22%3A%221875%22%2C%22zip%22%3A%2230307%22%2C%22city%22%3A%22Atlanta%22%2C%22state%22%3A%22GA%22%2C%22name%22%3A%22Atlanta-Edgewood%20Lowe\'s%22%2C%22region%22%3A%223%22%7D; zipcode=30307; nearbyid=1875; zipstate=GA; user=%7B%22zipPrompt%22%3Atrue%7D; audience=DIY; _abck=84784437A2290F7C7665B869C07C4FDE~0~YAAQTCXRFznOGs+LAQAApl0l5AoUWttzoglFBJBV0r/WGr6wXArpqRxmVKRftBWRNCD7Rc/+z809D45jGbTU0yldpjr9Jq5XeDPG1B6Gdkb3oeu+pL7t1YdLuYUU8pdsnTHiuNU6zW7wKAyzF7lmeXACJHQrlO7cN+zqBaTaile96J18Gj82+zHpDvkU1RuhcqH3rNlV8jq8Ecn8rminJr1LfE4xiOM6SH6yL0eFVl2T4wbNOpIhlZ7ycluXvEHEJQYrb8U3me7oJ0FVDbKXa8mi50c3LPk/maBSzz3LXvK8WwXAiMgWMnu7+D4r96p9YKKXVxiN2khwsm/YixV2j5vtGCEboSy+yWcBTZyDimKxpCf8JYbPRVvJyvgFmbEY/IZcDkueOCKIGxIsSfP+pyReapNRw0cvwmyBtzKDX4bnjU9lGGWZeoEUzwYzpheqs6Z2NyPpkpIl~-1~-1~-1; prodNumber=2; TAsessionID=a9359468-38d7-478b-98e3-860e86a1c42a|NEW; _lgsid=1700342200927; grs_search_token=HEAD:I3:1:NA:NA:b3dc2d9f6b133c15b34e9ca2541bf2dd; seo-partner=gDTMXB9g7l46qsQ3gCM3qCMsoDgSmXpC; ak_bmsc=A80C29BEB24AF3C79480B0F09D37CF62~000000000000000000000000000000~YAAQruULFz542duLAQAA5BRL5BXlhv5ALaFuOMlnw0rduBHyCy8g2x4aoRSl0bjIyvNthNZqx/oMOjDmsDXaGHch5h0UTU2NyX0uSZpoGaD5Nu7axdj83DCrq/+sLwzIF+fJuEVH082RuCsd8sgxzIPi+aapEk1DmwWZOWrcfpFqtAPPlKS4hBGcjW6jAPLFEwTsQpcqzKeAXG0WndvQa+UEg8LIHLTWhIG3AyrosHtIjhh9TgdBLz4qO+kJiBJqvCzsYmzgcVEJg2p63heU2mk81o1uHusoFpOr+9S4VG7ImIVxnOgpdloinc9kFQ3fhQRonCWzfX9mM9Fq3LvgL3lixNgkdAFbQv9D9uD9CtpqorrXUzYcP7R8Mm/bzUBSFPxQ3i1z0fynE9S9VeiyJ117QrGVbCo/hbzsZ1d2Bxa2T8plvUCFXGzma4B3IaB6uGdOqshQqEP5QGSiov1P; sbsd=spqmx35Jl1HZrCR8jTl/PwpARJNPMewXjZUqj7gbzQcY4wcZLgFQ9KZ5ScmDCPq9IQAJWPpG/ZzKqzHsEGcsMQieWXmXGHxPNFBLvWBK4e3P+9++e+Vt/LQ70pv2wTqJRSzpgXZKAD/1P3u8gwHUBNQ==; bm_mi=6808FB6A942BFA186D4C6F584A7C2C13~YAAQruULF1R42duLAQAAbx5L5BX3ooyVh0CCz1S9KEPjsw+YZ/EyDyiRfDZ5NN2w6tN4NyVhogBqJ40FFHb7E9ZsM3x5B5RHpjiDnd1z1t3nDhnLDCyQz/fDo28shr6/wtFLmRMzefrDK2MLPaoOmJ0HN2W/YgNp2H5LhNHPdClZqsrKDCbcI0Bu4PO/MREIY/7UYbVoV7Md1oZgMVxL42Rjsu7SKACEfGByzzysZCc8Fnlz66oecOp8+SMGPcsNk7+vrVklNCXi9VObPp5Zs02JmO4u3uGrTzHX91RvRNP5uLBmAcg3llq0XDnDUeLG~1; salsify_session_id=0869bdc0-eb71-4df8-8a00-2581bdc455a1; akavpau_default=1700342511~id=d12fe16cb50bff6560c1af6055b1278c; akavpau_cart=1700342513~id=d28f6ce6f94e835c9677ad1aa459d716; notice_behavior=implied,eu; p13n=%7B%22zipCode%22%3A%2230307%22%2C%22storeId%22%3A%221875%22%2C%22state%22%3A%22GA%22%2C%22audienceList%22%3A%5B%5D%7D; g_previous=%7B%22gpvPageLoadTime%22%3A%220.00%22%2C%22gpvPageScroll%22%3A%2226%7C27%7C0%7C3149%22%2C%22gpvSitesections%22%3A%22checkorderstatus%22%2C%22gpvSiteId%22%3A%22desktop%22%2C%22gpvPageType%22%3A%22check-order-status%22%7D; akaalb_prod_dual=1700428639~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=2cf1cd354d83c94f9da60e4ebbc25c6e; bm_sv=8B13230A1BED940DF1CD6E283A4D1610~YAAQruULF7R42duLAQAAVpBL5BUdn0LlPXETpnblyyruPK4VG5bVhjNMqHn059CHQH/1BiSLnADboIS3aZWm2HrbjSicvoG6MsTqumzNORm9VzKfH3+PRzhqk0m7XDglfg2qO03xrSoMhn2x0HtBaFHYUu+LPlZYRrrU+chMrVHtzp5i8JTx3grQiWcJnahnj5Dm2Nm6r3d22ifqZG1hcxA9oNG69Kbiwinwv2B0Dt7kbujRggMq+dV/rHHmdyNF~1; _abck=84784437A2290F7C7665B869C07C4FDE~-1~YAAQruULFyp82duLAQAAjltO5Aq5Z2Wy7IwrT8LGPETsMNBYgR3ioKo05jXyjh7pnHJE/6HuQ48H84Qlbz3pLV0XC0Em8SxGIWwx4/jtqFwVP2HseXKdmJJm7bO5DHvTg1K7wu1LyubY7qU+eSTAxOMgnJiKjMy10pGMnVIsgS5/3UWvZprfNvZWYVFT/q6FtVpK7EOXXyI+FIherVv1IQBngeQbxFFT3sZ9yGVgcpuXffHW5G2ph7UB3sKQCVyU+XovIpman//ZoiNIBUrp9NR5pOoIA6ui8Wg8N4cm/bBUGRfxBCw4je16mWTbZP5Jm0XQvREBYvBBR8mXhP/iZvReV8YCMg5zjerxzeT3MGyzIipoLQeLxLzr9I/SUG5cHN7mXh8YFvmbuppyhnBQCTKrnhm8wZ+6Ga0eHY0jz9zhgSijOECuGxpnV4mdtC/rX7hswdMyAmmj~0~-1~-1; ak_bmsc=A80C29BEB24AF3C79480B0F09D37CF62~000000000000000000000000000000~YAAQruULFyt82duLAQAAjltO5BUVgHseFizgyiwC7KNxfqvcDdkjtdW0+ykbMNKpCOBkYKvRomJO8hYi+7pVA6Oi5vIWP7qYR9hLzp5KZz8nWu3DkYMpaDqbMTD16nRwkh36KS/NYhosAjQABuYoOUYw1IbBsr1L/uKHHOJv+jLyZcdpI92BOATTt/x7ZmVxVTJMH3Po+92V7gsXFvbJr281h3e41RVJUpUD4KG+4OfnJTaHuGqK5z2+Iw0hRvJtKDnWaaG9/iCLxLwFm9tFO7+8hDMW7SdoolHwKZ0KeajzTbYkugFRiTbH0SyKnM2zqMIt0hJfvIYsPkwzvxXR23BYoEl//ocbzN1Egsiknd83AtUgDG0qTMNJ/fpS8ey0Lpic9jk+qxm1aIozuv6wqZMcN+pCVuOZXMrV1YYo6Iifzr2z9dtTtufBvFQI6UrLBYVStlorAkMNO1ieotC48iLQoZnWa7Cex0FFNQ==; akaalb_prod_dual=1700426449~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=987589ee78f2a6df0f0ac4a0eb2f0327',
|
122 |
-
'referer': 'https://www.lowes.com/c/Departments',
|
123 |
-
'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
124 |
-
'sec-ch-ua-mobile': '?0',
|
125 |
-
'sec-ch-ua-platform': '"Windows"',
|
126 |
-
'sec-fetch-dest': 'document',
|
127 |
-
'sec-fetch-mode': 'navigate',
|
128 |
-
'sec-fetch-site': 'same-origin',
|
129 |
-
'sec-fetch-user': '?1',
|
130 |
-
'upgrade-insecure-requests': '1',
|
131 |
-
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0'
|
132 |
}
|
133 |
|
134 |
response = requests.request("GET", url, headers=headers, data=payload)
|
135 |
-
|
136 |
return response.text
|
137 |
|
138 |
|
139 |
-
|
140 |
def refer_to_human_agent(summary: str) -> str:
|
141 |
return "I'm sorry, I don't know how to help you with that. I'll refer you to a human agent."
|
|
|
1 |
import json
|
2 |
+
import pandas as pd
|
3 |
import requests
|
4 |
+
from pandas import DataFrame
|
5 |
+
|
6 |
+
from home_depot_result import home_depot_result
|
7 |
|
8 |
|
9 |
def call_function(messages, function_call):
|
|
|
11 |
Currently extended by adding clauses to this if statement."""
|
12 |
print(function_call)
|
13 |
|
14 |
+
if function_call["name"] == "lookup_order_status":
|
15 |
try:
|
16 |
parsed_output = json.loads(
|
17 |
function_call["arguments"]
|
18 |
)
|
19 |
print("Looking up order status")
|
20 |
+
results = get_lookup_order_status(parsed_output["email_address"], parsed_output["order_number"])
|
21 |
return {
|
22 |
"role": "function",
|
23 |
"name": function_call["name"],
|
|
|
27 |
# print(parsed_output)
|
28 |
print(f"Function execution failed")
|
29 |
print(f"Error message: {e}")
|
30 |
+
return {"role": "function", "content": "call failed", "name": "lookup_order_status"}
|
31 |
+
elif function_call["name"] == "lookup_product":
|
32 |
+
try:
|
33 |
+
parsed_output = json.loads(
|
34 |
+
function_call["arguments"]
|
35 |
+
)
|
36 |
+
print("Looking up product sku")
|
37 |
+
results = lookup_product(parsed_output["query"])
|
38 |
+
return {
|
39 |
+
"role": "function",
|
40 |
+
"name": function_call["name"],
|
41 |
+
"content": str(results),
|
42 |
+
}
|
43 |
+
except Exception as e:
|
44 |
+
print(f"Function execution failed")
|
45 |
+
print(f"Error message: {e}")
|
46 |
+
return {"role": "function", "content": "call failed", "name": "lookup_product"}
|
47 |
+
elif function_call["name"] == "get_product_listing":
|
48 |
+
try:
|
49 |
+
parsed_output = json.loads(
|
50 |
+
function_call["arguments"]
|
51 |
+
)
|
52 |
+
print("retrieving product listing")
|
53 |
+
results = get_product_listing(parsed_output["sku"])
|
54 |
+
return {
|
55 |
+
"role": "function",
|
56 |
+
"name": function_call["name"],
|
57 |
+
"content": str(results),
|
58 |
+
}
|
59 |
+
except Exception as e:
|
60 |
+
print(f"Function execution failed")
|
61 |
+
print(f"Error message: {e}")
|
62 |
+
return {"role": "function", "content": "call failed", "name": "get_product_listing"}
|
63 |
elif function_call["name"] == "refer_to_human_agent":
|
64 |
try:
|
65 |
parsed_output = json.loads(
|
|
|
81 |
raise Exception("Function does not exist and cannot be called")
|
82 |
|
83 |
|
84 |
+
def get_lookup_order_status(email_address: str, order_number: int) -> str:
|
85 |
+
return home_depot_result
|
86 |
+
# url = "https://www.lowes.com/api/mylowes/orders/details"
|
87 |
+
#
|
88 |
+
# payload = json.dumps({
|
89 |
+
# "masterOrderNumber": f"{order_number}",
|
90 |
+
# "emailId": f"{email_address}",
|
91 |
+
# "type": "online",
|
92 |
+
# "storeNumber": "1875"
|
93 |
+
# })
|
94 |
+
# headers = {
|
95 |
+
# 'authority': 'www.lowes.com',
|
96 |
+
# 'accept': 'application/json, text/plain, */*',
|
97 |
+
# 'accept-language': 'en-US,en;q=0.9',
|
98 |
+
# 'content-type': 'application/json',
|
99 |
+
# 'cookie': 'dbidv2=56b2862a-8fa1-4476-ae09-6368c4fab002; al_sess=FuA4EWsuT07UWryyq/3foEQIwIqOxmho8CAP0qIisJkWP6yrEciiDxJiF8HPZ/09; HPLA=1; region=east; AKA_A2=A; EPID=NTZiMjg2MmEtOGZhMS00NDc2LWFlMDktNjM2OGM0ZmFiMDAy; bm_sz=FD2C6C9185843B61533705694D14EF09~YAAQTCXRFy7EGs+LAQAA9Cok5BVOqBRlOAkc2ibX247znTkInxYHj4yFBMY+lWEGSucc9Vag1mzB5owd7ujrIa8Tt+k8M+uWh6wPPUWz3QF7RpyIyxsA4NOmjVwds1rEkGCtXtnhtxNvg9eoBeVW2rKmOI+Wo6eeyG5ZD/Be3I8J0Mw859Xt03pOB7zh2NviHhi1rTbZLCqj7ihbL4OpgQWv4gd8p5JX2VOFHAjWA3xPtGEVZuPn3tcMJTKbETxO4xHmmO+ER0l6Pgsk+hDYu/G6s71XDkkcDyR2XosdOhO9sIYljoBjBCGktjJird6wvK8WJEC+9WFKdeY=~3486278~4604217; TAsessionID=0421ade3-7a84-4692-9ad8-d67927442c16|NEW; ak_bmsc=A80C29BEB24AF3C79480B0F09D37CF62~000000000000000000000000000000~YAAQTCXRF0zEGs+LAQAALC0k5BVU2zm/cgpTeSAB5oJBqTX8djy+rUtTzcodc06GoFRo/QB3NhhzPSPPvUd6lmCx0k5hK2OgXrT0s2ifZbUneCF7u/kOPX+aDP51oWsuZnVOScC1doltiJAJ7UVHfSlZ+7aCjw5+bm5istYopvV+sJHwtPdNabdtculQtPwq7uRDJadaMZCd+pieFtiMEltlxmCTYZp0ATGsxOSnqKn01LIOMAPHUNIJivM9tMPTSvDvr3mW0JbB7slTFD5CHuRLWYhHtT5LT8BzF0R3VTy+SGkrzdLyF8IuQmFfWAiT7FIHUrDtcxRZpjQUBkenz8ObtREzb23FobM3pWZgb9YbdxnxCUdgUnI33Hkh+uKFxNHfnCLCtwddDQ==; ph_aid=3c68acb4-b3eb-487a-fc03-1cd3fc616418-7080571749703-454eb8c121d15-bf29dec353e8d; _lgsid=1700339660085; sn=1875; sd=%7B%22id%22%3A%221875%22%2C%22zip%22%3A%2230307%22%2C%22city%22%3A%22Atlanta%22%2C%22state%22%3A%22GA%22%2C%22name%22%3A%22Atlanta-Edgewood%20Lowe\'s%22%2C%22region%22%3A%223%22%7D; zipcode=30307; nearbyid=1875; zipstate=GA; bm_mi=6808FB6A942BFA186D4C6F584A7C2C13~YAAQTCXRFzfLGs+LAQAA1fMk5BW7b5b1fpebVli+q0WvFABZFCZymNL07sKET78++WCh2c2PlR2cWb0Mhgy6c0kb+eQQXXnhzTvCBO+c3SXbahePgkJIiNOjvqCpTFDAiy4o0TOqYYTsE6ZalTslHCv7kgGY96uF1sBUFxvNqSN3/Cj5CGcIaCwZZb15pkIFLj7DXqoZ+AEYScs4TUAzhDbJ/g1ShZGx0fUeUqHVwn3pzgdFuuPh2O/WTXQzA4lgzTY+dkhTw5pdbc8vvsu7SdXK0d6R0JW3UyuP5oMThUuIetC0PoVSmycGaHLIPz16~1; user=%7B%22zipPrompt%22%3Atrue%7D; audience=DIY; _abck=84784437A2290F7C7665B869C07C4FDE~0~YAAQTCXRFznOGs+LAQAApl0l5AoUWttzoglFBJBV0r/WGr6wXArpqRxmVKRftBWRNCD7Rc/+z809D45jGbTU0yldpjr9Jq5XeDPG1B6Gdkb3oeu+pL7t1YdLuYUU8pdsnTHiuNU6zW7wKAyzF7lmeXACJHQrlO7cN+zqBaTaile96J18Gj82+zHpDvkU1RuhcqH3rNlV8jq8Ecn8rminJr1LfE4xiOM6SH6yL0eFVl2T4wbNOpIhlZ7ycluXvEHEJQYrb8U3me7oJ0FVDbKXa8mi50c3LPk/maBSzz3LXvK8WwXAiMgWMnu7+D4r96p9YKKXVxiN2khwsm/YixV2j5vtGCEboSy+yWcBTZyDimKxpCf8JYbPRVvJyvgFmbEY/IZcDkueOCKIGxIsSfP+pyReapNRw0cvwmyBtzKDX4bnjU9lGGWZeoEUzwYzpheqs6Z2NyPpkpIl~-1~-1~-1; prodNumber=2; akavpau_default=1700340036~id=0d6c97bed4e510e00b212e2c7151704a; akavpau_cart=1700340038~id=c8d179c7ab834971d54fb6b3f37fb5cd; notice_behavior=implied,eu; p13n=%7B%22zipCode%22%3A%2230307%22%2C%22storeId%22%3A%221875%22%2C%22state%22%3A%22GA%22%2C%22audienceList%22%3A%5B%5D%7D; g_previous=%7B%22gpvPageLoadTime%22%3A%220.00%22%2C%22gpvPageScroll%22%3A%228%7C9%7C0%7C10258%22%2C%22gpvSitesections%22%3A%22checkorderstatus%22%2C%22gpvSiteId%22%3A%22desktop%22%2C%22gpvPageType%22%3A%22check-order-status%22%7D; PT_ST=6c202780-f553-4693-bb78-129dedacc842; akaalb_prod_dual=1700426396~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=ddbf1d57536e8f52d396da19f5e80dc4; bm_sv=8B13230A1BED940DF1CD6E283A4D1610~YAAQTCXRFx0AG8+LAQAAb1Yp5BXh8z5aM//hZ+YV+MjKJgNR34HJmJZTf3AixPor3SXeREgpHBbsqJUONoLbqAG1NGKbZR0gevtiZH9fdU0VojEHjQOvH0dbif9h9QivxlMSphKTTDy5EQYEFumXDVmNKtMKFjh6uV5Imj2r5hfucyAyTZiQ6V0yOiRigqEUDnY3Yzx2y2CPKvHPpgOLu6NREx34B64M8OOl2nzIJCzlhZfizbm8tDyr6+YYRtgB~1; _abck=84784437A2290F7C7665B869C07C4FDE~-1~YAAQTCXRFyEKG8+LAQAAmScq5AqXSATqkt25kWxxHAg3BLxuo+Nz1ihcUXOUs/s0PjLsQmvz72U0IrKBhYjfN6DLPT0x/N4/ntmJOZQYWN0SUrK3S1MKBuDFQWRMQAdDYPgPrQ9sGLxg/9jiUX8mNYgODb9F9iOKvS0tl0W1MBaPygnbVYeo6YYU/7/GV3KuiLSUbHLRn2Y49ltGRz4SFJpy12VJTBP4f1SYjBovTH3WlsVfdVbY/4YNfGuA862HvGYwo2D7oDMhZsMxZNdm8vBEeGJS0GyOTmeZtUal0izS3wq6KC5ybCiwaCGlI+D8nYkg7SZvjfZTmkvr9oLRW+R40BbDk2OfXGjrqSEq4WLXoR7oFI9iIekZcsOb5nmrtTQEYcjkWCK6jLnIN5ayo+7gbwud/+a9iH3VNctfWmgOamOPjorT79jy3ydPfflYCW9e4iG1W6Ff~0~-1~-1; PT_ST=3c02c563-e159-4766-be6b-f6df25069176; akaalb_prod_dual=1700426449~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=987589ee78f2a6df0f0ac4a0eb2f0327',
|
100 |
+
# 'origin': 'https://www.lowes.com',
|
101 |
+
# 'referer': 'https://www.lowes.com/mylowes/orders/checkorderstatus',
|
102 |
+
# 'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
103 |
+
# 'sec-ch-ua-mobile': '?0',
|
104 |
+
# 'sec-ch-ua-platform': '"Windows"',
|
105 |
+
# 'sec-fetch-dest': 'empty',
|
106 |
+
# 'sec-fetch-mode': 'cors',
|
107 |
+
# 'sec-fetch-site': 'same-origin',
|
108 |
+
# 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0',
|
109 |
+
# 'x-requested-with': 'XMLHttpRequest'
|
110 |
+
# }
|
111 |
+
#
|
112 |
+
# response = requests.request("POST", url, headers=headers, data=payload)
|
113 |
+
#
|
114 |
+
# return response.text
|
115 |
+
|
116 |
+
|
117 |
+
def lookup_product(query: str) -> DataFrame:
|
118 |
+
df = pd.read_csv('home_depot_data.csv')
|
119 |
+
# df['score'] = df['title'].apply(lambda x: fuzz.ratio(x, query))
|
120 |
+
queries = query.split(" ")
|
121 |
+
df['contains_queries'] = df['url'].str.contains('|'.join(queries), case=False)
|
122 |
+
|
123 |
+
print(df[df["contains_queries"] == True])
|
124 |
+
|
125 |
+
return df[df["contains_queries"] == True].head(5)['title']
|
126 |
+
|
127 |
+
# url = "https://brickseek.com/api/brickseek-public"
|
128 |
+
#
|
129 |
+
# payload = {"params": {"search": query, "store_type": 10}, "url": "ajax/product_search"}
|
130 |
+
# headers = {
|
131 |
+
# 'authority': 'brickseek.com',
|
132 |
+
# 'accept': '*/*',
|
133 |
+
# 'accept-language': 'en-US,en;q=0.9',
|
134 |
+
# 'baggage': 'sentry-environment=vercel-production,sentry-release=ca34a251f847fd72e72bf9f0656cea41aec74315,sentry-public_key=cdad1d45449541899fbf219ad1d6ebdb,sentry-trace_id=d9fb3a828b3045b688a444c93ebe25a0',
|
135 |
+
# 'content-type': 'text/plain;charset=UTF-8',
|
136 |
+
# 'cookie': '__cf_bm=HU3YnfBsggOePLMQc2lMbpEGvRS6XGg7aPex5VNdJ3Q-1700341559-0-AWvI96ju3QZHuINgeCgWv4wciLY8puzHv0o+iAitfuZARVg+dp4RAKSG/Pr0Gey2lUWsJj0ORKBaphLMq51IHpc=; cf_clearance=1Bd418eBhJTFAfAAdoK8d3I3EFpST.1ler5y0XFXf8k-1700341561-0-1-389cfab0.3c4718a5.6f9da550-0.2.1700341561',
|
137 |
+
# 'origin': 'https://brickseek.com',
|
138 |
+
# 'referer': 'https://brickseek.com/lowes-inventory-checker',
|
139 |
+
# 'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
140 |
+
# 'sec-ch-ua-mobile': '?0',
|
141 |
+
# 'sec-ch-ua-platform': '"Windows"',
|
142 |
+
# 'sec-fetch-dest': 'empty',
|
143 |
+
# 'sec-fetch-mode': 'cors',
|
144 |
+
# 'sec-fetch-site': 'same-origin',
|
145 |
+
# 'sentry-trace': 'd9fb3a828b3045b688a444c93ebe25a0-874f3c7351675e10-1',
|
146 |
+
# 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0'
|
147 |
+
# }
|
148 |
+
#
|
149 |
+
# response = requests.request("POST", url, headers=headers, data=payload)
|
150 |
+
#
|
151 |
+
# print(response.text)
|
152 |
+
#
|
153 |
+
# # The output is a JSON object
|
154 |
+
# # Turn it into a python dictionary
|
155 |
+
# response_dict = json.loads(response.text)
|
156 |
+
#
|
157 |
+
# return response_dict
|
158 |
+
|
159 |
+
|
160 |
+
# https://www.lowes.com/search?searchTerm=MRN12
|
161 |
+
def get_product_listing(sku: str):
|
162 |
+
print("get_product_listing")
|
163 |
+
url = f"https://www.lowes.com/search?searchTerm={sku}"
|
164 |
|
165 |
+
payload = {}
|
|
|
|
|
|
|
|
|
|
|
166 |
headers = {
|
167 |
'authority': 'www.lowes.com',
|
168 |
+
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
169 |
'accept-language': 'en-US,en;q=0.9',
|
170 |
+
# 'cookie': 'dbidv2=56b2862a-8fa1-4476-ae09-6368c4fab002; al_sess=FuA4EWsuT07UWryyq/3foEQIwIqOxmho8CAP0qIisJkWP6yrEciiDxJiF8HPZ/09; region=east; AKA_A2=A; EPID=NTZiMjg2MmEtOGZhMS00NDc2LWFlMDktNjM2OGM0ZmFiMDAy; bm_sz=FD2C6C9185843B61533705694D14EF09~YAAQTCXRFy7EGs+LAQAA9Cok5BVOqBRlOAkc2ibX247znTkInxYHj4yFBMY+lWEGSucc9Vag1mzB5owd7ujrIa8Tt+k8M+uWh6wPPUWz3QF7RpyIyxsA4NOmjVwds1rEkGCtXtnhtxNvg9eoBeVW2rKmOI+Wo6eeyG5ZD/Be3I8J0Mw859Xt03pOB7zh2NviHhi1rTbZLCqj7ihbL4OpgQWv4gd8p5JX2VOFHAjWA3xPtGEVZuPn3tcMJTKbETxO4xHmmO+ER0l6Pgsk+hDYu/G6s71XDkkcDyR2XosdOhO9sIYljoBjBCGktjJird6wvK8WJEC+9WFKdeY=~3486278~4604217; ph_aid=3c68acb4-b3eb-487a-fc03-1cd3fc616418-7080571749703-454eb8c121d15-bf29dec353e8d; sn=1875; sd=%7B%22id%22%3A%221875%22%2C%22zip%22%3A%2230307%22%2C%22city%22%3A%22Atlanta%22%2C%22state%22%3A%22GA%22%2C%22name%22%3A%22Atlanta-Edgewood%20Lowe\'s%22%2C%22region%22%3A%223%22%7D; zipcode=30307; nearbyid=1875; zipstate=GA; user=%7B%22zipPrompt%22%3Atrue%7D; audience=DIY; _abck=84784437A2290F7C7665B869C07C4FDE~0~YAAQTCXRFznOGs+LAQAApl0l5AoUWttzoglFBJBV0r/WGr6wXArpqRxmVKRftBWRNCD7Rc/+z809D45jGbTU0yldpjr9Jq5XeDPG1B6Gdkb3oeu+pL7t1YdLuYUU8pdsnTHiuNU6zW7wKAyzF7lmeXACJHQrlO7cN+zqBaTaile96J18Gj82+zHpDvkU1RuhcqH3rNlV8jq8Ecn8rminJr1LfE4xiOM6SH6yL0eFVl2T4wbNOpIhlZ7ycluXvEHEJQYrb8U3me7oJ0FVDbKXa8mi50c3LPk/maBSzz3LXvK8WwXAiMgWMnu7+D4r96p9YKKXVxiN2khwsm/YixV2j5vtGCEboSy+yWcBTZyDimKxpCf8JYbPRVvJyvgFmbEY/IZcDkueOCKIGxIsSfP+pyReapNRw0cvwmyBtzKDX4bnjU9lGGWZeoEUzwYzpheqs6Z2NyPpkpIl~-1~-1~-1; prodNumber=2; TAsessionID=a9359468-38d7-478b-98e3-860e86a1c42a|NEW; _lgsid=1700342200927; grs_search_token=HEAD:I3:1:NA:NA:b3dc2d9f6b133c15b34e9ca2541bf2dd; seo-partner=gDTMXB9g7l46qsQ3gCM3qCMsoDgSmXpC; ak_bmsc=A80C29BEB24AF3C79480B0F09D37CF62~000000000000000000000000000000~YAAQruULFz542duLAQAA5BRL5BXlhv5ALaFuOMlnw0rduBHyCy8g2x4aoRSl0bjIyvNthNZqx/oMOjDmsDXaGHch5h0UTU2NyX0uSZpoGaD5Nu7axdj83DCrq/+sLwzIF+fJuEVH082RuCsd8sgxzIPi+aapEk1DmwWZOWrcfpFqtAPPlKS4hBGcjW6jAPLFEwTsQpcqzKeAXG0WndvQa+UEg8LIHLTWhIG3AyrosHtIjhh9TgdBLz4qO+kJiBJqvCzsYmzgcVEJg2p63heU2mk81o1uHusoFpOr+9S4VG7ImIVxnOgpdloinc9kFQ3fhQRonCWzfX9mM9Fq3LvgL3lixNgkdAFbQv9D9uD9CtpqorrXUzYcP7R8Mm/bzUBSFPxQ3i1z0fynE9S9VeiyJ117QrGVbCo/hbzsZ1d2Bxa2T8plvUCFXGzma4B3IaB6uGdOqshQqEP5QGSiov1P; sbsd=spqmx35Jl1HZrCR8jTl/PwpARJNPMewXjZUqj7gbzQcY4wcZLgFQ9KZ5ScmDCPq9IQAJWPpG/ZzKqzHsEGcsMQieWXmXGHxPNFBLvWBK4e3P+9++e+Vt/LQ70pv2wTqJRSzpgXZKAD/1P3u8gwHUBNQ==; bm_mi=6808FB6A942BFA186D4C6F584A7C2C13~YAAQruULF1R42duLAQAAbx5L5BX3ooyVh0CCz1S9KEPjsw+YZ/EyDyiRfDZ5NN2w6tN4NyVhogBqJ40FFHb7E9ZsM3x5B5RHpjiDnd1z1t3nDhnLDCyQz/fDo28shr6/wtFLmRMzefrDK2MLPaoOmJ0HN2W/YgNp2H5LhNHPdClZqsrKDCbcI0Bu4PO/MREIY/7UYbVoV7Md1oZgMVxL42Rjsu7SKACEfGByzzysZCc8Fnlz66oecOp8+SMGPcsNk7+vrVklNCXi9VObPp5Zs02JmO4u3uGrTzHX91RvRNP5uLBmAcg3llq0XDnDUeLG~1; salsify_session_id=0869bdc0-eb71-4df8-8a00-2581bdc455a1; akavpau_default=1700342511~id=d12fe16cb50bff6560c1af6055b1278c; akavpau_cart=1700342513~id=d28f6ce6f94e835c9677ad1aa459d716; notice_behavior=implied,eu; p13n=%7B%22zipCode%22%3A%2230307%22%2C%22storeId%22%3A%221875%22%2C%22state%22%3A%22GA%22%2C%22audienceList%22%3A%5B%5D%7D; g_previous=%7B%22gpvPageLoadTime%22%3A%220.00%22%2C%22gpvPageScroll%22%3A%2226%7C27%7C0%7C3149%22%2C%22gpvSitesections%22%3A%22checkorderstatus%22%2C%22gpvSiteId%22%3A%22desktop%22%2C%22gpvPageType%22%3A%22check-order-status%22%7D; akaalb_prod_dual=1700428639~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=2cf1cd354d83c94f9da60e4ebbc25c6e; bm_sv=8B13230A1BED940DF1CD6E283A4D1610~YAAQruULF7R42duLAQAAVpBL5BUdn0LlPXETpnblyyruPK4VG5bVhjNMqHn059CHQH/1BiSLnADboIS3aZWm2HrbjSicvoG6MsTqumzNORm9VzKfH3+PRzhqk0m7XDglfg2qO03xrSoMhn2x0HtBaFHYUu+LPlZYRrrU+chMrVHtzp5i8JTx3grQiWcJnahnj5Dm2Nm6r3d22ifqZG1hcxA9oNG69Kbiwinwv2B0Dt7kbujRggMq+dV/rHHmdyNF~1; _abck=84784437A2290F7C7665B869C07C4FDE~-1~YAAQruULFyp82duLAQAAjltO5Aq5Z2Wy7IwrT8LGPETsMNBYgR3ioKo05jXyjh7pnHJE/6HuQ48H84Qlbz3pLV0XC0Em8SxGIWwx4/jtqFwVP2HseXKdmJJm7bO5DHvTg1K7wu1LyubY7qU+eSTAxOMgnJiKjMy10pGMnVIsgS5/3UWvZprfNvZWYVFT/q6FtVpK7EOXXyI+FIherVv1IQBngeQbxFFT3sZ9yGVgcpuXffHW5G2ph7UB3sKQCVyU+XovIpman//ZoiNIBUrp9NR5pOoIA6ui8Wg8N4cm/bBUGRfxBCw4je16mWTbZP5Jm0XQvREBYvBBR8mXhP/iZvReV8YCMg5zjerxzeT3MGyzIipoLQeLxLzr9I/SUG5cHN7mXh8YFvmbuppyhnBQCTKrnhm8wZ+6Ga0eHY0jz9zhgSijOECuGxpnV4mdtC/rX7hswdMyAmmj~0~-1~-1; ak_bmsc=A80C29BEB24AF3C79480B0F09D37CF62~000000000000000000000000000000~YAAQruULFyt82duLAQAAjltO5BUVgHseFizgyiwC7KNxfqvcDdkjtdW0+ykbMNKpCOBkYKvRomJO8hYi+7pVA6Oi5vIWP7qYR9hLzp5KZz8nWu3DkYMpaDqbMTD16nRwkh36KS/NYhosAjQABuYoOUYw1IbBsr1L/uKHHOJv+jLyZcdpI92BOATTt/x7ZmVxVTJMH3Po+92V7gsXFvbJr281h3e41RVJUpUD4KG+4OfnJTaHuGqK5z2+Iw0hRvJtKDnWaaG9/iCLxLwFm9tFO7+8hDMW7SdoolHwKZ0KeajzTbYkugFRiTbH0SyKnM2zqMIt0hJfvIYsPkwzvxXR23BYoEl//ocbzN1Egsiknd83AtUgDG0qTMNJ/fpS8ey0Lpic9jk+qxm1aIozuv6wqZMcN+pCVuOZXMrV1YYo6Iifzr2z9dtTtufBvFQI6UrLBYVStlorAkMNO1ieotC48iLQoZnWa7Cex0FFNQ==; akaalb_prod_dual=1700426449~op=PROD_GCP_EAST_CTRL_DFLT:PROD_DEFAULT_EAST|PROD_GCP_EAST_CTRL_A:PROD_EAST_A|~rv=89~m=PROD_DEFAULT_EAST:0|PROD_EAST_A:0|~os=352fb8a62db4e37e16b221fb4cefd635~id=987589ee78f2a6df0f0ac4a0eb2f0327',
|
171 |
+
'referer': 'https://www.lowes.com/c/Departments',
|
|
|
|
|
172 |
'sec-ch-ua': '"Microsoft Edge";v="119", "Chromium";v="119", "Not?A_Brand";v="24"',
|
173 |
'sec-ch-ua-mobile': '?0',
|
174 |
'sec-ch-ua-platform': '"Windows"',
|
175 |
+
'sec-fetch-dest': 'document',
|
176 |
+
'sec-fetch-mode': 'navigate',
|
177 |
'sec-fetch-site': 'same-origin',
|
178 |
+
'sec-fetch-user': '?1',
|
179 |
+
'upgrade-insecure-requests': '1',
|
180 |
+
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
181 |
}
|
182 |
|
183 |
response = requests.request("GET", url, headers=headers, data=payload)
|
184 |
+
print("get_product_listing")
|
185 |
return response.text
|
186 |
|
187 |
|
|
|
188 |
def refer_to_human_agent(summary: str) -> str:
|
189 |
return "I'm sorry, I don't know how to help you with that. I'll refer you to a human agent."
|
home_depot_data.csv
ADDED
The diff for this file is too large to render.
See raw diff
|
|
home_depot_result.py
ADDED
@@ -0,0 +1,225 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
home_depot_result = {
|
2 |
+
"orderDetails": {
|
3 |
+
"bopisCancelEnabled": False,
|
4 |
+
"id": "WG37810008",
|
5 |
+
"versionId": "v0:Cj4KAjEwEh1IRFByb2Nlc3NTVlNUcmFuc2FjdGlvblNlcnZlchoZMjAyMy0wNy0xNFQyMjoyNTozMi0wNDowMA==",
|
6 |
+
"orderRefNumber": "WG37810008",
|
7 |
+
"status": "Delivered",
|
8 |
+
"statusCode": 105,
|
9 |
+
"grandTotal": 128.5,
|
10 |
+
"subTotal": 118.0,
|
11 |
+
"taxTotal": 10.5,
|
12 |
+
"returnTotal": 0.0,
|
13 |
+
"shippingCharge": 0.0,
|
14 |
+
"deliveryCharge": 0.0,
|
15 |
+
"createDateTime": "2023-07-13T21:30:23-04:00",
|
16 |
+
"changeOwner": "COM",
|
17 |
+
"fulfillmentOwner": "COM",
|
18 |
+
"emailId": "[email protected]",
|
19 |
+
"billingAddress": {
|
20 |
+
"addrIdentifier": 0,
|
21 |
+
"emailId": "[email protected]",
|
22 |
+
"name": {
|
23 |
+
"firstName": "Colin",
|
24 |
+
"lastName": "Flueck"
|
25 |
+
},
|
26 |
+
"postalDetails": {
|
27 |
+
"addressLine1": "4237 Western Ave",
|
28 |
+
"city": "WESTERN SPRINGS",
|
29 |
+
"state": "IL",
|
30 |
+
"zipCode": "60558",
|
31 |
+
"country": "US"
|
32 |
+
},
|
33 |
+
"primaryPhone": {
|
34 |
+
"number": "6307508897"
|
35 |
+
}
|
36 |
+
},
|
37 |
+
"lineItems": {
|
38 |
+
"lineItem": [
|
39 |
+
{
|
40 |
+
"lineId": "1",
|
41 |
+
"lineSeqNum": "1",
|
42 |
+
"type": "Special Order Merchandise",
|
43 |
+
"statusCode": 105,
|
44 |
+
"statusUpdatedDate": "2023-07-15",
|
45 |
+
"status": "Delivered",
|
46 |
+
"omsId": 317984876,
|
47 |
+
"storeSKU": "1007491039",
|
48 |
+
"modelNumber": "PCL206B",
|
49 |
+
"department": "25",
|
50 |
+
"itemClass": "9",
|
51 |
+
"itemSubClass": 3,
|
52 |
+
"vendorNumber": "72793",
|
53 |
+
"poNumber": "84632203",
|
54 |
+
"upcCode": "033287200160",
|
55 |
+
"itemWeightUnitOfMeasure": "LB",
|
56 |
+
"itemWeight": 3.00,
|
57 |
+
"scac": "UPS",
|
58 |
+
"brandName": "RYOBI",
|
59 |
+
"description": "ONE+ 18V Cordless 1/2 in. Drill/Driver (Tool Only)",
|
60 |
+
"currentQuantity": 2,
|
61 |
+
"orginalOrderedQuantity": 2,
|
62 |
+
"cancelledQuantity": 0,
|
63 |
+
"deliveredDateArray": [
|
64 |
+
"2023-07-15"
|
65 |
+
],
|
66 |
+
"unitPrice": 59.0,
|
67 |
+
"totalPrice": 118.0,
|
68 |
+
"pipSeoUrl": "/p/RYOBI-ONE-18V-Cordless-1-2-in-Drill-Driver-Tool-Only-PCL206B/317984876",
|
69 |
+
"imageUrl": "https://images.thdstatic.com/productImages/30cdd64e-b560-437c-8f90-3da447ed73d6/svn/ryobi-power-drills-pcl206b-64_100.jpg",
|
70 |
+
"productType": "MERCHANDISE",
|
71 |
+
"documents": {
|
72 |
+
"document": [
|
73 |
+
{
|
74 |
+
"name": "Warranty",
|
75 |
+
"url": "https://www.homedepot.com/catalog/pdfImages/61/61911e01-07fb-40d6-9b71-236f60d155bc.pdf"
|
76 |
+
},
|
77 |
+
{
|
78 |
+
"name": "Use and Care Manual",
|
79 |
+
"url": "https://www.homedepot.com/catalog/pdfImages/eb/eb728d57-8608-49cb-bfad-3760d0b4d9cf.pdf"
|
80 |
+
}
|
81 |
+
]
|
82 |
+
},
|
83 |
+
"fulfillment": {
|
84 |
+
"fulfillmentMethod": "ShipToHome",
|
85 |
+
"shippingAndHandling": {
|
86 |
+
"shipmentModeCode": "SG",
|
87 |
+
"shippingDescription": "Standard Shipping",
|
88 |
+
"shippingProvider": "UPS",
|
89 |
+
"shippingProviderCode": "UPS",
|
90 |
+
"shippingStatus": "Delivered",
|
91 |
+
"isCarrierIntegrationAvailable": True,
|
92 |
+
"trackingURL": "http://www.ups.com/",
|
93 |
+
"comEstEndDeliveryDate": "2023-07-15T00:00:00-04:00",
|
94 |
+
"shipments": {
|
95 |
+
"shipment": [
|
96 |
+
{
|
97 |
+
"trackingNumber": "1ZRX95040358704846",
|
98 |
+
"shippingProviderCode": "UPS",
|
99 |
+
"isCarrierIntegrationAvailable": True,
|
100 |
+
"trackingURL": "http://www.ups.com/",
|
101 |
+
"shipmentModeCode": "SG",
|
102 |
+
"shippingProvider": "UPS",
|
103 |
+
"trackingType": "LastMile",
|
104 |
+
"estimatedDeliveryDate": "2023-07-15"
|
105 |
+
}
|
106 |
+
]
|
107 |
+
},
|
108 |
+
"deliveryAddress": {
|
109 |
+
"name": {
|
110 |
+
"firstName": "Colin",
|
111 |
+
"lastName": "Flueck"
|
112 |
+
},
|
113 |
+
"postalDetails": {
|
114 |
+
"addressLine1": "176 5th St Nw",
|
115 |
+
"city": "ATLANTA",
|
116 |
+
"state": "GA",
|
117 |
+
"zipCode": "30313",
|
118 |
+
"country": "US"
|
119 |
+
},
|
120 |
+
"phoneNumbers": {
|
121 |
+
"dayPhone": "6307508897",
|
122 |
+
"mobilePhone": "6307508897"
|
123 |
+
}
|
124 |
+
},
|
125 |
+
"estStartDeliveryDate": "2023-07-15",
|
126 |
+
"estEndDeliveryDate": "2023-07-15",
|
127 |
+
"isLineHaul": False
|
128 |
+
}
|
129 |
+
},
|
130 |
+
"hideSKU": False,
|
131 |
+
"bossReorderZeroQuantity": False,
|
132 |
+
"isInstallItem": False,
|
133 |
+
"isCancelEnabled": False,
|
134 |
+
"isDFCSourced": True,
|
135 |
+
"isDFSCancelEnabled": False,
|
136 |
+
"isDFSRescheduleEnabled": False,
|
137 |
+
"actions": {
|
138 |
+
"buyAgain": True,
|
139 |
+
"isCancelEnabled": False,
|
140 |
+
"infoAndGuides": True,
|
141 |
+
"writeAReview": True,
|
142 |
+
"isDFSCancelEnabled": False,
|
143 |
+
"isDFSRescheduleEnabled": False
|
144 |
+
},
|
145 |
+
"isCOMAppliance": False,
|
146 |
+
"isBODFS": False,
|
147 |
+
"isDFS": False,
|
148 |
+
"delayedShipment": False,
|
149 |
+
"isGiftCard": False
|
150 |
+
}
|
151 |
+
]
|
152 |
+
},
|
153 |
+
"paymentMethods": {
|
154 |
+
"paymentMethod": [
|
155 |
+
{
|
156 |
+
"amount": 128.5,
|
157 |
+
"lastFour": "2291",
|
158 |
+
"cardType": "VI"
|
159 |
+
}
|
160 |
+
]
|
161 |
+
},
|
162 |
+
"trackingToLineAssociations": {
|
163 |
+
"trackingToLineAssociation": [
|
164 |
+
{
|
165 |
+
"trackingNumber": "1ZRX95040358704846",
|
166 |
+
"lineIds": "1"
|
167 |
+
}
|
168 |
+
]
|
169 |
+
},
|
170 |
+
"lineIdsWithoutTracking": "",
|
171 |
+
"returnOnlineAllowed": False,
|
172 |
+
"authDeclined": False,
|
173 |
+
"workOrderToLineAssociations": {
|
174 |
+
"workOrderToLineAssociations": []
|
175 |
+
},
|
176 |
+
"isCancelEnabled": False,
|
177 |
+
"isDFCSourced": True,
|
178 |
+
"orderGroups": [
|
179 |
+
{
|
180 |
+
"fulfillment": "ShipToHome",
|
181 |
+
"status": "Delivered",
|
182 |
+
"name": {
|
183 |
+
"firstName": "Colin",
|
184 |
+
"lastName": "Flueck"
|
185 |
+
},
|
186 |
+
"postalDetails": {
|
187 |
+
"addressLine1": "176 5th St Nw",
|
188 |
+
"city": "ATLANTA",
|
189 |
+
"state": "GA",
|
190 |
+
"zipCode": "30313",
|
191 |
+
"country": "US"
|
192 |
+
},
|
193 |
+
"actions": {
|
194 |
+
"trackingEnabled": False
|
195 |
+
},
|
196 |
+
"lineAssociation": [
|
197 |
+
"1"
|
198 |
+
],
|
199 |
+
"groupName": "ShipToHome_Delivered_1ZRX95040358704846",
|
200 |
+
"statusCode": 105,
|
201 |
+
"shipments": [
|
202 |
+
{
|
203 |
+
"trackingNumber": "1ZRX95040358704846",
|
204 |
+
"shippingProviderCode": "UPS",
|
205 |
+
"isCarrierIntegrationAvailable": True,
|
206 |
+
"trackingURL": "http://www.ups.com/",
|
207 |
+
"shipmentModeCode": "SG",
|
208 |
+
"shippingProvider": "UPS",
|
209 |
+
"trackingType": "LastMile",
|
210 |
+
"estimatedDeliveryDate": "2023-07-15"
|
211 |
+
}
|
212 |
+
],
|
213 |
+
"estDeliveryDate": "2023-07-15"
|
214 |
+
}
|
215 |
+
],
|
216 |
+
"trackingEnabled": False,
|
217 |
+
"cancellationRequested": False,
|
218 |
+
"isLineItemCancelEnabled": False,
|
219 |
+
"otherDiscountAmount": 0.00,
|
220 |
+
"isNEXOrder": False,
|
221 |
+
"isAAFESOrder": False,
|
222 |
+
"xAuthGuestToken": "If2SMV4Uhc6LadRhSbMf1wcvdgrbI1loyZFvAUHmrbjtOw53r22952ISw8UhvluZJjtcEfCdPid4KV7ph8vP8A=="
|
223 |
+
}
|
224 |
+
}
|
225 |
+
|
requirements.txt
CHANGED
@@ -1,2 +1,5 @@
|
|
1 |
openai==1.3.3
|
2 |
-
streamlit~=1.28.2
|
|
|
|
|
|
|
|
1 |
openai==1.3.3
|
2 |
+
streamlit~=1.28.2
|
3 |
+
pandas~=2.1.3
|
4 |
+
requests~=2.31.0
|
5 |
+
fuzzywuzzy~=0.18.0
|