Spaces:
Sleeping
Sleeping
pragneshbarik
commited on
Commit
·
592fd3e
1
Parent(s):
3fbf93c
integrated notion database
Browse files- config.yaml +4 -2
- middlewares/utils.py +77 -1
- requirements.txt +1 -0
config.yaml
CHANGED
@@ -1,12 +1,14 @@
|
|
1 |
PROMPT_ENGINEERING_DICT:
|
2 |
SYSTEM_INSTRUCTION: |
|
3 |
-
YOU ARE A SEARCH ENGINE HAVING FULL ACCESS TO WEB PAGES
|
|
|
|
|
4 |
SYSTEM_RESPONSE: |
|
5 |
Certainly! I'm here to help. What information are you looking for?
|
6 |
Please provide me with a specific topic or question, and I'll do my
|
7 |
best to provide you with detailed and accurate information.
|
8 |
|
9 |
-
PRE_CONTEXT: NOW YOU ARE SEARCHING THE WEB, AND HERE ARE THE CHUNKS RETRIEVED FROM THE WEB.
|
10 |
POST_CONTEXT: ""
|
11 |
PRE_PROMPT: NOW ACCORDING TO THE CONTEXT RETRIEVED FROM THE GENERATE THE CONTENT FOR THE FOLLOWING SUBJECT
|
12 |
POST_PROMPT: PRIORITIZE DATA, FACTS AND STATISTICS OVER PERSONAL EXPERIENCES AND OPINIONS, FOCUS MORE ON STATISTICS AND DATA.
|
|
|
1 |
PROMPT_ENGINEERING_DICT:
|
2 |
SYSTEM_INSTRUCTION: |
|
3 |
+
YOU ARE A SEARCH ENGINE AND AN INVENTORY MANAGER HAVING FULL ACCESS TO WEB PAGES AND NOTION DATABASE IN JSON,
|
4 |
+
YOU GIVE EXTREMELY DETAILED AND ACCURATE INFORMATION ACCORDING TO USER PROMPTS.
|
5 |
+
|
6 |
SYSTEM_RESPONSE: |
|
7 |
Certainly! I'm here to help. What information are you looking for?
|
8 |
Please provide me with a specific topic or question, and I'll do my
|
9 |
best to provide you with detailed and accurate information.
|
10 |
|
11 |
+
PRE_CONTEXT: NOW YOU ARE SEARCHING THE WEB, AND HERE ARE THE CHUNKS RETRIEVED FROM THE WEB, YOU ALSO HAVE ACCESS TO INVENTORY DATABASE IN JSON FORMAT.
|
12 |
POST_CONTEXT: ""
|
13 |
PRE_PROMPT: NOW ACCORDING TO THE CONTEXT RETRIEVED FROM THE GENERATE THE CONTENT FOR THE FOLLOWING SUBJECT
|
14 |
POST_PROMPT: PRIORITIZE DATA, FACTS AND STATISTICS OVER PERSONAL EXPERIENCES AND OPINIONS, FOCUS MORE ON STATISTICS AND DATA.
|
middlewares/utils.py
CHANGED
@@ -1,4 +1,7 @@
|
|
1 |
from sentence_transformers import CrossEncoder
|
|
|
|
|
|
|
2 |
import math
|
3 |
import numpy as np
|
4 |
from middlewares.search_client import SearchClient
|
@@ -20,6 +23,74 @@ googleSearchClient = SearchClient(
|
|
20 |
)
|
21 |
bingSearchClient = SearchClient("bing", api_key=BING_SEARCH_API_KEY, engine_id=None)
|
22 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
23 |
|
24 |
def rerank(query, top_k, search_results, chunk_size=512):
|
25 |
chunks = []
|
@@ -67,6 +138,7 @@ def gen_augmented_prompt_via_websearch(
|
|
67 |
chunk_size=512,
|
68 |
):
|
69 |
|
|
|
70 |
|
71 |
search_results = []
|
72 |
reranked_results = []
|
@@ -91,12 +163,16 @@ def gen_augmented_prompt_via_websearch(
|
|
91 |
prev_output = prev_output if pass_prev else ""
|
92 |
|
93 |
augmented_prompt = f"""
|
94 |
-
|
|
|
95 |
|
96 |
{context}
|
97 |
|
|
|
98 |
{post_context}
|
99 |
|
|
|
|
|
100 |
{pre_prompt}
|
101 |
|
102 |
{prompt}
|
|
|
1 |
from sentence_transformers import CrossEncoder
|
2 |
+
from pprint import pprint, pformat
|
3 |
+
from notion_client import Client
|
4 |
+
import json
|
5 |
import math
|
6 |
import numpy as np
|
7 |
from middlewares.search_client import SearchClient
|
|
|
23 |
)
|
24 |
bingSearchClient = SearchClient("bing", api_key=BING_SEARCH_API_KEY, engine_id=None)
|
25 |
|
26 |
+
def safe_get(data, dot_chained_keys):
|
27 |
+
'''
|
28 |
+
{'a': {'b': [{'c': 1}]}}
|
29 |
+
safe_get(data, 'a.b.0.c') -> 1
|
30 |
+
'''
|
31 |
+
keys = dot_chained_keys.split('.')
|
32 |
+
for key in keys:
|
33 |
+
try:
|
34 |
+
if isinstance(data, list):
|
35 |
+
data = data[int(key)]
|
36 |
+
else:
|
37 |
+
data = data[key]
|
38 |
+
except (KeyError, TypeError, IndexError):
|
39 |
+
return None
|
40 |
+
return data
|
41 |
+
|
42 |
+
def get_notion_data() :
|
43 |
+
integration_token = "secret_lTOe0q9dqqKQLRRb2KJwi7QFSl0vqoztroRFHW6MeQE"
|
44 |
+
notion_database_id = "6c0d877b823a4e3699016fa7083f3006"
|
45 |
+
|
46 |
+
client = Client(auth=integration_token)
|
47 |
+
|
48 |
+
first_db_rows = client.databases.query(notion_database_id)
|
49 |
+
rows = []
|
50 |
+
|
51 |
+
|
52 |
+
for row in first_db_rows['results']:
|
53 |
+
price = safe_get(row, 'properties.($) Per Unit.number')
|
54 |
+
store_link = safe_get(row, 'properties.Store Link.url')
|
55 |
+
supplier_email = safe_get(row, 'properties.Supplier Email.email')
|
56 |
+
exp_del = safe_get(row, 'properties.Expected Delivery.date')
|
57 |
+
|
58 |
+
collections = safe_get(row, 'properties.Collection.multi_select')
|
59 |
+
collection_names = []
|
60 |
+
for collection in collections :
|
61 |
+
collection_names.append(collection['name'])
|
62 |
+
|
63 |
+
status = safe_get(row, 'properties.Status.select.name')
|
64 |
+
sup_phone = safe_get(row, 'properties.Supplier Phone.phone_number')
|
65 |
+
stock_alert = safe_get(row, 'properties.Stock Alert.status.name')
|
66 |
+
prod_name = safe_get(row, 'properties.Product .title.0.text.content')
|
67 |
+
sku = safe_get(row, 'properties.SKU.number')
|
68 |
+
shipped_date = safe_get(row, 'properties.Shipped On.date')
|
69 |
+
on_order = safe_get(row, 'properties.On Order.number')
|
70 |
+
on_hand = safe_get(row, 'properties.On Hand.number')
|
71 |
+
size_names = []
|
72 |
+
sizes = safe_get(row, 'properties.Size.multi_select')
|
73 |
+
for size in sizes :
|
74 |
+
size_names.append(size['name'])
|
75 |
+
|
76 |
+
rows.append({
|
77 |
+
'Price Per unit': price,
|
78 |
+
'Store Link' : store_link,
|
79 |
+
'Supplier Email' : supplier_email,
|
80 |
+
'Expected Delivery' : exp_del,
|
81 |
+
'Collection' : collection_names,
|
82 |
+
'Status' : status,
|
83 |
+
'Supplier Phone' : sup_phone,
|
84 |
+
'Stock Alert' : stock_alert,
|
85 |
+
'Product Name' : prod_name,
|
86 |
+
'SKU' : sku,
|
87 |
+
'Sizes' : size_names,
|
88 |
+
})
|
89 |
+
|
90 |
+
notion_data_string = pformat(rows)
|
91 |
+
return notion_data_string
|
92 |
+
|
93 |
+
|
94 |
|
95 |
def rerank(query, top_k, search_results, chunk_size=512):
|
96 |
chunks = []
|
|
|
138 |
chunk_size=512,
|
139 |
):
|
140 |
|
141 |
+
notion_data= get_notion_data()
|
142 |
|
143 |
search_results = []
|
144 |
reranked_results = []
|
|
|
163 |
prev_output = prev_output if pass_prev else ""
|
164 |
|
165 |
augmented_prompt = f"""
|
166 |
+
|
167 |
+
{pre_context}
|
168 |
|
169 |
{context}
|
170 |
|
171 |
+
{notion_data}
|
172 |
{post_context}
|
173 |
|
174 |
+
|
175 |
+
|
176 |
{pre_prompt}
|
177 |
|
178 |
{prompt}
|
requirements.txt
CHANGED
@@ -1,3 +1,4 @@
|
|
|
|
1 |
altair==5.1.2
|
2 |
asttokens==2.2.1
|
3 |
attrs==23.1.0
|
|
|
1 |
+
notion-client==2.2.1
|
2 |
altair==5.1.2
|
3 |
asttokens==2.2.1
|
4 |
attrs==23.1.0
|