File size: 3,277 Bytes
0362b52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
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)}")