Langsung ke konten utama
POST
/
v1
/
images
/
generations
curl --request POST \
  --url https://api.apimart.ai/v1/images/generations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "model": "gpt-image-2",
    "prompt": "A ginger cat sitting on a windowsill watching the sunset, watercolor style",
    "n": 1,
    "size": "16:9",
    "resolution": "2k"
  }'
{
  "code": 200,
  "data": [
    {
      "status": "submitted",
      "task_id": "task_01KPQ7J7DWB7QZ3WCEK3YVPBRA"
    }
  ]
}

Documentation Index

Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt

Use this file to discover all available pages before exploring further.

curl --request POST \
  --url https://api.apimart.ai/v1/images/generations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "model": "gpt-image-2",
    "prompt": "A ginger cat sitting on a windowsill watching the sunset, watercolor style",
    "n": 1,
    "size": "16:9",
    "resolution": "2k"
  }'
{
  "code": 200,
  "data": [
    {
      "status": "submitted",
      "task_id": "task_01KPQ7J7DWB7QZ3WCEK3YVPBRA"
    }
  ]
}

Otorisasi

Authorization
string
wajib
Semua endpoint memerlukan autentikasi Bearer TokenDapatkan API Key Anda:Kunjungi halaman manajemen API Key untuk mendapatkan API Key AndaSertakan di header permintaan:
Authorization: Bearer YOUR_API_KEY

Body

model
string
default:"gpt-image-2"
wajib
Nama model pembuatan gambarTetap sebagai gpt-image-2
prompt
string
wajib
Deskripsi teks untuk pembuatan gambar
  • Mendukung bahasa Inggris dan Mandarin; deskripsi yang terperinci direkomendasikan
  • Moderasi konten / tinjauan keamanan sebelum pengiriman — pelanggaran langsung ditolak
n
integer
default:"1"
Jumlah gambar yang akan dibuatRentang: 1
Harus berupa angka murni (misalnya 1), jangan bungkus dengan tanda kutip
size
string
default:"1:1"
Rasio aspek gambarRasio yang didukung, ditambah auto agar server memilih rasio yang sesuai secara otomatis:
sizeType
autoAutomatic
1:1Persegi
3:2Lanskap
2:3Potret
4:3Lanskap
3:4Potret
5:4Lanskap
4:5Potret
16:9Lanskap
9:16Potret
2:1Lanskap
1:2Potret
3:1Lanskap
1:3Potret
21:9Lanskap
9:21Potret
Dimensi piksel juga dapat diteruskan langsung, seperti 1881x836 / 887x1774.
Saat size diatur ke auto, rasio default adalah 1:1.
resolution
string
default:"1k"
Tier resolusi outputOptions: 1k / 2k / 4ksize × resolution → pemetaan piksel aktual:
size1k2k4k
1:11024×1024 / 1254×12542048×20482880×2880
3:21536×10242048×13603520×2336
2:31024×15361360×20482336×3520
4:31024×7682048×15363312×2480
3:4768×10241536×20482480×3312
5:41280×1024 / 1448×10862560×20483216×2576
4:51024×1280 / 1122×14022048×25602576×3216
16:91536×864 / 1672×9412048×11523840×2160
9:16864×1536 / 941×16721152×20482160×3840
2:12048×1024 / 1774×8872688×13443840×1920
1:21024×2048 / 887×17741344×26881920×3840
3:11881×836 / 1536×5123072×10243840×1280
1:3887×1774 / 512×15361024×30721280×3840
21:92016×864 / 1915×8212688×11523840×1648
9:21864×2016 / 821×19151152×26881648×3840
4K mendukung 15 rasio yang tercantum di atas; Anda juga dapat meneruskan dimensi piksel dari tabel langsung melalui size.
image_urls
array
Array gambar referensi (bidang standar OpenAI). Beralih ke mode image-to-image saat disediakan.
Bidang standar OpenAI lainnya (response_format, quality, style) tidak didukung dan akan diabaikan. Hasil tugas hanya mengembalikan url — unduh dan konversi sendiri ke base64 jika diperlukan.
official_fallback
boolean
default:"false"
Apakah akan fallback ke kanal resmi
  • false: Jangan gunakan (default)
  • true: Gunakan kanal resmi

Contoh Penggunaan

