Upscale Video

API kılavuzu ve entegrasyon referansı

API Referansı

Endpoint

POST
https://kolayzeka.com/api/models/upscale-video/generate

cURL — JSON gövdesi

curl -X POST https://kolayzeka.com/api/models/upscale-video/generate \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
  "input": {
    "upscale_factor": 2,
    "model": "Proteus",
    "video_url": "https://cdn.example.com/input.jpg"
  },
  "webhook_url": "https://your-server.com/hooks/kolayzeka"
}'

cURL — multipart/form-data

curl -X POST https://kolayzeka.com/api/models/upscale-video/generate \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -F 'input[upscale_factor]=2' \
  -F 'input[model]=Proteus' \
  -F 'input[video_url]=@/path/to/video_url.jpg' \
  -F 'webhook_url=https://your-server.com/hooks/kolayzeka'

Yanıt akışı (asenkron)

Tüm üretimler asenkrondur. POST isteği HTTP 202 + status: "queued" döner — bu yanıtta henüz sonuç yoktur. Nihai sonucu (status: "completed" + output_data) almak için GET https://kolayzeka.com/api/generations/{id} adresini sorgulayın veya bir webhook_url belirtin (webhook gövdesi bu nihai yanıtın aynısıdır).

estimated_seconds = bu modun geçmiş çalıştırmalardan hesaplanan ortalama tamamlanma süresi (saniye); kuyruğa alınırken döner, null olabilir.

1 · POST yanıtı — kuyruğa alındı (HTTP 202)

{
  "data": {
    "id": "<uuid>",
    "model": "upscale-video",
    "output_type": "video",
    "source": "api",
    "status": "queued",
    "input_data": {
      "upscale_factor": 2,
      "model": "Proteus",
      "video_url": "https://cdn.example.com/input.jpg"
    },
    "output_data": null,
    "thumbnail_url": null,
    "credit_cost": null,
    "duration": null,
    "estimated_seconds": 12,
    "error_message": null,
    "webhook_url": "https://your-server.com/hooks/kolayzeka",
    "created_at": "2026-06-29T12:00:00.000000Z",
    "updated_at": "2026-06-29T12:00:00.000000Z"
  },
  "success": true
}

2 · Nihai sonuç (başarılı) — GET https://kolayzeka.com/api/generations/{id} veya webhook

{
  "data": {
    "id": "<uuid>",
    "model": "upscale-video",
    "output_type": "video",
    "source": "api",
    "status": "completed",
    "input_data": {
      "upscale_factor": 2,
      "model": "Proteus",
      "video_url": "https://cdn.example.com/input.jpg"
    },
    "output_data": {
      "result": "https://<s3-signed-url>/output.mp4"
    },
    "thumbnail_url": "https://<s3-signed-url>/thumb.jpg",
    "credit_cost": 5,
    "duration": 4.52,
    "error_message": null,
    "webhook_url": "https://your-server.com/hooks/kolayzeka",
    "created_at": "2026-06-29T12:00:00.000000Z",
    "updated_at": "2026-06-29T12:00:05.000000Z"
  },
  "success": true
}

3 · Nihai sonuç (başarısız) — status: "failed"

{
  "data": {
    "id": "<uuid>",
    "model": "upscale-video",
    "output_type": "video",
    "source": "api",
    "status": "failed",
    "input_data": {
      "upscale_factor": 2,
      "model": "Proteus",
      "video_url": "https://cdn.example.com/input.jpg"
    },
    "output_data": null,
    "thumbnail_url": null,
    "credit_cost": 0,
    "duration": null,
    "error_message": "Sağlayıcı isteği reddetti: ...",
    "webhook_url": "https://your-server.com/hooks/kolayzeka",
    "created_at": "2026-06-29T12:00:00.000000Z",
    "updated_at": "2026-06-29T12:00:03.000000Z"
  },
  "success": true
}

İstek anında reddedilirse (4xx/5xx) API { "success": false, "error": "…" } döndürür. Krediler yalnızca başarılı bir üretimde düşülür.

