> ## Documentation Index
> Fetch the complete documentation index at: https://docs.evolink.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Sora-2-Pro Generación de video

> - El modelo Sora 2 Pro (sora-2-pro-preview) admite texto a video, imagen a video y otros modos
- Modo de procesamiento asíncrono, use el ID de tarea devuelto para [consultar](/es/api-manual/task-management/get-task-detail)
- Los enlaces de video generados son válidos durante 24 horas, guárdelos de inmediato

**Nota:**
- Actualmente el mecanismo de moderación de contenido de Sora2Pro es muy estricto, las tareas pueden fallar debido a esto
- Actualmente no se admite la entrada de imágenes que contengan figuras humanas reales



## OpenAPI

````yaml es/api-manual/video-series/sora2pro/sora-2-pro-preview-video-generate.json POST /v1/videos/generations
openapi: 3.1.0
info:
  title: Interfaz sora-2-pro-preview
  description: >-
    Usar modelos de IA para crear tareas de generación de video, compatible con
    texto a video, imagen a video y otros modos de generación
  license:
    name: MIT
  version: 1.0.0
servers:
  - url: https://api.evolink.ai
    description: Entorno de producción
security:
  - bearerAuth: []
tags:
  - name: Generación de video
    description: APIs relacionadas con la generación de video por IA
paths:
  /v1/videos/generations:
    post:
      tags:
        - Generación de video
      summary: Interfaz sora-2-pro-preview
      description: >-
        - El modelo Sora 2 Pro (sora-2-pro-preview) admite texto a video, imagen
        a video y otros modos

        - Modo de procesamiento asíncrono, use el ID de tarea devuelto para
        [consultar](/es/api-manual/task-management/get-task-detail)

        - Los enlaces de video generados son válidos durante 24 horas, guárdelos
        de inmediato


        **Nota:**

        - Actualmente el mecanismo de moderación de contenido de Sora2Pro es muy
        estricto, las tareas pueden fallar debido a esto

        - Actualmente no se admite la entrada de imágenes que contengan figuras
        humanas reales
      operationId: createVideoGeneration
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/VideoGenerationRequest'
            examples:
              text_to_video:
                summary: Texto a Video
                value:
                  model: sora-2-pro-preview
                  prompt: A cat playing piano
      responses:
        '200':
          description: Tarea de generación de video creada exitosamente
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/VideoGenerationResponse'
        '400':
          description: Parámetros de solicitud inválidos
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: invalid_request
                  message: Invalid request parameters
                  type: invalid_request_error
        '401':
          description: No autenticado, token inválido o expirado
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: unauthorized
                  message: Invalid or expired token
                  type: authentication_error
        '402':
          description: Cuota insuficiente, se requiere recarga
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: insufficient_quota
                  message: Insufficient quota. Please top up your account.
                  type: insufficient_quota
        '403':
          description: Acceso denegado
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: model_access_denied
                  message: 'Token does not have access to model: sora-2-pro-preview'
                  type: invalid_request_error
        '429':
          description: Límite de velocidad excedido
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: rate_limit_exceeded
                  message: Too many requests, please try again later
                  type: rate_limit_error
        '500':
          description: Error interno del servidor
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: internal_error
                  message: Internal server error
                  type: api_error
