hackerloi45 commited on
Commit
27514c1
·
1 Parent(s): 666646e
Files changed (1) hide show
  1. app.py +25 -4
app.py CHANGED
@@ -1,5 +1,7 @@
1
  import gradio as gr
2
  import uuid
 
 
3
  from qdrant_client import QdrantClient
4
  from qdrant_client.models import PointStruct, VectorParams, Distance
5
  from sentence_transformers import SentenceTransformer
@@ -8,8 +10,8 @@ from PIL import Image
8
  # --------------------------
9
  # Qdrant Cloud Connection
10
  # --------------------------
11
- QDRANT_URL = "https://ff4da494-27b1-413c-ba58-d5ea14932fe1.europe-west3-0.gcp.cloud.qdrant.io:6333"
12
- QDRANT_API_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3MiOiJtIn0.jjeB1JgnUSlb1hOOKMdRpVvMrUER57-udT-X1AWXT1E"
13
  COLLECTION_NAME = "lost_and_found"
14
 
15
  # CLIP model (text + image embeddings)
@@ -35,6 +37,17 @@ qclient.recreate_collection(
35
  # Helper Functions
36
  # --------------------------
37
 
 
 
 
 
 
 
 
 
 
 
 
38
  def embed_text(text: str):
39
  return embedder.encode(text).tolist()
40
 
@@ -48,12 +61,14 @@ def add_item(image, description, finder_name, finder_phone):
48
 
49
  # Encode image
50
  embedding = embed_image(image)
 
51
 
52
- # Store metadata
53
  metadata = {
54
  "description": description,
55
  "finder_name": finder_name if finder_name.strip() else "NA",
56
  "finder_phone": finder_phone if finder_phone.strip() else "NA",
 
57
  }
58
 
59
  # Insert into Qdrant
@@ -98,7 +113,13 @@ def search_items(query_text, query_image):
98
  name = r.payload.get("finder_name", "NA")
99
  phone = r.payload.get("finder_phone", "NA")
100
  output_text += f"- **{desc}** (Finder: {name}, Phone: {phone})\n"
101
- gallery.append(Image.new("RGB", (200, 200), color="gray")) # Placeholder (no storage for images)
 
 
 
 
 
 
102
 
103
  return output_text, gallery
104
 
 
1
  import gradio as gr
2
  import uuid
3
+ import base64
4
+ import io
5
  from qdrant_client import QdrantClient
6
  from qdrant_client.models import PointStruct, VectorParams, Distance
7
  from sentence_transformers import SentenceTransformer
 
10
  # --------------------------
11
  # Qdrant Cloud Connection
12
  # --------------------------
13
+ QDRANT_URL = "https://ff4da494-27b1-413c-ba58-d5ea14932fe1.europe-west3-0.gcp.cloud.qdrant.io:6333" # 🔑 Replace with your cluster URL
14
+ QDRANT_API_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3MiOiJtIn0.jjeB1JgnUSlb1hOOKMdRpVvMrUER57-udT-X1AWXT1E" # 🔑 Replace with your API key
15
  COLLECTION_NAME = "lost_and_found"
16
 
17
  # CLIP model (text + image embeddings)
 
37
  # Helper Functions
38
  # --------------------------
39
 
40
+ def image_to_base64(img: Image.Image) -> str:
41
+ """Convert PIL image to base64 string"""
42
+ buf = io.BytesIO()
43
+ img.save(buf, format="PNG")
44
+ return base64.b64encode(buf.getvalue()).decode("utf-8")
45
+
46
+ def base64_to_image(b64_str: str) -> Image.Image:
47
+ """Convert base64 string back to PIL image"""
48
+ img_bytes = base64.b64decode(b64_str)
49
+ return Image.open(io.BytesIO(img_bytes))
50
+
51
  def embed_text(text: str):
52
  return embedder.encode(text).tolist()
53
 
 
61
 
62
  # Encode image
63
  embedding = embed_image(image)
64
+ img_b64 = image_to_base64(image)
65
 
66
+ # Store metadata including image
67
  metadata = {
68
  "description": description,
69
  "finder_name": finder_name if finder_name.strip() else "NA",
70
  "finder_phone": finder_phone if finder_phone.strip() else "NA",
71
+ "image_b64": img_b64
72
  }
73
 
74
  # Insert into Qdrant
 
113
  name = r.payload.get("finder_name", "NA")
114
  phone = r.payload.get("finder_phone", "NA")
115
  output_text += f"- **{desc}** (Finder: {name}, Phone: {phone})\n"
116
+
117
+ if "image_b64" in r.payload:
118
+ try:
119
+ img = base64_to_image(r.payload["image_b64"])
120
+ gallery.append(img)
121
+ except Exception:
122
+ pass
123
 
124
  return output_text, gallery
125