Usa la API de RunComfy para ejecutar google/nano-banana-2/text-to-image. Para entradas y salidas admitidas, consulta el esquema.
curl --request POST \
--url https://model-api.runcomfy.net/v1/models/google/nano-banana-2/text-to-image \
--header "Content-Type: application/json" \
--header "Authorization: Bearer <token>" \
--data '{
"prompt": "A cinematic close-up portrait of an American woman standing under neon lights in rainy Tokyo, shallow depth of field, reflective wet streets, ultra-detailed, realistic skin texture"
}'Define la variable de entorno YOUR_API_TOKEN con tu clave API (gestión en Perfil) e incluye en cada solicitud un token Bearer en la cabecera Authorization : Authorization: Bearer $YOUR_API_TOKEN.
Envía un trabajo de generación asíncrono y recibe de inmediato un request_id y URLs para consultar estado, obtener resultados y cancelar.
curl --request POST \
--url https://model-api.runcomfy.net/v1/models/google/nano-banana-2/text-to-image \
--header "Content-Type: application/json" \
--header "Authorization: Bearer <token>" \
--data '{
"prompt": "A cinematic close-up portrait of an American woman standing under neon lights in rainy Tokyo, shallow depth of field, reflective wet streets, ultra-detailed, realistic skin texture"
}'Obtiene el estado actual de un request_id ("in_queue", "in_progress", "completed" o "cancelled").
curl --request GET \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/status \
--header "Authorization: Bearer <token>"Obtiene las salidas finales y metadatos del request_id; si el trabajo no ha terminado, la respuesta devuelve el estado actual para seguir haciendo polling.
curl --request GET \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/result \
--header "Authorization: Bearer <token>"Cancela un trabajo en cola por request_id; los trabajos en curso no se pueden cancelar.
curl --request POST \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/cancel \
--header "Authorization: Bearer <token>"Proporciona una URL HTTPS públicamente accesible. El host debe permitir peticiones del servidor (sin login/cookies), sin rate limit agresivo ni bloqueo de bots. Recomendado: imágenes ≤ 50 MB (~4K), vídeos ≤ 100 MB (~2–5 min a 720p). Para activos privados, URLs estables o firmadas.
{
"type": "object",
"title": "Esquema de entrada",
"required": [
"prompt"
],
"properties": {
"prompt": {
"title": "Prompt",
"description": "El prompt para la generación de imágenes.",
"type": "string",
"default": "A cinematic close-up portrait of an American woman standing under neon lights in rainy Tokyo, shallow depth of field, reflective wet streets, ultra-detailed, realistic skin texture"
},
"num_images": {
"title": "Número de imágenes",
"description": "La cantidad de imágenes a generar.",
"type": "integer",
"default": 1,
"minimum": 1,
"maximum": 4
},
"seed": {
"title": "Seed",
"description": "La semilla del generador de números aleatorios.",
"type": "integer",
"default": 0
},
"aspect_ratio": {
"title": "Relación de aspecto (A:H)",
"description": "La relación de aspecto de la imagen generada.",
"type": "string",
"enum": [
"auto",
"21:9",
"16:9",
"3:2",
"4:3",
"5:4",
"1:1",
"4:5",
"3:4",
"2:3",
"9:16"
],
"default": "auto"
},
"resolution": {
"title": "Resolución",
"description": "La resolución de la imagen a generar.",
"type": "string",
"enum": [
"0.5K",
"1K",
"2K",
"4K"
],
"default": "1K"
},
"output_format": {
"title": "Formato de salida",
"description": "El formato de la imagen generada.",
"type": "string",
"enum": [
"jpeg",
"png",
"webp"
],
"default": "png"
},
"safety_tolerance": {
"title": "Tolerancia de seguridad",
"description": "El nivel de tolerancia de seguridad para moderación de contenido. 1 es el más estricto y 6 el menos estricto.",
"type": "integer",
"enum": [
1,
2,
3,
4,
5,
6
],
"default": 4
},
"limit_generations": {
"title": "Limitar generaciones",
"description": "Si es true, limita cada ronda de prompts a una sola generación.",
"type": "boolean",
"default": true
},
"enable_web_search": {
"title": "Habilitar búsqueda web",
"description": "Habilita la búsqueda web para usar información reciente en la generación.",
"type": "boolean",
"default": false
}
}
}{
"output": {
"type": "object",
"properties": {
"image": {
"type": "string",
"format": "uri",
"description": "URL de una sola imagen"
},
"video": {
"type": "string",
"format": "uri",
"description": "URL de un solo vídeo"
},
"images": {
"type": "array",
"description": "varias URLs de imagen",
"items": {
"type": "string",
"format": "uri"
}
},
"videos": {
"type": "array",
"description": "varias URLs de vídeo",
"items": {
"type": "string",
"format": "uri"
}
}
}
}
}RunComfy es la principal ComfyUI plataforma, ofreciendo ComfyUI en línea entorno y servicios, junto con flujos de trabajo de ComfyUI con impresionantes imágenes. RunComfy también ofrece AI Models, permitiendo a los artistas aprovechar las últimas herramientas de AI para crear arte increíble.