Flux Ultra Resolución

Imágenes de máxima calidad con detalle y resolución extremos.

✓ Resolución 4K

✓ Detalle extremo

✓ Calidad RAW

✓ Resultado profesional

Autenticación

Para acceder a Flux Ultra a través de la API de Doitong, usa tu clave de API de Doitong. Inclúyela en la mutación de GraphQL o en los encabezados de la API REST.

Importante: Mantén tu clave de API de Doitong segura y nunca la expongas en código del lado del cliente. Realiza siempre las llamadas a la API desde tu servidor backend.
// GraphQL Header
{
  "Authorization": "Bearer YOUR_API_KEY"
}

// REST Header
"X-API-Key": "YOUR_API_KEY"

Inicio rápido

Comienza con Flux Ultra API en solo unos minutos. Sigue estos sencillos pasos para generar tu primer text to image.

Paso 1: Obtén tu clave de API

Regístrate en Doitong y ve a tu panel de control para generar una clave de API.

Paso 2: Realiza tu primera solicitud

Usa uno de los siguientes ejemplos de código para realizar tu primera llamada a la API.

curl -X POST https://api.doitong.com/graphql \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -d '{
    "query": "mutation Generate($input: GenerateInput!) { generate(input: $input) { id status type provider url metadata creditCost } }",
    "variables": {
      "input": {
        "type": "IMAGE",
        "provider": "flux-ultra",
        "input": {
          "text": "A futuristic city with flying cars and neon lights"
        },
        "options": {
          "width": 1024,
          "height": 1024
        }
      }
    }
  }'
const response = await fetch('https://api.doitong.com/graphql', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'Authorization': 'Bearer YOUR_API_KEY'
  },
  body: JSON.stringify({
    query: `
      mutation GenerateImage($input: ImageGenerationInput!) {
        generateImage(input: $input) {
          id
          url
          width
          height
        }
      }
    `,
    variables: {
      input: {
        service: 'flux-ultra',
        prompt: 'A futuristic city with flying cars and neon lights',
        width: 1024,
        height: 1024
      }
    }
  })
});

const data = await response.json();
console.log('Image:', data.data.generateImage);
import requests
import json

url = "https://api.doitong.com/graphql"
headers = {
    "Content-Type": "application/json",
    "Authorization": "Bearer YOUR_API_KEY"
}

query = """
mutation Generate($input: GenerateInput!) {
  generate(input: $input) {
    id
    status
    type
    provider
    url
    metadata
    creditCost
  }
}
"""

variables = {
    "input": {
        "type": "IMAGE",
        "provider": "flux-ultra",
        "input": {
            "text": "A futuristic city with flying cars and neon lights"
        },
        "options": {
            "width": 1024,
            "height": 1024
        }
    }
}

response = requests.post(url, json={
    "query": query,
    "variables": variables
}, headers=headers)

data = response.json()
print("Result:", data["data"]["generate"])
mutation Generate($input: GenerateInput!) {
  generate(input: $input) {
    id
    status
    type
    provider
    url
    metadata
    creditCost
    createdAt
  }
}

# Variables
{
  "input": {
    "type": "IMAGE",
    "provider": "flux-ultra",
    "input": {
      "text": "A futuristic city with flying cars and neon lights"
    },
    "options": {
      "width": 1024,
      "height": 1024,
      "version": "flux-pro-1.1-ultra",
      "quality": "high"
    }
  }
}

Precios

Flux Ultra API utiliza un modelo de precios basado en créditos. Los créditos se consumen según la complejidad y duración del contenido generado.

Función Créditos Descripción
Resolución estándar 10-20 Créditos 512x512 a 1024x1024 píxeles
Alta resolución 30-50 Créditos 2048x2048 píxeles o superior

Endpoints de la API

Flux Ultra API está disponible a través de nuestro endpoint unificado de GraphQL.

Endpoint de GraphQL

POST https://api.doitong.com/graphql

Endpoint de REST

POST https://api.doitong.com/v1/text_to_image

Parámetros

Parámetros disponibles para las solicitudes de Flux Ultra API:

Parámetro Tipo Requerido Descripción
service String Yes Identificador del servicio: "flux-ultra"
prompt String Yes Descripción en texto de lo que se desea generar
width Integer No Ancho de la imagen en píxeles (por defecto: 1024)
height Integer No Alto de la imagen en píxeles (por defecto: 1024)
version String No Model version: "flux-pro-1.1-ultra"
webhookUrl String No URL para recibir notificaciones de finalización

