mediscenario-streamlit-FINAL / db_firestore.py
Yew Chong
update app
91701f5
raw
history blame
3.12 kB
from langchain_community.vectorstores import FAISS
from langchain_community.embeddings.huggingface import HuggingFaceBgeEmbeddings
import firebase_admin
from firebase_admin import credentials, storage
import json, os, dotenv
from dotenv import load_dotenv
load_dotenv()
try:
os.environ["FIREBASE_CREDENTIAL"] = dotenv.get_key(dotenv.find_dotenv(), "FIREBASE_CREDENTIAL")
if os.environ.get["FIREBASE_CREDENTIAL"] == None:
raise TypeError
except TypeError:
import streamlit as st
os.environ["FIREBASE_CREDENTIAL"] = st.secrets["FIREBASE_CREDENTIAL"]
cred = credentials.Certificate(json.loads(os.environ.get("FIREBASE_CREDENTIAL"), strict=False))
# firebase_admin.initialize_app(cred,{'storageBucket': 'healthhack-store.appspot.com'}) # connecting to firebase
if not firebase_admin._apps:
firebase_admin.initialize_app(cred, {'storageBucket': 'healthhack-store.appspot.com'})
def get_store(index_name, embeddings = None):
while index_name[-1]=="/":
index_name = index_name[:-1]
dir = index_name.split("/")
## Check if path exists locally
for i in range(len(dir)):
path = '/'.join(dir[:i+1])
if not os.path.exists(path):
os.mkdir(path)
## Check if file exists locally, get from blob
if (not os.path.exists(index_name+"/index.faiss") or
not os.path.exists(index_name+"/index.pkl")
):
bucket = storage.bucket()
blob = bucket.blob(f"{index_name}/index.pkl")
blob.download_to_filename(f"{index_name}/index.pkl")
bucket = storage.bucket()
blob = bucket.blob(f"{index_name}/index.faiss")
blob.download_to_filename(f"{index_name}/index.faiss")
## check embeddings, default to BGE
if embeddings is None:
model_name = "bge-large-en-v1.5"
model_kwargs = {"device": "cpu"}
encode_kwargs = {"normalize_embeddings": True}
embeddings = HuggingFaceBgeEmbeddings(
# model_name=model_name,
model_kwargs = model_kwargs,
encode_kwargs = encode_kwargs)
## load store from local
store = FAISS.load_local(index_name, embeddings)
return store
def update_store_from_local(index_name):
while index_name[-1]=="/":
index_name = index_name[:-1]
pathdir = index_name.split("/")
## Check if path exists locally
for i in range(len(pathdir)):
path = '/'.join(pathdir[:i+1])
if not os.path.exists(path):
raise Exception("Index name does not exist locally")
## Check if file exists locally, get from blob
if (not os.path.exists(index_name+"/index.faiss") or
not os.path.exists(index_name+"/index.pkl")
):
raise("Index is missing some files (index.faiss, index.pkl)")
## Update store
bucket = storage.bucket()
blob = bucket.blob(index_name+"/index.faiss")
blob.upload_from_filename(index_name+"/index.faiss")
blob = bucket.blob(index_name+"/index.pkl")
blob.upload_from_filename(index_name+"/index.pkl")
return True
if __name__ == "__main__":
print("y r u running dis")