summaryrefslogtreecommitdiff
path: root/python/fastembed-server.py
blob: fa3f7c82b5c9a832a8a1e90b889003e7a69d14af (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from fastembed import TextEmbedding
from fastapi import FastAPI
from pydantic import BaseModel

model = TextEmbedding("snowflake/snowflake-arctic-embed-xs")

app = FastAPI()

class EmbeddingRequest(BaseModel):
    model: str
    prompt: str

@app.post("/api/embeddings")
def embeddings(request: EmbeddingRequest):
    embeddings = next(model.embed(request.prompt)).tolist()
    return {"embedding": embeddings}

if __name__ == "__main__":
    import uvicorn

    uvicorn.run(app, host="0.0.0.0", port=11345)