Text-to-image (permintaan minimal)
{
  "model": "gpt-image-2",
  "prompt": "A ginger cat sitting on a windowsill watching the sunset, watercolor style"
}
Text-to-image (dengan rasio + 2K)
{
  "model": "gpt-image-2",
  "prompt": "a corgi astronaut on the moon, cinematic, 8k",
  "size": "16:9",
  "resolution": "2k"
}
Text-to-image (output 4K)
{
  "model": "gpt-image-2",
  "prompt": "An ancient castle under a starry sky",
  "size": "16:9",
  "resolution": "4k"
}
Image-to-image (referensi = URL)
{
  "model": "gpt-image-2",
  "prompt": "Turn this photo into a watercolor painting",
  "image_urls": [
    "https://example.com/photo.jpg"
  ]
}
Image-to-image (referensi = base64)
{
  "model": "gpt-image-2",
  "prompt": "Turn this photo into a watercolor painting",
  "image_urls": [
    "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
  ]
}
Image-to-image (fusi multi-referensi, URL + base64 campuran)
{
  "model": "gpt-image-2",
  "prompt": "Fuse these two photos into a single poster",
  "size": "4:3",
  "resolution": "2k",
  "image_urls": [
    "https://example.com/photo-a.jpg",
    "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA..."
  ]
}

Respons

code
integer
Kode status respons
data
array
Array data respons

Mengueri Hasil Tugas

Setelah pengiriman berhasil, task_id dikembalikan. Polling status tugas melalui GET /v1/tasks/{task_id}; lihat API Kueri Tugas untuk detail.

Contoh Respons Berhasil

{
  "code": 200,
  "data": {
    "id": "task_01KPQ7J7DWB7QZ3WCEK3YVPBRA",
    "status": "completed",
    "progress": 100,
    "created": 1776748674,
    "completed": 1776748726,
    "actual_time": 52,
    "cost": 0.05279,
    "estimated_time": 100,
    "result": {
      "images": [
        {
          "url": [
            "https://upload.apimart.ai/f/image/xxxxxxxx-gpt_image_2_task_xxx_0.png"
          ],
          "expires_at": 1776835126
        }
      ]
    }
  }
}
Akses gambar: data.result.images[0].url[0]

Task Status

StatusMeaning
submittedDikirim
processingSedang diproses upstream
completedBerhasil, result.images tersedia
failedGagal, periksa error.message

Rekomendasi Polling

  • Jeda kueri awal: Tunggu 10~20 detik setelah pengiriman sebelum kueri pertama
  • Interval kueri: 3~5 detik direkomendasikan, avoid millisecond-level polling
  • Referensi timeout: A single image typically completes in 3060 seconds (observed actual_time 4453s)
  • Kueri batch: Untuk mengueri beberapa tugas sekaligus, gunakan POST /v1/tasks/batch dengan body {"task_ids": ["task_xxx", "task_yyy"]}

Catatan

  1. Pemrosesan asinkron: Pengiriman mengembalikan task_id; polling /v1/tasks/{task_id} untuk mendapatkan URL gambar akhir
  2. Moderasi konten: prompt ditinjau terlebih dahulu — pelanggaran ditolak tanpa penagihan
  3. URL hasil: Platform mencerminkan tautan bertanda tangan sementara dari upstream ke penyimpanan objek R2 miliknya sendiri, lalu mengembalikan tautan stabil yang dapat diakses langsung oleh klien
  4. Validitas URL: expires_at = completed + 24h dalam respons adalah bidang petunjuk; segera unduh atau mirror ke CDN Anda sendiri
  5. Konflik rasio: Gunakan bidang size untuk rasio aspek — hindari mengulanginya di prompt untuk mencegah ambiguitas upstream
  6. Penagihan: Ditagih berdasarkan tier resolusi (1K / 2K / 4K), no charge on failure atau moderation rejection
  7. Rasio 4K yang didukung: Semua 15 rasio di atas mendukung 4K; Anda juga dapat meneruskan dimensi piksel yang sesuai langsung melalui size
  8. Retensi tugas: task_id disimpan dalam database selama beberapa hari secara default (dikonfigurasi oleh TASK_RETENTION_DAYS) — kueri yang kedaluwarsa mengembalikan “task does not exist or has expired”