Kvikontent's picture
Update app.py
bc26c87 verified
raw
history blame contribute delete
No virus
2.53 kB
import gradio as gr
import requests
import io
from io import BytesIO
import os
from PIL import Image
API_URL = "https://api-inference.huggingface.co/models/Kvikontent/midjourney-v6"
api_key = os.environ.get('api_token')
headers = {"Authorization": f"Bearer {api_key}"}
# Define custom Exception class for better error handling
class QueryError(Exception):
pass
def query(payload):
try:
# Make sure we have valid JSON data before sending the request
assert type(payload) == dict
# Send the POST request to the API URL
response = requests.post(API_URL, headers=headers, json=payload)
# Check if the status code indicates success (HTTP Status Code 2xx)
if not str(response.status_code).startswith("2"):
raise QueryError(f"Query failed! Response status code was '{response.status_code}'")
else:
# Return the raw bytes from the response object
return response.content
except AssertionError:
print("Invalid Payload Error: Please provide a dictionary.")
except RequestException as e:
print("Request Failed: ", e)
except ConnectionError as ce:
print("Connection Error: Unable to connect to the API.", ce)
except Timeout as t:
print("Timeout Error: Request timed out while trying to reach the API.", t)
except TooManyRedirects as tmr:
print("Too Many Redirects Error: Exceeded maximum number of redirects.", tmr)
except HTTPError as he:
print("HTTP Error: Invalid HTTP response.", he)
except QueryError as qe:
print(qe)
except Exception as ex:
print("Unknown Error occurred: ", ex)
def generate_image_from_prompt(prompt_text):
gr.Info("Image generation started")
image_bytes = query({"inputs": prompt_text})
img = BytesIO(image_bytes) # Convert to BytesIO stream
pil_img = Image.open(img) # Open the image using PIL library
return pil_img # Return the converted PIL image
title = "Midjourney V6 Demo 🎨"
description = "This app uses Hugging Face AI model api to generate an image based on the provided text prompt πŸ–Ό."
input_prompt = gr.Textbox(label="Enter Prompt πŸ“", placeholder="E.g. 'Astronaut riding a horse'")
output_generated_image = gr.Image(label="Generated Image")
iface = gr.Interface(
fn=generate_image_from_prompt,
inputs=input_prompt,
outputs=output_generated_image,
title=title,
description=description,
theme="soft"
)
iface.launch()