Spaces:
Running
Running
import os | |
import gradio as gr | |
import requests | |
import base64 | |
from io import BytesIO | |
from PIL import Image | |
count = 0 | |
def image_to_base64(image): | |
buffered = BytesIO() | |
image.save(buffered, format="JPEG", quality=90) | |
return base64.b64encode(buffered.getvalue()).decode('utf-8') | |
def base64_to_image(base64_str): | |
return Image.open(BytesIO(base64.b64decode(base64_str + '=' * (-len(base64_str) % 4)))) | |
def search_face(file, token): | |
global count | |
free_url = os.environ.get("SERVER_URL_FREE") | |
premium_url = os.environ.get("SERVER_URL_PREMIUM") | |
token_server_url = os.environ.get("TOKEN_URL") | |
url = free_url | |
if token: | |
try: | |
r = requests.post(url=token_server_url + '/verify-token', json={"token": token}) | |
if r.json().get('status') == 'success': | |
url = premium_url | |
else: | |
raise gr.Error("Invalid token! For free search, use empty string for token") | |
except: | |
raise gr.Error("Invalid token!") | |
try: | |
image = Image.open(file) | |
image_base64 = image_to_base64(image) | |
r = requests.post(url=url, headers={"X-RapidAPI-Key": os.environ.get("API_KEY")}, json={"image": image_base64}) | |
except: | |
raise gr.Error("Please select image file!") | |
status_code = r.status_code | |
if status_code == 301: | |
gr.Info("Too many faces in the photo.") | |
elif status_code == 302: | |
gr.Info("Face is not clear enough.") | |
elif status_code == 303: | |
gr.Info("No matches found.") | |
elif status_code == 304: | |
gr.Info("No face in the photo.") | |
elif status_code == 305: | |
gr.Info("Search blocked for privacy issue.") | |
elif status_code == 401: | |
gr.Info("Invalid image format.") | |
elif status_code == 402: | |
gr.Info("Wrong request.") | |
elif status_code == 403: | |
gr.Info("Requests all used in your token.") | |
elif status_code == 404: | |
gr.Info("Timeout, try again.") | |
if status_code > 300: | |
return [], count | |
try: | |
res = r.json().get('img_array') | |
out_array = [] | |
suffix = "*********" | |
if url == premium_url: | |
suffix = "" | |
for item in res: | |
out_array.append((base64_to_image(item["image"]), item["url"] + suffix)) | |
count += 1 | |
if url == premium_url: | |
try: | |
r = requests.post(url=token_server_url + '/activate-token', json={"token": token}) | |
#if r.json().get('status') == 'success': | |
# url = premium_url | |
except: | |
raise gr.Error("Invalid token!") | |
return out_array, count | |
except: | |
raise gr.Error("Try again.") | |
def search_face_free(file): | |
return search_face(file, '') | |
custom_css = """ | |
caption.caption { | |
user-select: text; | |
cursor: text; | |
} | |
""" | |
with gr.Blocks(css=custom_css) as demo: | |
gr.Markdown( | |
""" | |
# Search Your Face Online For Free | |
## For more detailed information, please check on our website.<br/> | |
## [FaceOnLive: On-premises ID Verification, Biometric Authentication Solution Provider](https://faceonlive.com) | |
<br> | |
""" | |
) | |
with gr.Row(): | |
with gr.Column(scale=1): | |
image = gr.Image(type='filepath', height=480) | |
token = gr.Textbox(placeholder="(Optional) Premium Token via the link below.", label="Premium Token") | |
gr.HTML("<a href='https://faceonlive.pocketsflow.com/checkout?productId=676c15b1971244a587ca07cb' target='_blank'>Get Premium Token: Perform Deep Search & Full URLs</a>") | |
search_face_button = gr.Button("Search Face") | |
with gr.Column(scale=2): | |
output = gr.Gallery(label="Found Images", columns=[4], object_fit="contain", height="auto") | |
countwg = gr.Number(label="Count") | |
gr.Examples(['examples/1.jpg', 'examples/2.jpg'], inputs=image, cache_examples=True, cache_mode='lazy', fn=search_face_free, outputs=[output, countwg]) | |
search_face_button.click(search_face, inputs=[image, token], outputs=[output, countwg], api_name=False) | |
gr.HTML('<a href="https://visitorbadge.io/status?path=https%3A%2F%2Fhuggingface.co%2Fspaces%2FFaceOnLive%2FFace-Search-Online"><img src="https://api.visitorbadge.io/api/combined?path=https%3A%2F%2Fhuggingface.co%2Fspaces%2FFaceOnLive%2FFace-Search-Online&labelColor=%23ff8a65&countColor=%2337d67a&style=flat&labelStyle=upper" /></a>') | |
demo.queue(api_open=False, default_concurrency_limit=4).launch(server_name="0.0.0.0", server_port=7860, show_api=False) |