Formato de respuesta

Todas las respuestas de la API siguen un formato consistente:

Respuesta exitosa

{
  "data": {
    "generateimage": {
      "id": "abc123xyz",
      "status": "processing",
      "url": null,
      "webhookUrl": "https://your-webhook.com/callback",
      "createdAt": "2024-01-01T00:00:00Z"
    }
  }
}

Respuesta completada

{
  "data": {
    "generateimage": {
      "id": "abc123xyz",
      "status": "completed",
      "url": "https://cdn.doitong.com/outputs/abc123xyz.jpg",
      "duration": null,
      "createdAt": "2024-01-01T00:00:00Z"
    }
  }
}

Manejo de errores

La API utiliza códigos de estado HTTP estándar y devuelve mensajes de error detallados.

Códigos de error comunes

Código de estado Tipo de error Descripción
400 Bad Request Invalid parameters or malformed request
401 Unauthorized Missing or invalid API key
402 Payment Required Insufficient credits
429 Too Many Requests Rate limit exceeded
500 Internal Server Error Server error, please retry

Formato de respuesta de error

{
  "errors": [
    {
      "message": "Insufficient credits for this operation",
      "extensions": {
        "code": "INSUFFICIENT_CREDITS",
        "creditsRequired": 100,
        "creditsAvailable": 50
      }
    }
  ]
}

Webhooks

Recibe notificaciones en tiempo real cuando la generación de tu text to image haya finalizado.

Configuración de Webhooks

Include a <code>webhookUrl</code> parameter in your request to receive a POST notification when processing is complete.

Payload del Webhook

{
  "id": "abc123xyz",
  "status": "completed",
  "url": "https://cdn.doitong.com/outputs/abc123xyz.jpg",
  "service": "flux-ultra",
  "createdAt": "2024-01-01T00:00:00Z",
  "completedAt": "2024-01-01T00:01:00Z",
  "metadata": {
    "duration": null,
    "width": 1920,
    "height": 1080
  }
}

Seguridad del Webhook

Todas las solicitudes de webhook incluyen un encabezado de firma para su verificación:

X-Doitong-Signature: sha256=abc123...

Límites de uso

Para garantizar un uso justo y la estabilidad del sistema, se aplican los siguientes límites de solicitudes:

Plan Solicitudes/Minuto Tareas simultáneas Límite diario
Gratis 10 1 100
Starter 30 3 1,000
Pro 60 10 10,000
Enterprise Personalizado Personalizado Ilimitado
Encabezados de límite de uso: Consulta los encabezados de respuesta para conocer el estado actual de tus límites:
  • X-RateLimit-Limit: Maximum requests per window
  • X-RateLimit-Remaining: Requests remaining
  • X-RateLimit-Reset: Window reset timestamp

Mejores prácticas

1. Optimiza tus prompts

Escribe prompts claros y descriptivos para obtener los mejores resultados:

  • Be specific about visual elements, style, and mood
  • Include details about lighting, camera angles, and composition
  • Avoid contradictory or impossible requests

2. Maneja el procesamiento asíncrono

La generación es asíncrona. Implementa un sistema de sondeo (polling) o webhooks adecuado:

// Polling example
async function pollStatus(jobId) {
  let status = 'processing';
  while (status === 'processing') {
    await sleep(2000); // Wait 2 seconds
    const result = await checkJobStatus(jobId);
    status = result.status;
  }
  return result;
}

3. Recuperación de errores

Implementa lógica de reintento con retroceso exponencial (exponential backoff):

async function retryWithBackoff(fn, maxRetries = 3) {
  for (let i = 0; i < maxRetries; i++) {
    try {
      return await fn();
    } catch (error) {
      if (i === maxRetries - 1) throw error;
      await sleep(Math.pow(2, i) * 1000);
    }
  }
}

4. Monitorea el uso de créditos

Rastrea tu consumo de créditos para evitar interrupciones en el servicio:

  • Check credit balance before large batch operations
  • Set up alerts for low credit thresholds
  • Implement credit-aware request queuing

¿Todo listo para empezar?

Únete a miles de desarrolladores que usan Flux Ultra API para crear contenido increíble

Obtener clave de API Ver precios