Üretim kuyruğa alındıktan sonra başarısız olursa terminal yanıt status: "failed" olur; sebep error_message alanındadır (webhook event'i generation.failed).

Kimlik Doğrulama

Tüm istekler Authorization başlığında bir Sanctum kişisel erişim token'ı gerektirir.

Authorization: Bearer YOUR_TOKEN

Token oluşturmak / yenilemek için Profil ayarları'na gidin.

İstek şeması

upscale_factor
isteğe bağlı
number

Upscale FactorFactor to upscale the video by (e.g. 2.0 doubles width and height)

Varsayılan: 2

recover_detail
isteğe bağlı
string

Recover DetailRecover original detail level (0.0-1.0). Higher values preserve more original detail.

halo
isteğe bağlı
string

HaloHalo reduction level (0.0-1.0). Default varies by model.

grain
isteğe bağlı
string

GrainFilm grain amount (0.0-0.1). Default varies by model.

model
isteğe bağlı
string (enum)

ModelVideo enhancement model. Proteus is best for most videos, Artemis for denoise+sharpen, Nyx for dedicated denoising, Gaia HQ/CG for rendered content, Gaia 2 for animation and motion graphics at 2x, and Starlight for generative diffusion-based upscaling and enhancement.

İzin verilen:ProteusArtemis HQArtemis MQArtemis LQNyxNyx FastNyx XLNyx HFGaia HQGaia CGGaia 2Starlight Precise 1Starlight Precise 2Starlight Precise 2.5Starlight HQStarlight MiniStarlight SharpStarlight Fast 1Starlight Fast 2

Varsayılan: Proteus

compression
isteğe bağlı
string

CompressionCompression artifact removal level (0.0-1.0). Default varies by model.

target_fps
isteğe bağlı
string

Target FpsTarget FPS for frame interpolation. If set, frame interpolation will be enabled.

H264_output
isteğe bağlı
boolean

H264 OutputWhether to use H264 codec for output video. Default is H265.

noise
isteğe bağlı
string

NoiseNoise reduction level (0.0-1.0). Default varies by model.

video_url
zorunlu
string (URL) or file
dosya

Video UrlURL of the video to upscale

JSON gövdesinde string olarak herkese açık erişilebilir bir URL geçirin veya dosyayı multipart/form-data ile -F 'input[video_url]=@./file.jpg' kullanarak yükleyin. Kabul edilen formatlar: any binary.

Dosya girdileri

Bu model 1 dosya türünde alan bekliyor. Ya (a) dosyayı herkese açık bir yerde barındırıp URL'sini JSON içinde geçirin, ya da (b) baytları doğrudan multipart/form-data ile yükleyin.

video_url

JSON: "input": { "video_url": "https://…" }

Multipart: -F "input[video_url]=@./file"

Webhook

Üretim tamamlandığında (veya başarısız olduğunda) sunucudan sunucuya geri çağrı almak için herhangi bir isteğe bir webhook_url ekleyin. Uzun süren video üretimleri veya sürekli sorgulamadan kaçınmak için kullanışlıdır.

Uç noktanız, nihai üretim verisini içeren imzalı bir POST isteği alır.X-KolayZeka-Signature başlığını (sha256=<hex>) kullanarak özgünlüğü doğrulayın; bu değer, ham gövdeden HMAC-SHA256 ve hesabınızın Webhook Gizli Anahtarı ile hesaplanır.

Webhook Gizli Anahtarınızı nasıl alırsınız

Hesabınızın tek bir webhook imzalama gizli anahtarı vardır. Bunu Profil sayfasında oluşturup yönetin — hangi API token'ı isteği tetiklerse tetiklesin, bu tek değer adınıza gönderdiğimiz her webhook'u doğrular.

  1. Webhook imzalama gizli anahtarı kartını açın ve Oluştur'a tıklayın. Değer yalnızca bir kez gösterilir — kopyalayıp güvenli bir şekilde saklayın.
  2. Geçersiz kılmanız mı gerekiyor? Yeni bir gizli anahtar üretmek için Yenile'ye veya webhook gönderimlerini tamamen devre dışı bırakmak için İptal Et'e tıklayın. Önceki değer anında çalışmayı durdurur.

Oluşturulmuş gizli anahtarı olmayan hesaplar webhook gönderemez — biri oluşturulana kadar giden gönderimler atlanır.

Gönderilen başlıklar

X-KolayZeka-Event: generation.completed // veya generation.failed

X-KolayZeka-Signature: sha256=<hex>

User-Agent: KolayZeka-Webhook/1.0

İmza doğrulama (Node.js)

import crypto from 'node:crypto';

const expected = 'sha256=' + crypto
  .createHmac('sha256', process.env.KOLAYZEKA_WEBHOOK_SECRET)
  .update(rawBody)
  .digest('hex');

if (!crypto.timingSafeEqual(Buffer.from(expected), Buffer.from(req.headers['x-kolayzeka-signature']))) {
  return res.status(401).end();
}

Özel / loopback / bulut-meta veri URL'leri gönderim sırasında reddedilir (SSRF koruması). Gönderim, ağ hatalarında veya 2xx olmayan yanıtlarda, geri çekilmeli olarak en fazla 5 kez yeniden denenir.

Hata yönetimi

401

Yetkisiz

Bearer token eksik veya geçersiz.

402

Ödeme Gerekli

Tahmini maliyet için yetersiz kredi.

422

Doğrulama Başarısız

Girdi zorunlu alanları içermiyor veya şemaya aykırı.

400

Geçersiz İstek

Sağlayıcı veriyi reddetti. Ayrıntılar için `error` alanına bakın.

404

Bulunamadı

Model slug mevcut değil veya aktif değil.

502

Sağlayıcı Hatası

Yukarı akış AI motoru hata döndürdü. Tekrar denemek genellikle güvenlidir.