Перейти к основному содержанию
POST
/
v1
/
media
/
{id}
/
operations
Выполнить операцию над медиа
curl --request POST \
  --url https://polza.ai/api/v1/media/{id}/operations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "operation": "extend",
  "params": {
    "prompt": "Продолжение сцены",
    "seeds": 12345
  },
  "async": false
}
'
{
  "id": "gen_581761234567890123",
  "object": "media.generation",
  "status": "pending",
  "created": 1703001234,
  "model": "google/gemini-2.5-flash-image",
  "completed_at": 1703001244,
  "data": "<unknown>",
  "usage": {
    "input_units": 1,
    "output_units": 1,
    "duration_seconds": 5,
    "input_tokens": 10,
    "output_tokens": 0,
    "total_tokens": 10,
    "cost_rub": 1.5,
    "cost": 1.5
  },
  "error": {
    "code": "BAD_GATEWAY",
    "message": "Ошибка генерации медиа контента"
  },
  "content": "Банан и яблоко — это фрукты.",
  "reasoning_summary": "Preparing image generation prompt with camera settings...",
  "warnings": [
    "Параметр isEnhance не поддерживается OpenRouter и будет проигнорирован"
  ]
}

Операции над медиа

После генерации медиа контента можно выполнять дополнительные операции:
ОперацияОписаниеТип
extendПродление видеоАсинхронная
upscale_1080pУвеличение разрешения до 1080pСинхронная
upscale_4kУвеличение разрешения до 4KСинхронная

Синхронные vs Асинхронные операции

Синхронные операции (upscale)

Результат возвращается сразу в поле data:
{
  "id": "aig_abc123",
  "object": "media.generation",
  "status": "completed",
  "created": 1703001244,
  "model": "google/gemini-2.5-flash-image",
  "data": {
    "url": "https://storage.polza.ai/video_1080p.mp4"
  }
}

Асинхронные операции (extend)

Создаётся новая генерация со статусом pending:
{
  "id": "aig_xyz789",
  "object": "media.generation",
  "status": "pending",
  "created": 1703001244,
  "model": "pending"
}
Для получения результата используйте GET /v1/media/ с новым ID.

Параметр async

  • async: false (по умолчанию) — ждёт результат до 120 секунд
  • async: true — сразу возвращает ID новой генерации

Примеры

Продление видео (extend)

curl -X POST "https://polza.ai/api/v1/media/aig_abc123/operations" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "operation": "extend",
    "params": {
      "prompt": "Камера отдаляется, показывая панораму города"
    }
  }'

Увеличение разрешения (upscale)

curl -X POST "https://polza.ai/api/v1/media/aig_abc123/operations" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "operation": "upscale_1080p"
  }'

Параметры операции extend

ПараметрТипОбязательныйОписание
promptstringДаПромпт для продолжения видео
seedsnumberНетSeed для воспроизводимости
durationnumberНетДлительность продления (3-10 сек)
Операция extend создаёт новую генерацию с новым ID. Оригинальное видео не изменяется.

Авторизации

Authorization
string
header
обязательно

API ключ передаётся в заголовке: Authorization: Bearer <POLZA_AI_API_KEY>

Параметры пути

id
string
обязательно

Тело

application/json
operation
enum<string>
обязательно

ID операции

Доступные опции:
extend,
upscale_1080p,
upscale_4k
Пример:

"extend"

params
object

Параметры операции. Зависят от типа операции.

Пример:
{
"prompt": "Продолжение сцены",
"seeds": 12345
}
async
boolean
по умолчанию:false

Асинхронный режим. При true сразу возвращает ID операции, результат получить через GET /v2/media/:id

Пример:

false

Ответ

id
string
обязательно

Уникальный идентификатор генерации

Пример:

"gen_581761234567890123"

object
string
обязательно

Тип объекта

Пример:

"media.generation"

status
enum<string>
обязательно

Статус генерации

Доступные опции:
pending,
processing,
completed,
failed,
cancelled
Пример:

"pending"

created
number
обязательно

Временная метка создания (Unix timestamp)

Пример:

1703001234

model
string
обязательно

ID модели, которая генерирует контент

Пример:

"google/gemini-2.5-flash-image"

completed_at
number

Временная метка завершения (Unix timestamp)

Пример:

1703001244

data

Данные сгенерированного контента

usage
object

Информация об использовании ресурсов

error
object

Информация об ошибке (если failed)

content
string

Текстовый ответ модели (если вернула текст вместо/вместе с изображением)

Пример:

"Банан и яблоко — это фрукты."

reasoning_summary
string

Краткое резюме рассуждений модели

Пример:

"Preparing image generation prompt with camera settings..."

warnings
string[]

Предупреждения (неподдерживаемые параметры и т.д.)

Пример:
[
"Параметр isEnhance не поддерживается OpenRouter и будет проигнорирован"
]