Flux Ultra Resolution

Imagens de qualidade máxima com detalhes e resolução extremos.

✓ Resolução 4K

✓ Detalhes extremos

✓ Qualidade RAW

✓ Saída profissional

Autenticação

Para acessar o Flux Ultra via API do Doitong, use sua chave de API. Inclua-a na mutação GraphQL ou nos cabeçalhos da API REST.

Importante: Mantenha sua chave de API do Doitong em segurança e nunca a exponha no código do lado do cliente. Sempre faça chamadas de API a partir do seu servidor backend.
// GraphQL Header
{
  "Authorization": "Bearer YOUR_API_KEY"
}

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

Início Rápido

Comece a usar o Flux Ultra API em poucos minutos. Siga estes passos simples para gerar seu primeiro text to image.

Passo 1: Obtenha sua Chave de API

Crie uma conta no Doitong e acesse seu painel para gerar uma chave de API.

Passo 2: Faça sua Primeira Requisição

Use um dos exemplos de código abaixo para fazer sua primeira chamada de 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"
    }
  }
}

Preços

O Flux Ultra API utiliza um modelo de preços baseado em créditos. Os créditos são consumidos de acordo com a complexidade e a duração do conteúdo gerado.

Recurso Créditos Descrição
Resolução Padrão 10-20 Créditos 512x512 a 1024x1024 pixels
Alta Resolução 30-50 Créditos 2048x2048 pixels ou superior

Endpoints da API

O Flux Ultra API está disponível através do nosso endpoint unificado de GraphQL.

Endpoint GraphQL

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

Endpoint REST

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

Parâmetros

Parâmetros disponíveis para requisições do Flux Ultra API:

Parâmetro Tipo Obrigatório Descrição
service String Yes Identificador do serviço: "flux-ultra"
prompt String Yes Descrição em texto do que será gerado
width Inteiro No Largura da imagem em pixels (padrão: 1024)
height Inteiro No Altura da imagem em pixels (padrão: 1024)
version String No Model version: "flux-pro-1.1-ultra"
webhookUrl String No URL para receber notificações de conclusão

Formato da Resposta

Todas as respostas da API seguem um formato consistente:

Resposta de Sucesso

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

Resposta Concluída

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

Tratamento de Erros

A API utiliza códigos de status HTTP padrão e retorna mensagens de erro detalhadas.

Códigos de Erro Comuns

Código de Status Tipo de Erro Descrição
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 Resposta de Erro

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

Webhooks

Receba notificações em tempo real quando a geração do seu text to image for concluída.

Configurando Webhooks

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

Payload do 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
  }
}

Segurança do Webhook

Todas as requisições de webhook incluem um cabeçalho de assinatura para verificação:

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

Limites de Taxa

Para garantir o uso justo e a estabilidade do sistema, aplicam-se os seguintes limites de taxa:

Plano Requisições/Minuto Trabalhos Simultâneos Limite Diário
Grátis 10 1 100
Starter 30 3 1,000
Pro 60 10 10,000
Enterprise Personalizado Personalizado Ilimitado
Cabeçalhos de Limite de Taxa: Verifique os cabeçalhos de resposta para o status atual do limite:
  • X-RateLimit-Limit: Maximum requests per window
  • X-RateLimit-Remaining: Requests remaining
  • X-RateLimit-Reset: Window reset timestamp

Boas Práticas

1. Otimize seus Prompts

Escreva prompts claros e descritivos para obter os melhores resultados:

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

2. Gerencie o Processamento Assíncrono

A geração é assíncrona. Implemente polling adequado ou webhooks:

// 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. Recuperação de Erros

Implemente lógica de repetição com backoff exponencial:

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. Monitore o Uso de Créditos

Acompanhe seu consumo de créditos para evitar interrupções:

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

Pronto para Começar?

Junte-se a milhares de desenvolvedores que usam o Flux Ultra API para criar conteúdos incríveis

Obter Chave de API Ver Preços