"results/sync_overhead.py" did not exist on "fe26930997c9041c7406c93e00ba6d9d15974b5e"
main.py 3.71 KB
Newer Older
Timothy J. Baek's avatar
Timothy J. Baek committed
1
2
3
4
5
6
7
8
9
10
from fastapi import (
    FastAPI,
    Request,
    Depends,
    HTTPException,
    status,
    UploadFile,
    File,
    Form,
)
Timothy J. Baek's avatar
Timothy J. Baek committed
11
12
from fastapi.middleware.cors import CORSMiddleware

13
from chromadb.utils import embedding_functions
Timothy J. Baek's avatar
Timothy J. Baek committed
14

Timothy J. Baek's avatar
Timothy J. Baek committed
15
from langchain.document_loaders import WebBaseLoader, TextLoader, PyPDFLoader
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
from langchain.text_splitter import RecursiveCharacterTextSplitter
from langchain_community.vectorstores import Chroma
from langchain.chains import RetrievalQA


from pydantic import BaseModel
from typing import Optional

import uuid

from config import EMBED_MODEL, CHROMA_CLIENT, CHUNK_SIZE, CHUNK_OVERLAP
from constants import ERROR_MESSAGES

EMBEDDING_FUNC = embedding_functions.SentenceTransformerEmbeddingFunction(
    model_name=EMBED_MODEL
)
Timothy J. Baek's avatar
Timothy J. Baek committed
32
33
34
35
36
37
38
39
40
41
42
43
44
45

app = FastAPI()

origins = ["*"]

app.add_middleware(
    CORSMiddleware,
    allow_origins=origins,
    allow_credentials=True,
    allow_methods=["*"],
    allow_headers=["*"],
)


Timothy J. Baek's avatar
Timothy J. Baek committed
46
class CollectionNameForm(BaseModel):
47
48
49
    collection_name: Optional[str] = "test"


Timothy J. Baek's avatar
Timothy J. Baek committed
50
51
52
53
class StoreWebForm(CollectionNameForm):
    url: str


54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
def store_data_in_vector_db(data, collection_name):
    text_splitter = RecursiveCharacterTextSplitter(
        chunk_size=CHUNK_SIZE, chunk_overlap=CHUNK_OVERLAP
    )
    docs = text_splitter.split_documents(data)

    texts = [doc.page_content for doc in docs]
    metadatas = [doc.metadata for doc in docs]

    collection = CHROMA_CLIENT.create_collection(
        name=collection_name, embedding_function=EMBEDDING_FUNC
    )

    collection.add(
        documents=texts, metadatas=metadatas, ids=[str(uuid.uuid1()) for _ in texts]
    )


Timothy J. Baek's avatar
Timothy J. Baek committed
72
73
74
@app.get("/")
async def get_status():
    return {"status": True}
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93


@app.get("/query/{collection_name}")
def query_collection(collection_name: str, query: str, k: Optional[int] = 4):
    collection = CHROMA_CLIENT.get_collection(
        name=collection_name,
    )
    result = collection.query(query_texts=[query], n_results=k)

    return result


@app.post("/web")
def store_web(form_data: StoreWebForm):
    # "https://www.gutenberg.org/files/1727/1727-h/1727-h.htm"
    try:
        loader = WebBaseLoader(form_data.url)
        data = loader.load()
        store_data_in_vector_db(data, form_data.collection_name)
94
        return {"status": True, "collection_name": form_data.collection_name}
95
96
97
98
99
100
101
102
103
    except Exception as e:
        print(e)
        raise HTTPException(
            status_code=status.HTTP_400_BAD_REQUEST,
            detail=ERROR_MESSAGES.DEFAULT(e),
        )


@app.post("/doc")
Timothy J. Baek's avatar
Timothy J. Baek committed
104
def store_doc(collection_name: str = Form(...), file: UploadFile = File(...)):
105
106
    # "https://www.gutenberg.org/files/1727/1727-h/1727-h.htm"

Timothy J. Baek's avatar
Timothy J. Baek committed
107
108
109
110
111
112
113
114
115
116
    file.filename = f"{uuid.uuid4()}-{file.filename}"
    print(dir(file))
    print(file.content_type)

    if file.content_type not in ["application/pdf", "text/plain"]:
        raise HTTPException(
            status_code=status.HTTP_400_BAD_REQUEST,
            detail=ERROR_MESSAGES.FILE_NOT_SUPPORTED,
        )

117
    try:
Timothy J. Baek's avatar
Timothy J. Baek committed
118
119
        filename = file.filename
        file_path = f"./data/{filename}"
120
        contents = file.file.read()
Timothy J. Baek's avatar
Timothy J. Baek committed
121
        with open(file_path, "wb") as f:
122
123
124
            f.write(contents)
            f.close()

Timothy J. Baek's avatar
Timothy J. Baek committed
125
126
127
128
129
130
131
        if file.content_type == "application/pdf":
            loader = PyPDFLoader(file_path)
        elif file.content_type == "text/plain":
            loader = TextLoader(file_path)

        data = loader.load()
        store_data_in_vector_db(data, collection_name)
132
        return {"status": True, "collection_name": collection_name}
133
134
135
136
137
138
139
140
141
142
143
    except Exception as e:
        print(e)
        raise HTTPException(
            status_code=status.HTTP_400_BAD_REQUEST,
            detail=ERROR_MESSAGES.DEFAULT(e),
        )


def reset_vector_db():
    CHROMA_CLIENT.reset()
    return {"status": True}