components:
  schemas:
    VideoGenerationRequest:
      type: object
      required:
        - model
        - prompt
      properties:
        model:
          type: string
          description: Nombre del modelo de generación de video
          enum:
            - sora-2-pro-preview
          default: sora-2-pro-preview
          example: sora-2-pro-preview
        prompt:
          type: string
          description: >-
            Prompt que describe qué tipo de video generar, limitado a 5000
            tokens
          example: A cat playing piano
          maxLength: 5000
        aspect_ratio:
          type: string
          description: >-
            Relación de aspecto del video, `16:9` genera video horizontal,
            `9:16` genera video vertical
          enum:
            - '16:9'
            - '9:16'
          example: '16:9'
        duration:
          type: integer
          description: >-
            Especifica la duración del video generado (segundos)


            **Nota:**

            - Actualmente solo admite los valores `4`, `8`, `12`, representando
            respectivamente `4 segundos`, `8 segundos`, `12 segundos`

            - La facturación se basa en el valor de `duration`, mayor duración
            tiene un costo más alto
          example: 4
        quality:
          type: string
          description: |-
            Calidad de video

            **Nota:**
            - `720p`: Calidad estándar, precio estándar
            - `1080p`: Alta calidad, el multiplicador de precio es 1.667x
          enum:
            - 720p
            - 1080p
          example: 720p
        image_urls:
          type: array
          description: >-
            Lista de URLs de imágenes de referencia para la función de imagen a
            video


            **Nota:**

            - No se admiten imágenes que contengan figuras humanas reales

            - Una solicitud individual admite la cantidad de imágenes de
            entrada: `1` imagen

            - Tamaño de imagen: no más de `10MB`

            - Formatos de archivo admitidos: `.jpg`, `.jpeg`, `.png`, `.webp`

            - Las URLs de las imágenes deben ser directamente visibles por el
            servidor, o la URL de la imagen debe activar una descarga directa al
            acceder (normalmente estas URLs terminan con extensiones de archivo
            de imagen, como `.png`, `.jpg`)
          items:
            type: string
            format: uri
          maxItems: 1
          example:
            - http://example.com/image1.jpg
        callback_url:
          type: string
          description: >-
            Dirección de callback HTTPS después de completar la tarea


            **Momento del callback:**

            - Se activa cuando la tarea se completa, falla o se cancela

            - Se envía después de completar la confirmación de facturación


            **Restricciones de seguridad:**

            - Solo se admite el protocolo HTTPS

            - El callback a direcciones IP internas está prohibido (127.0.0.1,
            10.x.x.x, 172.16-31.x.x, 192.168.x.x, etc.)

            - La longitud de la URL no debe exceder `2048` caracteres


            **Mecanismo de callback:**

            - Tiempo de espera: `10` segundos

            - Máximo `3` reintentos en caso de fallo (reintentos después de `1`
            segundo/`2` segundos/`4` segundos)

            - El formato del cuerpo de respuesta del callback es consistente con
            el formato de respuesta de la API de consulta de tareas

            - La dirección de callback que devuelve un código de estado 2xx se
            considera exitosa, otros códigos de estado activarán reintentos
          format: uri
          example: https://your-domain.com/webhooks/video-task-completed
    VideoGenerationResponse:
      type: object
      properties:
        created:
          type: integer
          description: Marca de tiempo de creación de la tarea
          example: 1757169743
        id:
          type: string
          description: ID de tarea
          example: task-unified-1757169743-7cvnl5zw
        model:
          type: string
          description: Nombre del modelo real utilizado
          example: sora-2-pro-preview
        object:
          type: string
          enum:
            - video.generation.task
          description: Tipo de tarea específico
        progress:
          type: integer
          description: Porcentaje de progreso de la tarea (0-100)
          minimum: 0
          maximum: 100
          example: 0
        status:
          type: string
          description: Estado de la tarea
          enum:
            - pending
            - processing
            - completed
            - failed
          example: pending
        task_info:
          $ref: '#/components/schemas/VideoTaskInfo'
          description: Información detallada de la tarea de video
        type:
          type: string
          enum:
            - text
            - image
            - audio
            - video
          description: Tipo de salida de la tarea
          example: video
        usage:
          $ref: '#/components/schemas/VideoUsage'
          description: Información de uso y facturación
    ErrorResponse:
      type: object
      properties:
        error:
          type: object
          properties:
            code:
              type: string
              description: Identificador del código de error
            message:
              type: string
              description: Descripción del error
            type:
              type: string
              description: Tipo de error
    VideoTaskInfo:
      type: object
      properties:
        can_cancel:
          type: boolean
          description: Si la tarea puede ser cancelada
          example: true
        estimated_time:
          type: integer
          description: Tiempo estimado de finalización (segundos)
          minimum: 0
          example: 300
        video_duration:
          type: integer
          description: Duración del video (segundos)
          example: 9
    VideoUsage:
      type: object
      description: Información de uso y facturación
      properties:
        billing_rule:
          type: string
          description: Regla de facturación
          enum:
            - per_call
            - per_token
            - per_second
          example: per_second
        credits_reserved:
          type: number
          description: Créditos estimados consumidos
          minimum: 0
          example: 7
        user_group:
          type: string
          description: Categoría de grupo de usuario
          example: default
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      description: >-
        ##Todas las APIs requieren autenticación Bearer Token##


        **Obtener API Key:**


        Visita la [Página de gestión de API
        Key](https://evolink.ai/dashboard/keys) para obtener tu API Key


        **Agregar al encabezado de la solicitud:**

        ```

        Authorization: Bearer YOUR_API_KEY

        ```

````