adsnap-studio / src /services /hd_image_generation.py
Dewmike's picture
Initial commit with Hugging Face Whisper integration
0362b52
from typing import Dict, Any, Optional, Union
import requests
import json
def generate_hd_image(
prompt: str,
api_key: str,
model_version: str = "2.2",
num_results: int = 1,
aspect_ratio: str = "1:1",
sync: bool = True,
seed: Optional[int] = None,
negative_prompt: str = "",
steps_num: Optional[int] = None,
text_guidance_scale: Optional[float] = None,
medium: Optional[str] = None,
prompt_enhancement: bool = False,
enhance_image: bool = False,
content_moderation: bool = False,
ip_signal: bool = False
) -> Dict[str, Any]:
"""Generate HD image from prompt using Bria's text-to-image API.
Args:
prompt: The prompt to generate images from
api_key: API key for authentication
model_version: Model version to use (default: "2.2")
num_results: Number of images to generate (1-4)
aspect_ratio: Image aspect ratio ("1:1", "2:3", "3:2", etc.)
sync: Whether to wait for results or get URLs immediately
seed: Optional seed for reproducible results
negative_prompt: Elements to exclude from generation
steps_num: Number of refinement iterations (20-50)
text_guidance_scale: How closely to follow text (1-10)
medium: Generation medium ("photography" or "art")
prompt_enhancement: Whether to enhance the prompt
enhance_image: Whether to enhance image quality
content_moderation: Whether to enable content moderation
ip_signal: Whether to flag potential IP content
"""
if not prompt:
raise ValueError("Prompt is required for image generation")
# Build request data with only provided parameters
data = {
"prompt": prompt,
"num_results": max(1, min(num_results, 4)),
"sync": sync,
"negative_prompt": negative_prompt
}
# Add optional parameters only if they have valid values
if aspect_ratio:
data["aspect_ratio"] = aspect_ratio
if seed is not None:
data["seed"] = seed
if steps_num is not None:
data["steps_num"] = max(20, min(steps_num, 50))
if text_guidance_scale is not None:
data["text_guidance_scale"] = max(1.0, min(text_guidance_scale, 10.0))
if medium:
data["medium"] = medium
if prompt_enhancement:
data["prompt_enhancement"] = prompt_enhancement
if enhance_image:
data["enhance_image"] = enhance_image
if content_moderation:
data["content_moderation"] = content_moderation
if ip_signal:
data["ip_signal"] = ip_signal
url = f"https://engine.prod.bria-api.com/v1/text-to-image/hd/{model_version}"
headers = {
'api_token': api_key,
'Accept': 'application/json',
'Content-Type': 'application/json'
}
try:
print(f"Making request to: {url}")
print(f"Headers: {headers}")
response = requests.post(url, headers=headers, json=data)
response.raise_for_status()
print(f"Response status: {response.status_code}")
print(f"Response body: {response.text}")
return response.json()
except Exception as e:
raise Exception(f"HD image generation failed: {str(e)}")